data:image/s3,"s3://crabby-images/15584/155840147059e663cc37bd2241bd39068c195089" alt="aaron_altamura aaron_altamura"
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
‎Jun 21, 2023 06:36 PM - edited ‎Jun 21, 2023 06:58 PM
Hello,
I'm trying to:
- Insert a variable to a script; | Complete
- Filter a view by this variable compared to a field (fldL0YbZsYuNJJwTP); | Partially Incomplete
- Return a running total from that subset of a view; | Partially complete
Right now I'm getting 0, so I suspect my filter is off.
Here's the code I've been able to cobble together:
// change these names to pick a view:
let inputConfig = input.config();
const table = base.getTable('Deals');
const view = table.getView('Pipeline Stages 2-4');
const checkedRecords = await view.selectRecordsAsync({fields: [
'Amount',
'fldL0YbZsYuNJJwTP'
]})
.then(queryResult => {
return queryResult.records.filter(record => {
record.getCellValue('fldL0YbZsYuNJJwTP') === inputConfig.Individual;
})
});
let runningTotal = 0;
for (let record of checkedRecords) {
// change the field names here to adapt this script to your base
runningTotal += record.getCellValue('Amount');
}
return runningTotal
And here's a screenshot of the automation step:
Any feedback or support is appreciated, thank you so much!
data:image/s3,"s3://crabby-images/ce5f4/ce5f4e76416b36b869ecc73c578cdaf474beaefd" alt="Stephen_Orr1 Stephen_Orr1"
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
‎Jun 21, 2023 07:13 PM
inputConfig.Individual is returning a record ID string. Is the value of fldL0YbZsYuNJJwTP also expected to be a record ID string?
Try inserting
output.set('checkedRecords', checkedRecords)
right before your for loop to see what checkedRecords contains. I'm guessing it's empty.
data:image/s3,"s3://crabby-images/15584/155840147059e663cc37bd2241bd39068c195089" alt="aaron_altamura aaron_altamura"
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
‎Jun 22, 2023 02:24 PM
Hi Stephen, appreciate the support!
The output is showing an empty set:
data:image/s3,"s3://crabby-images/ce5f4/ce5f4e76416b36b869ecc73c578cdaf474beaefd" alt="Stephen_Orr1 Stephen_Orr1"
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
‎Jun 22, 2023 02:37 PM
So does your field fldL0YbZsYuNJJwTP contain record IDs or some other value? It sounds like the filter here
queryResult.records.filter(record => { record.getCellValue('fldL0YbZsYuNJJwTP') === inputConfig.Individual; })
is removing everything because the value of fldL0YbZsYuNJJwTP is not a record ID or you don't have a record where this field contains the exact record ID that you're filtering on. What does this field look like in your table?
data:image/s3,"s3://crabby-images/15584/155840147059e663cc37bd2241bd39068c195089" alt="aaron_altamura aaron_altamura"
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
‎Jun 22, 2023 03:00 PM
It contains the string in an array, per the documentation:
data:image/s3,"s3://crabby-images/ce5f4/ce5f4e76416b36b869ecc73c578cdaf474beaefd" alt="Stephen_Orr1 Stephen_Orr1"
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
‎Jun 22, 2023 03:54 PM - edited ‎Jun 22, 2023 06:27 PM
Try this
return queryResult.records.filter(record =>
record.getCellValue('fldL0YbZsYuNJJwTP').includes(inputConfig.Individual)
)
data:image/s3,"s3://crabby-images/8cb2f/8cb2f3bec7aa3b8b55da0b6eb8d1d81194430375" alt=""