From 61bd26d530710e74ef1c0dfd6920b9c1d27cfdd5 Mon Sep 17 00:00:00 2001 From: Anton Tananaev Date: Fri, 5 Jun 2015 19:18:58 +1200 Subject: Add user account dialog --- web/app/view/user/UserDialog.js | 65 +++++++++++++++++++++++++++++++ web/app/view/user/UserDialogController.js | 32 +++++++++++++++ 2 files changed, 97 insertions(+) create mode 100644 web/app/view/user/UserDialog.js create mode 100644 web/app/view/user/UserDialogController.js (limited to 'web/app/view/user') 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(); + } + +}); -- cgit v1.2.3