@c8y/ngx-components 1021.63.2 → 1021.67.0

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.
Files changed (197) hide show
  1. package/auth-configuration/sso-configuration/template-parts/signature-configuration.component.d.ts +7 -2
  2. package/auth-configuration/sso-configuration/template-parts/signature-configuration.component.d.ts.map +1 -1
  3. package/core/bottom-drawer/bottom-drawer-ref.d.ts +4 -0
  4. package/core/bottom-drawer/bottom-drawer-ref.d.ts.map +1 -1
  5. package/core/breadcrumb/breadcrumb-item.component.d.ts +1 -1
  6. package/core/breadcrumb/breadcrumb-item.component.d.ts.map +1 -1
  7. package/core/breadcrumb/breadcrumb-outlet.component.d.ts +1 -1
  8. package/core/breadcrumb/breadcrumb-outlet.component.d.ts.map +1 -1
  9. package/core/breadcrumb/breadcrumb.component.d.ts +1 -1
  10. package/core/breadcrumb/breadcrumb.component.d.ts.map +1 -1
  11. package/core/breadcrumb/breadcrumb.module.d.ts +7 -7
  12. package/core/breadcrumb/breadcrumb.module.d.ts.map +1 -1
  13. package/core/common/common.module.d.ts +38 -38
  14. package/core/common/date-format.service.d.ts +30 -0
  15. package/core/common/date-format.service.d.ts.map +1 -0
  16. package/core/common/date.pipe.d.ts +7 -3
  17. package/core/common/date.pipe.d.ts.map +1 -1
  18. package/core/common/index.d.ts +1 -0
  19. package/core/common/index.d.ts.map +1 -1
  20. package/core/common/outlet.directive.d.ts +1 -1
  21. package/core/common/outlet.directive.d.ts.map +1 -1
  22. package/core/common/user-preferences/user-preferences-store-current-user.d.ts +11 -0
  23. package/core/common/user-preferences/user-preferences-store-current-user.d.ts.map +1 -0
  24. package/core/common/user-preferences/user-preferences.service.d.ts +40 -1
  25. package/core/common/user-preferences/user-preferences.service.d.ts.map +1 -1
  26. package/core/date-picker/date-picker.component.d.ts +3 -1
  27. package/core/date-picker/date-picker.component.d.ts.map +1 -1
  28. package/core/date-time-picker/date-time-picker.component.d.ts +6 -3
  29. package/core/date-time-picker/date-time-picker.component.d.ts.map +1 -1
  30. package/core/dynamic-forms/date/date.type.component.d.ts +3 -0
  31. package/core/dynamic-forms/date/date.type.component.d.ts.map +1 -1
  32. package/core/plugins/plugins.model.d.ts +1 -0
  33. package/core/plugins/plugins.model.d.ts.map +1 -1
  34. package/core/plugins/plugins.service.d.ts +7 -2
  35. package/core/plugins/plugins.service.d.ts.map +1 -1
  36. package/core/time-interval/time-interval.component.d.ts +4 -2
  37. package/core/time-interval/time-interval.component.d.ts.map +1 -1
  38. package/ecosystem/application-plugins/application-plugin-readme.component.d.ts +15 -0
  39. package/ecosystem/application-plugins/application-plugin-readme.component.d.ts.map +1 -0
  40. package/ecosystem/application-plugins/application-plugins.component.d.ts +4 -2
  41. package/ecosystem/application-plugins/application-plugins.component.d.ts.map +1 -1
  42. package/ecosystem/application-plugins/application-plugins.module.d.ts +4 -3
  43. package/ecosystem/application-plugins/application-plugins.module.d.ts.map +1 -1
  44. package/ecosystem/application-plugins/install-plugin.component.d.ts +8 -4
  45. package/ecosystem/application-plugins/install-plugin.component.d.ts.map +1 -1
  46. package/ecosystem/application-plugins/plugin-list.component.d.ts +10 -26
  47. package/ecosystem/application-plugins/plugin-list.component.d.ts.map +1 -1
  48. package/ecosystem/application-plugins/plugin-list.service.d.ts +27 -0
  49. package/ecosystem/application-plugins/plugin-list.service.d.ts.map +1 -0
  50. package/ecosystem/ecosystem.module.d.ts +2 -1
  51. package/ecosystem/ecosystem.module.d.ts.map +1 -1
  52. package/ecosystem/packages/package-changelog-tab/package-changelog-tab.component.d.ts +15 -0
  53. package/ecosystem/packages/package-changelog-tab/package-changelog-tab.component.d.ts.map +1 -0
  54. package/ecosystem/packages/package-changelog.guard.d.ts +10 -0
  55. package/ecosystem/packages/package-changelog.guard.d.ts.map +1 -0
  56. package/ecosystem/packages/package-details/package-details.component.d.ts +7 -9
  57. package/ecosystem/packages/package-details/package-details.component.d.ts.map +1 -1
  58. package/ecosystem/packages/package-versions/package-contents/contents-plugins/contents-plugins.component.d.ts +5 -1
  59. package/ecosystem/packages/package-versions/package-contents/contents-plugins/contents-plugins.component.d.ts.map +1 -1
  60. package/ecosystem/packages/package-versions/package-contents/packages-contents.component.d.ts +8 -3
  61. package/ecosystem/packages/package-versions/package-contents/packages-contents.component.d.ts.map +1 -1
  62. package/ecosystem/packages/package-versions/packages-versions.component.d.ts +9 -2
  63. package/ecosystem/packages/package-versions/packages-versions.component.d.ts.map +1 -1
  64. package/ecosystem/shared/index.d.ts +1 -0
  65. package/ecosystem/shared/index.d.ts.map +1 -1
  66. package/ecosystem/shared/package-changelog/package-changelog.component.d.ts +24 -0
  67. package/ecosystem/shared/package-changelog/package-changelog.component.d.ts.map +1 -0
  68. package/ecosystem/shared/shared-ecosystem.module.d.ts +2 -1
  69. package/ecosystem/shared/shared-ecosystem.module.d.ts.map +1 -1
  70. package/esm2022/auth-configuration/sso-configuration/template-parts/signature-configuration.component.mjs +11 -7
  71. package/esm2022/core/bottom-drawer/bottom-drawer-ref.mjs +9 -3
  72. package/esm2022/core/breadcrumb/breadcrumb-item.component.mjs +3 -3
  73. package/esm2022/core/breadcrumb/breadcrumb-outlet.component.mjs +19 -9
  74. package/esm2022/core/breadcrumb/breadcrumb.component.mjs +3 -3
  75. package/esm2022/core/breadcrumb/breadcrumb.module.mjs +16 -5
  76. package/esm2022/core/common/common.module.mjs +6 -6
  77. package/esm2022/core/common/date-format.service.mjs +81 -0
  78. package/esm2022/core/common/date.pipe.mjs +29 -6
  79. package/esm2022/core/common/index.mjs +2 -1
  80. package/esm2022/core/common/outlet.directive.mjs +4 -3
  81. package/esm2022/core/common/user-preferences/user-preferences-store-current-user.mjs +22 -0
  82. package/esm2022/core/common/user-preferences/user-preferences.service.mjs +106 -16
  83. package/esm2022/core/date-picker/date-picker.component.mjs +11 -4
  84. package/esm2022/core/date-time-picker/date-time-picker.component.mjs +20 -11
  85. package/esm2022/core/dynamic-forms/date/date.type.component.mjs +12 -4
  86. package/esm2022/core/plugins/plugins.model.mjs +1 -1
  87. package/esm2022/core/plugins/plugins.service.mjs +31 -5
  88. package/esm2022/core/time-interval/time-interval.component.mjs +9 -2
  89. package/esm2022/ecosystem/application-plugins/application-plugin-readme.component.mjs +26 -0
  90. package/esm2022/ecosystem/application-plugins/application-plugins.component.mjs +29 -14
  91. package/esm2022/ecosystem/application-plugins/application-plugins.module.mjs +6 -3
  92. package/esm2022/ecosystem/application-plugins/install-plugin.component.mjs +21 -15
  93. package/esm2022/ecosystem/application-plugins/plugin-list-item.component.mjs +3 -3
  94. package/esm2022/ecosystem/application-plugins/plugin-list.component.mjs +26 -202
  95. package/esm2022/ecosystem/application-plugins/plugin-list.service.mjs +200 -0
  96. package/esm2022/ecosystem/application-plugins/update-plugin-of-app/update-plugin-of-app.component.mjs +3 -3
  97. package/esm2022/ecosystem/application-properties/update-application-modal/update-application-modal.component.mjs +1 -1
  98. package/esm2022/ecosystem/ecosystem.module.mjs +21 -5
  99. package/esm2022/ecosystem/packages/package-changelog-tab/package-changelog-tab.component.mjs +33 -0
  100. package/esm2022/ecosystem/packages/package-changelog.guard.mjs +22 -0
  101. package/esm2022/ecosystem/packages/package-details/package-details.component.mjs +25 -44
  102. package/esm2022/ecosystem/packages/package-versions/package-contents/contents-plugins/contents-plugins.component.mjs +14 -4
  103. package/esm2022/ecosystem/packages/package-versions/package-contents/packages-contents.component.mjs +27 -8
  104. package/esm2022/ecosystem/packages/package-versions/packages-versions.component.mjs +22 -8
  105. package/esm2022/ecosystem/shared/index.mjs +2 -1
  106. package/esm2022/ecosystem/shared/list-filters/list-filters.component.mjs +3 -3
  107. package/esm2022/ecosystem/shared/package-changelog/package-changelog.component.mjs +82 -0
  108. package/esm2022/ecosystem/shared/package-version-select/package-version-select.component.mjs +3 -3
  109. package/esm2022/ecosystem/shared/shared-ecosystem.module.mjs +12 -6
  110. package/esm2022/operations/bulk-operation-scheduler/operation-scheduler.component.mjs +9 -7
  111. package/esm2022/operations/bulk-operations-list/bulk-operations-list.component.mjs +1 -1
  112. package/esm2022/upgrade/ng1/downgraded.services.mjs +3 -2
  113. package/esm2022/upgrade/ng1/index.mjs +3 -2
  114. package/esm2022/widgets/cockpit/index.mjs +3 -1
  115. package/esm2022/widgets/cockpit-exports/index.mjs +8 -1
  116. package/esm2022/widgets/definitions/index.mjs +2 -1
  117. package/esm2022/widgets/definitions/radial-gauge/c8y-ngx-components-widgets-definitions-radial-gauge.mjs +5 -0
  118. package/esm2022/widgets/definitions/radial-gauge/index.mjs +33 -0
  119. package/esm2022/widgets/implementations/info-gauge/index.mjs +2 -2
  120. package/esm2022/widgets/implementations/info-gauge/info-gauge-widget-config/gauge.model.mjs +295 -0
  121. package/esm2022/widgets/implementations/info-gauge/info-gauge-widget-config/info-gauge-widget-config.component.mjs +141 -11
  122. package/esm2022/widgets/implementations/info-gauge/info-gauge-widget-config/preset-preview/preset-preview.component.mjs +67 -0
  123. package/esm2022/widgets/implementations/info-gauge/info-gauge-widget-view/info-gauge-widget-view.component.mjs +34 -6
  124. package/esm2022/widgets/implementations/info-gauge/info-gauge-widget.module.mjs +9 -4
  125. package/esm2022/widgets/implementations/info-gauge/radial-gauge/radial-gauge.component.mjs +97 -0
  126. package/esm2022/widgets/implementations/info-gauge/radial-gauge/radial-gauge.service.mjs +369 -0
  127. package/fesm2022/c8y-ngx-components-auth-configuration.mjs +9 -5
  128. package/fesm2022/c8y-ngx-components-auth-configuration.mjs.map +1 -1
  129. package/fesm2022/c8y-ngx-components-ecosystem-application-plugins.mjs +209 -142
  130. package/fesm2022/c8y-ngx-components-ecosystem-application-plugins.mjs.map +1 -1
  131. package/fesm2022/c8y-ngx-components-ecosystem-shared.mjs +96 -13
  132. package/fesm2022/c8y-ngx-components-ecosystem-shared.mjs.map +1 -1
  133. package/fesm2022/c8y-ngx-components-ecosystem.mjs +336 -186
  134. package/fesm2022/c8y-ngx-components-ecosystem.mjs.map +1 -1
  135. package/fesm2022/c8y-ngx-components-operations-bulk-operation-scheduler.mjs +7 -5
  136. package/fesm2022/c8y-ngx-components-operations-bulk-operation-scheduler.mjs.map +1 -1
  137. package/fesm2022/c8y-ngx-components-operations-bulk-operations-list.mjs +1 -1
  138. package/fesm2022/c8y-ngx-components-operations-bulk-operations-list.mjs.map +1 -1
  139. package/fesm2022/c8y-ngx-components-upgrade.mjs +3 -1
  140. package/fesm2022/c8y-ngx-components-upgrade.mjs.map +1 -1
  141. package/fesm2022/c8y-ngx-components-widgets-cockpit-exports.mjs +7 -0
  142. package/fesm2022/c8y-ngx-components-widgets-cockpit-exports.mjs.map +1 -1
  143. package/fesm2022/c8y-ngx-components-widgets-cockpit.mjs +2 -0
  144. package/fesm2022/c8y-ngx-components-widgets-cockpit.mjs.map +1 -1
  145. package/fesm2022/c8y-ngx-components-widgets-definitions-radial-gauge.mjs +40 -0
  146. package/fesm2022/c8y-ngx-components-widgets-definitions-radial-gauge.mjs.map +1 -0
  147. package/fesm2022/c8y-ngx-components-widgets-definitions.mjs +1 -0
  148. package/fesm2022/c8y-ngx-components-widgets-definitions.mjs.map +1 -1
  149. package/fesm2022/c8y-ngx-components-widgets-implementations-info-gauge.mjs +991 -28
  150. package/fesm2022/c8y-ngx-components-widgets-implementations-info-gauge.mjs.map +1 -1
  151. package/fesm2022/c8y-ngx-components.mjs +833 -550
  152. package/fesm2022/c8y-ngx-components.mjs.map +1 -1
  153. package/locales/de.po +45 -6
  154. package/locales/es.po +45 -6
  155. package/locales/fr.po +45 -6
  156. package/locales/ja_JP.po +45 -6
  157. package/locales/ko.po +45 -6
  158. package/locales/locales.pot +73 -10
  159. package/locales/nl.po +45 -6
  160. package/locales/pl.po +45 -6
  161. package/locales/pt_BR.po +45 -6
  162. package/locales/zh_CN.po +45 -6
  163. package/locales/zh_TW.po +45 -6
  164. package/operations/bulk-operation-scheduler/operation-scheduler.component.d.ts +4 -2
  165. package/operations/bulk-operation-scheduler/operation-scheduler.component.d.ts.map +1 -1
  166. package/package.json +1 -1
  167. package/upgrade/ng1/downgraded.services.d.ts +1 -0
  168. package/upgrade/ng1/downgraded.services.d.ts.map +1 -1
  169. package/upgrade/ng1/index.d.ts.map +1 -1
  170. package/widgets/cockpit/index.d.ts +29 -0
  171. package/widgets/cockpit/index.d.ts.map +1 -1
  172. package/widgets/cockpit-exports/index.d.ts +6 -0
  173. package/widgets/cockpit-exports/index.d.ts.map +1 -1
  174. package/widgets/definitions/index.d.ts +1 -0
  175. package/widgets/definitions/index.d.ts.map +1 -1
  176. package/widgets/definitions/radial-gauge/c8y-ngx-components-widgets-definitions-radial-gauge.d.ts.map +1 -0
  177. package/widgets/definitions/radial-gauge/index.d.ts +33 -0
  178. package/widgets/definitions/radial-gauge/index.d.ts.map +1 -0
  179. package/widgets/implementations/info-gauge/index.d.ts +1 -1
  180. package/widgets/implementations/info-gauge/index.d.ts.map +1 -1
  181. package/widgets/implementations/info-gauge/info-gauge-widget-config/gauge.model.d.ts +339 -0
  182. package/widgets/implementations/info-gauge/info-gauge-widget-config/gauge.model.d.ts.map +1 -0
  183. package/widgets/implementations/info-gauge/info-gauge-widget-config/info-gauge-widget-config.component.d.ts +27 -7
  184. package/widgets/implementations/info-gauge/info-gauge-widget-config/info-gauge-widget-config.component.d.ts.map +1 -1
  185. package/widgets/implementations/info-gauge/info-gauge-widget-config/preset-preview/preset-preview.component.d.ts +33 -0
  186. package/widgets/implementations/info-gauge/info-gauge-widget-config/preset-preview/preset-preview.component.d.ts.map +1 -0
  187. package/widgets/implementations/info-gauge/info-gauge-widget-view/info-gauge-widget-view.component.d.ts +7 -3
  188. package/widgets/implementations/info-gauge/info-gauge-widget-view/info-gauge-widget-view.component.d.ts.map +1 -1
  189. package/widgets/implementations/info-gauge/info-gauge-widget.module.d.ts +2 -1
  190. package/widgets/implementations/info-gauge/info-gauge-widget.module.d.ts.map +1 -1
  191. package/widgets/implementations/info-gauge/radial-gauge/radial-gauge.component.d.ts +37 -0
  192. package/widgets/implementations/info-gauge/radial-gauge/radial-gauge.component.d.ts.map +1 -0
  193. package/widgets/implementations/info-gauge/radial-gauge/radial-gauge.service.d.ts +146 -0
  194. package/widgets/implementations/info-gauge/radial-gauge/radial-gauge.service.d.ts.map +1 -0
  195. package/esm2022/widgets/implementations/info-gauge/info-gauge.model.mjs +0 -2
  196. package/widgets/implementations/info-gauge/info-gauge.model.d.ts +0 -7
  197. 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"]}