diff options
author | Anton Tananaev <anton.tananaev@gmail.com> | 2016-12-22 22:11:50 +1300 |
---|---|---|
committer | GitHub <noreply@github.com> | 2016-12-22 22:11:50 +1300 |
commit | 987f2aad51e825eba983517b113412ff49777c42 (patch) | |
tree | a4922661ae14f4c7c3516023bf347445bb632ae9 | |
parent | 5bccab1d99586777b346d474b34b764e3b595a92 (diff) | |
parent | ca3109cce72bfc780960d468c2fcf6a75f39a859 (diff) | |
download | etbsa-traccar-web-987f2aad51e825eba983517b113412ff49777c42.tar.gz etbsa-traccar-web-987f2aad51e825eba983517b113412ff49777c42.tar.bz2 etbsa-traccar-web-987f2aad51e825eba983517b113412ff49777c42.zip |
Merge pull request #367 from Abyss777/custom_report_color
Add support for custom report colors
-rw-r--r-- | web/app/view/MapMarkerController.js | 28 | ||||
-rw-r--r-- | web/load.js | 14 |
2 files changed, 25 insertions, 17 deletions
diff --git a/web/app/view/MapMarkerController.js b/web/app/view/MapMarkerController.js index b978aaf..510e11b 100644 --- a/web/app/view/MapMarkerController.js +++ b/web/app/view/MapMarkerController.js @@ -276,14 +276,26 @@ Ext.define('Traccar.view.MapMarkerController', { } }, - getRouteStyle: function (deviceId) { - var index = 0; - if (deviceId !== undefined) { - index = deviceId % Traccar.Style.mapRouteColor.length; + getReportColor: function (deviceId) { + var index, reportColor, device = Ext.getStore('Devices').getById(deviceId); + if (device) { + reportColor = device.get('attributes')['web.reportColor']; + } + if (reportColor) { + return reportColor; + } else { + index = 0; + if (deviceId !== undefined) { + index = deviceId % Traccar.Style.mapRouteColor.length; + } + return Traccar.Style.mapRouteColor[index]; } + }, + + getRouteStyle: function (deviceId) { return new ol.style.Style({ stroke: new ol.style.Stroke({ - color: Traccar.Style.mapRouteColor[index], + color: this.getReportColor(deviceId), width: Traccar.Style.mapRouteWidth }) }); @@ -313,11 +325,7 @@ Ext.define('Traccar.view.MapMarkerController', { }, getReportMarker: function (deviceId, angle) { - var index = 0; - if (deviceId !== undefined) { - index = deviceId % Traccar.Style.mapRouteColor.length; - } - return this.getMarkerStyle(false, Traccar.Style.mapRouteColor[index], angle, 'arrow'); + return this.getMarkerStyle(false, this.getReportColor(deviceId), angle, 'arrow'); }, resizeMarker: function (style, zoom) { diff --git a/web/load.js b/web/load.js index cd012f1..4dedd77 100644 --- a/web/load.js +++ b/web/load.js @@ -1,5 +1,5 @@ (function () { - var debugMode, touchMode, locale, localeParameter, extjsVersion, fontAwesomeVersion, olVersion; + var debugMode, touchMode, locale, localeParameter, extjsVersion, fontAwesomeVersion, olVersion, i, language, languages; function addStyleFile(file) { var link = document.createElement('link'); @@ -78,13 +78,13 @@ localeParameter = window.location.search.match(/locale=([^&#]+)/); locale.language = localeParameter && localeParameter[1]; if (!(locale.language in locale.languages)) { - var languages = window.navigator.languages !== undefined ? window.navigator.languages.slice() : []; - var language = window.navigator.userLanguage || window.navigator.language; + languages = window.navigator.languages !== undefined ? window.navigator.languages.slice() : []; + language = window.navigator.userLanguage || window.navigator.language; languages.push(language); - languages.push(language.substr(0,2)); - languages.push("en"); //default - for (var i = 0; i < languages.length; i ++) { - var language = languages[i].replace("-", "_"); + languages.push(language.substr(0, 2)); + languages.push('en'); //default + for (i = 0; i < languages.length; i++) { + language = languages[i].replace('-', '_'); if (language in locale.languages) { locale.language = language; break; |