Jan 18, 2023 04:50 AM
Hi guys and gals 🙂
I am a newbie to Airtable, can someone help me out with the script and automation?
I want to populate two fields in the column Notes and Points with the data returning from a web API call using bearer token authorization, but I also need to add the parameters included in Product and Quantity in the API call and filter out specific elements from the json file to be stored in the field Notes and Points.
I have the following columns:
RunWork | Status | Product | Quantity | Notes | Points
RunWork contains the checkbox.
Status is either blank, In Progress, Done
Notes and Points will get populated with json data from an API call.
My logic would be,
If RunWork is checked,
-> Then change Status to In Progress
-> Then populate Notes and Points using parameters in Product and Quantity
When all fields are filled,
-> then change Status to Done
Any help or code example is greatly appreciated!
Jan 18, 2023 01:16 PM
Hey @BIG!
I'd like to make sure I'm understanding what you're trying to do a bit better.
You have a checkbox field (RunWork) that triggers an automation once it is checked to true.
When that automation runs, the record's Status single-select field is set to In Progress.
You the make an API call to another service that is authenticated with a bearer token.
The HTTP request body contains the data from the trigger record's Product and Quantity fields.
The data returned from the API call should then be used to populate the Notes and Points fields on the triggering record.
Finally, the Status single-select field is set to Done.
If my understanding is correct, then I would probably implement something like this:
const config = input.config();
const { recordId } = config;
const yourTableId = "your_table_id";
const table = base.getTable(yourTableId);
const fields = [
//Notes
"notes_field_id",
//Points
"points_field_id",
//Quantity
"quantity_field_id",
//Product
"product_field_id",
//Status
"status_field_id",
//RunWork
"runwork_field_id"
];
const record = await table.selectRecordAsync(recordId, {fields: fields});
await table.updateRecordAsync(recordId, {
//Status
"status_field_id": {name: "In Progress"}
});
const body = {
product: (function () {
let value = record.getCellValue(fields[3]);
return (value ? value : "")
}),
quantity: (function () {
let value = record.getCellValue(fields[2]);
return (value ? value : "")
})
};
const apiKey = "your_bearer_token";
const apiUrl = "your_api_endpoint";
const options = {
method: "GET",
headers: {
"Content-Type": "application/json",
"authorization": `Bearer: ${apiKey}`
},
body: JSON.stringify(body)
};
const apiQuery = await fetch(apiUrl, options)
.then(response => {
if (response.status === 200) {
return response.json();
} else {
console.log(`Request Failed With Status: ${response.status}`)
return undefined;
}
});
if (apiQuery) {
await updateRecordAsync(recordId, {
//RunWork is reset to false.
"runwork_field_id": false,
//Notes
"notes_field_id": apiQuery.product,
//Points
"points_field_id": apiQuery.quantity,
//Status
"status_field_id": {name: "Done"}
});
};
I wrote this rather quickly and am missing a few key details about your schema and implementation to properly write an example, but if my understanding is correct, then that's how I would probably begin to approach it.
Jan 21, 2023 02:51 PM
Oh my god, you are so helpful! I thank you so much! I will try to implement and test if it works.