diff options
Diffstat (limited to 'web/app/view')
-rw-r--r-- | web/app/view/device/Device.js | 3 | ||||
-rw-r--r-- | web/app/view/device/DeviceController.js | 8 | ||||
-rw-r--r-- | web/app/view/user/UserDialog.js | 65 | ||||
-rw-r--r-- | web/app/view/user/UserDialogController.js | 32 |
4 files changed, 108 insertions, 0 deletions
diff --git a/web/app/view/device/Device.js b/web/app/view/device/Device.js index bccb43e9e..a166cb573 100644 --- a/web/app/view/device/Device.js +++ b/web/app/view/device/Device.js @@ -47,6 +47,9 @@ Ext.define('Traccar.view.device.Device', { }, { text: strings.device_settings, menu: [{ + text: strings.device_settings_user, + handler: 'onUserClick' + }, { text: strings.device_settings_server, disabled: true, handler: 'onServerClick', diff --git a/web/app/view/device/DeviceController.js b/web/app/view/device/DeviceController.js index 6d88d8d3e..451b6bbf3 100644 --- a/web/app/view/device/DeviceController.js +++ b/web/app/view/device/DeviceController.js @@ -20,6 +20,7 @@ Ext.define('Traccar.view.device.DeviceController', { requires: [ 'Traccar.view.device.DeviceDialog', + 'Traccar.view.user.UserDialog', 'Traccar.view.admin.ServerDialog' ], @@ -73,6 +74,13 @@ Ext.define('Traccar.view.device.DeviceController', { this.lookupReference('deviceRemoveButton').setDisabled(disabled); }, + onUserClick: function() { + var user = Traccar.getApplication().getUser(); + var dialog = Ext.create('Traccar.view.user.UserDialog'); + dialog.down('form').loadRecord(user); + dialog.show(); + }, + onServerClick: function() { var server = Traccar.getApplication().getServer(); var dialog = Ext.create('Traccar.view.admin.ServerDialog'); diff --git a/web/app/view/user/UserDialog.js b/web/app/view/user/UserDialog.js new file mode 100644 index 000000000..7b6dc4199 --- /dev/null +++ b/web/app/view/user/UserDialog.js @@ -0,0 +1,65 @@ +/* + * Copyright 2015 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.user.UserDialog', { + extend: 'Ext.window.Window', + xtype: 'user-dialog', + + requires: [ + 'Traccar.view.user.UserDialogController' + ], + + controller: 'userdialog', + + bodyPadding: styles.panel_padding, + title: strings.login_user_title, + resizable: false, + modal: true, + + items: { + xtype: 'form', + items: [{ + xtype: 'textfield', + name: 'name', + fieldLabel: strings.login_name + }, { + xtype: 'textfield', + name: 'email', + fieldLabel: strings.login_email, + allowBlank: false + }, { + xtype: 'textfield', + name: 'password', + fieldLabel: strings.login_password, + inputType: 'password', + allowBlank: false + }, { + xtype: 'checkboxfield', + name: 'admin', + fieldLabel: strings.login_admin, + allowBlank: false + }] + }, + + buttons: [{ + text: strings.dialog_save, + handler: 'onSaveClick' + }, { + text: strings.dialog_cancel, + handler: 'onCancelClick' + }] + +}); diff --git a/web/app/view/user/UserDialogController.js b/web/app/view/user/UserDialogController.js new file mode 100644 index 000000000..4c6b6c42f --- /dev/null +++ b/web/app/view/user/UserDialogController.js @@ -0,0 +1,32 @@ +/* + * Copyright 2015 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.user.UserDialogController', { + extend: 'Ext.app.ViewController', + alias: 'controller.userdialog', + + onSaveClick: function(button) { + var dialog = button.up('window').down('form'); + dialog.updateRecord(); + dialog.getRecord().save(); + button.up('window').close(); + }, + + onCancelClick: function(button) { + button.up('window').close(); + } + +}); |