MapComplete is a webapp which allows to use and update OpenStreetMap within thematic maps. This repository contains all of the source code.
Find a file
2021-01-05 01:30:59 +01:00
assets Use proper description in layerconfig 2021-01-05 01:30:59 +01:00
css Improvements on the climbing-theme, small tweaks in the review form 2020-12-18 01:36:45 +01:00
Customizations Use proper description in layerconfig 2021-01-05 01:30:59 +01:00
Logic Fixing adding multiple points 2021-01-04 22:59:11 +01:00
Models Version bump 2021-01-05 00:21:28 +01:00
scripts Fix the build 2021-01-03 13:50:18 +01:00
static Added cyclofix capacity cargo; covered; non-bike shop; pump dyn title 2020-07-29 13:16:21 +02:00
test More refactoring! 2021-01-03 00:19:42 +01:00
UI Use proper description in layerconfig 2021-01-05 01:30:59 +01:00
vendor Add working clustering! 2021-01-04 18:55:10 +01:00
.gitignore Add built files in root of repo to gitignore 2020-12-27 16:00:55 +01:00
AllTranslationAssets.ts Add proper rendering for single review title 2020-12-31 21:18:44 +01:00
customGenerator.html Add charset configuration onto html 2020-12-23 19:00:14 +01:00
customGenerator.ts Huge refactoring (WIP) 2020-10-27 01:01:34 +01:00
Folder.DotSettings.user Merge trees theme 2021-01-04 19:08:22 +01:00
index.css Small fixes to climbing theme, wiki generation, version bump 2020-12-18 02:10:26 +01:00
index.html Merge branch 'master' into refactor/clean-layer-rendering 2021-01-04 19:08:38 +01:00
index.ts Merge branch 'master' into refactor/clean-layer-rendering 2021-01-04 19:08:38 +01:00
InitUiElements.ts Performance improvement 2021-01-04 23:46:35 +01:00
land.html Add MapComplete 2020-06-24 00:35:19 +02:00
LICENSE Small fixes for the GRB theme and value substitution 2020-08-27 00:08:00 +02:00
manifest.manifest Add icons, add validation, add phone and email types, add css fixes 2020-07-26 02:01:34 +02:00
package-lock.json Add working clustering! 2021-01-04 18:55:10 +01:00
package.json Add working clustering! 2021-01-04 18:55:10 +01:00
preferences.html Add the possibility to load a custom layout with base64-encoded jsons 2020-08-08 17:50:43 +02:00
preferences.ts Cleanup of empty classes, partial use of default export 2020-10-02 19:00:24 +02:00
README.md Add missing step in setup 2020-12-23 18:14:06 +01:00
run.bat Spanish translation 2020-08-26 01:03:51 +02:00
State.ts Automatically cluster maps with more then 250 elements 2021-01-05 00:21:00 +01:00
Svg.ts More refactoring, stabilizing rotation and direction_gradient 2021-01-04 04:06:21 +01:00
test.html First version of reviews 2020-12-07 03:02:50 +01:00
test.ts More cleaning up 2021-01-04 04:36:21 +01:00
tsconfig.json Generate assets as SVG 2020-11-05 12:28:02 +01:00
Utils.ts Expose clustering in layoutConfig 2021-01-04 20:09:07 +01:00

MapComplete

Let a thousand flowers bloom

MapComplete attempts to be a webversion crossover of StreetComplete and MapContrib. It tries to be just as easy to use as StreetComplete, but it allows to focus on one single theme per instance (e.g. nature, bicycle infrastructure, ...)

The design goals of MapComplete are to be:

  • Easy to use, both on web and on mobile
  • Easy to deploy (by not having a backend)
  • Easy to set up a custom theme
  • Easy to fall down the rabbit hole of OSM

The basic functionality is to download some map features from Overpass and then ask certain questions. An answer is sent back to directly to OpenStreetMap.

Furthermore, it shows images present in the image tag or, if a wikidata or wikimedia_commons-tag is present, it follows those to get these images too.

An explicit non-goal of MapComplete is to modify geometries of ways. Although adding a point to a way or splitting a way in two parts might be added one day.

Creating your own theme

You can create your own theme too

If you have created a new theme and tested it, you can ask to have it included in the main repository. See Dev for how to do this.

Examples

There are plenty more. Discover them in the app.

Statistics

To see statistics, consult OsmCha or the analytics page

User journey

MapComplete is set up to lure people into OpenStreetMap and to teach them while they are on the go, step by step.

