@evergis/react 3.1.22 → 3.1.23

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/dist/index.js CHANGED
@@ -27,181 +27,180 @@ const AddFeatureButton = ({ title, icon = "feature_add" /* , layerName, geometry
27
27
  return (jsxRuntime.jsx(uilibGl.IconButton, { kind: icon, primary: true, onClick: handleAddFeature, children: title }));
28
28
  };
29
29
 
30
- const ChartTooltipTable = styled.table `
31
- td {
32
- padding: 0;
33
- }
34
-
35
- tr:not(:last-child) td {
36
- padding-bottom: 0.375rem;
37
- }
38
- `;
39
- const ChartTooltip = styled(uilibGl.Flex) `
40
- flex-wrap: nowrap;
41
- background: rgb(48, 69, 79);
42
- border-radius: 0.25rem;
43
- color: white;
44
-
45
- :not(:last-child) {
46
- margin-bottom: 0.25rem;
47
- }
48
- `;
49
- const ChartTooltipLabel = styled.div `
50
- margin-right: 0.25rem;
51
- `;
52
- const ChartTooltipColor = styled.div `
53
- width: 0.625rem;
54
- height: 0.625rem;
55
- background-color: ${({ $color }) => $color};
56
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.smallest};
57
- margin-right: 0.25rem;
58
- `;
59
- const ChartLegendColor$1 = styled.div `
60
- width: 0.5rem;
61
- height: 0.5rem;
62
- background-color: ${({ $color }) => $color};
63
- border-radius: 0.125rem;
64
- `;
65
- const ChartLegendValue = styled.div `
66
- opacity: 0.65;
67
- `;
68
- const ChartTooltipRow = styled(uilibGl.Flex) `
69
- display: flex;
70
- flex-direction: row;
71
- flex-wrap: nowrap;
72
- align-items: center;
73
- margin-top: 0.25rem;
74
- line-height: 0;
75
-
76
- ${ChartLegendColor$1} {
77
- margin-right: 0.25rem;
78
- }
79
- `;
80
- const ChartTooltipName = styled.div `
81
- margin-right: 1rem;
82
- opacity: 0.65;
83
- `;
84
- const PieChartCenter = styled.div `
85
- position: absolute;
86
- top: 50%;
87
- left: 50%;
88
- transform: translate(-50%, -50%);
89
- text-align: center;
90
- font-weight: bold;
91
- font-size: 1.5rem;
92
- `;
93
- const ChartWrapperContainer = styled.div `
94
- position: relative;
95
- width: 100%;
96
- `;
97
- const Tooltip = styled.div `
98
- position: relative;
99
- border-radius: 0.25rem;
100
- background-color: rgba(28, 33, 48);
101
- padding: 0.5rem;
102
- box-shadow: 0 0.125rem 0.25rem 0 rgba(0, 0, 0, 0.15);
103
- font-size: 0.75rem;
104
- transform: ${({ transform }) => transform};
105
- color: white;
106
-
107
- :before {
108
- position: absolute;
109
- display: block;
110
- content: "";
111
- width: 0;
112
- height: 0;
113
- }
114
- `;
115
- const LineChartStyles = styled.createGlobalStyle `
116
- .dashboardLineChartTooltip.${charts.lineChartClassNames.lineChartMouseLabel} {
117
- .${charts.lineChartClassNames.lineChartLabelFlex} {
118
- justify-content: center;
119
- align-items: flex-end;
120
-
121
- ${Tooltip} {
122
- margin: 0 0 12px 0;
123
-
124
- :before {
125
- top: auto;
126
- bottom: 0;
127
- left: 50%;
128
- transform: translate(-50%, 100%);
129
- border-left: 4px solid transparent;
130
- border-right: 4px solid transparent;
131
- border-top: 4px solid rgba(28, 33, 48, 0.9);
132
- }
133
- }
134
- }
135
- }
136
-
137
- .${charts.lineChartClassNames.lineChartYScaleGlobal}, .${charts.lineChartClassNames.lineChartXScaleGlobal} {
138
- .domain {
139
- visibility: hidden;
140
- }
141
-
142
- .tick {
143
- text {
144
- fill: ${({ theme: { palette } }) => palette.textDisabled};
145
- }
146
-
147
- line {
148
- visibility: hidden;
149
- }
150
- }
151
- }
152
-
153
- .${charts.lineChartClassNames.lineChartXScaleGlobal} {
154
- .tick {
155
- :first-of-type {
156
- text {
157
- text-anchor: start;
158
- }
159
- }
160
-
161
- :last-of-type {
162
- text {
163
- text-anchor: end;
164
- }
165
- }
166
- }
167
- }
168
-
169
- .${charts.lineChartClassNames.lineChartLine} {
170
- stroke-width: 2px;
171
- }
172
-
173
- .${charts.lineChartClassNames.lineChartLabel} {
174
- color: ${({ theme: { palette } }) => palette.textPrimary};
175
- }
176
-
177
- .${charts.lineChartClassNames.lineChartMouseCircle} {
178
- stroke: #ffffff;
179
- stroke-width: 2px;
180
- }
181
-
182
- .${charts.lineChartClassNames.lineChartGridLineX} {
183
- stroke: ${({ theme: { palette } }) => palette.element};
184
- }
185
-
186
- text {
187
- fill: ${({ theme: { palette } }) => palette.textDisabled};
188
- }
189
- `;
190
- const StyledBarChart = styled(charts.BarChart) `
191
- .domain,
192
- line {
193
- display: none;
194
- }
195
-
196
- .tick {
197
- text {
198
- fill: ${({ theme: { palette } }) => palette.textDisabled};
199
- }
200
-
201
- line {
202
- visibility: hidden;
203
- }
204
- }
30
+ const ChartTooltipTable = styled.table `
31
+ td {
32
+ padding: 0;
33
+ }
34
+
35
+ tr:not(:last-child) td {
36
+ padding-bottom: 0.375rem;
37
+ }
38
+ `;
39
+ const ChartTooltip = styled(uilibGl.Flex) `
40
+ flex-wrap: nowrap;
41
+ background: rgb(48, 69, 79);
42
+ border-radius: 0.25rem;
43
+ color: white;
44
+
45
+ :not(:last-child) {
46
+ margin-bottom: 0.25rem;
47
+ }
48
+ `;
49
+ const ChartTooltipLabel = styled.div `
50
+ margin-right: 0.25rem;
51
+ `;
52
+ const ChartTooltipColor = styled.div `
53
+ width: 0.625rem;
54
+ height: 0.625rem;
55
+ background-color: ${({ $color }) => $color};
56
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.smallest};
57
+ margin-right: 0.25rem;
58
+ `;
59
+ const ChartLegendColor$1 = styled.div `
60
+ width: 0.5rem;
61
+ height: 0.5rem;
62
+ background-color: ${({ $color }) => $color};
63
+ border-radius: 0.125rem;
64
+ `;
65
+ const ChartLegendValue = styled.div `
66
+ opacity: 0.65;
67
+ `;
68
+ const ChartTooltipRow = styled(uilibGl.Flex) `
69
+ display: flex;
70
+ flex-direction: row;
71
+ flex-wrap: nowrap;
72
+ align-items: center;
73
+ margin-top: 0.5rem;
74
+ line-height: 0;
75
+
76
+ ${ChartLegendColor$1} {
77
+ margin-right: 0.25rem;
78
+ }
79
+ `;
80
+ const ChartTooltipName = styled.div `
81
+ margin-right: 1rem;
82
+ opacity: 0.65;
83
+ `;
84
+ const PieChartCenter = styled.div `
85
+ position: absolute;
86
+ top: 50%;
87
+ left: 50%;
88
+ transform: translate(-50%, -50%);
89
+ text-align: center;
90
+ font-weight: bold;
91
+ font-size: 1.5rem;
92
+ `;
93
+ const ChartWrapperContainer = styled.div `
94
+ position: relative;
95
+ width: 100%;
96
+ `;
97
+ const Tooltip = styled.div `
98
+ position: relative;
99
+ border-radius: 0.25rem;
100
+ background-color: rgba(28, 33, 48);
101
+ padding: 0.5rem;
102
+ box-shadow: 0 0.125rem 0.25rem 0 rgba(0, 0, 0, 0.15);
103
+ font-size: 0.75rem;
104
+ transform: ${({ transform }) => transform};
105
+ color: white;
106
+
107
+ :before {
108
+ position: absolute;
109
+ display: block;
110
+ content: "";
111
+ width: 0;
112
+ height: 0;
113
+ }
114
+ `;
115
+ const LineChartStyles = styled.createGlobalStyle `
116
+ .dashboardLineChartTooltip.${charts.lineChartClassNames.lineChartMouseLabel} {
117
+ .${charts.lineChartClassNames.lineChartLabelFlex} {
118
+ justify-content: center;
119
+ align-items: flex-end;
120
+
121
+ ${Tooltip} {
122
+ margin: 0 0 12px 0;
123
+
124
+ :before {
125
+ top: auto;
126
+ bottom: 0;
127
+ left: 50%;
128
+ transform: translate(-50%, 100%);
129
+ border-left: 4px solid transparent;
130
+ border-right: 4px solid transparent;
131
+ border-top: 4px solid rgba(28, 33, 48, 0.9);
132
+ }
133
+ }
134
+ }
135
+ }
136
+
137
+ .${charts.lineChartClassNames.lineChartYScaleGlobal}, .${charts.lineChartClassNames.lineChartXScaleGlobal} {
138
+ .domain {
139
+ visibility: hidden;
140
+ }
141
+
142
+ .tick {
143
+ text {
144
+ fill: ${({ theme: { palette } }) => palette.textDisabled};
145
+ }
146
+
147
+ line {
148
+ visibility: hidden;
149
+ }
150
+ }
151
+ }
152
+
153
+ .${charts.lineChartClassNames.lineChartXScaleGlobal} {
154
+ .tick {
155
+ :first-of-type {
156
+ text {
157
+ text-anchor: start;
158
+ }
159
+ }
160
+
161
+ :last-of-type {
162
+ text {
163
+ text-anchor: end;
164
+ }
165
+ }
166
+ }
167
+ }
168
+
169
+ .${charts.lineChartClassNames.lineChartLine} {
170
+ stroke-width: 2px;
171
+ }
172
+
173
+ .${charts.lineChartClassNames.lineChartLabel} {
174
+ color: ${({ theme: { palette } }) => palette.textPrimary};
175
+ }
176
+
177
+ .${charts.lineChartClassNames.lineChartMouseCircle} {
178
+ stroke: #ffffff;
179
+ stroke-width: 2px;
180
+ }
181
+
182
+ .${charts.lineChartClassNames.lineChartGridLineX} {
183
+ stroke: ${({ theme: { palette } }) => palette.element};
184
+ }
185
+
186
+ text {
187
+ fill: ${({ theme: { palette } }) => palette.textDisabled};
188
+ }
189
+ `;
190
+ const StyledBarChart = styled(charts.BarChart) `
191
+ .domain {
192
+ display: none;
193
+ }
194
+
195
+ .tick {
196
+ text {
197
+ fill: ${({ theme: { palette } }) => palette.textDisabled};
198
+ }
199
+
200
+ line {
201
+ visibility: hidden;
202
+ }
203
+ }
205
204
  `;
206
205
 
207
206
  function range(start, stop, step) {
@@ -3429,42 +3428,42 @@ const NUMERIC_ATTRIBUTE_TYPES = [api.AttributeType.Double, api.AttributeType.Int
3429
3428
  const GEOMETRY_ATTRIBUTE = "geometry";
3430
3429
  const DEFAULT_ID_ATTRIBUTE_NAME = "gid";
3431
3430
 
3432
- const StackBarContainer = styled(uilibGl.Flex) `
3433
- flex-wrap: nowrap;
3434
- width: 100%;
3435
- `;
3436
- const StackBarHeader = styled(uilibGl.Flex) `
3437
- justify-content: space-between;
3438
- margin-bottom: 0.375rem;
3439
- font-size: 0.75rem;
3440
- `;
3441
- const StackBarSection = styled.div `
3442
- cursor: ${({ onClick }) => (onClick ? "pointer" : "default")};
3443
- width: ${({ $width }) => $width}%;
3444
- height: ${({ $height }) => ($height ? `${$height}px` : "0.5rem")};
3445
- margin: 0 0.5px;
3446
- background-color: ${({ $color }) => $color};
3447
- opacity: ${({ hasAnyFilter, isFiltered }) => (isFiltered ? 1 : hasAnyFilter ? FILTERED_VALUE_OPACITY / 100 : 1)};
3448
- transition: opacity ${uilibGl.transition.release};
3449
-
3450
- :first-child {
3451
- border-top-left-radius: ${({ cornerRadius }) => (cornerRadius ? `${cornerRadius}px` : "0.5rem")};
3452
- border-bottom-left-radius: ${({ cornerRadius }) => (cornerRadius ? `${cornerRadius}px` : "0.5rem")};
3453
- }
3454
-
3455
- :last-child {
3456
- border-top-right-radius: ${({ cornerRadius }) => (cornerRadius ? `${cornerRadius}px` : "0.5rem")};
3457
- border-bottom-right-radius: ${({ cornerRadius }) => (cornerRadius ? `${cornerRadius}px` : "0.5rem")};
3458
- }
3459
- `;
3460
- const StackBarAlias = styled.div `
3461
- color: ${({ theme: { palette } }) => palette.textSecondary};
3431
+ const StackBarContainer = styled(uilibGl.Flex) `
3432
+ flex-wrap: nowrap;
3433
+ width: 100%;
3434
+ `;
3435
+ const StackBarHeader = styled(uilibGl.Flex) `
3436
+ justify-content: space-between;
3437
+ margin-bottom: 0.375rem;
3438
+ font-size: 0.75rem;
3439
+ `;
3440
+ const StackBarSection = styled.div `
3441
+ cursor: ${({ onClick }) => (onClick ? "pointer" : "default")};
3442
+ width: ${({ $width }) => $width}%;
3443
+ height: ${({ $height }) => ($height ? `${$height}px` : "0.5rem")};
3444
+ margin: 0 0.5px;
3445
+ background-color: ${({ $color }) => $color};
3446
+ opacity: ${({ hasAnyFilter, isFiltered }) => (isFiltered ? 1 : hasAnyFilter ? FILTERED_VALUE_OPACITY / 100 : 1)};
3447
+ transition: opacity ${uilibGl.transition.release};
3448
+
3449
+ :first-child {
3450
+ border-top-left-radius: ${({ cornerRadius }) => (cornerRadius ? `${cornerRadius}px` : "0.5rem")};
3451
+ border-bottom-left-radius: ${({ cornerRadius }) => (cornerRadius ? `${cornerRadius}px` : "0.5rem")};
3452
+ }
3453
+
3454
+ :last-child {
3455
+ border-top-right-radius: ${({ cornerRadius }) => (cornerRadius ? `${cornerRadius}px` : "0.5rem")};
3456
+ border-bottom-right-radius: ${({ cornerRadius }) => (cornerRadius ? `${cornerRadius}px` : "0.5rem")};
3457
+ }
3458
+ `;
3459
+ const StackBarAlias = styled.div `
3460
+ color: ${({ theme: { palette } }) => palette.textSecondary};
3462
3461
  `;
3463
3462
  const StackBarTotal = styled(uilibGl.Flex) ``;
3464
3463
  const StackBarValue = styled.div ``;
3465
- const StackBarUnits = styled.div `
3466
- margin-left: 0.25rem;
3467
- color: ${({ theme: { palette } }) => palette.textSecondary};
3464
+ const StackBarUnits = styled.div `
3465
+ margin-left: 0.25rem;
3466
+ color: ${({ theme: { palette } }) => palette.textSecondary};
3468
3467
  `;
3469
3468
 
3470
3469
  const transparentizeColor = (originalColor, percent) => {
@@ -4004,7 +4003,7 @@ function wrap() {
4004
4003
  textLength = self.node().getComputedTextLength();
4005
4004
  }
4006
4005
  }
4007
- const useChartChange = ({ dataSources, chartId, width, height, relatedAttributes, defaultColor, fontColor, showMarkers, }) => {
4006
+ const useChartChange = ({ dataSources, chartId, width, height, relatedAttributes, defaultColor, fontColor, markers, showMarkers, }) => {
4008
4007
  const { t } = useGlobalContext();
4009
4008
  const { layerInfos } = useWidgetContext();
4010
4009
  const strokeColors = relatedAttributes.filter(({ chartAxis }) => chartAxis === "y").map(({ axisColor }) => axisColor);
@@ -4028,8 +4027,8 @@ const useChartChange = ({ dataSources, chartId, width, height, relatedAttributes
4028
4027
  const customize = React.useCallback(({ svg }) => {
4029
4028
  svg.style("overflow", "visible");
4030
4029
  svg
4031
- .selectAll(`.${charts.lineChartClassNames.lineChartXScaleGlobal} line,
4032
- .${charts.lineChartClassNames.lineChartYScaleGlobal} line,
4030
+ .selectAll(`.${charts.lineChartClassNames.lineChartXScaleGlobal} line,
4031
+ .${charts.lineChartClassNames.lineChartYScaleGlobal} line,
4033
4032
  .domain`)
4034
4033
  .each((_, index, nodes) => {
4035
4034
  nodes[index].remove();
@@ -4041,8 +4040,11 @@ const useChartChange = ({ dataSources, chartId, width, height, relatedAttributes
4041
4040
  if (index === nodes.length - 1) {
4042
4041
  nodes[index].style.textAnchor = "end";
4043
4042
  }
4043
+ if (markers) {
4044
+ nodes[index].remove();
4045
+ }
4044
4046
  if (showMarkers) {
4045
- if (index % (showMarkers || 1) !== 0) {
4047
+ if (index % showMarkers !== 0) {
4046
4048
  nodes[index].remove();
4047
4049
  }
4048
4050
  }
@@ -4083,11 +4085,11 @@ const useChartChange = ({ dataSources, chartId, width, height, relatedAttributes
4083
4085
  .attr("fill", `url(#${gradientId})`)
4084
4086
  .attr("stroke-width", "0")
4085
4087
  .attr("fill-opacity", FILL_OPACITY);
4086
- defs.push(`
4087
- <linearGradient id="${gradientId}" x1="0" y1="0" x2="0" y2="1">
4088
- <stop offset="0" stop-color="${color}" stop-opacity="1" />
4089
- <stop offset="1" stop-color="${color}" stop-opacity="0" />
4090
- </linearGradient>
4088
+ defs.push(`
4089
+ <linearGradient id="${gradientId}" x1="0" y1="0" x2="0" y2="1">
4090
+ <stop offset="0" stop-color="${color}" stop-opacity="1" />
4091
+ <stop offset="1" stop-color="${color}" stop-opacity="0" />
4092
+ </linearGradient>
4091
4093
  `);
4092
4094
  ref.current = {
4093
4095
  path: newPath,
@@ -4097,7 +4099,7 @@ const useChartChange = ({ dataSources, chartId, width, height, relatedAttributes
4097
4099
  onChange();
4098
4100
  });
4099
4101
  svg.append("defs").html(() => defs.join(""));
4100
- }, [fontColor, dataSources, layerInfos, relatedAttributes, chartId, strokeColors, defaultColor, width, onChange, showMarkers]);
4102
+ }, [fontColor, dataSources, layerInfos, relatedAttributes, chartId, strokeColors, defaultColor, width, onChange, showMarkers, markers]);
4101
4103
  return [customize, onChange];
4102
4104
  };
4103
4105
 
@@ -4436,247 +4438,247 @@ const formatDataSourceCondition = ({ condition, configFilters, filters, attribut
4436
4438
  : conditionSection.join(splitter);
4437
4439
  };
4438
4440
 
4439
- const DashboardChipsContainer = styled(uilibGl.Flex) `
4440
- flex-wrap: wrap;
4441
- `;
4442
- const DashboardChip$1 = styled(uilibGl.Chip) `
4443
- margin: 0 0.25rem 0.25rem 0;
4444
- background: ${({ $isDefault, $bgColor, theme: { palette } }) => $isDefault ? palette.element : $bgColor || palette.primary};
4445
- border-radius: ${({ $radius, theme: { borderRadius } }) => $radius || borderRadius.medium};
4446
- white-space: nowrap;
4447
- font-size: ${({ $fontSize }) => $fontSize || "0.875rem"};
4448
- color: ${({ $isDefault, $fontColor, theme: { palette } }) => $isDefault ? palette.textPrimary : $fontColor || "#fff"};
4449
-
4450
- > * {
4451
- font-size: ${({ $fontSize }) => $fontSize || "0.875rem"};
4452
- color: ${({ $isDefault, $fontColor, theme: { palette } }) => $isDefault ? palette.textPrimary : $fontColor || "#fff"};
4453
- }
4454
-
4455
- span[kind] {
4456
- height: 0.875rem;
4457
-
4458
- :after {
4459
- color: ${({ $isDefault, $fontColor, theme: { palette } }) => ($isDefault ? palette.icon : $fontColor || "#fff")};
4460
- font-size: 0.875rem;
4461
- }
4462
- }
4463
-
4464
- button {
4465
- width: auto;
4466
- padding: 0 0.5rem;
4467
- }
4468
- `;
4469
-
4470
- const ChartLegendContainer = styled(uilibGl.Flex) `
4471
- flex-direction: column;
4472
- flex-wrap: wrap;
4473
- justify-content: ${({ twoColumns }) => (twoColumns ? "flex-start" : "center")};
4474
- `;
4475
- const ChartLegendItem = styled(uilibGl.Flex) `
4476
- cursor: ${({ onClick }) => (onClick ? "pointer" : "default")};
4477
- align-items: center;
4478
- flex-wrap: nowrap;
4479
- width: auto;
4480
- margin-right: 0.375rem;
4481
- margin-bottom: 0.25rem;
4482
- opacity: ${({ isFiltered, hasAnyFilter }) => (isFiltered ? 1 : hasAnyFilter ? FILTERED_VALUE_OPACITY / 100 : 1)};
4483
- `;
4484
- const ChartLegendColor = styled.div `
4485
- width: 0.5rem;
4486
- height: 0.5rem;
4487
- margin-right: 0.375rem;
4488
- background-color: ${({ color }) => color};
4489
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.tiny};
4490
- `;
4491
- const ChartLegendName = styled.div `
4492
- flex: 1;
4493
- font-size: 0.625rem;
4494
- color: ${({ theme: { palette }, $fontColor }) => $fontColor || palette.textPrimary};
4495
- `;
4496
-
4497
- const Container = styled(uilibGl.Flex) `
4498
- flex-direction: column;
4499
- width: 100%;
4500
-
4441
+ const DashboardChipsContainer = styled(uilibGl.Flex) `
4442
+ flex-wrap: wrap;
4443
+ `;
4444
+ const DashboardChip$1 = styled(uilibGl.Chip) `
4445
+ margin: 0 0.25rem 0.25rem 0;
4446
+ background: ${({ $isDefault, $bgColor, theme: { palette } }) => $isDefault ? palette.element : $bgColor || palette.primary};
4447
+ border-radius: ${({ $radius, theme: { borderRadius } }) => $radius || borderRadius.medium};
4448
+ white-space: nowrap;
4449
+ font-size: ${({ $fontSize }) => $fontSize || "0.875rem"};
4450
+ color: ${({ $isDefault, $fontColor, theme: { palette } }) => $isDefault ? palette.textPrimary : $fontColor || "#fff"};
4451
+
4452
+ > * {
4453
+ font-size: ${({ $fontSize }) => $fontSize || "0.875rem"};
4454
+ color: ${({ $isDefault, $fontColor, theme: { palette } }) => $isDefault ? palette.textPrimary : $fontColor || "#fff"};
4455
+ }
4456
+
4457
+ span[kind] {
4458
+ height: 0.875rem;
4459
+
4460
+ :after {
4461
+ color: ${({ $isDefault, $fontColor, theme: { palette } }) => ($isDefault ? palette.icon : $fontColor || "#fff")};
4462
+ font-size: 0.875rem;
4463
+ }
4464
+ }
4465
+
4466
+ button {
4467
+ width: auto;
4468
+ padding: 0 0.5rem;
4469
+ }
4470
+ `;
4471
+
4472
+ const ChartLegendContainer = styled(uilibGl.Flex) `
4473
+ flex-direction: column;
4474
+ flex-wrap: wrap;
4475
+ justify-content: ${({ twoColumns }) => (twoColumns ? "flex-start" : "center")};
4476
+ `;
4477
+ const ChartLegendItem = styled(uilibGl.Flex) `
4478
+ cursor: ${({ onClick }) => (onClick ? "pointer" : "default")};
4479
+ align-items: center;
4480
+ flex-wrap: nowrap;
4481
+ width: auto;
4482
+ margin-right: 0.375rem;
4483
+ margin-bottom: 0.25rem;
4484
+ opacity: ${({ isFiltered, hasAnyFilter }) => (isFiltered ? 1 : hasAnyFilter ? FILTERED_VALUE_OPACITY / 100 : 1)};
4485
+ `;
4486
+ const ChartLegendColor = styled.div `
4487
+ width: 0.5rem;
4488
+ height: 0.5rem;
4489
+ margin-right: 0.375rem;
4490
+ background-color: ${({ color }) => color};
4491
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.tiny};
4492
+ `;
4493
+ const ChartLegendName = styled.div `
4494
+ flex: 1;
4495
+ font-size: 0.625rem;
4496
+ color: ${({ theme: { palette }, $fontColor }) => $fontColor || palette.textPrimary};
4497
+ `;
4498
+
4499
+ const Container = styled(uilibGl.Flex) `
4500
+ flex-direction: column;
4501
+ width: 100%;
4502
+
4501
4503
  ${({ isColumn }) => isColumn
4502
- ? styled.css `
4503
- > * {
4504
- width: 100%;
4505
- }
4504
+ ? styled.css `
4505
+ > * {
4506
+ width: 100%;
4507
+ }
4506
4508
  `
4507
- : styled.css `
4508
- flex-direction: row;
4509
- justify-content: space-between;
4510
- align-items: center;
4511
- `}
4512
-
4509
+ : styled.css `
4510
+ flex-direction: row;
4511
+ justify-content: space-between;
4512
+ align-items: center;
4513
+ `}
4514
+
4513
4515
  ${({ isMain, isColumn }) => (isMain || isColumn) &&
4514
- styled.css `
4515
- > :not(:last-child) {
4516
- margin-bottom: 0.5rem;
4517
- }
4518
- `}
4519
-
4516
+ styled.css `
4517
+ > :not(:last-child) {
4518
+ margin-bottom: 0.5rem;
4519
+ }
4520
+ `}
4521
+
4520
4522
  ${({ isTitle }) => isTitle &&
4521
- styled.css `
4522
- &&&& {
4523
- margin-bottom: 0.75rem;
4524
- }
4525
- `}
4526
- `;
4527
- const ContainerAlias = styled(uilibGl.Flex) `
4528
- align-items: center;
4529
- flex-wrap: nowrap;
4530
- margin-bottom: ${({ hasBottomMargin }) => (hasBottomMargin ? 0.25 : 0)}rem;
4531
- font-size: 0.75rem;
4532
- color: ${({ theme: { palette } }) => palette.textSecondary};
4533
-
4534
- span[kind] {
4535
- margin-right: 0.5rem;
4536
-
4537
- :after {
4538
- color: ${({ theme: { palette } }) => palette.primary};
4539
- }
4540
- }
4541
- `;
4542
- const ContainerAliasIcon = styled.div `
4543
- margin-right: 0.5rem;
4544
- `;
4545
- const ContainerChart = styled(uilibGl.Flex) `
4546
- justify-content: flex-start;
4547
-
4548
- > * {
4549
- display: flex;
4550
- justify-content: center;
4551
- width: 100%;
4552
- }
4523
+ styled.css `
4524
+ &&&& {
4525
+ margin-bottom: 0.75rem;
4526
+ }
4527
+ `}
4528
+ `;
4529
+ const ContainerAlias = styled(uilibGl.Flex) `
4530
+ align-items: center;
4531
+ flex-wrap: nowrap;
4532
+ margin-bottom: ${({ hasBottomMargin }) => (hasBottomMargin ? 0.25 : 0)}rem;
4533
+ font-size: 0.75rem;
4534
+ color: ${({ theme: { palette } }) => palette.textSecondary};
4535
+
4536
+ span[kind] {
4537
+ margin-right: 0.5rem;
4538
+
4539
+ :after {
4540
+ color: ${({ theme: { palette } }) => palette.primary};
4541
+ }
4542
+ }
4543
+ `;
4544
+ const ContainerAliasIcon = styled.div `
4545
+ margin-right: 0.5rem;
4546
+ `;
4547
+ const ContainerChart = styled(uilibGl.Flex) `
4548
+ justify-content: flex-start;
4549
+
4550
+ > * {
4551
+ display: flex;
4552
+ justify-content: center;
4553
+ width: 100%;
4554
+ }
4553
4555
  `;
4554
4556
  const ContainerLegend = styled(uilibGl.Flex) ``;
4555
- const ContainerUnits = styled.div `
4556
- margin-left: 0.5rem;
4557
- white-space: nowrap;
4558
- font-size: 0.75rem;
4559
- `;
4560
- const ContainerValue = styled(uilibGl.Flex) `
4561
- justify-content: flex-end;
4562
- align-items: center;
4563
- flex-wrap: nowrap;
4564
- width: 100%;
4565
- font-size: ${({ big }) => (big ? 1.5 : 1)}rem;
4566
- color: ${({ fontColor, theme: { palette } }) => fontColor || palette.textPrimary};
4567
-
4568
- > * {
4569
- width: ${({ column }) => (column ? "100%" : "auto")};
4570
- }
4571
-
4572
- ${ContainerChart}, ${ContainerLegend} {
4573
- width: ${({ column }) => (column ? "100%" : "50%")};
4574
- }
4575
-
4576
- ${ContainerLegend} {
4577
- margin-left: ${({ column }) => (column ? 0 : "1rem")};
4578
- }
4579
-
4580
- ${ChartLegendContainer} {
4581
- flex-direction: ${({ column }) => (column ? "row" : "column")};
4582
- margin-top: ${({ column }) => (column ? "1rem" : 0)};
4583
- }
4584
- `;
4585
- const ColorIconMixin = styled.css `
4586
- :after {
4587
- color: ${({ $fontColor }) => $fontColor} !important;
4588
- }
4589
- `;
4590
- const SizeIconMixin = styled.css `
4591
- :after {
4592
- font-size: ${({ $fontSize }) => $fontSize}px !important;
4593
- }
4594
- `;
4595
- const ContainerIcon = styled(uilibGl.Icon) `
4596
- width: auto;
4597
- height: auto;
4598
- margin-bottom: 0.5rem;
4599
- ${({ $fontColor }) => !!$fontColor && ColorIconMixin};
4600
- ${({ $fontSize }) => !!$fontSize && SizeIconMixin};
4601
- `;
4602
- const SvgContainerColorMixin$1 = styled.css `
4603
- path,
4604
- line,
4605
- circle {
4606
- fill: ${({ $fontColor }) => $fontColor};
4607
- }
4608
- `;
4609
- const SvgContainer$1 = styled.div `
4610
- &&& {
4611
- min-width: ${({ $width }) => ($width ? `${$width}px` : "1rem")};
4612
- max-width: ${({ $width }) => ($width ? `${$width}px` : "1rem")};
4613
-
4614
- ${({ $fontColor }) => !!$fontColor && SvgContainerColorMixin$1};
4615
-
4616
- > * {
4617
- min-width: inherit;
4618
- }
4619
- }
4620
- `;
4621
- const TwoColumnContainerWrapper = styled(uilibGl.Flex) `
4622
- width: 100%;
4623
- flex-direction: row;
4624
- flex-wrap: nowrap;
4625
- align-items: center;
4626
-
4627
- > * {
4628
- flex: 1;
4629
- }
4630
-
4631
- > ${ContainerValue} {
4632
- justify-content: flex-end;
4633
-
4634
- > * {
4635
- text-align: right;
4636
- }
4637
- }
4638
- `;
4639
-
4640
- const LayerGroupContainer = styled(uilibGl.Flex) `
4641
- display: flex;
4642
- justify-content: center;
4643
- position: relative;
4644
- flex-direction: column;
4645
- padding: 0 0.25rem 0 1rem;
4646
- box-sizing: border-box;
4647
- transition: opacity ${uilibGl.transition.hover}, background-color ${uilibGl.transition.hover};
4648
- font-family: "NunitoSans", sans-serif;
4649
- `;
4650
- const LayerGroupMain = styled(uilibGl.Flex) `
4651
- flex-direction: row;
4652
- flex-wrap: nowrap;
4653
- align-items: center;
4654
- justify-content: space-between;
4655
- width: 100%;
4656
-
4657
- ${uilibGl.Icon} {
4658
- width: 2rem;
4659
- min-width: 2rem;
4660
- height: 2rem;
4661
- display: inline-flex;
4662
- align-items: center;
4663
- justify-content: center;
4664
- margin-right: 0.75rem;
4665
- }
4666
-
4667
- ${uilibGl.Description} {
4668
- display: flex;
4669
- align-items: center;
4670
- flex-grow: 1;
4671
- width: 100%;
4672
- margin-right: 0.25rem;
4673
- color: ${({ theme }) => theme.palette.textPrimary};
4674
- }
4675
-
4676
- button {
4677
- width: 2.25rem;
4678
- justify-content: flex-start;
4679
- }
4557
+ const ContainerUnits = styled.div `
4558
+ margin-left: 0.5rem;
4559
+ white-space: nowrap;
4560
+ font-size: 0.75rem;
4561
+ `;
4562
+ const ContainerValue = styled(uilibGl.Flex) `
4563
+ justify-content: flex-end;
4564
+ align-items: center;
4565
+ flex-wrap: nowrap;
4566
+ width: 100%;
4567
+ font-size: ${({ big }) => (big ? 1.5 : 1)}rem;
4568
+ color: ${({ fontColor, theme: { palette } }) => fontColor || palette.textPrimary};
4569
+
4570
+ > * {
4571
+ width: ${({ column }) => (column ? "100%" : "auto")};
4572
+ }
4573
+
4574
+ ${ContainerChart}, ${ContainerLegend} {
4575
+ width: ${({ column }) => (column ? "100%" : "50%")};
4576
+ }
4577
+
4578
+ ${ContainerLegend} {
4579
+ margin-left: ${({ column }) => (column ? 0 : "1rem")};
4580
+ }
4581
+
4582
+ ${ChartLegendContainer} {
4583
+ flex-direction: ${({ column }) => (column ? "row" : "column")};
4584
+ margin-top: ${({ column }) => (column ? "1rem" : 0)};
4585
+ }
4586
+ `;
4587
+ const ColorIconMixin = styled.css `
4588
+ :after {
4589
+ color: ${({ $fontColor }) => $fontColor} !important;
4590
+ }
4591
+ `;
4592
+ const SizeIconMixin = styled.css `
4593
+ :after {
4594
+ font-size: ${({ $fontSize }) => $fontSize}px !important;
4595
+ }
4596
+ `;
4597
+ const ContainerIcon = styled(uilibGl.Icon) `
4598
+ width: auto;
4599
+ height: auto;
4600
+ margin-bottom: 0.5rem;
4601
+ ${({ $fontColor }) => !!$fontColor && ColorIconMixin};
4602
+ ${({ $fontSize }) => !!$fontSize && SizeIconMixin};
4603
+ `;
4604
+ const SvgContainerColorMixin$1 = styled.css `
4605
+ path,
4606
+ line,
4607
+ circle {
4608
+ fill: ${({ $fontColor }) => $fontColor};
4609
+ }
4610
+ `;
4611
+ const SvgContainer$1 = styled.div `
4612
+ &&& {
4613
+ min-width: ${({ $width }) => ($width ? `${$width}px` : "1rem")};
4614
+ max-width: ${({ $width }) => ($width ? `${$width}px` : "1rem")};
4615
+
4616
+ ${({ $fontColor }) => !!$fontColor && SvgContainerColorMixin$1};
4617
+
4618
+ > * {
4619
+ min-width: inherit;
4620
+ }
4621
+ }
4622
+ `;
4623
+ const TwoColumnContainerWrapper = styled(uilibGl.Flex) `
4624
+ width: 100%;
4625
+ flex-direction: row;
4626
+ flex-wrap: nowrap;
4627
+ align-items: center;
4628
+
4629
+ > * {
4630
+ flex: 1;
4631
+ }
4632
+
4633
+ > ${ContainerValue} {
4634
+ justify-content: flex-end;
4635
+
4636
+ > * {
4637
+ text-align: right;
4638
+ }
4639
+ }
4640
+ `;
4641
+
4642
+ const LayerGroupContainer = styled(uilibGl.Flex) `
4643
+ display: flex;
4644
+ justify-content: center;
4645
+ position: relative;
4646
+ flex-direction: column;
4647
+ padding: 0 0.25rem 0 1rem;
4648
+ box-sizing: border-box;
4649
+ transition: opacity ${uilibGl.transition.hover}, background-color ${uilibGl.transition.hover};
4650
+ font-family: "NunitoSans", sans-serif;
4651
+ `;
4652
+ const LayerGroupMain = styled(uilibGl.Flex) `
4653
+ flex-direction: row;
4654
+ flex-wrap: nowrap;
4655
+ align-items: center;
4656
+ justify-content: space-between;
4657
+ width: 100%;
4658
+
4659
+ ${uilibGl.Icon} {
4660
+ width: 2rem;
4661
+ min-width: 2rem;
4662
+ height: 2rem;
4663
+ display: inline-flex;
4664
+ align-items: center;
4665
+ justify-content: center;
4666
+ margin-right: 0.75rem;
4667
+ }
4668
+
4669
+ ${uilibGl.Description} {
4670
+ display: flex;
4671
+ align-items: center;
4672
+ flex-grow: 1;
4673
+ width: 100%;
4674
+ margin-right: 0.25rem;
4675
+ color: ${({ theme }) => theme.palette.textPrimary};
4676
+ }
4677
+
4678
+ button {
4679
+ width: 2.25rem;
4680
+ justify-content: flex-start;
4681
+ }
4680
4682
  `;
4681
4683
 
4682
4684
  const customModes = MapboxDraw.modes;
@@ -5067,286 +5069,286 @@ const LayerTree = ({ layers, onlyMainTools }) => {
5067
5069
  return (jsxRuntime.jsx(uilibGl.DraggableTree, { nodes: nodes, disableDrag: onlyMainTools, options: { pastePlaceholderHeight: "0.0625rem" }, onUpdate: onUpdate }));
5068
5070
  };
5069
5071
 
5070
- const LayersListWrapper = styled(uilibGl.Flex) `
5071
- flex-direction: column;
5072
- height: 100%;
5073
- width: 100%;
5074
- box-sizing: border-box;
5075
- `;
5076
- const LayerListContainer = styled(uilibGl.Flex) `
5077
- flex-grow: 1;
5078
- height: 100%;
5079
- box-sizing: border-box;
5080
- `;
5081
-
5082
- const ElementValueWrapper = styled.div `
5083
- transition: background-color ${uilibGl.transition.toggle};
5084
- `;
5085
- const ContainerWrapper = styled(uilibGl.Flex) `
5086
- position: relative;
5087
- min-height: 1rem;
5088
- box-sizing: border-box;
5089
- width: 100%;
5090
- background: ${({ theme: { palette } }) => palette.backgroundAlpha};
5091
- box-shadow: rgb(0 0 0 / 15%) 0 0.1875rem 0.625rem;
5092
- padding: 1.5rem;
5093
- border-radius: 0.5rem;
5094
- backdrop-filter: blur(20px);
5095
- color: ${({ theme: { palette } }) => palette.textPrimary};
5096
- z-index: ${({ $zIndex }) => $zIndex ?? 1};
5097
- transition: background-color ${uilibGl.transition.toggle};
5098
-
5099
- ${Container} > ${ElementValueWrapper}:not(:last-child) {
5100
- margin-bottom: 1.5rem;
5101
- }
5102
- `;
5103
- const DashboardChip = styled(uilibGl.Chip) `
5104
- margin: 0 0.25rem 0.25rem 0;
5105
- background: ${({ $isDefault, $bgColor, theme: { palette } }) => $isDefault ? palette.element : $bgColor || palette.primary};
5106
- border-radius: ${({ $radius, theme: { borderRadius } }) => $radius || borderRadius.medium};
5107
- font-size: ${({ $fontSize }) => $fontSize || "0.875rem"};
5108
- color: ${({ $isDefault, $fontColor, theme: { palette } }) => $isDefault ? palette.textPrimary : $fontColor || "#fff"};
5109
-
5110
- > * {
5111
- font-size: ${({ $fontSize }) => $fontSize || "0.875rem"};
5112
- color: ${({ $isDefault, $fontColor, theme: { palette } }) => $isDefault ? palette.textPrimary : $fontColor || "#fff"};
5113
- }
5114
-
5115
- span[kind]:after {
5116
- color: ${({ $isDefault, $fontColor, theme: { palette } }) => ($isDefault ? palette.icon : $fontColor || "#fff")};
5117
- }
5118
- `;
5119
- const DashboardPlaceholderWrap = styled(uilibGl.Flex) `
5120
- flex-grow: 1;
5121
- flex-direction: column;
5122
- justify-content: center;
5123
- align-items: center;
5124
- width: 100%;
5125
- margin-bottom: 2rem;
5126
- `;
5127
- const DashboardPlaceholder = styled(uilibGl.Flex) `
5128
- flex-direction: column;
5129
- justify-content: center;
5130
- align-items: center;
5131
- margin-top: 2rem;
5132
-
5072
+ const LayersListWrapper = styled(uilibGl.Flex) `
5073
+ flex-direction: column;
5074
+ height: 100%;
5075
+ width: 100%;
5076
+ box-sizing: border-box;
5077
+ `;
5078
+ const LayerListContainer = styled(uilibGl.Flex) `
5079
+ flex-grow: 1;
5080
+ height: 100%;
5081
+ box-sizing: border-box;
5082
+ `;
5083
+
5084
+ const ElementValueWrapper = styled.div `
5085
+ transition: background-color ${uilibGl.transition.toggle};
5086
+ `;
5087
+ const ContainerWrapper = styled(uilibGl.Flex) `
5088
+ position: relative;
5089
+ min-height: 1rem;
5090
+ box-sizing: border-box;
5091
+ width: 100%;
5092
+ background: ${({ theme: { palette } }) => palette.backgroundAlpha};
5093
+ box-shadow: rgb(0 0 0 / 15%) 0 0.1875rem 0.625rem;
5094
+ padding: 1.5rem;
5095
+ border-radius: 0.5rem;
5096
+ backdrop-filter: blur(20px);
5097
+ color: ${({ theme: { palette } }) => palette.textPrimary};
5098
+ z-index: ${({ $zIndex }) => $zIndex ?? 1};
5099
+ transition: background-color ${uilibGl.transition.toggle};
5100
+
5101
+ ${Container} > ${ElementValueWrapper}:not(:last-child) {
5102
+ margin-bottom: 1.5rem;
5103
+ }
5104
+ `;
5105
+ const DashboardChip = styled(uilibGl.Chip) `
5106
+ margin: 0 0.25rem 0.25rem 0;
5107
+ background: ${({ $isDefault, $bgColor, theme: { palette } }) => $isDefault ? palette.element : $bgColor || palette.primary};
5108
+ border-radius: ${({ $radius, theme: { borderRadius } }) => $radius || borderRadius.medium};
5109
+ font-size: ${({ $fontSize }) => $fontSize || "0.875rem"};
5110
+ color: ${({ $isDefault, $fontColor, theme: { palette } }) => $isDefault ? palette.textPrimary : $fontColor || "#fff"};
5111
+
5112
+ > * {
5113
+ font-size: ${({ $fontSize }) => $fontSize || "0.875rem"};
5114
+ color: ${({ $isDefault, $fontColor, theme: { palette } }) => $isDefault ? palette.textPrimary : $fontColor || "#fff"};
5115
+ }
5116
+
5117
+ span[kind]:after {
5118
+ color: ${({ $isDefault, $fontColor, theme: { palette } }) => ($isDefault ? palette.icon : $fontColor || "#fff")};
5119
+ }
5120
+ `;
5121
+ const DashboardPlaceholderWrap = styled(uilibGl.Flex) `
5122
+ flex-grow: 1;
5123
+ flex-direction: column;
5124
+ justify-content: center;
5125
+ align-items: center;
5126
+ width: 100%;
5127
+ margin-bottom: 2rem;
5128
+ `;
5129
+ const DashboardPlaceholder = styled(uilibGl.Flex) `
5130
+ flex-direction: column;
5131
+ justify-content: center;
5132
+ align-items: center;
5133
+ margin-top: 2rem;
5134
+
5133
5135
  ${({ isLoading }) => isLoading &&
5134
- styled.css `
5135
- width: 6.25rem;
5136
- `}
5137
- &&& > * {
5138
- margin-bottom: 0;
5139
- }
5140
-
5141
- > div {
5142
- width: 100%;
5143
- margin-top: 1rem;
5144
- font-size: 0.75rem;
5145
- text-align: center;
5146
- color: ${({ theme: { palette } }) => palette.textDisabled};
5147
- }
5148
-
5149
- span[kind] {
5150
- width: 2.25rem;
5151
- height: 2.25rem;
5152
- opacity: 0.28;
5153
-
5154
- :after {
5155
- font-size: 32px;
5156
- }
5157
- }
5158
- `;
5159
- const DashboardWrapper = styled(uilibGl.Flex) `
5160
- flex-direction: column;
5161
- flex-wrap: nowrap;
5162
- flex-grow: 1;
5163
- width: calc(100% - 3rem);
5164
- height: calc(100% - ${LEFT_PANEL_HEADER_HEIGHT});
5165
-
5166
- > ${ContainerWrapper} {
5167
- > * {
5168
- margin-bottom: 2rem;
5169
- }
5170
- }
5171
-
5136
+ styled.css `
5137
+ width: 6.25rem;
5138
+ `}
5139
+ &&& > * {
5140
+ margin-bottom: 0;
5141
+ }
5142
+
5143
+ > div {
5144
+ width: 100%;
5145
+ margin-top: 1rem;
5146
+ font-size: 0.75rem;
5147
+ text-align: center;
5148
+ color: ${({ theme: { palette } }) => palette.textDisabled};
5149
+ }
5150
+
5151
+ span[kind] {
5152
+ width: 2.25rem;
5153
+ height: 2.25rem;
5154
+ opacity: 0.28;
5155
+
5156
+ :after {
5157
+ font-size: 32px;
5158
+ }
5159
+ }
5160
+ `;
5161
+ const DashboardWrapper = styled(uilibGl.Flex) `
5162
+ flex-direction: column;
5163
+ flex-wrap: nowrap;
5164
+ flex-grow: 1;
5165
+ width: calc(100% - 3rem);
5166
+ height: calc(100% - ${LEFT_PANEL_HEADER_HEIGHT});
5167
+
5168
+ > ${ContainerWrapper} {
5169
+ > * {
5170
+ margin-bottom: 2rem;
5171
+ }
5172
+ }
5173
+
5172
5174
  ${({ hasImage, isPresentationMode }) => hasImage &&
5173
5175
  !isPresentationMode &&
5174
- styled.css `
5175
- margin-top: -0.35rem;
5176
- `}
5177
- `;
5178
- const DashboardContent = styled(uilibGl.Flex) `
5179
- flex-grow: 1;
5180
- width: 100%;
5181
- padding: 1.5rem 1.5rem 2rem;
5182
- overflow-y: auto;
5183
- scrollbar-gutter: stable;
5184
- `;
5185
- const PresentationWrapperCss = styled.css `
5186
- margin-bottom: 0.75rem;
5187
- padding: 1.5rem;
5188
- background-color: ${({ theme: { palette } }) => palette.panelBackground};
5189
- backdrop-filter: blur(10px);
5190
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
5191
- box-shadow: ${uilibGl.shadows.raised};
5192
- `;
5193
- const PresentationWrapper = styled.div `
5194
- ${PresentationWrapperCss};
5195
- position: relative;
5196
- z-index: 1;
5197
- `;
5198
- const PresentationPanelWrapper = styled(PresentationWrapper) `
5199
- margin-top: 0.75rem;
5200
- transition: background-color ${uilibGl.transition.toggle};
5201
- `;
5202
- const PresentationHeader = styled.div `
5203
- margin: -1.5rem -1.5rem 0 -1.5rem;
5204
- padding: 1.5rem;
5205
- // background: url(images.presentationHeader) 0 0 no-repeat;
5206
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
5207
- transition: background-color ${uilibGl.transition.toggle};
5208
-
5176
+ styled.css `
5177
+ margin-top: -0.35rem;
5178
+ `}
5179
+ `;
5180
+ const DashboardContent = styled(uilibGl.Flex) `
5181
+ flex-grow: 1;
5182
+ width: 100%;
5183
+ padding: 1.5rem 1.5rem 2rem;
5184
+ overflow-y: auto;
5185
+ scrollbar-gutter: stable;
5186
+ `;
5187
+ const PresentationWrapperCss = styled.css `
5188
+ margin-bottom: 0.75rem;
5189
+ padding: 1.5rem;
5190
+ background-color: ${({ theme: { palette } }) => palette.panelBackground};
5191
+ backdrop-filter: blur(10px);
5192
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
5193
+ box-shadow: ${uilibGl.shadows.raised};
5194
+ `;
5195
+ const PresentationWrapper = styled.div `
5196
+ ${PresentationWrapperCss};
5197
+ position: relative;
5198
+ z-index: 1;
5199
+ `;
5200
+ const PresentationPanelWrapper = styled(PresentationWrapper) `
5201
+ margin-top: 0.75rem;
5202
+ transition: background-color ${uilibGl.transition.toggle};
5203
+ `;
5204
+ const PresentationHeader = styled.div `
5205
+ margin: -1.5rem -1.5rem 0 -1.5rem;
5206
+ padding: 1.5rem;
5207
+ // background: url(images.presentationHeader) 0 0 no-repeat;
5208
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
5209
+ transition: background-color ${uilibGl.transition.toggle};
5210
+
5209
5211
  ${({ image }) => !!image &&
5210
- styled.css `
5211
- padding-top: 7rem;
5212
- `};
5213
- `;
5214
- const PresentationHeaderTools = styled(uilibGl.Flex) `
5215
- justify-content: space-between;
5216
- align-items: center;
5217
- margin-bottom: -0.5rem;
5218
- margin-right: -0.5rem;
5219
-
5220
- span[kind="sun"],
5221
- span[kind="moon"] {
5222
- :after {
5223
- font-size: 0.85rem;
5224
- color: ${({ theme: { palette } }) => palette.iconDisabled};
5225
- }
5226
-
5227
- :hover:after {
5228
- color: ${({ theme: { palette } }) => palette.icon};
5229
- }
5230
- }
5231
- `;
5232
- const LayerGroupList = styled(uilibGl.Flex) `
5233
- flex-direction: column;
5234
- height: 100%;
5235
- flex-wrap: nowrap;
5236
- overflow-x: ${({ $noScroll }) => ($noScroll ? "visible" : "hidden")};
5237
- overflow-y: ${({ $noScroll }) => ($noScroll ? "visible" : "auto")};
5238
- padding: 0 0.125rem 0 0.75rem;
5239
- scrollbar-gutter: stable;
5240
-
5241
- > * {
5242
- flex-grow: 1;
5243
- }
5212
+ styled.css `
5213
+ padding-top: 7rem;
5214
+ `};
5215
+ `;
5216
+ const PresentationHeaderTools = styled(uilibGl.Flex) `
5217
+ justify-content: space-between;
5218
+ align-items: center;
5219
+ margin-bottom: -0.5rem;
5220
+ margin-right: -0.5rem;
5221
+
5222
+ span[kind="sun"],
5223
+ span[kind="moon"] {
5224
+ :after {
5225
+ font-size: 0.85rem;
5226
+ color: ${({ theme: { palette } }) => palette.iconDisabled};
5227
+ }
5228
+
5229
+ :hover:after {
5230
+ color: ${({ theme: { palette } }) => palette.icon};
5231
+ }
5232
+ }
5233
+ `;
5234
+ const LayerGroupList = styled(uilibGl.Flex) `
5235
+ flex-direction: column;
5236
+ height: 100%;
5237
+ flex-wrap: nowrap;
5238
+ overflow-x: ${({ $noScroll }) => ($noScroll ? "visible" : "hidden")};
5239
+ overflow-y: ${({ $noScroll }) => ($noScroll ? "visible" : "auto")};
5240
+ padding: 0 0.125rem 0 0.75rem;
5241
+ scrollbar-gutter: stable;
5242
+
5243
+ > * {
5244
+ flex-grow: 1;
5245
+ }
5244
5246
  `;
5245
5247
  const PresentationHeaderButtons = styled(uilibGl.Flex) ``;
5246
- const PresentationPanelContainer = styled.div `
5247
- position: absolute;
5248
- top: 0;
5249
- left: calc(${({ left }) => left || 0}px + 0.75rem);
5250
- bottom: 0;
5251
- z-index: 3;
5252
- display: flex;
5253
- flex-direction: column;
5254
- width: ${LEFT_PANEL_HEADER_HEIGHT}px;
5255
- padding-right: 0.5rem;
5256
- scrollbar-gutter: stable;
5257
- overflow-y: hidden;
5258
-
5259
- :hover {
5260
- overflow-y: auto;
5261
- }
5262
-
5248
+ const PresentationPanelContainer = styled.div `
5249
+ position: absolute;
5250
+ top: 0;
5251
+ left: calc(${({ left }) => left || 0}px + 0.75rem);
5252
+ bottom: 0;
5253
+ z-index: 3;
5254
+ display: flex;
5255
+ flex-direction: column;
5256
+ width: ${LEFT_PANEL_HEADER_HEIGHT}px;
5257
+ padding-right: 0.5rem;
5258
+ scrollbar-gutter: stable;
5259
+ overflow-y: hidden;
5260
+
5261
+ :hover {
5262
+ overflow-y: auto;
5263
+ }
5264
+
5263
5265
  ${({ showLayers }) => !showLayers &&
5264
- styled.css `
5265
- > :first-child {
5266
- padding-bottom: 0;
5267
- }
5268
- `};
5269
-
5270
- ${PresentationHeader} > * {
5271
- position: relative;
5272
- z-index: 2;
5273
- }
5274
-
5275
- /* PaginationWrapper {
5276
- ${PresentationWrapperCss};
5277
- width: calc(100% - 2rem);
5278
- min-height: 8.625rem;
5279
- padding-top: 0.5rem;
5280
- padding-bottom: 0.5rem;
5281
- margin-bottom: 0.75rem;
5282
- }*/
5283
-
5284
- ${DashboardWrapper} {
5285
- width: 100%;
5286
- margin-top: 0;
5287
-
5288
- ${DashboardContent} {
5289
- padding: 0;
5290
- overflow-y: unset;
5291
-
5292
- > * > ${ContainerWrapper} > * > ${ContainerWrapper} {
5293
- ${PresentationWrapperCss};
5294
- width: calc(100% - 3rem);
5295
- }
5296
- }
5297
- }
5298
-
5299
- ${DashboardPlaceholder} {
5300
- ${PresentationWrapperCss};
5301
- width: 18.5rem;
5302
- height: 10.75rem;
5303
- }
5304
-
5305
- ${LayerListContainer} {
5306
- height: auto;
5307
- margin: 0 -1.125rem -1.5rem;
5308
- padding: 0;
5309
-
5310
- ${LayerGroupList} {
5311
- padding: 0;
5312
- }
5313
- }
5314
- `;
5315
- const DataSourceErrorContainer = styled(uilibGl.Flex) `
5316
- align-items: center;
5317
- justify-content: center;
5318
- flex-wrap: nowrap;
5319
- flex-grow: 1;
5320
- padding: 1rem;
5321
- border: 1px ${({ theme: { palette } }) => palette.element} solid;
5322
- border-radius: 10px;
5323
- font-size: 0.875rem;
5324
- color: ${({ theme: { palette } }) => palette.textDisabled};
5325
-
5326
- span[kind] {
5327
- margin-right: 1rem;
5328
-
5329
- :after {
5330
- color: ${({ theme: { palette } }) => palette.iconDisabled};
5331
- }
5332
- }
5333
- `;
5334
- const AttributeLabel = styled(uilibGl.Description) `
5335
- margin-top: 0 !important;
5336
- margin-bottom: ${({ forCheckbox }) => (forCheckbox ? "0.75rem" : "0.25rem")} !important;
5337
- padding-left: ${({ isEdit }) => (isEdit ? "0.5rem" : "0")};
5338
- `;
5339
- const FeatureControls = styled(uilibGl.Flex) `
5340
- align-items: center;
5341
- gap: 1rem;
5342
- flex-wrap: nowrap;
5343
- position: relative;
5344
- flex-shrink: 0;
5345
-
5346
- button {
5347
- padding: 0;
5348
- width: auto;
5349
- }
5266
+ styled.css `
5267
+ > :first-child {
5268
+ padding-bottom: 0;
5269
+ }
5270
+ `};
5271
+
5272
+ ${PresentationHeader} > * {
5273
+ position: relative;
5274
+ z-index: 2;
5275
+ }
5276
+
5277
+ /* PaginationWrapper {
5278
+ ${PresentationWrapperCss};
5279
+ width: calc(100% - 2rem);
5280
+ min-height: 8.625rem;
5281
+ padding-top: 0.5rem;
5282
+ padding-bottom: 0.5rem;
5283
+ margin-bottom: 0.75rem;
5284
+ }*/
5285
+
5286
+ ${DashboardWrapper} {
5287
+ width: 100%;
5288
+ margin-top: 0;
5289
+
5290
+ ${DashboardContent} {
5291
+ padding: 0;
5292
+ overflow-y: unset;
5293
+
5294
+ > * > ${ContainerWrapper} > * > ${ContainerWrapper} {
5295
+ ${PresentationWrapperCss};
5296
+ width: calc(100% - 3rem);
5297
+ }
5298
+ }
5299
+ }
5300
+
5301
+ ${DashboardPlaceholder} {
5302
+ ${PresentationWrapperCss};
5303
+ width: 18.5rem;
5304
+ height: 10.75rem;
5305
+ }
5306
+
5307
+ ${LayerListContainer} {
5308
+ height: auto;
5309
+ margin: 0 -1.125rem -1.5rem;
5310
+ padding: 0;
5311
+
5312
+ ${LayerGroupList} {
5313
+ padding: 0;
5314
+ }
5315
+ }
5316
+ `;
5317
+ const DataSourceErrorContainer = styled(uilibGl.Flex) `
5318
+ align-items: center;
5319
+ justify-content: center;
5320
+ flex-wrap: nowrap;
5321
+ flex-grow: 1;
5322
+ padding: 1rem;
5323
+ border: 1px ${({ theme: { palette } }) => palette.element} solid;
5324
+ border-radius: 10px;
5325
+ font-size: 0.875rem;
5326
+ color: ${({ theme: { palette } }) => palette.textDisabled};
5327
+
5328
+ span[kind] {
5329
+ margin-right: 1rem;
5330
+
5331
+ :after {
5332
+ color: ${({ theme: { palette } }) => palette.iconDisabled};
5333
+ }
5334
+ }
5335
+ `;
5336
+ const AttributeLabel = styled(uilibGl.Description) `
5337
+ margin-top: 0 !important;
5338
+ margin-bottom: ${({ forCheckbox }) => (forCheckbox ? "0.75rem" : "0.25rem")} !important;
5339
+ padding-left: ${({ isEdit }) => (isEdit ? "0.5rem" : "0")};
5340
+ `;
5341
+ const FeatureControls = styled(uilibGl.Flex) `
5342
+ align-items: center;
5343
+ gap: 1rem;
5344
+ flex-wrap: nowrap;
5345
+ position: relative;
5346
+ flex-shrink: 0;
5347
+
5348
+ button {
5349
+ padding: 0;
5350
+ width: auto;
5351
+ }
5350
5352
  `;
5351
5353
 
5352
5354
  const getAttributeByName = (attributeName, attributes) => {
@@ -5399,14 +5401,20 @@ const getChartFilterName = (relatedDataSources) => {
5399
5401
  return axes?.[0]?.filterName;
5400
5402
  };
5401
5403
 
5404
+ function getValueIndex(items, attributes) {
5405
+ return items?.findIndex(({ name }) => name.toString() === attributes.value?.toString());
5406
+ }
5402
5407
  const getChartMarkers = (items, markers, dataSources) => {
5403
5408
  if (typeof markers === "string") {
5404
5409
  const dataSource = getDataSource(markers, dataSources);
5405
- return dataSource?.features?.map(({ attributes }) => attributes) || [];
5410
+ return dataSource?.features?.map(({ attributes }) => ({
5411
+ ...attributes,
5412
+ value: getValueIndex(items, attributes),
5413
+ })) || [];
5406
5414
  }
5407
5415
  return (markers?.map(marker => ({
5408
5416
  ...marker,
5409
- value: items?.findIndex(({ name }) => name.toString() === marker.value?.toString()),
5417
+ value: getValueIndex(items, marker),
5410
5418
  })) || []);
5411
5419
  };
5412
5420
 
@@ -5476,10 +5484,10 @@ const TwoColumnContainer = React.memo(({ config, elementConfig, type, renderElem
5476
5484
  return renderAttributes?.length ? (jsxRuntime.jsx(jsxRuntime.Fragment, { children: renderAttributes.map(attribute => renderContainer(elementConfig, attribute)) })) : (renderContainer(elementConfig));
5477
5485
  });
5478
5486
 
5479
- const InnerContainerWrapper = styled.div `
5480
- cursor: ${({ onClick }) => (onClick ? "pointer" : "default")};
5481
- width: ${({ column }) => (column ? "100%" : "auto")};
5482
- opacity: ${({ hasAnyFilter, isFiltered }) => (isFiltered ? 1 : hasAnyFilter ? FILTERED_VALUE_OPACITY / 100 : 1)};
5487
+ const InnerContainerWrapper = styled.div `
5488
+ cursor: ${({ onClick }) => (onClick ? "pointer" : "default")};
5489
+ width: ${({ column }) => (column ? "100%" : "auto")};
5490
+ opacity: ${({ hasAnyFilter, isFiltered }) => (isFiltered ? 1 : hasAnyFilter ? FILTERED_VALUE_OPACITY / 100 : 1)};
5483
5491
  `;
5484
5492
 
5485
5493
  const DataSourceInnerContainer = React.memo(({ config, elementConfig, feature, maxValue, type, index, innerComponent }) => {
@@ -5550,107 +5558,107 @@ const DataSourceInnerContainer = React.memo(({ config, elementConfig, feature, m
5550
5558
  return (jsxRuntime.jsx(InnerContainerWrapper, { hasAnyFilter: hasAnyFilter, isFiltered: isFiltered(value), column: column === undefined || column, onClick: filterName ? () => onFilter(value) : undefined, children: jsxRuntime.jsx(InnerContainer, { config: config, elementConfig: elementConfig, feature: feature, maxValue: maxValue, type: type, index: index, renderElement: render }) }));
5551
5559
  });
5552
5560
 
5553
- const DataSourceProgressContainerWrapper = styled.div `
5554
- width: 100%;
5555
- `;
5556
- const ContainerToggler = styled(uilibGl.LegendToggler) `
5557
- width: auto;
5558
- margin-left: -1rem;
5559
- `;
5560
-
5561
- const ProgressContainerWrapper = styled(uilibGl.Flex) `
5562
- align-items: center;
5563
- width: 100%;
5564
- margin-bottom: 1rem;
5565
- `;
5566
- const ProgressIcon = styled.div `
5567
- margin-right: 0.5rem;
5568
- `;
5569
- const ProgressContent = styled(uilibGl.Flex) `
5570
- flex: 1;
5571
- flex-direction: column;
5572
- `;
5573
- const ProgressAlias = styled(uilibGl.Flex) `
5574
- flex: 1;
5575
- justify-content: space-between;
5576
- margin-bottom: 0.25rem;
5577
- font-size: 0.75rem;
5578
- color: ${({ theme: { palette } }) => palette.textSecondary};
5579
- `;
5580
- const ProgressValue = styled(uilibGl.Flex) `
5581
- align-items: center;
5582
- width: auto;
5583
- font-size: 1rem;
5584
- color: ${({ theme: { palette } }) => palette.textPrimary};
5585
- `;
5586
- const ProgressInnerValue = styled(ProgressValue) `
5587
- justify-content: flex-end;
5588
- width: 4rem;
5589
- margin-left: 0.5rem;
5590
- `;
5591
- const ProgressUnits = styled(uilibGl.Flex) `
5592
- margin-left: 0.25rem;
5593
- font-size: 0.75rem;
5594
- color: ${({ theme: { palette } }) => palette.textSecondary};
5595
- `;
5596
- const ProgressBarWrapper = styled.div `
5597
- flex-grow: 1;
5598
- height: 0.5rem;
5599
- background-color: ${({ theme: { palette } }) => palette.element};
5600
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.xSmall};
5601
- `;
5602
- const ProgressBarContainer = styled(uilibGl.Flex) `
5603
- position: relative;
5604
- align-items: center;
5605
- width: 100%;
5606
-
5561
+ const DataSourceProgressContainerWrapper = styled.div `
5562
+ width: 100%;
5563
+ `;
5564
+ const ContainerToggler = styled(uilibGl.LegendToggler) `
5565
+ width: auto;
5566
+ margin-left: -1rem;
5567
+ `;
5568
+
5569
+ const ProgressContainerWrapper = styled(uilibGl.Flex) `
5570
+ align-items: center;
5571
+ width: 100%;
5572
+ margin-bottom: 1rem;
5573
+ `;
5574
+ const ProgressIcon = styled.div `
5575
+ margin-right: 0.5rem;
5576
+ `;
5577
+ const ProgressContent = styled(uilibGl.Flex) `
5578
+ flex: 1;
5579
+ flex-direction: column;
5580
+ `;
5581
+ const ProgressAlias = styled(uilibGl.Flex) `
5582
+ flex: 1;
5583
+ justify-content: space-between;
5584
+ margin-bottom: 0.25rem;
5585
+ font-size: 0.75rem;
5586
+ color: ${({ theme: { palette } }) => palette.textSecondary};
5587
+ `;
5588
+ const ProgressValue = styled(uilibGl.Flex) `
5589
+ align-items: center;
5590
+ width: auto;
5591
+ font-size: 1rem;
5592
+ color: ${({ theme: { palette } }) => palette.textPrimary};
5593
+ `;
5594
+ const ProgressInnerValue = styled(ProgressValue) `
5595
+ justify-content: flex-end;
5596
+ width: 4rem;
5597
+ margin-left: 0.5rem;
5598
+ `;
5599
+ const ProgressUnits = styled(uilibGl.Flex) `
5600
+ margin-left: 0.25rem;
5601
+ font-size: 0.75rem;
5602
+ color: ${({ theme: { palette } }) => palette.textSecondary};
5603
+ `;
5604
+ const ProgressBarWrapper = styled.div `
5605
+ flex-grow: 1;
5606
+ height: 0.5rem;
5607
+ background-color: ${({ theme: { palette } }) => palette.element};
5608
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.xSmall};
5609
+ `;
5610
+ const ProgressBarContainer = styled(uilibGl.Flex) `
5611
+ position: relative;
5612
+ align-items: center;
5613
+ width: 100%;
5614
+
5607
5615
  ${({ innerValue }) => innerValue &&
5608
- styled.css `
5609
- ${ProgressBarWrapper} {
5610
- height: 1.125rem;
5611
- }
5612
-
5613
- ${ProgressInnerValue} {
5614
- z-index: 1;
5615
- position: absolute;
5616
- right: 0.25rem;
5617
- }
5618
- `}
5619
- `;
5620
- const ProgressBar = styled.div `
5621
- width: ${({ $width }) => $width};
5622
- height: inherit;
5623
- background-color: ${({ $color }) => $color || "#a7d759"};
5624
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.xSmall};
5625
- `;
5626
- const ProgressTooltipAlias = styled.div `
5627
- margin-bottom: 0.25rem;
5628
- text-align: left;
5629
- color: ${({ theme: { palette } }) => palette.primary};
5616
+ styled.css `
5617
+ ${ProgressBarWrapper} {
5618
+ height: 1.125rem;
5619
+ }
5620
+
5621
+ ${ProgressInnerValue} {
5622
+ z-index: 1;
5623
+ position: absolute;
5624
+ right: 0.25rem;
5625
+ }
5626
+ `}
5627
+ `;
5628
+ const ProgressBar = styled.div `
5629
+ width: ${({ $width }) => $width};
5630
+ height: inherit;
5631
+ background-color: ${({ $color }) => $color || "#a7d759"};
5632
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.xSmall};
5633
+ `;
5634
+ const ProgressTooltipAlias = styled.div `
5635
+ margin-bottom: 0.25rem;
5636
+ text-align: left;
5637
+ color: ${({ theme: { palette } }) => palette.primary};
5630
5638
  `;
5631
5639
  const ProgressTooltipValue = styled.div ``;
5632
- const ProgressTooltipValueContainer = styled(uilibGl.Flex) `
5633
- align-items: center;
5634
-
5635
- > * {
5636
- opacity: 0.65;
5637
- }
5638
-
5639
- ${ProgressTooltipValue} {
5640
- opacity: 1;
5641
- }
5642
- `;
5643
- const ProgressTooltipValueOf = styled.div `
5644
- margin: 0 0.25rem;
5645
- `;
5646
- const ProgressTotalTitle = styled.div `
5647
- font-size: 0.75rem;
5648
- font-weight: bold;
5649
- `;
5650
- const ProgressTotal = styled(uilibGl.Flex) `
5651
- align-items: center;
5652
- justify-content: space-between;
5653
- margin-top: 1rem;
5640
+ const ProgressTooltipValueContainer = styled(uilibGl.Flex) `
5641
+ align-items: center;
5642
+
5643
+ > * {
5644
+ opacity: 0.65;
5645
+ }
5646
+
5647
+ ${ProgressTooltipValue} {
5648
+ opacity: 1;
5649
+ }
5650
+ `;
5651
+ const ProgressTooltipValueOf = styled.div `
5652
+ margin: 0 0.25rem;
5653
+ `;
5654
+ const ProgressTotalTitle = styled.div `
5655
+ font-size: 0.75rem;
5656
+ font-weight: bold;
5657
+ `;
5658
+ const ProgressTotal = styled(uilibGl.Flex) `
5659
+ align-items: center;
5660
+ justify-content: space-between;
5661
+ margin-top: 1rem;
5654
5662
  `;
