-
Notifications
You must be signed in to change notification settings - Fork 88
/
component.js
129 lines (117 loc) · 3.61 KB
/
component.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
// The MIT License (MIT)
//
// Copyright (c) 2018-2021 Camptocamp SA
//
// Permission is hereby granted, free of charge, to any person obtaining a copy of
// this software and associated documentation files (the "Software"), to deal in
// the Software without restriction, including without limitation the rights to
// use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
// the Software, and to permit persons to whom the Software is furnished to do so,
// subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included in all
// copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
// FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
// COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
// IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
// CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
import angular from 'angular';
/**
* @type {angular.IModule}
* @hidden
*/
const myModule = angular.module('gmfLidarprofile', []);
myModule.value(
'gmfLidarprofileTemplateUrl',
/**
* @param {JQuery} $element Element.
* @param {angular.IAttributes} $attrs Attributes.
* @return {string} Template.
*/
($element, $attrs) => {
const templateUrl = $attrs.gmfLidarprofileTemplateUrl;
return templateUrl !== undefined ? templateUrl : 'gmf/lidarprofile';
}
);
myModule.run(
/**
* @ngInject
* @param {angular.ITemplateCacheService} $templateCache
*/
($templateCache) => {
// @ts-ignore: webpack
$templateCache.put('gmf/lidarprofile', require('./component.html'));
}
);
/**
* @param {JQuery} $element Element.
* @param {angular.IAttributes} $attrs Attributes.
* @param {function(JQuery, angular.IAttributes): string} gmfLidarprofileTemplateUrl Template function.
* @return {string} Template URL.
* @ngInject
* @private
* @hidden
*/
function gmfLidarprofileTemplateUrl($element, $attrs, gmfLidarprofileTemplateUrl) {
return gmfLidarprofileTemplateUrl($element, $attrs);
}
/**
* Provide a component that display a lidar profile panel.
* You can have only one lidarprofile in your page.
*
* Example:
*
* <gmf-lidarprofile
* gmf-lidarprofile-active="ctrl.profileActive"
* gmf-lidarprofile-line="ctrl.profileLine">
* </gmf-lidarprofile>
*
* @ngdoc component
* @ngname gmfLidarprofile
*/
const lidarprofileComponent = {
controller: 'GmfLidarprofileController',
bindings: {
'active': '=gmfLidarprofileActive',
'line': '=gmfLidarprofileLine',
},
templateUrl: gmfLidarprofileTemplateUrl,
};
myModule.component('gmfLidarprofile', lidarprofileComponent);
/**
* @hidden
*/
export class Controller {
/**
* @param {angular.IScope} $scope Angular scope.
* @ngInject
* @ngdo controller
* @ngname GmfLidarprofileController
*/
constructor($scope) {
/**
* The OpenLayers LineStringt that defines the profile
* @type {?import("ol/geom/LineString.js").default}
*/
this.line = null;
/**
* The profile active state
* @type {boolean}
*/
this.active = false;
// Watch the line to update the profileData (data for the chart).
$scope.$watch(
() => this.line,
(newLine, oldLine) => {
if (oldLine !== newLine) {
this.active = !!this.line;
}
}
);
}
}
myModule.controller('GmfLidarprofileController', Controller);
export default myModule;