A typical user journey would be:

  1. Oh, this is a cool map of my specific interest! There is a lot of data already...

    • The user might discover the explanation about OSM in the second tab
    • The user might share the map and/or embed it in the third tab
    • The user might discover the other themes in the last tab
  2. The user clicks that big tempting button 'login' in order to answer questions - there's enough of these login buttons... The user creates an account.

  3. The user answers a question! Hooray! The user transformed into a contributor now.

    • When at least one question is answered (aka: having one changeset on OSM), adding a new point is unlocked
  4. The user adds a new POI somewhere

    • Note that all messages must be read before being able to add a point.
    • In other words, sending a message to a misbehaving MapComplete user acts as having a zero-day-block. This is added deliberately to make sure new users have to read feedback from the community.
  5. At 50 changesets, the personal layout is advertised. The personal theme is a theme where contributors can pick layers from all the offical themes. Note that the personal theme is always available.

  6. At 200 changesets, the tags become visible when answering questions and when adding a new point from a preset. This is to give more control to power users and to teach new users the tagging scheme

  7. At 250 changesets, the tags get linked to the wiki

  8. At 500 changesets, I expect contributors to be power users and to be comfortable with tagging scheme and such. The custom theme generator is unlocked.

License

GPLv3.0 + recommended pingback.

I love it to see where the project ends up. You are free to reuse the software (under GPL) but, when you have made your own change and are using it, I would like to know about it. Drop me a line, give a pingback in the issues,...

Dev

To develop:

  1. Make a fork and clone the repository.
  2. Install npm. Linux: sudo apt install npm (or your favourite package manager), Windows: install nodeJS: https://nodejs.org/en/download/
  3. Run npm install to install the package dependencies
  4. Run npm run generate and npm run generate:editor-layer-index to generate some additional dependencies
  5. Run npm run start to host a local testversion at http://localhost:1234/index.html
  6. By default, the 'bookcases'-theme is loaded. In order to load another theme, use layout=themename or userlayout=true#<layout configuration>. Note that the custom URLs (e.g. bookcases.html, aed.html, ...) don't exist on the development version. (These are automatically generated from a template on the server).

To deploy:

  1. rm -rf dist/ to remove the local build
  2. npm run build
  3. Copy the entire dist folder to where you host your website. Visiting index.html gives you the website

Translating MapComplete

Help to translate mapcomplete.

A theme has translations into the preset.json (assets/themes/themename/themename.json). To add a translation:

  1. Fork this repository
  2. Modify "language" to contain the new language, e.g. "language": "nl" becomes "language": ["nl", "en"]
  3. Add extra strings to the texts. If it used to be a single-language theme, one can replace the strings, e.g.: "description": "Welcome to Open Bookcase Map" to "description": {"en": "Welcome to Open Bookcase Map", "nl": "Welkom bij de OpenBoekenruilkastenKaart", "fr": "Bienvenue sûr la carte des petites bibliotheques"}. If the correct language is not found, it'll fallback to another supported language.
  4. If you notice missing translations in the core of MapComplete, fork this project, open the file containing all translations, add add a language string there
  5. Send a pull request to update the languages, I'll gladly add it! It doesn't have to be a complete translation from the start ;)

Adding your theme to the repository

Did you make an awesome theme that you want to share with the OpenStreetMap community? Have it included in the main application, which makes it more discoverable.

In order to include your theme:

  1. Make sure the theme has an English version. This makes it easier for me to understand what is going on. The more other languages, the better of course!
  2. Fork this repository
  3. Go to assets/themes and create a new directory yourtheme
  4. Create a new file yourtheme.json, paste the theme configuration in there. You can find your theme configuration in the customThemeBuilder (the tab with the Floppy disk icon)
  5. Copy all the images into this new directory: external assets can suddenly break and leak privacy
    • Make sure the license is suitable, preferable a Creative Commons license. Attribution can be added at the bottom of this document
    • If an SVG version is available, use the SVG version
    • Make sure all the links in yourtheme.json are updated. You can use ./assets/themes/yourtheme/yourimage.svg instead of the HTML link
  6. Add your theme to the code base:
    • Open AllKnownLayouts.ts
    • Add an import statatement, e.g. import * as yourtheme from "../assets/themes/yourtheme/yourthemes.json";
    • Add your theme to the LayoutList, by adding a line FromJSON.LayoutFromJSON(yourtheme)
  7. Test your theme: run the project as described above
  8. Happy with your theme? Time to open a Pull Request!
  9. Thanks a lot for improving MapComplete!

Architecture

High-level overview

The website is purely static. This means that there is no database here, nor one is needed as all the data is kept in OpenStreetMap, Wikimedia (for images), IMGUR. Settings are saved in the preferences-space of the OSM-website, amended by some local-storage if the user is not logged-in.

When viewing, the data is loaded from overpass. The data is then converted (in the browser) to geojson, which is rendered by Leaflet.

When a map feature is clicked, a popup shows the information, images and questions that are relevant for that object. The answers given by the user are sent (after a few seconds) to OpenStreetMap directly - if the user is logged in. If not logged in, the user is prompted to do so.

