/* * Copyright 2015 - 2016 Anton Tananaev (anton.tananaev@gmail.com) * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ Ext.define('Traccar.view.DevicesController', { extend: 'Ext.app.ViewController', alias: 'controller.devices', requires: [ 'Traccar.view.CommandDialog', 'Traccar.view.DeviceDialog', 'Traccar.view.DeviceGeofences', 'Traccar.view.BaseWindow', 'Traccar.model.Device', 'Traccar.model.Command' ], config: { listen: { controller: { '*': { selectdevice: 'selectDevice', selectreport: 'selectReport' } }, store: { '#Devices': { update: 'onUpdateDevice' } } } }, init: function () { var readonly = Traccar.app.getServer().get('readonly') && !Traccar.app.getUser().get('admin'); this.lookupReference('toolbarAddButton').setVisible(!readonly); this.lookupReference('toolbarEditButton').setVisible(!readonly); this.lookupReference('toolbarRemoveButton').setVisible(!readonly); 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(); } } }); }, onGeofencesClick: function () { var device = this.getView().getSelectionModel().getSelection()[0]; Ext.create('Traccar.view.BaseWindow', { title: Strings.sharedGeofences, items: { xtype: 'deviceGeofencesView', baseObjectName: 'deviceId', linkObjectName: 'geofenceId', storeName: 'Geofences', urlApi: 'api/devices/geofences', baseObject: device.getId() } }).show(); }, onCommandClick: function () { var device, deviceId, command, dialog, comboStore; device = this.getView().getSelectionModel().getSelection()[0]; deviceId = device.get('id'); command = Ext.create('Traccar.model.Command'); command.set('deviceId', deviceId); dialog = Ext.create('Traccar.view.CommandDialog'); comboStore = dialog.down('form').down('combobox').getStore(); comboStore.getProxy().setExtraParam('deviceId', deviceId); dialog.down('form').loadRecord(command); dialog.show(); }, onFollowClick: function (button, pressed) { var device; if (pressed) { device = this.getView().getSelectionModel().getSelection()[0]; this.fireEvent('selectdevice', device, true); } }, updateButtons: function (selected) { var empty = selected.getCount() === 0; this.lookupReference('toolbarEditButton').setDisabled(empty); this.lookupReference('toolbarRemoveButton').setDisabled(empty); this.lookupReference('toolbarGeofencesButton').setDisabled(empty); this.lookupReference('deviceCommandButton').setDisabled(empty || (selected.getLastSelected().get('status') !== 'online')); }, onSelectionChange: function (selected) { this.updateButtons(selected); if (selected.getCount() > 0) { this.fireEvent('selectdevice', selected.getLastSelected(), true); } }, selectDevice: function (device, center) { this.getView().getSelectionModel().select([device], false, true); }, selectReport: function (position) { if (position !== undefined) { this.getView().getSelectionModel().deselectAll(); } }, onUpdateDevice: function (store, data) { this.updateButtons(this.getView().getSelectionModel()); } });