diff options
author | Anton Tananaev <anton.tananaev@gmail.com> | 2015-10-03 13:39:53 +1300 |
---|---|---|
committer | Anton Tananaev <anton.tananaev@gmail.com> | 2015-10-03 13:39:53 +1300 |
commit | 001424d7ada69390fd7ebea8e585fb0408e147ac (patch) | |
tree | d4bac262bbb0cc2122626004b95eb2d57e089937 /web/app/view/StateController.js | |
parent | 00ebfd00f204bdfbd8e66254b79c7b8814d7ee3b (diff) | |
download | trackermap-server-001424d7ada69390fd7ebea8e585fb0408e147ac.tar.gz trackermap-server-001424d7ada69390fd7ebea8e585fb0408e147ac.tar.bz2 trackermap-server-001424d7ada69390fd7ebea8e585fb0408e147ac.zip |
More clean up for web interface
Diffstat (limited to 'web/app/view/StateController.js')
-rw-r--r-- | web/app/view/StateController.js | 137 |
1 files changed, 137 insertions, 0 deletions
diff --git a/web/app/view/StateController.js b/web/app/view/StateController.js new file mode 100644 index 000000000..dc2ddfb2b --- /dev/null +++ b/web/app/view/StateController.js @@ -0,0 +1,137 @@ +/* + * 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.StateController', { + extend: 'Ext.app.ViewController', + alias: 'controller.state', + + config: { + listen: { + controller: { + '*': { + selectDevice: 'selectDevice' + } + } + } + }, + + init: function() { + var store = Ext.getStore('LatestPositions'); + store.on('add', this.add, this); + store.on('update', this.update, this); + }, + + keys: { + fixTime: { + priority: 1, + name: strings.positionTime + }, + latitude: { + priority: 2, + name: strings.positionLatitude + }, + longitude: { + priority: 3, + name: strings.positionLongitude + }, + valid: { + priority: 4, + name: strings.positionValid + }, + altitude: { + priority: 5, + name: strings.positionAltitude + }, + speed: { + priority: 6, + name: strings.positionSpeed + }, + course: { + priority: 7, + name: strings.positionCourse + }, + address: { + priority: 8, + name: strings.positionAddress + }, + protocol: { + priority: 9, + name: strings.positionProtocol + } + }, + + formatValue: function(value) { + if (typeof(id) === 'number') { + return value.toFixed(2); + } else { + return value; + } + }, + + updatePosition: function(position) { + var attributes, value, unit, store, key; + store = Ext.getStore('Attributes'); + store.removeAll(); + + for (key in position.data) { + if (position.data.hasOwnProperty(key) && this.keys[key] !== undefined) { + store.add(Ext.create('Traccar.model.Attribute', { + priority: this.keys[key].priority, + name: this.keys[key].name, + value: Traccar.AttributeFormatter.getFormatter(key)(position.get(key)) + })); + } + } + + attributes = position.get('attributes'); + if (attributes instanceof Object) { + for (key in attributes) { + if (attributes.hasOwnProperty(key)) { + store.add(Ext.create('Traccar.model.Attribute', { + priority: 1024, + name: key.replace(/^./, function (match) { + return match.toUpperCase(); + }), + value: Traccar.AttributeFormatter.getFormatter(key)(attributes[key]) + })); + } + } + } + }, + + selectDevice: function(device) { + var found; + this.deviceId = device.get('id'); + found = Ext.getStore('LatestPositions').query('deviceId', this.deviceId); + if (found.getCount() > 0) { + this.updatePosition(found.first()); + } else { + Ext.getStore('Attributes').removeAll(); + } + }, + + add: function(store, data) { + if (this.deviceId === data[0].get('deviceId')) { + this.updatePosition(data[0]); + } + }, + + update: function(store, data) { + if (this.deviceId === data.get('deviceId')) { + this.updatePosition(data); + } + } +}); |