5655
5663
 
5656
5664
  const DataSourceProgressContainer = React.memo(({ config, elementConfig, type, innerComponent, renderElement }) => {
@@ -5747,166 +5755,166 @@ const DEFAULT_BAR_CHART_MARGINS = {
5747
5755
  right: 0,
5748
5756
  };
5749
5757
 
5750
- const FiltersContainerWrapper = styled(uilibGl.Flex) `
5751
- flex-direction: column;
5752
- padding: ${({ $padding }) => $padding ?? "0.75rem"};
5753
- background-color: ${({ $bgColor, $fontColor, theme: { palette } }) => $bgColor || ($fontColor ? transparentizeColor($fontColor, 6) : palette.element)};
5754
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
5755
-
5756
- ${uilibGl.DropdownField}, input {
5757
- background-color: ${({ theme: { palette } }) => palette.background};
5758
- }
5759
-
5760
- > div:not(:last-child) {
5761
- margin-bottom: 0.5rem;
5762
- }
5763
-
5764
- > label {
5765
- align-items: flex-start;
5766
- font-size: ${({ $fontSize }) => $fontSize || "0.875rem"};
5767
-
5768
- &.active {
5769
- color: ${({ $fontColor }) => $fontColor};
5770
-
5771
- svg rect {
5772
- fill: ${({ $fontColor }) => $fontColor} !important;
5773
- }
5774
- }
5775
-
5776
- &:not(:last-child) {
5777
- margin-bottom: 0.75rem;
5778
- }
5779
-
5780
- &:last-child {
5781
- margin-bottom: 0;
5782
- }
5783
- }
5784
- `;
5785
- const StyledIconButton = styled(uilibGl.IconButton) `
5786
- width: 0.75rem;
5787
- height: 0.75rem;
5788
-
5789
- span[kind] {
5790
- height: 0.75rem;
5791
-
5792
- :after {
5793
- font-size: 0.75rem;
5794
- }
5795
- }
5796
- `;
5797
- const TextFilterContainer = styled.div `
5798
- width: 15.85rem;
5799
-
5800
- ${uilibGl.MultiSelectContainer} {
5801
- color: ${({ theme: { palette } }) => palette.textPrimary};
5802
-
5803
- ${uilibGl.IconButtonButton} {
5804
- span[kind]:after {
5805
- color: ${({ theme: { palette } }) => palette.textPrimary};
5806
- }
5807
- }
5808
- }
5809
- `;
5810
- const BarChartContainer = styled.div `
5811
- width: 100%;
5812
- overflow-x: hidden;
5813
-
5758
+ const FiltersContainerWrapper = styled(uilibGl.Flex) `
5759
+ flex-direction: column;
5760
+ padding: ${({ $padding }) => $padding ?? "0.75rem"};
5761
+ background-color: ${({ $bgColor, $fontColor, theme: { palette } }) => $bgColor || ($fontColor ? transparentizeColor($fontColor, 6) : palette.element)};
5762
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
5763
+
5764
+ ${uilibGl.DropdownField}, input {
5765
+ background-color: ${({ theme: { palette } }) => palette.background};
5766
+ }
5767
+
5768
+ > div:not(:last-child) {
5769
+ margin-bottom: 0.5rem;
5770
+ }
5771
+
5772
+ > label {
5773
+ align-items: flex-start;
5774
+ font-size: ${({ $fontSize }) => $fontSize || "0.875rem"};
5775
+
5776
+ &.active {
5777
+ color: ${({ $fontColor }) => $fontColor};
5778
+
5779
+ svg rect {
5780
+ fill: ${({ $fontColor }) => $fontColor} !important;
5781
+ }
5782
+ }
5783
+
5784
+ &:not(:last-child) {
5785
+ margin-bottom: 0.75rem;
5786
+ }
5787
+
5788
+ &:last-child {
5789
+ margin-bottom: 0;
5790
+ }
5791
+ }
5792
+ `;
5793
+ const StyledIconButton = styled(uilibGl.IconButton) `
5794
+ width: 0.75rem;
5795
+ height: 0.75rem;
5796
+
5797
+ span[kind] {
5798
+ height: 0.75rem;
5799
+
5800
+ :after {
5801
+ font-size: 0.75rem;
5802
+ }
5803
+ }
5804
+ `;
5805
+ const TextFilterContainer = styled.div `
5806
+ width: 15.85rem;
5807
+
5808
+ ${uilibGl.MultiSelectContainer} {
5809
+ color: ${({ theme: { palette } }) => palette.textPrimary};
5810
+
5811
+ ${uilibGl.IconButtonButton} {
5812
+ span[kind]:after {
5813
+ color: ${({ theme: { palette } }) => palette.textPrimary};
5814
+ }
5815
+ }
5816
+ }
5817
+ `;
5818
+ const BarChartContainer = styled.div `
5819
+ width: 100%;
5820
+ overflow-x: hidden;
5821
+
5814
5822
  ${({ barHeight, marginBottom }) => !!barHeight &&
5815
- styled.css `
5816
- .barChartBarGlobal rect {
5817
- height: ${barHeight}px;
5818
- y: calc(100% - ${barHeight + marginBottom}px);
5819
- }
5820
- `}
5821
- `;
5822
- const AnyChartWrapper = styled.div `
5823
- width: 100%;
5824
- height: ${({ height }) => height}px;
5825
- `;
5826
- const BarChartWrapper = styled(AnyChartWrapper) `
5827
- width: 100%;
5828
- margin: 0 auto ${BAR_CHART_FOOTER_MARGIN}px;
5829
-
5830
- :hover {
5831
- ${BarChartContainer} {
5832
- overflow-x: auto;
5833
- }
5834
- }
5835
- `;
5836
- const BarChartFilterHeader = styled(uilibGl.Flex) `
5837
- justify-content: space-between;
5838
- align-items: center;
5839
- height: ${({ height }) => `calc(${typeof height === "number" ? `${height}px` : height} - 0.5rem)`};
5840
- padding: 0.25rem 0;
5841
- `;
5842
- const BarChartFilterArrows = styled(uilibGl.Flex) `
5843
- margin-left: -0.5rem;
5844
-
5845
- span[kind] {
5846
- display: flex;
5847
- align-items: center;
5848
-
5849
- :after {
5850
- font-size: 0.75rem;
5851
- }
5852
- }
5853
- `;
5854
- const BarChartFilterSelected = styled.div `
5855
- font-size: 0.75rem;
5856
- font-weight: bold;
5857
- color: ${({ theme: { palette } }) => palette.textPrimary};
5858
- `;
5859
- styled.div `
5860
- color: ${({ theme: { palette } }) => palette.textSecondary};
5861
- `;
5862
- const BarChart = styled(charts.BarChart) `
5863
- .${charts.barChartClassNames.barChartXAxis} {
5864
- .domain,
5865
- line {
5866
- display: none;
5867
- }
5868
-
5869
- .tick {
5870
- text {
5871
- text-anchor: start;
5872
- font-size: 12px;
5873
- color: rgba(48, 69, 79, 0.46);
5874
- }
5875
-
5876
- :last-of-type {
5877
- text {
5878
- text-anchor: end;
5879
- }
5880
- }
5881
- }
5882
- }
5883
-
5884
- .marker {
5885
- font-size: 12px;
5886
- }
5887
- `;
5888
- const TooltipContainer = styled.div `
5889
- position: relative;
5890
- font-size: 0.75rem;
5891
- color: #ffffff;
5892
- margin-bottom: 0.5rem;
5893
- padding: 0.375rem;
5894
- background-color: rgba(0, 0, 0, 1);
5895
- border-radius: 0.25rem;
5896
- box-shadow: 0 0.1875rem 0.5rem rgba(48, 69, 79, 0.06);
5897
-
5898
- :before {
5899
- content: "";
5900
- position: absolute;
5901
- bottom: 0;
5902
- left: 50%;
5903
- transform: translate(-50%, 100%);
5904
- width: 0;
5905
- height: 0;
5906
- border-style: solid;
5907
- border-width: 0.25rem 0.1875rem 0 0.1875rem;
5908
- border-color: rgba(48, 69, 79, 1) transparent transparent transparent;
5909
- }
5823
+ styled.css `
5824
+ .barChartBarGlobal rect {
5825
+ height: ${barHeight}px;
5826
+ y: calc(100% - ${barHeight + marginBottom}px);
5827
+ }
5828
+ `}
5829
+ `;
5830
+ const AnyChartWrapper = styled.div `
5831
+ width: 100%;
5832
+ height: ${({ height }) => height}px;
5833
+ `;
5834
+ const BarChartWrapper = styled(AnyChartWrapper) `
5835
+ width: 100%;
5836
+ margin: 0 auto ${BAR_CHART_FOOTER_MARGIN}px;
5837
+
5838
+ :hover {
5839
+ ${BarChartContainer} {
5840
+ overflow-x: auto;
5841
+ }
5842
+ }
5843
+ `;
5844
+ const BarChartFilterHeader = styled(uilibGl.Flex) `
5845
+ justify-content: space-between;
5846
+ align-items: center;
5847
+ height: ${({ height }) => `calc(${typeof height === "number" ? `${height}px` : height} - 0.5rem)`};
5848
+ padding: 0.25rem 0;
5849
+ `;
5850
+ const BarChartFilterArrows = styled(uilibGl.Flex) `
5851
+ margin-left: -0.5rem;
5852
+
5853
+ span[kind] {
5854
+ display: flex;
5855
+ align-items: center;
5856
+
5857
+ :after {
5858
+ font-size: 0.75rem;
5859
+ }
5860
+ }
5861
+ `;
5862
+ const BarChartFilterSelected = styled.div `
5863
+ font-size: 0.75rem;
5864
+ font-weight: bold;
5865
+ color: ${({ theme: { palette } }) => palette.textPrimary};
5866
+ `;
5867
+ styled.div `
5868
+ color: ${({ theme: { palette } }) => palette.textSecondary};
5869
+ `;
5870
+ const BarChart = styled(charts.BarChart) `
5871
+ .${charts.barChartClassNames.barChartXAxis} {
5872
+ .domain,
5873
+ line {
5874
+ display: none;
5875
+ }
5876
+
5877
+ .tick {
5878
+ text {
5879
+ text-anchor: start;
5880
+ font-size: 12px;
5881
+ color: rgba(48, 69, 79, 0.46);
5882
+ }
5883
+
5884
+ :last-of-type {
5885
+ text {
5886
+ text-anchor: end;
5887
+ }
5888
+ }
5889
+ }
5890
+ }
5891
+
5892
+ .marker {
5893
+ font-size: 12px;
5894
+ }
5895
+ `;
5896
+ const TooltipContainer = styled.div `
5897
+ position: relative;
5898
+ font-size: 0.75rem;
5899
+ color: #ffffff;
5900
+ margin-bottom: 0.5rem;
5901
+ padding: 0.375rem;
5902
+ background-color: rgba(0, 0, 0, 1);
5903
+ border-radius: 0.25rem;
5904
+ box-shadow: 0 0.1875rem 0.5rem rgba(48, 69, 79, 0.06);
5905
+
5906
+ :before {
5907
+ content: "";
5908
+ position: absolute;
5909
+ bottom: 0;
5910
+ left: 50%;
5911
+ transform: translate(-50%, 100%);
5912
+ width: 0;
5913
+ height: 0;
5914
+ border-style: solid;
5915
+ border-width: 0.25rem 0.1875rem 0 0.1875rem;
5916
+ border-color: rgba(48, 69, 79, 1) transparent transparent transparent;
5917
+ }
5910
5918
  `;
5911
5919
 
5912
5920
  const FiltersContainer = React.memo(({ elementConfig, config, type, renderElement }) => {
@@ -5986,64 +5994,64 @@ const TwoColumnsInnerContainer = React.memo(({ renderElement }) => {
5986
5994
  return (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.jsxs(TwoColumnContainerWrapper, { children: [jsxRuntime.jsxs(Container, { children: [jsxRuntime.jsx(ContainerAlias, { children: renderElement({ id: "firstAlias" }) }), jsxRuntime.jsx(ContainerValue, { big: true, children: renderElement({ id: "firstValue" }) })] }), jsxRuntime.jsxs(Container, { children: [jsxRuntime.jsx(ContainerAlias, { children: renderElement({ id: "secondAlias" }) }), jsxRuntime.jsx(ContainerValue, { big: true, children: renderElement({ id: "secondValue" }) })] })] }), renderElement({ id: "thirdContainer" })] }));
5987
5995
  });
5988
5996
 
5989
- const ImageContainerBg$1 = styled.div `
5990
- position: absolute;
5991
- top: 0;
5992
- bottom: 0;
5993
- left: 0;
5994
- right: 0;
5995
-
5996
- img {
5997
- width: 100%;
5998
- height: 100%;
5999
- object-position: center;
6000
- object-fit: cover;
6001
- }
6002
- `;
6003
- const ImageContainerTitle = styled.div `
6004
- width: 100%;
6005
- overflow-wrap: break-word;
6006
- font-size: 1rem;
6007
- font-weight: 500;
6008
- `;
6009
- const ImageContainerText = styled.div `
6010
- width: 100%;
6011
- overflow-wrap: break-word;
6012
- margin-top: 0.5rem;
6013
- font-size: 0.75rem;
6014
- `;
6015
- const ImageContainerButton$1 = styled(uilibGl.FlatButton) `
6016
- min-height: 1.5rem;
6017
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.large};
6018
- background-color: ${({ theme: { palette } }) => palette.primary};
6019
- text-transform: none;
6020
-
6021
- :hover {
6022
- background-color: ${({ theme: { palette } }) => palette.primaryDeep};
6023
- }
6024
- `;
6025
- const ImageContainerWrapper = styled(uilibGl.Flex) `
6026
- flex-direction: column;
6027
- justify-content: flex-end;
6028
- position: relative;
6029
- padding: 1rem;
6030
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
6031
- overflow: hidden;
6032
-
6033
- ${ImageContainerTitle}, ${ImageContainerText}, ${ImageContainerButton$1} {
6034
- z-index: 1;
6035
- color: ${({ theme: { palette } }) => palette.textContrast};
6036
- }
6037
-
6038
- :after {
6039
- content: "";
6040
- position: absolute;
6041
- top: 0;
6042
- bottom: 0;
6043
- left: 0;
6044
- right: 0;
6045
- background-color: rgba(0, 0, 0, 0.4);
6046
- }
5997
+ const ImageContainerBg$1 = styled.div `
5998
+ position: absolute;
5999
+ top: 0;
6000
+ bottom: 0;
6001
+ left: 0;
6002
+ right: 0;
6003
+
6004
+ img {
6005
+ width: 100%;
6006
+ height: 100%;
6007
+ object-position: center;
6008
+ object-fit: cover;
6009
+ }
6010
+ `;
6011
+ const ImageContainerTitle = styled.div `
6012
+ width: 100%;
6013
+ overflow-wrap: break-word;
6014
+ font-size: 1rem;
6015
+ font-weight: 500;
6016
+ `;
6017
+ const ImageContainerText = styled.div `
6018
+ width: 100%;
6019
+ overflow-wrap: break-word;
6020
+ margin-top: 0.5rem;
6021
+ font-size: 0.75rem;
6022
+ `;
6023
+ const ImageContainerButton$1 = styled(uilibGl.FlatButton) `
6024
+ min-height: 1.5rem;
6025
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.large};
6026
+ background-color: ${({ theme: { palette } }) => palette.primary};
6027
+ text-transform: none;
6028
+
6029
+ :hover {
6030
+ background-color: ${({ theme: { palette } }) => palette.primaryDeep};
6031
+ }
6032
+ `;
6033
+ const ImageContainerWrapper = styled(uilibGl.Flex) `
6034
+ flex-direction: column;
6035
+ justify-content: flex-end;
6036
+ position: relative;
6037
+ padding: 1rem;
6038
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
6039
+ overflow: hidden;
6040
+
6041
+ ${ImageContainerTitle}, ${ImageContainerText}, ${ImageContainerButton$1} {
6042
+ z-index: 1;
6043
+ color: ${({ theme: { palette } }) => palette.textContrast};
6044
+ }
6045
+
6046
+ :after {
6047
+ content: "";
6048
+ position: absolute;
6049
+ top: 0;
6050
+ bottom: 0;
6051
+ left: 0;
6052
+ right: 0;
6053
+ background-color: rgba(0, 0, 0, 0.4);
6054
+ }
6047
6055
  `;
