Forum Discussion
Custom thumbnail images with a fallback to default ones
- Aug 07, 2023gretesh Seems like Thumbnail is kind of reserved/default column name in SharePoint libraries. Try using this JSON: { "$schema": "https://developer.microsoft.com/json-schemas/sp/v2/column-formatting.schema.json", "elmType": "div", "children": [ { "elmType": "img", "attributes": { "src": "=getThumbnailImage([$Thumbnail], 50, 50)" }, "style": { "display": "=if([$Thumbnail.serverRelativeUrl]=='', 'none', 'block')", "height": "50px" } }, { "elmType": "img", "attributes": { "src": "@thumbnail.small" }, "style": { "display": "=if([$Thumbnail.serverRelativeUrl]=='', 'block', 'none')", "height": "50px" } } ] }For safer side, I will suggest you to create a Image column with different name (say CustomThumbnail) and then use JSON like below in Image column: { "$schema": "https://developer.microsoft.com/json-schemas/sp/v2/column-formatting.schema.json", "elmType": "div", "children": [ { "elmType": "img", "attributes": { "src": "=getThumbnailImage([$CustomThumbnail], 50, 50)" }, "style": { "display": "=if([$CustomThumbnail.serverRelativeUrl]=='', 'none', 'block')", "height": "50px" } }, { "elmType": "img", "attributes": { "src": "@thumbnail.small" }, "style": { "display": "=if([$CustomThumbnail.serverRelativeUrl]=='', 'block', 'none')", "height": "50px" } } ] }I have tested both the JSON and working fine for me. Output: Please click Mark as Best Response & Like if my post helped you to solve your issue. This will help others to find the correct solution easily. It also closes the item. If the post was useful in other ways, please consider giving it Like. 
gretesh Are you using SharePoint Image column for custom thumbnail/image?
Try using this JSON:
{
  "$schema": "https://developer.microsoft.com/json-schemas/sp/v2/column-formatting.schema.json",
  "elmType": "img",
  "attributes": {
    "src": "=if([$Thumbnail.serverRelativeUrl], getThumbnailImage([$Thumbnail], 100, 100), @thumbnail.small)"
  }
}
Where Thumbnail is the internal name of your custom image column. You can get the internal name of your column by following this article: How to find the Internal name of columns in SharePoint Online?
Or use this:
{
  "$schema": "https://developer.microsoft.com/json-schemas/sp/v2/column-formatting.schema.json",
  "elmType": "img",
  "attributes": {
    "src": "=if([$Thumbnail.serverRelativeUrl]!='', getThumbnailImage([$Thumbnail], 100, 100), @thumbnail.small)"
  }
}
Please click Mark as Best Response & Like if my post helped you to solve your issue. This will help others to find the correct solution easily. It also closes the item. If the post was useful in other ways, please consider giving it Like.
Thanks for your tips, ganeshsanap 
Unfortunately, your suggested snippets still don't allow me to display both, the custom uploaded images and the default thumbnails (as fallback). Somehow, the "else"-clause doesn't seem to get executed, both of your snippets from above give the following result: 
Could there be a bug in how the JSON is interpreted?
FYI, yes, the column that I have named "Thumbnail" is of type of Image: 
- ganeshsanapAug 07, 2023MVPgretesh Seems like Thumbnail is kind of reserved/default column name in SharePoint libraries. Try using this JSON: { "$schema": "https://developer.microsoft.com/json-schemas/sp/v2/column-formatting.schema.json", "elmType": "div", "children": [ { "elmType": "img", "attributes": { "src": "=getThumbnailImage([$Thumbnail], 50, 50)" }, "style": { "display": "=if([$Thumbnail.serverRelativeUrl]=='', 'none', 'block')", "height": "50px" } }, { "elmType": "img", "attributes": { "src": "@thumbnail.small" }, "style": { "display": "=if([$Thumbnail.serverRelativeUrl]=='', 'block', 'none')", "height": "50px" } } ] }For safer side, I will suggest you to create a Image column with different name (say CustomThumbnail) and then use JSON like below in Image column: { "$schema": "https://developer.microsoft.com/json-schemas/sp/v2/column-formatting.schema.json", "elmType": "div", "children": [ { "elmType": "img", "attributes": { "src": "=getThumbnailImage([$CustomThumbnail], 50, 50)" }, "style": { "display": "=if([$CustomThumbnail.serverRelativeUrl]=='', 'none', 'block')", "height": "50px" } }, { "elmType": "img", "attributes": { "src": "@thumbnail.small" }, "style": { "display": "=if([$CustomThumbnail.serverRelativeUrl]=='', 'block', 'none')", "height": "50px" } } ] }I have tested both the JSON and working fine for me. Output: Please click Mark as Best Response & Like if my post helped you to solve your issue. This will help others to find the correct solution easily. It also closes the item. If the post was useful in other ways, please consider giving it Like. - greteshAug 07, 2023Copper ContributorThanks a lot for the quick reply, ganeshsanap! Using the if-clause only for the display settings solved it for me 🙂 I'll use this as a workaround. - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - For the record, my original issue doesn't seem to be related to the fact that the column was called "Thumbnail". At least using the older snippets on a new column called "Test" (type "Image") didn't solve the issue: { "$schema": "https://developer.microsoft.com/json-schemas/sp/v2/column-formatting.schema.json", "elmType": "img", "attributes": { "src": "=if([$Test.serverRelativeUrl]!='', getThumbnailImage([$Test], 100, 100), @thumbnail.small)" } }- wlauritsonJun 25, 2024Copper Contributorganeshsanap gretesh ; Did you ever figure out how to have this update work in the Tiles view too? Your assistance worked great on the list view for the specific column, but need help on the tiles view.