@flexem/fc-gui 3.0.0-alpha.94 → 3.0.0-alpha.96
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +2 -35
- package/bundles/@flexem/fc-gui.umd.js +90 -223
- package/bundles/@flexem/fc-gui.umd.js.map +1 -1
- package/bundles/@flexem/fc-gui.umd.min.js +4 -4
- package/bundles/@flexem/fc-gui.umd.min.js.map +1 -1
- package/elements/historical-curve/historical-curve.element.d.ts +0 -3
- package/elements/historical-curve/historical-curve.element.js +0 -71
- package/elements/historical-curve/historical-curve.element.metadata.json +1 -1
- package/elements/video/video-element.d.ts +3 -4
- package/elements/video/video-element.js +86 -129
- package/elements/video/video-element.metadata.json +1 -1
- package/elements/view-operation/view-operation.element.js +0 -8
- package/modal/write-value/write-value-modal.component.js +2 -13
- package/model/historical-curve/historical-curve-chanel.model.d.ts +0 -8
- package/package.json +1 -1
|
@@ -32,8 +32,6 @@ export declare class HistoricalCurveElement extends ConditionalDisplayElement {
|
|
|
32
32
|
private elementStatus;
|
|
33
33
|
private chartElement;
|
|
34
34
|
private isMobileMode;
|
|
35
|
-
private data;
|
|
36
|
-
private timer;
|
|
37
35
|
constructor(element: HTMLElement, injector: Injector, permissionChecker: PermissionChecker, variableCommunicator: VariableCommunicator, variableStore: VariableStore, historyDataStore: HistoryDataStore, signalRAppId: string);
|
|
38
36
|
dispose(): void;
|
|
39
37
|
private getValidTimePeriods;
|
|
@@ -42,7 +40,6 @@ export declare class HistoricalCurveElement extends ConditionalDisplayElement {
|
|
|
42
40
|
private reRenderElement;
|
|
43
41
|
private renderElement;
|
|
44
42
|
private renderChart;
|
|
45
|
-
initPoint(): void;
|
|
46
43
|
private getLineChart;
|
|
47
44
|
private getMultiBarWithFocusChart;
|
|
48
45
|
private renderCommonProperty;
|
|
@@ -29,7 +29,6 @@ export class HistoricalCurveElement extends ConditionalDisplayElement {
|
|
|
29
29
|
operationButtonMargin: 4
|
|
30
30
|
};
|
|
31
31
|
this.elementStatus = HistoricalCurveElementStatus.Loading;
|
|
32
|
-
this.data = [];
|
|
33
32
|
this.logger = injector.get(LOGGER_SERVICE_TOKEN);
|
|
34
33
|
this.localization = injector.get(LOCALIZATION);
|
|
35
34
|
this.timePeriods = this.getValidTimePeriods();
|
|
@@ -141,7 +140,6 @@ export class HistoricalCurveElement extends ConditionalDisplayElement {
|
|
|
141
140
|
each(result, v => values.push({ x: moment(v.time).local().toDate().valueOf(), y: v.values[key] }));
|
|
142
141
|
data.push({ key: channel.name, area: channel.projectEnabled, values: values });
|
|
143
142
|
});
|
|
144
|
-
this.data = data;
|
|
145
143
|
nv.addGraph(() => {
|
|
146
144
|
if (this.model.displaySetting.curveType === CurveType.BarGroup || this.model.displaySetting.curveType === CurveType.BarStack) {
|
|
147
145
|
return this.getMultiBarWithFocusChart(chartWidth, chartHeight, data);
|
|
@@ -151,50 +149,6 @@ export class HistoricalCurveElement extends ConditionalDisplayElement {
|
|
|
151
149
|
}
|
|
152
150
|
});
|
|
153
151
|
}
|
|
154
|
-
initPoint() {
|
|
155
|
-
try {
|
|
156
|
-
const legendList = this.$element
|
|
157
|
-
.find('.nv-legend')
|
|
158
|
-
.find('.nv-series');
|
|
159
|
-
let hiddenCount = 0;
|
|
160
|
-
for (let i = 0; i < this.data.length; i++) {
|
|
161
|
-
const channel = this.model.dataSetting.channels[i];
|
|
162
|
-
if (legendList.eq(i).children().eq(0).css('fill-opacity') === '1') {
|
|
163
|
-
const pointList = this.$element
|
|
164
|
-
.find('.nv-scatterWrap')
|
|
165
|
-
.find('.nv-series-' + (i - hiddenCount))
|
|
166
|
-
.find('.nv-point');
|
|
167
|
-
if (pointList && pointList.length) {
|
|
168
|
-
for (let j = 0; j < pointList.length; j++) {
|
|
169
|
-
const point = pointList.eq(j);
|
|
170
|
-
const previousPoint = pointList.eq(j - 1);
|
|
171
|
-
if (j && point.attr('transform').split(',')[1] !== previousPoint.attr('transform').split(',')[1]) {
|
|
172
|
-
if (channel.enablePoint && channel.pointColor) {
|
|
173
|
-
const pointStyle = {
|
|
174
|
-
'stroke-opacity': 1,
|
|
175
|
-
'stroke-width': '2px',
|
|
176
|
-
'stroke': channel.pointColor,
|
|
177
|
-
'fill-opacity': 1,
|
|
178
|
-
'fill': channel.pointColor
|
|
179
|
-
};
|
|
180
|
-
point.addClass('nv-mark-point');
|
|
181
|
-
point.css(pointStyle);
|
|
182
|
-
previousPoint.addClass('nv-mark-point');
|
|
183
|
-
previousPoint.css(pointStyle);
|
|
184
|
-
}
|
|
185
|
-
}
|
|
186
|
-
}
|
|
187
|
-
}
|
|
188
|
-
}
|
|
189
|
-
else {
|
|
190
|
-
hiddenCount++;
|
|
191
|
-
}
|
|
192
|
-
}
|
|
193
|
-
}
|
|
194
|
-
catch (e) {
|
|
195
|
-
console.log(e);
|
|
196
|
-
}
|
|
197
|
-
}
|
|
198
152
|
getLineChart(chartWidth, chartHeight, data) {
|
|
199
153
|
const chart = nv.models.lineChart().showLegend(true)
|
|
200
154
|
.margin({ top: 0, bottom: 0, left: this.displayOption.marginLeft, right: this.displayOption.marginRight })
|
|
@@ -210,19 +164,6 @@ export class HistoricalCurveElement extends ConditionalDisplayElement {
|
|
|
210
164
|
}
|
|
211
165
|
this.renderCommonProperty(chart, chartWidth, chartHeight, data);
|
|
212
166
|
this.renderOperationArea(chartWidth, chartHeight);
|
|
213
|
-
this.initPoint();
|
|
214
|
-
chart.legend.dispatch.on('legendClick', () => {
|
|
215
|
-
setTimeout(() => {
|
|
216
|
-
this.$element.find('.nv-mark-point').css({
|
|
217
|
-
'stroke-opacity': 0,
|
|
218
|
-
'stroke-width': 0,
|
|
219
|
-
'stroke': 'unset',
|
|
220
|
-
'fill-opacity': 0,
|
|
221
|
-
'fill': 'unset'
|
|
222
|
-
}).removeClass('nv-mark-point');
|
|
223
|
-
this.initPoint();
|
|
224
|
-
}, 1);
|
|
225
|
-
});
|
|
226
167
|
return chart;
|
|
227
168
|
}
|
|
228
169
|
getMultiBarWithFocusChart(chartWidth, chartHeight, data) {
|
|
@@ -266,18 +207,6 @@ export class HistoricalCurveElement extends ConditionalDisplayElement {
|
|
|
266
207
|
chart.tooltip.headerFormatter(d => this.timeFormat(d, '%x %X'));
|
|
267
208
|
if (this.model.displaySetting.showAxis) {
|
|
268
209
|
chart.xAxis.showMaxMin(true).tickFormat(d => {
|
|
269
|
-
this.$element.find('.nv-mark-point').css({
|
|
270
|
-
'stroke-opacity': 0,
|
|
271
|
-
'stroke-width': 0,
|
|
272
|
-
'stroke': 'unset',
|
|
273
|
-
'fill-opacity': 0,
|
|
274
|
-
'fill': 'unset'
|
|
275
|
-
}).removeClass('nv-mark-point');
|
|
276
|
-
clearTimeout(this.timer);
|
|
277
|
-
this.timer = undefined;
|
|
278
|
-
this.timer = setTimeout(() => {
|
|
279
|
-
this.initPoint();
|
|
280
|
-
}, 100);
|
|
281
210
|
if (this.currentTimePeriod === 3 || this.currentTimePeriod === 4 || this.currentTimePeriod === 5) {
|
|
282
211
|
return this.timeFormat(d, '%y-%m-%d');
|
|
283
212
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
[{"__symbolic":"module","version":4,"metadata":{"HistoricalCurveElement":{"__symbolic":"class","extends":{"__symbolic":"reference","module":"../base/conditional-display-element","name":"ConditionalDisplayElement","line":21,"character":44},"members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"error","message":"Could not resolve type","line":
|
|
1
|
+
[{"__symbolic":"module","version":4,"metadata":{"HistoricalCurveElement":{"__symbolic":"class","extends":{"__symbolic":"reference","module":"../base/conditional-display-element","name":"ConditionalDisplayElement","line":21,"character":44},"members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"error","message":"Could not resolve type","line":63,"character":25,"context":{"typeName":"HTMLElement"}},{"__symbolic":"reference","module":"@angular/core","name":"Injector","line":64,"character":18},{"__symbolic":"reference","module":"../../service","name":"PermissionChecker","line":65,"character":27},{"__symbolic":"reference","module":"../../communication","name":"VariableCommunicator","line":66,"character":30},{"__symbolic":"reference","module":"../../config","name":"VariableStore","line":67,"character":23},{"__symbolic":"reference","module":"../../config","name":"HistoryDataStore","line":68,"character":43},{"__symbolic":"reference","name":"string"}]}],"dispose":[{"__symbolic":"method"}],"getValidTimePeriods":[{"__symbolic":"method"}],"updateTimeRange":[{"__symbolic":"method"}],"updateQueryTimeRange":[{"__symbolic":"method"}],"reRenderElement":[{"__symbolic":"method"}],"renderElement":[{"__symbolic":"method"}],"renderChart":[{"__symbolic":"method"}],"getLineChart":[{"__symbolic":"method"}],"getMultiBarWithFocusChart":[{"__symbolic":"method"}],"renderCommonProperty":[{"__symbolic":"method"}],"renderOperationArea":[{"__symbolic":"method"}],"timeFormat":[{"__symbolic":"method"}],"loadFirstPage":[{"__symbolic":"method"}],"loadNextPage":[{"__symbolic":"method"}],"loadPreviousPage":[{"__symbolic":"method"}],"loadLastPage":[{"__symbolic":"method"}],"initElementStatus":[{"__symbolic":"method"}],"updateElementStatus":[{"__symbolic":"method"}],"setStatusAsUnbound":[{"__symbolic":"method"}],"setStatusAsLoading":[{"__symbolic":"method"}],"setStatusAsLoadFailed":[{"__symbolic":"method"}],"renderStatus":[{"__symbolic":"method"}],"clearStatus":[{"__symbolic":"method"}]}}}}]
|
|
@@ -16,16 +16,15 @@ export declare class VideoElement extends ConditionalDisplayElement {
|
|
|
16
16
|
private videoId;
|
|
17
17
|
private isShow;
|
|
18
18
|
private videoPlayer;
|
|
19
|
+
private resetTimer;
|
|
19
20
|
private refreshTimer;
|
|
20
|
-
private
|
|
21
|
-
private videoUrl;
|
|
21
|
+
private isMobileType;
|
|
22
22
|
constructor(element: HTMLElement, injector: Injector, permissionChecker: PermissionChecker, variableCommunicator: VariableCommunicator, variableStore: VariableStore, videoService: VideoService, guiSize: Size, svgRootClass: string, signalRAppId: string);
|
|
23
23
|
dispose(): void;
|
|
24
24
|
hide(): void;
|
|
25
25
|
show(): void;
|
|
26
26
|
private init;
|
|
27
|
-
private initVideo;
|
|
28
27
|
private addVideoAddressToolTip;
|
|
29
28
|
private setAndroidVideo;
|
|
30
|
-
private
|
|
29
|
+
private bindFullscreenEvent;
|
|
31
30
|
}
|
|
@@ -11,7 +11,6 @@ export class VideoElement extends ConditionalDisplayElement {
|
|
|
11
11
|
this.guiSize = guiSize;
|
|
12
12
|
this.svgRootClass = svgRootClass;
|
|
13
13
|
this.videoId = '';
|
|
14
|
-
this.isFullscreen = false;
|
|
15
14
|
this.isMobileMode = DisplayMode.Mobile === injector.get(GlobalSettings).displayMode;
|
|
16
15
|
this.localization = injector.get(LOCALIZATION);
|
|
17
16
|
this.init();
|
|
@@ -47,84 +46,60 @@ export class VideoElement extends ConditionalDisplayElement {
|
|
|
47
46
|
return;
|
|
48
47
|
}
|
|
49
48
|
this.videoId = Guid.newGuid().toString('n');
|
|
50
|
-
this.rootElement.append('rect').attr('id', 'rect' + this.videoId).attr('fill', 'transparent')
|
|
51
|
-
.attr('width', this.model.size.width)
|
|
52
|
-
.attr('height', this.model.size.height);
|
|
53
49
|
this.videoService.getVideoUrl(this.model.videoTag).then(result => {
|
|
54
|
-
this.
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
initVideo(videoUrl, videoId) {
|
|
61
|
-
const patt = /https:.+.m3u8/;
|
|
62
|
-
if (videoUrl.indexOf('http:') !== -1) {
|
|
63
|
-
videoUrl = videoUrl.replace('http:', 'https:');
|
|
64
|
-
}
|
|
65
|
-
if (!patt.test(videoUrl)) {
|
|
66
|
-
let videoToolTip = this.localization.invalidVideoAddress;
|
|
67
|
-
if (isNil(videoUrl) || videoUrl === '') {
|
|
68
|
-
videoToolTip = this.localization.unconfiguredVideoAddress;
|
|
69
|
-
}
|
|
70
|
-
this.addVideoAddressToolTip(videoToolTip);
|
|
71
|
-
return;
|
|
72
|
-
}
|
|
73
|
-
const isAndroid = !!navigator.userAgent.match(/(Android)/i);
|
|
74
|
-
const isIos = !!navigator.userAgent.match(/(Mac)/i);
|
|
75
|
-
const currentRect = this.$element.find('rect#rect' + videoId).first();
|
|
76
|
-
if (!currentRect.length) {
|
|
77
|
-
return;
|
|
78
|
-
}
|
|
79
|
-
const clientRect = currentRect[0].getBoundingClientRect();
|
|
80
|
-
const chartWidth = clientRect.width;
|
|
81
|
-
const chartHeight = clientRect.height;
|
|
82
|
-
const left = this.model.location.x / this.guiSize.width * $('.' + this.svgRootClass).find('.svg-content').width();
|
|
83
|
-
const top = this.model.location.y / this.guiSize.height * $('.' + this.svgRootClass).find('.svg-content').height();
|
|
84
|
-
const scareX = this.model.location.x / this.guiSize.width;
|
|
85
|
-
const scareY = this.model.location.y / this.guiSize.height;
|
|
86
|
-
if (isIos) {
|
|
87
|
-
videoUrl = videoUrl + '#t=1';
|
|
88
|
-
}
|
|
89
|
-
const preload = isIos ? ' preload=\'metadata\'' : '';
|
|
90
|
-
let videoHtml = `<video scareX="${scareX}"
|
|
91
|
-
scareY="${scareY}" id="${videoId}" ${preload} src="${videoUrl}" width="${chartWidth}" height="${chartHeight}"
|
|
92
|
-
style="position: absolute;top:${top}px;left:${left}px;object-fit:fill;z-index:0;"
|
|
93
|
-
playsInline webkit-playsinline `;
|
|
94
|
-
if (this.isMobileMode) {
|
|
95
|
-
if (isAndroid) {
|
|
96
|
-
videoHtml += ' autoplay muted></video>';
|
|
50
|
+
this.isMobileType = result.isMobileType;
|
|
51
|
+
const isAndroid = !!navigator.userAgent.match(/(Android)/i);
|
|
52
|
+
let videoUrl = result.url;
|
|
53
|
+
const patt = /https:.+.m3u8/;
|
|
54
|
+
if (videoUrl.indexOf('http:') !== -1) {
|
|
55
|
+
videoUrl = videoUrl.replace('http:', 'https:');
|
|
97
56
|
}
|
|
98
|
-
|
|
99
|
-
|
|
57
|
+
if (!patt.test(videoUrl)) {
|
|
58
|
+
let videoToolTip = this.localization.invalidVideoAddress;
|
|
59
|
+
if (isNil(videoUrl) || videoUrl === '') {
|
|
60
|
+
videoToolTip = this.localization.unconfiguredVideoAddress;
|
|
61
|
+
}
|
|
62
|
+
this.addVideoAddressToolTip(videoToolTip);
|
|
63
|
+
return;
|
|
100
64
|
}
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
65
|
+
const video = this.rootElement.append('foreignObject')
|
|
66
|
+
.attr('x', 0)
|
|
67
|
+
.attr('y', 0)
|
|
68
|
+
.attr('width', this.model.size.width)
|
|
69
|
+
.attr('height', this.model.size.height)
|
|
70
|
+
.append('xhtml:video')
|
|
71
|
+
.attr('id', this.videoId)
|
|
72
|
+
.attr('class', 'element-video')
|
|
73
|
+
.attr('scareX', this.model.location.x / this.guiSize.width)
|
|
74
|
+
.attr('scareY', this.model.location.y / this.guiSize.height)
|
|
75
|
+
.attr('src', videoUrl)
|
|
76
|
+
.style('width', '100%')
|
|
77
|
+
.style('height', '100%')
|
|
78
|
+
.style('object-fit', 'fill')
|
|
79
|
+
.attr('playsInline', true)
|
|
80
|
+
.attr('webkit-playsinline', true)
|
|
81
|
+
.attr('controls', true)
|
|
82
|
+
.attr('muted', true);
|
|
83
|
+
if (this.isMobileMode) {
|
|
84
|
+
if (isAndroid) {
|
|
85
|
+
video.attr('autoplay', true);
|
|
86
|
+
}
|
|
112
87
|
}
|
|
113
|
-
else
|
|
114
|
-
|
|
88
|
+
else {
|
|
89
|
+
video.attr('autoplay', true);
|
|
115
90
|
}
|
|
116
|
-
|
|
117
|
-
this.
|
|
91
|
+
if (this.isShow === false) {
|
|
92
|
+
$('#' + this.videoId).hide();
|
|
118
93
|
}
|
|
119
|
-
|
|
120
|
-
|
|
94
|
+
this.videoPlayer = new EZUIPlayer(this.videoId);
|
|
95
|
+
if (isAndroid) {
|
|
96
|
+
setTimeout(() => {
|
|
97
|
+
this.setAndroidVideo();
|
|
98
|
+
}, 500);
|
|
121
99
|
}
|
|
122
|
-
}
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
display: none;
|
|
126
|
-
}`;
|
|
127
|
-
document.head.append();
|
|
100
|
+
}).catch(() => {
|
|
101
|
+
throw new Error('Failure of the videoService');
|
|
102
|
+
});
|
|
128
103
|
}
|
|
129
104
|
addVideoAddressToolTip(videoToolTip) {
|
|
130
105
|
const size = this.model.size;
|
|
@@ -146,69 +121,51 @@ export class VideoElement extends ConditionalDisplayElement {
|
|
|
146
121
|
const textElement = new TextElementModal(videoToolTip, font, size.width, size.height);
|
|
147
122
|
this.$element.append(textElement.Element);
|
|
148
123
|
}
|
|
149
|
-
setAndroidVideo(
|
|
150
|
-
const videoElement = $('#' + videoId);
|
|
151
|
-
let preHeight = videoElement.height();
|
|
152
|
-
let preWidth = videoElement.width();
|
|
153
|
-
let preTop = videoElement.css('top');
|
|
154
|
-
let preLeft = videoElement.css('left');
|
|
124
|
+
setAndroidVideo() {
|
|
155
125
|
const { StatusBar } = window;
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
}
|
|
179
|
-
catch (error) {
|
|
180
|
-
console.error(error);
|
|
181
|
-
}
|
|
126
|
+
this.bindFullscreenEvent();
|
|
127
|
+
window.addEventListener('orientationchange', () => {
|
|
128
|
+
StatusBar.show();
|
|
129
|
+
this.hide();
|
|
130
|
+
clearTimeout(this.refreshTimer);
|
|
131
|
+
this.refreshTimer = null;
|
|
132
|
+
this.refreshTimer = setTimeout(() => {
|
|
133
|
+
this.init();
|
|
134
|
+
this.show();
|
|
135
|
+
}, 1000);
|
|
136
|
+
});
|
|
137
|
+
}
|
|
138
|
+
bindFullscreenEvent() {
|
|
139
|
+
const that = this;
|
|
140
|
+
const { StatusBar } = window;
|
|
141
|
+
$('#' + this.videoId).bind('webkitfullscreenchange', () => {
|
|
142
|
+
if (document.webkitIsFullScreen) {
|
|
143
|
+
$('#' + that.videoId).css({
|
|
144
|
+
'object-fit': 'contain',
|
|
145
|
+
'z-index': 99
|
|
146
|
+
});
|
|
147
|
+
StatusBar.hide();
|
|
182
148
|
}
|
|
183
149
|
else {
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
videoElement.css('left', preLeft);
|
|
188
|
-
videoElement.css('top', preTop);
|
|
189
|
-
videoElement.css('z-index', '0');
|
|
190
|
-
videoElement.css('position', 'absolute');
|
|
191
|
-
this.isFullscreen = false;
|
|
192
|
-
try {
|
|
193
|
-
if (screen.orientation.type.includes('portrait')) {
|
|
194
|
-
StatusBar.show();
|
|
195
|
-
}
|
|
150
|
+
StatusBar.show();
|
|
151
|
+
if (that.isMobileType) {
|
|
152
|
+
$('#' + this.videoId).css('object-fit', document.webkitIsFullScreen ? 'contain' : 'fill');
|
|
196
153
|
}
|
|
197
|
-
|
|
198
|
-
|
|
154
|
+
else {
|
|
155
|
+
clearTimeout(this.resetTimer);
|
|
156
|
+
this.resetTimer = null;
|
|
157
|
+
$('#' + this.videoId).css('display', 'none');
|
|
158
|
+
this.resetTimer = setTimeout(() => {
|
|
159
|
+
$('#' + this.videoId).css({
|
|
160
|
+
'width': '100%',
|
|
161
|
+
'height': '100%',
|
|
162
|
+
'display': 'block',
|
|
163
|
+
'z-index': 0,
|
|
164
|
+
'object-fit': document.webkitIsFullScreen ? 'contain' : 'fill'
|
|
165
|
+
});
|
|
166
|
+
}, 1000);
|
|
199
167
|
}
|
|
200
168
|
}
|
|
201
169
|
});
|
|
202
170
|
}
|
|
203
|
-
setIosVideo(videoUrl, videoId) {
|
|
204
|
-
const video = $('#' + this.videoId);
|
|
205
|
-
video.on('webkitendfullscreen', () => {
|
|
206
|
-
video.remove();
|
|
207
|
-
clearTimeout(this.refreshTimer);
|
|
208
|
-
this.refreshTimer = null;
|
|
209
|
-
this.refreshTimer = setTimeout(() => {
|
|
210
|
-
this.initVideo(videoUrl, videoId);
|
|
211
|
-
}, 500);
|
|
212
|
-
});
|
|
213
|
-
}
|
|
214
171
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
[{"__symbolic":"module","version":4,"metadata":{"VideoElement":{"__symbolic":"class","extends":{"__symbolic":"reference","module":"../base/conditional-display-element","name":"ConditionalDisplayElement","line":15,"character":34},"members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"error","message":"Could not resolve type","line":27,"character":25,"context":{"typeName":"HTMLElement"}},{"__symbolic":"reference","module":"@angular/core","name":"Injector","line":28,"character":18},{"__symbolic":"reference","module":"../../service","name":"PermissionChecker","line":29,"character":27},{"__symbolic":"reference","module":"../../communication","name":"VariableCommunicator","line":30,"character":30},{"__symbolic":"reference","module":"../../config","name":"VariableStore","line":31,"character":23},{"__symbolic":"reference","module":"../../service","name":"VideoService","line":32,"character":39},{"__symbolic":"reference","module":"../../model","name":"Size","line":33,"character":34},{"__symbolic":"reference","name":"string"},{"__symbolic":"reference","name":"string"}]}],"dispose":[{"__symbolic":"method"}],"hide":[{"__symbolic":"method"}],"show":[{"__symbolic":"method"}],"init":[{"__symbolic":"method"}],"
|
|
1
|
+
[{"__symbolic":"module","version":4,"metadata":{"VideoElement":{"__symbolic":"class","extends":{"__symbolic":"reference","module":"../base/conditional-display-element","name":"ConditionalDisplayElement","line":15,"character":34},"members":{"__ctor__":[{"__symbolic":"constructor","parameters":[{"__symbolic":"error","message":"Could not resolve type","line":27,"character":25,"context":{"typeName":"HTMLElement"}},{"__symbolic":"reference","module":"@angular/core","name":"Injector","line":28,"character":18},{"__symbolic":"reference","module":"../../service","name":"PermissionChecker","line":29,"character":27},{"__symbolic":"reference","module":"../../communication","name":"VariableCommunicator","line":30,"character":30},{"__symbolic":"reference","module":"../../config","name":"VariableStore","line":31,"character":23},{"__symbolic":"reference","module":"../../service","name":"VideoService","line":32,"character":39},{"__symbolic":"reference","module":"../../model","name":"Size","line":33,"character":34},{"__symbolic":"reference","name":"string"},{"__symbolic":"reference","name":"string"}]}],"dispose":[{"__symbolic":"method"}],"hide":[{"__symbolic":"method"}],"show":[{"__symbolic":"method"}],"init":[{"__symbolic":"method"}],"addVideoAddressToolTip":[{"__symbolic":"method"}],"setAndroidVideo":[{"__symbolic":"method"}],"bindFullscreenEvent":[{"__symbolic":"method"}]}}}}]
|
|
@@ -170,9 +170,6 @@ export class ViewOperationElement extends ConditionalEnableElement {
|
|
|
170
170
|
const viewIndex = this.model.viewIndex;
|
|
171
171
|
if (null != viewIndex) {
|
|
172
172
|
this.popupViewService.popView(viewIndex, this.hostContainerId, this.el).subscribe(() => this.recordViewOperation(), error => this.logger.error(`ToggleView(${viewIndex}) failed. ${error}`));
|
|
173
|
-
$(`#${this.hostContainerId} video`)
|
|
174
|
-
.addClass('video-hidden')
|
|
175
|
-
.css('visibility', 'hidden');
|
|
176
173
|
}
|
|
177
174
|
else {
|
|
178
175
|
this.logger.error('[GUI]Toggle View:invalid view index');
|
|
@@ -180,11 +177,6 @@ export class ViewOperationElement extends ConditionalEnableElement {
|
|
|
180
177
|
}
|
|
181
178
|
closeView() {
|
|
182
179
|
this.popupViewService.closeView();
|
|
183
|
-
if ($(`#${this.hostContainerId} > svg > svg`).length === 0) {
|
|
184
|
-
$(`#${this.hostContainerId} .video-hidden`)
|
|
185
|
-
.removeClass('video-hidden')
|
|
186
|
-
.css('visibility', 'visible');
|
|
187
|
-
}
|
|
188
180
|
this.recordViewOperation();
|
|
189
181
|
}
|
|
190
182
|
moveView(movementX, movementY) {
|
|
@@ -110,24 +110,13 @@ let WriteValueModalComponent = class WriteValueModalComponent {
|
|
|
110
110
|
value = this.formatWriteValue();
|
|
111
111
|
}
|
|
112
112
|
}
|
|
113
|
-
if (!this.args.releasedVariableService) {
|
|
114
|
-
this.onClosed({
|
|
115
|
-
value: value,
|
|
116
|
-
showValue: showValue,
|
|
117
|
-
enableNumericalOperation: false,
|
|
118
|
-
isNumericalOperation: this.isNumericalOperation,
|
|
119
|
-
variableRwType: 6
|
|
120
|
-
});
|
|
121
|
-
return;
|
|
122
|
-
}
|
|
123
113
|
this.args.releasedVariableService.getVariableWithValueTransform(this.variableName).subscribe(result => {
|
|
124
114
|
const valueTransform = JSON.parse(result.valueTransform);
|
|
125
|
-
if (valueTransform.Type !== 0) {
|
|
115
|
+
if ((valueTransform === null || valueTransform === void 0 ? void 0 : valueTransform.Type) !== 0) {
|
|
126
116
|
this.isNumericalOperation = true;
|
|
127
117
|
}
|
|
128
118
|
this.onClosed({
|
|
129
|
-
value
|
|
130
|
-
showValue: showValue,
|
|
119
|
+
value, showValue,
|
|
131
120
|
enableNumericalOperation: this.enableNumericalOperation,
|
|
132
121
|
isNumericalOperation: this.isNumericalOperation,
|
|
133
122
|
variableRwType: result.variableRwType
|