X-Git-Url: https://git.openstreetmap.org./nominatim-ui.git/blobdiff_plain/19f626c2a6f4bb6b1b86c640b49a37c6faa1eb3e..f357bd32747fb38f00f59e65f74ae0dfcc4d5da6:/dist/handlebar_helpers.js?ds=sidebyside diff --git a/dist/handlebar_helpers.js b/dist/handlebar_helpers.js index 4d1889f..36deacd 100644 --- a/dist/handlebar_helpers.js +++ b/dist/handlebar_helpers.js @@ -13,6 +13,13 @@ function formatOSMType(sType, bExcludeExternal) { return ''; } +function formatShortOSMType(sType) { + if (sType === 'node') return 'N'; + if (sType === 'way') return 'W'; + if (sType === 'relation') return 'R'; + return ''; +} + function getIcon(aPlace) { // equivalent to PHP Nominatim::ClassTypes::getIcon // covers 83 of 214 available icon filenames, e.g. transport_roundabout_anticlockwise @@ -115,10 +122,7 @@ Handlebars.registerHelper({ return formatOSMType(sType, bExcludeExternal); }, shortOSMType: function (sType) { - if (sType === 'node') return 'N'; - if (sType === 'way') return 'W'; - if (sType === 'relation') return 'R'; - return ''; + return formatShortOSMType(sType); }, // { osm_type: 'R', osm_id: 12345 } // relation 12345' + sTitle + '' ); }, - // { osm_type: 'R', osm_id: 12345 } - // details - detailsLink: function (aFeature, sTitle) { - if (!aFeature) return ''; - if (!aFeature.place_id) return ''; - - var sTitleEscaped = Handlebars.escapeExpression(sTitle || 'details >'); - - return new Handlebars.SafeString( - '' + sTitleEscaped + '' - ); - }, - detailsPermaLink: function (aFeature, sTitle) { + // 'details.html?osmtype=R&osmid=2181874&class=boundary' + detailsURL: function (aFeature) { if (!aFeature) return ''; - var sOSMType = formatOSMType(aFeature.osm_type, false); + var sOSMType = aFeature.osm_type; + if (sOSMType && sOSMType.length !== 1) { + sOSMType = formatShortOSMType(aFeature.osm_type, false); // node => N + } if (!sOSMType) return ''; - var sTitleEscaped = Handlebars.escapeExpression(sTitle || sOSMType + ' ' + aFeature.osm_id); - - var sURL = 'details.html?osmtype=' + aFeature.osm_type + '&osmid=' + aFeature.osm_id; - if (aFeature.category) { + var sURL = 'details.html?osmtype=' + sOSMType + '&osmid=' + aFeature.osm_id; + if (aFeature.class) { + sURL = sURL + '&class=' + aFeature.class; + } else if (aFeature.category) { sURL = sURL + '&class=' + aFeature.category; } - - return new Handlebars.SafeString( - '' + sTitleEscaped + '' - ); + return sURL; }, formatPlaceType: function (aPlace) { var sOut = aPlace.class + ':' + aPlace.type; @@ -184,16 +177,25 @@ Handlebars.registerHelper({ coverageType: function (aPlace) { return (aPlace.isarea ? 'Polygon' : 'Point'); }, - // fDistance is in meters - formatDistance: function (fDistanceMeters) { - if (fDistanceMeters < 1) return '0'; + formatDistance: function (fDistance, bInMeters) { + if (bInMeters) { + if (fDistance < 1) return '0'; + var sFormatted = (fDistance >= 1000) + ? Math.round(fDistance / 1000, 1) + ' km' + : Math.round(fDistance, 0) + ' m'; + + return new Handlebars.SafeString( + '~' + sFormatted + '' + ); + } - var formatted = (fDistanceMeters >= 1000) - ? Math.round(fDistanceMeters / 1000, 1) + ' km' - : Math.round(fDistanceMeters, 0) + ' m'; + // spheric distance, http://postgis.net/docs/ST_Distance_Spheroid.html + if (fDistance === 0) return '0'; return new Handlebars.SafeString( - '~' + formatted + '' + '~' + + (Math.round(fDistance * 1000, 4) / 1000) + + '' ); }, // mark partial tokens (those starting with a space) with a star for readability