This is a fork of the world wide map veggiekarte from piratenpanda. This map is for local use. Improvements will be added to the upstream project.
A OpenStreetMap based map to easily find places, like restaurants and cafes, with vegetarian and vegan options.
You can use it in any modern browser or install it as an app (as an PWA).
There are several ways to get involved:
- Improve the data on OpenStreetMap
- Add missing places
- Add and correct information (like opening hours) of places
- Check and fix issues on https://veggiekarte.de/datacheck/
- Report issues
- Help to translate
- Translate to new languages - take locales/en.json as template.
- Complete translations: locales/ko.json is incomplete.
- Participate in development
- Write reviews for places on https://lib.reviews/
The most important keys for us are diet: vegan and diet: vegetarian. These keys are used to determine whether a place is shown on the Veggiekarte or not.
You can find an overview of which other keys we use at Taginfo.
This is an overview of the third-party software and data we use. Many thanks to the open source community, especially to the authors of the following projects! ❤️ 🍻
software | license | version | purpose |
---|---|---|---|
chart.js | MIT * | 4.4.0 | JavaScript library to create charts. We use this in the data_chart.html . |
i18next | MIT * | 24.2.0 | JavaScript internationalization framework. |
leaflet | BSD-2-Clause * | 1.9.4 | JavaScript library to create interactive maps. |
leaflet.control.geocoder | BSD-2-Clause * | 3.1.0 | A control to locate places. The button with the magnifier 🔍. |
leaflet.easybutton | MIT * | 2.4.0 | Adding buttons. We are using it for the info button. |
leaflet.featuregroup.subgroup | BSD-2-Clause * | 1.0.2 | Dynamically add/remove groups of markers. |
leaflet.fullscreen | MIT * | 3.0.2 | Add a fullscreen button. |
modern.leaflet.hash | MIT * | 1.1.1 | Add coordinate hashes to the URL in the browser address field. |
leaflet.languageselector | CC0 * | 1.2.5 | A control to switch between languages. |
leaflet.locatecontrol | MIT * | 0.82.0 | A control to locate the position of the user. |
leaflet.markercluster | MIT * | 1.5.5 | Marker Clustering plugin. |
opening_hours.js | LGPL-3.0-only * | 3.8.0 | Library to parse and process the opening_hours tag from OpenStreetMap data. |
OpenStreetMap | CC BY-SA * | There we get the data of the places. We also show the markers on an OpenStreetMap map. | |
icons from OpenStreetMap Carto | CC0 * | Default marker icons | |
icons from Maki | CC0 | Fallback marker icons | |
veggiepenguin | CC0 * | Favicon |
We use node.js for a few developer tools. For the operation of veggiekarte node.js is not necessary.
To use the tools you have to run npm install
once to install the required packages. The prerequisite is that you have node.js installed on your system.
To produce a more consistent code we use ESLint and Prettier.
To test whether the linter and prettier rules are complied with in the code, execute the following command: npm run lint
.
If errors occur, you can use the following command to eliminate some of the errors: npm run lint:fix
.
We use some 3rd party software for veggiekarte. So that the browser doesn't have to download an extra JavaScript file for each one, we bundle our JavaScript code with the 3rd party software in one package. In some cases, unused code is also discarded (treeshaking) - but unfortunately not all plugins are designed for treeshaking yet. This makes the website load faster.
A new bundle must be build after each change to the code. Use this command to do that: npm run build
.
For test purposes, you can also bypass the bundling process by changing this line
<script src="js/bundle.js" type="module"></script>
to this
<script src="js/veggiemap.js" type="module"></script>
in the index.html.
Run python3 refresh.py
to get new data from OpenStreetMap.
Run python3 datacheck/datacheck.py
to run the data check on the data.
To create a new release, you have to run the following command: npm run release
. This will run the following steps:
- Run the linter and fix some errors.
- Build the bundle.
- Update the version in the package.json, package-lock.json and the bundle.js. And add a new tag to the git repository.
The changes are not pushed to the repository. You have to do that manually after checking the changes.