6048
6056
 
6049
6057
  const ImageContainer = React.memo(({ elementConfig, renderElement }) => {
@@ -6051,52 +6059,52 @@ const ImageContainer = React.memo(({ elementConfig, renderElement }) => {
6051
6059
  return (jsxRuntime.jsxs(ImageContainerWrapper, { style: style, children: [jsxRuntime.jsx(ImageContainerTitle, { children: renderElement({ id: "alias" }) }), jsxRuntime.jsx(ImageContainerText, { children: renderElement({ id: "text" }) }), renderElement({ id: "button" }), jsxRuntime.jsx(ImageContainerBg$1, { children: renderElement({ id: "image" }) })] }));
6052
6060
  });
6053
6061
 
6054
- const IconContainerWrapper = styled(uilibGl.Flex) `
6055
- flex-direction: column;
6056
- justify-content: center;
6057
- position: relative;
6058
- padding: 0.5rem 1rem 1rem;
6059
- background-color: ${({ theme: { palette } }) => palette.element};
6060
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
6061
- overflow: hidden;
6062
- `;
6063
- const IconContainerHeaderWrapper = styled(uilibGl.Flex) `
6064
- justify-content: space-between;
6065
- align-items: center;
6066
- flex-wrap: nowrap;
6067
- width: 100%;
6068
- margin-bottom: 0.25rem;
6069
- `;
6070
- const IconContainerHeader = styled(uilibGl.Flex) `
6071
- align-items: center;
6072
- flex-wrap: nowrap;
6073
- width: 100%;
6074
- margin-right: 0.5rem;
6075
- font-size: 0.875rem;
6076
-
6077
- ${uilibGl.Icon} {
6078
- margin-right: 0.5rem;
6079
-
6080
- :after {
6081
- font-size: 1.15rem;
6082
- color: ${({ theme: { palette } }) => palette.textSecondary};
6083
- }
6084
- }
6085
- `;
6086
- const IconContainerTitle = styled(uilibGl.Flex) `
6087
- > * {
6088
- width: 13rem;
6089
- white-space: nowrap;
6090
- overflow: hidden;
6091
- font-weight: bold;
6092
- text-overflow: ellipsis;
6093
- }
6094
- `;
6095
- const IconContainerText = styled.div `
6096
- width: 100%;
6097
- overflow-wrap: break-word;
6098
- font-size: 0.75rem;
6099
- color: ${({ theme: { palette } }) => palette.textSecondary};
6062
+ const IconContainerWrapper = styled(uilibGl.Flex) `
6063
+ flex-direction: column;
6064
+ justify-content: center;
6065
+ position: relative;
6066
+ padding: 0.5rem 1rem 1rem;
6067
+ background-color: ${({ theme: { palette } }) => palette.element};
6068
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
6069
+ overflow: hidden;
6070
+ `;
6071
+ const IconContainerHeaderWrapper = styled(uilibGl.Flex) `
6072
+ justify-content: space-between;
6073
+ align-items: center;
6074
+ flex-wrap: nowrap;
6075
+ width: 100%;
6076
+ margin-bottom: 0.25rem;
6077
+ `;
6078
+ const IconContainerHeader = styled(uilibGl.Flex) `
6079
+ align-items: center;
6080
+ flex-wrap: nowrap;
6081
+ width: 100%;
6082
+ margin-right: 0.5rem;
6083
+ font-size: 0.875rem;
6084
+
6085
+ ${uilibGl.Icon} {
6086
+ margin-right: 0.5rem;
6087
+
6088
+ :after {
6089
+ font-size: 1.15rem;
6090
+ color: ${({ theme: { palette } }) => palette.textSecondary};
6091
+ }
6092
+ }
6093
+ `;
6094
+ const IconContainerTitle = styled(uilibGl.Flex) `
6095
+ > * {
6096
+ width: 13rem;
6097
+ white-space: nowrap;
6098
+ overflow: hidden;
6099
+ font-weight: bold;
6100
+ text-overflow: ellipsis;
6101
+ }
6102
+ `;
6103
+ const IconContainerText = styled.div `
6104
+ width: 100%;
6105
+ overflow-wrap: break-word;
6106
+ font-size: 0.75rem;
6107
+ color: ${({ theme: { palette } }) => palette.textSecondary};
6100
6108
  `;
6101
6109
 
6102
6110
  const IconContainer = React.memo(({ elementConfig, renderElement }) => {
@@ -6118,83 +6126,83 @@ const DataSourceContainer = React.memo(({ config, elementConfig, type, innerComp
6118
6126
  return (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.jsx(ExpandableTitle, { elementConfig: elementConfig, type: type, renderElement: renderElement }), !isVisible ? null : dataSource ? (jsxRuntime.jsx(Container, { isColumn: column, style: { height: isLoading ? "3rem" : "auto", ...style }, children: dataSource.features?.map((feature, index) => (jsxRuntime.jsx(DataSourceInnerContainer, { index: index, type: type, config: config, feature: feature, elementConfig: elementConfig, innerComponent: innerComponent }, index))) })) : (jsxRuntime.jsx(ContainerLoading, {}))] }));
6119
6127
  });
6120
6128
 
6121
- const SvgContainerColorMixin = styled.css `
6122
- path,
6123
- line,
6124
- circle {
6125
- fill: ${({ $fontColor }) => $fontColor};
6126
- }
6127
- `;
6128
- const SvgContainer = styled.div `
6129
- &&& {
6130
- min-width: ${({ $width }) => ($width ? `${$width}px` : "1rem")};
6131
- max-width: ${({ $width }) => ($width ? `${$width}px` : "1rem")};
6132
-
6133
- ${({ $fontColor }) => !!$fontColor && SvgContainerColorMixin};
6134
-
6135
- > * {
6136
- min-width: inherit;
6137
- }
6138
- }
6139
- `;
6140
-
6141
- const ContainerIconTitle = styled(uilibGl.Flex) `
6142
- align-items: center;
6143
- flex-wrap: nowrap;
6144
- color: ${({ fontColor, theme: { palette } }) => fontColor || palette.textSecondary};
6145
-
6146
- svg,
6147
- img,
6148
- span[kind],
6149
- ${SvgContainer} {
6150
- margin-right: 0.5rem;
6151
- }
6152
-
6129
+ const SvgContainerColorMixin = styled.css `
6130
+ path,
6131
+ line,
6132
+ circle {
6133
+ fill: ${({ $fontColor }) => $fontColor};
6134
+ }
6135
+ `;
6136
+ const SvgContainer = styled.div `
6137
+ &&& {
6138
+ min-width: ${({ $width }) => ($width ? `${$width}px` : "1rem")};
6139
+ max-width: ${({ $width }) => ($width ? `${$width}px` : "1rem")};
6140
+
6141
+ ${({ $fontColor }) => !!$fontColor && SvgContainerColorMixin};
6142
+
6143
+ > * {
6144
+ min-width: inherit;
6145
+ }
6146
+ }
6147
+ `;
6148
+
6149
+ const ContainerIconTitle = styled(uilibGl.Flex) `
6150
+ align-items: center;
6151
+ flex-wrap: nowrap;
6152
+ color: ${({ fontColor, theme: { palette } }) => fontColor || palette.textSecondary};
6153
+
6154
+ svg,
6155
+ img,
6156
+ span[kind],
6157
+ ${SvgContainer} {
6158
+ margin-right: 0.5rem;
6159
+ }
6160
+
6153
6161
  ${({ fontColor }) => !!fontColor &&
6154
- styled.css `
6155
- span[kind] {
6156
- color: ${fontColor};
6157
- }
6158
-
6159
- ${SvgContainer} {
6160
- path,
6161
- circle {
6162
- fill: ${fontColor};
6163
- }
6164
- }
6165
- `};
6166
-
6167
- ${uilibGl.LegendToggler} {
6168
- margin-left: 0.25rem;
6169
- }
6170
- `;
6171
- const ContainerTitle = styled(uilibGl.Flex) `
6172
- align-items: center;
6173
- justify-content: space-between;
6174
- width: 100%;
6175
-
6176
- > * {
6177
- font-size: 1.125rem;
6178
- font-weight: 500;
6179
- }
6180
-
6181
- ${uilibGl.LegendToggler} {
6182
- padding-right: 0;
6183
- }
6184
-
6162
+ styled.css `
6163
+ span[kind] {
6164
+ color: ${fontColor};
6165
+ }
6166
+
6167
+ ${SvgContainer} {
6168
+ path,
6169
+ circle {
6170
+ fill: ${fontColor};
6171
+ }
6172
+ }
6173
+ `};
6174
+
6175
+ ${uilibGl.LegendToggler} {
6176
+ margin-left: 0.25rem;
6177
+ }
6178
+ `;
6179
+ const ContainerTitle = styled(uilibGl.Flex) `
6180
+ align-items: center;
6181
+ justify-content: space-between;
6182
+ width: 100%;
6183
+
6184
+ > * {
6185
+ font-size: 1.125rem;
6186
+ font-weight: 500;
6187
+ }
6188
+
6189
+ ${uilibGl.LegendToggler} {
6190
+ padding-right: 0;
6191
+ }
6192
+
6185
6193
  ${({ simple }) => simple &&
6186
- styled.css `
6187
- justify-content: flex-start;
6188
-
6189
- ${ContainerIconTitle} {
6190
- font-size: 0.75rem;
6191
- }
6192
-
6193
- ${uilibGl.LegendToggler} {
6194
- margin-left: 0;
6195
- padding-left: 0.25rem;
6196
- }
6197
- `}
6194
+ styled.css `
6195
+ justify-content: flex-start;
6196
+
6197
+ ${ContainerIconTitle} {
6198
+ font-size: 0.75rem;
6199
+ }
6200
+
6201
+ ${uilibGl.LegendToggler} {
6202
+ margin-left: 0;
6203
+ padding-left: 0.25rem;
6204
+ }
6205
+ `}
6198
6206
  `;
6199
6207
 
6200
6208
  const TitleContainer = React.memo(({ containerId, templateName, layerNames, fontColor, expandable, expanded, isVisible, elementConfig, renderElement, type, }) => {
@@ -6221,9 +6229,9 @@ const TitleContainer = React.memo(({ containerId, templateName, layerNames, font
6221
6229
  return (jsxRuntime.jsx(Container, { isTitle: isVisible, style: style, children: jsxRuntime.jsxs(ContainerTitle, { simple: simple, children: [jsxRuntime.jsxs(ContainerIconTitle, { fontColor: fontColor, children: [renderElement({ id: "titleIcon", wrap: false }), renderElement({ id: "title" }), isLayers && renderToggler] }), !isLayers && renderToggler, renderVisibility] }) }));
6222
6230
  });
6223
6231
 
6224
- const ContainerDivider = styled(uilibGl.Divider) `
6225
- width: 100%;
6226
- border-color: ${({ theme: { palette }, $bgColor }) => $bgColor || palette.elementDeep};
6232
+ const ContainerDivider = styled(uilibGl.Divider) `
6233
+ width: 100%;
6234
+ border-color: ${({ theme: { palette }, $bgColor }) => $bgColor || palette.elementDeep};
6227
6235
  `;
6228
6236
 
6229
6237
  const DividerContainer = React.memo(({ elementConfig, config }) => {
@@ -6276,82 +6284,82 @@ const CameraContainer = React.memo(({ elementConfig, type, renderElement }) => {
6276
6284
  return (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.jsx(ExpandableTitle, { elementConfig: elementConfig, type: type, renderElement: renderElement }), isVisible && (jsxRuntime.jsxs(Container, { style: style, children: [jsxRuntime.jsx(ContainerAlias, { hasBottomMargin: true, children: renderElement({ id: "alias" }) }), jsxRuntime.jsx(ContainerValue, { children: renderElement({ id: "value", wrap: false }) })] }))] }));
6277
6285
  });
6278
6286
 
6279
- const TabAnchor = styled.div `
6280
- position: absolute;
6281
- top: -1.5rem;
6282
- right: 0;
6283
- `;
6284
- const TabValue = styled(uilibGl.Flex) `
6285
- flex-wrap: nowrap;
6286
- `;
6287
- const noBgMixin = styled.css `
6288
- background-color: transparent;
6289
- border-radius: 0;
6290
- border-bottom: 0.125rem solid
6291
- ${({ active, bgColor, theme: { palette } }) => (active ? bgColor || palette.primary : palette.element)};
6292
-
6293
- ${TabValue},
6294
- span[kind] {
6295
- color: ${({ active, bgColor, theme: { palette } }) => active ? bgColor || palette.primary : palette.textSecondary};
6296
- }
6297
-
6298
- &&& svg {
6299
- path,
6300
- line,
6301
- circle {
6302
- fill: ${({ active, bgColor, theme: { palette } }) => active ? bgColor || palette.primary : palette.textSecondary};
6303
- }
6304
- }
6305
-
6306
- :not(:last-child) {
6307
- margin-right: 0;
6308
- }
6309
- `;
6310
- const TabContainer = styled.a `
6311
- display: flex;
6312
- flex-direction: ${({ column }) => (column ? "column" : "row")};
6313
- align-items: center;
6314
- justify-content: center;
6315
- flex-wrap: nowrap;
6316
- padding: ${({ onlyIcon }) => (onlyIcon ? 1 : 0.5)}rem 1rem;
6317
- background-color: ${({ active, bgColor, theme: { palette } }) => active ? bgColor || palette.primary : palette.element};
6318
- border-radius: ${({ column, radius, theme: { borderRadius } }) => radius ? `${radius}px` : column ? borderRadius.medium : borderRadius.xLarge};
6319
- text-decoration: none;
6320
-
6321
- :not(:last-child) {
6322
- margin-right: 0.5rem;
6323
- }
6324
-
6325
- ${TabValue} {
6326
- margin-top: ${({ column }) => (column ? 0.5 : 0)}rem;
6327
- margin-left: ${({ column, hasIcon }) => (column || !hasIcon ? 0 : 0.5)}rem;
6328
- font-size: ${({ column }) => (column ? 0.75 : 0.875)}rem;
6329
- white-space: nowrap;
6330
- }
6331
-
6332
- ${TabValue},
6333
- span[kind] {
6334
- color: ${({ active, theme: { palette } }) => (active ? palette.textContrast : palette.textSecondary)};
6335
- }
6336
-
6337
- ${SvgContainer$1} {
6338
- height: 1rem;
6339
- }
6340
-
6341
- svg,
6342
- img {
6343
- max-width: 1rem;
6344
- max-height: 1rem;
6345
- }
6346
-
6347
- ${({ noBg }) => noBg && noBgMixin};
6348
- `;
6349
- const SwiperContainer = styled.div `
6350
- width: 100%;
6351
-
6352
- .swiper-wrapper {
6353
- display: flex;
6354
- }
6287
+ const TabAnchor = styled.div `
6288
+ position: absolute;
6289
+ top: -1.5rem;
6290
+ right: 0;
6291
+ `;
6292
+ const TabValue = styled(uilibGl.Flex) `
6293
+ flex-wrap: nowrap;
6294
+ `;
6295
+ const noBgMixin = styled.css `
6296
+ background-color: transparent;
6297
+ border-radius: 0;
6298
+ border-bottom: 0.125rem solid
6299
+ ${({ active, bgColor, theme: { palette } }) => (active ? bgColor || palette.primary : palette.element)};
6300
+
6301
+ ${TabValue},
6302
+ span[kind] {
6303
+ color: ${({ active, bgColor, theme: { palette } }) => active ? bgColor || palette.primary : palette.textSecondary};
6304
+ }
6305
+
6306
+ &&& svg {
6307
+ path,
6308
+ line,
6309
+ circle {
6310
+ fill: ${({ active, bgColor, theme: { palette } }) => active ? bgColor || palette.primary : palette.textSecondary};
6311
+ }
6312
+ }
6313
+
6314
+ :not(:last-child) {
6315
+ margin-right: 0;
6316
+ }
6317
+ `;
6318
+ const TabContainer = styled.a `
6319
+ display: flex;
6320
+ flex-direction: ${({ column }) => (column ? "column" : "row")};
6321
+ align-items: center;
6322
+ justify-content: center;
6323
+ flex-wrap: nowrap;
6324
+ padding: ${({ onlyIcon }) => (onlyIcon ? 1 : 0.5)}rem 1rem;
6325
+ background-color: ${({ active, bgColor, theme: { palette } }) => active ? bgColor || palette.primary : palette.element};
6326
+ border-radius: ${({ column, radius, theme: { borderRadius } }) => radius ? `${radius}px` : column ? borderRadius.medium : borderRadius.xLarge};
6327
+ text-decoration: none;
6328
+
6329
+ :not(:last-child) {
6330
+ margin-right: 0.5rem;
6331
+ }
6332
+
6333
+ ${TabValue} {
6334
+ margin-top: ${({ column }) => (column ? 0.5 : 0)}rem;
6335
+ margin-left: ${({ column, hasIcon }) => (column || !hasIcon ? 0 : 0.5)}rem;
6336
+ font-size: ${({ column }) => (column ? 0.75 : 0.875)}rem;
6337
+ white-space: nowrap;
6338
+ }
6339
+
6340
+ ${TabValue},
6341
+ span[kind] {
6342
+ color: ${({ active, theme: { palette } }) => (active ? palette.textContrast : palette.textSecondary)};
6343
+ }
6344
+
6345
+ ${SvgContainer$1} {
6346
+ height: 1rem;
6347
+ }
6348
+
6349
+ svg,
6350
+ img {
6351
+ max-width: 1rem;
6352
+ max-height: 1rem;
6353
+ }
6354
+
6355
+ ${({ noBg }) => noBg && noBgMixin};
6356
+ `;
6357
+ const SwiperContainer = styled.div `
6358
+ width: 100%;
6359
+
6360
+ .swiper-wrapper {
6361
+ display: flex;
6362
+ }
6355
6363
  `;
6356
6364
 
6357
6365
  const TabsContainer = React.memo(({ elementConfig, type }) => {
@@ -6379,96 +6387,96 @@ const TabsContainer = React.memo(({ elementConfig, type }) => {
6379
6387
  });
6380
6388
 
6381
6389
  const ContainerIconValue = styled(uilibGl.Flex) ``;
6382
- const RoundedBackgroundContainerWrapper = styled(uilibGl.Flex) `
6383
- position: relative;
6384
- flex-direction: ${({ $bigIcon }) => ($bigIcon ? "row" : "column")};
6385
- width: 9rem;
6386
- padding: 0.75rem 0.75rem 0.5rem;
6387
- background-color: ${({ theme: { palette } }) => palette.element};
6388
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.large};
6389
- flex-wrap: nowrap;
6390
-
6391
- && {
6392
- margin-bottom: 0.5rem;
6393
- }
6394
-
6390
+ const RoundedBackgroundContainerWrapper = styled(uilibGl.Flex) `
6391
+ position: relative;
6392
+ flex-direction: ${({ $bigIcon }) => ($bigIcon ? "row" : "column")};
6393
+ width: 9rem;
6394
+ padding: 0.75rem 0.75rem 0.5rem;
6395
+ background-color: ${({ theme: { palette } }) => palette.element};
6396
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.large};
6397
+ flex-wrap: nowrap;
6398
+
6399
+ && {
6400
+ margin-bottom: 0.5rem;
6401
+ }
6402
+
6395
6403
  ${({ $center }) => $center &&
6396
- styled.css `
6397
- align-items: center;
6398
-
6399
- > * {
6400
- display: flex;
6401
- justify-content: center;
6402
- text-align: center;
6403
- width: 100%;
6404
- }
6405
- `};
6406
-
6404
+ styled.css `
6405
+ align-items: center;
6406
+
6407
+ > * {
6408
+ display: flex;
6409
+ justify-content: center;
6410
+ text-align: center;
6411
+ width: 100%;
6412
+ }
6413
+ `};
6414
+
6407
6415
  ${({ $color }) => $color &&
6408
- styled.css `
6409
- background-color: ${transparentizeColor($color, 6)};
6410
-
6411
- * {
6412
- color: ${$color};
6413
- }
6414
- `};
6415
-
6416
- ${ContainerIcon}, ${SvgContainer$1} {
6417
- margin-bottom: 0.25rem;
6418
- }
6419
-
6416
+ styled.css `
6417
+ background-color: ${transparentizeColor($color, 6)};
6418
+
6419
+ * {
6420
+ color: ${$color};
6421
+ }
6422
+ `};
6423
+
6424
+ ${ContainerIcon}, ${SvgContainer$1} {
6425
+ margin-bottom: 0.25rem;
6426
+ }
6427
+
6420
6428
  ${({ $bigIcon }) => $bigIcon &&
6421
- styled.css `
6422
- ${ContainerIcon}, ${SvgContainer$1} {
6423
- position: absolute;
6424
- top: 0.75rem;
6425
- right: 0.75rem;
6426
- width: 3rem;
6427
- opacity: 0.12;
6428
-
6429
- :after {
6430
- font-size: 3rem;
6431
- }
6432
- }
6433
- `};
6434
-
6435
- ${ContainerIconValue} {
6436
- align-items: center;
6437
- flex-direction: column;
6438
-
6429
+ styled.css `
6430
+ ${ContainerIcon}, ${SvgContainer$1} {
6431
+ position: absolute;
6432
+ top: 0.75rem;
6433
+ right: 0.75rem;
6434
+ width: 3rem;
6435
+ opacity: 0.12;
6436
+
6437
+ :after {
6438
+ font-size: 3rem;
6439
+ }
6440
+ }
6441
+ `};
6442
+
6443
+ ${ContainerIconValue} {
6444
+ align-items: center;
6445
+ flex-direction: column;
6446
+
6439
6447
  ${({ $big }) => $big &&
6440
- styled.css `
6441
- flex-direction: row;
6442
- margin-bottom: 0.5rem;
6443
-
6444
- > * {
6445
- text-align: left;
6446
- }
6447
-
6448
- span[kind] {
6449
- margin-right: 0.5rem;
6450
- }
6451
-
6452
- ${ContainerValue} {
6453
- width: auto;
6454
- }
6455
- `};
6456
- }
6457
-
6458
- ${ContainerValue} {
6459
- flex-direction: ${({ $inlineUnits }) => ($inlineUnits ? "row" : "column")};
6460
- justify-content: ${({ $big }) => ($big ? "flex-start" : "flex-end")};
6461
- align-items: ${({ $inlineUnits }) => ($inlineUnits ? "center" : "flex-start")};
6462
- line-height: 1;
6463
- }
6464
-
6465
- ${ContainerUnits} {
6466
- margin-left: ${({ $inlineUnits }) => ($inlineUnits ? "0.25rem" : 0)};
6467
- }
6468
-
6469
- ${ContainerAlias} {
6470
- margin-top: 0.25rem;
6471
- }
6448
+ styled.css `
6449
+ flex-direction: row;
6450
+ margin-bottom: 0.5rem;
6451
+
6452
+ > * {
6453
+ text-align: left;
6454
+ }
6455
+
6456
+ span[kind] {
6457
+ margin-right: 0.5rem;
6458
+ }
6459
+
6460
+ ${ContainerValue} {
6461
+ width: auto;
6462
+ }
6463
+ `};
6464
+ }
6465
+
6466
+ ${ContainerValue} {
6467
+ flex-direction: ${({ $inlineUnits }) => ($inlineUnits ? "row" : "column")};
6468
+ justify-content: ${({ $big }) => ($big ? "flex-start" : "flex-end")};
6469
+ align-items: ${({ $inlineUnits }) => ($inlineUnits ? "center" : "flex-start")};
6470
+ line-height: 1;
6471
+ }
6472
+
6473
+ ${ContainerUnits} {
6474
+ margin-left: ${({ $inlineUnits }) => ($inlineUnits ? "0.25rem" : 0)};
6475
+ }
6476
+
6477
+ ${ContainerAlias} {
6478
+ margin-top: 0.25rem;
6479
+ }
6472
6480
  `;
6473
6481
 
6474
6482
  const ALIAS_DEFAULT_MAX_LENGTH = 28;
@@ -6507,20 +6515,20 @@ const AddFeatureContainer = React.memo(({ elementConfig }) => {
6507
6515
  .map(({ options }, index) => (jsxRuntime.jsx(AddFeatureButton, { icon: options?.icon, title: options?.title, layerName: options?.layerName, geometryType: options?.geometryType }, index))) }));
6508
6516
  });
6509
6517
 
6510
- const LayersContainerWrapper = styled(Container) `
6511
- ${uilibGl.DraggableTreeContainer} {
6512
- width: calc(100% + 3rem);
6513
- margin: -0.75rem -1.5rem 0;
6514
- }
6515
-
6516
- ${LayerListContainer} {
6517
- height: auto;
6518
- }
6519
-
6520
- ${LayerGroupList} {
6521
- margin: ${({ isPresentationMode }) => (isPresentationMode ? 0 : "0 -1.25rem 0 -1rem")};
6522
- padding: 0;
6523
- }
6518
+ const LayersContainerWrapper = styled(Container) `
6519
+ ${uilibGl.DraggableTreeContainer} {
6520
+ width: calc(100% + 3rem);
6521
+ margin: -0.75rem -1.5rem 0;
6522
+ }
6523
+
6524
+ ${LayerListContainer} {
6525
+ height: auto;
6526
+ }
6527
+
6528
+ ${LayerGroupList} {
6529
+ margin: ${({ isPresentationMode }) => (isPresentationMode ? 0 : "0 -1.25rem 0 -1rem")};
6530
+ padding: 0;
6531
+ }
6524
6532
  `;
6525
6533
 
6526
6534
  const LayersContainer = React.memo(({ type, elementConfig, renderElement }) => {
@@ -6568,99 +6576,99 @@ const getContainerComponent = (innerTemplateName) => innerTemplateName ? contain
6568
6576
  var img$3 = "";
6569
6577
 
6570
6578
  const getMaskColor = (isDark) => (isDark ? "0, 0, 0" : "255, 255, 255");
6571
- const DefaultHeaderContainer = styled(uilibGl.Flex) `
6572
- flex-direction: column;
6573
- position: relative;
6574
- flex-shrink: 0;
6575
- min-height: 8.375rem;
6576
- margin-bottom: -1.5rem;
6577
- padding: 1.5rem 1.5rem 0;
6578
- border-top-left-radius: 0.5rem;
6579
- border-top-right-radius: 0.5rem;
6580
- overflow: hidden;
6581
-
6582
- > * {
6583
- z-index: 1;
6584
- }
6585
-
6586
- &::before {
6587
- content: "";
6588
- position: absolute;
6589
- top: 0;
6590
- left: 0;
6591
- width: 100%;
6592
- height: 100%;
6593
-
6579
+ const DefaultHeaderContainer = styled(uilibGl.Flex) `
6580
+ flex-direction: column;
6581
+ position: relative;
6582
+ flex-shrink: 0;
6583
+ min-height: 8.375rem;
6584
+ margin-bottom: -1.5rem;
6585
+ padding: 1.5rem 1.5rem 0;
6586
+ border-top-left-radius: 0.5rem;
6587
+ border-top-right-radius: 0.5rem;
6588
+ overflow: hidden;
6589
+
6590
+ > * {
6591
+ z-index: 1;
6592
+ }
6593
+
6594
+ &::before {
6595
+ content: "";
6596
+ position: absolute;
6597
+ top: 0;
6598
+ left: 0;
6599
+ width: 100%;
6600
+ height: 100%;
6601
+
6594
6602
  ${({ image, isDark }) => image
6595
- ? styled.css `
6596
- background: url(${image}) 0 0 no-repeat;
6597
- background-size: cover;
6603
+ ? styled.css `
6604
+ background: url(${image}) 0 0 no-repeat;
6605
+ background-size: cover;
6598
6606
  `
6599
- : styled.css `
6600
- background: url(${img$3}) 50% 0 no-repeat;
6601
- opacity: ${isDark ? 1 : 0.5};
6602
- `}
6603
- }
6604
-
6607
+ : styled.css `
6608
+ background: url(${img$3}) 50% 0 no-repeat;
6609
+ opacity: ${isDark ? 1 : 0.5};
6610
+ `}
6611
+ }
6612
+
6605
6613
  ${({ image, isDark }) => image &&
6606
- styled.css `
6607
- &::before {
6608
- -webkit-mask-image: linear-gradient(
6609
- to bottom,
6610
- rgba(${getMaskColor(isDark)}, 1),
6611
- rgba(${getMaskColor(isDark)}, 0)
6612
- );
6613
- mask-image: linear-gradient(to bottom, rgba(${getMaskColor(isDark)}, 1), rgba(${getMaskColor(isDark)}, 0));
6614
- }
6615
- `}
6616
- ${uilibGl.LinearProgress} {
6617
- position: absolute;
6618
- top: 0;
6619
- left: 0;
6620
- }
6621
- `;
6622
- const TopContainer = styled(uilibGl.Flex) `
6623
- z-index: 1;
6624
- position: relative;
6625
- justify-content: space-between;
6626
- flex-wrap: nowrap;
6627
- width: 100%;
6628
- align-items: flex-start;
6629
- `;
6630
- const TopContainerButtons = styled(uilibGl.Flex) `
6631
- align-items: center;
6632
- width: auto;
6633
- margin-right: -0.5rem;
6634
-
6635
- button {
6636
- width: auto;
6637
- height: 1rem;
6638
- padding: 0 0.5rem;
6639
- }
6640
- `;
6641
- const LogoContainer = styled(uilibGl.Flex) `
6642
- max-width: calc(100% - 1.4rem);
6643
- flex-grow: 1;
6644
- font-size: 0;
6645
-
6646
- & > span::after {
6647
- font-size: 2rem;
6648
- }
6649
-
6650
- img {
6651
- max-height: 1.875rem;
6652
- }
6653
- `;
6654
- const PageTitle = styled(uilibGl.H2) `
6655
- display: -webkit-box;
6656
- -webkit-line-clamp: 3;
6657
- -webkit-box-orient: vertical;
6658
- overflow: hidden;
6659
- margin: 0;
6660
- font-size: 1.25rem;
6661
- font-weight: 600;
6662
- pointer-events: initial;
6663
- font-family: "Nunito Sans", serif;
6614
+ styled.css `
6615
+ &::before {
6616
+ -webkit-mask-image: linear-gradient(
6617
+ to bottom,
6618
+ rgba(${getMaskColor(isDark)}, 1),
6619
+ rgba(${getMaskColor(isDark)}, 0)
6620
+ );
6621
+ mask-image: linear-gradient(to bottom, rgba(${getMaskColor(isDark)}, 1), rgba(${getMaskColor(isDark)}, 0));
6622
+ }
6623
+ `}
6624
+ ${uilibGl.LinearProgress} {
6625
+ position: absolute;
6626
+ top: 0;
6627
+ left: 0;
6628
+ }
6629
+ `;
6630
+ const TopContainer = styled(uilibGl.Flex) `
6631
+ z-index: 1;
6632
+ position: relative;
6633
+ justify-content: space-between;
6634
+ flex-wrap: nowrap;
6635
+ width: 100%;
6636
+ align-items: flex-start;
6637
+ `;
6638
+ const TopContainerButtons = styled(uilibGl.Flex) `
6639
+ align-items: center;
6640
+ width: auto;
6641
+ margin-right: -0.5rem;
6642
+
6643
+ button {
6644
+ width: auto;
6645
+ height: 1rem;
6646
+ padding: 0 0.5rem;
6647
+ }
6648
+ `;
6649
+ const LogoContainer = styled(uilibGl.Flex) `
6650
+ max-width: calc(100% - 1.4rem);
6651
+ flex-grow: 1;
6652
+ font-size: 0;
6653
+
6654
+ & > span::after {
6655
+ font-size: 2rem;
6656
+ }
6657
+
6658
+ img {
6659
+ max-height: 1.875rem;
6660
+ }
6661
+ `;
6662
+ const PageTitle = styled(uilibGl.H2) `
6663
+ display: -webkit-box;
6664
+ -webkit-line-clamp: 3;
6665
+ -webkit-box-orient: vertical;
6666
+ overflow: hidden;
6667
+ margin: 0;
6668
+ font-size: 1.25rem;
6669
+ font-weight: 600;
6670
+ pointer-events: initial;
6671
+ font-family: "Nunito Sans", serif;
6664
6672
  `;
6665
6673
 
6666
6674
  exports.ThemeName = void 0;
@@ -6686,81 +6694,81 @@ const DashboardDefaultHeader = React.memo(() => {
6686
6694
  return (jsxRuntime.jsxs(DefaultHeaderContainer, { image: image, isDark: themeName === exports.ThemeName.Dark, children: [!pageId && jsxRuntime.jsx(uilibGl.LinearProgress, {}), jsxRuntime.jsxs(uilibGl.Flex, { column: true, gap: "1rem", children: [jsxRuntime.jsx(uilibGl.FlexSpan, { children: jsxRuntime.jsxs(TopContainer, { children: [jsxRuntime.jsx(LogoContainer, { children: icon }), jsxRuntime.jsxs(TopContainerButtons, { children: [jsxRuntime.jsx(ProjectCatalogMenu, {}), jsxRuntime.jsx(ProjectPanelMenu, {})] })] }) }), jsxRuntime.jsx(uilibGl.FlexSpan, { children: jsxRuntime.jsx(uilibGl.Flex, { column: true, gap: "0.25rem", children: jsxRuntime.jsx(uilibGl.FlexSpan, { children: jsxRuntime.jsxs(uilibGl.Flex, { alignItems: "center", children: [jsxRuntime.jsx(uilibGl.FlexSpan, { flexGrow: 1, children: jsxRuntime.jsx(uilibGl.Tooltip, { arrow: true, content: tooltip, children: ref => (jsxRuntime.jsx(PageTitle, { ref: ref, children: jsxRuntime.jsx(ProjectPagesMenu, {}) })) }) }), jsxRuntime.jsx(uilibGl.FlexSpan, { children: jsxRuntime.jsx(Pagination, {}) })] }) }) }) })] })] }));
6687
6695
  });
6688
6696
 
6689
- const HeaderFrontView = styled(uilibGl.Flex) `
6690
- z-index: 10;
6691
- position: relative;
6692
- justify-content: space-between;
6693
- align-items: ${({ isDefault }) => (isDefault ? "center" : "flex-start")};
6694
- width: 100%;
6695
- font: ${({ theme: { fonts } }) => fonts.subtitle};
6696
- `;
6697
- const HeaderContainer = styled(uilibGl.FlexSpan) `
6698
- display: flex;
6699
- flex-grow: 1;
6700
- flex-wrap: nowrap;
6701
- width: calc(100% - 48px);
6702
- `;
6703
- const FeatureTitleContainer = styled.div `
6704
- display: -webkit-box;
6705
- max-width: 100%;
6706
- width: 100%;
6707
- margin: 0.5rem 0;
6708
- -webkit-line-clamp: 2;
6709
- -webkit-box-orient: vertical;
6710
- overflow: hidden;
6711
- text-overflow: ellipsis;
6712
- color: ${({ theme: { palette } }) => palette.textPrimary};
6713
-
6714
- & > ${uilibGl.FlexSpan} {
6715
- cursor: ${({ clickable }) => clickable && "pointer"};
6716
-
6717
- &:hover {
6718
- color: ${({ clickable, theme: { palette } }) => clickable && palette.primary};
6719
- }
6720
- }
6721
- `;
6722
- const LayerDescription = styled(uilibGl.Description) `
6723
- width: calc(100% - 4rem);
6724
- display: -webkit-box;
6725
- -webkit-line-clamp: 2;
6726
- -webkit-box-orient: vertical;
6727
- overflow: hidden;
6728
- text-overflow: ellipsis;
6729
- `;
6730
- const HeaderTitleContainer = styled(uilibGl.Flex) `
6731
- flex-direction: column;
6732
- width: 100%;
6733
- `;
6734
- const RowHeaderMixin = styled.css `
6735
- &&& {
6736
- min-height: auto;
6737
-
6738
- ${FeatureTitleContainer}, ${LayerDescription} {
6739
- text-align: left;
6740
- }
6741
- }
6742
-
6743
- ${HeaderContainer} {
6744
- flex-direction: row;
6745
- }
6746
-
6747
- ${FeatureTitleContainer} {
6748
- max-width: calc(100% - 3.8rem);
6749
- }
6750
- `;
6751
- const Header = styled(uilibGl.Flex) `
6752
- z-index: 1;
6753
- position: relative;
6754
- top: 0;
6755
- flex-shrink: 0;
6756
- overflow: hidden;
6757
- padding: 0.5rem;
6758
-
6759
- ${HeaderContainer} {
6760
- flex-direction: column;
6761
- }
6762
-
6763
- ${({ $isRow }) => $isRow && RowHeaderMixin};
6697
+ const HeaderFrontView = styled(uilibGl.Flex) `
6698
+ z-index: 10;
6699
+ position: relative;
6700
+ justify-content: space-between;
6701
+ align-items: ${({ isDefault }) => (isDefault ? "center" : "flex-start")};
6702
+ width: 100%;
6703
+ font: ${({ theme: { fonts } }) => fonts.subtitle};
6704
+ `;
6705
+ const HeaderContainer = styled(uilibGl.FlexSpan) `
6706
+ display: flex;
6707
+ flex-grow: 1;
6708
+ flex-wrap: nowrap;
6709
+ width: calc(100% - 48px);
6710
+ `;
6711
+ const FeatureTitleContainer = styled.div `
6712
+ display: -webkit-box;
6713
+ max-width: 100%;
6714
+ width: 100%;
6715
+ margin: 0.5rem 0;
6716
+ -webkit-line-clamp: 2;
6717
+ -webkit-box-orient: vertical;
6718
+ overflow: hidden;
6719
+ text-overflow: ellipsis;
6720
+ color: ${({ theme: { palette } }) => palette.textPrimary};
6721
+
6722
+ & > ${uilibGl.FlexSpan} {
6723
+ cursor: ${({ clickable }) => clickable && "pointer"};
6724
+
6725
+ &:hover {
6726
+ color: ${({ clickable, theme: { palette } }) => clickable && palette.primary};
6727
+ }
6728
+ }
6729
+ `;
6730
+ const LayerDescription = styled(uilibGl.Description) `
6731
+ width: calc(100% - 4rem);
6732
+ display: -webkit-box;
6733
+ -webkit-line-clamp: 2;
6734
+ -webkit-box-orient: vertical;
6735
+ overflow: hidden;
6736
+ text-overflow: ellipsis;
6737
+ `;
6738
+ const HeaderTitleContainer = styled(uilibGl.Flex) `
6739
+ flex-direction: column;
6740
+ width: 100%;
6741
+ `;
6742
+ const RowHeaderMixin = styled.css `
6743
+ &&& {
6744
+ min-height: auto;
6745
+
6746
+ ${FeatureTitleContainer}, ${LayerDescription} {
6747
+ text-align: left;
6748
+ }
6749
+ }
6750
+
6751
+ ${HeaderContainer} {
6752
+ flex-direction: row;
6753
+ }
6754
+
6755
+ ${FeatureTitleContainer} {
6756
+ max-width: calc(100% - 3.8rem);
6757
+ }
6758
+ `;
6759
+ const Header = styled(uilibGl.Flex) `
6760
+ z-index: 1;
6761
+ position: relative;
6762
+ top: 0;
6763
+ flex-shrink: 0;
6764
+ overflow: hidden;
6765
+ padding: 0.5rem;
6766
+
6767
+ ${HeaderContainer} {
6768
+ flex-direction: column;
6769
+ }
6770
+
6771
+ ${({ $isRow }) => $isRow && RowHeaderMixin};
6764
6772
  `;
6765
6773
 
6766
6774
  const HeaderTitle = ({ noFeature }) => {
@@ -6788,22 +6796,22 @@ const HeaderTitle = ({ noFeature }) => {
6788
6796
  return (jsxRuntime.jsxs(HeaderTitleContainer, { children: [noFeature ? (jsxRuntime.jsx(FeatureTitleContainer, { children: t("noObjectFound", { ns: "dashboard", defaultValue: "Объектов не найдено" }) })) : (jsxRuntime.jsx(FeatureTitleContainer, { clickable: true, children: jsxRuntime.jsx(uilibGl.Tooltip, { arrow: true, placement: "top", content: t("zoomToFeature", { ns: "dashboard", defaultValue: "Приблизить к объекту" }), delay: [600, 0], children: ref => (jsxRuntime.jsx(uilibGl.FlexSpan, { ref: ref, onClick: () => zoomToFeatures([feature]), children: resultTitle })) }) })), jsxRuntime.jsx(LayerDescription, { title: resultDescription, children: resultDescription })] }));
6789
6797
  };
6790
6798
 
6791
- const LayerIconContainer = styled.div `
6792
- display: flex;
6793
- align-items: center;
6794
- margin-right: 0.75rem;
6799
+ const LayerIconContainer = styled.div `
6800
+ display: flex;
6801
+ align-items: center;
6802
+ margin-right: 0.75rem;
6795
6803
  `;
6796
- const AlertIconContainer = styled(uilibGl.Flex) `
6797
- align-items: center;
6798
- justify-content: center;
6799
- width: 2rem;
6800
- height: 2rem;
6801
-
6802
- ${uilibGl.Icon} {
6803
- :after {
6804
- color: ${({ theme: { palette } }) => palette.error};
6805
- }
6806
- }
6804
+ const AlertIconContainer = styled(uilibGl.Flex) `
6805
+ align-items: center;
6806
+ justify-content: center;
6807
+ width: 2rem;
6808
+ height: 2rem;
6809
+
6810
+ ${uilibGl.Icon} {
6811
+ :after {
6812
+ color: ${({ theme: { palette } }) => palette.error};
6813
+ }
6814
+ }
6807
6815
  `;
6808
6816
 
6809
6817
  var img$2 = "data:image/svg+xml,%3csvg width='32' height='32' viewBox='0 0 32 32' fill='none' xmlns='http://www.w3.org/2000/svg'%3e %3crect width='32' height='32' fill='transparent'/%3e %3cpath d='M20.248 9.67787C18.5318 8.04035 15.9473 7.54977 13.7024 8.43543C11.4576 9.32109 9.99566 11.4081 10 13.721C10 18.2894 16 24 16 24C16 24 22 18.2894 22 13.721C22.0028 12.2054 21.3726 10.7509 20.248 9.67787Z' fill='url(%23paint0_linear_6459_10338)'/%3e %3ccircle cx='16' cy='14' r='2' fill='white'/%3e %3cdefs%3e %3clinearGradient id='paint0_linear_6459_10338' x1='10' y1='8' x2='25.36' y2='19.52' gradientUnits='userSpaceOnUse'%3e %3cstop stop-color='%230084D6'/%3e %3cstop offset='0.489583' stop-color='%230084D6'/%3e %3cstop offset='0.489683' stop-color='%2305A9FF'/%3e %3cstop offset='0.921875' stop-color='%2305A9FF'/%3e %3c/linearGradient%3e %3c/defs%3e%3c/svg%3e";
@@ -6835,56 +6843,56 @@ const FeatureCardDefaultHeader = ({ noFeature }) => {
6835
6843
  return (jsxRuntime.jsx(Header, { "$isRow": true, children: jsxRuntime.jsxs(HeaderFrontView, { isDefault: true, children: [jsxRuntime.jsxs(HeaderContainer, { children: [!!layerInfo?.name && jsxRuntime.jsx(LayerIcon, { layerInfo: layerInfo }), jsxRuntime.jsx(HeaderTitle, { noFeature: noFeature })] }), jsxRuntime.jsx(FeatureCardButtons, {})] }) }));
6836
6844
  };
6837
6845
 
6838
- const HeaderFontColorMixin$1 = styled.css `
6839
- ${HeaderTitleContainer}, ${LayerDescription} {
6840
- color: ${({ $fontColor }) => $fontColor};
6841
- }
6842
- `;
6843
- const HeaderWrapperMixin$1 = styled.css `
6844
- padding: 0.5rem 0.5rem 0;
6845
-
6846
- ${Header} {
6847
- min-height: 5.25rem;
6848
- }
6849
-
6850
- ${HeaderContainer} {
6851
- max-width: 100%;
6852
- width: 100%;
6853
- }
6854
-
6855
- ${FeatureControls} {
6856
- max-width: calc(100% - 2rem);
6857
- width: calc(100% - 2rem);
6858
- margin-top: -0.5rem;
6859
- padding-top: 1rem;
6860
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
6861
- }
6862
-
6863
- ${({ $fontColor }) => !!$fontColor && HeaderFontColorMixin$1};
6864
- `;
6865
- const GradientHeaderWrapper = styled.div `
6866
- ${Header} {
6867
- background: ${({ $bgColor }) => $bgColor || "radial-gradient(129.21% 133.22% at 51.94% 0%, #e8fffe 9.48%, #5fcaff 100%)"};
6868
- }
6869
-
6870
- ${HeaderContainer} {
6871
- align-items: center;
6872
- }
6873
-
6874
- ${HeaderTitleContainer} {
6875
- margin-left: 0;
6876
- text-align: center;
6877
- }
6878
-
6879
- ${FeatureTitleContainer} {
6880
- text-align: center;
6881
- }
6882
-
6883
- ${LayerDescription} {
6884
- text-align: center;
6885
- }
6886
-
6887
- ${HeaderWrapperMixin$1};
6846
+ const HeaderFontColorMixin$1 = styled.css `
6847
+ ${HeaderTitleContainer}, ${LayerDescription} {
6848
+ color: ${({ $fontColor }) => $fontColor};
6849
+ }
6850
+ `;
6851
+ const HeaderWrapperMixin$1 = styled.css `
6852
+ padding: 0.5rem 0.5rem 0;
6853
+
6854
+ ${Header} {
6855
+ min-height: 5.25rem;
6856
+ }
6857
+
6858
+ ${HeaderContainer} {
6859
+ max-width: 100%;
6860
+ width: 100%;
6861
+ }
6862
+
6863
+ ${FeatureControls} {
6864
+ max-width: calc(100% - 2rem);
6865
+ width: calc(100% - 2rem);
6866
+ margin-top: -0.5rem;
6867
+ padding-top: 1rem;
6868
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
6869
+ }
6870
+
6871
+ ${({ $fontColor }) => !!$fontColor && HeaderFontColorMixin$1};
6872
+ `;
6873
+ const GradientHeaderWrapper = styled.div `
6874
+ ${Header} {
6875
+ background: ${({ $bgColor }) => $bgColor || "radial-gradient(129.21% 133.22% at 51.94% 0%, #e8fffe 9.48%, #5fcaff 100%)"};
6876
+ }
6877
+
6878
+ ${HeaderContainer} {
6879
+ align-items: center;
6880
+ }
6881
+
6882
+ ${HeaderTitleContainer} {
6883
+ margin-left: 0;
6884
+ text-align: center;
6885
+ }
6886
+
6887
+ ${FeatureTitleContainer} {
6888
+ text-align: center;
6889
+ }
6890
+
6891
+ ${LayerDescription} {
6892
+ text-align: center;
6893
+ }
6894
+
6895
+ ${HeaderWrapperMixin$1};
6888
6896
  `;
6889
6897
 
6890
6898
  const FeatureCardGradientHeader = ({ isRow }) => {
@@ -6901,82 +6909,82 @@ const FeatureCardGradientHeader = ({ isRow }) => {
6901
6909
  }) })] }), jsxRuntime.jsx(FeatureCardButtons, {})] }) }) }) }));
