diff options
Diffstat (limited to 'web/app')
-rw-r--r-- | web/app/store/ReportPeriods.js | 9 | ||||
-rw-r--r-- | web/app/view/ReportController.js | 3 | ||||
-rw-r--r-- | web/app/view/dialog/ReportConfig.js | 5 | ||||
-rw-r--r-- | web/app/view/dialog/ReportConfigController.js | 18 |
4 files changed, 35 insertions, 0 deletions
diff --git a/web/app/store/ReportPeriods.js b/web/app/store/ReportPeriods.js index b9c19f9..542fdce 100644 --- a/web/app/store/ReportPeriods.js +++ b/web/app/store/ReportPeriods.js @@ -21,6 +21,9 @@ Ext.define('Traccar.store.ReportPeriods', { fields: ['key', 'name'], data: [{ + key: 'custom', + name: Strings.reportCustom + }, { key: 'today', name: Strings.reportToday }, { @@ -30,7 +33,13 @@ Ext.define('Traccar.store.ReportPeriods', { key: 'thisWeek', name: Strings.reportThisWeek }, { + key: 'previousWeek', + name: Strings.reportPreviousWeek + }, { key: 'thisMonth', name: Strings.reportThisMonth + }, { + key: 'previousMonth', + name: Strings.reportPreviousMonth }] }); diff --git a/web/app/view/ReportController.js b/web/app/view/ReportController.js index 6d984de..80e56ba 100644 --- a/web/app/view/ReportController.js +++ b/web/app/view/ReportController.js @@ -128,6 +128,9 @@ Ext.define('Traccar.view.ReportController', { if (this.toTime !== undefined) { dialog.lookupReference('toTimeField').setValue(this.toTime); } + if (this.period !== undefined) { + dialog.lookupReference('periodField').setValue(this.period); + } dialog.show(); }, diff --git a/web/app/view/dialog/ReportConfig.js b/web/app/view/dialog/ReportConfig.js index cdf11e1..67080bf 100644 --- a/web/app/view/dialog/ReportConfig.js +++ b/web/app/view/dialog/ReportConfig.js @@ -75,6 +75,8 @@ Ext.define('Traccar.view.dialog.ReportConfig', { }, { xtype: 'fieldcontainer', layout: 'vbox', + reference: 'fromContainer', + hidden: true, fieldLabel: Strings.reportFrom, items: [{ xtype: 'datefield', @@ -90,6 +92,8 @@ Ext.define('Traccar.view.dialog.ReportConfig', { }, { xtype: 'fieldcontainer', layout: 'vbox', + reference: 'toContainer', + hidden: true, fieldLabel: Strings.reportTo, items: [{ xtype: 'datefield', @@ -104,6 +108,7 @@ Ext.define('Traccar.view.dialog.ReportConfig', { }] }, { fieldLabel: Strings.reportPeriod, + reference: 'periodField', xtype: 'combobox', store: 'ReportPeriods', editable: false, diff --git a/web/app/view/dialog/ReportConfigController.js b/web/app/view/dialog/ReportConfigController.js index 2958515..17699b9 100644 --- a/web/app/view/dialog/ReportConfigController.js +++ b/web/app/view/dialog/ReportConfigController.js @@ -44,6 +44,7 @@ Ext.define('Traccar.view.dialog.ReportConfigController', { callingPanel.fromTime = this.lookupReference('fromTimeField').getValue(); callingPanel.toDate = this.lookupReference('toDateField').getValue(); callingPanel.toTime = this.lookupReference('toTimeField').getValue(); + callingPanel.period = this.lookupReference('periodField').getValue(); callingPanel.updateButtons(); button.up('window').close(); }, @@ -51,6 +52,10 @@ Ext.define('Traccar.view.dialog.ReportConfigController', { onPeriodChange: function (combobox, newValue) { var day, first, from = new Date(), to = new Date(); switch (newValue) { + case 'custom': + this.lookupReference('fromContainer').setHidden(false); + this.lookupReference('toContainer').setHidden(false); + return; case 'today': to.setDate(to.getDate() + 1); break; @@ -63,11 +68,22 @@ Ext.define('Traccar.view.dialog.ReportConfigController', { from.setDate(first); to.setDate(first + 7); break; + case 'previousWeek': + day = from.getDay(); + first = from.getDate() - day + (day === 0 ? -6 : 1); + from.setDate(first - 7); + to.setDate(first); + break; case 'thisMonth': from.setDate(1); to.setDate(1); to.setMonth(from.getMonth() + 1); break; + case 'previousMonth': + from.setDate(1); + from.setMonth(from.getMonth() - 1); + to.setDate(1); + break; default: } from.setHours(0, 0, 0, 0); @@ -76,5 +92,7 @@ Ext.define('Traccar.view.dialog.ReportConfigController', { this.lookupReference('fromTimeField').setValue(from); this.lookupReference('toDateField').setValue(to); this.lookupReference('toTimeField').setValue(to); + this.lookupReference('fromContainer').setHidden(true); + this.lookupReference('toContainer').setHidden(true); } }); |