aboutsummaryrefslogtreecommitdiff
path: root/web/app/view
diff options
context:
space:
mode:
authorAbyss777 <abyss@fox5.ru>2017-07-17 09:21:43 +0500
committerAbyss777 <abyss@fox5.ru>2017-07-17 09:21:43 +0500
commit714da0355baee78fb28e97aed95db68a63c43424 (patch)
tree2972a37765510e6c53a91e652538baab1d110ca4 /web/app/view
parentdab4694bcab525bcc26e6af42aacc45901093dc2 (diff)
downloadetbsa-traccar-web-714da0355baee78fb28e97aed95db68a63c43424.tar.gz
etbsa-traccar-web-714da0355baee78fb28e97aed95db68a63c43424.tar.bz2
etbsa-traccar-web-714da0355baee78fb28e97aed95db68a63c43424.zip
Implement Geofences column for Devices with filtering
Diffstat (limited to 'web/app/view')
-rw-r--r--web/app/view/ArrayListFilter.js46
-rw-r--r--web/app/view/ReportController.js6
-rw-r--r--web/app/view/edit/Devices.js23
3 files changed, 68 insertions, 7 deletions
diff --git a/web/app/view/ArrayListFilter.js b/web/app/view/ArrayListFilter.js
new file mode 100644
index 0000000..b4442cc
--- /dev/null
+++ b/web/app/view/ArrayListFilter.js
@@ -0,0 +1,46 @@
+/*
+ * 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.ArrayListFilter', {
+ extend: 'Ext.grid.filters.filter.List',
+ alias: 'grid.filter.arraylist',
+
+ type: 'arraylist',
+
+ constructor: function (config) {
+ var me = this;
+ me.callParent([config]);
+ me.filter.setFilterFn(function (item) {
+ var i, property, value;
+ property = item.get(this.getProperty());
+ value = this.getValue();
+ if (Ext.isArray(property)) {
+ for (i = 0; i < property.length; i++) {
+ if (value.indexOf(property[i]) !== -1) {
+ return true;
+ }
+ }
+ } else {
+ if (value.indexOf(property) !== -1) {
+ return true;
+ }
+ }
+ return false;
+ });
+ }
+});
diff --git a/web/app/view/ReportController.js b/web/app/view/ReportController.js
index 7dfeaf3..ff39a56 100644
--- a/web/app/view/ReportController.js
+++ b/web/app/view/ReportController.js
@@ -456,11 +456,7 @@ Ext.define('Traccar.view.ReportController', {
}, {
text: Strings.sharedGeofence,
dataIndex: 'geofenceId',
- renderer: function (value) {
- if (value !== 0) {
- return Ext.getStore('Geofences').getById(value).get('name');
- }
- }
+ renderer: Traccar.AttributeFormatter.getFormatter('geofenceId')
}],
summaryColumns: [{
diff --git a/web/app/view/edit/Devices.js b/web/app/view/edit/Devices.js
index 97cbba2..d601800 100644
--- a/web/app/view/edit/Devices.js
+++ b/web/app/view/edit/Devices.js
@@ -22,7 +22,8 @@ Ext.define('Traccar.view.edit.Devices', {
requires: [
'Ext.grid.filters.Filters',
'Traccar.AttributeFormatter',
- 'Traccar.view.edit.DevicesController'
+ 'Traccar.view.edit.DevicesController',
+ 'Traccar.view.ArrayListFilter'
],
controller: 'devices',
@@ -149,6 +150,24 @@ Ext.define('Traccar.view.edit.Devices', {
},
renderer: Traccar.AttributeFormatter.getFormatter('groupId')
}, {
+ text: Strings.sharedGeofences,
+ dataIndex: 'geofenceIds',
+ hidden: true,
+ filter: {
+ type: 'arraylist',
+ idField: 'id',
+ labelField: 'name',
+ store: 'Geofences'
+ },
+ renderer: function (value) {
+ var i, result = '';
+ for (i = 0; i < value.length; i++) {
+ result += Traccar.AttributeFormatter.geofenceIdFormatter(value[i]);
+ result += (i < value.length - 1) ? ', ' : '';
+ }
+ return result;
+ }
+ }, {
text: Strings.deviceStatus,
dataIndex: 'status',
filter: {
@@ -156,7 +175,7 @@ Ext.define('Traccar.view.edit.Devices', {
labelField: 'name',
store: 'DeviceStatuses'
},
- renderer: function (value, metaData) {
+ renderer: function (value) {
var status;
if (value) {
status = Ext.getStore('DeviceStatuses').getById(value);