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
2025-06-13 01:14:24 +02:00
.forgejo Scripts: drop overwrite flag 2025-06-07 23:33:46 +02:00
.reuse Chore: Remove more GH references (#2374) 2025-04-07 19:10:11 +02:00
.vscode Chore: Gitlens settings 2025-03-13 19:11:09 +01:00
android@fc597bf3c9 Fix: attempt to get build working 2025-06-05 15:42:45 +02:00
app App: add "no google play services needed" explanation 2025-06-12 13:36:05 +02:00
assets Merge branch 'master' into develop 2025-06-12 13:37:19 +02:00
Docs Scripts: improve documentation and try to speed up things 2025-06-04 21:17:44 +02:00
langs Chore: remove obsolete log, translation sync 2025-06-12 14:42:25 +02:00
LICENSES Fix: SPDX-compliance 2023-07-27 14:34:05 +02:00
public Feature(opening_hours): correctly display "open ended" opening hours, see #2438 2025-06-12 14:32:22 +02:00
scripts Scripts: fix delete 2025-06-05 12:34:55 +02:00
src Chore: add test case 2025-06-13 01:14:24 +02:00
test Chore: fix tests: use UTC in tests 2025-06-12 15:23:48 +02:00
.editorconfig feat: add prettier config 2022-09-08 20:57:11 +02:00
.eslintignore Add basic ESLint configuration 2023-07-27 13:03:27 +02:00
.eslintrc.cjs Change environment, fix some linting errors 2023-07-27 14:48:17 +02:00
.git-blame-ignore-revs chore: add prettier to blame ignore 2022-09-09 21:55:39 +02:00
.gitignore Chore: ignore 'bing.json' 2025-03-16 22:49:47 +01:00
.gitmodules Update submodule home 2025-04-28 13:19:44 +02:00
.gitpod.yml chore: Update gitpod and vscode config 2023-03-19 19:37:16 +01:00
.nvmrc Use later node version 2025-02-06 19:16:51 +01:00
.prettierignore Ignore some generated files in prettier 2023-12-06 02:55:51 +01:00
.prettierrc.json Prettier: Fix new line setting 2023-06-15 06:04:39 +02:00
.tool-versions Use node16 and asdf 2021-09-22 18:56:51 +02:00
.versionrc.json Add feature section to versionrc 2025-04-19 23:40:52 +02:00
404.html Fix: extract goatcounter to update hash 2025-06-04 21:17:44 +02:00
capacitor.config.ts chore: automated housekeeping... 2025-05-03 23:50:24 +02:00
CHANGELOG.md chore(release): 0.51.11 2025-06-05 18:27:46 +02:00
CODE_OF_CONDUCT.md Create CODE_OF_CONDUCT.md 2022-10-05 01:13:18 +02:00
config.json CI: add extra config file for easier per-deployment veriations, add hetzner deploy script 2023-09-25 03:14:41 +02:00
CONTRIBUTING.md Chore: Remove more GH references (#2374) 2025-04-07 19:10:11 +02:00
index.html Fix: extract goatcounter to update hash 2025-06-04 21:17:44 +02:00
inspector.html Fix: extract goatcounter to update hash 2025-06-04 21:17:44 +02:00
land.html Chore: update to OAuth 2.0, fix #1548 2023-09-01 21:36:39 +02:00
package-lock.json chore(release): 0.51.11 2025-06-05 18:27:46 +02:00
package.json chore(release): 0.51.11 2025-06-05 18:27:46 +02:00
postcss.config.cjs 🚧 First svelte component 2023-02-08 01:18:56 +01:00
privacy.html Fix: extract goatcounter to update hash 2025-06-04 21:17:44 +02:00
README.md Update README.md - Correct analytics link formatting 2025-02-15 18:01:14 +01:00
statistics.html Fix: extract goatcounter to update hash 2025-06-04 21:17:44 +02:00
status.html Fix: extract goatcounter to update hash 2025-06-04 21:17:44 +02:00
studio.html Fix: extract goatcounter to update hash 2025-06-04 21:17:44 +02:00
style_test.html Fix: css-generate script; loading of stylesheet in style_test, add small buttons to style_test 2023-09-16 02:27:29 +02:00
svelte.config.js Cleanup vite.config.js and fix scripts in package.json 2023-02-09 14:06:23 +01:00
tailwind.config.cjs Refactoring: fix statistics in onwheels theme 2025-03-04 22:21:24 +01:00
test.html Chore: remove mentions of no longer existing CSS-file 2025-02-25 02:15:41 +01:00
theme.html Fix: extract goatcounter to update hash 2025-06-04 21:17:44 +02:00
tsconfig.json Merge develop 2025-01-22 01:26:12 +01:00
tslint.json Update doctestts, add lint config 2022-04-08 17:59:14 +02:00
vite.config.js Merge develop 2025-01-22 01:26:12 +01:00
vitest.config.ts Fix tests 2024-01-07 17:59:10 +01:00

MapComplete

Let a thousand flowers bloom

Liberapay Matrix

MapComplete is an OpenStreetMap viewer and editor. The main goal is to make it trivial to see and update information on OpenStreetMap, also for non-technical users. This is achieved by showing only features related to a single topic on the map. MapComplete contains many thematic maps, each built for a certain community of users, showing data and questions that are highly relevant for this topic. By showing only objects on a single topic, contributors are not distracted by objects that are not relevant to them. Furthermore, this allows to show (and ask for) attributes that are highly specialized (e.g. a widget that determines tree species based on pictures) but also by reusing common attributes and elements (such as showing and adding opening hours or pictures).

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, especially generic geometry editing. (Splitting roads is possible; in some restricted themes, geometry conflation is also possible). If adding geometry would be supported, we'd also have to show all geometries (to avoid accidental intersections). This would invite showing and editing other geometries as well, resulting in a general-purpose editor. However, we already have an excellent, web-based general purpose editor.

More about MapComplete: Watch Pieter's talk on the 2021 State Of The Map Conference (YouTube) about the history, vision and future of MapComplete.

How is it different from StreetComplete?

This is the repository of Map Complete. Street Complete is an Android-only application where the contributor is shown some questions to solve, after which the pin will dissappear from the map.

StreetComplete can thus be seen as a Todo-map for contributors who go on a stroll, whereas MapComplete is a website showing relevant information and which allows adding or updating information.

The codebases are separate, even though many ideas and some artwork are copied from the StreetComplete app.

Documentation

All documentation can be found in the documentation directory

Dev

To develop or deploy a version of MapComplete, have a look to the guide.

Creating your own theme

It is possible to quickly make and distribute your own theme, please read the documentation on how to do this.

The main developer is currently not taking requests for new themes (unless they are commissioned). There are simply too many good thematic maps to make. We do however encourage you to try to create your own theme yourself - we'll gladly accept it as an official theme if it meets the criteria.

Examples

There are plenty more. Discover them in the app.

Statistics

To see statistics, consult OsmCha or the analytics page.

The first ever (testing) changeset https://www.openstreetmap.org/changeset/85856178 and first proper changeset: https://www.openstreetmap.org/changeset/85903433

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 is now transformed into a contributor.

    • 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 official 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.

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,...

Translating MapComplete

The core strings and builtin themes of MapComplete are translated on Weblate. You can easily make an account and start translating in their web-environment - no installation required.

You can even jump to the right translation string directly from MapComplete:

Translation status

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 uploaded 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 transferred 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.

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 through the device's GPS location (so no geolocation is sent to Google).

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

Attribution and Copyright

The code is available under GPL; all map data comes from OpenStreetMap (both foreground and background maps).

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

Icons are attributed in various 'license_info.json'-files and can be found in the app.