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.
- 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.
-
yarn
to fetch and install NPM modules. -
yarn run start
to fire up the front-end server. -
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
andCallback 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. -
Fire up your backend scala server (installed separately from the maproulette2 project), setting the
MR_OAUTH_CONSUMER_KEY
andMR_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 setMR3_JS_ASSET_URI=https://localhost:<port>/static/js/bundle.js
(replacing with the proper port) andMR3_CSS_ASSET_URI=https://localhost:<port>/static/css/bundle.css
. -
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
andMR3_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 theasset-manifest.json
file and can be easily extracted with jq (e.g.jq -r '."main.js"' MR3React/asset-manifest.json
andjq -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.