/maproulette3

Upcoming new version of MapRoulette

Primary LanguageJavaScript

Getting Started

This is a new front-end for MapRoulette built on React. The back-end (scala) server from the maproulette2 project is still required.

Note: because of the oauth authentication workflow, your dev machine must be publicly accessible to the OpenStreetMap (OSM) servers in order to login to the app. You may wish to setup an open-source tunneling server like go-http-tunnel or use a commercial service like ngrok.

  1. Create a .env.development.local file and:
  • set REACT_APP_BASE_PATH='/mr3'
  • set REACT_APP_URL='https://maproulette.mydevserver.com/mr3' (substituting your dev domain, of course)
  • set REACT_APP_MAP_ROULETTE_SERVER_URL='https://maproulette.mydevserver.com'
  • if you wish to use Mapbox maps, set the REACT_APP_MAPBOX_ACCESS_TOKEN to your API token.
  • if you want some debug output, set REACT_APP_DEBUG='enabled'.
  • override any other settings from the .env file as needed or desired.
  1. yarn to fetch and install NPM modules.

  2. yarn run start to fire up the front-end server.

  3. Visit your OpenStreetMap account and go to My Settings -> oauth settings -> Register your application and setup a new application for development. For the Main Application URL and Callback URL settings, put in your dev server URL (e.g. https://maproulette.mydevserver.com). Take note of your new app's consumer key and secret key, as you'll need them in the next step.

  4. Fire up your backend scala server (installed separately from the maproulette2 project), setting the MR_OAUTH_CONSUMER_KEY and MR_OAUTH_CONSUMER_SECRET environment variables to your OSM app's consumer key and secret key, respectively. The back-end server assumes your front-end dev server is running on port 3000, which is the default; if you've changed the port, you'll also need to set MR3_JS_ASSET_URI=https://localhost:<port>/static/js/bundle.js (replacing with the proper port) and MR3_CSS_ASSET_URI=https://localhost:<port>/static/css/bundle.css.

  5. Point your browser at /mr3 on your server (e.g. https://maproulette.mydevserver.com/mr3) to bring up the front-end.

Staging/Production build:

  • Setup a .env.production file with the desired production setting overrides.
  • yarn run build to create a minified front-end tarball.

Note that the minified front-end JS and CSS bundles are given new hashed names with each build, and that the back-end server needs to know these names so it can serve up the files. You'll always need to set the MR3_JS_ASSET_URI and MR3_CSS_ASSET_URI environment variables in a staging or production environment to point to the correct filenames. For scripting/automation purposes, the filenames can always be found in the asset-manifest.json file and can be easily extracted with jq (e.g. jq -r '."main.js"' MR3React/asset-manifest.json and jq -r '."main.css"' MR3React/asset-manifest.json)

Development Notes

The project was bootstrapped with Create React App.

Branch management follows GitFlow with active development of the next release occurring on the develop branch. Pull requests should target the develop branch. The master branch always contains the latest release.

Release versions follow Semantic Versioning.

Testing

Jest + Enzyme are being used for tests. yarn test to run them.

CSS Styling and Naming

The app uses Sass/scss in combination with the Bulma CSS framework. The BEM methodology has been loosely used as a guide for CSS class naming within components.

The node-sass-chokidar package is used for compiling the .scss files into .css, which are then imported into the components (the .css files are not added to source control). It's run automatically as part of the yarn start and build scripts, so there's no need to run it separately.

The src/variables.scss includes global sass variables (such as colors), some Bulma variable overrides, etc.. Reusable mixins are kept in src/mixins.scss. Everything is pulled together (including Bulma's own Sass) into the src/theme.scss file.

Internationalization and Localization

Internationalization and localization is performed via react-intl. Each component features a co-located Messages.js file that contains messages intended for display, along with a default (English) version of each message. Given that the app is still under active development and seeing significant UI changes, no translation files have been generated yet.