The code behind https://parkingreform.org/parking-lot-map/.
The code is fairly simple and we do not use fancy frameworks like React or Svelte. The main files are index.html
, src/js/setUpSite.js
, and data/*.geojson
. setUpSite.js
will load the .geojson
files to dynamically update index.html
with all our data.
All the commands take place in a terminal, a text-based interface for interacting with your computer. On macOS, you can open the "Terminal" app. On Windows, you can use "Git Bash", which will be installed when you install Git below.
You will also need to install:
- Git, which we use for "version control": https://git-scm.com/book/en/v2/Getting-Started-Installing-Git
- NPM, which is how we run JavaScript and our tests. Use the LTS at https://nodejs.dev/en/download/
To run the below commands, open your terminal app. Make sure you have git clone
d the fork of your repository somewhere on your machine. Then, use cd <directory>
to navigate there, e.g. cd code/parking-lot-map
.
You must first install the project's dependencies before running any of the below commands.
❯ npm install
❯ npx playwright install
❯ npm start
Then open http://127.0.0.1:1234 in a browser. Hit CTRL-C
to stop the server.
When the server is running, you can make any changes you want to the project. Reload the page in the browser to see those changes. (You may need to force reload, e.g. hold the shift key while reloading on macOS.)
❯ npm test
If the tests are taking a long time to start, run rm -rf .parcel-cache
and try the tests again.
❯ npm run fmt
"Linting" means using tools that check for common issues that may be bugs or low code quality.
❯ npm run lint
Manually edit the values in the file data/score-cards.json
.
Run the site with npm start
and make sure it's what you want.
Then, save your changes in Git (in a new branch) and open a pull request. See the section "Make a contribution" below.
Export the GeoJSON file and save it as the file parking-lots-update.geojson
in the root of this repository. If the file already exists, overwrite it with your new data.
Then, determine the city/state name. This is the same as what we show in the city toggle on the site, e.g. St. Louis, MO
.
Now, run the below but replace the last part with the city/state name (in single quotes!):
❯ npm run update-lots -- 'My City, AZ'
Run the site with npm start
and make sure it's what you want. Also, autoformat the file with npm run fmt
.
Then, save your changes in Git (in a new branch) and open a pull request. See the section "Make a contribution" below.
Export the GeoJSON file and save it as the file city-update.geojson
in the root of this repository. If the file already exists, overwrite it with your new data.
Then, determine the city/state name. This is the same as what we show in the city toggle on the site, e.g. St. Louis, MO
.
Now, run the below but replace the last part with the city/state name (in single quotes!):
❯ npm run update-city-boundaries -- 'My City, AZ'
Start the site with npm start
and make sure it's what you want. Also, autoformat the file with npm run fmt
.
Finally, save your changes in Git (in a new branch) and open a pull request. See the section "Make a contribution" below.
Export the city boundaries' GeoJSON and save it as the file city-update.geojson
in the root of this repository. If the file already exists, overwrite it with your new data.
Also export the city's parking lots GeoJSON and save it as the file parking-lots-update.geojson
.
Then, determine the city/state name, such as St. Louis, MO
.
Now, run the below but replace the last part with the city/state name (in single quotes!):
❯ npm run add-city -- 'My City, AZ'
Next, manually fill in the score card entries in the file data/score-cards.json
. Search for the city name and update the values.
Start the site with npm start
and make sure it's what you want. Also, autoformat the file with npm run fmt
.
Finally, save your changes in Git (in a new branch) and open a pull request. See the section "Make a contribution" below.
We use the typical forking model to make contributions by opening Pull Requests. See https://docs.github.com/en/get-started/quickstart/contributing-to-projects.
You can preview what a build will look like by running npm run build
. Then use npm run serve-dist
to start the server.
You can also run our integration tests on built dist folder with npm run test-dist
(make sure the server is not already running).
We use continuous deployment, meaning that we re-deploy the site every time we merge a pull request to staging at https://parkingreform.org/plm-staging/. You can check how the site renders about ~1-2 minutes after your change merges.
After you've confirmed staging looks good at https://parkingreform.org/plm-staging/, you can manually trigger a deploy.
Go to https://github.com/ParkingReformNetwork/parking-lot-map/actions and open the "Deploy to prod" workflow. Initiate a build.