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