6902
6910
  };
6903
6911
 
6904
- const HeaderFontColorMixin = styled.css `
6905
- ${HeaderTitleContainer}, ${LayerDescription} {
6906
- color: ${({ $fontColor }) => $fontColor};
6907
- }
6908
- `;
6909
- const HeaderWrapperMixin = styled.css `
6910
- padding: 0.5rem 0.5rem 0;
6911
-
6912
- ${Header} {
6913
- min-height: 5.25rem;
6914
- }
6915
-
6916
- ${HeaderContainer} {
6917
- max-width: 100%;
6918
- width: 100%;
6919
- }
6920
-
6921
- ${FeatureControls} {
6922
- max-width: calc(100% - 2rem);
6923
- width: calc(100% - 2rem);
6924
- margin-top: -0.5rem;
6925
- padding-top: 1rem;
6926
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
6927
- }
6928
-
6929
- ${({ $fontColor }) => !!$fontColor && HeaderFontColorMixin};
6930
- `;
6931
- const HeaderIcon = styled(uilibGl.Flex) `
6932
- position: absolute;
6933
- top: 0;
6934
- right: 0;
6935
- justify-content: flex-end;
6936
- align-items: center;
6937
- min-width: 7.5rem;
6938
- height: 100%;
6939
-
6940
- span[kind]:after {
6941
- font-size: 7.5rem;
6942
- }
6943
-
6944
- span[kind]:after,
6945
- path,
6946
- line,
6947
- circle {
6948
- fill: rgba(255, 255, 255, 0.36);
6949
- }
6950
-
6951
- && > * {
6952
- display: flex;
6953
- align-items: center;
6954
- height: 100%;
6955
- }
6956
- `;
6957
- const BigIconHeaderMixin = styled.css `
6958
- ${HeaderIcon} {
6959
- min-width: 14rem;
6960
- right: -3rem;
6961
-
6962
- span[kind]:after {
6963
- font-size: 14rem;
6964
- }
6965
- }
6966
- `;
6967
- const IconHeaderWrapper = styled.div `
6968
- ${Header} {
6969
- width: calc(100% + 3rem);
6970
- margin: -1.5rem -1.5rem 0 -1.5rem;
6971
- padding: 1.5rem;
6972
- border-top-left-radius: 0.5rem;
6973
- border-top-right-radius: 0.5rem;
6974
- background: ${({ $bgColor }) => $bgColor || "linear-gradient(96.55deg, #FFFCD3 0%, #B4DC47 100%)"};
6975
- }
6976
-
6977
- ${HeaderWrapperMixin};
6978
-
6979
- ${({ $bigIcon }) => $bigIcon && BigIconHeaderMixin};
6912
+ const HeaderFontColorMixin = styled.css `
6913
+ ${HeaderTitleContainer}, ${LayerDescription} {
6914
+ color: ${({ $fontColor }) => $fontColor};
6915
+ }
6916
+ `;
6917
+ const HeaderWrapperMixin = styled.css `
6918
+ padding: 0.5rem 0.5rem 0;
6919
+
6920
+ ${Header} {
6921
+ min-height: 5.25rem;
6922
+ }
6923
+
6924
+ ${HeaderContainer} {
6925
+ max-width: 100%;
6926
+ width: 100%;
6927
+ }
6928
+
6929
+ ${FeatureControls} {
6930
+ max-width: calc(100% - 2rem);
6931
+ width: calc(100% - 2rem);
6932
+ margin-top: -0.5rem;
6933
+ padding-top: 1rem;
6934
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
6935
+ }
6936
+
6937
+ ${({ $fontColor }) => !!$fontColor && HeaderFontColorMixin};
6938
+ `;
6939
+ const HeaderIcon = styled(uilibGl.Flex) `
6940
+ position: absolute;
6941
+ top: 0;
6942
+ right: 0;
6943
+ justify-content: flex-end;
6944
+ align-items: center;
6945
+ min-width: 7.5rem;
6946
+ height: 100%;
6947
+
6948
+ span[kind]:after {
6949
+ font-size: 7.5rem;
6950
+ }
6951
+
6952
+ span[kind]:after,
6953
+ path,
6954
+ line,
6955
+ circle {
6956
+ fill: rgba(255, 255, 255, 0.36);
6957
+ }
6958
+
6959
+ && > * {
6960
+ display: flex;
6961
+ align-items: center;
6962
+ height: 100%;
6963
+ }
6964
+ `;
6965
+ const BigIconHeaderMixin = styled.css `
6966
+ ${HeaderIcon} {
6967
+ min-width: 14rem;
6968
+ right: -3rem;
6969
+
6970
+ span[kind]:after {
6971
+ font-size: 14rem;
6972
+ }
6973
+ }
6974
+ `;
6975
+ const IconHeaderWrapper = styled.div `
6976
+ ${Header} {
6977
+ width: calc(100% + 3rem);
6978
+ margin: -1.5rem -1.5rem 0 -1.5rem;
6979
+ padding: 1.5rem;
6980
+ border-top-left-radius: 0.5rem;
6981
+ border-top-right-radius: 0.5rem;
6982
+ background: ${({ $bgColor }) => $bgColor || "linear-gradient(96.55deg, #FFFCD3 0%, #B4DC47 100%)"};
6983
+ }
6984
+
6985
+ ${HeaderWrapperMixin};
6986
+
6987
+ ${({ $bigIcon }) => $bigIcon && BigIconHeaderMixin};
6980
6988
  `;
6981
6989
 
6982
6990
  const FeatureCardIconHeader = ({ isRow }) => {
@@ -6996,15 +7004,15 @@ const FeatureCardIconHeader = ({ isRow }) => {
6996
7004
  }) })] }) }) }));
6997
7005
  };
6998
7006
 
6999
- const ImageContainerButton = styled(uilibGl.FlatButton) `
7000
- min-height: 1.5rem;
7001
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.large};
7002
- background-color: ${({ theme: { palette } }) => palette.primary};
7003
- text-transform: none;
7004
-
7005
- :hover {
7006
- background-color: ${({ theme: { palette } }) => palette.primaryDeep};
7007
- }
7007
+ const ImageContainerButton = styled(uilibGl.FlatButton) `
7008
+ min-height: 1.5rem;
7009
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.large};
7010
+ background-color: ${({ theme: { palette } }) => palette.primary};
7011
+ text-transform: none;
7012
+
7013
+ :hover {
7014
+ background-color: ${({ theme: { palette } }) => palette.primaryDeep};
7015
+ }
7008
7016
  `;
