data:image/s3,"s3://crabby-images/fe8b1/fe8b1eff6ff6393f18bec2b7372d682c6b7fa357" alt="darth_flitcraft darth_flitcraft"
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Jun 06, 2022 10:13 AM
Hello Community!
I have the below script that will create X number of records based on the Episode Count, but I would like to tweak it to auto-number those episodes each time. For instance, Show 1 has 5 episodes, then each episode record would be numbered 1, 2, 3, 4, 5
//Tables
let projects = base.getTable('Shows');
let episodes = base.getTable('Episodes');
//Record Input
let record = await input.recordAsync('Please select a project', projects);
//Record variables
let quantity = record.getCellValue('Ep Count');
let order = record.id;
//New record array
let recArray = [];
//Iterate by quantity
if(quantity > 1){
for(let i=0; i < quantity; i++){
//Push to the array
recArray.push({
fields: {
'Shows': [{id: order}],
}
});
}
//Create new records
await episodes.createRecordsAsync(recArray);
}
Any insight would be so incredible appreciated :pray: Thank you!
Solved! Go to Solution.
Accepted Solutions
data:image/s3,"s3://crabby-images/addae/addae48351e2c8e059d4d74140ca3d86b5c4685d" alt="Kamille_Parks Kamille_Parks"
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Jun 06, 2022 10:24 AM
Sounds like your Episodes table should have a Number field.
recArray.push({
fields: {
'Shows': [{id: order}],
'Episode Number': i + 1
}
});
its i + 1
and not just i
because your loop starts i
at zero, and I’m assuming you don’t want “Episode 0” to be a result.
Also FYI your script will throw an error if you ever try creating more than 50 episodes at once.
data:image/s3,"s3://crabby-images/addae/addae48351e2c8e059d4d74140ca3d86b5c4685d" alt="Kamille_Parks Kamille_Parks"
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Jun 06, 2022 10:24 AM
Sounds like your Episodes table should have a Number field.
recArray.push({
fields: {
'Shows': [{id: order}],
'Episode Number': i + 1
}
});
its i + 1
and not just i
because your loop starts i
at zero, and I’m assuming you don’t want “Episode 0” to be a result.
Also FYI your script will throw an error if you ever try creating more than 50 episodes at once.
data:image/s3,"s3://crabby-images/fe8b1/fe8b1eff6ff6393f18bec2b7372d682c6b7fa357" alt="darth_flitcraft darth_flitcraft"
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Jun 06, 2022 11:04 AM
Kamille - you are amazing!
This worked perfectly. Thank you so much for the assist here!
data:image/s3,"s3://crabby-images/fd698/fd698713d0baac0a63656a05635b6caad01a7886" alt=""