This web app makes it easy to curate & display media slideshows (ideal for NFTs) using Google Sheets as the back end / admin interface.
It was originally built for the NFT Screens in the Union Square Ventures office in NYC, as described here.
This is built to deploy on Netlify, but of course can be edited for other environments.
-
Copy and save this google sheet template.
- Each sheet in the workbook can be a playlist. You can create multiple playlists by duplicating the first playlist sheet.
- Each row per sheet is a single NFT. The sample sheet shows the fields required for each NFT you want to display.
- NFTs can be of type: Image, Video or Generator. Generator is for certain NFTs (e.g., Art Blocks) where the output is a script rather than a static media file -- Generators are displayed using <iframe>s.
-
Set up an account at sheet.best, which makes it easy to access Google Sheets data via API. Create a new Connection.
-
Configure environmental vars
- your Sheet Best connection URL will be stored as an environmental variable, and used to make API calls via Javascript.
- create a file named
env.js
. it should look like this:Note:env = { SHEET_BEST_CONNECTION_URL: 'your-connection-url', SLIDE_TIMING: 60 }
env.js
file is for local development only, and will be ignored by Git when you commit. - In your netlify application settings, create a new environmental variable called SHEET_BEST_CONNECTION_URL and add your URL there, and add SLIDE_TIMING to set the default time per slide (defaults to 60 even if you don't put anything here).
- When you deploy to Netlify,
netlify.toml
will collect your environmental variables from your app config and make them available to javascript viaenv.js
. (Hat tip for this trick to Simone Web Design)
-
Test
- if you're working locally, run
netlify dev
from the command line (requires the Netlify CLI Client) - Whenever you run the app, you'll need to add a query parameter
tab
which specifies which tab in the spreadsheet you're using. For example, a Netlify development URL would look likehttp://localhost:8888/?tab=Sample_Vertical
whereSample_Vertical
is the exact name of the tab for this slideshow. - Another optional parameter is
slide_timing
which specifies an amount of time for each item, in seconds (the default is 30).
- if you're working locally, run
-
Deploy
- push to Netlify and enjoy!
At USV, we have a number of Samsung Commercial Displays set up to show NFTs. We have Samsung QMR-A 55"s in vertical/portrait orientation, and Samsung QM85R-B 85"s in horizontal/landscape orientation.
Each screen is connected to a Yodeck device which controls content on the screen. We configure each yodeck with a URL media source pointing to the URL for the slideshow that should run on that screen.