data:image/s3,"s3://crabby-images/51a9f/51a9f16a275c9dac435abc9cbf78fcaf85b48864" alt="Sticker_ninja Sticker_ninja"
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Feb 02, 2021 03:34 PM
I’m building a custom app and need to show an attachment’s thumbnail image as part of an info card.
When I enter <div>{record.getCellValue("Attachment field")}</div>
to view the cell values, I get the following error:
Error: Objects are not valid as a React child (found: object with keys {linkedRecordId, value}). If you meant to render a collection of children, use an array instead.
I’ve tried adding record.getCellValue("Attachment field").fields.url
but it comes up as undefined.
I’ve also tried {record.map(value => {value.url})}
to try access the object’s properties but map is not a function of record.
How can I access the thumbnail’s URL?
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
Feb 02, 2021 03:47 PM
Try something like:
record.getCellValue("Attachment field")?.map(x => {
var url= x.url
return (<img src={url} />)
})
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
Feb 02, 2021 03:47 PM
Try something like:
record.getCellValue("Attachment field")?.map(x => {
var url= x.url
return (<img src={url} />)
})
data:image/s3,"s3://crabby-images/96134/96134731d4f60e9648202e2b5fd08705240eafc3" alt="Emma_Yeap Emma_Yeap"
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Feb 02, 2021 03:49 PM
Hi Michael,
Adding on to Kamille’s solution: the cell value formats for all the different field types are documented here: Airtable Blocks SDK
The cell value for attachment fields is an array of attachment objects (even if there’s only one attachment), so you’ll need to get the url(s) from those individual attachment objects.
data:image/s3,"s3://crabby-images/51a9f/51a9f16a275c9dac435abc9cbf78fcaf85b48864" alt="Sticker_ninja Sticker_ninja"
- Mark as New
- Bookmark
- Subscribe
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Feb 02, 2021 04:24 PM
Right on, thanks to @Kamille_Parks and @Emma_Yeap I was able to piece it together:
{record.getCellValue("Lookup attachment field")?.map(x => {
var url= x.value.thumbnails?.large?.url
return (<img src={url} />)
})}
The extra value
property is what allows this to work with a lookup field pointing to an attachment in another table if that is helpful to anyone.
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
Feb 02, 2021 04:30 PM
To clarify for others only add .value
if you’re pulling from a Lookup field. This question was asked regarding Attachment fields. Actual attachment fields do not return a value
property within the object returned by .getCellValue()
.
data:image/s3,"s3://crabby-images/79abb/79abbc03cc624ea7bc441501b499dd398789db84" alt=""