/overpass-layer

Show a Leaflet layer using OpenStreetMap data from Overpass API via OverpassFrontend.

Primary LanguageJavaScriptGNU General Public License v3.0GPL-3.0

overpass-layer

Show a Leaflet layer using OpenStreetMap data from Overpass API via overpass-frontend.

API

constructor OverpassLayer(options)

Create a Layer with an Overpass query and optional options.

Options:

  • id: an optional id, which will be passed as sublayer_id to twig templates (see below).

  • query: e.g. node[natural=tree];. Combine queries with: (way[building];relation[building];);. Optionally zoom-dependend queries can be given by using an object with the minimum zoom level as index, e.g. { 13: 'way[landuse=forest]', 15: '(way[landuse=forest];node[natural=tree];)' }: zoom levels 13 and 14 all forests will be shown, from zoom level 15 all forests and trees.

  • overpassFrontend: An OverpassFrontend object (defaults to the global variable overpassFrontend)

  • minZoom: Show layer only from the given zoom level (default: 16)

  • maxZoom: Show layer only up to the given zoom level (default: no limit)

  • styles: Array of style-id which should be shown. Default: ['default']. May be overridden by a feature dependant styles array. Can be a comma-separated string.

  • updateAssets: a function which will be called for all map feature specific HTML contexts. It can be used to update URLs of imgs. It will be passed the following parameters: domNode (the node which should be updated), objectData (data of the map feature), layer (the layer object).

  • feature: an object describing how the feature will be formated resp. styled. Each of the values may be either a function which will be passed an OverpassObject or a string which will be processed with the templating language TwigJS:

    • styles: Array of style-id which should be shown. If not set, the value of the parent 'styles' values will be used. Can be a comma-separated string.
    • style: An object or a function or a TwigJS template (string), styling the resulting map feature. Style-Id: "default".
      • If an object is used, e.g.: { weight: 2, fillColor: 'red' }
      • If a function is used, the function will be passed the OverpassObject object and should return the style as object.
      • If a TwigJS template is used, the template should create lines with "key: value" (E.g. color: red\nweight: 2). See below for possible patterns.
    • "style:*": Additional styles with the style-id as suffix (e.g. "style:casing").
    • title: the title of the feature popup and the object in the list.
    • body: the body of the feature popup.
    • description: a short description shown in the list (or in the popup).
    • popupDescription: a short description shown in the popup (when undefined, use 'description').
    • markerSymbol: a HTML string which will be shown as marker. The first dom node may contain 'width', 'height' (iconSize), 'anchorX', 'anchorY' (iconAnchor), 'popupAnchorX', 'popupAnchorY' (popupAnchor), 'signAnchorX', 'signAnchorY' (anchor for markerSign) properties to override the default marker.anchor property.
    • markerSign: a HTML string which will be shown within the icon.
    • priority: a numeric value by which the elements in the list will be sorted (lower values first)
    • appUrl: an url for the link of an item in the list, default: '#'.
  • queryOptions: options for OverpassFrontend.BBoxQuery.

  • styleNoBindPopup: array, list of styles where popup should not bind to. Default: []

  • stylesNoAutoShow: array, list of styles which should not automatically be shown.

  • The following feature properties define behaviour in lists. Default prefix is 'list':

    • Exclude: (boolean) If true, object will not be shown in the list.
  • const: an object variable which is available as prefix in twig functions. See below.

    • Title: the title of the object in the list (override 'title')
    • MarkerSign: a HTML string which will be shown within the icon in the list (default: value of 'markerSign').
    • MarkerSign: a HTML string which will be shown within the icon in the list (default: value of 'markerSign').
    • Description: a HTML string which will be shown as description shown in the list (default: value of 'description').

TwigJS templates

The data of an object is available as patterns. Tags and Meta information is only available, if these properties have been downloaded (see option 'properties'). Variables will automatically be HTML escaped, if not the filter raw is used, e.g.: {{ tags.name|raw }}.

The templates will be rendered when the object becomes visible and when the zoom level changes.

  • id (the id of the object is always available, prefixed 'n' for nodes, 'w' for ways and 'r' for relations; e.g. 'n1234')
  • osm_id (the numerical id of the object)
  • sublayer_id (the id of the sub layer)
  • type ('node', 'way' or 'relation')
  • tags.* (all tags are available with the prefix tags., e.g. tags.amenity)
  • meta.timestamp (timestamp of last modification)
  • meta.version (version of the object)
  • meta.changeset (ID of the changeset, the object was last modified in)
  • meta.user (Username of the user, who changed the object last)
  • meta.uid (UID of the user, who changed the object last)
  • members: Array of member objects (if loaded)
  • members[].id: id of member
  • members[].tags: tags of member (if loaded)
  • members[].meta: meta of member (if loaded)
  • members[].sequence: member is nth element
  • members[].role: member has role
  • masters: Array of links to current master objects:
  • masters[].id: id of relation
  • masters[].tags: tags of relation
  • masters[].meta: meta of relation
  • masters[].sequence: current object is nth member
  • masters[].role: current object has role
  • map.zoom (Current zoom level)
  • const.* (Values from the 'const' option)

