From d93e45e176fc2cbba6525f100ef084d904baa1c1 Mon Sep 17 00:00:00 2001 From: Abyss777 Date: Wed, 8 Nov 2017 15:04:43 +0500 Subject: Implement geocoding retry --- web/app/view/ReportController.js | 34 +++++++++++++++++++++++++++++++++- 1 file changed, 33 insertions(+), 1 deletion(-) (limited to 'web/app/view/ReportController.js') diff --git a/web/app/view/ReportController.js b/web/app/view/ReportController.js index 80e56ba4..5d4d00c2 100644 --- a/web/app/view/ReportController.js +++ b/web/app/view/ReportController.js @@ -40,6 +40,9 @@ Ext.define('Traccar.view.ReportController', { selectreport: 'selectReport' } }, + global: { + routegeocode: 'onGeocode' + }, store: { '#ReportEvents': { add: 'loadRelatedPositions', @@ -423,6 +426,28 @@ Ext.define('Traccar.view.ReportController', { this.updateButtons(); }, + onGeocode: function (positionId) { + var position = Ext.getStore('ReportRoute').getById(positionId); + if (position && !position.get('address')) { + Ext.Ajax.request({ + scope: this, + method: 'GET', + url: 'api/server/geocode', + params: { + latitude: position.get('latitude'), + longitude: position.get('longitude') + }, + success: function (response) { + position.set('address', response.responseText); + position.commit(); + }, + failure: function (response) { + Traccar.app.showError(response); + } + }); + } + }, + routeColumns: [{ text: Strings.reportDeviceName, dataIndex: 'deviceId', @@ -455,7 +480,14 @@ Ext.define('Traccar.view.ReportController', { }, { text: Strings.positionAddress, dataIndex: 'address', - renderer: Traccar.AttributeFormatter.getFormatter('address') + renderer: function (value, metaData, record) { + if (!value) { + return '' + + Strings.stateShowAddress + ''; + } + return Traccar.AttributeFormatter.getFormatter('address')(value); + } }], eventsColumns: [{ -- cgit v1.2.3