A resource for Pennsylvania journalists to improve representation and diversify perspectives in their coverage.
All content copyright Spotlight PA. Code available under the MIT license. Photos used with permission of subjects. Information contained in this database is self-reported by participants and should be verified before publication.
Project requires Yarn, Hugo, and optionally Go. See netlify.toml file for Node and Hugo versions. Go version specified in .go-version file.
To setup, run yarn
.
To develop locally, run hugo serve
and open a web browser to http://localhost:1313/.
The site uses a THANG Stack architecture:
- Tailwind CSS: Provides basic CSS architecture/theming
- Hugo: Site builder
- Alpine.js: JavaScript micro-framework
- Netlify CMS: Allows editors to change pages without coding
- Go: Handles miscellaneous tasks
Site search is powered by Algolia. On deploy, a search index JSON file is built at /searchindex.json and sent to Algolia by a small Go script. To work, the Algolia script API key must have permission to create/drop an index because it creates a temporary table, sends all the data to the temporary table, then swaps it in.
Email addresses are Base64 encoded to prevent casual scraping.
The site was not made with reuse in mind, but it shouldn't be so hard. Just rip out the content files, rewrite nav.html and footer.html to remove references to Spotlight PA, and change the base URL and Google Analytics key in config.toml. Contact [email protected] with questions.