...
|
...
|
@@ -17,9 +17,7 @@ import './trip-animation-widget.scss'; |
17
|
17
|
import template from "./trip-animation-widget.tpl.html";
|
18
|
18
|
import TbOpenStreetMap from '../openstreet-map';
|
19
|
19
|
import L from 'leaflet';
|
20
|
|
-//import tinycolor from 'tinycolor2';
|
21
|
|
-import MultiOptionsPolyline from '../../../../vendor/leaflet-multi-options-polyline/Leaflet.MultiOptionsPolyline';
|
22
|
|
-import GeometryUtil from '../../../../vendor/leaflet-geometryutil/leaflet-geometryutil';
|
|
20
|
+// //import tinycolor from 'tinycolor2';
|
23
|
21
|
import tinycolor from "tinycolor2";
|
24
|
22
|
import {fillPatternWithActions, isNumber, padValue, processPattern} from "../widget-utils";
|
25
|
23
|
//import {fillPatternWithActions, isNumber, padValue, processPattern, fillPattern} from "../widget-utils";
|
...
|
...
|
@@ -128,6 +126,8 @@ function tripAnimationController($document, $scope, $http, $timeout, $filter, $l |
128
|
126
|
//const varsRegex = /\$\{([^\}]*)\}/g;
|
129
|
127
|
//let icon;
|
130
|
128
|
|
|
129
|
+ vm.initBounds = true;
|
|
130
|
+
|
131
|
131
|
vm.markers = [];
|
132
|
132
|
vm.index = 0;
|
133
|
133
|
vm.dsIndex = 0;
|
...
|
...
|
@@ -147,12 +147,6 @@ function tripAnimationController($document, $scope, $http, $timeout, $filter, $l |
147
|
147
|
vm.showHideTooltip = showHideTooltip;
|
148
|
148
|
vm.recalculateTrips = recalculateTrips;
|
149
|
149
|
|
150
|
|
- L.MultiOptionsPolyline = MultiOptionsPolyline;
|
151
|
|
- L.GeometryUtil = GeometryUtil;
|
152
|
|
- L.multiOptionsPolyline = function (latlngs, options) {
|
153
|
|
- return new MultiOptionsPolyline(latlngs, options);
|
154
|
|
- };
|
155
|
|
-
|
156
|
150
|
$scope.$watch('vm.ctx', function () {
|
157
|
151
|
if (vm.ctx) {
|
158
|
152
|
vm.utils = vm.ctx.$scope.$injector.get('utils');
|
...
|
...
|
@@ -240,8 +234,14 @@ function tripAnimationController($document, $scope, $http, $timeout, $filter, $l |
240
|
234
|
|
241
|
235
|
vm.showTimestamp = vm.settings.showTimestamp !== false;
|
242
|
236
|
vm.ctx.$element = angular.element("#heat-map", vm.ctx.$container);
|
243
|
|
- //vm.map = L.map(vm.ctx.$element[0]).setView([0, 0], 2);
|
244
|
|
- vm.map = new TbOpenStreetMap(vm.ctx.$element, vm.utils, initCallback, 2, null, null, vm.staticSettings.mapProvider);
|
|
237
|
+ vm.defaultZoomLevel = 2;
|
|
238
|
+ if (vm.ctx.settings.defaultZoomLevel) {
|
|
239
|
+ if (vm.ctx.settings.defaultZoomLevel > 0 && vm.ctx.settings.defaultZoomLevel < 21) {
|
|
240
|
+ vm.defaultZoomLevel = Math.floor(vm.ctx.settings.defaultZoomLevel);
|
|
241
|
+ }
|
|
242
|
+ }
|
|
243
|
+ vm.dontFitMapBounds = vm.ctx.settings.fitMapBounds === false;
|
|
244
|
+ vm.map = new TbOpenStreetMap(vm.ctx.$element, vm.utils, initCallback, vm.defaultZoomLevel, vm.dontFitMapBounds, null, vm.staticSettings.mapProvider);
|
245
|
245
|
vm.map.bounds = vm.map.createBounds();
|
246
|
246
|
vm.map.invalidateSize(true);
|
247
|
247
|
vm.map.bounds = vm.map.createBounds();
|
...
|
...
|
@@ -262,6 +262,7 @@ function tripAnimationController($document, $scope, $http, $timeout, $filter, $l |
262
|
262
|
staticSettings.lngKeyName = vm.ctx.settings.lngKeyName || "longitude";
|
263
|
263
|
staticSettings.rotationAngle = vm.ctx.settings.rotationAngle || 0;
|
264
|
264
|
staticSettings.displayTooltip = vm.ctx.settings.showTooltip || false;
|
|
265
|
+ staticSettings.defaultZoomLevel = vm.ctx.settings.defaultZoomLevel || true;
|
265
|
266
|
staticSettings.showTooltip = false;
|
266
|
267
|
staticSettings.label = vm.ctx.settings.label || "${entityName}";
|
267
|
268
|
staticSettings.useLabelFunction = vm.ctx.settings.useLabelFunction || false;
|
...
|
...
|
@@ -282,7 +283,7 @@ function tripAnimationController($document, $scope, $http, $timeout, $filter, $l |
282
|
283
|
staticSettings.pointColor = vm.ctx.settings.pointColor ? tinycolor(vm.ctx.settings.pointColor).toHexString() : "#ff6300";
|
283
|
284
|
staticSettings.markerImages = vm.ctx.settings.markerImages || [];
|
284
|
285
|
staticSettings.icon = L.icon({
|
285
|
|
- iconUrl: "",
|
|
286
|
+ iconUrl: "",
|
286
|
287
|
iconSize: [30, 30],
|
287
|
288
|
iconAnchor: [15, 15]
|
288
|
289
|
});
|
...
|
...
|
@@ -468,24 +469,38 @@ function tripAnimationController($document, $scope, $http, $timeout, $filter, $l |
468
|
469
|
vm.trips.forEach(function (trip) {
|
469
|
470
|
if (trip.marker) {
|
470
|
471
|
trip.marker.remove();
|
|
472
|
+ delete trip.marker;
|
471
|
473
|
}
|
472
|
474
|
if (trip.polyline) {
|
473
|
475
|
trip.polyline.remove();
|
|
476
|
+ delete trip.polyline;
|
474
|
477
|
}
|
475
|
478
|
if (trip.points && trip.points.length) {
|
476
|
479
|
trip.points.forEach(function (point) {
|
477
|
480
|
point.remove();
|
478
|
|
- })
|
|
481
|
+ });
|
|
482
|
+ delete trip.points;
|
479
|
483
|
}
|
480
|
|
- })
|
|
484
|
+ });
|
|
485
|
+ vm.initBounds = true;
|
481
|
486
|
}
|
482
|
487
|
let normalizedTimeRange = createNormalizedTime(vm.data, 1000);
|
483
|
488
|
createNormalizedTrips(normalizedTimeRange, vm.datasources);
|
484
|
489
|
createTripsOnMap();
|
485
|
|
- vm.trips.forEach(function (trip) {
|
486
|
|
- vm.map.extendBounds(vm.map.bounds, trip.polyline);
|
|
490
|
+ if (vm.initBounds && !vm.initTrips) {
|
|
491
|
+ vm.trips.forEach(function (trip) {
|
|
492
|
+ vm.map.extendBounds(vm.map.bounds, trip.polyline);
|
|
493
|
+ vm.initBounds = !vm.datasources.every(
|
|
494
|
+ function (ds) {
|
|
495
|
+ return ds.dataReceived === true;
|
|
496
|
+ });
|
|
497
|
+ vm.initTrips = vm.trips.every(function (trip) {
|
|
498
|
+ return angular.isDefined(trip.marker) && angular.isDefined(trip.polyline);
|
|
499
|
+ });
|
|
500
|
+ });
|
|
501
|
+
|
487
|
502
|
vm.map.fitBounds(vm.map.bounds);
|
488
|
|
- })
|
|
503
|
+ }
|
489
|
504
|
|
490
|
505
|
}
|
491
|
506
|
|
...
|
...
|
@@ -650,8 +665,9 @@ function tripAnimationController($document, $scope, $http, $timeout, $filter, $l |
650
|
665
|
|
651
|
666
|
function moveMarker(trip) {
|
652
|
667
|
if (angular.isDefined(trip.marker)) {
|
|
668
|
+ trip.markerAngleIsSet = true;
|
653
|
669
|
trip.marker.setLatLng(trip.timeRange[vm.index].latLng);
|
654
|
|
- trip.marker.setRotationAngle(trip.timeRange[vm.index].h + vm.staticSettings.rotationAngle);
|
|
670
|
+ trip.marker.setRotationAngle(trip.timeRange[vm.index].h);
|
655
|
671
|
trip.marker.update();
|
656
|
672
|
} else {
|
657
|
673
|
if (trip.timeRange && trip.timeRange.length) {
|
...
|
...
|
@@ -670,6 +686,7 @@ function tripAnimationController($document, $scope, $http, $timeout, $filter, $l |
670
|
686
|
configureTripSettings(trip);
|
671
|
687
|
}
|
672
|
688
|
|
|
689
|
+
|
673
|
690
|
function showHideTooltip(trip) {
|
674
|
691
|
if (vm.staticSettings.displayTooltip) {
|
675
|
692
|
if (vm.staticSettings.showTooltip && trip && vm.activeTripIndex !== trip.dSIndex) {
|
...
|
...
|
|