7009
7017
 
7010
7018
  const ElementButton = React.memo(({ type, elementConfig }) => {
@@ -7016,157 +7024,157 @@ const ElementButton = React.memo(({ type, elementConfig }) => {
7016
7024
  return (jsxRuntime.jsx(ImageContainerButton, { onClick: () => window.open(attribute?.value), children: elementConfig.value || "" }));
7017
7025
  });
7018
7026
 
7019
- const AttributeGalleryContainer = styled.div `
7020
- && {
7021
- width: calc(100% + 3rem);
7022
- }
7023
-
7024
- min-height: 12.625rem;
7025
- background-color: ${({ theme: { palette } }) => palette.element};
7026
-
7027
- img {
7028
- width: 100%;
7029
- }
7030
- `;
7031
- const LinearProgressContainer = styled(uilibGl.Flex) `
7032
- align-items: center;
7033
- justify-content: center;
7034
- min-height: inherit;
7035
-
7036
- ${uilibGl.LinearProgress} {
7037
- max-width: 4rem;
7038
- }
7039
- `;
7040
- const NoLiveSnapshotContainer = styled(uilibGl.Flex) `
7041
- flex-direction: column;
7042
- align-items: center;
7043
-
7044
- span[kind="alert"] {
7045
- width: 2rem;
7046
- height: 2rem;
7047
-
7048
- &:after {
7049
- font-size: 2rem;
7050
- color: ${({ theme: { palette } }) => palette.elementDeep};
7051
- }
7052
- }
7053
-
7054
- ${uilibGl.Description} {
7055
- font-size: 0.75rem;
7056
- color: ${({ theme: { palette } }) => palette.textDisabled};
7057
- }
7058
- `;
7059
- const SmallPreviewControl = styled(uilibGl.IconButton) `
7060
- cursor: ${({ $isDisabled }) => ($isDisabled ? "default" : "pointer")};
7061
- z-index: 3;
7062
- position: absolute;
7063
- top: 50%;
7064
- width: 2.5rem;
7065
- height: 2.5rem;
7066
- margin-top: -1.25rem;
7067
- background-color: rgba(61, 61, 61, 0.8);
7068
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.smallest};
7069
-
7070
- span:after {
7071
- color: ${({ $isDisabled }) => ($isDisabled ? "rgba(255, 255, 255, 0.28)" : "rgba(255, 255, 255, 1)")};
7072
- transition: color ${uilibGl.transition.hover};
7073
- }
7074
- `;
7075
- const SmallPreviewCounter = styled(uilibGl.Flex) `
7076
- z-index: 3;
7077
- position: absolute;
7078
- bottom: 0.625rem;
7079
- left: 0;
7080
- width: 100%;
7081
- height: 1rem;
7082
- justify-content: center;
7083
-
7084
- > div {
7085
- background-color: rgba(61, 61, 61, 0.8);
7086
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
7087
- padding: 0 0.5rem;
7088
- font-size: 0.625rem;
7089
- line-height: 1rem;
7090
- color: #fff;
7091
- }
7027
+ const AttributeGalleryContainer = styled.div `
7028
+ && {
7029
+ width: calc(100% + 3rem);
7030
+ }
7031
+
7032
+ min-height: 12.625rem;
7033
+ background-color: ${({ theme: { palette } }) => palette.element};
7034
+
7035
+ img {
7036
+ width: 100%;
7037
+ }
7038
+ `;
7039
+ const LinearProgressContainer = styled(uilibGl.Flex) `
7040
+ align-items: center;
7041
+ justify-content: center;
7042
+ min-height: inherit;
7043
+
7044
+ ${uilibGl.LinearProgress} {
7045
+ max-width: 4rem;
7046
+ }
7047
+ `;
7048
+ const NoLiveSnapshotContainer = styled(uilibGl.Flex) `
7049
+ flex-direction: column;
7050
+ align-items: center;
7051
+
7052
+ span[kind="alert"] {
7053
+ width: 2rem;
7054
+ height: 2rem;
7055
+
7056
+ &:after {
7057
+ font-size: 2rem;
7058
+ color: ${({ theme: { palette } }) => palette.elementDeep};
7059
+ }
7060
+ }
7061
+
7062
+ ${uilibGl.Description} {
7063
+ font-size: 0.75rem;
7064
+ color: ${({ theme: { palette } }) => palette.textDisabled};
7065
+ }
7066
+ `;
7067
+ const SmallPreviewControl = styled(uilibGl.IconButton) `
7068
+ cursor: ${({ $isDisabled }) => ($isDisabled ? "default" : "pointer")};
7069
+ z-index: 3;
7070
+ position: absolute;
7071
+ top: 50%;
7072
+ width: 2.5rem;
7073
+ height: 2.5rem;
7074
+ margin-top: -1.25rem;
7075
+ background-color: rgba(61, 61, 61, 0.8);
7076
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.smallest};
7077
+
7078
+ span:after {
7079
+ color: ${({ $isDisabled }) => ($isDisabled ? "rgba(255, 255, 255, 0.28)" : "rgba(255, 255, 255, 1)")};
7080
+ transition: color ${uilibGl.transition.hover};
7081
+ }
7082
+ `;
7083
+ const SmallPreviewCounter = styled(uilibGl.Flex) `
7084
+ z-index: 3;
7085
+ position: absolute;
7086
+ bottom: 0.625rem;
7087
+ left: 0;
7088
+ width: 100%;
7089
+ height: 1rem;
7090
+ justify-content: center;
7091
+
7092
+ > div {
7093
+ background-color: rgba(61, 61, 61, 0.8);
7094
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
7095
+ padding: 0 0.5rem;
7096
+ font-size: 0.625rem;
7097
+ line-height: 1rem;
7098
+ color: #fff;
7099
+ }
7092
7100
  `;
7093
7101
  const SmallPreviewLeft = styled(SmallPreviewControl).attrs(() => ({
7094
7102
  kind: "prev",
7095
- })) `
7096
- left: 1.5rem;
7103
+ })) `
7104
+ left: 1.5rem;
7097
7105
  `;
