data:image/s3,"s3://crabby-images/f02b0/f02b051450a0e9bd6ee3c9ef0a079e74940ca94f" alt="Jeffrey_Brandt Jeffrey_Brandt"
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Jun 30, 2021 12:08 PM
Hi,
Using the following script from this post, I created a field that combines a URL and text:
let tb = base.getTable(“URL Test”);
let query = await tb.selectRecordsAsync();
for (let record of query.records) {
let url = record.getCellValue(“URL”);
let name = record.name;
let text = record.getCellValue(“Text”);
if(url) {
tb.updateRecordAsync(record, {“Rich”: [${text}](${url}) - ${name}
})
}
}
I have two questions:
1: Can I make this script complete this task in multiple columns? (for example - perform the script for column “Rich” and then have “Rich2” to repeat the script, but using a different URL column.)
2: This doesn’t work if my URL is coming from a lookup - even if the lookup is a URL. Is there a way to get this to work from a lookup field?
Thanks!
Jeffrey
data:image/s3,"s3://crabby-images/940e1/940e135223332b9d19b1ab1302c3183a406470b3" alt="kuovonne kuovonne"
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Jun 30, 2021 01:54 PM
Lookup fields are tricky. Try using getCellValueAsString
instead of getCellValue
for the lookup fields.
You can also have the script make changes in multiple columns. There are several different ways. The simplest ways is to duplicate the code. Other ways are to update both fields at the same time. Another variation to consider is to make an array of the updates and then perform the updates in a batch at the end of the script. However, these different ways are more about understanding coding and JavaScript versus using the API.
data:image/s3,"s3://crabby-images/79abb/79abbc03cc624ea7bc441501b499dd398789db84" alt=""