forked from OpenStreetBrowser/main
172 lines
7.7 KiB
172 lines
7.7 KiB
{
|
|
"type": "overpass",
|
|
"name": {
|
|
"de": "Radrouten",
|
|
"en": "Cycle Routes",
|
|
"fr": "Itinéraires vélo",
|
|
"hu": "Kerékpáros útvonalak",
|
|
"pt": "Ciclovias",
|
|
"pt-br": "Ciclorrotas"
|
|
},
|
|
"query": {
|
|
"6": "relation[type=route][route~\"(|.*;)bicycle(|;.*)\"][network~'^(icn)$']",
|
|
"9": "relation[type=route][route~\"(|.*;)bicycle(|;.*)\"][network~'^(icn|ncn)$']",
|
|
"12": "relation[type=route][route~\"(|.*;)bicycle(|;.*)\"][network~'^(icn|ncn|rcn)$']",
|
|
"15": "relation[type=route][route~\"(|.*;)bicycle(|;.*)\"]"
|
|
},
|
|
"members": true,
|
|
"feature": {
|
|
"title": "{% if tags.ref and tags.name %}{{ tags.ref }} - {{ tags.name }}{% elseif tags.ref %}{{ tags.ref }}{% elseif tags.name %}{{ tags.name }}{% else %}{{ trans('unnamed') }}{% endif %}",
|
|
"description": "{{ tagTrans('network', tags.network) }}",
|
|
"markerSymbol": "",
|
|
"listMarkerSymbol": "{{ markerLine({ 'width': 4, 'color': const[tags.network].color|default(const[''].color) })|raw }}",
|
|
"priority": "{{ const[tags.network].priority|default(4) }}",
|
|
"styles": "",
|
|
"style:hover": {
|
|
"width": "0"
|
|
},
|
|
"style:selected": {
|
|
"width": "0"
|
|
}
|
|
},
|
|
"memberFeature": {
|
|
"pre": [
|
|
"{% set priority = 4 %}",
|
|
"{% set network = '' %}",
|
|
"{% set refs = [] %}",
|
|
"{% set dirForward = false %}",
|
|
"{% set dirBackward = false %}",
|
|
"{% set hover = false %}",
|
|
"{% set selected = false %}",
|
|
"",
|
|
"{% for master in masters %}",
|
|
" {% set _p = const[master.tags.network].priority|default(4) %}",
|
|
" {% if _p < priority %}",
|
|
" {% set priority = _p %}",
|
|
" {% set network = master.tags.network %}",
|
|
" {% endif %}",
|
|
" {% if master.tags.ref %}",
|
|
" {% set refs = refs|merge([ master.tags.ref ]) %}",
|
|
" {% endif %}",
|
|
" {% if master.role == 'forward' %}{% set dirForward = true %}",
|
|
" {% elseif master.role == 'backward' %}{% set dirBackward = true %}",
|
|
" {% else %}{% set dirForward = true %}{% set dirBackward = true %}",
|
|
" {% endif %}",
|
|
" {% if master.flags.hover %}{% set hover = master.role|default('both') %}{% endif %}",
|
|
" {% if master.flags.selected %}{% set selected = master.role|default('both') %}{% endif %}",
|
|
"{% endfor %}"
|
|
],
|
|
"title": "",
|
|
"body": [
|
|
"<h4>Routes</h4>",
|
|
"<ul class='overpass-layer-list'>",
|
|
"{% for master in masters %}",
|
|
" <li data-object=\"{{ master.id }}\">",
|
|
" <span class='markerParent'><div class='marker'>{{ markerLine({ width: 4, color: const[master.tags.network].color|default(const[''].color) })|raw }}</div></span>",
|
|
" <span class='title'>{% if master.tags.ref and master.tags.name %}{{ master.tags.ref }} - {{ master.tags.name|default(master.tags.ref) }}{% elseif master.tags.ref %}{{ master.tags.ref }}{% elseif master.tags.name %}{{ master.tags.name }}{% else %}{{ trans('unnamed') }}{% endif %}</span>",
|
|
" <span class='description'>{{ tagTrans('network', master.tags.network) }}</span>",
|
|
" </li>",
|
|
"{% endfor %}",
|
|
"</ul>"
|
|
],
|
|
"listExclude": "1",
|
|
"styles": "default{% if hover %},hover{% endif %}{% if selected %},selected{% endif %}",
|
|
"style": {
|
|
"width": "4",
|
|
"color": "{{ const[network].color }}",
|
|
"opacity": "1",
|
|
"lineCap": "{% if not dirForward or not dirBackward %}butt{% else %}round{% endif %}",
|
|
"dashArray": "{% if not dirForward or not dirBackward %}27,8{% endif %}",
|
|
"dashOffset": "{% if dirBackward %}28{% else %}0{% endif %}",
|
|
"noClip": "{% if not dirForward or not dirBackward %}true{% else %}false{% endif %}",
|
|
"text": "{{ refs|join(' · ') }} ",
|
|
"textRepeat": "1",
|
|
"textOffset": "12",
|
|
"pattern": "{% if dirForward and dirBackward %}{% else %}arrowHead{% endif %}",
|
|
"pattern-offset": "{% if dirBackward %}4{% else %}30.5{% endif %}",
|
|
"pattern-repeat": "35",
|
|
"pattern-polygon": "true",
|
|
"pattern-pixelSize": "9",
|
|
"pattern-angleCorrection": "{% if dirBackward %}180{% else %}0{% endif %}",
|
|
"pattern-path-width": "0",
|
|
"pattern-path-color": "{{ const[network].color }}",
|
|
"pattern-path-fillOpacity": "1",
|
|
"textFontWeight": "bold"
|
|
},
|
|
"style:hover": {
|
|
"pane": "hover",
|
|
"width": "4",
|
|
"color": "black",
|
|
"lineCap": "{% if hover == 'forward' or hover == 'backward' %}butt{% else %}round{% endif %}",
|
|
"dashArray": "{% if hover == 'forward' or hover == 'backward' %}27,8{% endif %}",
|
|
"dashOffset": "{% if hover == 'backward' %}28{% else %}0{% endif %}",
|
|
"noClip": "{% if hover == 'forward' or hover == 'backward' %}true{% else %}false{% endif %}",
|
|
"pattern": "{% if hover == 'forward' or hover == 'backward' %}arrowHead{% endif %}",
|
|
"pattern-offset": "{% if hover == 'backward' %}4{% else %}30.5{% endif %}",
|
|
"pattern-repeat": "35",
|
|
"pattern-polygon": "true",
|
|
"pattern-pixelSize": "9",
|
|
"pattern-angleCorrection": "{% if hover == 'backward' %}180{% else %}0{% endif %}",
|
|
"pattern-path-width": "0",
|
|
"pattern-path-color": "black",
|
|
"pattern-path-fillOpacity": "1"
|
|
},
|
|
"style:selected": {
|
|
"pane": "selected",
|
|
"width": "4",
|
|
"color": "#3f3f3f",
|
|
"lineCap": "{% if selected == 'forward' or selected == 'backward' %}butt{% else %}round{% endif %}",
|
|
"dashArray": "{% if selected == 'forward' or selected == 'backward' %}27,8{% endif %}",
|
|
"dashOffset": "{% if selected == 'backward' %}28{% else %}0{% endif %}",
|
|
"noClip": "{% if selected == 'forward' or selected == 'backward' %}true{% else %}false{% endif %}",
|
|
"pattern": "{% if selected == 'forward' or selected == 'backward' %}arrowHead{% endif %}",
|
|
"pattern-offset": "{% if selected == 'backward' %}4{% else %}30.5{% endif %}",
|
|
"pattern-repeat": "35",
|
|
"pattern-polygon": "true",
|
|
"pattern-pixelSize": "9",
|
|
"pattern-angleCorrection": "{% if selected == 'backward' %}180{% else %}0{% endif %}",
|
|
"pattern-path-width": "0",
|
|
"pattern-path-color": "#3f3f3f",
|
|
"pattern-path-fillOpacity": "1"
|
|
}
|
|
},
|
|
"const": {
|
|
"icn": {
|
|
"color": "#ff0000",
|
|
"priority": 0,
|
|
"zoom": 6
|
|
},
|
|
"ncn": {
|
|
"color": "#ff00ba",
|
|
"priority": 1,
|
|
"zoom": 9
|
|
},
|
|
"rcn": {
|
|
"color": "#ba00ff",
|
|
"priority": 2,
|
|
"zoom": 12
|
|
},
|
|
"lcn": {
|
|
"color": "#0000ff",
|
|
"priority": 3,
|
|
"zoom": 15
|
|
},
|
|
"": {
|
|
"color": "#007fff",
|
|
"priority": 4,
|
|
"zoom": 15
|
|
}
|
|
},
|
|
"info": [
|
|
"<table>",
|
|
"{% for value, data in const %}",
|
|
"{% if data.zoom <= map.zoom %}",
|
|
" <tr>",
|
|
" <td>{{ markerLine({ 'width': 4, color: data.color })|raw }}</td>",
|
|
" <td>{% if value %}{{ tagTrans('network', value) }}{% else %}{{ trans('unknown') }}{% endif %}</td>",
|
|
" </tr>",
|
|
"{% endif %}",
|
|
"{% endfor %}",
|
|
"</table>"
|
|
]
|
|
}
|