|
|
|
|
|
|
|
var GeoJSON = require('geojson');
|
|
|
|
|
|
|
|
function suggest( docs ){
|
|
|
|
|
|
|
|
// emit a warning if the doc format is invalid
|
|
|
|
// @note: if you see this error, fix it ASAP!
|
|
|
|
function warning(){
|
|
|
|
console.error( 'error: invalid doc', __filename );
|
|
|
|
return false; // remove offending doc from results
|
|
|
|
}
|
|
|
|
|
|
|
|
// flatten & expand data for geojson conversion
|
|
|
|
var geodata = docs.map( function( doc ){
|
|
|
|
|
|
|
|
// something went very wrong
|
|
|
|
if( !doc || !doc.payload ) return warning();
|
|
|
|
|
|
|
|
// split payload id string in to geojson properties
|
|
|
|
if( 'string' !== typeof doc.payload.id ) return warning();
|
|
|
|
var idParts = doc.payload.id.split('/');
|
|
|
|
doc.type = idParts[0];
|
|
|
|
doc.id = idParts[1];
|
|
|
|
|
|
|
|
// split payload geo string in to geojson properties
|
|
|
|
if( 'string' !== typeof doc.payload.geo ) return warning();
|
|
|
|
var geoParts = doc.payload.geo.split(',');
|
|
|
|
doc.lat = parseFloat( geoParts[1] );
|
|
|
|
doc.lng = parseFloat( geoParts[0] );
|
|
|
|
|
|
|
|
// remove payload from doc
|
|
|
|
delete doc.payload;
|
|
|
|
return doc;
|
|
|
|
|
|
|
|
// filter-out invalid entries
|
|
|
|
}).filter( function( doc ){
|
|
|
|
return doc;
|
|
|
|
});
|
|
|
|
|
|
|
|
// convert to geojson
|
|
|
|
return GeoJSON.parse( geodata, { Point: ['lat', 'lng'] } );
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
function search( docs ){
|
|
|
|
|
|
|
|
// emit a warning if the doc format is invalid
|
|
|
|
// @note: if you see this error, fix it ASAP!
|
|
|
|
function warning(){
|
|
|
|
console.error( 'error: invalid doc', __filename );
|
|
|
|
return false; // remove offending doc from results
|
|
|
|
}
|
|
|
|
|
|
|
|
// flatten & expand data for geojson conversion
|
|
|
|
var geodata = docs.map( function( doc ){
|
|
|
|
|
|
|
|
var output = {};
|
|
|
|
|
|
|
|
// something went very wrong
|
|
|
|
if( !doc ) return warning();
|
|
|
|
|
|
|
|
// map center_point
|
|
|
|
if( !doc.center_point ) return warning();
|
|
|
|
output.lat = parseFloat( doc.center_point.lat );
|
|
|
|
output.lng = parseFloat( doc.center_point.lon );
|
|
|
|
|
|
|
|
// map name
|
|
|
|
if( !doc.name || !doc.name.default ) return warning();
|
|
|
|
output.name = doc.name.default;
|
|
|
|
|
|
|
|
// map admin values
|
|
|
|
if( doc.admin0 ){ output.admin0 = doc.admin0; }
|
|
|
|
if( doc.admin1 ){ output.admin1 = doc.admin1; }
|
|
|
|
if( doc.admin2 ){ output.admin2 = doc.admin2; }
|
|
|
|
|
|
|
|
// map suggest output
|
|
|
|
if( doc.suggest && doc.suggest.output ){
|
|
|
|
output.text = doc.suggest.output;
|
|
|
|
}
|
|
|
|
|
|
|
|
return output;
|
|
|
|
|
|
|
|
// filter-out invalid entries
|
|
|
|
}).filter( function( doc ){
|
|
|
|
return doc;
|
|
|
|
});
|
|
|
|
|
|
|
|
// convert to geojson
|
|
|
|
return GeoJSON.parse( geodata, { Point: ['lat', 'lng'] } );
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
module.exports.suggest = suggest;
|
|
|
|
module.exports.search = search;
|