The UI-event-source is a class where the entire system is built upon, it acts as an observable object: another object can register for changes to update when needed.

Searching images

Images are fetched from:

  • The OSM image, image:0, image:1, ... tags
  • The OSM wikimedia_commons tags
  • If wikidata is present, the wikidata P18 (image) claim and, if a commons link is present, the commons images

Uploading images

Images are uplaoded to imgur, as their API was way easier to handle. The URL is written into the changes

The idea is that once in a while, the images are transfered to wikipedia or that we hook up wikimedia directly (but I need some help in getting their API working).

Uploading changes

In order to avoid lots of small changesets, a changeset is opened and kept open. The changeset number is saved into the users preferences on OSM.

Whenever a change is made -even adding a single tag- the change is uploaded into this changeset. If that fails, the changeset is probably closed and we open a new changeset.

Note that changesets are closed automatically after one hour of inactivity, so we don't have to worry about closing them.

Query parameters

By adding extra query parameters, more options are available to influence:

test: If true, 'dryrun' mode is activated. The app will behave as normal, except that changes to OSM will be printed onto the console instead of actually uploaded to osm.org (default value: false)

layout: The layout to load into MapComplete (default value: bookcases)

userlayout: undefined (default value: false)

layer-control-toggle: Wether or not the layer control is shown (default value: false)

tab: The tab that is shown in the welcome-message. 0 = the explanation of the theme,1 = OSM-credits, 2 = sharescreen, 3 = more themes, 4 = about mapcomplete (user must be logged in and have >200 changesets) (default value: 0)

z: The initial/current zoom level (default value: 1)

lat: The initial/current latitude (default value: 0)

lon: The initial/current longitude of the app (default value: 0)

fs-userbadge: Disables/Enables the userbadge (and thus disables login capabilities) (default value: true)

fs-search: Disables/Enables the search bar (default value: true)

fs-layers: Disables/Enables the layer control (default value: true)

fs-add-new: Disables/Enables the 'add new feature'-popup. (A theme without presets might not have it in the first place) (default value: true)

fs-welcome-message: undefined (default value: true)

fs-iframe: Disables/Enables the iframe-popup (default value: false)

fs-more-quests: Disables/Enables the 'More Quests'-tab in the welcome message (default value: true)

fs-share-screen: Disables/Enables the 'Share-screen'-tab in the welcome message (default value: true)

fs-geolocation: Disables/Enables the geolocation button (default value: true)

oauth_token: Used to complete the login (default value: undefined)

background: The id of the background layer to start with (default value: undefined)

layer-bookcases: Wehter or not layer bookcases is shown (default value: true) index.ts:104:8

Privacy

Privacy is important, we try to leak as little information as possible. All major personal information is handled by OSM. Geolocation is available on mobile only throught hte device's GPS location (so no geolocation is sent of to google)

TODO: erase cookies of third party websites and API's

Attributions

Data from OpenStreetMap

Background layer selection: curated by https://github.com/osmlab/editor-layer-index

Images from Wikipedia/Wikimedia

https://commons.wikimedia.org/wiki/File:Camera_font_awesome.svg Camera Icon, Dave Gandy, CC-BY-SA 3.0

https://commons.wikimedia.org/wiki/File:OOjs_UI_indicator_search-rtl.svg Search Icon, MIT

https://commons.wikimedia.org/wiki/File:Trash_font_awesome.svg Trash icon by Dave Gandy, CC-BY-SA

https://commons.wikimedia.org/wiki/File:Home-icon.svg Home icon by Timothy Miller, CC-BY-SA 3.0

https://commons.wikimedia.org/wiki/File:Map_icons_by_Scott_de_Jonge_-_bicycle-store.svg Bicycle logo, Scott de Jonge

Nature Reserve icon via http://www.onlinewebfonts.com/icon/389579, CC BY 3.0 (@ Эдуард Черных)

Park icon via http://www.onlinewebfonts.com/icon/425974, CC BY 3.0 (@sterankofrank)

Forest icon via https://www.onlinewebfonts.com/icon/498112, CC BY

Statistics icon via https://www.onlinewebfonts.com/icon/197818

Chronometer (on monitoring_station.svg): ANTU chronometer https://commons.wikimedia.org/w/index.php?title=Antu_chronometer

Fries icon: https://www.flaticon.com/free-icon/french-fries_1144288

Shower icon (used in 'bike_cleaning.svg'): https://commons.wikimedia.org/wiki/File:Shower_symbol.svg

Bench icons from StreetComplete: https://github.com/westnordost/StreetComplete/tree/v25.0-beta1/res/graphics/quest%20icons, GPLv3.0

Urinal icon: https://thenounproject.com/term/urinal/1307984/

24/7 icon: https://www.vecteezy.com/vector-art/1394992-24-7-service-and-support-icon-set