From 7a00288ff927c3b7f2b8f6445d85b41ba04972f8 Mon Sep 17 00:00:00 2001 From: Tobias Date: Wed, 7 Aug 2024 12:32:07 +0200 Subject: [PATCH] Docs: Extended guidelines for presets, fields, deprecations (#1229) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit This is heavily inspired by https://github.com/streetcomplete/StreetComplete/blob/master/QUEST_GUIDELINES.md – thanks a lot See also: * https://github.com/openstreetmap/id-tagging-schema/issues/401#issuecomment-1133035676 * https://github.com/openstreetmap/id-tagging-schema/pull/1229#discussion_r1669753917 * https://github.com/openstreetmap/id-tagging-schema/pull/1229/files/6776de01e228681d671186e8bc7d412c22aaabd0#r1669745086 --- CONTRIBUTING.md | 9 +++---- GUIDELINES.md | 64 +++++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 67 insertions(+), 6 deletions(-) create mode 100644 GUIDELINES.md diff --git a/CONTRIBUTING.md b/CONTRIBUTING.md index 595c6414..f246f98f 100644 --- a/CONTRIBUTING.md +++ b/CONTRIBUTING.md @@ -1,3 +1,5 @@ +# Contributing to the tagging schema + ## Submitting Issues Don't hesitate to submit feedback about issues or how the tagging schema could be improved, but please [search existing issues](https://github.com/search?l=&q=repo%3Aopenstreetmap%2Fid-tagging-schema&type=Issues) before [opening a new one](https://github.com/openstreetmap/id-tagging-schema/issues/new/choose). @@ -7,12 +9,7 @@ iD's [code of conduct](https://github.com/openstreetmap/iD/blob/release/CODE_OF_ ## General Guidelines -As a general guideline, the tagging schema will only consider tags that are documented on the OSM wiki and have completed a [proposal process](https://wiki.openstreetmap.org/wiki/Proposal_process) or can in some other way be considered as _accepted_ by the OpenStreetMap community. - -As the tagging schema is meant to be a general representation of the OSM data for a wide audience of users, some tags might be considered out of scope: for example when a tag requires expert knowledge to be used, or when a tag is extremely rare. - -Tags which are not universally applicable globally, can and should be limited to their respective region in the corresponding preset or field of this repository. - +Read the [GUIDELINES](./GUIDELINES.md) to help you understand what fields and tags should be added to the tagging schema. ## Translating diff --git a/GUIDELINES.md b/GUIDELINES.md new file mode 100644 index 00000000..479823ca --- /dev/null +++ b/GUIDELINES.md @@ -0,0 +1,64 @@ +# Guidelines for the Tagging Schema + +Do you have an idea for a new preset or field? Read this! + +## 1. Evaluate Your Idea for the Tagging Schema Project + +Adding a preset or field to the tagging schema is a significant responsibility. +We must ensure that both new and experienced users can understand the presets and fields, +thereby contributing high-quality data to OpenStreetMap (OSM). + +Consider the following: + +### General Guidelines + +- 📋 **Established Documentation**: The tagging schema will only consider tags that are well-documented on the OSM wiki. The documentation should be clear and unambiguous. +- 🏷️ **Established Tags Only**: No new or unestablished tags should be part of presets. Establishing tags must remain a community-driven process, not dictated by software implementation. +- ✅ **Proposal or Accepted**: A tag is considered established when it has completed the [proposal process](https://wiki.openstreetmap.org/wiki/Proposal_process) or is otherwise accepted by the OSM community. Factors include the tag's duration and frequency of use, whether its usage is increasing over time and it's usage by mainstream data consumers. +- 🤷 **Useful Purpose**: Especially for less established tags, presets and fields should have a practical application. OSM allows for the collection of a wide variety of data, but not all of it is useful. For example, the brightness of street lamps might be documented, but it doesn't necessarily warrant a preset or field. +- 🕓 **Effort vs. Impact**: Consider whether the effort required is justified by the impact the preset or field will have. Assess how many elements this new type will apply to. This is particularly important if you do not plan to contribute the code changes yourself through a pull request (PR). + +### User Experience + +No preset or field is isolated; they are always presented alongside others in various user interfaces that utilize the tagging schema. + +- 🔦 **Easy to Pick**: Users must be able to understand and select the correct preset given the limited information available in the user interfaces. Good presets guide the user with clear names and helpful additional documentation `(i)`. +- 🔎 **Easy to Search**: When searching, similar presets will appear next to each other. Consider and test typical search scenarios. You might need to adjust the names and documentation of other presets to ensure users can make the best decision. +- 👨‍💻 **Users Are Not Experts**: No prior knowledge of OpenStreetMap or any other background information should be necessary. +- 🐿️ **Easy Answer**: Users are often on the go and impatient. Fields should allow for quick, straightforward, and clear answers. + +### Situational Presets + +- 🙈 **Unsearchable Presets**: The tagging schema is not only for adding information but also for presenting existing information. Consider adding an unsearchable preset for tagging that should be highlighted with a preset on the map and with defined fields. Reasons to make a preset unsearchable include: multiple ways to tag something where one method is preferred, or other reasons to hide commonly used tags from the search and list interface to preserve a good [user experience](#user-experience). +- 🏝️ **Local Presets and Fields**: Generally, presets and fields in OSM should be globally applicable, and efforts should be made to ensure this. However, when local tagging conventions exist or when presets only make sense for certain regions, presets and fields can be given a local filter. This increases the need for thorough testing and makes it more challenging to maintain a good [user experience](#user-experience). + +### Tag Updates and Additions + +- ➕ **Suggested Additions**: Presets can suggest additional tags. These suggestions must be clearly supported by the wiki and community consensus. +- 🔄 **Updates**: Deprecation rules can suggest updating tags. Good documentation and consensus are needed for these deprecations. + +In both cases, _indicators for consensus_ are: +- The deprecation is documented in the wiki and is either official (resulting from a proposal process) or long-standing (about a year). +- There is a significant drop in usage compared to current numbers, with a negative trend ([visible in the graph](https://taghistory.raifer.tech/)). +- Usage of the deprecated tag remains stagnant for a longer period (about a year). + +## 2. Design the Preset + +The user interface must be clear, concise, and easy to use, leaving no room for misunderstandings. + +- Define the tags required on an object to trigger the preset. +- Choose a name, category, and define a list of American English search terms. +- Use Title Case for the the preset `name` and [`aliases`](https://github.com/ideditor/schema-builder?tab=readme-ov-file#aliases) as well as the field [`label`](https://github.com/ideditor/schema-builder?tab=readme-ov-file#label) property. Use lower case for the preset [`terms`](https://github.com/ideditor/schema-builder?tab=readme-ov-file#terms) (sorted A-Z) and Title Case or sentences for preset's [`strings`-`options`](https://github.com/ideditor/schema-builder?tab=readme-ov-file#strings). +- Check the search functionality to ensure other presets do not cause confusion. +- Select an icon or start the process to create a new one. +- Define which fields to show (`fields`) and suggest (`moreFields`), considering the order of fields. +- Check the `(i)` documentation and add or update the Wikidata item if needed to provide a helpful short text. +- Use the PR preview to add test cases with deep links to OSM objects that demonstrate the preset in use. + +## 3. Implement + +If you are familiar with `JSON`, you can implement the preset or field yourself. First, create a ticket to introduce your quest idea and discuss it with the community to get feedback on its feasibility and desirability. After implementation, create a pull request to get it merged. + +For more details on adding presets, see ["Making changes"](./CONTRIBUTING.md#making-changes). + +If you are not familiar with `JSON`, still create a ticket. The more you have considered and prepared from the above steps, the easier it will be for someone else to code it.