-
Notifications
You must be signed in to change notification settings - Fork 895
Info for Maintainers
Snowysauce edited this page Sep 29, 2024
·
16 revisions
This page contains useful information for maintainers, including how to clone and build the project.
You don't need to know all of this if you just want to contribute to the index!
- Prerequisites
- Project Setup
- Building the index
- Syncing with Wikidata
- Releasing
- Building nsi.guide
- Other commands
- Collecting names from the OSM planet
- GitHub Desktop: a visual interface that can be used instead of using git commands
- Visual Studio Code: a powerful IDE that has a built-in terminal to run npm commands
- Clone this project, for example:
git clone [email protected]:osmlab/name-suggestion-index.git
-
cd
into the project folder, - Run
npm install
to install libraries
-
git pull origin --rebase
is a good way to keep your local copy of the code updated - rerun
npm install
whenever dependencies are updated inpackage.json
-
npm run build
- Takes about 45 seconds and should be run whenever the
data/*
orconfig/*
files change - Processes custom locations under
features/**/*.geojson
intodist/featureCollection.json
- Sorts
dist/collected/*
name lists intodist/filtered/*
"keep" and "discard" name lists - Merges new items found in the "keep" lists into the
data/*
files - Generates ids
-
Outputs warnings to suggest updates to
data/**/*.json
- Make sure to check in code when done, with something like
git add . && git commit -m 'npm run build'
- Takes about 45 seconds and should be run whenever the
-
npm run wikidata
- Requires a secrets file
- Takes about 20 minutes and should be run occasionally to keep NSI in sync with Wikidata
- Fetches related Wikidata names, descriptions, logos, then updates
dist/wikidata.json
- Updates the Wikidata pages to contain the current NSI identifiers
- Outputs warnings to suggest fixes on Wikidata for missing social accounts, or other common errors
- Make sure to check in code when done, with something like
git add . && git commit -m 'npm run wikidata'
- (We may try to automate more of this eventually)
-
npm run dist
- Takes about one minute and generates all the files in
dist/*
- The semantic version number of the project is updated automatically:
major.minor.patch
where patch is the date inyyyymmdd
format - Rebuilds iD and JOSM presets, taginfo file, other output files
- Should be run whenever the index is in a good state (build and wikidata sync has happened successfully)
- Make sure to check in code when done, with something like
git add . && git commit -m 'npm run dist'
- Projects which pull NSI data from GitHub (such as https://nsi.guide) will appear updated soon after
npm run dist
- Other downstream projects may pull from
dist/*
too
- Takes about one minute and generates all the files in
To publish an official release, follow the steps in the Release Checklist.
- Official releases are stable forever and available via NPM or on CDNs like JSDelivr
- Projects which pull name-suggestion-index from NPM or a CDN (such as RapiD) will appear updated soon after publishing
- Publishing the code to NPM requires rights to run
npm publish
https://nsi.guide is a web application written in ReactJS that lets anyone browse the index.
-
npm run appbuild
- Rebuilds the ReactJS code for https://nsi.guide
- The source code for this app can be found under
app/*
- Only need to rebuild this when the app code changes, not when the index changes
-
npm run lint
- Checks the Javascript code for correctness -
npm run test
- Runs tests agains the Javascript code -
npm run
- Lists other available commands
New: This lives over in https://github.com/ideditor/nsi-collector now.
Once nsi-collector publishes a new version:
- Run
npm update --save @ideditor/nsi-collector
to grab the new version - Run
npm run build
to move the collector data intodist/
- Attempt an
npm run build
. Now that uniqueid
properties are generated, it is possible that this command will fail. - This can happen if there are multiple new items that end up with the same
id
(e.g. "MetroBus" vs "Metrobus") - You'll need to just pick one to keep, then keep trying to run
npm run build
until the duplicateid
issues are gone.
Contributing to the index
- Feature Files (geofences)
- Using Overpass Turbo
- Config Files
- Property Reference
- Technical Details
Information for developers using the name-suggestion-index in another project.
Information for maintainers, including how to clone and build the project.