Skip to content

opieop333/meme-wall

 
 

Repository files navigation

SUCHO Meme Wall

GitHub Pages Deployment Status Update Media Workflow Status

Visit the Meme Wall

Submit a Meme

About the Meme Wall

The Meme Wall is built directly from submissions to a Google Form. Contributors complete the form with details about a meme they have identified and attach an image or other media file to the form submission. Form submissions are recorded in a Google Spreadsheet and submitted files are uploaded to a Google Drive folder. Submissions are checked and curated by SUCHO volunteers.

The codebase in this repository uses the Astro static site builder to build the site and the required assets from the curated submissions on a daily basis.

Dataset and Asset Generation

When pnpm dev or pnpm build is run, the build process will fetch and parse the latest data from the curated "Ready" tab on the submission sheet and synchronize the local media cache with the contents of the submissions folder on Google Drive. Additional material for the glossaries is fetched and parsed from a number of Google Docs. The identifiers for the sheets and docs etc. (which need to be publicly viewable), are found in src/config.mjs.

Running pnpm update-media will fetch and synchronize the media files and then exit, and pnpm print-dataset will fetch and parse the data and media files and then output the parsed data to stdout (it can take arguments to output different parts of the parsed dataset -- see src/dataset.mjs for details).

Development

  1. git clone this repository

Live-Updating Development Build

  1. Run pnpm install to install dependencies.
  2. Run pnpm dev to start the development server and reflect your changes to the page as you save files.
  3. Visit http://localhost:3000/ in your browser.

Static Build

  1. Run pnpm build to create a production build (the deployment url can be set in astro.config.mjs but only matters for OpenGraph/Twitter metadata etc.).
  2. Run pnpm preview to serve the contents of dist/ using an http server at http://localhost:3000/.

Deploy to GH Pages

  1. Users with write permissions to this repository can run pnpm gh-deploy from the project root to install dependencies, build the static assets, and update and push to the gh-pages branch.
    Note: the GitHub Actions workflow at .github/workflows/update-media-and-deploy-site.yml runs once a day and will automatically acquire new media, update the repository, and build and deploy the site as appropriate -- manual deploys should not generally be required.

Additional Development Commands

  • pnpm update-media (requires node >= v18) will fetch the spreadsheet, update the local working tree with any new (or missing) media files fetched from Google Drive, and delete any media files from meme_media/ that do not correspond to records in the spreadsheet.

  • pnpm print-dataset (requires node >= v18) will fetch the spreadsheet, process the data and media files, and then output the parsed dataset to stdout in JSON format.

  • All pnpm commands can be prepended with LOG_LEVEL=DEBUG for additional debugging information on the console.

Packages

No packages published

Languages

  • Astro 41.1%
  • JavaScript 40.5%
  • CSS 8.6%
  • Svelte 7.7%
  • Shell 2.1%