From ff266d342ae3c6922005f043470ef659447882b5 Mon Sep 17 00:00:00 2001 From: Anton Tananaev Date: Thu, 7 Apr 2016 17:05:08 +1200 Subject: Create separate class for tree store --- web/app/store/DevicesTree.js | 100 +++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 100 insertions(+) create mode 100644 web/app/store/DevicesTree.js (limited to 'web/app/store') diff --git a/web/app/store/DevicesTree.js b/web/app/store/DevicesTree.js new file mode 100644 index 000000000..eaf451a3e --- /dev/null +++ b/web/app/store/DevicesTree.js @@ -0,0 +1,100 @@ +/* + * Copyright 2016 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.store.DevicesTree', { + extend: 'Ext.data.TreeStore', + + parentIdProperty: 'groupId', + + proxy: { + type: 'memory', + reader: { + type: 'json' + } + }, + + constructor: function () { + this.callParent(arguments); + + Ext.getStore('Groups').on({ + scope: this, + load: this.onGroupLoad, + update: this.onGroupUpdate + }); + + Ext.getStore('Devices').on({ + scope: this, + load: this.onDeviceLoad, + update: this.onDeviceUpdate + }); + }, + + reloadData: function () { + var groupsStore, devicesStore, nodes = []; + groupsStore = Ext.getStore('Groups'); + devicesStore = Ext.getStore('Devices'); + + groupsStore.each(function (record) { + var groupId, node = { + id: 'g' + record.get('id'), + original: record, + name: record.get('name'), + leaf: true + }; + groupId = record.get('groupId'); + if (groupId !== 0 && groupsStore.indexOfId(groupId) !== -1) { + node.groupId = 'g' + groupId; + } + nodes.push(node); + }, this); + devicesStore.each(function (record) { + var groupId, node = { + id: 'd' + record.get('id'), + original: record, + name: record.get('name'), + status: record.get('status'), + lastUpdate: record.get('lastUpdate'), + leaf: true + }; + groupId = record.get('groupId'); + if (groupId !== 0 && groupsStore.indexOfId(groupId) !== -1) { + node.groupId = 'g' + groupId; + } + nodes.push(node); + }, this); + + this.getProxy().setData(nodes); + this.load(); + }, + + onGroupLoad: function () { + console.log('onGroupLoad'); + this.reloadData(); + }, + + onDeviceLoad: function () { + console.log('onDeviceLoad'); + this.reloadData(); + }, + + onGroupUpdate: function () { + console.log('onGroupUpdate'); + }, + + onDeviceUpdate: function () { + console.log('onDeviceUpdate'); + } +}); -- cgit v1.2.3