aboutsummaryrefslogtreecommitdiff
path: root/web/app/view
diff options
context:
space:
mode:
authorAnton Tananaev <anton.tananaev@gmail.com>2017-05-23 22:43:48 +1200
committerGitHub <noreply@github.com>2017-05-23 22:43:48 +1200
commit4152d5749c9a2030edc4c7548a04ffa0ef851cd9 (patch)
treee742b51bd3e1490dac798af9cd6c152087decdac /web/app/view
parentf4b6d4d46dd8378c2d50d82a6a6c2293fcb796ec (diff)
parentdbf31c907fb261dbc02463e2582a1c1a05ab3657 (diff)
downloadtrackermap-web-4152d5749c9a2030edc4c7548a04ffa0ef851cd9.tar.gz
trackermap-web-4152d5749c9a2030edc4c7548a04ffa0ef851cd9.tar.bz2
trackermap-web-4152d5749c9a2030edc4c7548a04ffa0ef851cd9.zip
Merge pull request #493 from Abyss777/test_computed_attribute
Implement testing computedAttribute
Diffstat (limited to 'web/app/view')
-rw-r--r--web/app/view/dialog/ComputedAttribute.js6
-rw-r--r--web/app/view/dialog/ComputedAttributeController.js13
-rw-r--r--web/app/view/dialog/SelectDevice.js59
-rw-r--r--web/app/view/dialog/SelectDeviceController.js45
4 files changed, 123 insertions, 0 deletions
diff --git a/web/app/view/dialog/ComputedAttribute.js b/web/app/view/dialog/ComputedAttribute.js
index 90234b57..ef6269be 100644
--- a/web/app/view/dialog/ComputedAttribute.js
+++ b/web/app/view/dialog/ComputedAttribute.js
@@ -60,6 +60,12 @@ Ext.define('Traccar.view.dialog.ComputedAttribute', {
},
buttons: [{
+ glyph: 'xf128@FontAwesome',
+ tooltip: Strings.sharedCheckComputedAttribute,
+ tooltipType: 'title',
+ minWidth: 0,
+ handler: 'onCheckClick'
+ }, {
glyph: 'xf00c@FontAwesome',
tooltip: Strings.sharedSave,
tooltipType: 'title',
diff --git a/web/app/view/dialog/ComputedAttributeController.js b/web/app/view/dialog/ComputedAttributeController.js
index 807653a6..f680b1b5 100644
--- a/web/app/view/dialog/ComputedAttributeController.js
+++ b/web/app/view/dialog/ComputedAttributeController.js
@@ -20,6 +20,10 @@ Ext.define('Traccar.view.dialog.ComputedAttributeController', {
extend: 'Traccar.view.dialog.BaseEditController',
alias: 'controller.computedAttribute',
+ requires: [
+ 'Traccar.view.dialog.SelectDevice'
+ ],
+
onAttributeChange: function (combobox, newValue) {
var attribute = Ext.getStore('PositionAttributes').getById(newValue);
if (attribute) {
@@ -28,5 +32,14 @@ Ext.define('Traccar.view.dialog.ComputedAttributeController', {
} else {
this.getView().lookupReference('typeComboField').setReadOnly(false);
}
+ },
+
+ onCheckClick: function (button) {
+ var dialog, form;
+ dialog = Ext.create('Traccar.view.dialog.SelectDevice');
+ form = button.up('window').down('form');
+ form.updateRecord();
+ dialog.record = form.getRecord();
+ dialog.show();
}
});
diff --git a/web/app/view/dialog/SelectDevice.js b/web/app/view/dialog/SelectDevice.js
new file mode 100644
index 00000000..5b11c03f
--- /dev/null
+++ b/web/app/view/dialog/SelectDevice.js
@@ -0,0 +1,59 @@
+/*
+ * Copyright 2017 Anton Tananaev (anton@traccar.org)
+ * Copyright 2017 Andrey Kunitsyn (andrey@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.SelectDevice', {
+ extend: 'Traccar.view.dialog.Base',
+
+ requires: [
+ 'Traccar.view.dialog.SelectDeviceController'
+ ],
+
+ controller: 'selectDevice',
+ title: Strings.sharedDevice,
+
+ items: {
+ xtype: 'form',
+ items: [{
+ xtype: 'combobox',
+ reference: 'deviceField',
+ store: 'Devices',
+ queryMode: 'local',
+ displayField: 'name',
+ valueField: 'id',
+ editable: false,
+ listeners: {
+ change: 'onDeviceChange'
+ }
+ }]
+ },
+
+ buttons: [{
+ glyph: 'xf00c@FontAwesome',
+ reference: 'saveButton',
+ tooltip: Strings.sharedSave,
+ tooltipType: 'title',
+ minWidth: 0,
+ handler: 'onSaveClick',
+ disabled: true
+ }, {
+ glyph: 'xf00d@FontAwesome',
+ tooltip: Strings.sharedCancel,
+ tooltipType: 'title',
+ minWidth: 0,
+ handler: 'closeView'
+ }]
+});
diff --git a/web/app/view/dialog/SelectDeviceController.js b/web/app/view/dialog/SelectDeviceController.js
new file mode 100644
index 00000000..9ed5e217
--- /dev/null
+++ b/web/app/view/dialog/SelectDeviceController.js
@@ -0,0 +1,45 @@
+/*
+ * Copyright 2017 Anton Tananaev (anton@traccar.org)
+ * Copyright 2017 Andrey Kunitsyn (andrey@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.SelectDeviceController', {
+ extend: 'Ext.app.ViewController',
+ alias: 'controller.selectDevice',
+
+ onSaveClick: function (button) {
+ var deviceId, record;
+ deviceId = this.lookupReference('deviceField').getValue();
+ record = this.getView().record.data;
+ Ext.Ajax.request({
+ url: 'api/attributes/computed?deviceId=' + deviceId,
+ method: 'POST',
+ jsonData: Ext.util.JSON.encode(record),
+ callback: function (options, success, response) {
+ if (success) {
+ Ext.Msg.alert(Strings.sharedInfoTitle, response.responseText || response.statusText);
+ } else {
+ Traccar.app.showError(response);
+ }
+ }
+ });
+ button.up('window').close();
+ },
+
+ onDeviceChange: function (combobox, newValue) {
+ this.lookupReference('saveButton').setDisabled(newValue === null);
+ }
+});