Help

Save the date! Join us on October 16 for our Product Ops launch event. Register here.

Re: Convert the triggered record (multiple linked records) from an automation in one row

Solved
Jump to Solution
2031 0
cancel
Showing results for 
Search instead for 
Did you mean: 
francoislvr
5 - Automation Enthusiast
5 - Automation Enthusiast

Hi everyone, 

I've two tables with two type of granularity, for instance Table Name and Table Sport, and I would like to create a table with one line equal one name and one sport. I show you this juste below, for the moment I have 

In my first table one record = one name  

Name 1  - Tennis Rugby Football

Name 2 - Football 

In my second one record = one sport 

Tennis - Name 1

Rugby - Name 1 

Football - Name 1 Name 2 

I would like to create a third table NameSport where one record = one name and one sport like this : 

Tennis - Name 1 

Rugby - Name 1 

Football - Name 1 

Football - Name 2 

I created an automation, when a new record enter a view in the table name, it runs a script, to create in the third table the good granularity. I inspire myself from this community message but it takes the all table and I would like only the triggered record. I created an input variable with the record id, but it's still inserting me in my third table the number of record of the source table with each time the good automation triggered record. Here's my script : 

 

 

const sourcetable = base.getTable('Name');
const desttable = base.getTable('NameSport');
const config = input.config();
const recordId = config.recordId
const query=await sourcetable.selectRecordsAsync({fields:['name','sport']});
const record = query.getRecord(recordId)
const converse=rec=>record.getCellValue('sport').map(x=>[record.getCellValue('name'),{id:x.id}])
const create=(el)=>({fields:{'name':el[0], 'sport':[el[1]]}})
const crt=query.records.flatMap(converse).map(create)
while (crt.length) await desttable.createRecordsAsync(crt.splice(0,50))

 

 
Any help will be much appreciated ! 
 
Thanks a lot, 
 
François 

 

1 Solution

Accepted Solutions
TheTimeSavingCo
18 - Pluto
18 - Pluto

If you're okay with a non-scripting option, you can do this with a repeating groups automation instead

Best of luck with the code either way

See Solution in Thread

2 Replies 2
TheTimeSavingCo
18 - Pluto
18 - Pluto

If you're okay with a non-scripting option, you can do this with a repeating groups automation instead

Best of luck with the code either way

Wow thanks a lot it's much more easier like this !