If you're looking for a starter development task to get your feet wet with our codebase, any of our Issues tagged help wanted might be a good fit.
Some of the other Issues are larger and require some deeper design or architectural work; if one of those catches your eye, you'll probably want to talk with us for some more context and background. Either comment on the Issue or — even better — catch up with us at one of Code for Sacramento's weekly Hack Nights.
- Sign into GitHub and fork this repo
- Clone the fork onto your machine and navigate to the new folder
- While still in the root directory of the repo, create a new folder called "build". This folder will be ignored by our version control system.
- Navigate to the _src/ folder, which is where all development work takes place.
- Install dependencies with
npm install
- Serve the website by entering
npx @11ty/eleventy --serve --port=8011
Congratulations! Your local copy of Open Budget Sacramento's website should now be running at http://localhost:8011. That means you're ready to do the codez if you want to contribute to the codebase of Open Budget Sacramento. You will probably want to open a new terminal window, though, to regain access to the command line.
- Please note that after editing a SASS file you should run
npm run build-css
from the _src/ folder in order to incorporate your changes into the CSS
This site is built with Eleventy, a JavaScript-based static site generator that parses Markdown, Pug, and other template languages and runs on Node.js. That means you can reproduce our site locally with minimal setup!
You'll need these installed globally:
- Node is a prerequisite for NPM
- NPM or Yarn
- NVM is optional, but very handy for downloading, updating, and switching between versions of NPM
Once you have the NPM package manager installed, you can install Eleventy and the other dependencies listed in package.json. Enter the following from the _src/ folder, where the Eleventy configuration file .eleventy.js lives.
npm install
This command usually runs without a glitch, but if you run into trouble, check your version of node. The latest version of node that we can confirm works with our set-up is v15.14.0.
To start Eleventy, simply enter the following. (You may choose any network port on your system that is available; 8011 is just a suggestion.)
npx @11ty/eleventy --serve --port=8011
This project is coded with, among other things:
- Bootstrap, a CSS framework
- D3, a data visualization library for JavaScript
- Pug, a JavaScript-friendly HTML templating language
- React, a rendering library for JavaScript
- Sass, a CSS preprocessor
- Please note that it is your responsibility to keep your fork of the repo up-to-date with changes made by others working on the project. Doing this diligently should go a long way towards protecting you from scary git merge conflicts.
- All development activity occurs in
_src/
. The root folder is only for compiled output for deployment. - Page content is inserted into the
content
block. If you are updating data, be sure you understand how it will be consumed. - In many cases you will simply create or update a
.pug
file, which Eleventy will turn into HTML. If you are making another type of change, you may need to read Pug documentation (which is excellent, by the way!). - If your page uses custom page-specific css, add it to a new
.scss
partial and import it into the main stylesheet. (Make sure to namespace it the same way the others are.)
- Flow pages are built off a template; copy one of the
*-budget-flow.pug
pages and update the content blocks as necessary. - Data files must be placed in the
data/flow
directory. Follow the naming convention seen there or your files won't load properly. You also will need to point your page at the appropriate files as seen in theget_datafiles
content block. - the following columns are required in your datafile and their names should be normalized as seen here. Other columns should be removed to minimize the data download.
- budget_year
- department
- fund_code
- account_type (this should be the Expense/Revenue column, if there are duplicate names)
- account_category
- amount
- Treemap pages are built off a template; copy one of the
*-budget-tree.pug
pages and update the content blocks as necessary. - Instructions for generating the necessary data files can be found here. Add them to the
data/tree/
directory following the naming convention seen in the existing files. - Update the
datafiles
content block with the appropriate metadata and file path for the data files you generated.
- The Compare page is a React application. The source files are in
_src/js/compare/
and are are bundled with Webpack. - When developing on the Compare page, run
yarn
to install all the necessary node dependencies andyarn run watch
to watch the source files for changes and rebuild the asset bundles accordingly.
Make changes and review them on your local development site. If everything looks good, push your changes to your personal fork and merge the commit(s) into your master branch. Finally, issue a pull request and we'll take it from there!
Simply push your code changes to your repo in whatever branch you used locally, then merge into master. At this point you can either 1) push from your master to the staging branch of the upstream repo or 2) just tell an admin of the upstream repo that your work is ready for review. (Anyone with admin privileges on the original repo will be able to create a pull request from your repo). Your changes will then be reviewed, tested, and (if everything looks good) pushed into the master branch.
Starting in March 2020, code changes pushed to the master branch of the (original) repo will use GitHub Actions to trigger a continuous integration process that (among other things):
- runs WebPack;
- builds static files with Eleventy; and
- deploys the updated web files to GitHub Pages