@c8y/ngx-components 1021.66.0 → 1021.70.1
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/core/common/bytes.pipe.d.ts +26 -10
- package/core/common/bytes.pipe.d.ts.map +1 -1
- package/echart/charts.component.d.ts +14 -3
- package/echart/charts.component.d.ts.map +1 -1
- package/esm2022/core/common/bytes.pipe.mjs +47 -18
- package/esm2022/core/data-grid/data-grid.component.mjs +3 -3
- package/esm2022/echart/charts.component.mjs +50 -3
- package/esm2022/messaging-management/api/model/backlogQuota.mjs +2 -0
- package/esm2022/messaging-management/api/model/namespace.mjs +2 -0
- package/esm2022/messaging-management/api/model/namespaceDetails.mjs +2 -0
- package/esm2022/messaging-management/api/model/namespaceList.mjs +2 -0
- package/esm2022/messaging-management/api/model/namespacePolicies.mjs +2 -0
- package/esm2022/messaging-management/api/model/namespacePublishers.mjs +2 -0
- package/esm2022/messaging-management/api/model/namespaceSubscribers.mjs +2 -0
- package/esm2022/messaging-management/api/model/namespaceTopics.mjs +2 -0
- package/esm2022/messaging-management/api/model/pageStatistics.mjs +2 -0
- package/esm2022/messaging-management/api/model/pageable.mjs +2 -0
- package/esm2022/messaging-management/api/model/sortable.mjs +2 -0
- package/esm2022/messaging-management/api/model/subscriber.mjs +2 -0
- package/esm2022/messaging-management/api/model/subscriberFilters.mjs +2 -0
- package/esm2022/messaging-management/api/model/subscriberList.mjs +2 -0
- package/esm2022/messaging-management/api/model/subscriberToDelete.mjs +2 -0
- package/esm2022/messaging-management/api/model/topic.mjs +2 -0
- package/esm2022/messaging-management/api/model/topicDetailFilters.mjs +2 -0
- package/esm2022/messaging-management/api/model/topicList.mjs +2 -0
- package/esm2022/messaging-management/api/model/topicListFilters.mjs +2 -0
- package/esm2022/messaging-management/api/model/topicType.mjs +9 -0
- package/esm2022/messaging-management/api/services/messaging-namespaces.service.mjs +83 -0
- package/esm2022/messaging-management/api/services/messaging-subscribers.service.mjs +55 -0
- package/esm2022/messaging-management/api/services/messaging-topics.service.mjs +48 -0
- package/esm2022/messaging-management/c8y-ngx-components-messaging-management.mjs +5 -0
- package/esm2022/messaging-management/constants.mjs +4 -0
- package/esm2022/messaging-management/index.mjs +2 -0
- package/esm2022/messaging-management/messaging/namespace-list/namespace-item/namespace-item-card/namespace-item-card.component.mjs +43 -0
- package/esm2022/messaging-management/messaging/namespace-list/namespace-item/namespace-item.component.mjs +36 -0
- package/esm2022/messaging-management/messaging/namespace-list/namespace-list.component.mjs +51 -0
- package/esm2022/messaging-management/messaging/shared/usage/usage.component.mjs +68 -0
- package/esm2022/messaging-management/messaging/topic/topic-list-view.component.mjs +81 -0
- package/esm2022/messaging-management/messaging/topic/topic-subscribers-view/topic-subscribers-data-grid.service.mjs +220 -0
- package/esm2022/messaging-management/messaging/topic/topic-subscribers-view/topic-subscribers-view.component.mjs +137 -0
- package/esm2022/messaging-management/messaging/topic/topics-data-grid.service.mjs +113 -0
- package/esm2022/messaging-management/messaging-management.guard.mjs +40 -0
- package/esm2022/messaging-management/messaging-management.module.mjs +72 -0
- package/esm2022/messaging-management/navigator/messaging-navigator-factory.mjs +55 -0
- package/esm2022/messaging-management/navigator/topic-details-tab.factory.mjs +33 -0
- package/esm2022/messaging-management/utils/backlog-quota-limit.pipe.mjs +32 -0
- package/esm2022/messaging-management/utils/namespace-props.mjs +23 -0
- package/esm2022/messaging-management/utils/time-to-live.pipe.mjs +122 -0
- package/esm2022/operations/device-selector/device-selector.component.mjs +5 -1
- package/esm2022/widgets/cockpit/index.mjs +3 -1
- package/esm2022/widgets/cockpit-exports/index.mjs +8 -1
- package/esm2022/widgets/definitions/index.mjs +2 -1
- package/esm2022/widgets/definitions/radial-gauge/c8y-ngx-components-widgets-definitions-radial-gauge.mjs +5 -0
- package/esm2022/widgets/definitions/radial-gauge/index.mjs +33 -0
- package/esm2022/widgets/implementations/datapoints-graph/datapoints-graph-view/datapoints-graph-widget-view.component.mjs +18 -3
- package/esm2022/widgets/implementations/info-gauge/index.mjs +2 -2
- package/esm2022/widgets/implementations/info-gauge/info-gauge-widget-config/gauge.model.mjs +295 -0
- package/esm2022/widgets/implementations/info-gauge/info-gauge-widget-config/info-gauge-widget-config.component.mjs +141 -11
- package/esm2022/widgets/implementations/info-gauge/info-gauge-widget-config/preset-preview/preset-preview.component.mjs +67 -0
- package/esm2022/widgets/implementations/info-gauge/info-gauge-widget-view/info-gauge-widget-view.component.mjs +34 -6
- package/esm2022/widgets/implementations/info-gauge/info-gauge-widget.module.mjs +9 -4
- package/esm2022/widgets/implementations/info-gauge/radial-gauge/radial-gauge.component.mjs +97 -0
- package/esm2022/widgets/implementations/info-gauge/radial-gauge/radial-gauge.service.mjs +369 -0
- package/fesm2022/c8y-ngx-components-echart.mjs +49 -2
- package/fesm2022/c8y-ngx-components-echart.mjs.map +1 -1
- package/fesm2022/c8y-ngx-components-messaging-management.mjs +1225 -0
- package/fesm2022/c8y-ngx-components-messaging-management.mjs.map +1 -0
- package/fesm2022/c8y-ngx-components-operations-device-selector.mjs +4 -0
- package/fesm2022/c8y-ngx-components-operations-device-selector.mjs.map +1 -1
- package/fesm2022/c8y-ngx-components-widgets-cockpit-exports.mjs +7 -0
- package/fesm2022/c8y-ngx-components-widgets-cockpit-exports.mjs.map +1 -1
- package/fesm2022/c8y-ngx-components-widgets-cockpit.mjs +2 -0
- package/fesm2022/c8y-ngx-components-widgets-cockpit.mjs.map +1 -1
- package/fesm2022/c8y-ngx-components-widgets-definitions-radial-gauge.mjs +40 -0
- package/fesm2022/c8y-ngx-components-widgets-definitions-radial-gauge.mjs.map +1 -0
- package/fesm2022/c8y-ngx-components-widgets-definitions.mjs +1 -0
- package/fesm2022/c8y-ngx-components-widgets-definitions.mjs.map +1 -1
- package/fesm2022/c8y-ngx-components-widgets-implementations-datapoints-graph.mjs +17 -2
- package/fesm2022/c8y-ngx-components-widgets-implementations-datapoints-graph.mjs.map +1 -1
- package/fesm2022/c8y-ngx-components-widgets-implementations-info-gauge.mjs +991 -28
- package/fesm2022/c8y-ngx-components-widgets-implementations-info-gauge.mjs.map +1 -1
- package/fesm2022/c8y-ngx-components.mjs +49 -22
- package/fesm2022/c8y-ngx-components.mjs.map +1 -1
- package/locales/de.po +272 -5
- package/locales/es.po +271 -4
- package/locales/fr.po +272 -5
- package/locales/ja_JP.po +272 -5
- package/locales/ko.po +271 -4
- package/locales/locales.pot +271 -4
- package/locales/nl.po +271 -4
- package/locales/pl.po +271 -4
- package/locales/pt_BR.po +272 -5
- package/locales/zh_CN.po +271 -4
- package/locales/zh_TW.po +272 -5
- package/messaging-management/api/model/backlogQuota.d.ts +14 -0
- package/messaging-management/api/model/backlogQuota.d.ts.map +1 -0
- package/messaging-management/api/model/namespace.d.ts +13 -0
- package/messaging-management/api/model/namespace.d.ts.map +1 -0
- package/messaging-management/api/model/namespaceDetails.d.ts +8 -0
- package/messaging-management/api/model/namespaceDetails.d.ts.map +1 -0
- package/messaging-management/api/model/namespaceList.d.ts +5 -0
- package/messaging-management/api/model/namespaceList.d.ts.map +1 -0
- package/messaging-management/api/model/namespacePolicies.d.ts +10 -0
- package/messaging-management/api/model/namespacePolicies.d.ts.map +1 -0
- package/messaging-management/api/model/namespacePublishers.d.ts +4 -0
- package/messaging-management/api/model/namespacePublishers.d.ts.map +1 -0
- package/messaging-management/api/model/namespaceSubscribers.d.ts +4 -0
- package/messaging-management/api/model/namespaceSubscribers.d.ts.map +1 -0
- package/messaging-management/api/model/namespaceTopics.d.ts +5 -0
- package/messaging-management/api/model/namespaceTopics.d.ts.map +1 -0
- package/messaging-management/api/model/pageStatistics.d.ts +12 -0
- package/messaging-management/api/model/pageStatistics.d.ts.map +1 -0
- package/messaging-management/api/model/pageable.d.ts +8 -0
- package/messaging-management/api/model/pageable.d.ts.map +1 -0
- package/messaging-management/api/model/sortable.d.ts +6 -0
- package/messaging-management/api/model/sortable.d.ts.map +1 -0
- package/messaging-management/api/model/subscriber.d.ts +28 -0
- package/messaging-management/api/model/subscriber.d.ts.map +1 -0
- package/messaging-management/api/model/subscriberFilters.d.ts +13 -0
- package/messaging-management/api/model/subscriberFilters.d.ts.map +1 -0
- package/messaging-management/api/model/subscriberList.d.ts +7 -0
- package/messaging-management/api/model/subscriberList.d.ts.map +1 -0
- package/messaging-management/api/model/subscriberToDelete.d.ts +12 -0
- package/messaging-management/api/model/subscriberToDelete.d.ts.map +1 -0
- package/messaging-management/api/model/topic.d.ts +52 -0
- package/messaging-management/api/model/topic.d.ts.map +1 -0
- package/messaging-management/api/model/topicDetailFilters.d.ts +9 -0
- package/messaging-management/api/model/topicDetailFilters.d.ts.map +1 -0
- package/messaging-management/api/model/topicList.d.ts +7 -0
- package/messaging-management/api/model/topicList.d.ts.map +1 -0
- package/messaging-management/api/model/topicListFilters.d.ts +12 -0
- package/messaging-management/api/model/topicListFilters.d.ts.map +1 -0
- package/messaging-management/api/model/topicType.d.ts +8 -0
- package/messaging-management/api/model/topicType.d.ts.map +1 -0
- package/messaging-management/api/services/messaging-namespaces.service.d.ts +52 -0
- package/messaging-management/api/services/messaging-namespaces.service.d.ts.map +1 -0
- package/messaging-management/api/services/messaging-subscribers.service.d.ts +30 -0
- package/messaging-management/api/services/messaging-subscribers.service.d.ts.map +1 -0
- package/messaging-management/api/services/messaging-topics.service.d.ts +21 -0
- package/messaging-management/api/services/messaging-topics.service.d.ts.map +1 -0
- package/messaging-management/c8y-ngx-components-messaging-management.d.ts.map +1 -0
- package/messaging-management/constants.d.ts +4 -0
- package/messaging-management/constants.d.ts.map +1 -0
- package/messaging-management/index.d.ts +2 -0
- package/messaging-management/index.d.ts.map +1 -0
- package/messaging-management/messaging/namespace-list/namespace-item/namespace-item-card/namespace-item-card.component.d.ts +29 -0
- package/messaging-management/messaging/namespace-list/namespace-item/namespace-item-card/namespace-item-card.component.d.ts.map +1 -0
- package/messaging-management/messaging/namespace-list/namespace-item/namespace-item.component.d.ts +15 -0
- package/messaging-management/messaging/namespace-list/namespace-item/namespace-item.component.d.ts.map +1 -0
- package/messaging-management/messaging/namespace-list/namespace-list.component.d.ts +17 -0
- package/messaging-management/messaging/namespace-list/namespace-list.component.d.ts.map +1 -0
- package/messaging-management/messaging/shared/usage/usage.component.d.ts +40 -0
- package/messaging-management/messaging/shared/usage/usage.component.d.ts.map +1 -0
- package/messaging-management/messaging/topic/topic-list-view.component.d.ts +38 -0
- package/messaging-management/messaging/topic/topic-list-view.component.d.ts.map +1 -0
- package/messaging-management/messaging/topic/topic-subscribers-view/topic-subscribers-data-grid.service.d.ts +21 -0
- package/messaging-management/messaging/topic/topic-subscribers-view/topic-subscribers-data-grid.service.d.ts.map +1 -0
- package/messaging-management/messaging/topic/topic-subscribers-view/topic-subscribers-view.component.d.ts +52 -0
- package/messaging-management/messaging/topic/topic-subscribers-view/topic-subscribers-view.component.d.ts.map +1 -0
- package/messaging-management/messaging/topic/topics-data-grid.service.d.ts +13 -0
- package/messaging-management/messaging/topic/topics-data-grid.service.d.ts.map +1 -0
- package/messaging-management/messaging-management.guard.d.ts +12 -0
- package/messaging-management/messaging-management.guard.d.ts.map +1 -0
- package/messaging-management/messaging-management.module.d.ts +7 -0
- package/messaging-management/messaging-management.module.d.ts.map +1 -0
- package/messaging-management/navigator/messaging-navigator-factory.d.ts +18 -0
- package/messaging-management/navigator/messaging-navigator-factory.d.ts.map +1 -0
- package/messaging-management/navigator/topic-details-tab.factory.d.ts +15 -0
- package/messaging-management/navigator/topic-details-tab.factory.d.ts.map +1 -0
- package/messaging-management/utils/backlog-quota-limit.pipe.d.ts +13 -0
- package/messaging-management/utils/backlog-quota-limit.pipe.d.ts.map +1 -0
- package/messaging-management/utils/namespace-props.d.ts +10 -0
- package/messaging-management/utils/namespace-props.d.ts.map +1 -0
- package/messaging-management/utils/time-to-live.pipe.d.ts +16 -0
- package/messaging-management/utils/time-to-live.pipe.d.ts.map +1 -0
- package/operations/device-selector/device-selector.component.d.ts.map +1 -1
- package/package.json +1 -1
- package/widgets/cockpit/index.d.ts +29 -0
- package/widgets/cockpit/index.d.ts.map +1 -1
- package/widgets/cockpit-exports/index.d.ts +6 -0
- package/widgets/cockpit-exports/index.d.ts.map +1 -1
- package/widgets/definitions/index.d.ts +1 -0
- package/widgets/definitions/index.d.ts.map +1 -1
- package/widgets/definitions/radial-gauge/c8y-ngx-components-widgets-definitions-radial-gauge.d.ts.map +1 -0
- package/widgets/definitions/radial-gauge/index.d.ts +33 -0
- package/widgets/definitions/radial-gauge/index.d.ts.map +1 -0
- package/widgets/implementations/datapoints-graph/datapoints-graph-view/datapoints-graph-widget-view.component.d.ts +2 -0
- package/widgets/implementations/datapoints-graph/datapoints-graph-view/datapoints-graph-widget-view.component.d.ts.map +1 -1
- package/widgets/implementations/info-gauge/index.d.ts +1 -1
- package/widgets/implementations/info-gauge/index.d.ts.map +1 -1
- package/widgets/implementations/info-gauge/info-gauge-widget-config/gauge.model.d.ts +339 -0
- package/widgets/implementations/info-gauge/info-gauge-widget-config/gauge.model.d.ts.map +1 -0
- package/widgets/implementations/info-gauge/info-gauge-widget-config/info-gauge-widget-config.component.d.ts +27 -7
- package/widgets/implementations/info-gauge/info-gauge-widget-config/info-gauge-widget-config.component.d.ts.map +1 -1
- package/widgets/implementations/info-gauge/info-gauge-widget-config/preset-preview/preset-preview.component.d.ts +33 -0
- package/widgets/implementations/info-gauge/info-gauge-widget-config/preset-preview/preset-preview.component.d.ts.map +1 -0
- package/widgets/implementations/info-gauge/info-gauge-widget-view/info-gauge-widget-view.component.d.ts +7 -3
- package/widgets/implementations/info-gauge/info-gauge-widget-view/info-gauge-widget-view.component.d.ts.map +1 -1
- package/widgets/implementations/info-gauge/info-gauge-widget.module.d.ts +2 -1
- package/widgets/implementations/info-gauge/info-gauge-widget.module.d.ts.map +1 -1
- package/widgets/implementations/info-gauge/radial-gauge/radial-gauge.component.d.ts +37 -0
- package/widgets/implementations/info-gauge/radial-gauge/radial-gauge.component.d.ts.map +1 -0
- package/widgets/implementations/info-gauge/radial-gauge/radial-gauge.service.d.ts +146 -0
- package/widgets/implementations/info-gauge/radial-gauge/radial-gauge.service.d.ts.map +1 -0
- package/esm2022/widgets/implementations/info-gauge/info-gauge.model.mjs +0 -2
- package/widgets/implementations/info-gauge/info-gauge.model.d.ts +0 -7
- package/widgets/implementations/info-gauge/info-gauge.model.d.ts.map +0 -1
|
@@ -0,0 +1,369 @@
|
|
|
1
|
+
import { Injectable } from '@angular/core';
|
|
2
|
+
import { DatePipe } from '@c8y/ngx-components';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@c8y/ngx-components";
|
|
5
|
+
export class RadialGaugeService {
|
|
6
|
+
constructor(c8yDatePipe) {
|
|
7
|
+
this.c8yDatePipe = c8yDatePipe;
|
|
8
|
+
this.containerSize = 400;
|
|
9
|
+
}
|
|
10
|
+
setChart(chart) {
|
|
11
|
+
this.chart = chart;
|
|
12
|
+
}
|
|
13
|
+
getChartOptions(gaugeOptions, activeDatapointGauge, selectedPresetId, gaugeOptionsColors, rangeColors, measurement, fractionSize) {
|
|
14
|
+
const colorArray = this.getColorArray(activeDatapointGauge, rangeColors);
|
|
15
|
+
return {
|
|
16
|
+
series: [
|
|
17
|
+
{
|
|
18
|
+
type: 'gauge',
|
|
19
|
+
radius: gaugeOptions?.radius || '90%',
|
|
20
|
+
center: gaugeOptions?.center || ['50%', '50%'],
|
|
21
|
+
startAngle: gaugeOptions?.startAngle || 240,
|
|
22
|
+
endAngle: gaugeOptions?.endAngle || 300,
|
|
23
|
+
min: activeDatapointGauge?.min || 0,
|
|
24
|
+
max: activeDatapointGauge?.max !== undefined && activeDatapointGauge?.max !== null
|
|
25
|
+
? activeDatapointGauge.max
|
|
26
|
+
: 100,
|
|
27
|
+
// Split properties
|
|
28
|
+
splitNumber: gaugeOptions?.splitNumber || 10,
|
|
29
|
+
splitLine: {
|
|
30
|
+
distance: gaugeOptions?.splitLineDistanceRatio
|
|
31
|
+
? this.containerSize *
|
|
32
|
+
gaugeOptions?.axisLineWidthRatio *
|
|
33
|
+
gaugeOptions?.splitLineDistanceRatio
|
|
34
|
+
: gaugeOptions?.splitLineDistance || -30,
|
|
35
|
+
length: gaugeOptions?.splitLineLengthRatio
|
|
36
|
+
? this.containerSize *
|
|
37
|
+
gaugeOptions?.axisLineWidthRatio *
|
|
38
|
+
gaugeOptions?.splitLineLengthRatio
|
|
39
|
+
: gaugeOptions?.splitLineLength || 30,
|
|
40
|
+
lineStyle: {
|
|
41
|
+
color: selectedPresetId === 'custom' || selectedPresetId === 'grade-rating'
|
|
42
|
+
? gaugeOptions?.splitLineColor
|
|
43
|
+
: gaugeOptionsColors?.splitLineColor || '#fff',
|
|
44
|
+
width: gaugeOptions?.splitLineWidth || 4
|
|
45
|
+
}
|
|
46
|
+
},
|
|
47
|
+
// Tick properties
|
|
48
|
+
axisTick: {
|
|
49
|
+
show: gaugeOptions?.tickShow || false,
|
|
50
|
+
distance: gaugeOptions?.tickDistanceRatio
|
|
51
|
+
? this.containerSize *
|
|
52
|
+
gaugeOptions?.axisLineWidthRatio *
|
|
53
|
+
gaugeOptions?.tickDistanceRatio
|
|
54
|
+
: gaugeOptions?.tickDistance || -30,
|
|
55
|
+
length: gaugeOptions?.tickLengthRatio
|
|
56
|
+
? this.containerSize *
|
|
57
|
+
gaugeOptions?.axisLineWidthRatio *
|
|
58
|
+
gaugeOptions?.tickLengthRatio
|
|
59
|
+
: gaugeOptions?.tickLength || 8,
|
|
60
|
+
lineStyle: {
|
|
61
|
+
color: selectedPresetId === 'custom' || selectedPresetId === 'grade-rating'
|
|
62
|
+
? gaugeOptions.tickColor
|
|
63
|
+
: gaugeOptionsColors?.tickColor || '#fff',
|
|
64
|
+
width: gaugeOptions?.tickWidth || 2
|
|
65
|
+
}
|
|
66
|
+
},
|
|
67
|
+
// Axis properties
|
|
68
|
+
axisLine: {
|
|
69
|
+
lineStyle: {
|
|
70
|
+
width: gaugeOptions?.axisLineWidthRatio
|
|
71
|
+
? this.containerSize * gaugeOptions?.axisLineWidthRatio
|
|
72
|
+
: gaugeOptions?.axisLineWidth || 30,
|
|
73
|
+
color: colorArray
|
|
74
|
+
}
|
|
75
|
+
},
|
|
76
|
+
axisLabel: {
|
|
77
|
+
color: selectedPresetId === 'custom' || selectedPresetId === 'grade-rating'
|
|
78
|
+
? gaugeOptions.axisLabelColor
|
|
79
|
+
: gaugeOptionsColors?.axisLabelColor || 'inherit',
|
|
80
|
+
distance: gaugeOptions?.axisLabelDistanceRatio
|
|
81
|
+
? this.containerSize *
|
|
82
|
+
gaugeOptions?.axisLineWidthRatio *
|
|
83
|
+
gaugeOptions?.axisLabelDistanceRatio
|
|
84
|
+
: gaugeOptions?.axisLabelDistance || 40,
|
|
85
|
+
fontSize: gaugeOptions?.axisLabelFontSizeRatio
|
|
86
|
+
? this.clampRelative(gaugeOptions?.axisLabelFontSizeRatio, gaugeOptions?.axisLabelFontSizeMin, gaugeOptions?.axisLabelFontSizeMax)
|
|
87
|
+
: gaugeOptions?.axisLabelFontSize || 16,
|
|
88
|
+
fontWeight: 'bold',
|
|
89
|
+
fontFamily: gaugeOptionsColors?.fontFamily
|
|
90
|
+
},
|
|
91
|
+
// pointer properties
|
|
92
|
+
pointer: {
|
|
93
|
+
...(gaugeOptions?.pointerStyle !== 'default' && {
|
|
94
|
+
icon: gaugeOptions?.pointerStyle
|
|
95
|
+
}),
|
|
96
|
+
show: gaugeOptions?.showPointer || false,
|
|
97
|
+
length: gaugeOptions?.pointerLengthRatio
|
|
98
|
+
? gaugeOptions?.pointerLengthRatio *
|
|
99
|
+
(this.containerSize * gaugeOptions?.axisLineWidthRatio)
|
|
100
|
+
: gaugeOptions?.pointerLength || '65%',
|
|
101
|
+
width: gaugeOptions?.pointerWidthRatio
|
|
102
|
+
? this.containerSize *
|
|
103
|
+
gaugeOptions?.axisLineWidthRatio *
|
|
104
|
+
gaugeOptions?.pointerWidthRatio
|
|
105
|
+
: gaugeOptions?.pointerWidth || 40,
|
|
106
|
+
offsetCenter: selectedPresetId === 'default'
|
|
107
|
+
? [0, this.containerSize * gaugeOptions?.axisLineWidthRatio * -1]
|
|
108
|
+
: [0, gaugeOptions?.pointerOffset || -30],
|
|
109
|
+
itemStyle: {
|
|
110
|
+
color: selectedPresetId === 'custom'
|
|
111
|
+
? gaugeOptions.pointerColor
|
|
112
|
+
: gaugeOptionsColors?.pointerColor || 'inherit'
|
|
113
|
+
}
|
|
114
|
+
},
|
|
115
|
+
// Progress bar properties
|
|
116
|
+
progress: {
|
|
117
|
+
show: gaugeOptions?.progressBar || false,
|
|
118
|
+
roundCap: gaugeOptions?.progressBarRoundCap || false,
|
|
119
|
+
width: gaugeOptions?.progressBarWidthRatio
|
|
120
|
+
? this.containerSize *
|
|
121
|
+
gaugeOptions?.axisLineWidthRatio *
|
|
122
|
+
gaugeOptions?.progressBarWidthRatio
|
|
123
|
+
: gaugeOptions?.progressBarWidth || 18,
|
|
124
|
+
itemStyle: {
|
|
125
|
+
color: selectedPresetId === 'custom'
|
|
126
|
+
? gaugeOptions.progressBarColor
|
|
127
|
+
: gaugeOptionsColors?.progressBarColor || 'inherit'
|
|
128
|
+
}
|
|
129
|
+
},
|
|
130
|
+
// Anchor properties
|
|
131
|
+
anchor: gaugeOptions?.anchor
|
|
132
|
+
? {
|
|
133
|
+
...gaugeOptions.anchor,
|
|
134
|
+
size: gaugeOptions?.anchor?.sizeRatio
|
|
135
|
+
? this.containerSize * gaugeOptions?.anchor?.sizeRatio
|
|
136
|
+
: gaugeOptions?.anchor?.size || 45,
|
|
137
|
+
itemStyle: {
|
|
138
|
+
color: selectedPresetId === 'custom'
|
|
139
|
+
? gaugeOptions.pointerColor
|
|
140
|
+
: gaugeOptionsColors?.pointerColor
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
: undefined,
|
|
144
|
+
// Detail properties
|
|
145
|
+
detail: {
|
|
146
|
+
show: gaugeOptions?.showDetail || false,
|
|
147
|
+
valueAnimation: true,
|
|
148
|
+
offsetCenter: gaugeOptions?.detailOffsetCenterYRatio
|
|
149
|
+
? [0, gaugeOptions?.detailOffsetCenterYRatio * this.containerSize]
|
|
150
|
+
: gaugeOptions?.detailOffsetCenter || [0, 0],
|
|
151
|
+
formatter: () => {
|
|
152
|
+
const value = measurement?.value.toFixed(fractionSize) || 0;
|
|
153
|
+
const unit = activeDatapointGauge?.unit || measurement?.unit || '';
|
|
154
|
+
const date = new Date(measurement?.date);
|
|
155
|
+
const formattedDate = this.c8yDatePipe.transform(date);
|
|
156
|
+
return `{value|${value}}{unit|${unit}} \n {date|${formattedDate}} `;
|
|
157
|
+
},
|
|
158
|
+
color: 'inherit',
|
|
159
|
+
lineHeight: gaugeOptions?.measurementValueFontRatio
|
|
160
|
+
? this.clampRelative(gaugeOptions?.measurementValueFontRatio * 0.9, gaugeOptions?.measurementValueFontSizeMin, gaugeOptions?.measurementValueFontSizeMax)
|
|
161
|
+
: gaugeOptions?.measurementValueFontSize || 32,
|
|
162
|
+
rich: {
|
|
163
|
+
value: {
|
|
164
|
+
fontSize: gaugeOptions?.measurementValueFontRatio
|
|
165
|
+
? this.clampRelative(fractionSize > 5 || measurement?.value > 9999
|
|
166
|
+
? gaugeOptions?.measurementValueFontRatio * 0.5
|
|
167
|
+
: gaugeOptions?.measurementValueFontRatio, gaugeOptions?.measurementValueFontSizeMin, gaugeOptions?.measurementValueFontSizeMax)
|
|
168
|
+
: gaugeOptions?.measurementValueFontSize || 32,
|
|
169
|
+
fontWeight: 'bolder',
|
|
170
|
+
fontFamily: gaugeOptionsColors?.fontFamily,
|
|
171
|
+
color: selectedPresetId === 'custom'
|
|
172
|
+
? gaugeOptions.measurementValueColor
|
|
173
|
+
: gaugeOptionsColors?.measurementValueColor || '#777'
|
|
174
|
+
},
|
|
175
|
+
unit: {
|
|
176
|
+
fontSize: gaugeOptions?.unitFontRatio
|
|
177
|
+
? this.clampRelative(gaugeOptions?.unitFontRatio, gaugeOptions?.unitFontMin, gaugeOptions?.unitFontMax)
|
|
178
|
+
: gaugeOptions?.unitFontSize || 20,
|
|
179
|
+
fontFamily: gaugeOptionsColors?.fontFamily,
|
|
180
|
+
color: selectedPresetId === 'custom'
|
|
181
|
+
? gaugeOptions?.unitColor
|
|
182
|
+
: gaugeOptionsColors?.unitColor || '#999'
|
|
183
|
+
},
|
|
184
|
+
date: {
|
|
185
|
+
fontSize: gaugeOptions?.dateFontRatio
|
|
186
|
+
? this.clampRelative(gaugeOptions?.dateFontRatio, gaugeOptions?.dateFontSizeMin, gaugeOptions?.dateFontSizeMax)
|
|
187
|
+
: gaugeOptions?.dateFontSize || 12,
|
|
188
|
+
fontFamily: gaugeOptionsColors?.fontFamily,
|
|
189
|
+
color: selectedPresetId === 'custom'
|
|
190
|
+
? gaugeOptions?.dateColor
|
|
191
|
+
: gaugeOptionsColors?.dateColor || '#555'
|
|
192
|
+
}
|
|
193
|
+
}
|
|
194
|
+
},
|
|
195
|
+
markPoint: {
|
|
196
|
+
symbolSize: 0,
|
|
197
|
+
offsetCenter: gaugeOptions?.detailOffsetCenter || [0, 0],
|
|
198
|
+
data: [
|
|
199
|
+
{
|
|
200
|
+
x: '50%',
|
|
201
|
+
y: '50%',
|
|
202
|
+
label: {
|
|
203
|
+
show: gaugeOptions?.showMarkPoint,
|
|
204
|
+
formatter: () => {
|
|
205
|
+
const value = measurement?.value.toFixed(fractionSize) || 0;
|
|
206
|
+
const unit = activeDatapointGauge?.unit || measurement?.unit || '';
|
|
207
|
+
const date = new Date(measurement?.date);
|
|
208
|
+
const formattedDate = this.c8yDatePipe.transform(date);
|
|
209
|
+
return `{value|${value}}{unit|${unit}} \n {date|${formattedDate}} `;
|
|
210
|
+
},
|
|
211
|
+
color: '#fff',
|
|
212
|
+
align: 'center',
|
|
213
|
+
rich: {
|
|
214
|
+
value: {
|
|
215
|
+
fontSize: gaugeOptions?.measurementValueFontRatio
|
|
216
|
+
? this.clampRelative(fractionSize > 5
|
|
217
|
+
? gaugeOptions?.measurementValueFontRatio * 0.5
|
|
218
|
+
: gaugeOptions?.measurementValueFontRatio, fractionSize > 5
|
|
219
|
+
? gaugeOptions.measurementValueFontMin * 0.5
|
|
220
|
+
: gaugeOptions?.measurementValueFontSizeMin, gaugeOptions?.measurementValueFontSizeMax)
|
|
221
|
+
: gaugeOptions?.measurementValueFontSize || 32,
|
|
222
|
+
fontFamily: gaugeOptionsColors?.fontFamily,
|
|
223
|
+
fontWeight: 'bolder',
|
|
224
|
+
color: gaugeOptionsColors?.knobFontColor || '#777'
|
|
225
|
+
},
|
|
226
|
+
unit: {
|
|
227
|
+
fontSize: gaugeOptions?.unitFontRatio
|
|
228
|
+
? this.clampRelative(gaugeOptions?.unitFontRatio, gaugeOptions?.unitFontSizeMin, gaugeOptions?.unitFontSizeMax)
|
|
229
|
+
: gaugeOptions?.unitFontSize || 20,
|
|
230
|
+
fontFamily: gaugeOptionsColors?.fontFamily,
|
|
231
|
+
color: gaugeOptionsColors?.knobFontColor || '#999'
|
|
232
|
+
},
|
|
233
|
+
date: {
|
|
234
|
+
fontSize: gaugeOptions?.dateFontRatio
|
|
235
|
+
? this.clampRelative(gaugeOptions?.dateFontRatio, gaugeOptions?.dateFontSizeMin, gaugeOptions?.dateFontSizeMax)
|
|
236
|
+
: gaugeOptions?.dateFontSize || 12,
|
|
237
|
+
fontFamily: gaugeOptionsColors?.fontFamily,
|
|
238
|
+
color: gaugeOptionsColors?.knobFontColor || '#555'
|
|
239
|
+
}
|
|
240
|
+
}
|
|
241
|
+
}
|
|
242
|
+
}
|
|
243
|
+
]
|
|
244
|
+
},
|
|
245
|
+
data: [
|
|
246
|
+
{
|
|
247
|
+
value: 0 || measurement?.value
|
|
248
|
+
}
|
|
249
|
+
]
|
|
250
|
+
}
|
|
251
|
+
]
|
|
252
|
+
};
|
|
253
|
+
}
|
|
254
|
+
updateRangeColors() {
|
|
255
|
+
if (!this.chart) {
|
|
256
|
+
return;
|
|
257
|
+
}
|
|
258
|
+
return {
|
|
259
|
+
default: getComputedStyle(this.chart.nativeElement).getPropertyValue('--c8y-form-control-border-color-default'),
|
|
260
|
+
yellow: getComputedStyle(this.chart.nativeElement).getPropertyValue('--c8y-palette-status-warning'),
|
|
261
|
+
red: getComputedStyle(this.chart.nativeElement).getPropertyValue('--c8y-palette-status-danger')
|
|
262
|
+
};
|
|
263
|
+
}
|
|
264
|
+
updateGaugeOptionsColors() {
|
|
265
|
+
if (!this.chart) {
|
|
266
|
+
return;
|
|
267
|
+
}
|
|
268
|
+
return {
|
|
269
|
+
splitLineColor: getComputedStyle(this.chart.nativeElement).getPropertyValue('--c8y-root-component-background-default'),
|
|
270
|
+
tickColor: getComputedStyle(this.chart.nativeElement).getPropertyValue('--c8y-root-component-background-default'),
|
|
271
|
+
axisLabelColor: getComputedStyle(this.chart.nativeElement).getPropertyValue('--c8y-root-component-color-default'),
|
|
272
|
+
pointerColor: getComputedStyle(this.chart.nativeElement).getPropertyValue('--c8y-root-component-color-default'),
|
|
273
|
+
knobColor: getComputedStyle(this.chart.nativeElement).getPropertyValue('--c8y-root-component-color-default'),
|
|
274
|
+
knobFontColor: getComputedStyle(this.chart.nativeElement).getPropertyValue('--c8y-root-component-background-default'),
|
|
275
|
+
measurementValueColor: getComputedStyle(this.chart.nativeElement).getPropertyValue('--c8y-root-component-color-default'),
|
|
276
|
+
unitColor: getComputedStyle(this.chart.nativeElement).getPropertyValue('--c8y-root-component-color-default'),
|
|
277
|
+
dateColor: getComputedStyle(this.chart.nativeElement).getPropertyValue('--c8y-root-component-text-muted'),
|
|
278
|
+
progressBarColor: getComputedStyle(this.chart.nativeElement).getPropertyValue('--c8y-root-component-brand-primary'),
|
|
279
|
+
fontFamily: getComputedStyle(document.body).getPropertyValue('font-family')
|
|
280
|
+
};
|
|
281
|
+
}
|
|
282
|
+
getColorArray(activeDatapointGauge, rangeColors) {
|
|
283
|
+
const min = activeDatapointGauge?.min ?? 0;
|
|
284
|
+
const max = activeDatapointGauge?.max ?? 100;
|
|
285
|
+
const range = max - min;
|
|
286
|
+
const yellowMin = activeDatapointGauge?.yellowRangeMin;
|
|
287
|
+
const yellowMax = activeDatapointGauge?.yellowRangeMax;
|
|
288
|
+
const redMin = activeDatapointGauge?.redRangeMin;
|
|
289
|
+
const redMax = activeDatapointGauge?.redRangeMax;
|
|
290
|
+
const ranges = [];
|
|
291
|
+
// First add red range
|
|
292
|
+
if (redMin != null && redMax != null && redMin < redMax) {
|
|
293
|
+
ranges.push({ start: redMin, end: redMax, color: rangeColors.red });
|
|
294
|
+
}
|
|
295
|
+
// Then add yellow, but clip out any overlap with red
|
|
296
|
+
if (yellowMin != null && yellowMax != null && yellowMin < yellowMax) {
|
|
297
|
+
const redRange = ranges.find(r => r.color === rangeColors.red);
|
|
298
|
+
if (!redRange ||
|
|
299
|
+
yellowMax <= redRange.start || // yellow ends before red
|
|
300
|
+
yellowMin >= redRange.end // yellow starts after red
|
|
301
|
+
) {
|
|
302
|
+
// no overlap
|
|
303
|
+
ranges.push({ start: yellowMin, end: yellowMax, color: rangeColors.yellow });
|
|
304
|
+
}
|
|
305
|
+
else {
|
|
306
|
+
// partial overlap – split yellow into non-overlapping parts
|
|
307
|
+
if (yellowMin < redRange.start) {
|
|
308
|
+
ranges.push({
|
|
309
|
+
start: yellowMin,
|
|
310
|
+
end: Math.min(yellowMax, redRange.start),
|
|
311
|
+
color: rangeColors.yellow
|
|
312
|
+
});
|
|
313
|
+
}
|
|
314
|
+
if (yellowMax > redRange.end) {
|
|
315
|
+
ranges.push({
|
|
316
|
+
start: Math.max(yellowMin, redRange.end),
|
|
317
|
+
end: yellowMax,
|
|
318
|
+
color: rangeColors.yellow
|
|
319
|
+
});
|
|
320
|
+
}
|
|
321
|
+
}
|
|
322
|
+
}
|
|
323
|
+
// Sort by start position
|
|
324
|
+
ranges.sort((a, b) => a.start - b.start);
|
|
325
|
+
// Build segments
|
|
326
|
+
const segments = [];
|
|
327
|
+
let current = min;
|
|
328
|
+
for (const { start, end, color } of ranges) {
|
|
329
|
+
if (start > current) {
|
|
330
|
+
// Default fill before this range
|
|
331
|
+
segments.push([(start - min) / range, rangeColors.default]);
|
|
332
|
+
}
|
|
333
|
+
// Start color
|
|
334
|
+
segments.push([(start - min) / range, color]);
|
|
335
|
+
// End color
|
|
336
|
+
segments.push([(end - min) / range, color]);
|
|
337
|
+
current = Math.max(current, end);
|
|
338
|
+
}
|
|
339
|
+
// Fill remaining with default
|
|
340
|
+
if (current < max) {
|
|
341
|
+
segments.push([(current - min) / range, rangeColors.default]);
|
|
342
|
+
}
|
|
343
|
+
if (segments.length === 0 || segments[segments.length - 1][0] < 1) {
|
|
344
|
+
segments.push([1, rangeColors.default]);
|
|
345
|
+
}
|
|
346
|
+
return segments;
|
|
347
|
+
}
|
|
348
|
+
clampRelative(ratio, min, max) {
|
|
349
|
+
const clampedValue = this.containerSize * ratio;
|
|
350
|
+
if (clampedValue < min) {
|
|
351
|
+
return min;
|
|
352
|
+
}
|
|
353
|
+
else if (clampedValue > max) {
|
|
354
|
+
return max;
|
|
355
|
+
}
|
|
356
|
+
else {
|
|
357
|
+
return clampedValue;
|
|
358
|
+
}
|
|
359
|
+
}
|
|
360
|
+
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: RadialGaugeService, deps: [{ token: i1.DatePipe }], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
361
|
+
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: RadialGaugeService, providedIn: 'root' }); }
|
|
362
|
+
}
|
|
363
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: RadialGaugeService, decorators: [{
|
|
364
|
+
type: Injectable,
|
|
365
|
+
args: [{
|
|
366
|
+
providedIn: 'root'
|
|
367
|
+
}]
|
|
368
|
+
}], ctorParameters: () => [{ type: i1.DatePipe }] });
|
|
369
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radial-gauge.service.js","sourceRoot":"","sources":["../../../../../../widgets/implementations/info-gauge/radial-gauge/radial-gauge.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { ElementRef, Injectable } from '@angular/core';\nimport { KPIDetails } from '@c8y/ngx-components/datapoint-selector';\nimport { GaugeOptions, GaugeOptionsColors } from '../info-gauge-widget-config/gauge.model';\nimport { IMeasurementValue } from '@c8y/client';\nimport { DatePipe } from '@c8y/ngx-components';\n\n@Injectable({\n  providedIn: 'root'\n})\nexport class RadialGaugeService {\n  private chart: ElementRef;\n  containerSize = 400;\n\n  constructor(private c8yDatePipe: DatePipe) {}\n\n  setChart(chart: ElementRef): void {\n    this.chart = chart;\n  }\n\n  getChartOptions(\n    gaugeOptions: GaugeOptions,\n    activeDatapointGauge: KPIDetails,\n    selectedPresetId: string,\n    gaugeOptionsColors: GaugeOptionsColors,\n    rangeColors: { default: string; yellow: string; red: string },\n    measurement: IMeasurementValue,\n    fractionSize: number\n  ) {\n    const colorArray = this.getColorArray(activeDatapointGauge, rangeColors);\n\n    return {\n      series: [\n        {\n          type: 'gauge',\n          radius: gaugeOptions?.radius || '90%',\n          center: gaugeOptions?.center || ['50%', '50%'],\n          startAngle: gaugeOptions?.startAngle || 240,\n          endAngle: gaugeOptions?.endAngle || 300,\n          min: activeDatapointGauge?.min || 0,\n          max:\n            activeDatapointGauge?.max !== undefined && activeDatapointGauge?.max !== null\n              ? activeDatapointGauge.max\n              : 100,\n\n          // Split properties\n          splitNumber: gaugeOptions?.splitNumber || 10,\n          splitLine: {\n            distance: gaugeOptions?.splitLineDistanceRatio\n              ? this.containerSize *\n                gaugeOptions?.axisLineWidthRatio *\n                gaugeOptions?.splitLineDistanceRatio\n              : gaugeOptions?.splitLineDistance || -30,\n\n            length: gaugeOptions?.splitLineLengthRatio\n              ? this.containerSize *\n                gaugeOptions?.axisLineWidthRatio *\n                gaugeOptions?.splitLineLengthRatio\n              : gaugeOptions?.splitLineLength || 30,\n\n            lineStyle: {\n              color:\n                selectedPresetId === 'custom' || selectedPresetId === 'grade-rating'\n                  ? gaugeOptions?.splitLineColor\n                  : gaugeOptionsColors?.splitLineColor || '#fff',\n              width: gaugeOptions?.splitLineWidth || 4\n            }\n          },\n\n          // Tick properties\n          axisTick: {\n            show: gaugeOptions?.tickShow || false,\n            distance: gaugeOptions?.tickDistanceRatio\n              ? this.containerSize *\n                gaugeOptions?.axisLineWidthRatio *\n                gaugeOptions?.tickDistanceRatio\n              : gaugeOptions?.tickDistance || -30,\n            length: gaugeOptions?.tickLengthRatio\n              ? this.containerSize *\n                gaugeOptions?.axisLineWidthRatio *\n                gaugeOptions?.tickLengthRatio\n              : gaugeOptions?.tickLength || 8,\n            lineStyle: {\n              color:\n                selectedPresetId === 'custom' || selectedPresetId === 'grade-rating'\n                  ? gaugeOptions.tickColor\n                  : gaugeOptionsColors?.tickColor || '#fff',\n              width: gaugeOptions?.tickWidth || 2\n            }\n          },\n\n          // Axis properties\n          axisLine: {\n            lineStyle: {\n              width: gaugeOptions?.axisLineWidthRatio\n                ? this.containerSize * gaugeOptions?.axisLineWidthRatio\n                : gaugeOptions?.axisLineWidth || 30,\n              color: colorArray\n            }\n          },\n\n          axisLabel: {\n            color:\n              selectedPresetId === 'custom' || selectedPresetId === 'grade-rating'\n                ? gaugeOptions.axisLabelColor\n                : gaugeOptionsColors?.axisLabelColor || 'inherit',\n            distance: gaugeOptions?.axisLabelDistanceRatio\n              ? this.containerSize *\n                gaugeOptions?.axisLineWidthRatio *\n                gaugeOptions?.axisLabelDistanceRatio\n              : gaugeOptions?.axisLabelDistance || 40,\n            fontSize: gaugeOptions?.axisLabelFontSizeRatio\n              ? this.clampRelative(\n                  gaugeOptions?.axisLabelFontSizeRatio,\n                  gaugeOptions?.axisLabelFontSizeMin,\n                  gaugeOptions?.axisLabelFontSizeMax\n                )\n              : gaugeOptions?.axisLabelFontSize || 16,\n            fontWeight: 'bold',\n            fontFamily: gaugeOptionsColors?.fontFamily\n          },\n\n          // pointer properties\n          pointer: {\n            ...(gaugeOptions?.pointerStyle !== 'default' && {\n              icon: gaugeOptions?.pointerStyle\n            }),\n            show: gaugeOptions?.showPointer || false,\n            length: gaugeOptions?.pointerLengthRatio\n              ? gaugeOptions?.pointerLengthRatio *\n                (this.containerSize * gaugeOptions?.axisLineWidthRatio)\n              : gaugeOptions?.pointerLength || '65%',\n            width: gaugeOptions?.pointerWidthRatio\n              ? this.containerSize *\n                gaugeOptions?.axisLineWidthRatio *\n                gaugeOptions?.pointerWidthRatio\n              : gaugeOptions?.pointerWidth || 40,\n            offsetCenter:\n              selectedPresetId === 'default'\n                ? [0, this.containerSize * gaugeOptions?.axisLineWidthRatio * -1]\n                : [0, gaugeOptions?.pointerOffset || -30],\n            itemStyle: {\n              color:\n                selectedPresetId === 'custom'\n                  ? gaugeOptions.pointerColor\n                  : gaugeOptionsColors?.pointerColor || 'inherit'\n            }\n          },\n\n          // Progress bar properties\n          progress: {\n            show: gaugeOptions?.progressBar || false,\n            roundCap: gaugeOptions?.progressBarRoundCap || false,\n            width: gaugeOptions?.progressBarWidthRatio\n              ? this.containerSize *\n                gaugeOptions?.axisLineWidthRatio *\n                gaugeOptions?.progressBarWidthRatio\n              : gaugeOptions?.progressBarWidth || 18,\n            itemStyle: {\n              color:\n                selectedPresetId === 'custom'\n                  ? gaugeOptions.progressBarColor\n                  : gaugeOptionsColors?.progressBarColor || 'inherit'\n            }\n          },\n\n          // Anchor properties\n          anchor: gaugeOptions?.anchor\n            ? {\n                ...gaugeOptions.anchor,\n                size: gaugeOptions?.anchor?.sizeRatio\n                  ? this.containerSize * gaugeOptions?.anchor?.sizeRatio\n                  : gaugeOptions?.anchor?.size || 45,\n                itemStyle: {\n                  color:\n                    selectedPresetId === 'custom'\n                      ? gaugeOptions.pointerColor\n                      : gaugeOptionsColors?.pointerColor\n                }\n              }\n            : undefined,\n\n          // Detail properties\n          detail: {\n            show: gaugeOptions?.showDetail || false,\n            valueAnimation: true,\n            offsetCenter: gaugeOptions?.detailOffsetCenterYRatio\n              ? [0, gaugeOptions?.detailOffsetCenterYRatio * this.containerSize]\n              : gaugeOptions?.detailOffsetCenter || [0, 0],\n\n            formatter: () => {\n              const value = measurement?.value.toFixed(fractionSize) || 0;\n              const unit = activeDatapointGauge?.unit || measurement?.unit || '';\n              const date = new Date(measurement?.date);\n              const formattedDate = this.c8yDatePipe.transform(date);\n              return `{value|${value}}{unit|${unit}} \\n {date|${formattedDate}} `;\n            },\n            color: 'inherit',\n            lineHeight: gaugeOptions?.measurementValueFontRatio\n              ? this.clampRelative(\n                  gaugeOptions?.measurementValueFontRatio * 0.9,\n                  gaugeOptions?.measurementValueFontSizeMin,\n                  gaugeOptions?.measurementValueFontSizeMax\n                )\n              : gaugeOptions?.measurementValueFontSize || 32,\n            rich: {\n              value: {\n                fontSize: gaugeOptions?.measurementValueFontRatio\n                  ? this.clampRelative(\n                      fractionSize > 5 || measurement?.value > 9999\n                        ? gaugeOptions?.measurementValueFontRatio * 0.5\n                        : gaugeOptions?.measurementValueFontRatio,\n                      gaugeOptions?.measurementValueFontSizeMin,\n                      gaugeOptions?.measurementValueFontSizeMax\n                    )\n                  : gaugeOptions?.measurementValueFontSize || 32,\n                fontWeight: 'bolder',\n                fontFamily: gaugeOptionsColors?.fontFamily,\n                color:\n                  selectedPresetId === 'custom'\n                    ? gaugeOptions.measurementValueColor\n                    : gaugeOptionsColors?.measurementValueColor || '#777'\n              },\n              unit: {\n                fontSize: gaugeOptions?.unitFontRatio\n                  ? this.clampRelative(\n                      gaugeOptions?.unitFontRatio,\n                      gaugeOptions?.unitFontMin,\n                      gaugeOptions?.unitFontMax\n                    )\n                  : gaugeOptions?.unitFontSize || 20,\n                fontFamily: gaugeOptionsColors?.fontFamily,\n                color:\n                  selectedPresetId === 'custom'\n                    ? gaugeOptions?.unitColor\n                    : gaugeOptionsColors?.unitColor || '#999'\n              },\n              date: {\n                fontSize: gaugeOptions?.dateFontRatio\n                  ? this.clampRelative(\n                      gaugeOptions?.dateFontRatio,\n                      gaugeOptions?.dateFontSizeMin,\n                      gaugeOptions?.dateFontSizeMax\n                    )\n                  : gaugeOptions?.dateFontSize || 12,\n                fontFamily: gaugeOptionsColors?.fontFamily,\n                color:\n                  selectedPresetId === 'custom'\n                    ? gaugeOptions?.dateColor\n                    : gaugeOptionsColors?.dateColor || '#555'\n              }\n            }\n          },\n          markPoint: {\n            symbolSize: 0,\n            offsetCenter: gaugeOptions?.detailOffsetCenter || [0, 0],\n            data: [\n              {\n                x: '50%',\n                y: '50%',\n                label: {\n                  show: gaugeOptions?.showMarkPoint,\n                  formatter: () => {\n                    const value = measurement?.value.toFixed(fractionSize) || 0;\n                    const unit = activeDatapointGauge?.unit || measurement?.unit || '';\n                    const date = new Date(measurement?.date);\n                    const formattedDate = this.c8yDatePipe.transform(date);\n                    return `{value|${value}}{unit|${unit}} \\n {date|${formattedDate}} `;\n                  },\n                  color: '#fff',\n                  align: 'center',\n                  rich: {\n                    value: {\n                      fontSize: gaugeOptions?.measurementValueFontRatio\n                        ? this.clampRelative(\n                            fractionSize > 5\n                              ? gaugeOptions?.measurementValueFontRatio * 0.5\n                              : gaugeOptions?.measurementValueFontRatio,\n                            fractionSize > 5\n                              ? gaugeOptions.measurementValueFontMin * 0.5\n                              : gaugeOptions?.measurementValueFontSizeMin,\n                            gaugeOptions?.measurementValueFontSizeMax\n                          )\n                        : gaugeOptions?.measurementValueFontSize || 32,\n                      fontFamily: gaugeOptionsColors?.fontFamily,\n                      fontWeight: 'bolder',\n                      color: gaugeOptionsColors?.knobFontColor || '#777'\n                    },\n                    unit: {\n                      fontSize: gaugeOptions?.unitFontRatio\n                        ? this.clampRelative(\n                            gaugeOptions?.unitFontRatio,\n                            gaugeOptions?.unitFontSizeMin,\n                            gaugeOptions?.unitFontSizeMax\n                          )\n                        : gaugeOptions?.unitFontSize || 20,\n                      fontFamily: gaugeOptionsColors?.fontFamily,\n                      color: gaugeOptionsColors?.knobFontColor || '#999'\n                    },\n                    date: {\n                      fontSize: gaugeOptions?.dateFontRatio\n                        ? this.clampRelative(\n                            gaugeOptions?.dateFontRatio,\n                            gaugeOptions?.dateFontSizeMin,\n                            gaugeOptions?.dateFontSizeMax\n                          )\n                        : gaugeOptions?.dateFontSize || 12,\n                      fontFamily: gaugeOptionsColors?.fontFamily,\n                      color: gaugeOptionsColors?.knobFontColor || '#555'\n                    }\n                  }\n                }\n              }\n            ]\n          },\n          data: [\n            {\n              value: 0 || measurement?.value\n            }\n          ]\n        }\n      ]\n    };\n  }\n\n  updateRangeColors(): any {\n    if (!this.chart) {\n      return;\n    }\n\n    return {\n      default: getComputedStyle(this.chart.nativeElement).getPropertyValue(\n        '--c8y-form-control-border-color-default'\n      ),\n      yellow: getComputedStyle(this.chart.nativeElement).getPropertyValue(\n        '--c8y-palette-status-warning'\n      ),\n      red: getComputedStyle(this.chart.nativeElement).getPropertyValue(\n        '--c8y-palette-status-danger'\n      )\n    };\n  }\n\n  updateGaugeOptionsColors(): any {\n    if (!this.chart) {\n      return;\n    }\n\n    return {\n      splitLineColor: getComputedStyle(this.chart.nativeElement).getPropertyValue(\n        '--c8y-root-component-background-default'\n      ),\n      tickColor: getComputedStyle(this.chart.nativeElement).getPropertyValue(\n        '--c8y-root-component-background-default'\n      ),\n      axisLabelColor: getComputedStyle(this.chart.nativeElement).getPropertyValue(\n        '--c8y-root-component-color-default'\n      ),\n      pointerColor: getComputedStyle(this.chart.nativeElement).getPropertyValue(\n        '--c8y-root-component-color-default'\n      ),\n      knobColor: getComputedStyle(this.chart.nativeElement).getPropertyValue(\n        '--c8y-root-component-color-default'\n      ),\n      knobFontColor: getComputedStyle(this.chart.nativeElement).getPropertyValue(\n        '--c8y-root-component-background-default'\n      ),\n      measurementValueColor: getComputedStyle(this.chart.nativeElement).getPropertyValue(\n        '--c8y-root-component-color-default'\n      ),\n      unitColor: getComputedStyle(this.chart.nativeElement).getPropertyValue(\n        '--c8y-root-component-color-default'\n      ),\n      dateColor: getComputedStyle(this.chart.nativeElement).getPropertyValue(\n        '--c8y-root-component-text-muted'\n      ),\n      progressBarColor: getComputedStyle(this.chart.nativeElement).getPropertyValue(\n        '--c8y-root-component-brand-primary'\n      ),\n      fontFamily: getComputedStyle(document.body).getPropertyValue('font-family')\n    };\n  }\n\n  private getColorArray(\n    activeDatapointGauge: KPIDetails,\n    rangeColors: { default: string; yellow: string; red: string }\n  ): [number, string][] {\n    const min = activeDatapointGauge?.min ?? 0;\n    const max = activeDatapointGauge?.max ?? 100;\n    const range = max - min;\n\n    const yellowMin = activeDatapointGauge?.yellowRangeMin;\n    const yellowMax = activeDatapointGauge?.yellowRangeMax;\n    const redMin = activeDatapointGauge?.redRangeMin;\n    const redMax = activeDatapointGauge?.redRangeMax;\n\n    type Range = { start: number; end: number; color: string };\n\n    const ranges: Range[] = [];\n\n    // First add red range\n    if (redMin != null && redMax != null && redMin < redMax) {\n      ranges.push({ start: redMin, end: redMax, color: rangeColors.red });\n    }\n\n    // Then add yellow, but clip out any overlap with red\n    if (yellowMin != null && yellowMax != null && yellowMin < yellowMax) {\n      const redRange = ranges.find(r => r.color === rangeColors.red);\n\n      if (\n        !redRange ||\n        yellowMax <= redRange.start || // yellow ends before red\n        yellowMin >= redRange.end // yellow starts after red\n      ) {\n        // no overlap\n        ranges.push({ start: yellowMin, end: yellowMax, color: rangeColors.yellow });\n      } else {\n        // partial overlap – split yellow into non-overlapping parts\n        if (yellowMin < redRange.start) {\n          ranges.push({\n            start: yellowMin,\n            end: Math.min(yellowMax, redRange.start),\n            color: rangeColors.yellow\n          });\n        }\n        if (yellowMax > redRange.end) {\n          ranges.push({\n            start: Math.max(yellowMin, redRange.end),\n            end: yellowMax,\n            color: rangeColors.yellow\n          });\n        }\n      }\n    }\n\n    // Sort by start position\n    ranges.sort((a, b) => a.start - b.start);\n\n    // Build segments\n    const segments: [number, string][] = [];\n    let current = min;\n\n    for (const { start, end, color } of ranges) {\n      if (start > current) {\n        // Default fill before this range\n        segments.push([(start - min) / range, rangeColors.default]);\n      }\n      // Start color\n      segments.push([(start - min) / range, color]);\n      // End color\n      segments.push([(end - min) / range, color]);\n\n      current = Math.max(current, end);\n    }\n\n    // Fill remaining with default\n    if (current < max) {\n      segments.push([(current - min) / range, rangeColors.default]);\n    }\n\n    if (segments.length === 0 || segments[segments.length - 1][0] < 1) {\n      segments.push([1, rangeColors.default]);\n    }\n\n    return segments;\n  }\n\n  private clampRelative(ratio: number, min: number, max: number): number {\n    const clampedValue = this.containerSize * ratio;\n    if (clampedValue < min) {\n      return min;\n    } else if (clampedValue > max) {\n      return max;\n    } else {\n      return clampedValue;\n    }\n  }\n}\n"]}
|
|
@@ -1496,12 +1496,14 @@ class ChartsComponent {
|
|
|
1496
1496
|
this.chartEventsService = inject(ChartEventsService);
|
|
1497
1497
|
this.chartAlarmsService = inject(ChartAlarmsService);
|
|
1498
1498
|
this.widgetTimeContextDateRangeService = inject(WidgetTimeContextDateRangeService);
|
|
1499
|
+
this.loadedTimeRange = null;
|
|
1499
1500
|
this.chartOption$ = this.configChangedSubject.pipe(switchMap(() => this.loadAlarmsAndEvents()), switchMap(() => this.fetchSeriesForDatapoints$()), switchMap((datapointsWithValues) => {
|
|
1500
1501
|
if (datapointsWithValues.length === 0) {
|
|
1501
1502
|
this.echartsInstance?.clear();
|
|
1502
1503
|
this.showLoadMore = false;
|
|
1503
1504
|
return of(this.getDefaultChartOptions());
|
|
1504
1505
|
}
|
|
1506
|
+
this.loadedTimeRange = { ...this.getTimeRange() };
|
|
1505
1507
|
return this.getChartOptions(datapointsWithValues);
|
|
1506
1508
|
}), tap(v => {
|
|
1507
1509
|
if (v['empty']) {
|
|
@@ -1510,7 +1512,13 @@ class ChartsComponent {
|
|
|
1510
1512
|
this.chartRealtimeService.stopRealtime();
|
|
1511
1513
|
this.startRealtimeIfPossible();
|
|
1512
1514
|
if (this.echartsInstance) {
|
|
1513
|
-
|
|
1515
|
+
/**
|
|
1516
|
+
* * Set the chart options
|
|
1517
|
+
* First parameter is the options to set
|
|
1518
|
+
* Second parameter is a boolean to indicate that the chart should be re-rendered as we do not want to merge.
|
|
1519
|
+
* Third parameter is a boolean to indicate that we want to lazy load the chart.
|
|
1520
|
+
*/
|
|
1521
|
+
this.echartsInstance.setOption(v, true, true);
|
|
1514
1522
|
const options = this.echartsInstance.getOption();
|
|
1515
1523
|
const dataZoom = options['dataZoom'][0];
|
|
1516
1524
|
if (dataZoom.start !== 0) {
|
|
@@ -1520,7 +1528,16 @@ class ChartsComponent {
|
|
|
1520
1528
|
this.sliderZoomUsed = false;
|
|
1521
1529
|
}));
|
|
1522
1530
|
}
|
|
1523
|
-
ngOnChanges() {
|
|
1531
|
+
ngOnChanges(changes) {
|
|
1532
|
+
const currentTimeRange = this.getTimeRange();
|
|
1533
|
+
// Check if the current time range is within the loaded time range to avoid unnecessary updates
|
|
1534
|
+
if (this.loadedTimeRange &&
|
|
1535
|
+
new Date(currentTimeRange.dateFrom) >= new Date(this.loadedTimeRange.dateFrom) &&
|
|
1536
|
+
new Date(currentTimeRange.dateTo) <= new Date(this.loadedTimeRange.dateTo) &&
|
|
1537
|
+
changes.config.previousValue?.dateFrom !== changes.config.currentValue.dateFrom &&
|
|
1538
|
+
changes.config.previousValue?.dateTo !== changes.config.currentValue.dateTo) {
|
|
1539
|
+
return;
|
|
1540
|
+
}
|
|
1524
1541
|
this.configChangedSubject.next();
|
|
1525
1542
|
}
|
|
1526
1543
|
ngOnInit() {
|
|
@@ -1662,6 +1679,36 @@ class ChartsComponent {
|
|
|
1662
1679
|
timeout = setTimeout(() => func(...args), wait);
|
|
1663
1680
|
};
|
|
1664
1681
|
}
|
|
1682
|
+
/**
|
|
1683
|
+
* Toggles the visibility of a series in the chart based on the provided datapoint.
|
|
1684
|
+
* @param datapoint - The datapoint to toggle visibility for.
|
|
1685
|
+
*/
|
|
1686
|
+
toggleDatapointSeriesVisibility(datapoint) {
|
|
1687
|
+
const series = this.echartsInstance.getOption().series;
|
|
1688
|
+
const seriesToUpdate = series.find(s => s.datapointLabel === datapoint.label);
|
|
1689
|
+
if (seriesToUpdate) {
|
|
1690
|
+
this.echartsInstance.dispatchAction({
|
|
1691
|
+
type: 'legendToggleSelect',
|
|
1692
|
+
name: seriesToUpdate.name
|
|
1693
|
+
});
|
|
1694
|
+
}
|
|
1695
|
+
}
|
|
1696
|
+
/**
|
|
1697
|
+
* Toggles the visibility of a series in the chart based on the provided alarm or event.
|
|
1698
|
+
* @param alarmOrEvent - The alarm or event to toggle visibility for.
|
|
1699
|
+
*/
|
|
1700
|
+
toggleAlarmEventSeriesVisibility(alarmOrEvent) {
|
|
1701
|
+
const series = this.echartsInstance.getOption().series;
|
|
1702
|
+
const seriesToUpdate = series.filter(s => s.name === `${alarmOrEvent.label}-markPoint` || s.name === `${alarmOrEvent.label}-markLine`);
|
|
1703
|
+
if (seriesToUpdate) {
|
|
1704
|
+
seriesToUpdate.forEach(s => {
|
|
1705
|
+
this.echartsInstance.dispatchAction({
|
|
1706
|
+
type: 'legendToggleSelect',
|
|
1707
|
+
name: s.name
|
|
1708
|
+
});
|
|
1709
|
+
});
|
|
1710
|
+
}
|
|
1711
|
+
}
|
|
1665
1712
|
getDefaultChartOptions() {
|
|
1666
1713
|
return {
|
|
1667
1714
|
title: {
|