7098
7106
  const SmallPreviewRight = styled(SmallPreviewControl).attrs(() => ({
7099
7107
  kind: "next",
7100
- })) `
7101
- right: 1.5rem;
7102
- `;
7103
- const imgSlideShowMixin = styled.css `
7104
- &:nth-child(${({ prevIndex }) => prevIndex}) {
7105
- z-index: 2;
7106
- position: absolute;
7107
- top: 0;
7108
- left: 0;
7109
- right: 0;
7110
- bottom: 0;
7111
- opacity: 0;
7112
-
7113
- animation-duration: 0.25s;
7114
- animation-name: fadeOut;
7115
- animation-timing-function: linear;
7116
-
7117
- @keyframes fadeOut {
7118
- from {
7119
- opacity: 1;
7120
- }
7121
-
7122
- to {
7123
- opacity: 0;
7124
- }
7125
- }
7126
- }
7127
- `;
7128
- const SmallPreviewContainer$1 = styled.div `
7129
- cursor: ${({ onClick }) => (onClick ? "pointer" : "default")};
7130
- position: relative;
7131
- width: 100%;
7132
- height: 100%;
7133
- min-height: inherit;
7134
- line-height: 0;
7135
-
7136
- ${uilibGl.LinearProgress} {
7137
- z-index: 3;
7138
- position: absolute;
7139
- }
7140
-
7141
- ${SmallPreviewControl}, ${SmallPreviewCounter} {
7142
- opacity: 0;
7143
- transition: opacity ${uilibGl.transition.hover};
7144
- }
7145
-
7146
- &:hover {
7147
- ${SmallPreviewControl}, ${SmallPreviewCounter} {
7148
- opacity: 1;
7149
- }
7150
- }
7151
-
7152
- img {
7153
- z-index: 0;
7154
- cursor: pointer;
7155
- position: absolute;
7156
- top: 0;
7157
- left: 0;
7158
- width: 100%;
7159
- height: 100%;
7160
- min-height: inherit;
7161
- object-position: center;
7162
- object-fit: cover;
7163
-
7164
- &:nth-child(${({ currentIndex }) => currentIndex}) {
7165
- z-index: 1;
7166
- }
7167
-
7168
- ${({ prevIndex, currentIndex }) => prevIndex !== currentIndex && imgSlideShowMixin}
7169
- }
7108
+ })) `
7109
+ right: 1.5rem;
7110
+ `;
7111
+ const imgSlideShowMixin = styled.css `
7112
+ &:nth-child(${({ prevIndex }) => prevIndex}) {
7113
+ z-index: 2;
7114
+ position: absolute;
7115
+ top: 0;
7116
+ left: 0;
7117
+ right: 0;
7118
+ bottom: 0;
7119
+ opacity: 0;
7120
+
7121
+ animation-duration: 0.25s;
7122
+ animation-name: fadeOut;
7123
+ animation-timing-function: linear;
7124
+
7125
+ @keyframes fadeOut {
7126
+ from {
7127
+ opacity: 1;
7128
+ }
7129
+
7130
+ to {
7131
+ opacity: 0;
7132
+ }
7133
+ }
7134
+ }
7135
+ `;
7136
+ const SmallPreviewContainer$1 = styled.div `
7137
+ cursor: ${({ onClick }) => (onClick ? "pointer" : "default")};
7138
+ position: relative;
7139
+ width: 100%;
7140
+ height: 100%;
7141
+ min-height: inherit;
7142
+ line-height: 0;
7143
+
7144
+ ${uilibGl.LinearProgress} {
7145
+ z-index: 3;
7146
+ position: absolute;
7147
+ }
7148
+
7149
+ ${SmallPreviewControl}, ${SmallPreviewCounter} {
7150
+ opacity: 0;
7151
+ transition: opacity ${uilibGl.transition.hover};
7152
+ }
7153
+
7154
+ &:hover {
7155
+ ${SmallPreviewControl}, ${SmallPreviewCounter} {
7156
+ opacity: 1;
7157
+ }
7158
+ }
7159
+
7160
+ img {
7161
+ z-index: 0;
7162
+ cursor: pointer;
7163
+ position: absolute;
7164
+ top: 0;
7165
+ left: 0;
7166
+ width: 100%;
7167
+ height: 100%;
7168
+ min-height: inherit;
7169
+ object-position: center;
7170
+ object-fit: cover;
7171
+
7172
+ &:nth-child(${({ currentIndex }) => currentIndex}) {
7173
+ z-index: 1;
7174
+ }
7175
+
7176
+ ${({ prevIndex, currentIndex }) => prevIndex !== currentIndex && imgSlideShowMixin}
7177
+ }
7170
7178
  `;
7171
7179
  const SmallPreviewImages = styled.div ``;
7172
7180
 
@@ -7342,21 +7350,21 @@ const ElementChips = React.memo(({ type, elementConfig }) => {
7342
7350
  return (jsxRuntime.jsx(DashboardChipsContainer, { style: style, children: tags?.map(tag => (jsxRuntime.jsx(DashboardChip$1, { text: tag, "$bgColor": bgColor, "$fontColor": fontColor, "$fontSize": fontSize, "$isDefault": true }, tag))) }));
7343
7351
  });
7344
7352
 
7345
- const StyledIconFontSizeMixin = styled.css `
7346
- height: ${({ fontSize }) => `${fontSize}px`};
7347
-
7348
- &&:after {
7349
- font-size: ${({ fontSize }) => `${fontSize}px`};
7350
- }
7353
+ const StyledIconFontSizeMixin = styled.css `
7354
+ height: ${({ fontSize }) => `${fontSize}px`};
7355
+
7356
+ &&:after {
7357
+ font-size: ${({ fontSize }) => `${fontSize}px`};
7358
+ }
7351
7359
  `;
