Added directions!

This commit is contained in:
Martin Donnelly 2018-10-12 16:19:55 +01:00
parent 0b10d76c20
commit d6135ddf0c
10 changed files with 442 additions and 246 deletions

View File

@ -15,6 +15,14 @@
-webkit-font-smoothing: antialiased; -webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale; -moz-osx-font-smoothing: grayscale;
} }
.fa-xs {
font-size: .75em; }
.fa-sm {
font-size: .875em; }
/* makes the font 33% larger relative to the icon container */ /* makes the font 33% larger relative to the icon container */
.fa-lg { .fa-lg {
font-size: 1.33333333em; font-size: 1.33333333em;
@ -203,3 +211,23 @@
.fa-home:before { .fa-home:before {
content: "\EA1E" content: "\EA1E"
} }
.fa-location-arrow:before {
content: "\EA76"
}
.fa-map-marker:before {
content: "\EA3D"
}
.fa-map-marker-hollow:before {
content: "\EA3E"
}
.fa-direction-filled:before {
content: "\E9D6"
}
.fa-direction-hollow:before {
content: "\E9D7"
}

31
fonts/test.html Normal file
View File

@ -0,0 +1,31 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<link href="fujicons.css" rel="stylesheet" type="text/css"/>
</head>
<body>
<p>fa-back <i class=" fa fa-back"></i> </p>
<p>.fa-forward <i class=" fa fa-forward"></i> </p>
<p>.fa-globe <i class=" fa fa-globe"></i> <i class="fa"></i></p>
<p>.fa-up <i class=" fa fa-up"></i> </p>
<p>.fa-down <i class=" fa fa-down"></i> </p>
<p>.fa-work <i class=" fa fa-work"></i> </p>
<p>.fa-home <i class=" fa fa-home"></i> </p>
<p>.fa-location-arrow <i class=" fa fa-location-arrow"></i> </p>
<p>.fa-map-marker <i class=" fa fa-map-marker"></i> </p>
</body>
</html>

View File

@ -15,6 +15,7 @@ function reduceEstDirections(body = '') {
const obj = {}; const obj = {};
const { ResultSet } = jBody; const { ResultSet } = jBody;
const streets = []; const streets = [];
const steps = [];
if (has(ResultSet, 'Result')) { if (has(ResultSet, 'Result')) {
const directions = get(ResultSet, 'Result.yahoo_driving_directions'); const directions = get(ResultSet, 'Result.yahoo_driving_directions');
@ -44,13 +45,16 @@ function reduceEstDirections(body = '') {
} }
for (const item of route) { for (const item of route) {
logger.debug(item);
if (item.hasOwnProperty('street')) { if (item.hasOwnProperty('street')) {
const street = item.street.split(','); const street = item.street.split(',');
if (street[0] !== '') streets.push(street[0]); if (street[0] !== '') streets.push(street[0]);
} }
}
if (has(item, 'description')) {
steps.push(item.description);
}
}
obj.directions = steps;
obj.streets = uniq(streets); obj.streets = uniq(streets);
} }

View File

@ -478,4 +478,9 @@ li {
margin-bottom: 3px; margin-bottom: 3px;
} }
.separate {
border-bottom: 1px solid mui-color('grey', '200');
margin-bottom: 5px;
}
@import "./src/css/weather"; @import "./src/css/weather";

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.812' }; const CACHE_VERSION = { 'version': '0.0.884' };
const PRECACHE = `jubileeData-${CACHE_VERSION.version}`; const PRECACHE = `jubileeData-${CACHE_VERSION.version}`;
const RUNTIME = 'runtime'; const RUNTIME = 'runtime';

137
src/v1/js/Goto.js Normal file
View File

@ -0,0 +1,137 @@
const $ = require('jquery');
const _ = require('underscore');
const Backbone = require('backbone');
const request = require('request');
const { get, has, isEmpty } = require('lodash');
const { createPanel, addPanel } = require('./libs/panel');
const templates = require('./libs/templates');
const GotoCardModel = Backbone.Model.extend({
'initialize': function() {
this.listenTo(this, 'change:detail', this.getDirections);
},
'getDirections': function() {
const { from, to } = this.get('detail');
console.log('goto from', from);
console.log('goto to', to);
const qs = {
'olat':to.lat, 'olon': to.long, 'dlat': from.lat, 'dlon': from.long
};
console.log('qs', qs);
request({
'url': `${window.loc}/traffic`,
'method': 'GET',
'qs': qs
}, function(err, res, body) {
if (err)
console.error(err);
else {
console.log('statusCode', res.statusCode);
const now = new Date().getTime();
const gotoJSON = JSON.parse(body);
console.log('>> gotoJSON', gotoJSON);
this.set('directions', gotoJSON.directions);
console.log(this.attributes);
// this.logUpdate();
}
}.bind(this));
}
});
const GotoCardView = Backbone.View.extend({
'initialize': function(options) {
this.eventBus = options.eventBus;
this.location = options.location;
this.location.bind('change', this.updateMyLocation, this);
/* this.model.on('all', function(eventName) {
console.log(`${eventName } was triggered!`);
});*/
this.model.bind('change:directions', this.doUpdateRender, this);
this.eventBus.on('showDirections', this.showDirectionsPanel, this);
},
'updateMyLocation': function(l) {
console.log('Goto:My location Changed', l);
},
'template': _.template(`
<div id='gotoDetails' class="mui-container" style="margin-bottom: 50px;">
<div><h1>Details</h1></div>
<div id="gotoDetailsText"></div>
</div>
</div>
`),
'showDirectionsPanel': function(toDest, cb = null) {
console.log('Showing directions', toDest);
const detail = { 'from':{}, 'to':{} };
this.$newPanel = createPanel({ 'title':'Directions', 'divId':'directionsP' }, cb);
this.$el = addPanel(this.$newPanel);
// this.$el.empty();
this.$newPanel.show();
const l = this.location.toJSON();
console.log('l', l);
if (l.hasOwnProperty('latitude')) {
detail.from.lat = l.latitude;
detail.from.long = l.longitude;
}
else
console.log('>> No location yet');
detail.to.lat = toDest.latitude;
detail.to.long = toDest.longitude;
console.log('detail', detail);
this.model.set('detail', detail);
// if (prevGuid === guid)
this.doRender();
},
'events': {
'click .closebutton': 'doClick'
},
'doClick': function(d) {
console.log('Do click', d);
const id = get(d, 'currentTarget', '');
console.log(id);
// this.eventBus.trigger('showNews', id);
},
'doClose': function(d) {
this.model.clear({ 'silent':true });
console.log('close??');
},
'doRender': function() {
this.$el.empty();
// this.$el.html(this.template(this.model.get('article')));
this.$el.html(this.template());
},
'doUpdateRender': function() {
// this.$el.empty();
// this.$el.html(this.template(this.model.get('article')));
const html = templates.templateDirections({ 'directions':this.model.get('directions') });
console.log(html);
const $el = this.$el;
$el.find('#gotoDetailsText').html(html);
}
});
module.exports = { GotoCardModel, GotoCardView };

View File

@ -67,7 +67,10 @@ const VenueDetailView = Backbone.View.extend({
this.doRender(); this.doRender();
}, },
'events': { 'events': {
'click .closebutton': 'doClick' 'click .closebutton': 'doClick',
'click #getDirections': (d) => {
console.log('Clicked', d);
}
}, },
'doClick': function(d) { 'doClick': function(d) {
console.log('Do click', d); console.log('Do click', d);
@ -75,6 +78,17 @@ const VenueDetailView = Backbone.View.extend({
console.log(id); console.log(id);
// this.eventBus.trigger('showNews', id); // this.eventBus.trigger('showNews', id);
}, },
'doNavigate': function(d) {
// console.log('Do click', d);
console.log('>> this.model', this);
const details = this.model.get('details');
console.log(details);
this.eventBus.trigger('showDirections', details, () => {
console.log('Navigate panel closed');
this.$newPanel.show();
});
this.$newPanel.hide();
},
'doClose': function(d) { 'doClose': function(d) {
console.log('close??'); console.log('close??');
}, },
@ -93,6 +107,7 @@ const VenueDetailView = Backbone.View.extend({
contents.push(templates.map()); contents.push(templates.map());
contents.push(templates.venueDirections());
if (!isEmpty(m.yelp)) if (!isEmpty(m.yelp))
contents.push(templates.yelpTemplate(m)); contents.push(templates.yelpTemplate(m));
@ -144,6 +159,9 @@ const VenueDetailView = Backbone.View.extend({
'radius': 30 'radius': 30
}).addTo(this.map); }).addTo(this.map);
this.$el.find('#getDirections').on('click', () => {
this.doNavigate();
});
// console.log(this.location.attributes); // console.log(this.location.attributes);
} }

View File

@ -19,6 +19,9 @@ const { AgendaModel, AgendaView } = require('./Agenda');
const { TrafficModel, TrafficView } = require('./Traffic'); const { TrafficModel, TrafficView } = require('./Traffic');
const { NearbyListModel, NearbyListView } = require('./NearbyList'); const { NearbyListModel, NearbyListView } = require('./NearbyList');
const { NearbyPlacesView } = require('./NearbyPlaces'); const { NearbyPlacesView } = require('./NearbyPlaces');
const { GotoCardModel, GotoCardView } = require('./Goto');
var app = app || {}; var app = app || {};
const live = true; const live = true;
@ -101,23 +104,23 @@ function main() {
app.traffic = new TrafficView({ 'model': new TrafficModel(), 'eventBus': app.eventBus, 'location': app.locationModel, 'el':'#traffic' }); app.traffic = new TrafficView({ 'model': new TrafficModel(), 'eventBus': app.eventBus, 'location': app.locationModel, 'el':'#traffic' });
app.newsCard = new VenueDetailView({ 'model': new VenueDetailModel(), 'eventBus': app.eventBus, 'location': app.locationModel }); app.venueCard = new VenueDetailView({ 'model': new VenueDetailModel(), 'eventBus': app.eventBus, 'location': app.locationModel });
app.nearbyList = new NearbyListView({ 'model': new NearbyListModel(), 'eventBus' : app.eventBus }); app.nearbyList = new NearbyListView({ 'model': new NearbyListModel(), 'eventBus' : app.eventBus });
app.nearbyPlacesView = new NearbyPlacesView({ 'eventBus': app.eventBus, 'location': app.locationModel, 'el':'#nearbyPlaces' }); app.nearbyPlacesView = new NearbyPlacesView({ 'eventBus': app.eventBus, 'location': app.locationModel, 'el':'#nearbyPlaces' });
app.gotoCard = new GotoCardView({ 'model': new GotoCardModel(), 'eventBus': app.eventBus, 'location': app.locationModel });
app.updateOnlineStatus = function(event) { app.updateOnlineStatus = function(event) {
if (navigator.onLine) if (navigator.onLine) {
// handle online status // handle online status
{
console.log('online'); console.log('online');
$('#connectionStatus').hide(500); $('#connectionStatus').hide(500);
} }
else else {
// handle offline status // handle offline status
{
console.log('offline'); console.log('offline');
$('#connectionStatus').show(500); $('#connectionStatus').show(500);
} }

View File

@ -59,6 +59,9 @@ const templates = {
'venueTitle' : _.template(` 'venueTitle' : _.template(`
<div class="mui--text-display1 mui--text-center" style="font-weight: 900;"><%=name %></div> <div class="mui--text-display1 mui--text-center" style="font-weight: 900;"><%=name %></div>
`), `),
'venueDirections' : _.template(`
<div class="mui--text-subhead mui--text-center separate" style="" id="getDirections"><p><i class="fa fa-sm fa-map-marker mui--align-middle " ></i></p><p>Directions</p></div>
`),
'openInFS' : _.template(` 'openInFS' : _.template(`
<div class=""><a href="https://m.foursquare.com/v/<%=id%>">Open in Foursquare</a></div> <div class=""><a href="https://m.foursquare.com/v/<%=id%>">Open in Foursquare</a></div>
`), `),
@ -137,6 +140,13 @@ const templates = {
</div> </div>
</div> </div>
`),
'templateDirections': _.template(`
<%_.forEach(directions, function(i) {%>
<div class="directionsCard">
<div class="mui--text-body2"><%=i %></div>
</div>
<%}) %>
`) `)
}; };

View File

@ -16,8 +16,8 @@ const requestData = {
'address': [ 'address': [
{ {
'type': 'Origin', 'type': 'Origin',
'lat': '55.942592', 'lat': '51.508577',
'lon': '-4.556346', 'lon': '-0.067628',
'line1': '', 'line1': '',
'line2': '', 'line2': '',
'line3': '', 'line3': '',
@ -26,8 +26,8 @@ const requestData = {
}, },
{ {
'type': 'Destination', 'type': 'Destination',
'lat': '55.872443', 'lat': '51.490002',
'lon': '-3.548992', 'lon': '-0.140245',
'line1': '', 'line1': '',
'line2': '', 'line2': '',
'line3': '', 'line3': '',
@ -35,286 +35,193 @@ const requestData = {
'country': '' 'country': ''
} }
], ],
'total_distance': '83339', 'total_distance': '7189',
'total_time': '65.0', 'total_time': '42.0',
'total_time_with_traffic': '70.0', 'total_time_with_traffic': '0.0',
'boundingbox': { 'boundingbox': {
'north': '55.942587', 'north': '51.512259',
'south': '55.832605', 'south': '51.490066',
'east': '-3.541074', 'east': '-0.06742',
'west': '-4.556462' 'west': '-0.143531'
}, },
'route_id': 'AIUACAAAAB4AAABRAAAAlgAAAKAAAAB42mNYwMDAxMQABI+6DtXs5zyRzgAFBvE1Yi4Mi6wY/v+HCDywZ0ACXEBs/kYnl4nhz5vK2okuu+Ea4+ZXi61gXmSDR2PShr4NjECL4YJs6Qcz5wJpB4aEhgeMQClGrglVHA4OTAw+/ADTGiAC9jefAA==',
'directions': { 'directions': {
'route_leg': [ 'route_leg': [
{ {
'@type': 'PrivateRouteLeg', '@type': 'PrivateRouteLeg',
'number': '1', 'number': '1',
'lat': '55.942587', 'lat': '51.508648',
'lon': '-4.556462', 'lon': '-0.06742',
'distance': '2060', 'distance': '49',
'description': 'Head toward Bruce Street on Glasgow Road (A814). Go for 2.1 km.', 'description': 'Head northwest on Vaughan Way. Go for 49 m.',
'time': '3', 'time': '2018-10-11T17:14:37+01:00',
'time_with_traffic': '3', 'time_with_traffic': '1',
'turn_angle': '0', 'turn_angle': '0',
'exit_num': '', 'exit_num': '',
'man_type': '0', 'man_type': '0',
'street': 'A814, GLASGOW ROAD' 'street': ', VAUGHAN WAY'
}, },
{ {
'@type': 'PrivateRouteLeg', '@type': 'PrivateRouteLeg',
'number': '2', 'number': '2',
'lat': '55.935098', 'lat': '51.509045',
'lon': '-4.526989', 'lon': '-0.06772',
'distance': '1616', 'distance': '340',
'description': 'Continue on Dumbarton Road (A82). Go for 1.6 km.', 'description': 'Turn left onto East Smithfield. Go for 340 m.',
'time': '2', 'time': '2018-10-11T17:15:36+01:00',
'time_with_traffic': '2', 'time_with_traffic': '6',
'turn_angle': '0', 'turn_angle': '-90',
'exit_num': '', 'exit_num': '',
'man_type': '11', 'man_type': '9',
'street': 'A82, DUMBARTON ROAD' 'street': 'A1203, EAST SMITHFIELD'
}, },
{ {
'@type': 'PrivateRouteLeg', '@type': 'PrivateRouteLeg',
'number': '3', 'number': '3',
'lat': '55.931944', 'lat': '51.508584',
'lon': '-4.503633', 'lon': '-0.072323',
'distance': '3334', 'distance': '281',
'description': 'Take the 2nd exit from Dunglass Roundabout roundabout onto Great Western Road (A82) toward Glasgow/Erskine Bridge/(A898). Go for 3.3 km.', 'description': 'Turn left. Go for 281 m.',
'time': '3', 'time': '2018-10-11T17:21:17+01:00',
'time_with_traffic': '3', 'time_with_traffic': '5',
'turn_angle': '-90', 'turn_angle': '-90',
'exit_num': '', 'exit_num': '',
'man_type': '29', 'man_type': '9',
'street': 'A82, GREAT WESTERN ROAD', 'street': ', '
'sign': '(A898), Erskine Bridge, Glasgow'
}, },
{ {
'@type': 'PrivateRouteLeg', '@type': 'PrivateRouteLeg',
'number': '4', 'number': '4',
'lat': '55.926161', 'lat': '51.509378',
'lon': '-4.452403', 'lon': '-0.076046',
'distance': '2919', 'distance': '40',
'description': 'Take ramp onto A898 toward Erskine Bridge/Paisley/(M898). Go for 2.9 km.', 'description': 'Turn right. Go for 40 m.',
'time': '2', 'time': '2018-10-11T17:25:58+01:00',
'time_with_traffic': '2', 'time_with_traffic': '1',
'turn_angle': '-30', 'turn_angle': '90',
'exit_num': '', 'exit_num': '',
'man_type': '19', 'man_type': '13',
'street': 'A898, ', 'street': ', '
'sign': '(M898), Erskine Bridge, Paisley'
}, },
{ {
'@type': 'PrivateRouteLeg', '@type': 'PrivateRouteLeg',
'number': '5', 'number': '5',
'lat': '55.910207', 'lat': '51.509732',
'lon': '-4.472519', 'lon': '-0.076164',
'distance': '1152', 'distance': '22',
'description': 'Keep right onto M898 toward Paisley/Glasgow Airport/Greenock/(M8). Go for 1.2 km.', 'description': 'Turn left. Go for 22 m.',
'time': '1', 'time': '2018-10-11T17:26:38+01:00',
'time_with_traffic': '1',
'turn_angle': '30',
'exit_num': '',
'man_type': '23',
'street': 'M898, ',
'sign': '(M8), Glasgow Airport, Greenock, Paisley'
},
{
'@type': 'PrivateRouteLeg',
'number': '6',
'lat': '55.901495',
'lon': '-4.481091',
'distance': '396',
'description': 'Keep left onto M898 toward Paisley/Airports. Go for 396 m.',
'time': '0',
'time_with_traffic': '0', 'time_with_traffic': '0',
'turn_angle': '-30', 'turn_angle': '-90',
'exit_num': '', 'exit_num': '',
'man_type': '21', 'man_type': '9',
'street': 'M898, ', 'street': ', '
'sign': 'Airports, Paisley'
}, },
{ {
'@type': 'PrivateRouteLeg', '@type': 'PublicRouteLeg',
'number': '6',
'lat': '51.509834',
'lon': '-0.076454',
'distance': '5670',
'description': 'Go to the Train station Tower Hill and take the rail District toward Ealing Broadway. Follow for 9 stations.',
'time': '2018-10-11T17:27:00+01:00',
'time_with_traffic': '16',
'stop_name': 'Tower Hill',
'platform_name': {
'@nil': 'true'
},
'platform_level': {
'@nil': 'true'
},
'line': {
'@nil': 'true'
},
'wait_time': '1'
},
{
'@type': 'PublicRouteLeg',
'number': '7', 'number': '7',
'lat': '55.898287', 'lat': '51.495981',
'lon': '-4.483226', 'lon': '-0.143475',
'distance': '64579', 'distance': '0',
'description': 'Keep left onto M8. Go for 64.6 km.', 'description': 'Get off at Victoria.',
'time': '42', 'time': '2018-10-11T17:43:00+01:00',
'time_with_traffic': '42', 'time_with_traffic': '0',
'turn_angle': '-30', 'stop_name': 'Victoria',
'exit_num': '', 'platform_name': {
'man_type': '21', '@nil': 'true'
'street': 'M8, ' },
'platform_level': {
'@nil': 'true'
},
'line': {
'@nil': 'true'
},
'wait_time': '0'
}, },
{ {
'@type': 'PrivateRouteLeg', '@type': 'PrivateRouteLeg',
'number': '8', 'number': '8',
'lat': '55.895294', 'lat': '51.495981',
'lon': '-3.596402', 'lon': '-0.143475',
'distance': '240', 'distance': '21',
'description': 'Take exit 3A toward Bathgate/(A89)/Broxburn/Livingston West/(A779). Go for 240 m.', 'description': 'Head northeast on Terminus Place. Go for 21 m.',
'time': '0', 'time': '2018-10-11T17:43:00+01:00',
'time_with_traffic': '0',
'turn_angle': '-30',
'exit_num': '',
'man_type': '17',
'street': ', ',
'sign': '(A779), (A89), Bathgate, Broxburn, Livingston West'
},
{
'@type': 'PrivateRouteLeg',
'number': '9',
'lat': '55.897204',
'lon': '-3.595244',
'distance': '420',
'description': 'Take the 1st exit from roundabout onto Carnegie Road (A779) toward Glasgow/(M8)/Livingston/Bathgate/(A89)/Broxburn. Go for 420 m.',
'time': '1',
'time_with_traffic': '1',
'turn_angle': '-90',
'exit_num': '',
'man_type': '29',
'street': 'A779, CARNEGIE ROAD',
'sign': '(A89), (M8), A779, Bathgate, Broxburn, Glasgow, Livingston'
},
{
'@type': 'PrivateRouteLeg',
'number': '10',
'lat': '55.897193',
'lon': '-3.601885',
'distance': '840',
'description': 'Take the 1st exit from Boghall Roundabout roundabout onto A779 toward Glasgow/(M8)/Livingston. Go for 840 m.',
'time': '1',
'time_with_traffic': '1',
'turn_angle': '-90',
'exit_num': '',
'man_type': '29',
'street': 'A779, ',
'sign': '(M8), A779, Glasgow, Livingston'
},
{
'@type': 'PrivateRouteLeg',
'number': '11',
'lat': '55.890466',
'lon': '-3.596713',
'distance': '1622',
'description': 'Take the 1st exit from Starlaw West Roundabout roundabout onto Starlaw Road (A779) toward Livingston/Kirkton Campus/Alba Centre/Starlaw Park. Go for 1.6 km.',
'time': '2',
'time_with_traffic': '2',
'turn_angle': '-90',
'exit_num': '',
'man_type': '29',
'street': 'A779, STARLAW ROAD',
'sign': 'Alba Centre, Kirkton Campus, Livingston, Starlaw Park'
},
{
'@type': 'PrivateRouteLeg',
'number': '12',
'lat': '55.89009',
'lon': '-3.570975',
'distance': '657',
'description': 'Take the 3rd exit from Tailend Roundabout roundabout onto Starlaw Road (A779). Go for 657 m.',
'time': '1',
'time_with_traffic': '1',
'turn_angle': '-90',
'exit_num': '',
'man_type': '29',
'street': 'A779, STARLAW ROAD'
},
{
'@type': 'PrivateRouteLeg',
'number': '13',
'lat': '55.886743',
'lon': '-3.563787',
'distance': '486',
'description': 'Take the 2nd exit from Toll Roundabout roundabout onto A705. Go for 486 m.',
'time': '1',
'time_with_traffic': '1',
'turn_angle': '-90',
'exit_num': '',
'man_type': '29',
'street': 'A705, '
},
{
'@type': 'PrivateRouteLeg',
'number': '14',
'lat': '55.885638',
'lon': '-3.557596',
'distance': '2131',
'description': 'Turn right onto Simpson Parkway (B7015). Go for 2.1 km.',
'time': '3',
'time_with_traffic': '3',
'turn_angle': '90',
'exit_num': '',
'man_type': '13',
'street': 'B7015, SIMPSON PARKWAY'
},
{
'@type': 'PrivateRouteLeg',
'number': '15',
'lat': '55.876765',
'lon': '-3.542415',
'distance': '345',
'description': 'Continue on Simpson Parkway. Go for 345 m.',
'time': '0',
'time_with_traffic': '0', 'time_with_traffic': '0',
'turn_angle': '0', 'turn_angle': '0',
'exit_num': '', 'exit_num': '',
'man_type': '11', 'man_type': '11',
'street': ', SIMPSON PARKWAY' 'street': ', TERMINUS PLACE'
}, },
{ {
'@type': 'PrivateRouteLeg', '@type': 'PrivateRouteLeg',
'number': '16', 'number': '9',
'lat': '55.873793', 'lat': '51.496063',
'lon': '-3.541074', 'lon': '-0.143208',
'distance': '197', 'distance': '624',
'description': 'Take the 3rd exit from Rosebank Roundabout roundabout. Go for 197 m.', 'description': 'Turn right onto Wilton Road. Go for 624 m.',
'time': '1', 'time': '2018-10-11T17:43:21+01:00',
'time_with_traffic': '11',
'turn_angle': '90',
'exit_num': '',
'man_type': '13',
'street': 'A202, WILTON ROAD'
},
{
'@type': 'PrivateRouteLeg',
'number': '10',
'lat': '51.491032',
'lon': '-0.139561',
'distance': '22',
'description': 'Turn left onto Belgrave Road. Go for 22 m.',
'time': '2018-10-11T17:53:51+01:00',
'time_with_traffic': '1', 'time_with_traffic': '1',
'turn_angle': '-90', 'turn_angle': '-90',
'exit_num': '', 'exit_num': '',
'man_type': '29', 'man_type': '9',
'street': ', ' 'street': 'A3213, BELGRAVE ROAD'
}, },
{ {
'@type': 'PrivateRouteLeg', '@type': 'PrivateRouteLeg',
'number': '17', 'number': '11',
'lat': '55.872957', 'lat': '51.490914',
'lon': '-3.542737', 'lon': '-0.139314',
'distance': '222', 'distance': '120',
'description': 'Take the 2nd exit from Brotherton Roundabout roundabout. Go for 222 m.', 'description': 'Turn right onto Denbigh Street. Go for 120 m.',
'time': '1', 'time': '2018-10-11T17:54:23+01:00',
'time_with_traffic': '1', 'time_with_traffic': '2',
'turn_angle': '-90', 'turn_angle': '90',
'exit_num': '', 'exit_num': '',
'man_type': '29', 'man_type': '13',
'street': ', ' 'street': ', DENBIGH STREET'
}, },
{ {
'@type': 'PrivateRouteLeg', '@type': 'PrivateRouteLeg',
'number': '18', 'number': '12',
'lat': '55.873075', 'lat': '51.490066',
'lon': '-3.546073', 'lon': '-0.140383',
'distance': '123',
'description': 'Take the 1st exit from roundabout. Go for 123 m.',
'time': '0',
'time_with_traffic': '0',
'turn_angle': '-90',
'exit_num': '',
'man_type': '29',
'street': ', '
},
{
'@type': 'PrivateRouteLeg',
'number': '19',
'lat': '55.872313',
'lon': '-3.547393',
'distance': '0', 'distance': '0',
'description': 'Arrive at your destination.', 'description': 'Arrive at Gloucester Street. Your destination is on the left.',
'time': '0', 'time': '2018-10-11T17:56:26+01:00',
'time_with_traffic': '0', 'time_with_traffic': '0',
'turn_angle': '0', 'turn_angle': '0',
'exit_num': '', 'exit_num': '',
@ -323,19 +230,72 @@ const requestData = {
} }
] ]
}, },
'maneuverGroups': {
'maneuverGroup': [
{
'arrivalDescription': 'Arrive at Tower Hill.',
'firstManeuver': 'M1',
'lastManeuver': 'M5',
'summaryDescription': 'Walk to Train Tower Hill.',
'transportMode': 'pedestrian',
'transportModeNum': '6'
},
{
'arrivalDescription': 'Get off at Victoria.',
'firstManeuver': 'M6',
'lastManeuver': 'M7',
'publicTransportType': 'railMetro',
'publicTransportTypeNum': '5',
'summaryDescription': 'Take the rail District toward Ealing Broadway.',
'transportMode': 'pubTimeTable',
'transportModeNum': '11',
'waitDescription': '1 minutes to connect.'
},
{
'arrivalDescription': 'Arrive at Gloucester Street.',
'firstManeuver': 'M8',
'lastManeuver': 'M12',
'summaryDescription': '',
'transportMode': 'pedestrian',
'transportModeNum': '6'
}
]
},
'copy_right': 'Copyright &copy; 2018 Yahoo! Inc. All rights reserved. &copy; Navteq' 'copy_right': 'Copyright &copy; 2018 Yahoo! Inc. All rights reserved. &copy; Navteq'
}, },
'geocode_results': null 'geocode_results': null,
'source_attribution': {
'attribution': 'With the support of <span class="company"><a rel="nofollow" target="_blank" href="https://transit.api.here.com/r?appId=eAdkWGYRoc4RfxVo0Z4B&amp;u=https://www.networkrail.co.uk/who-we-are/transparency-and-ethics/transparency/open-data-feeds/network-rail-infrastructure-limited-data-feeds-licence/">London Underground (TfL)</a></span>. All information is provided without warranty of any kind. London Underground (TfL) <a rel="nofollow" target="_blank" href="https://transit.api.here.com/r?appId=eAdkWGYRoc4RfxVo0Z4B&amp;u=https://www.networkrail.co.uk/who-we-are/transparency-and-ethics/transparency/open-data-feeds/network-rail-infrastructure-limited-data-feeds-licence/">Contains public sector information licensed under the Open Government Licence v3.0. Contains OS data © Crown copyright and database rights 2016. Powered by TfL Open Data. Contains Information of Network Rail Infrastructure Limited licensed under the linked licence.</a>',
'sourceSuppliers': {
'href': 'https://transit.api.here.com/r?appId=eAdkWGYRoc4RfxVo0Z4B&amp;u=https://www.networkrail.co.uk/who-we-are/transparency-and-ethics/transparency/open-data-feeds/network-rail-infrastructure-limited-data-feeds-licence/',
'title': 'London Underground (TfL) <a rel="nofollow" target="_blank" href="https://transit.api.here.com/r?appId=eAdkWGYRoc4RfxVo0Z4B&amp;u=https://www.networkrail.co.uk/who-we-are/transparency-and-ethics/transparency/open-data-feeds/network-rail-infrastructure-limited-data-feeds-licence/">Contains public sector information licensed under the Open Government Licence v3.0. Contains OS data © Crown copyright and database rights 2016. Powered by TfL Open Data. Contains Information of Network Rail Infrastructure Limited licensed under the linked licence.</a>'
} }
} }
}; }
}
}
;
const goodOutput = { 'totalTime': 65, const goodOutput = { 'totalTime': 42,
'totalTimeWithTraffic': 70, 'totalTimeWithTraffic': 0,
'readable': '1 hour, 10 minutes', 'readable': '42 minutes',
'timePercentage': 10.5, 'timePercentage': -58,
'traffic': 'no traffic', 'traffic': 'no traffic',
'className': 'trafficNone' }; 'className': 'trafficNone',
'directions':
[ 'Head northwest on Vaughan Way. Go for 49 m.',
'Turn left onto East Smithfield. Go for 340 m.',
'Turn left. Go for 281 m.',
'Turn right. Go for 40 m.',
'Turn left. Go for 22 m.',
'Go to the Train station Tower Hill and take the rail District toward Ealing Broadway. Follow for 9 stations.',
'Get off at Victoria.',
'Head northeast on Terminus Place. Go for 21 m.',
'Turn right onto Wilton Road. Go for 624 m.',
'Turn left onto Belgrave Road. Go for 22 m.',
'Turn right onto Denbigh Street. Go for 120 m.',
'Arrive at Gloucester Street. Your destination is on the left.' ],
'streets': [ 'A1203', 'A202', 'A3213' ] };
describe('Directions', () => { describe('Directions', () => {
it('should gracefully handle no data', done => { it('should gracefully handle no data', done => {