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. 
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: 
gretesh 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.- greteshJun 26, 2024Copper ContributorI used the snippet ganeshsanap suggested and with this, the thumbnails I set up back then show up both in list and tiles mode. { "$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" } } ] }Now trying adding new thumbnails both in a new folder (to test the json snippet) and in the old folder, but uploading doesn't seem to work anymore (the image gets uploaded but after I close the grid view, the uploaded image blob is shown broken - "file not found"). So I cannot test whether the old snippet still works as expected with any new uploads.