7352
- const StyledIconFontColorMixin = styled.css `
7353
- &&:after {
7354
- color: ${({ fontColor }) => fontColor};
7355
- }
7360
+ const StyledIconFontColorMixin = styled.css `
7361
+ &&:after {
7362
+ color: ${({ fontColor }) => fontColor};
7363
+ }
7356
7364
  `;
7357
- const StyledIcon = styled(uilibGl.Icon) `
7358
- ${({ fontSize }) => !!fontSize && StyledIconFontSizeMixin};
7359
- ${({ fontColor }) => !!fontColor && StyledIconFontColorMixin};
7365
+ const StyledIcon = styled(uilibGl.Icon) `
7366
+ ${({ fontSize }) => !!fontSize && StyledIconFontSizeMixin};
7367
+ ${({ fontColor }) => !!fontColor && StyledIconFontColorMixin};
7360
7368
  `;
7361
7369
 
7362
7370
  const ElementIcon = React.memo(({ type, elementConfig }) => {
@@ -7410,51 +7418,51 @@ const ElementLegend = React.memo(({ type, element, elementConfig, expandedContai
7410
7418
 
7411
7419
  const ExternalLink = styled(uilibGl.IconButton).attrs(() => ({
7412
7420
  kind: "external_link",
7413
- })) `
7414
- ${uilibGl.Icon} {
7415
- color: ${({ theme: { palette } }) => palette.primary};
7416
- }
7417
-
7418
- &:hover ${uilibGl.Icon} {
7419
- color: ${({ theme: { palette } }) => palette.primaryDeep};
7420
- }
7421
- `;
7422
- const LocalLinkBlank = styled(uilibGl.Blank) `
7423
- min-width: 13.5rem;
7424
- padding: 0.5rem 0.75rem 0;
7425
-
7426
- a {
7427
- text-decoration: none;
7428
- font-size: 0.75rem;
7429
- color: ${({ theme: { palette } }) => palette.primary};
7430
- }
7431
-
7432
- ${uilibGl.IconButtonButton} {
7433
- font-size: 0.75rem;
7434
- }
7421
+ })) `
7422
+ ${uilibGl.Icon} {
7423
+ color: ${({ theme: { palette } }) => palette.primary};
7424
+ }
7425
+
7426
+ &:hover ${uilibGl.Icon} {
7427
+ color: ${({ theme: { palette } }) => palette.primaryDeep};
7428
+ }
7429
+ `;
7430
+ const LocalLinkBlank = styled(uilibGl.Blank) `
7431
+ min-width: 13.5rem;
7432
+ padding: 0.5rem 0.75rem 0;
7433
+
7434
+ a {
7435
+ text-decoration: none;
7436
+ font-size: 0.75rem;
7437
+ color: ${({ theme: { palette } }) => palette.primary};
7438
+ }
7439
+
7440
+ ${uilibGl.IconButtonButton} {
7441
+ font-size: 0.75rem;
7442
+ }
7435
7443
  `;
7436
7444
  const LocalLinkButton = styled(uilibGl.IconButton).attrs(() => ({
7437
7445
  kind: "link",
7438
- })) `
7439
- width: 1rem;
7440
- height: 1rem;
7441
- background-color: ${({ theme: { palette } }) => palette.primary};
7442
- border-radius: 50%;
7443
-
7444
- span[kind] {
7445
- display: flex;
7446
- justify-content: center;
7447
- align-items: center;
7448
-
7449
- :after {
7450
- position: relative;
7451
- font-size: 0.6rem;
7452
- color: white;
7453
- }
7454
- }
7455
- `;
7456
- const LocalLinkCopy = styled(uilibGl.Flex) `
7457
- justify-content: center;
7446
+ })) `
7447
+ width: 1rem;
7448
+ height: 1rem;
7449
+ background-color: ${({ theme: { palette } }) => palette.primary};
7450
+ border-radius: 50%;
7451
+
7452
+ span[kind] {
7453
+ display: flex;
7454
+ justify-content: center;
7455
+ align-items: center;
7456
+
7457
+ :after {
7458
+ position: relative;
7459
+ font-size: 0.6rem;
7460
+ color: white;
7461
+ }
7462
+ }
7463
+ `;
7464
+ const LocalLinkCopy = styled(uilibGl.Flex) `
7465
+ justify-content: center;
7458
7466
  `;
7459
7467
 
7460
7468
  const LocalLink = React.memo(({ link }) => {
@@ -7476,9 +7484,9 @@ const ElementLink = React.memo(({ type, elementConfig }) => {
7476
7484
  return link.startsWith("http") ? jsxRuntime.jsx(ExternalLink, { onClick: () => window.open(link) }) : jsxRuntime.jsx(LocalLink, { link: link });
7477
7485
  });
7478
7486
 
7479
- const SmallPreviewContainer = styled.div `
7480
- width: 100%;
7481
- height: 100%;
7487
+ const SmallPreviewContainer = styled.div `
7488
+ width: 100%;
7489
+ height: 100%;
7482
7490
  `;
7483
7491
 
7484
7492
  const ElementSlideshow = ({ elementConfig, type, renderElement }) => {
@@ -7514,18 +7522,18 @@ const ElementSvg = React.memo(({ type, elementConfig }) => {
7514
7522
  return (jsxRuntime.jsx(SvgImage, { url: getSvgUrl({ elementConfig, layerInfo, attributes }), width: width, height: height, fontColor: fontColor }));
7515
7523
  });
7516
7524
 
7517
- const TooltipIcon = styled(uilibGl.Icon) `
7518
- &&& {
7519
- :after {
7520
- font-size: 0.75rem;
7521
- color: ${({ theme: { palette } }) => palette.iconDisabled};
7522
- transition: color ${uilibGl.transition.hover};
7523
- }
7524
-
7525
- :hover:after {
7526
- color: ${({ theme: { palette } }) => palette.icon};
7527
- }
7528
- }
7525
+ const TooltipIcon = styled(uilibGl.Icon) `
7526
+ &&& {
7527
+ :after {
7528
+ font-size: 0.75rem;
7529
+ color: ${({ theme: { palette } }) => palette.iconDisabled};
7530
+ transition: color ${uilibGl.transition.hover};
7531
+ }
7532
+
7533
+ :hover:after {
7534
+ color: ${({ theme: { palette } }) => palette.icon};
7535
+ }
7536
+ }
7529
7537
  `;
7530
7538
 
7531
7539
  const ElementTooltip = React.memo(({ type, elementConfig }) => {
@@ -7537,76 +7545,76 @@ const ElementTooltip = React.memo(({ type, elementConfig }) => {
7537
7545
  return text ? (jsxRuntime.jsx(uilibGl.Tooltip, { placement: "top", arrow: true, content: text, children: ref => jsxRuntime.jsx(TooltipIcon, { kind: icon || "question", ref: ref }) })) : null;
7538
7546
  });
7539
7547
 
7540
- const SlideshowHeaderWrapper = styled.div `
7541
- padding: ${({ withPadding }) => (withPadding ? "0.5rem 0.5rem 0" : 0)};
7542
-
7543
- ${Header} {
7544
- align-items: flex-start;
7545
- width: calc(100% + 2rem);
7546
- height: ${({ big }) => (big ? "15.5rem" : "auto")};
7547
- padding: 1.5rem;
7548
- margin: -1rem -1rem 0 -1rem;
7549
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
7550
-
7551
- ${SmallPreviewCounter} {
7552
- bottom: ${({ withPadding }) => (withPadding ? 0.625 : 1.125)}rem;
7553
- }
7554
-
7555
- :before,
7556
- :after {
7557
- content: "";
7558
- z-index: 2;
7559
- position: absolute;
7560
- top: 0;
7561
- left: 0;
7562
- width: 100%;
7563
- }
7564
-
7565
- :before {
7566
- height: 100%;
7567
- background: rgba(32, 46, 53, 0.25);
7568
- }
7569
-
7570
- :after {
7571
- height: 4.5rem;
7572
- background: linear-gradient(180deg, #000000 0%, rgba(0, 0, 0, 0) 100%);
7573
- }
7574
-
7575
- :hover {
7576
- ${SmallPreviewControl}, ${SmallPreviewCounter} {
7577
- opacity: 1;
7578
- }
7579
- }
7580
- }
7581
- `;
7582
- const ImageContainerBg = styled.div `
7583
- position: absolute;
7584
- top: 0;
7585
- bottom: 0;
7586
- left: 0;
7587
- right: 0;
7588
-
7589
- img {
7590
- width: 100%;
7591
- height: 100%;
7592
- object-position: center;
7593
- object-fit: cover;
7594
- }
7595
- `;
7596
- const HeaderSlideshow = styled.div `
7597
- position: absolute;
7598
- top: 0;
7599
- bottom: ${({ height }) => (height ? `${height}px` : 0)};
7600
- left: 0;
7601
- right: 0;
7602
-
7603
- img {
7604
- width: 100%;
7605
- height: 100%;
7606
- min-height: inherit;
7607
- object-position: center;
7608
- object-fit: cover;
7609
- }
7548
+ const SlideshowHeaderWrapper = styled.div `
7549
+ padding: ${({ withPadding }) => (withPadding ? "0.5rem 0.5rem 0" : 0)};
7550
+
7551
+ ${Header} {
7552
+ align-items: flex-start;
7553
+ width: calc(100% + 2rem);
7554
+ height: ${({ big }) => (big ? "15.5rem" : "auto")};
7555
+ padding: 1.5rem;
7556
+ margin: -1rem -1rem 0 -1rem;
7557
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
7558
+
7559
+ ${SmallPreviewCounter} {
7560
+ bottom: ${({ withPadding }) => (withPadding ? 0.625 : 1.125)}rem;
7561
+ }
7562
+
7563
+ :before,
7564
+ :after {
7565
+ content: "";
7566
+ z-index: 2;
7567
+ position: absolute;
7568
+ top: 0;
7569
+ left: 0;
7570
+ width: 100%;
7571
+ }
7572
+
7573
+ :before {
7574
+ height: 100%;
7575
+ background: rgba(32, 46, 53, 0.25);
7576
+ }
7577
+
7578
+ :after {
7579
+ height: 4.5rem;
7580
+ background: linear-gradient(180deg, #000000 0%, rgba(0, 0, 0, 0) 100%);
7581
+ }
7582
+
7583
+ :hover {
7584
+ ${SmallPreviewControl}, ${SmallPreviewCounter} {
7585
+ opacity: 1;
7586
+ }
7587
+ }
7588
+ }
7589
+ `;
7590
+ const ImageContainerBg = styled.div `
7591
+ position: absolute;
7592
+ top: 0;
7593
+ bottom: 0;
7594
+ left: 0;
7595
+ right: 0;
7596
+
7597
+ img {
7598
+ width: 100%;
7599
+ height: 100%;
7600
+ object-position: center;
7601
+ object-fit: cover;
7602
+ }
7603
+ `;
7604
+ const HeaderSlideshow = styled.div `
7605
+ position: absolute;
7606
+ top: 0;
7607
+ bottom: ${({ height }) => (height ? `${height}px` : 0)};
7608
+ left: 0;
7609
+ right: 0;
7610
+
7611
+ img {
7612
+ width: 100%;
7613
+ height: 100%;
7614
+ min-height: inherit;
7615
+ object-position: center;
7616
+ object-fit: cover;
7617
+ }
7610
7618
  `;
7611
7619
 
7612
7620
  const FeatureCardSlideshowHeader = ({ isRow }) => {
@@ -8792,11 +8800,26 @@ const useDataSources = ({ type: widgetType, config, attributes, filters, layerPa
8792
8800
  const { dataSources } = useWidgetContext(widgetType);
8793
8801
  const { filters: configFilters, dataSources: configDataSources } = config || {};
8794
8802
  const prevFilters = React.useRef({});
8795
- const getDataSourcePromises = React.useCallback(async ({ ds, query, parameters, layerName, limit, condition, url, resourceId, type }, newFilters, offset = 0) => {
8803
+ const getDataSourcePromises = React.useCallback(async ({ ds, query, parameters, layerName, limit, condition, url, resourceId }, newFilters, offset = 0) => {
8796
8804
  const selectedFilters = {
8797
8805
  ...(filters || {}),
8798
8806
  ...(newFilters || {}),
8799
8807
  };
8808
+ if (resourceId) {
8809
+ const response = await api.remoteTaskManager.post({
8810
+ workerType: "pythonService",
8811
+ methodType: "pythonrunner/run",
8812
+ data: {
8813
+ method: "get",
8814
+ resourceId,
8815
+ parameters,
8816
+ }
8817
+ });
8818
+ return {
8819
+ items: response.result.items,
8820
+ attributeDefinition: null,
8821
+ };
8822
+ }
8800
8823
  const newParams = applyQueryFilters({
8801
8824
  parameters,
8802
8825
  dataSources,
@@ -8804,8 +8827,8 @@ const useDataSources = ({ type: widgetType, config, attributes, filters, layerPa
8804
8827
  filters: configFilters,
8805
8828
  geometry: ewktGeometry,
8806
8829
  });
8807
- if (url || resourceId) {
8808
- const response = await fetch(url || `https://beta5.evergis.ru/sp/${type}/resource/run?resourceId=${resourceId}`, {
8830
+ if (url) {
8831
+ const response = await fetch(url, {
8809
8832
  method: "POST",
8810
8833
  headers: {
8811
8834
  Accept: "application/json",
@@ -9175,6 +9198,7 @@ const Chart = React.memo(({ config, element, elementConfig, type, renderElement
9175
9198
  fontColor,
9176
9199
  relatedAttributes,
9177
9200
  defaultColor: primaryColor,
9201
+ markers: configMarkers,
9178
9202
  showMarkers,
9179
9203
  });
9180
9204
  const { formatFilterColor, onFilter } = useFeatureFilters(type, filterName, data?.[0]?.items);
@@ -9204,6 +9228,15 @@ const Chart = React.memo(({ config, element, elementConfig, type, renderElement
9204
9228
  })] }));
9205
9229
  }, [labels, layerInfos]);
9206
9230
  const markers = React.useMemo(() => getChartMarkers(data[0]?.items, configMarkers, dataSources), [data, dataSources, configMarkers]);
9231
+ const margin = React.useMemo(() => {
9232
+ const markersMargin = showMarkers ? 10 : 0;
9233
+ return {
9234
+ top: markersMargin,
9235
+ right: markersMargin,
9236
+ bottom: markers?.length ? 20 : markersMargin,
9237
+ left: markersMargin
9238
+ };
9239
+ }, [showMarkers, markers?.length]);
9207
9240
  const formatTooltipName = React.useCallback((name) => (isRelated ? name : tooltipNameFromAttributes(name, formattedAttributes)), [formattedAttributes, isRelated]);
9208
9241
  const formatTooltipValue = React.useCallback((value, name) => isRelated
9209
9242
  ? tooltipValueFromRelatedFeatures(t, value, relatedAttributes, data[0]?.layerInfo)
@@ -9212,11 +9245,14 @@ const Chart = React.memo(({ config, element, elementConfig, type, renderElement
9212
9245
  yAxisLeft.tickFormat((index) => index);
9213
9246
  }, []);
9214
9247
  const customXAxisBottom = React.useCallback((xAxisBottom, data) => {
9215
- xAxisBottom.tickFormat((index) => (showMarkers
9216
- ? index % (showMarkers || 1) === 0
9217
- : index === 0 || index === data.length - 1)
9218
- ? data[index]?.groupName || "" : "");
9219
- }, [showMarkers]);
9248
+ xAxisBottom.tickFormat((index) => markers
9249
+ ? ""
9250
+ : (showMarkers
9251
+ ? index % showMarkers === 0
9252
+ : index === 0 || index === data.length - 1)
9253
+ ? data[index]?.groupName || ""
9254
+ : "");
9255
+ }, [markers, showMarkers]);
9220
9256
  const renderChart = React.useMemo(() => {
9221
9257
  if (!element)
9222
9258
  return null;
@@ -9234,16 +9270,11 @@ const Chart = React.memo(({ config, element, elementConfig, type, renderElement
9234
9270
  .flat()
9235
9271
  .map(({ values }) => values)
9236
9272
  .flat();
9237
- return (jsxRuntime.jsxs(AnyChartWrapper, { height: height, children: [jsxRuntime.jsx(LineChartStyles, {}), jsxRuntime.jsx(charts.LineChart, { data: lineChartData, labels: labels, width: +width, height: height, xAxisPadding: 15, yAxisPadding: 0, min: Math.min(...chartValues), customYAxisSelection: yAxis => {
9273
+ return (jsxRuntime.jsxs(AnyChartWrapper, { height: height, children: [jsxRuntime.jsx(LineChartStyles, {}), jsxRuntime.jsx(charts.LineChart, { data: lineChartData, labels: labels, markers: markers, width: +width, height: height, xAxisPadding: 15, yAxisPadding: 0, min: Math.min(...chartValues), customYAxisSelection: yAxis => {
9238
9274
  if (isHidedY) {
9239
9275
  yAxis.remove();
9240
9276
  }
9241
- }, customYAxis: yAxis => yAxis.ticks(4), renderTooltip: renderLineChartTooltip, customize: customize, dynamicTooltipEnable: true, stackedTooltip: true, tooltipClassName: "dashboardLineChartTooltip", drawGridX: !isHidedY, margin: {
9242
- top: 0,
9243
- right: 0,
9244
- bottom: 0,
9245
- left: 0
9246
- } })] }));
9277
+ }, customYAxis: yAxis => yAxis.ticks(4), renderTooltip: renderLineChartTooltip, customize: customize, dynamicTooltipEnable: true, stackedTooltip: true, tooltipClassName: "dashboardLineChartTooltip", drawGridX: !isHidedY, margin: margin })] }));
9247
9278
  }
9248
9279
  if (isStackBar) {
9249
9280
  return (jsxRuntime.jsx(AnyChartWrapper, { height: height, children: jsxRuntime.jsx(StackBar, { data: data, filterName: filterName, type: type, alias: elementConfig?.children?.find(child => child.id === "alias"), options: options, renderTooltip: renderPieChartTooltip, renderElement: renderElement }) }));
@@ -9257,13 +9288,6 @@ const Chart = React.memo(({ config, element, elementConfig, type, renderElement
9257
9288
  })) || []), width: +width, height: +width, padAngle: angle, outerRadius: radius, cornerRadius: cornerRadius, renderTooltip: renderPieChartTooltip, withTooltip: true, onClick: filterName ? item => onFilter(item.name) : undefined, children: showTotal && jsxRuntime.jsx(PieChartCenter, { children: totalWord || roundTotalSum(+totalSum) }) }) }));
9258
9289
  }
9259
9290
  const barChartData = getDataFromFilterItems(data[0]?.items);
9260
- const markersMargin = showMarkers ? 10 : 0;
9261
- const margin = {
9262
- top: markersMargin,
9263
- right: markersMargin,
9264
- bottom: markers?.length ? 20 : markersMargin,
9265
- left: markersMargin
9266
- };
9267
9291
  return (jsxRuntime.jsx(BarChartWrapper, { height: height + margin.bottom, children: jsxRuntime.jsx(BarChartContainer, { children: jsxRuntime.jsx(StyledBarChart, { data: barChartData, colors: getColorsFromFilterItems(data[0]?.items, defaultColor, formatFilterColor), minValue: getMinValueFromFilterItems(data[0]?.items), markers: markers, width: +width, height: height, barWidth: barWidth, barPadding: padding, customYAxisLeft: customYAxisLeft, customXAxisBottom: xAxisBottom => customXAxisBottom(xAxisBottom, barChartData), customYAxis: axis => !showLabels && axis.remove(), customBars: ({ bars }) => {
9268
9292
  bars.attr("rx", radius);
9269
9293
  bars.attr("ry", radius);
@@ -9290,6 +9314,7 @@ const Chart = React.memo(({ config, element, elementConfig, type, renderElement
9290
9314
  filterName,
9291
9315
  axes,
9292
9316
  labels,
9317
+ margin,
9293
9318
  renderLineChartTooltip,
9294
9319
  customize,
9295
9320
  primaryColor,
@@ -9351,8 +9376,8 @@ const Dashboard = React.memo(({ type = exports.WidgetType.Dashboard, config }) =
9351
9376
  return (jsxRuntime.jsx(ConfigProvider, { config: config, children: jsxRuntime.jsx(PagesContainer, { type: type }) }));
9352
9377
  });
9353
9378
 
9354
- const CardCheckbox = styled(uilibGl.Checkbox) `
9355
- padding-left: 0.5rem;
9379
+ const CardCheckbox = styled(uilibGl.Checkbox) `
9380
+ padding-left: 0.5rem;
9356
9381
  `;
9357
9382
 
9358
9383
  const DashboardCheckbox = ({ title, checked, onChange, }) => {
@@ -9427,15 +9452,15 @@ const FeatureCardTitle = ({ title, description }) => {
9427
9452
  return (jsxRuntime.jsxs(HeaderTitleContainer, { children: [jsxRuntime.jsx(FeatureTitleContainer, { clickable: true, children: jsxRuntime.jsx(uilibGl.Tooltip, { arrow: true, placement: "top", content: t("zoomToFeature", { ns: "dashboard", defaultValue: "Приблизить к объекту" }), delay: [600, 0], children: ref => (jsxRuntime.jsx(uilibGl.FlexSpan, { ref: ref, onClick: () => zoomToFeatures([feature]), children: resultTitle })) }) }), jsxRuntime.jsx(LayerDescription, { title: resultDescription, children: resultDescription })] }));
9428
9453
  };
9429
9454
 
9430
- const HiddenFilters = styled(uilibGl.Flex) `
9431
- flex-wrap: wrap;
9432
- margin-top: -1.25rem;
9433
-
9434
- ${DashboardChip$1} {
9435
- height: 1.5rem;
9436
- margin: 0 0.25rem 0.25rem 0;
9437
- padding: 0 0 0 0.5rem;
9438
- }
9455
+ const HiddenFilters = styled(uilibGl.Flex) `
9456
+ flex-wrap: wrap;
9457
+ margin-top: -1.25rem;
9458
+
9459
+ ${DashboardChip$1} {
9460
+ height: 1.5rem;
9461
+ margin: 0 0.25rem 0.25rem 0;
9462
+ padding: 0 0 0 0.5rem;
9463
+ }
9439
9464
  `;
9440
9465
 
9441
9466
  function spliceValue(filterValue, splicingValue) {
@@ -9505,24 +9530,24 @@ const HiddenTitleItems = React.memo(({ elementConfig, config, type, filter }) =>
9505
9530
  getConfigFilter(filterName, configFilters)?.defaultValue, index)) }));
9506
9531
  });
9507
9532
 
9508
- const PageNavigator = styled(uilibGl.Flex) `
9509
- margin-right: -0.5rem;
9510
- align-items: center;
9511
-
9512
- button {
9513
- width: auto;
9514
- height: 1.5rem;
9515
- padding: 0 0.5rem;
9516
-
9517
- span[kind]:after {
9518
- color: ${({ theme: { palette } }) => palette.textDisabled};
9519
- transition: color ${uilibGl.transition.hover};
9520
- }
9521
-
9522
- :hover span[kind]:after {
9523
- color: ${({ theme: { palette } }) => palette.textSecondary};
9524
- }
9525
- }
9533
+ const PageNavigator = styled(uilibGl.Flex) `
9534
+ margin-right: -0.5rem;
9535
+ align-items: center;
9536
+
9537
+ button {
9538
+ width: auto;
9539
+ height: 1.5rem;
9540
+ padding: 0 0.5rem;
9541
+
9542
+ span[kind]:after {
9543
+ color: ${({ theme: { palette } }) => palette.textDisabled};
9544
+ transition: color ${uilibGl.transition.hover};
9545
+ }
9546
+
9547
+ :hover span[kind]:after {
9548
+ color: ${({ theme: { palette } }) => palette.textSecondary};
9549
+ }
9550
+ }
9526
9551
  `;
9527
9552
 
9528
9553
  const Pagination = React.memo(({ type = exports.WidgetType.Dashboard }) => {
@@ -9531,34 +9556,34 @@ const Pagination = React.memo(({ type = exports.WidgetType.Dashboard }) => {
9531
9556
  return (jsxRuntime.jsxs(PageNavigator, { children: [jsxRuntime.jsx(uilibGl.IconButton, { kind: "prev", onClick: () => prevPage(pages.length) }), jsxRuntime.jsx(uilibGl.IconButton, { kind: "next", onClick: () => nextPage(pages.length) })] }));
9532
9557
  });
9533
9558
 
9534
- const StyledSvgWidthMixin = styled.css `
9535
- &&& {
9536
- svg {
9537
- width: ${({ $width }) => $width}px;
9538
- }
9539
- }
9540
- `;
9541
- const StyledSvgHeightMixin = styled.css `
9542
- &&& {
9543
- svg {
9544
- height: ${({ $height }) => $height}px;
9545
- }
9546
- }
9547
- `;
9548
- const StyledSvgColorMixin = styled.css `
9549
- svg {
9550
- path,
9551
- line,
9552
- circle {
9553
- fill: ${({ $fontColor }) => $fontColor} !important;
9554
- }
9555
- }
9556
- `;
9557
- const StyledSvg = styled(uilibGl.Flex) `
9558
- align-items: center;
9559
- ${({ $width }) => !!$width && StyledSvgWidthMixin};
9560
- ${({ $height }) => !!$height && StyledSvgHeightMixin};
9561
- ${({ $fontColor }) => !!$fontColor && StyledSvgColorMixin};
9559
+ const StyledSvgWidthMixin = styled.css `
9560
+ &&& {
9561
+ svg {
9562
+ width: ${({ $width }) => $width}px;
9563
+ }
9564
+ }
9565
+ `;
9566
+ const StyledSvgHeightMixin = styled.css `
9567
+ &&& {
9568
+ svg {
9569
+ height: ${({ $height }) => $height}px;
9570
+ }
9571
+ }
9572
+ `;
9573
+ const StyledSvgColorMixin = styled.css `
9574
+ svg {
9575
+ path,
9576
+ line,
9577
+ circle {
9578
+ fill: ${({ $fontColor }) => $fontColor} !important;
9579
+ }
9580
+ }
9581
+ `;
9582
+ const StyledSvg = styled(uilibGl.Flex) `
9583
+ align-items: center;
9584
+ ${({ $width }) => !!$width && StyledSvgWidthMixin};
9585
+ ${({ $height }) => !!$height && StyledSvgHeightMixin};
9586
+ ${({ $fontColor }) => !!$fontColor && StyledSvgColorMixin};
9562
9587
  `;
9563
9588
 
9564
9589
  const SvgImage = React.memo(({ url, width, height, fontColor }) => {
@@ -9787,28 +9812,28 @@ const Layer = ({ layer, layerType, visible, beforeId, tileUrl, getLayerTempStyle
9787
9812
  return (jsxRuntime.jsx(VectorLayer, { layer: layer, tileUrl: tileUrl, visible: visible, beforeId: beforeId, getLayerTempStyle: getLayerTempStyle }));
9788
9813
  };
9789
9814
 
9790
- const MapWrapper = styled.div `
9791
- position: relative;
9792
- width: 100%;
9793
- height: 100%;
9794
- box-sizing: border-box;
9795
- z-index: ${({ $zIndex }) => $zIndex ?? 1};
9796
-
9797
- .mapbox-gl-draw_trash {
9798
- display: none;
9799
- }
9800
-
9801
- .mapboxgl-ctrl-logo {
9802
- display: none;
9803
- }
9804
-
9805
- .mapboxgl-ctrl.mapboxgl-ctrl-attrib {
9806
- display: none;
9807
- }
9808
-
9809
- .mapboxgl-ctrl-geocoder.mapboxgl-ctrl {
9810
- width: 350px;
9811
- }
9815
+ const MapWrapper = styled.div `
9816
+ position: relative;
9817
+ width: 100%;
9818
+ height: 100%;
9819
+ box-sizing: border-box;
9820
+ z-index: ${({ $zIndex }) => $zIndex ?? 1};
9821
+
9822
+ .mapbox-gl-draw_trash {
9823
+ display: none;
9824
+ }
9825
+
9826
+ .mapboxgl-ctrl-logo {
9827
+ display: none;
9828
+ }
9829
+
9830
+ .mapboxgl-ctrl.mapboxgl-ctrl-attrib {
9831
+ display: none;
9832
+ }
9833
+
9834
+ .mapboxgl-ctrl-geocoder.mapboxgl-ctrl {
9835
+ width: 350px;
9836
+ }
9812
9837
  `;
9813
9838
 
9814
9839
  const Map$1 = ({ zIndex, lowerSiblings, upperSiblings, onError, children, ...rest }) => {