This repo includes code for the TOP website. www.opportunity.census.gov
This project is built off of the USWDS site code, and just like that repo, uses Jekyll for the file framework, gulp, and the node module for USWDS.
- Ruby v2.2.2+, Installation guides
- Node v4.2.3+, Installation guides
a. gulp (
npm i -g gulp
) - Bundler v1.12.3+, Installation guides
a. jekyll (
gem install jekyll
) - Chrome v59 or higher (v60 if on Windows)
To work on the site, switch to your local copy of the repository in terminal then run the following command to install project dependencies:
npm install
Now that all of your dependencies are installed, you can run your local server by running the following command:
npm start
Go to 127.0.0.1:4000
in your browser — you should be viewing a local instance
-
npm run watch
: Runs a series of commands that watches for any changes in both USWDS node module and the root level asset folders in this repo. -
npm start -- --incremental
ornpm run serve
: Runs your local server with incremental regeneration enabled to greatly improve build time. Use instead ofnpm start
.
We use Airtable as our single source of truth for data files. npm run airtable
will pull the latest data from airtable and insert into the _data
folder for use in the site if you have access to it.
Be sure to set up a .env
file with AIRTABLE_TOP_ID
and AIRTABLE_API_KEY
set for this script to work. Otherwise, you can simply run the airtable-export
command manually, and it will work as well.
The project uses gulp to compile assets, and many plugins for a smooth build process and to shrink assets. Check out /config/gulp/*
for more info.
Place all assets (images, js files, pdfs, etc.) in their respective root folders. Do not place them in /assets
or _site/assets
. The gulp files will find them :-)
You can place .png
and .jpg
images right in /img
and the build process will automatically create a .webp
copy during the build. It is not necessary to create .webp
images yourself.
If you use the {% include image.html %}
include, that will also include a <picture>
tag with a webp
src and png
/ jpg
fallback.
We do recommend shrinking images with the great squoosh.app before including them, though.
See /config/gulp/images.js
for more details.
As of March 2021, we run tests locally but not in the cloud due to limitations integrating GitHub Actions with Federalist. This is a potential area for improvement and can possibly be figured out! But for now, this set up works pretty well. It just requires manually running tests locally. Here's how:
run npm run proof
to validate the site's HTML, check broken links, missing images & alts, etc with HTMLProofer.
run npm run proof-external
to also check all external links. This takes longer, but is useful if you've just imported new data which has a bunch of external links that may be broken!
We test for accessibility issues using pa11y-ci following this guide.
There are two commands set up in package.json
:
npm run pa11y-ci
to run against a specific set of URLs as listed inpa11y.json
npm run pa11y-ci:sitemap
to run against all urls found in the local sitemap and using the config specified in.pa11y
This repository is hooked up to Federalist, an automatic build process used by many government websites.
Whenever you push changes to Github, Federalist will make a new build (using the federalist
command in package.json
).
Federalist will then provide a URL for this build which you can use for user testing. To get the URL for the build, click on the green check-mark next to the build status for whatever branch you just pushed to, and then click the "Details" link.
When you merge a branch into main
, Federalist will then make a new build with the same process and deploy it to opportunity.census.gov
If Federalist fails to build, the status dot on the branch in Github will change from yellow (in progress) to red (failed). If this happens, contact Logan Powell via Slack in the Census Bureau workspace to see the logs from the failed build. He has access to Federalist itself. We do not.