The Airtable Community will undergo scheduled maintenance on September 17 from 10:00 PM PST to 11:15 PM PST. During this period, you may experience temporary disruptions. We apologize for any inconvenience and appreciate your understanding.
Dec 16, 2020 09:56 AM
Hi,
Could someone demo this script showing how to properly create the parent/child and template tabs to utilize this script?
I am having difficulty getting it to properly work.
Thanks.
May 04, 2021 01:04 AM
Taylor, it worked perfectly! You’ve been a lifesaver again!
May 04, 2021 01:11 AM
Hi, for convenience I’m resharing the scripts that Taylor gave, with some small modifications I made to match all the fields properly. My use case and details of the table are here: New Script for multiple templates - Development and integrations / Scripting app - Airtable Communit...
For scripting app
// Get a hold of your projects table.
const projectsTable = base.getTable("Projects");
// Let the user pick a record from the Projects table to generate tasks
let projectRecord = await input.recordAsync("Select a Project to generate Tasks", projectsTable)
// Get the values from the Videos and Images fields for that record
const numVideos = projectRecord.getCellValue("Videos")
const numImages = projectRecord.getCellValue("Images")
if (numVideos == null || numImages == null) {
throw new Error("Make sure you input a number for the number of Images and Videos required!")
}
// Get a hold of your tasks table.
const tasksTable = base.getTable("Tasks")
// Create all of the Images tasks in the tasks table
for (let i = 1; i <= numImages; i++) {
await tasksTable.createRecordAsync({
"Task Name": `Images ${i}`, // This will generate names like "Images 1", "Images 2", etc.
"Task Type": {name: "Images"}, // Since this is a single select field, you set it by passing an object with "Name" equal to the tag you want
"Project": [{id: projectRecord.id}], // Since we're setting a linked record field here, we need to pass an array of objets, with the "id" key set to the id of the record we want to link to.
"Status": {name: "Open"}
})
}
// Create all of the video tasks in the tasks table
for (let i = 1; i <= numVideos; i++) {
await tasksTable.createRecordAsync({
"Task Name": `Videos ${i}`, // This will generate names like "Videos 1", "Videos 2", etc.
"Task Type": {name: "Videos"}, // Since this is a single select field, you set it by passing an object with "Name" equal to the tag you want
"Project": [{id: projectRecord.id}], // Since we're setting a linked record field here, we need to pass an array of objets, with the "id" key set to the id of the record we want to link to.
"Status": {name: "Open"}
})
}
For automation:
// Get a hold of your projects table.
const projectsTable = base.getTable("Projects");
// Get a hold of your tasks table.
const tasksTable = base.getTable("Tasks")
const projectRecordsQuery = await projectsTable.selectRecordsAsync();
const allProjectRecords = projectRecordsQuery.records;
// Iterate over all project records in the base.
Promise.all(allProjectRecords.map(async (projectRecord) => {
// Get the values from the Videos and Images fields for that record
const numVideos = projectRecord.getCellValue("Videos")
const numImages = projectRecord.getCellValue("Images")
if (numVideos == null || numImages == null) {
throw new Error("Make sure you input a number for the number of Images and Videos required!")
}
// Create all of the video tasks in the tasks table
for (let i = 1; i <= numVideos; i++) {
await tasksTable.createRecordAsync({
"Task Name": `Videos ${i}`, // This will generate names like "Videos 1", "Videos 2", etc.
"Task Type": {name: "Videos"}, // Since this is a single select field, you set it by passing an object with "Name" equal to the tag you want
"Project": [{id: projectRecord.id}], // Since we're setting a linked record field here, we need to pass an array of objets, with the "id" key set to the id of the record we want to link to.
"Status": {name: "Open"}
})
}
// Create all of the Images tasks in the tasks table
for (let i = 1; i <= numImages; i++) {
await tasksTable.createRecordAsync({
"Task Name": `Images ${i}`, // This will generate names like "Images 1", "Images 2", etc.
"Task Type": {name: "Images"}, // Since this is a single select field, you set it by passing an object with "Name" equal to the tag you want
"Project": [{id: projectRecord.id}], // Since we're setting a linked record field here, we need to pass an array of objets, with the "id" key set to the id of the record we want to link to.
"Status": {name: "Open"}
})
}
}))
Sep 20, 2021 12:15 AM
Hi @Taylor_Savage , I have read through this thread in detail and have a working Script for Creating records for multiple templates. However, I am having trouble adding an additional field to the script.
I have followed the instructions in the script, and done a number of trial and errors, but I’m stuck hoping that you or someone may be able to help.
The field I am trying to add is ‘category’, which is effectively the text field name of the Type table (Template Type). I am trying to add that to the Child table.
I have adjusted the table names for the purposes of these screenshots:
In the Parent table, the ‘category’ field is a linked record to Type Table. A second part to my question is that the use case requires multiple ‘categories’ (Template Types) to be selected here, prior to clicking the orange button. At the moment we can only select one at a time.
In the Child table, I tried both text and single select fields. Because the error I was getting says 'invalid cell value, that the must be a string.
In the Template Table, the ‘category’ field is a linked record to Type Table. But I also tried with a lookup to try and use a string rather than linked record. Neither seemed to work?
The following is what I added to the Script to try and add the category field.
From line 87:
let types = typesRecords.map(c => ({
'child': [c],
'childName': c.getCellValue(childFieldInTemplate),
'templateTypes': c.getCellValue(templateType).map(x => x.id),
'templateOrder': c.getCellValue(templateOrder),
'category': c.getCellValue('category')
// Add additional template fields here and in section below using format below.
// Field names within c.getCellValue parentheticals should match field names in template table
// 'templatePhase':c.getCellValue('Phase'),
// 'templateDays': c.getCellValue('Days')
})).filter(x => x.templateTypes.includes(parentType[0].id))
from line 100
let createRecords = types.map(c => ({
fields: {
[childNameInChild.name]: c.childName,
[parentFieldInChild.name]: [selectedEvent],
[childOrder.name]: c.templateOrder,
['category']: c.category
I tried adding the following to the script from line 71 but that didn’t work either:
let category = settings.category;
Can you see where the problem is? Or how to adjust the script to solve for this?
Would really appreciate any guidance you can provide.
Many thanks,
Jazmin
Dec 21, 2021 08:01 PM
@Taylor_Savage is there a follow on video from the ‘walkthrough video’ linked above to show how to copy across more fields from the template table to the child table? I’m having trouble with this, primarily because in my template table (the one that corresponds to your Tasks Template in your video) is has multiple linked records/template types.
Dec 28, 2021 10:07 PM
@Taylor_Savage Can the script posted here on Feb 19 be revised to include an option for a Single Select field? I’m running into an issue copying the Single Select field from my Template Table onto the Child Table.
Mar 16, 2022 03:22 PM
Hitting this error…can anyone help? I used the Scripting app for it.
Apr 20, 2022 09:23 AM
Please reshare the link to the walkthrough video. Thanks!
May 06, 2022 10:00 AM
Hello there. Is it possible for us to get access on the walkthrough video regarding this script? Thank you.
Mar 20, 2023 03:37 AM
For those of you (like me) that really wanted to better understand this script but was bummed that the video link was dead... hopefully this helps.