Skip to content

hartkopfa/the-opportunity-project

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

The Opportunity Project Website

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.


Dependencies

  1. Ruby v2.2.2+, Installation guides
  2. Node v4.2.3+, Installation guides a. gulp (npm i -g gulp)
  3. Bundler v1.12.3+, Installation guides a. jekyll (gem install jekyll)
  4. Chrome v59 or higher (v60 if on Windows)

Getting Started

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 or npm run serve: Runs your local server with incremental regeneration enabled to greatly improve build time. Use instead of npm start.


Importing Data

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.



Building assets

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 :-)

Processing images with gulp-webp

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.


Testing

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:

HTML Validation

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!

Accessibility Testing

We test for accessibility issues using pa11y-ci following this guide.

There are two commands set up in package.json:

  1. npm run pa11y-ci to run against a specific set of URLs as listed in pa11y.json
  2. npm run pa11y-ci:sitemap to run against all urls found in the local sitemap and using the config specified in .pa11y

Building with Federalist

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

When a build fails

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.

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • SCSS 41.7%
  • HTML 36.4%
  • JavaScript 21.5%
  • Other 0.4%