-
Notifications
You must be signed in to change notification settings - Fork 894
Item Property Reference
Each category file contains an Array
of items
that belong to that catetory.
The items can include:
- "Normal" items - items representing brands, flags, routes, or other map features.
- Templates - placeholders that will expand all the normal items from another source category, but modify the source tags to fit the destination category.
You can include both normal and template items in the same items
Array.
"items": [
…
{
"displayName": "McDonald's",
"id": "mcdonalds-658eea",
"locationSet": {"include": ["001"]},
"tags": {
"amenity": "fast_food",
"brand": "McDonald's",
"brand:wikidata": "Q38076",
"brand:wikipedia": "en:McDonald's",
"cuisine": "burger",
"name": "McDonald's"
}
},
…
Normal item properties:
Required | yes |
Type | String |
Example | "McDonald's" |
The displayName
can contain anything, but it should be a short text appropriate for display in lists or as preset names in editor software. This is different from the OpenStreetMap name
tag.
The displayName
should be written in the local language of the item.
displayName
must be unique within a category.
By convention, if you need to disambiguate between multiple brands with the same name, we add text in parenthesis. Here there are 2 items named "Target", but they have been assigned different display names to tell them apart.
In brands/shop/department_store.json
:
"items": [
…
{
"displayName": "Target (Australia)",
"id": "target-c93bbd",
"locationSet": {"include": ["au"]},
"tags": {
"brand": "Target",
"brand:wikidata": "Q7685854",
"brand:wikipedia": "en:Target Australia",
"name": "Target",
"shop": "department_store"
}
},
{
"displayName": "Target (USA)",
"id": "target-592fe0",
"locationSet": {"include": ["us"]},
"tags": {
"brand": "Target",
"brand:wikidata": "Q1046951",
"brand:wikipedia": "en:Target Corporation",
"name": "Target",
"shop": "department_store"
}
},
…
Required | no (generated automatically) |
Type | String |
Example | "mcdonalds-658eea" |
Each item has a unique id
generated for it. When adding a new item, you don't need to add an id
.
The next time npm run build
is run, the id
will be generated automatically.
The identifiers are stable unless the name, key, value, or locationSet change.
Required | yes |
Type | Object {} |
Each item requires a locationSet
to define where the item is available. You can define the locationSet
as an Object with include
and exclude
properties:
"locationSet": {
"include": [ Array of locations ],
"exclude": [ Array of locations ]
}
The "locations" can be any of the following:
-
Strings recognized by the country-coder library. These include ISO 3166-1 2 or 3 letter country codes, UN M.49 numeric codes, and supported Wikidata QIDs. Example:
"de"
-
Filenames for custom
.geojson
features (aka geofence). To reference a custom feature, you'll need to add these under thefeatures/
folder (see Feature Files for more details). Example:"new_jersey.geojson"
- The M49 code for the whole world is
"001"
- A current list of supported codes can be found at https://ideditor.codes
- You can view examples and learn more about working with
locationSets
in the @ideditor/location-conflation project. - You can test locationSets on this interactive map: https://ideditor.github.io/location-conflation/
Required | no |
Type | Array[Strings] |
Brands are often tagged inconsistently in OpenStreetMap. For example, some mappers write "International House of Pancakes" and others write "IHOP".
This project includes a "fuzzy" matcher that can match alternate names and tags to a single entry in the name-suggestion-index. The matcher keeps duplicate items out of the index and is used in the iD editor to help suggest tag improvements.
matchNames
and matchTags
properties can be used to list the less-preferred alternatives.
"properties": {
"path": "brands/amenity/fast_food" // all items in this file will match the tag `amenity=fast_food`
…
},
"items": [
…
{
"displayName": "Honey Baked Ham",
"id": "honeybakedham-4d2ff4",
"locationSet": { "include": ["us"] },
"matchNames": ["honey baked ham company"], // also match these less-preferred names
"matchTags": ["shop/butcher", "shop/deli"], // also match these less-preferred tags
"tags": {
"alt_name": "HoneyBaked Ham", // match `alt_name`
"amenity": "fast_food",
"brand": "Honey Baked Ham", // match `brand`
"brand:wikidata": "Q5893363",
"brand:wikipedia": "en:The Honey Baked Ham Company",
"cuisine": "american",
"name": "Honey Baked Ham", // match `name`
"official_name": "The Honey Baked Ham Company" // match `official_name`
}
},
…
The matcher code also has some useful automatic behaviors…
You don't need to add matchNames
for:
- variations in capitalization, punctuation, spacing (the middots common in Japanese names count as punctuation, so "V・ドラッグ" already matches "vドラッグ")
- variations that already appear in the
name
,brand
,operator
,network
. - variations that already appear in an alternate name tag (e.g.
alt_name
,short_name
,official_name
, etc.) - variations that already appear in any international version of those tags (e.g.
name:en
,official_name:ja
, etc.) - variations in diacritic marks (e.g. "Häagen-Dazs" already matches "Haagen-Dazs")
- variations in
&
vs.and
You don't need to add matchTags
for:
- Tags assigned to match groups (defined in
config/matchGroups.json
). For example, you don't need addmatchTags: ["shop/doityourself"]
to every "shop/hardware" and vice versa. Tags in a match group will automatically match any other tags in the same match group.
👉 Bonus: The build script will automatically remove extramatchNames
andmatchTags
that are unnecessary.
Required | no |
Type | Array[Regex Strings] |
Example | ["^name"] |
For tags matching these regular expressions, values in NSI should not replace an existing value in OSM.
By default, all of the tags as they appear in NSI are how they should appear on an OSM feature. Validator software (such as built into iD) can suggest updates to OSM by comparing an OSM feature's tags against NSI's tags.
In some situations, we want to leave an existing OSM tag value alone. preserveTags
contains an Array of regular expressions to match OSM keys where we want to preserve any existing tag value and never suggest a replacement.
👉 ThepreserveTags
property can be set per-category (applying to all items in a category) or per-item.
preserveTags
is useful for tags such as "^name"
(key starts with "name"), on items where the name
tag is expected to be unique:
- Amazon Locker ("Amazon Locker - Robot")
- Apple Store ("Apple Bridgewater")
See also issue #4906
Required | no |
Type | String |
You can optionally add a note
property to any item. The note can contain any text useful for maintaining the index - for example, information about the brand's status, or a link to a GitHub issue.
The notes just stay with the name-suggestion-index; they aren't OpenStreetMap tags or used by other software.
{
"displayName": "United Bank (Connecticut)",
"id": "unitedbank-28419b",
"locationSet": { "include": ["peoples_united_bank_ct.geojson"] },
"note": "Merged into People's United Bank (Q7165802) in 2019, see https://en.wikipedia.org/wiki/United_Financial_Bancorp",
"tags": { … }
}
Required | yes |
Type | Object {} |
Each item requires a tags
value. This is just an Object containing all the OpenStreetMap tags that should be set on the feature.
Templates can appear in the items
Array alongside the "normal" items.
A template is placeholder that will expand all the normal items from another source category, but modify the source tags to fit the destination category.
Templates are used in the name-suggestion-index to implement several convenient rules:
- For each Bank in
brands/amenity/bank
, create an ATM inbrands/amenity/atm
but with theoperator
set to the bank - For each Post Office in
operators/amenity/post_office
, create a Post Box item inoperators/amenity/post_box
- For each Bus Route in
transit/route/bus
, create a Bus Stop item intransit/highway/bus_stop
- and more…
See also issue #2883
"properties": {
"path": "brands/amenity/atm",
"skipCollection": true,
"exclude": {"generic": ["^atm$"]}
},
"items": [
…
{
"templateSource": "brands/amenity/bank",
"templateTags": {
"amenity": "atm",
"operator": "{source.tags.brand}",
"operator:wikidata": "{source.tags.brand:wikidata}",
"operator:wikipedia": "{source.tags.brand:wikipedia}"
}
},
…
Template item properties:
Required | yes |
Type | String |
Example | "brands/amenity/bank" |
A tree/key/value path to use as the source of the expanded items.
Required | yes |
Type | Object {} |
By default, all source item tags are copied as-is into the destination item tags.
The templateTags
Object contains the tags which should be different (added, modified, or removed).
You can use replacement tokens in the form {source.tags.key}
to refer to source tag values.
For example, to copy the bank brand
tags to ATM operator
tags:
{
"templateSource": "brands/amenity/bank",
"templateTags": {
"amenity": "atm",
"operator": "{source.tags.brand}",
"operator:wikidata": "{source.tags.brand:wikidata}",
"operator:wikipedia": "{source.tags.brand:wikipedia}"
}
},
You can also use empty tags to indicate that a source tag should not be copied.
For example, to expand bus stops for every bus route, you can remove the source route
tag like this:
{
"templateSource": "transit/route/bus",
"templateTags": {
"highway": "bus_stop",
"route": ""
}
}
Required | no |
Type | Array[Regex Strings] |
By default, a template will expand all source items into destination items.
If templateInclude
is specified, only the source items with id
matching the regular expressions in the templateInclude
Array will be included.
See also issue #4866
Required | no |
Type | Array[Regex Strings] |
By default, a template will expand all source items into destination items.
If templateExclude
is specified, source items with id
matching the regular expressions in the templateExclude
Array will be excluded.
See also issue #4866
Contributing to the index
- Feature Files (geofences)
- Using Overpass Turbo
- Config Files
- Property Reference
- Technical Details
Information for developers using the name-suggestion-index in another project.
Information for maintainers, including how to clone and build the project.