diff options
author | Anton Tananaev <anton.tananaev@gmail.com> | 2017-03-29 09:58:40 +1300 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-03-29 09:58:40 +1300 |
commit | f78c547cdda0180a16bf76ddd7395d57dfc49016 (patch) | |
tree | e224b0867554d64ba7c2a985c1ceaab529a075d1 /web/app/view/dialog/UserController.js | |
parent | 94973f80f543f82630351a7e5943dd4c9150a8b0 (diff) | |
parent | 6f0bcddcac9a2ec711f545f1278a4ec991d05aa6 (diff) | |
download | trackermap-web-f78c547cdda0180a16bf76ddd7395d57dfc49016.tar.gz trackermap-web-f78c547cdda0180a16bf76ddd7395d57dfc49016.tar.bz2 trackermap-web-f78c547cdda0180a16bf76ddd7395d57dfc49016.zip |
Merge pull request #454 from Abyss777/move_dialog
Move BaseDialog, subclasses and their controllers to dialog subfolder
Diffstat (limited to 'web/app/view/dialog/UserController.js')
-rw-r--r-- | web/app/view/dialog/UserController.js | 79 |
1 files changed, 79 insertions, 0 deletions
diff --git a/web/app/view/dialog/UserController.js b/web/app/view/dialog/UserController.js new file mode 100644 index 00000000..89b0bc83 --- /dev/null +++ b/web/app/view/dialog/UserController.js @@ -0,0 +1,79 @@ +/* + * 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 + * the Free Software Foundation, either version 3 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program. If not, see <http://www.gnu.org/licenses/>. + */ + +Ext.define('Traccar.view.dialog.UserController', { + extend: 'Traccar.view.dialog.MapPickerController', + alias: 'controller.user', + + init: function () { + if (Traccar.app.getUser().get('admin')) { + this.lookupReference('adminField').setDisabled(false); + this.lookupReference('deviceLimitField').setDisabled(false); + this.lookupReference('userLimitField').setDisabled(false); + } + if (Traccar.app.getUser().get('admin') || !this.getView().selfEdit) { + this.lookupReference('readonlyField').setDisabled(false); + this.lookupReference('disabledField').setDisabled(false); + this.lookupReference('expirationTimeField').setDisabled(false); + this.lookupReference('deviceReadonlyField').setDisabled(false); + } + }, + + symbols: 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789', + + generateToken: function () { + var i, newToken = ''; + + for (i = 0; i < 32; i++) { + newToken += this.symbols.charAt(Math.floor(Math.random() * this.symbols.length)); + } + + this.lookupReference('tokenField').setValue(newToken); + }, + + testNotification: function () { + Ext.Ajax.request({ + url: 'api/users/notifications/test', + method: 'POST', + failure: function (response) { + Traccar.app.showError(response); + } + }); + }, + + onSaveClick: function (button) { + var dialog, record, store; + dialog = button.up('window').down('form'); + dialog.updateRecord(); + record = dialog.getRecord(); + if (record === Traccar.app.getUser()) { + record.save(); + } else { + store = Ext.getStore('Users'); + if (record.phantom) { + store.add(record); + } + store.sync({ + failure: function (batch) { + store.rejectChanges(); + Traccar.app.showError(batch.exceptions[0].getError().response); + } + }); + } + button.up('window').close(); + } +}); |