Examples: Amenity: {{ tags.amenity }}: might render as "Amenity: restaurant" {% if tags.cuisine=='pizza' %}🍕{% else %}🍴{% endif %}: might render as "🍴" {% for k, v in tags %}{{ k }}: {{ v }}<br/>{% endfor %}: list all tags with "key: value" <a href="{{ tags.website }}">{{ tags.name }}</a>: Create a HTML link to the website with the tag name as title.

You can access the twig instance via OverpassLayer.twig for extending (e.g. with custom functions or filters). Use OverpassLayer.twig.extendFunction(...).

If you set an arbitrary value within a twig template (e.g.: {% set foo = "bar" %}), it will also be available in further templates of the same object by using (e.g.: {{ foo }}). The templates will be evaluated in the order as they are defined.

method addTo(map)

Add layer to the given map.

method remove()

Removes the OverpassLayer and all its features.

method recalc()

Calculates the object data for each visible feature and call the update event.

method get(id, callback)

Load the given object, even if it should not be shown in the given layer / at the current zoom level.

The callback will be called with the following parameters: err, ob (see event onAppear).

method show(id, options, callback)

Show the given object, even if it should not be shown in the given layer / at the current zoom level.

The options parameter influences how the object should be shown. (Consecutive calls of show() will override the options of previous calls).

Available options:

  • styles: Aside from the styles which are shown from the general options, show additional styles. (Array)

The callback will be called with the following parameters: err, ob, data (see event 'appear').

method hide(id)

Hide the given object, resp. remove show options. If it is shown due to layer definition, it will still be visible.

method twigData(object)

Return twig data for object (for rendering).

event 'add', Paramters: ob, data

Will be called when an object appears on the map (e.g. load from server, zoom in, viewport moves in)

Parameter:

  • ob: an OverpassObject object
  • data.id: Unique ID of the object (e.g. 'w1234')
  • data.object is an instance of OSMObject (see OverpassFrontend for details)
  • data.data are the parsed options for the current object.
  • data.features: an object with all leaflet feature which show the object. Index is the id of the style (e.g. 'highlight' for 'style:highlight'. 'default' for 'style').
  • data.feature: the first leaflet feature (of the styles array). it will be used for binding popups to.
  • data.featureMarker: the leaflet marker, if a marker is shown on the object
  • data.popup: the popup, which is attached to the object (even if it is not shown)
  • data.styles: array of style-ids which are currently active
  • data.isShown: whether the object is currently shown on the map (boolean)
  • data.listItem: DOM node of the list item which shows this object (if item is shown and a list has been added for this layer)

event 'remove', Parameters: ob, data

Will be called when an object disappears from the map (e.g. zoom out, pan out, ...)

See appear for the description of parameters.

event 'zoomChange', Parameters: ob, data

Will be called every time when the zoom level changes. Occurs instantly after zoom level change for each object, before assessing if the object is visible at the current zoom level.

See appear for the description of parameters.

event 'update', Parameters: ob, data

Called every time, when the object is being re-calculated (also when zoom level changes).

See appear for the description of parameters.

event 'twigData', Parameters: ob, data, result

Called for every object on re-calculation. Result is the twigData which will used for evaluating each object. Any listeners may modify this result object.

See appear for the description of other parameters.

Optional features

Text along lines

npm install --save https://github.com/makinacorpus/Leaflet.TextPath#leaflet0.8-dev

Include script:

<script src="node_modules/leaflet-textpath/leaflet.textpath.js"></script>

Line offset

npm install --save leaflet-polylineoffset

Include script:

<script src="node_modules/leaflet-polylineoffset/leaflet.polylineoffset.js"></script>

Pattern

npm install --save leaflet-polylinedecorator

Include script:

<script src="node_modules/leaflet-polylinedecorator/dist/leaflet.polylineDecorator.js"></script>

Each style can have these additional values:

  • pattern: false/empty: no pattern, 'arrowHead', 'dash', 'marker'
  • pattern-offset: Offset of the first pattern symbol, from the start point of the line. Default: 0.
  • pattern-endOffset: Minimum offset of the last pattern symbol, from the end point of the line. Default: 0.
  • pattern-repeat: Repetition interval of the pattern symbols. Defines the distance between each consecutive symbol's anchor point.

Depending on the type of pattern, the following options are available:

  • arrowHead:

  • pattern-polygon: true/false

  • pattern-pixelSize: size of pattern

  • pattern-headAngle: Angle of the digits

  • pattern-angleCorrection: degrees (see #88)

  • dash:

  • pattern-pixelSize: size of pattern

  • marker:

  • pattern-rotate: false

  • pattern-angleCorrection: degrees

To set path options use the prefix pattern-path-, e.g. pattern-path-width or pattern-path-color.