using the new geocoder

This commit is contained in:
Martin Donnelly 2018-11-04 12:03:30 +00:00
parent 9e69e6942f
commit 7f7c1f1734
5 changed files with 107 additions and 89 deletions

16
package-lock.json generated
View File

@ -52,7 +52,7 @@
}, },
"@sinonjs/formatio": { "@sinonjs/formatio": {
"version": "2.0.0", "version": "2.0.0",
"resolved": "https://registry.npmjs.org/@sinonjs/formatio/-/formatio-2.0.0.tgz", "resolved": "http://registry.npmjs.org/@sinonjs/formatio/-/formatio-2.0.0.tgz",
"integrity": "sha512-ls6CAMA6/5gG+O/IdsBcblvnd8qcO/l1TYoNeAzp3wcISOxlPXQEus0mLcdwazEkWjaBdaJ3TaxmNgCLWwvWzg==", "integrity": "sha512-ls6CAMA6/5gG+O/IdsBcblvnd8qcO/l1TYoNeAzp3wcISOxlPXQEus0mLcdwazEkWjaBdaJ3TaxmNgCLWwvWzg==",
"dev": true, "dev": true,
"requires": { "requires": {
@ -9924,11 +9924,20 @@
"version": "1.1.1", "version": "1.1.1",
"resolved": "https://registry.npmjs.org/request-promise-core/-/request-promise-core-1.1.1.tgz", "resolved": "https://registry.npmjs.org/request-promise-core/-/request-promise-core-1.1.1.tgz",
"integrity": "sha1-Pu4AssWqgyOc+wTFcA2jb4HNCLY=", "integrity": "sha1-Pu4AssWqgyOc+wTFcA2jb4HNCLY=",
"dev": true,
"requires": { "requires": {
"lodash": "^4.13.1" "lodash": "^4.13.1"
} }
}, },
"request-promise-native": {
"version": "1.0.5",
"resolved": "https://registry.npmjs.org/request-promise-native/-/request-promise-native-1.0.5.tgz",
"integrity": "sha1-UoF3D2jgyXGeUWP9P6tIIhX0/aU=",
"requires": {
"request-promise-core": "1.1.1",
"stealthy-require": "^1.1.0",
"tough-cookie": ">=2.3.3"
}
},
"requestretry": { "requestretry": {
"version": "1.13.0", "version": "1.13.0",
"resolved": "https://registry.npmjs.org/requestretry/-/requestretry-1.13.0.tgz", "resolved": "https://registry.npmjs.org/requestretry/-/requestretry-1.13.0.tgz",
@ -10807,8 +10816,7 @@
"stealthy-require": { "stealthy-require": {
"version": "1.1.1", "version": "1.1.1",
"resolved": "https://registry.npmjs.org/stealthy-require/-/stealthy-require-1.1.1.tgz", "resolved": "https://registry.npmjs.org/stealthy-require/-/stealthy-require-1.1.1.tgz",
"integrity": "sha1-NbCYdbT/SfJqd35QmzCQoyJr8ks=", "integrity": "sha1-NbCYdbT/SfJqd35QmzCQoyJr8ks="
"dev": true
}, },
"stream-browserify": { "stream-browserify": {
"version": "2.0.1", "version": "2.0.1",

View File

@ -44,6 +44,7 @@
"node-foursquare-venues": "^1.1.0", "node-foursquare-venues": "^1.1.0",
"openweather-apis": "^3.3.5", "openweather-apis": "^3.3.5",
"request-json": "^0.6.3", "request-json": "^0.6.3",
"request-promise-native": "^1.0.5",
"strict-uri-encode": "^2.0.0", "strict-uri-encode": "^2.0.0",
"string": "^3.3.3", "string": "^3.3.3",
"sugar": "^2.0.4", "sugar": "^2.0.4",

View File

@ -32,7 +32,10 @@ function formatResult (result) {
'streetNumber': result.components.house_number, 'streetNumber': result.components.house_number,
'countryCode': result.components.country_code, 'countryCode': result.components.country_code,
'county': result.components.county, 'county': result.components.county,
'suburb': result.components.suburb || '', 'suburb': result.components.suburb,
'neighbourhood' : result.components.neighbourhood,
'village' : result.components.village,
'formatted' : result.formatted,
'extra': { 'extra': {
'flag' : result.annotations.flag, 'flag' : result.annotations.flag,
'confidence': confidence, 'confidence': confidence,
@ -44,11 +47,11 @@ function formatResult (result) {
} }
function reduceOpencage(result) { function reduceOpencage(result) {
logger.debug(JSON.stringify(result));
var results = []; const results = [];
if (result && result.results instanceof Array) if (result && result.results instanceof Array)
for (var i = 0; i < result.results.length; i++) for (let i = 0; i < result.results.length; i++)
results.push(formatResult(result.results[i])); results.push(formatResult(result.results[i]));
return results; return results;

View File

@ -11,7 +11,7 @@
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and // See the License for the specific language governing permissions and
// limitations under the License. // limitations under the License.
const CACHE_VERSION = { 'version': '0.0.934' }; const CACHE_VERSION = { 'version': '0.0.955' };
const PRECACHE = `jubileeData-${CACHE_VERSION.version}`; const PRECACHE = `jubileeData-${CACHE_VERSION.version}`;
const RUNTIME = 'runtime'; const RUNTIME = 'runtime';

View File

@ -2,10 +2,10 @@ const _ = require('underscore');
const Backbone = require('backbone'); const Backbone = require('backbone');
const geolocation = require('geolocation'); const geolocation = require('geolocation');
const TimeFormat = require('hh-mm-ss'); const TimeFormat = require('hh-mm-ss');
const request = require('request');
const { distance } = require('./libs/utils'); const { distance } = require('./libs/utils');
const NodeGeocoder = require('node-geocoder');
// const locationData = require('./portGlasgow-Aldi-2018-03-09.json'); // const locationData = require('./portGlasgow-Aldi-2018-03-09.json');
const LocationModel = Backbone.Model.extend({ const LocationModel = Backbone.Model.extend({
@ -13,7 +13,7 @@ const LocationModel = Backbone.Model.extend({
// defaults go here - "children" may be contained here // defaults go here - "children" may be contained here
}, },
'tick': function() { 'tick': function () {
const p = locationData[this.pos]; const p = locationData[this.pos];
const now = new Date(); const now = new Date();
@ -29,7 +29,7 @@ const LocationModel = Backbone.Model.extend({
p.time p.time
); );
}, },
'initialize': function() { 'initialize': function () {
// this.listenTo(this, 'change sync reset', this.onChange); // this.listenTo(this, 'change sync reset', this.onChange);
// https://opencagedata.com/dashboard // https://opencagedata.com/dashboard
@ -49,12 +49,12 @@ const LocationModel = Backbone.Model.extend({
geolocation.options = geoOptions; geolocation.options = geoOptions;
geolocation.on('error', function(err) { geolocation.on('error', function (err) {
console.warn('Geolocation error'); console.warn('Geolocation error');
console.error(err); console.error(err);
}); });
geolocation.on('change', function( position) { geolocation.on('change', function (position) {
console.log('Location update'); console.log('Location update');
const location = { 'latitude': position.coords.latitude, 'longitude': position.coords.longitude, 'timestamp': position.timestamp }; const location = { 'latitude': position.coords.latitude, 'longitude': position.coords.longitude, 'timestamp': position.timestamp };
@ -67,7 +67,7 @@ const LocationModel = Backbone.Model.extend({
else else
console.log('Throttling location update...'); console.log('Throttling location update...');
// this.set('location', location); // this.set('location', location);
}.bind(this)); }.bind(this));
this.watcher = geolocation.createWatcher(); this.watcher = geolocation.createWatcher();
@ -75,66 +75,64 @@ const LocationModel = Backbone.Model.extend({
this.listenTo(this, 'change:location', this.onChange); this.listenTo(this, 'change:location', this.onChange);
// this.tick(); // this.tick();
}, },
'onChange': function() { 'onChange': function () {
console.log('>> Location updated'); console.log('>> Location updated');
console.log(JSON.stringify(this.get('location'))); console.log(JSON.stringify(this.get('location')));
}, },
'processPosition': function(pos) { 'processPosition': function (pos) {
console.log('processPosition'); console.log('processPosition');
const { latitude, longitude, timestamp } = pos; let { latitude, longitude, timestamp } = pos;
latitude = Number.parseFloat(latitude).toFixed(6);
longitude = Number.parseFloat(longitude).toFixed(6);
// const current = this.get('location'); // const current = this.get('location');
const current = this.toJSON(); const current = this.toJSON();
// console.log('># current', current); // console.log('># current', current);
/*const options = {
'provider': 'google',
// Optional depending on the providers const myCoords = {
'httpAdapter': 'https', // Default 'home': {
'apiKey': 'AIzaSyA7oGP6QS28tTwtT6UzA7hzh0b3MWwMYB8', // for Mapquest, OpenCage, Google Premier 'lat': 51.490002, 'long': -0.140245
'formatter': null // 'gpx', 'string', ... },
};*/ 'work': {
'lat': 51.508471, 'long': -0.068798
}
// opencage 893ab539eca84b5ca7a54cb03ef23443 };
const options = {
'provider': 'opencage',
// Optional depending on the providers
'httpAdapter': 'https', // Default
'apiKey': '893ab539eca84b5ca7a54cb03ef23443', // for Mapquest, OpenCage, Google Premier
'formatter': null // 'gpx', 'string', ...
};
const myCoords = { 'home': {
'lat':51.490002, 'long':-0.140245
},
'work':{
'lat':51.5084707, 'long':-0.068798
} };
// rawburn house 51.490002, -0.140245 // rawburn house 51.490002, -0.140245
// thomas more 51.5084707,-0.068798 // thomas more 51.5084707,-0.068798
const geocoder = NodeGeocoder(options);
// 55.872407, -3.549003 // 55.872407, -3.549003
const homeDistance = distance(myCoords.home.lat, myCoords.home.long, latitude, longitude); const homeDistance = distance(myCoords.home.lat, myCoords.home.long, latitude, longitude);
const workDistance = distance(myCoords.work.lat, myCoords.work.long, latitude, longitude); const workDistance = distance(myCoords.work.lat, myCoords.work.long, latitude, longitude);
const atHome = (homeDistance < 0.10); const atHome = (homeDistance < 0.10);
const atWork = (workDistance < 0.10); const atWork = (workDistance < 0.10);
const atHomeOrWork = (atHome || atWork); const atHomeOrWork = (atHome || atWork);
const latlong = { 'lat':latitude, 'lon':longitude }; const latlong = { 'lat': latitude, 'lon': longitude };
const ll = `${latitude},${longitude}`; const ll = `${latitude},${longitude}`;
const llFixed = `${Number.parseFloat(latitude).toFixed(3)},${Number.parseFloat(longitude).toFixed(3)}`; const llFixed = `${Number.parseFloat(latitude).toFixed(3)},${Number.parseFloat(longitude).toFixed(3)}`;
const llSix = `${Number.parseFloat(latitude).toFixed(6)},${Number.parseFloat(longitude).toFixed(6)}`; const llSix = `${Number.parseFloat(latitude).toFixed(6)},${Number.parseFloat(longitude).toFixed(6)}`;
const llShort = `${Number.parseFloat(latitude).toFixed(1)},${Number.parseFloat(longitude).toFixed(1)}`; const llShort = `${Number.parseFloat(latitude).toFixed(1)},${Number.parseFloat(longitude).toFixed(1)}`;
const moving = true; const moving = true;
const newLocation = { homeDistance, workDistance, latitude, longitude, atHome, atWork, atHomeOrWork, timestamp, ll, llFixed, llSix, llShort, moving, latlong, 'city' : '', 'cityCC':'' }; const newLocation = {
homeDistance,
workDistance,
latitude,
longitude,
atHome,
atWork,
atHomeOrWork,
timestamp,
ll,
llFixed,
llSix,
llShort,
moving,
latlong,
'city': '',
'cityCC': ''
};
console.log('homeDistance', homeDistance, 'workDistance:', workDistance); console.log('homeDistance', homeDistance, 'workDistance:', workDistance);
// console.log('>> NewLocation', JSON.stringify(newLocation)); // console.log('>> NewLocation', JSON.stringify(newLocation));
@ -142,23 +140,28 @@ const LocationModel = Backbone.Model.extend({
if (!_.has(current, 'atHomeOrWork')) { if (!_.has(current, 'atHomeOrWork')) {
console.info('>> Location:geocoder request'); console.info('>> Location:geocoder request');
geocoder.reverse(latlong)
.then(function(res) { request({
console.log(JSON.stringify(res)); 'url': `${window.loc}/geocode`,
newLocation.city = res[0].extra.neighborhood || res[0].city; 'method': 'GET',
newLocation.cityCC = `${res[0].city},${res[0].countryCode}`; 'qs': {
newLocation.address = res[0].formattedAddress; 'll': ll
// this.set('location', newLocation); },
newLocation.lastGeocode = { 'lat':latitude, 'lng':longitude, 'timestamp':timestamp }; 'json': true
this.set( newLocation); }, function(err, res, body) {
// this.set('moving', moving); if (err)
// this.set('lastGeocode', { 'lat':latitude, 'lng':longitude, 'timestamp':timestamp });
// console.log('### location', this);
}.bind(this))
.catch(function(err) {
console.error(err); console.error(err);
this.set('location', newLocation); else {
}); console.log('New geocode', res);
const body = res.body;
const __city = body.neighborhood || body.village || body.suburb || body.city || body.county;
newLocation.city = __city;
newLocation.cityCC = `${__city},${body.countryCode}`;
newLocation.address = body.formatted;
newLocation.lastGeocode = { 'lat': latitude, 'lng': longitude, 'timestamp': timestamp };
this.set(newLocation);
}
}.bind(this));
} }
else { else {
newLocation.city = current.city; newLocation.city = current.city;
@ -176,34 +179,37 @@ const LocationModel = Backbone.Model.extend({
// console.log(`(currentTime:${currentTime}, timestamp:${timestamp}, lastGeocode.timestamp:${lastGeocode.timestamp})`); // console.log(`(currentTime:${currentTime}, timestamp:${timestamp}, lastGeocode.timestamp:${lastGeocode.timestamp})`);
// console.log('(currentTime - current.timestamp > 900000) ', (currentTime - current.timestamp > 900000)); // console.log('(currentTime - current.timestamp > 900000) ', (currentTime - current.timestamp > 900000));
// if ((distanceFromLast > 0.5 && distanceFromLast < 2.0) || (timestamp - current.timestamp > 900000)) { // if ((distanceFromLast > 0.5 && distanceFromLast < 2.0) || (timestamp - current.timestamp > 900000)) {
if (((distanceFromLast > 0.80 && distanceFromLast < 2.0) && ( currentSince > 120000)) || ((currentSince > 900000) && (sinceLastGeocode < 1.8e+6))) { if (((distanceFromLast > 0.80 && distanceFromLast < 2.0) && (currentSince > 120000)) || ((currentSince > 900000) && (sinceLastGeocode < 1.8e+6))) {
// dont bother re geocoding // dont bother re geocoding
console.log('Slightly moved from previous'); console.log('Slightly moved from previous');
// this.set('location', newLocation); // this.set('location', newLocation);
// this.set('moving', moving); // this.set('moving', moving);
this.set( newLocation); this.set(newLocation);
} }
else if (((distanceFromLastGeocode >= 2.0) && (sinceLastGeocode > 120000)) || (sinceLastGeocode >= 1.8e+6) ) { else if (((distanceFromLastGeocode >= 2.0) && (sinceLastGeocode > 120000)) || (sinceLastGeocode >= 1.8e+6)) {
console.log('>> Moved from previous', sinceLastGeocode, (sinceLastGeocode >= 1.8e+6)); console.log('>> Moved from previous', sinceLastGeocode, (sinceLastGeocode >= 1.8e+6));
console.info('>> Location:geocoder request'); console.info('>> Location:geocoder request');
geocoder.reverse(latlong) request({
.then(function(res) { 'url': `${window.loc}/geocode`,
console.log('>> location res', JSON.stringify(res)); 'method': 'GET',
newLocation.city = res[0].extra.neighborhood || res[0].city; 'qs': {
newLocation.cityCC = `${res[0].city},${res[0].countryCode}`; 'll': ll
newLocation.address = res[0].formattedAddress; },
console.log('!!! Setting location...'); 'json': true
// this.set('location', newLocation); }, function(err, res, body) {
// this.set('lastGeocode', { 'lat':latitude, 'lng':longitude, 'timestamp':timestamp }); if (err)
// this.set('moving', moving);
newLocation.lastGeocode = { 'lat':latitude, 'lng':longitude, 'timestamp':timestamp };
this.set( newLocation);
console.log(this);
}.bind(this))
.catch(function(err) {
console.error(err); console.error(err);
this.set( newLocation); else {
}); console.log('New geocode', res);
const body = res.body;
const __city = body.neighborhood || body.village || body.suburb || body.city || body.county;
newLocation.city = __city;
newLocation.cityCC = `${__city},${body.countryCode}`;
newLocation.address = body.formatted;
newLocation.lastGeocode = { 'lat': latitude, 'lng': longitude, 'timestamp': timestamp };
this.set(newLocation);
}
}.bind(this));
} }
} }
@ -228,12 +234,12 @@ const LocationModel = Backbone.Model.extend({
}); });
const LocationView = Backbone.View.extend({ const LocationView = Backbone.View.extend({
'initialize' : function(options) { 'initialize': function (options) {
this.model.bind('change', this.render, this); this.model.bind('change', this.render, this);
}, 'template': _.template(` }, 'template': _.template(`
<div class="">Moving:<%=moving%></div> <div class="">Moving:<%=moving%></div>
`), `),
'render': function() { 'render': function () {
this.$el.html(this.template(this.model.attributes)); this.$el.html(this.template(this.model.attributes));
console.log('>> location attributes', this.model.attributes); console.log('>> location attributes', this.model.attributes);