diff options
author | Anton Tananaev <anton.tananaev@gmail.com> | 2017-01-31 17:06:07 +1300 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-01-31 17:06:07 +1300 |
commit | 962c40e2127f9c9a7687e4ccb7a6d4a33ac203f7 (patch) | |
tree | 20aa53bbe7d9bb08391e97afdaf1210afd2e4077 /web/app/view/DevicesController.js | |
parent | d1dd9f84e819d70154861ac2487f902da12885ed (diff) | |
parent | da14c04199fe22e6c8bdc02edb2fba7a7ab96a4c (diff) | |
download | trackermap-web-962c40e2127f9c9a7687e4ccb7a6d4a33ac203f7.tar.gz trackermap-web-962c40e2127f9c9a7687e4ccb7a6d4a33ac203f7.tar.bz2 trackermap-web-962c40e2127f9c9a7687e4ccb7a6d4a33ac203f7.zip |
Merge pull request #394 from Abyss777/toolbar_controller
Implement base controller for windows with EditToolbar
Diffstat (limited to 'web/app/view/DevicesController.js')
-rw-r--r-- | web/app/view/DevicesController.js | 51 |
1 files changed, 6 insertions, 45 deletions
diff --git a/web/app/view/DevicesController.js b/web/app/view/DevicesController.js index f7e4bb47..e856731c 100644 --- a/web/app/view/DevicesController.js +++ b/web/app/view/DevicesController.js @@ -1,5 +1,5 @@ /* - * Copyright 2015 - 2016 Anton Tananaev (anton@traccar.org) + * Copyright 2015 - 2017 Anton Tananaev (anton@traccar.org) * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by @@ -16,7 +16,7 @@ */ Ext.define('Traccar.view.DevicesController', { - extend: 'Ext.app.ViewController', + extend: 'Traccar.view.EditToolbarController', alias: 'controller.devices', requires: [ @@ -47,6 +47,10 @@ Ext.define('Traccar.view.DevicesController', { } }, + objectModel: 'Traccar.model.Device', + objectDialog: 'Traccar.view.DeviceDialog', + removeTitle: Strings.sharedDevice, + init: function () { var readonly, deviceReadonly; deviceReadonly = Traccar.app.getUser().get('deviceReadonly'); @@ -57,49 +61,6 @@ Ext.define('Traccar.view.DevicesController', { this.lookupReference('toolbarGeofencesButton').setVisible(!readonly); }, - onAddClick: function () { - var device, dialog; - device = Ext.create('Traccar.model.Device'); - device.store = Ext.getStore('Devices'); - dialog = Ext.create('Traccar.view.DeviceDialog'); - dialog.down('form').loadRecord(device); - dialog.show(); - }, - - onEditClick: function () { - var device, dialog; - device = this.getView().getSelectionModel().getSelection()[0]; - dialog = Ext.create('Traccar.view.DeviceDialog'); - dialog.down('form').loadRecord(device); - dialog.show(); - }, - - onRemoveClick: function () { - var device = this.getView().getSelectionModel().getSelection()[0]; - Ext.Msg.show({ - title: Strings.deviceDialog, - message: Strings.sharedRemoveConfirm, - buttons: Ext.Msg.YESNO, - buttonText: { - yes: Strings.sharedRemove, - no: Strings.sharedCancel - }, - fn: function (btn) { - var store; - if (btn === 'yes') { - store = Ext.getStore('Devices'); - store.remove(device); - store.sync({ - failure: function (batch) { - store.rejectChanges(); - Traccar.app.showError(batch.exceptions[0].getError().response); - } - }); - } - } - }); - }, - onGeofencesClick: function () { var device = this.getView().getSelectionModel().getSelection()[0]; Ext.create('Traccar.view.BaseWindow', { |