mirror of https://github.com/pelias/api.git
112 lines
3.0 KiB
112 lines
3.0 KiB
var logger = require('pelias-logger').get('api'); |
|
|
|
// all the address parsing logic |
|
function addParsedVariablesToQueryVariables( parsed_text, vs ){ |
|
// ==== add parsed matches [address components] ==== |
|
|
|
// query - Mexitaly, Sunoco, Lowes |
|
if (parsed_text.hasOwnProperty('query')) { |
|
vs.var('input:query', parsed_text.query); |
|
} |
|
|
|
// categories - restaurants, hotels, bars |
|
if (parsed_text.hasOwnProperty('category')) { |
|
vs.var('input:category', parsed_text.category); |
|
} |
|
|
|
// house number |
|
if( parsed_text.hasOwnProperty('number') ){ |
|
vs.var( 'input:housenumber', parsed_text.number ); |
|
} |
|
|
|
// street name |
|
if( parsed_text.hasOwnProperty('street') ){ |
|
vs.var( 'input:street', parsed_text.street ); |
|
} |
|
|
|
// neighbourhood |
|
if (parsed_text.hasOwnProperty('neighbourhood')) { |
|
vs.var( 'input:neighbourhood', parsed_text.neighbourhood); |
|
} |
|
|
|
// borough |
|
if (parsed_text.hasOwnProperty('borough')) { |
|
vs.var( 'input:borough', parsed_text.borough); |
|
} |
|
|
|
// postal code |
|
if( parsed_text.hasOwnProperty('postalcode') ){ |
|
vs.var( 'input:postcode', parsed_text.postalcode ); |
|
} |
|
|
|
|
|
// island |
|
if( parsed_text.hasOwnProperty('island') ){ |
|
vs.var( 'input:island', parsed_text.island ); |
|
} |
|
|
|
// ==== add parsed matches [admin components] ==== |
|
|
|
// city |
|
if( parsed_text.hasOwnProperty('city') ){ |
|
vs.var( 'input:locality', parsed_text.city ); |
|
} |
|
|
|
// county |
|
if( parsed_text.hasOwnProperty('county') ){ |
|
vs.var( 'input:county', parsed_text.county ); |
|
} |
|
|
|
// state |
|
if( parsed_text.hasOwnProperty('state') ){ |
|
vs.var( 'input:region', parsed_text.state ); |
|
} |
|
|
|
// country |
|
if( parsed_text.hasOwnProperty('country') ){ |
|
vs.var( 'input:country', parsed_text.country ); |
|
} |
|
|
|
// libpostal sometimes parses addresses with prefix house numbers in places where |
|
// the house number is normally postfix incorrectly, for instance: |
|
// ```> 1 Grolmanstraße, Berlin, Germany |
|
// |
|
// Result: |
|
// |
|
// { |
|
// "house": "1", |
|
// "road": "grolmanstrasse", |
|
// "state": "berlin", |
|
// "country": "germany" |
|
// }``` |
|
// |
|
// In libpostal parlance, `house` is just a query term, not the house number. |
|
// This special case moves the query term to the house number field if there's a street, |
|
// there's no house number, and the query is parseable as an integer, then use the |
|
// query as the house number and blank out the query. |
|
if (shouldSetQueryIntoHouseNumber(vs)) { |
|
vs.var( 'input:housenumber', vs.var('input:query').toString()); |
|
vs.unset( 'input:query' ); |
|
} |
|
|
|
|
|
if (shouldTreatIslandAsCounty(vs)) { |
|
vs.var( 'input:county', vs.var('input:island').toString()); |
|
vs.unset('input:island'); |
|
} |
|
} |
|
|
|
function shouldSetQueryIntoHouseNumber(vs) { |
|
return !vs.isset('input:housenumber') && |
|
vs.isset('input:street') && |
|
/^[0-9]+$/.test(vs.var('input:query').toString()); |
|
} |
|
|
|
function shouldTreatIslandAsCounty(vs) { |
|
return vs.isset('input:island') && |
|
vs.isset('input:region') && |
|
!vs.isset('input:county') && |
|
vs.var('input:region').toString() === 'hawaii'; |
|
} |
|
|
|
module.exports = addParsedVariablesToQueryVariables;
|
|
|