From 71f8cd7bdf580f48374fbb152bcbf710c54e6c85 Mon Sep 17 00:00:00 2001 From: Abyss777 Date: Wed, 12 Oct 2016 11:57:16 +0500 Subject: Autoscroll to selected on map device and position --- web/app/view/DevicesController.js | 5 ++++- web/app/view/ReportController.js | 20 ++++++++++++++------ web/app/view/StateController.js | 2 +- 3 files changed, 19 insertions(+), 8 deletions(-) diff --git a/web/app/view/DevicesController.js b/web/app/view/DevicesController.js index 02463241..bcdfc6f9 100644 --- a/web/app/view/DevicesController.js +++ b/web/app/view/DevicesController.js @@ -32,8 +32,10 @@ Ext.define('Traccar.view.DevicesController', { listen: { controller: { '*': { - selectdevice: 'selectDevice', selectreport: 'selectReport' + }, + 'map': { + selectdevice: 'selectDevice' } }, store: { @@ -143,6 +145,7 @@ Ext.define('Traccar.view.DevicesController', { selectDevice: function (device, center) { this.getView().getSelectionModel().select([device], false, true); + this.getView().getView().focusRow(device); }, selectReport: function (position) { diff --git a/web/app/view/ReportController.js b/web/app/view/ReportController.js index ff5d32f8..115769d8 100644 --- a/web/app/view/ReportController.js +++ b/web/app/view/ReportController.js @@ -32,7 +32,9 @@ Ext.define('Traccar.view.ReportController', { listen: { controller: { '*': { - selectdevice: 'selectDevice', + selectdevice: 'selectDevice' + }, + 'map': { selectreport: 'selectReport' } } @@ -126,8 +128,13 @@ Ext.define('Traccar.view.ReportController', { }, onSelectionChange: function (selected) { + var report; if (selected.getCount() > 0) { - this.fireEvent('selectreport', selected.getLastSelected(), true); + report = selected.getLastSelected(); + this.fireEvent('selectreport', report, true); + if (report instanceof Traccar.model.ReportTrip) { + this.selectTrip(report); + } } }, @@ -138,17 +145,18 @@ Ext.define('Traccar.view.ReportController', { }, selectReport: function (object, center) { - if (object instanceof Traccar.model.Position) { + var reportType = this.lookupReference('reportTypeField').getValue(); + if (object instanceof Traccar.model.Position && reportType === 'route') { this.getView().getSelectionModel().select([object], false, true); - } else if (object instanceof Traccar.model.ReportTrip) { - this.selectTrip(object); - } + this.getView().getView().focusRow(object); + } }, selectTrip: function (trip) { var from, to; from = new Date(trip.get('startTime')); to = new Date(trip.get('endTime')); + Ext.getStore('ReportRoute').removeAll(); Ext.getStore('ReportRoute').load({ params: { deviceId: trip.get('deviceId'), diff --git a/web/app/view/StateController.js b/web/app/view/StateController.js index b0188081..20188e20 100644 --- a/web/app/view/StateController.js +++ b/web/app/view/StateController.js @@ -42,7 +42,7 @@ Ext.define('Traccar.view.StateController', { add: 'updateLatest', update: 'updateLatest' }, - '#Positions': { + '#ReportRoute': { clear: 'clearReport' }, '#AttributeAliases': { -- cgit v1.2.3