X-Git-Url: https://git.openstreetmap.org./nominatim-ui.git/blobdiff_plain/c38f9ad9ee9adc2955644392bc4ad21c2c06ca81..e322758be287af4362499df4c8b6703eb0bcda18:/dist/handlebar_helpers.js diff --git a/dist/handlebar_helpers.js b/dist/handlebar_helpers.js index 3ece852..bbb6e16 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; @@ -240,28 +233,26 @@ Handlebars.registerHelper({ } return ''; }, - formatSearchRank: function (iRank) { - // same as - // https://github.com/osm-search/Nominatim/blob/master/sql/functions.sql - // get_searchrank_label() - - if (iRank < 2) return 'continent'; - if (iRank < 4) return 'sea'; - if (iRank < 8) return 'country'; - if (iRank < 12) return 'state'; - if (iRank < 16) return 'county'; - if (iRank === 16) return 'city'; - if (iRank === 17) return 'town / island'; - if (iRank === 18) return 'village / hamlet'; - if (iRank === 20) return 'suburb'; - if (iRank === 21) return 'postcode area'; - if (iRank === 22) return 'croft / farm / locality / islet'; - if (iRank === 23) return 'postcode area'; - if (iRank === 25) return 'postcode point'; - if (iRank === 26) return 'street / major landmark'; + formatAddressRank: function (iRank) { + if (iRank < 4) return 'other'; + if (iRank < 6) return 'country'; + if (iRank < 8) return 'region'; + if (iRank < 10) return 'state'; + if (iRank < 12) return 'state district'; + if (iRank < 14) return 'county'; + if (iRank < 16) return 'municipality'; + if (iRank < 18) return 'city / town / village'; + if (iRank < 20) return 'city / village district'; + if (iRank < 22) return 'suburb / hamlet'; + if (iRank < 24) return 'neighbourhood'; + if (iRank < 26) return 'city block / square'; + if (iRank === 26) return 'major street'; if (iRank === 27) return 'minory street / path'; - if (iRank === 28) return 'house / building'; - return 'other: ' + iRank; + if (iRank <= 30) return 'house / building'; + return 'other'; + }, + isAdminBoundary: function (aPlace) { + return aPlace.category === 'boundary' && aPlace.type === 'administrative'; }, tooManyHierarchyLinesWarning: function (aPlace) { if (!aPlace.hierarchy) return '';