@evergis/react 3.1.31 → 3.1.33

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.js CHANGED
@@ -27,180 +27,180 @@ const AddFeatureButton = ({ title, icon = "feature_add" /* , layerName, geometry
27
27
  return (jsxRuntime.jsx(uilibGl.IconButton, { kind: icon, primary: true, onClick: handleAddFeature, children: title }));
28
28
  };
29
29
 
30
- const ChartTooltipTable = styled.table `
31
- td {
32
- padding: 0;
33
- }
34
-
35
- tr:not(:last-child) td {
36
- padding-bottom: 0.375rem;
37
- }
38
- `;
39
- const ChartTooltip = styled(uilibGl.Flex) `
40
- flex-wrap: nowrap;
41
- background: rgb(48, 69, 79);
42
- border-radius: 0.25rem;
43
- color: white;
44
-
45
- :not(:last-child) {
46
- margin-bottom: 0.25rem;
47
- }
48
- `;
49
- const ChartTooltipLabel = styled.div `
50
- margin-right: 0.25rem;
51
- `;
52
- const ChartTooltipColor = styled.div `
53
- width: 0.625rem;
54
- height: 0.625rem;
55
- background-color: ${({ $color }) => $color};
56
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.smallest};
57
- margin-right: 0.25rem;
58
- `;
59
- const ChartLegendColor$1 = styled.div `
60
- width: 0.5rem;
61
- height: 0.5rem;
62
- background-color: ${({ $color }) => $color};
63
- border-radius: 0.125rem;
64
- `;
65
- const ChartLegendValue = styled.div `
66
- opacity: 0.65;
67
- `;
68
- const ChartTooltipRow = styled(uilibGl.Flex) `
69
- display: flex;
70
- flex-direction: row;
71
- flex-wrap: nowrap;
72
- align-items: center;
73
- margin-top: 0.5rem;
74
- line-height: 0;
75
-
76
- ${ChartLegendColor$1} {
77
- margin-right: 0.25rem;
78
- }
79
- `;
80
- const ChartTooltipName = styled.div `
81
- margin-right: 1rem;
82
- opacity: 0.65;
83
- `;
84
- const PieChartCenter = styled.div `
85
- position: absolute;
86
- top: 50%;
87
- left: 50%;
88
- transform: translate(-50%, -50%);
89
- text-align: center;
90
- font-weight: bold;
91
- font-size: 1.5rem;
92
- `;
93
- const ChartWrapperContainer = styled.div `
94
- position: relative;
95
- width: 100%;
96
- `;
97
- const Tooltip = styled.div `
98
- position: relative;
99
- border-radius: 0.25rem;
100
- background-color: rgba(28, 33, 48);
101
- padding: 0.5rem;
102
- box-shadow: 0 0.125rem 0.25rem 0 rgba(0, 0, 0, 0.15);
103
- font-size: 0.75rem;
104
- transform: ${({ transform }) => transform};
105
- color: white;
106
-
107
- :before {
108
- position: absolute;
109
- display: block;
110
- content: "";
111
- width: 0;
112
- height: 0;
113
- }
114
- `;
115
- const LineChartStyles = styled.createGlobalStyle `
116
- .dashboardLineChartTooltip.${charts.lineChartClassNames.lineChartMouseLabel} {
117
- .${charts.lineChartClassNames.lineChartLabelFlex} {
118
- justify-content: center;
119
- align-items: flex-end;
120
-
121
- ${Tooltip} {
122
- margin: 0 0 12px 0;
123
-
124
- :before {
125
- top: auto;
126
- bottom: 0;
127
- left: 50%;
128
- transform: translate(-50%, 100%);
129
- border-left: 4px solid transparent;
130
- border-right: 4px solid transparent;
131
- border-top: 4px solid rgba(28, 33, 48, 0.9);
132
- }
133
- }
134
- }
135
- }
136
-
137
- .${charts.lineChartClassNames.lineChartYScaleGlobal}, .${charts.lineChartClassNames.lineChartXScaleGlobal} {
138
- .domain {
139
- visibility: hidden;
140
- }
141
-
142
- .tick {
143
- text {
144
- fill: ${({ theme: { palette } }) => palette.textDisabled};
145
- }
146
-
147
- line {
148
- visibility: hidden;
149
- }
150
- }
151
- }
152
-
153
- .${charts.lineChartClassNames.lineChartXScaleGlobal} {
154
- .tick {
155
- :first-of-type {
156
- text {
157
- text-anchor: start;
158
- }
159
- }
160
-
161
- :last-of-type {
162
- text {
163
- text-anchor: end;
164
- }
165
- }
166
- }
167
- }
168
-
169
- .${charts.lineChartClassNames.lineChartLine} {
170
- stroke-width: 2px;
171
- }
172
-
173
- .${charts.lineChartClassNames.lineChartLabel} {
174
- color: ${({ theme: { palette } }) => palette.textPrimary};
175
- }
176
-
177
- .${charts.lineChartClassNames.lineChartMouseCircle} {
178
- stroke: #ffffff;
179
- stroke-width: 2px;
180
- }
181
-
182
- .${charts.lineChartClassNames.lineChartGridLineX} {
183
- stroke: ${({ theme: { palette } }) => palette.element};
184
- }
185
-
186
- text {
187
- fill: ${({ theme: { palette } }) => palette.textDisabled};
188
- }
189
- `;
190
- const StyledBarChart = styled(charts.BarChart) `
191
- .domain {
192
- display: none;
193
- }
194
-
195
- .tick {
196
- text {
197
- fill: ${({ theme: { palette } }) => palette.textDisabled};
198
- }
199
-
200
- line {
201
- visibility: hidden;
202
- }
203
- }
30
+ const ChartTooltipTable = styled.table `
31
+ td {
32
+ padding: 0;
33
+ }
34
+
35
+ tr:not(:last-child) td {
36
+ padding-bottom: 0.375rem;
37
+ }
38
+ `;
39
+ const ChartTooltip = styled(uilibGl.Flex) `
40
+ flex-wrap: nowrap;
41
+ background: rgb(48, 69, 79);
42
+ border-radius: 0.25rem;
43
+ color: white;
44
+
45
+ :not(:last-child) {
46
+ margin-bottom: 0.25rem;
47
+ }
48
+ `;
49
+ const ChartTooltipLabel = styled.div `
50
+ margin-right: 0.25rem;
51
+ `;
52
+ const ChartTooltipColor = styled.div `
53
+ width: 0.625rem;
54
+ height: 0.625rem;
55
+ background-color: ${({ $color }) => $color};
56
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.smallest};
57
+ margin-right: 0.25rem;
58
+ `;
59
+ const ChartLegendColor$1 = styled.div `
60
+ width: 0.5rem;
61
+ height: 0.5rem;
62
+ background-color: ${({ $color }) => $color};
63
+ border-radius: 0.125rem;
64
+ `;
65
+ const ChartLegendValue = styled.div `
66
+ opacity: 0.65;
67
+ `;
68
+ const ChartTooltipRow = styled(uilibGl.Flex) `
69
+ display: flex;
70
+ flex-direction: row;
71
+ flex-wrap: nowrap;
72
+ align-items: center;
73
+ margin-top: 0.5rem;
74
+ line-height: 0;
75
+
76
+ ${ChartLegendColor$1} {
77
+ margin-right: 0.25rem;
78
+ }
79
+ `;
80
+ const ChartTooltipName = styled.div `
81
+ margin-right: 1rem;
82
+ opacity: 0.65;
83
+ `;
84
+ const PieChartCenter = styled.div `
85
+ position: absolute;
86
+ top: 50%;
87
+ left: 50%;
88
+ transform: translate(-50%, -50%);
89
+ text-align: center;
90
+ font-weight: bold;
91
+ font-size: 1.5rem;
92
+ `;
93
+ const ChartWrapperContainer = styled.div `
94
+ position: relative;
95
+ width: 100%;
96
+ `;
97
+ const Tooltip = styled.div `
98
+ position: relative;
99
+ border-radius: 0.25rem;
100
+ background-color: rgba(28, 33, 48);
101
+ padding: 0.5rem;
102
+ box-shadow: 0 0.125rem 0.25rem 0 rgba(0, 0, 0, 0.15);
103
+ font-size: 0.75rem;
104
+ transform: ${({ transform }) => transform};
105
+ color: white;
106
+
107
+ :before {
108
+ position: absolute;
109
+ display: block;
110
+ content: "";
111
+ width: 0;
112
+ height: 0;
113
+ }
114
+ `;
115
+ const LineChartStyles = styled.createGlobalStyle `
116
+ .dashboardLineChartTooltip.${charts.lineChartClassNames.lineChartMouseLabel} {
117
+ .${charts.lineChartClassNames.lineChartLabelFlex} {
118
+ justify-content: center;
119
+ align-items: flex-end;
120
+
121
+ ${Tooltip} {
122
+ margin: 0 0 12px 0;
123
+
124
+ :before {
125
+ top: auto;
126
+ bottom: 0;
127
+ left: 50%;
128
+ transform: translate(-50%, 100%);
129
+ border-left: 4px solid transparent;
130
+ border-right: 4px solid transparent;
131
+ border-top: 4px solid rgba(28, 33, 48, 0.9);
132
+ }
133
+ }
134
+ }
135
+ }
136
+
137
+ .${charts.lineChartClassNames.lineChartYScaleGlobal}, .${charts.lineChartClassNames.lineChartXScaleGlobal} {
138
+ .domain {
139
+ visibility: hidden;
140
+ }
141
+
142
+ .tick {
143
+ text {
144
+ fill: ${({ theme: { palette } }) => palette.textDisabled};
145
+ }
146
+
147
+ line {
148
+ visibility: hidden;
149
+ }
150
+ }
151
+ }
152
+
153
+ .${charts.lineChartClassNames.lineChartXScaleGlobal} {
154
+ .tick {
155
+ :first-of-type {
156
+ text {
157
+ text-anchor: start;
158
+ }
159
+ }
160
+
161
+ :last-of-type {
162
+ text {
163
+ text-anchor: end;
164
+ }
165
+ }
166
+ }
167
+ }
168
+
169
+ .${charts.lineChartClassNames.lineChartLine} {
170
+ stroke-width: 2px;
171
+ }
172
+
173
+ .${charts.lineChartClassNames.lineChartLabel} {
174
+ color: ${({ theme: { palette } }) => palette.textPrimary};
175
+ }
176
+
177
+ .${charts.lineChartClassNames.lineChartMouseCircle} {
178
+ stroke: #ffffff;
179
+ stroke-width: 2px;
180
+ }
181
+
182
+ .${charts.lineChartClassNames.lineChartGridLineX} {
183
+ stroke: ${({ theme: { palette } }) => palette.element};
184
+ }
185
+
186
+ text {
187
+ fill: ${({ theme: { palette } }) => palette.textDisabled};
188
+ }
189
+ `;
190
+ const StyledBarChart = styled(charts.BarChart) `
191
+ .domain {
192
+ display: none;
193
+ }
194
+
195
+ .tick {
196
+ text {
197
+ fill: ${({ theme: { palette } }) => palette.textDisabled};
198
+ }
199
+
200
+ line {
201
+ visibility: hidden;
202
+ }
203
+ }
204
204
  `;
205
205
 
206
206
  function range(start, stop, step) {
@@ -3428,42 +3428,42 @@ const NUMERIC_ATTRIBUTE_TYPES = [api.AttributeType.Double, api.AttributeType.Int
3428
3428
  const GEOMETRY_ATTRIBUTE = "geometry";
3429
3429
  const DEFAULT_ID_ATTRIBUTE_NAME = "gid";
3430
3430
 
3431
- const StackBarContainer = styled(uilibGl.Flex) `
3432
- flex-wrap: nowrap;
3433
- width: 100%;
3434
- `;
3435
- const StackBarHeader = styled(uilibGl.Flex) `
3436
- justify-content: space-between;
3437
- margin-bottom: 0.375rem;
3438
- font-size: 0.75rem;
3439
- `;
3440
- const StackBarSection = styled.div `
3441
- cursor: ${({ onClick }) => (onClick ? "pointer" : "default")};
3442
- width: ${({ $width }) => $width}%;
3443
- height: ${({ $height }) => ($height ? `${$height}px` : "0.5rem")};
3444
- margin: 0 0.5px;
3445
- background-color: ${({ $color }) => $color};
3446
- opacity: ${({ hasAnyFilter, isFiltered }) => (isFiltered ? 1 : hasAnyFilter ? FILTERED_VALUE_OPACITY / 100 : 1)};
3447
- transition: opacity ${uilibGl.transition.release};
3448
-
3449
- :first-child {
3450
- border-top-left-radius: ${({ cornerRadius }) => (cornerRadius ? `${cornerRadius}px` : "0.5rem")};
3451
- border-bottom-left-radius: ${({ cornerRadius }) => (cornerRadius ? `${cornerRadius}px` : "0.5rem")};
3452
- }
3453
-
3454
- :last-child {
3455
- border-top-right-radius: ${({ cornerRadius }) => (cornerRadius ? `${cornerRadius}px` : "0.5rem")};
3456
- border-bottom-right-radius: ${({ cornerRadius }) => (cornerRadius ? `${cornerRadius}px` : "0.5rem")};
3457
- }
3458
- `;
3459
- const StackBarAlias = styled.div `
3460
- color: ${({ theme: { palette } }) => palette.textSecondary};
3431
+ const StackBarContainer = styled(uilibGl.Flex) `
3432
+ flex-wrap: nowrap;
3433
+ width: 100%;
3434
+ `;
3435
+ const StackBarHeader = styled(uilibGl.Flex) `
3436
+ justify-content: space-between;
3437
+ margin-bottom: 0.375rem;
3438
+ font-size: 0.75rem;
3439
+ `;
3440
+ const StackBarSection = styled.div `
3441
+ cursor: ${({ onClick }) => (onClick ? "pointer" : "default")};
3442
+ width: ${({ $width }) => $width}%;
3443
+ height: ${({ $height }) => ($height ? `${$height}px` : "0.5rem")};
3444
+ margin: 0 0.5px;
3445
+ background-color: ${({ $color }) => $color};
3446
+ opacity: ${({ hasAnyFilter, isFiltered }) => (isFiltered ? 1 : hasAnyFilter ? FILTERED_VALUE_OPACITY / 100 : 1)};
3447
+ transition: opacity ${uilibGl.transition.release};
3448
+
3449
+ :first-child {
3450
+ border-top-left-radius: ${({ cornerRadius }) => (cornerRadius ? `${cornerRadius}px` : "0.5rem")};
3451
+ border-bottom-left-radius: ${({ cornerRadius }) => (cornerRadius ? `${cornerRadius}px` : "0.5rem")};
3452
+ }
3453
+
3454
+ :last-child {
3455
+ border-top-right-radius: ${({ cornerRadius }) => (cornerRadius ? `${cornerRadius}px` : "0.5rem")};
3456
+ border-bottom-right-radius: ${({ cornerRadius }) => (cornerRadius ? `${cornerRadius}px` : "0.5rem")};
3457
+ }
3458
+ `;
3459
+ const StackBarAlias = styled.div `
3460
+ color: ${({ theme: { palette } }) => palette.textSecondary};
3461
3461
  `;
3462
3462
  const StackBarTotal = styled(uilibGl.Flex) ``;
3463
3463
  const StackBarValue = styled.div ``;
3464
- const StackBarUnits = styled.div `
3465
- margin-left: 0.25rem;
3466
- color: ${({ theme: { palette } }) => palette.textSecondary};
3464
+ const StackBarUnits = styled.div `
3465
+ margin-left: 0.25rem;
3466
+ color: ${({ theme: { palette } }) => palette.textSecondary};
3467
3467
  `;
3468
3468
 
3469
3469
  const transparentizeColor = (originalColor, percent) => {
@@ -3972,7 +3972,7 @@ const areaGenerator = (height) => area()
3972
3972
  .y1(d => d[1])
3973
3973
  .curve(monotoneX);
3974
3974
  function getLinePoints(numPoints, svgLine) {
3975
- if (!svgLine) {
3975
+ if (!svgLine?.getTotalLength) {
3976
3976
  return [];
3977
3977
  }
3978
3978
  const lineLength = svgLine.getTotalLength();
@@ -3983,7 +3983,7 @@ function getLinePoints(numPoints, svgLine) {
3983
3983
  else {
3984
3984
  interval = lineLength / (numPoints - 1);
3985
3985
  }
3986
- return range(numPoints).map(d => {
3986
+ return range(numPoints).filter(d => d * interval).map(d => {
3987
3987
  const value = d * interval;
3988
3988
  const { x, y } = svgLine.getPointAtLength(value);
3989
3989
  return [x, y];
@@ -4025,8 +4025,8 @@ const useChartChange = ({ dataSources, chartId, width, height, relatedAttributes
4025
4025
  const customize = React.useCallback(({ svg }) => {
4026
4026
  svg.style("overflow", "visible");
4027
4027
  svg
4028
- .selectAll(`.${charts.lineChartClassNames.lineChartXScaleGlobal} line,
4029
- .${charts.lineChartClassNames.lineChartYScaleGlobal} line,
4028
+ .selectAll(`.${charts.lineChartClassNames.lineChartXScaleGlobal} line,
4029
+ .${charts.lineChartClassNames.lineChartYScaleGlobal} line,
4030
4030
  .domain`)
4031
4031
  .each((_, index, nodes) => {
4032
4032
  nodes[index].remove();
@@ -4083,11 +4083,11 @@ const useChartChange = ({ dataSources, chartId, width, height, relatedAttributes
4083
4083
  .attr("fill", `url(#${gradientId})`)
4084
4084
  .attr("stroke-width", "0")
4085
4085
  .attr("fill-opacity", FILL_OPACITY);
4086
- defs.push(`
4087
- <linearGradient id="${gradientId}" x1="0" y1="0" x2="0" y2="1">
4088
- <stop offset="0" stop-color="${color}" stop-opacity="1" />
4089
- <stop offset="1" stop-color="${color}" stop-opacity="0" />
4090
- </linearGradient>
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>
4091
4091
  `);
4092
4092
  ref.current = {
4093
4093
  path: newPath,
@@ -4442,255 +4442,255 @@ const formatDataSourceCondition = ({ condition, configFilters, filters, attribut
4442
4442
  : conditionSection.join(splitter);
4443
4443
  };
4444
4444
 
4445
- const DashboardChipsContainer = styled(uilibGl.Flex) `
4446
- flex-wrap: wrap;
4447
- `;
4448
- const DashboardChip$1 = styled(uilibGl.Chip) `
4449
- margin: 0 0.25rem 0.25rem 0;
4450
- background: ${({ $isDefault, $bgColor, theme: { palette } }) => $isDefault ? palette.element : $bgColor || palette.primary};
4451
- border-radius: ${({ $radius, theme: { borderRadius } }) => $radius || borderRadius.medium};
4452
- white-space: nowrap;
4453
- font-size: ${({ $fontSize }) => $fontSize || "0.875rem"};
4454
- color: ${({ $isDefault, $fontColor, theme: { palette } }) => $isDefault ? palette.textPrimary : $fontColor || "#fff"};
4455
-
4456
- > * {
4457
- font-size: ${({ $fontSize }) => $fontSize || "0.875rem"};
4458
- color: ${({ $isDefault, $fontColor, theme: { palette } }) => $isDefault ? palette.textPrimary : $fontColor || "#fff"};
4459
- }
4460
-
4461
- span[kind] {
4462
- height: 0.875rem;
4463
-
4464
- :after {
4465
- color: ${({ $isDefault, $fontColor, theme: { palette } }) => ($isDefault ? palette.icon : $fontColor || "#fff")};
4466
- font-size: 0.875rem;
4467
- }
4468
- }
4469
-
4470
- button {
4471
- width: auto;
4472
- padding: 0 0.5rem;
4473
- }
4474
- `;
4475
-
4476
- const ChartLegendContainer = styled(uilibGl.Flex) `
4477
- flex-direction: column;
4478
- flex-wrap: wrap;
4479
- justify-content: ${({ twoColumns }) => (twoColumns ? "flex-start" : "center")};
4480
- `;
4481
- const ChartLegendItem = styled(uilibGl.Flex) `
4482
- cursor: ${({ onClick }) => (onClick ? "pointer" : "default")};
4483
- align-items: center;
4484
- flex-wrap: nowrap;
4485
- width: auto;
4486
- margin-right: 0.375rem;
4487
- margin-bottom: 0.25rem;
4488
- line-height: 0.75rem;
4489
- opacity: ${({ isFiltered, hasAnyFilter }) => (isFiltered ? 1 : hasAnyFilter ? FILTERED_VALUE_OPACITY / 100 : 1)};
4490
- `;
4491
- const ChartLegendColor = styled.div `
4492
- width: 0.5rem;
4493
- height: 0.5rem;
4494
- margin-right: 0.375rem;
4495
- background-color: ${({ color }) => color};
4496
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.tiny};
4497
- `;
4498
- const ChartLegendName = styled.div `
4499
- flex: 1;
4500
- font-size: 0.625rem;
4501
- color: ${({ theme: { palette }, $fontColor }) => $fontColor || palette.textPrimary};
4502
- `;
4503
-
4504
- const Container = styled(uilibGl.Flex) `
4505
- flex-direction: column;
4506
- width: 100%;
4507
-
4445
+ const DashboardChipsContainer = styled(uilibGl.Flex) `
4446
+ flex-wrap: wrap;
4447
+ `;
4448
+ const DashboardChip$1 = styled(uilibGl.Chip) `
4449
+ margin: 0 0.25rem 0.25rem 0;
4450
+ background: ${({ $isDefault, $bgColor, theme: { palette } }) => $isDefault ? palette.element : $bgColor || palette.primary};
4451
+ border-radius: ${({ $radius, theme: { borderRadius } }) => $radius || borderRadius.medium};
4452
+ white-space: nowrap;
4453
+ font-size: ${({ $fontSize }) => $fontSize || "0.875rem"};
4454
+ color: ${({ $isDefault, $fontColor, theme: { palette } }) => $isDefault ? palette.textPrimary : $fontColor || "#fff"};
4455
+
4456
+ > * {
4457
+ font-size: ${({ $fontSize }) => $fontSize || "0.875rem"};
4458
+ color: ${({ $isDefault, $fontColor, theme: { palette } }) => $isDefault ? palette.textPrimary : $fontColor || "#fff"};
4459
+ }
4460
+
4461
+ span[kind] {
4462
+ height: 0.875rem;
4463
+
4464
+ :after {
4465
+ color: ${({ $isDefault, $fontColor, theme: { palette } }) => ($isDefault ? palette.icon : $fontColor || "#fff")};
4466
+ font-size: 0.875rem;
4467
+ }
4468
+ }
4469
+
4470
+ button {
4471
+ width: auto;
4472
+ padding: 0 0.5rem;
4473
+ }
4474
+ `;
4475
+
4476
+ const ChartLegendContainer = styled(uilibGl.Flex) `
4477
+ flex-direction: column;
4478
+ flex-wrap: wrap;
4479
+ justify-content: ${({ twoColumns }) => (twoColumns ? "flex-start" : "center")};
4480
+ `;
4481
+ const ChartLegendItem = styled(uilibGl.Flex) `
4482
+ cursor: ${({ onClick }) => (onClick ? "pointer" : "default")};
4483
+ align-items: center;
4484
+ flex-wrap: nowrap;
4485
+ width: auto;
4486
+ margin-right: 0.375rem;
4487
+ margin-bottom: 0.25rem;
4488
+ line-height: 0.75rem;
4489
+ opacity: ${({ isFiltered, hasAnyFilter }) => (isFiltered ? 1 : hasAnyFilter ? FILTERED_VALUE_OPACITY / 100 : 1)};
4490
+ `;
4491
+ const ChartLegendColor = styled.div `
4492
+ width: 0.5rem;
4493
+ height: 0.5rem;
4494
+ margin-right: 0.375rem;
4495
+ background-color: ${({ color }) => color};
4496
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.tiny};
4497
+ `;
4498
+ const ChartLegendName = styled.div `
4499
+ flex: 1;
4500
+ font-size: 0.625rem;
4501
+ color: ${({ theme: { palette }, $fontColor }) => $fontColor || palette.textPrimary};
4502
+ `;
4503
+
4504
+ const Container = styled(uilibGl.Flex) `
4505
+ flex-direction: column;
4506
+ width: 100%;
4507
+
4508
4508
  ${({ isColumn }) => isColumn
4509
- ? styled.css `
4510
- > * {
4511
- width: 100%;
4512
- }
4509
+ ? styled.css `
4510
+ > * {
4511
+ width: 100%;
4512
+ }
4513
4513
  `
4514
- : styled.css `
4515
- flex-direction: row;
4516
- justify-content: space-between;
4517
- align-items: center;
4518
- `}
4519
-
4514
+ : styled.css `
4515
+ flex-direction: row;
4516
+ justify-content: space-between;
4517
+ align-items: center;
4518
+ `}
4519
+
4520
4520
  ${({ isMain, isColumn }) => (isMain || isColumn) &&
4521
- styled.css `
4522
- > :not(:last-child) {
4523
- margin-bottom: 1.5rem;
4524
- }
4525
- `}
4526
-
4521
+ styled.css `
4522
+ > :not(:last-child) {
4523
+ margin-bottom: 1.5rem;
4524
+ }
4525
+ `}
4526
+
4527
4527
  ${({ isTitle }) => isTitle &&
4528
- styled.css `
4529
- &&&& {
4530
- margin-bottom: 0.75rem;
4531
- }
4532
- `}
4533
-
4534
- ${({ noBorders }) => noBorders && styled.css `
4535
- ${ContainerWrapper} {
4536
- box-shadow: none;
4537
- padding: 0;
4538
- }
4539
- `}
4540
- `;
4541
- const ContainerAlias = styled(uilibGl.Flex) `
4542
- align-items: center;
4543
- flex-wrap: nowrap;
4544
- margin-bottom: ${({ hasBottomMargin }) => (hasBottomMargin ? 0.25 : 0)}rem;
4545
- font-size: 0.75rem;
4546
- color: ${({ theme: { palette } }) => palette.textSecondary};
4547
-
4548
- span[kind] {
4549
- margin-right: 0.5rem;
4550
-
4551
- :after {
4552
- color: ${({ theme: { palette } }) => palette.primary};
4553
- }
4554
- }
4555
- `;
4556
- const ContainerAliasIcon = styled.div `
4557
- margin-right: 0.5rem;
4558
- `;
4559
- const ContainerChart = styled(uilibGl.Flex) `
4560
- justify-content: flex-start;
4561
-
4562
- > * {
4563
- display: flex;
4564
- justify-content: center;
4565
- width: 100%;
4566
- }
4528
+ styled.css `
4529
+ &&&& {
4530
+ margin-bottom: 0.75rem;
4531
+ }
4532
+ `}
4533
+
4534
+ ${({ noBorders }) => noBorders && styled.css `
4535
+ ${ContainerWrapper} {
4536
+ box-shadow: none;
4537
+ padding: 0;
4538
+ }
4539
+ `}
4540
+ `;
4541
+ const ContainerAlias = styled(uilibGl.Flex) `
4542
+ align-items: center;
4543
+ flex-wrap: nowrap;
4544
+ margin-bottom: ${({ hasBottomMargin }) => (hasBottomMargin ? 0.25 : 0)}rem;
4545
+ font-size: 0.75rem;
4546
+ color: ${({ theme: { palette } }) => palette.textSecondary};
4547
+
4548
+ span[kind] {
4549
+ margin-right: 0.5rem;
4550
+
4551
+ :after {
4552
+ color: ${({ theme: { palette } }) => palette.primary};
4553
+ }
4554
+ }
4555
+ `;
4556
+ const ContainerAliasIcon = styled.div `
4557
+ margin-right: 0.5rem;
4558
+ `;
4559
+ const ContainerChart = styled(uilibGl.Flex) `
4560
+ justify-content: flex-start;
4561
+
4562
+ > * {
4563
+ display: flex;
4564
+ justify-content: center;
4565
+ width: 100%;
4566
+ }
4567
4567
  `;
4568
4568
  const ContainerLegend = styled(uilibGl.Flex) ``;
4569
- const ContainerUnits = styled.div `
4570
- margin-left: 0.5rem;
4571
- white-space: nowrap;
4572
- font-size: 0.75rem;
4573
- `;
4574
- const ContainerValue = styled(uilibGl.Flex) `
4575
- justify-content: flex-end;
4576
- align-items: center;
4577
- flex-wrap: nowrap;
4578
- width: 100%;
4579
- font-size: ${({ big }) => (big ? 1.5 : 1)}rem;
4580
- color: ${({ fontColor, theme: { palette } }) => fontColor || palette.textPrimary};
4581
-
4582
- > * {
4583
- width: ${({ column }) => (column ? "100%" : "auto")};
4584
- }
4585
-
4586
- ${ContainerChart}, ${ContainerLegend} {
4587
- width: ${({ column }) => (column ? "100%" : "50%")};
4588
- }
4589
-
4590
- ${ContainerLegend} {
4591
- margin-left: ${({ column }) => (column ? 0 : "1rem")};
4592
- }
4593
-
4594
- ${ChartLegendContainer} {
4595
- flex-direction: ${({ column }) => (column ? "row" : "column")};
4596
- margin-top: ${({ column }) => (column ? "1rem" : 0)};
4597
- }
4598
- `;
4599
- const ColorIconMixin = styled.css `
4600
- :after {
4601
- color: ${({ $fontColor }) => $fontColor} !important;
4602
- }
4603
- `;
4604
- const SizeIconMixin = styled.css `
4605
- :after {
4606
- font-size: ${({ $fontSize }) => $fontSize}px !important;
4607
- }
4608
- `;
4609
- const ContainerIcon = styled(uilibGl.Icon) `
4610
- width: auto;
4611
- height: auto;
4612
- margin-bottom: 0.5rem;
4613
- ${({ $fontColor }) => !!$fontColor && ColorIconMixin};
4614
- ${({ $fontSize }) => !!$fontSize && SizeIconMixin};
4615
- `;
4616
- const SvgContainerColorMixin$1 = styled.css `
4617
- path,
4618
- line,
4619
- circle {
4620
- fill: ${({ $fontColor }) => $fontColor};
4621
- }
4622
- `;
4623
- const SvgContainer$1 = styled.div `
4624
- &&& {
4625
- min-width: ${({ $width }) => ($width ? `${$width}px` : "1rem")};
4626
- max-width: ${({ $width }) => ($width ? `${$width}px` : "1rem")};
4627
-
4628
- ${({ $fontColor }) => !!$fontColor && SvgContainerColorMixin$1};
4629
-
4630
- > * {
4631
- min-width: inherit;
4632
- }
4633
- }
4634
- `;
4635
- const TwoColumnContainerWrapper = styled(uilibGl.Flex) `
4636
- width: 100%;
4637
- flex-direction: row;
4638
- flex-wrap: nowrap;
4639
- align-items: center;
4640
-
4641
- > * {
4642
- flex: 1;
4643
- }
4644
-
4645
- > ${ContainerValue} {
4646
- justify-content: flex-end;
4647
-
4648
- > * {
4649
- text-align: right;
4650
- }
4651
- }
4652
- `;
4653
-
4654
- const LayerGroupContainer = styled(uilibGl.Flex) `
4655
- display: flex;
4656
- justify-content: center;
4657
- position: relative;
4658
- flex-direction: column;
4659
- padding: 0 0.25rem 0 1rem;
4660
- box-sizing: border-box;
4661
- transition: opacity ${uilibGl.transition.hover}, background-color ${uilibGl.transition.hover};
4662
- font-family: "NunitoSans", sans-serif;
4663
- `;
4664
- const LayerGroupMain = styled(uilibGl.Flex) `
4665
- flex-direction: row;
4666
- flex-wrap: nowrap;
4667
- align-items: center;
4668
- justify-content: space-between;
4669
- width: 100%;
4670
-
4671
- ${uilibGl.Icon} {
4672
- width: 2rem;
4673
- min-width: 2rem;
4674
- height: 2rem;
4675
- display: inline-flex;
4676
- align-items: center;
4677
- justify-content: center;
4678
- margin-right: 0.75rem;
4679
- }
4680
-
4681
- ${uilibGl.Description} {
4682
- display: flex;
4683
- align-items: center;
4684
- flex-grow: 1;
4685
- width: 100%;
4686
- margin-right: 0.25rem;
4687
- color: ${({ theme }) => theme.palette.textPrimary};
4688
- }
4689
-
4690
- button {
4691
- width: 2.25rem;
4692
- justify-content: flex-start;
4693
- }
4569
+ const ContainerUnits = styled.div `
4570
+ margin-left: 0.5rem;
4571
+ white-space: nowrap;
4572
+ font-size: 0.75rem;
4573
+ `;
4574
+ const ContainerValue = styled(uilibGl.Flex) `
4575
+ justify-content: flex-end;
4576
+ align-items: center;
4577
+ flex-wrap: nowrap;
4578
+ width: 100%;
4579
+ font-size: ${({ big }) => (big ? 1.5 : 1)}rem;
4580
+ color: ${({ fontColor, theme: { palette } }) => fontColor || palette.textPrimary};
4581
+
4582
+ > * {
4583
+ width: ${({ column }) => (column ? "100%" : "auto")};
4584
+ }
4585
+
4586
+ ${ContainerChart}, ${ContainerLegend} {
4587
+ width: ${({ column }) => (column ? "100%" : "50%")};
4588
+ }
4589
+
4590
+ ${ContainerLegend} {
4591
+ margin-left: ${({ column }) => (column ? 0 : "1rem")};
4592
+ }
4593
+
4594
+ ${ChartLegendContainer} {
4595
+ flex-direction: ${({ column }) => (column ? "row" : "column")};
4596
+ margin-top: ${({ column }) => (column ? "1rem" : 0)};
4597
+ }
4598
+ `;
4599
+ const ColorIconMixin = styled.css `
4600
+ :after {
4601
+ color: ${({ $fontColor }) => $fontColor} !important;
4602
+ }
4603
+ `;
4604
+ const SizeIconMixin = styled.css `
4605
+ :after {
4606
+ font-size: ${({ $fontSize }) => $fontSize}px !important;
4607
+ }
4608
+ `;
4609
+ const ContainerIcon = styled(uilibGl.Icon) `
4610
+ width: auto;
4611
+ height: auto;
4612
+ margin-bottom: 0.5rem;
4613
+ ${({ $fontColor }) => !!$fontColor && ColorIconMixin};
4614
+ ${({ $fontSize }) => !!$fontSize && SizeIconMixin};
4615
+ `;
4616
+ const SvgContainerColorMixin$1 = styled.css `
4617
+ path,
4618
+ line,
4619
+ circle {
4620
+ fill: ${({ $fontColor }) => $fontColor};
4621
+ }
4622
+ `;
4623
+ const SvgContainer$1 = styled.div `
4624
+ &&& {
4625
+ min-width: ${({ $width }) => ($width ? `${$width}px` : "1rem")};
4626
+ max-width: ${({ $width }) => ($width ? `${$width}px` : "1rem")};
4627
+
4628
+ ${({ $fontColor }) => !!$fontColor && SvgContainerColorMixin$1};
4629
+
4630
+ > * {
4631
+ min-width: inherit;
4632
+ }
4633
+ }
4634
+ `;
4635
+ const TwoColumnContainerWrapper = styled(uilibGl.Flex) `
4636
+ width: 100%;
4637
+ flex-direction: row;
4638
+ flex-wrap: nowrap;
4639
+ align-items: center;
4640
+
4641
+ > * {
4642
+ flex: 1;
4643
+ }
4644
+
4645
+ > ${ContainerValue} {
4646
+ justify-content: flex-end;
4647
+
4648
+ > * {
4649
+ text-align: right;
4650
+ }
4651
+ }
4652
+ `;
4653
+
4654
+ const LayerGroupContainer = styled(uilibGl.Flex) `
4655
+ display: flex;
4656
+ justify-content: center;
4657
+ position: relative;
4658
+ flex-direction: column;
4659
+ padding: 0 0.25rem 0 1rem;
4660
+ box-sizing: border-box;
4661
+ transition: opacity ${uilibGl.transition.hover}, background-color ${uilibGl.transition.hover};
4662
+ font-family: "NunitoSans", sans-serif;
4663
+ `;
4664
+ const LayerGroupMain = styled(uilibGl.Flex) `
4665
+ flex-direction: row;
4666
+ flex-wrap: nowrap;
4667
+ align-items: center;
4668
+ justify-content: space-between;
4669
+ width: 100%;
4670
+
4671
+ ${uilibGl.Icon} {
4672
+ width: 2rem;
4673
+ min-width: 2rem;
4674
+ height: 2rem;
4675
+ display: inline-flex;
4676
+ align-items: center;
4677
+ justify-content: center;
4678
+ margin-right: 0.75rem;
4679
+ }
4680
+
4681
+ ${uilibGl.Description} {
4682
+ display: flex;
4683
+ align-items: center;
4684
+ flex-grow: 1;
4685
+ width: 100%;
4686
+ margin-right: 0.25rem;
4687
+ color: ${({ theme }) => theme.palette.textPrimary};
4688
+ }
4689
+
4690
+ button {
4691
+ width: 2.25rem;
4692
+ justify-content: flex-start;
4693
+ }
4694
4694
  `;
4695
4695
 
4696
4696
  const customModes = MapboxDraw.modes;
@@ -4905,6 +4905,10 @@ const convertSpToTurfFeature = (geometry) => {
4905
4905
  case api.GeometryType.Polygon:
4906
4906
  case api.GeometryType.Envelope:
4907
4907
  return turf.polygon(geometry.coordinates);
4908
+ case api.GeometryType.MultiPolygon:
4909
+ return turf.multiPolygon(geometry.coordinates);
4910
+ case api.GeometryType.GeometryCollection:
4911
+ return turf.geometryCollection(geometry.geometries);
4908
4912
  }
4909
4913
  };
4910
4914
 
@@ -5081,286 +5085,286 @@ const LayerTree = ({ layers, onlyMainTools }) => {
5081
5085
  return (jsxRuntime.jsx(uilibGl.DraggableTree, { nodes: nodes, disableDrag: onlyMainTools, options: { pastePlaceholderHeight: "0.0625rem" }, onUpdate: onUpdate }));
5082
5086
  };
5083
5087
 
5084
- const LayersListWrapper = styled(uilibGl.Flex) `
5085
- flex-direction: column;
5086
- height: 100%;
5087
- width: 100%;
5088
- box-sizing: border-box;
5089
- `;
5090
- const LayerListContainer = styled(uilibGl.Flex) `
5091
- flex-grow: 1;
5092
- height: 100%;
5093
- box-sizing: border-box;
5094
- `;
5095
-
5096
- const ElementValueWrapper = styled.div `
5097
- transition: background-color ${uilibGl.transition.toggle};
5098
- `;
5099
- const ContainerWrapper = styled(uilibGl.Flex) `
5100
- position: relative;
5101
- min-height: 1rem;
5102
- box-sizing: border-box;
5103
- width: 100%;
5104
- background: ${({ theme: { palette } }) => palette.backgroundAlpha};
5105
- box-shadow: rgb(0 0 0 / 15%) 0 0.1875rem 0.625rem;
5106
- padding: 1.5rem;
5107
- border-radius: 0.5rem;
5108
- backdrop-filter: blur(20px);
5109
- color: ${({ theme: { palette } }) => palette.textPrimary};
5110
- z-index: ${({ $zIndex }) => $zIndex ?? 1};
5111
- transition: background-color ${uilibGl.transition.toggle};
5112
-
5113
- ${Container} > ${ElementValueWrapper}:not(:last-child) {
5114
- margin-bottom: 1.5rem;
5115
- }
5116
- `;
5117
- const DashboardChip = styled(uilibGl.Chip) `
5118
- margin: 0 0.25rem 0.25rem 0;
5119
- background: ${({ $isDefault, $bgColor, theme: { palette } }) => $isDefault ? palette.element : $bgColor || palette.primary};
5120
- border-radius: ${({ $radius, theme: { borderRadius } }) => $radius || borderRadius.medium};
5121
- font-size: ${({ $fontSize }) => $fontSize || "0.875rem"};
5122
- color: ${({ $isDefault, $fontColor, theme: { palette } }) => $isDefault ? palette.textPrimary : $fontColor || "#fff"};
5123
-
5124
- > * {
5125
- font-size: ${({ $fontSize }) => $fontSize || "0.875rem"};
5126
- color: ${({ $isDefault, $fontColor, theme: { palette } }) => $isDefault ? palette.textPrimary : $fontColor || "#fff"};
5127
- }
5128
-
5129
- span[kind]:after {
5130
- color: ${({ $isDefault, $fontColor, theme: { palette } }) => ($isDefault ? palette.icon : $fontColor || "#fff")};
5131
- }
5132
- `;
5133
- const DashboardPlaceholderWrap = styled(uilibGl.Flex) `
5134
- flex-grow: 1;
5135
- flex-direction: column;
5136
- justify-content: center;
5137
- align-items: center;
5138
- width: 100%;
5139
- margin-bottom: 2rem;
5140
- `;
5141
- const DashboardPlaceholder = styled(uilibGl.Flex) `
5142
- flex-direction: column;
5143
- justify-content: center;
5144
- align-items: center;
5145
- margin-top: 2rem;
5146
-
5088
+ const LayersListWrapper = styled(uilibGl.Flex) `
5089
+ flex-direction: column;
5090
+ height: 100%;
5091
+ width: 100%;
5092
+ box-sizing: border-box;
5093
+ `;
5094
+ const LayerListContainer = styled(uilibGl.Flex) `
5095
+ flex-grow: 1;
5096
+ height: 100%;
5097
+ box-sizing: border-box;
5098
+ `;
5099
+
5100
+ const ElementValueWrapper = styled.div `
5101
+ transition: background-color ${uilibGl.transition.toggle};
5102
+ `;
5103
+ const ContainerWrapper = styled(uilibGl.Flex) `
5104
+ position: relative;
5105
+ min-height: 1rem;
5106
+ box-sizing: border-box;
5107
+ width: 100%;
5108
+ background: ${({ theme: { palette } }) => palette.backgroundAlpha};
5109
+ box-shadow: rgb(0 0 0 / 15%) 0 0.1875rem 0.625rem;
5110
+ padding: 1.5rem;
5111
+ border-radius: 0.5rem;
5112
+ backdrop-filter: blur(20px);
5113
+ color: ${({ theme: { palette } }) => palette.textPrimary};
5114
+ z-index: ${({ $zIndex }) => $zIndex ?? 1};
5115
+ transition: background-color ${uilibGl.transition.toggle};
5116
+
5117
+ ${Container} > ${ElementValueWrapper}:not(:last-child) {
5118
+ margin-bottom: 1.5rem;
5119
+ }
5120
+ `;
5121
+ const DashboardChip = styled(uilibGl.Chip) `
5122
+ margin: 0 0.25rem 0.25rem 0;
5123
+ background: ${({ $isDefault, $bgColor, theme: { palette } }) => $isDefault ? palette.element : $bgColor || palette.primary};
5124
+ border-radius: ${({ $radius, theme: { borderRadius } }) => $radius || borderRadius.medium};
5125
+ font-size: ${({ $fontSize }) => $fontSize || "0.875rem"};
5126
+ color: ${({ $isDefault, $fontColor, theme: { palette } }) => $isDefault ? palette.textPrimary : $fontColor || "#fff"};
5127
+
5128
+ > * {
5129
+ font-size: ${({ $fontSize }) => $fontSize || "0.875rem"};
5130
+ color: ${({ $isDefault, $fontColor, theme: { palette } }) => $isDefault ? palette.textPrimary : $fontColor || "#fff"};
5131
+ }
5132
+
5133
+ span[kind]:after {
5134
+ color: ${({ $isDefault, $fontColor, theme: { palette } }) => ($isDefault ? palette.icon : $fontColor || "#fff")};
5135
+ }
5136
+ `;
5137
+ const DashboardPlaceholderWrap = styled(uilibGl.Flex) `
5138
+ flex-grow: 1;
5139
+ flex-direction: column;
5140
+ justify-content: center;
5141
+ align-items: center;
5142
+ width: 100%;
5143
+ margin-bottom: 2rem;
5144
+ `;
5145
+ const DashboardPlaceholder = styled(uilibGl.Flex) `
5146
+ flex-direction: column;
5147
+ justify-content: center;
5148
+ align-items: center;
5149
+ margin-top: 2rem;
5150
+
5147
5151
  ${({ isLoading }) => isLoading &&
5148
- styled.css `
5149
- width: 6.25rem;
5150
- `}
5151
- &&& > * {
5152
- margin-bottom: 0;
5153
- }
5154
-
5155
- > div {
5156
- width: 100%;
5157
- margin-top: 1rem;
5158
- font-size: 0.75rem;
5159
- text-align: center;
5160
- color: ${({ theme: { palette } }) => palette.textDisabled};
5161
- }
5162
-
5163
- span[kind] {
5164
- width: 2.25rem;
5165
- height: 2.25rem;
5166
- opacity: 0.28;
5167
-
5168
- :after {
5169
- font-size: 32px;
5170
- }
5171
- }
5172
- `;
5173
- const DashboardWrapper = styled(uilibGl.Flex) `
5174
- flex-direction: column;
5175
- flex-wrap: nowrap;
5176
- flex-grow: 1;
5177
- width: calc(100% - 3rem);
5178
- height: calc(100% - ${LEFT_PANEL_HEADER_HEIGHT});
5179
-
5180
- > ${ContainerWrapper} {
5181
- > * {
5182
- margin-bottom: 2rem;
5183
- }
5184
- }
5185
-
5152
+ styled.css `
5153
+ width: 6.25rem;
5154
+ `}
5155
+ &&& > * {
5156
+ margin-bottom: 0;
5157
+ }
5158
+
5159
+ > div {
5160
+ width: 100%;
5161
+ margin-top: 1rem;
5162
+ font-size: 0.75rem;
5163
+ text-align: center;
5164
+ color: ${({ theme: { palette } }) => palette.textDisabled};
5165
+ }
5166
+
5167
+ span[kind] {
5168
+ width: 2.25rem;
5169
+ height: 2.25rem;
5170
+ opacity: 0.28;
5171
+
5172
+ :after {
5173
+ font-size: 32px;
5174
+ }
5175
+ }
5176
+ `;
5177
+ const DashboardWrapper = styled(uilibGl.Flex) `
5178
+ flex-direction: column;
5179
+ flex-wrap: nowrap;
5180
+ flex-grow: 1;
5181
+ width: calc(100% - 3rem);
5182
+ height: calc(100% - ${LEFT_PANEL_HEADER_HEIGHT});
5183
+
5184
+ > ${ContainerWrapper} {
5185
+ > * {
5186
+ margin-bottom: 2rem;
5187
+ }
5188
+ }
5189
+
5186
5190
  ${({ hasImage, isPresentationMode }) => hasImage &&
5187
5191
  !isPresentationMode &&
5188
- styled.css `
5189
- margin-top: -0.35rem;
5190
- `}
5191
- `;
5192
- const DashboardContent = styled(uilibGl.Flex) `
5193
- flex-grow: 1;
5194
- width: 100%;
5195
- padding: 1.5rem 1.5rem 2rem;
5196
- overflow-y: auto;
5197
- scrollbar-gutter: stable;
5198
- `;
5199
- const PresentationWrapperCss = styled.css `
5200
- margin-bottom: 0.75rem;
5201
- padding: 1.5rem;
5202
- background-color: ${({ theme: { palette } }) => palette.panelBackground};
5203
- backdrop-filter: blur(10px);
5204
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
5205
- box-shadow: ${uilibGl.shadows.raised};
5206
- `;
5207
- const PresentationWrapper = styled.div `
5208
- ${PresentationWrapperCss};
5209
- position: relative;
5210
- z-index: 1;
5211
- `;
5212
- const PresentationPanelWrapper = styled(PresentationWrapper) `
5213
- margin-top: 0.75rem;
5214
- transition: background-color ${uilibGl.transition.toggle};
5215
- `;
5216
- const PresentationHeader = styled.div `
5217
- margin: -1.5rem -1.5rem 0 -1.5rem;
5218
- padding: 1.5rem;
5219
- // background: url(images.presentationHeader) 0 0 no-repeat;
5220
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
5221
- transition: background-color ${uilibGl.transition.toggle};
5222
-
5192
+ styled.css `
5193
+ margin-top: -0.35rem;
5194
+ `}
5195
+ `;
5196
+ const DashboardContent = styled(uilibGl.Flex) `
5197
+ flex-grow: 1;
5198
+ width: 100%;
5199
+ padding: 1.5rem 1.5rem 2rem;
5200
+ overflow-y: auto;
5201
+ scrollbar-gutter: stable;
5202
+ `;
5203
+ const PresentationWrapperCss = styled.css `
5204
+ margin-bottom: 0.75rem;
5205
+ padding: 1.5rem;
5206
+ background-color: ${({ theme: { palette } }) => palette.panelBackground};
5207
+ backdrop-filter: blur(10px);
5208
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
5209
+ box-shadow: ${uilibGl.shadows.raised};
5210
+ `;
5211
+ const PresentationWrapper = styled.div `
5212
+ ${PresentationWrapperCss};
5213
+ position: relative;
5214
+ z-index: 1;
5215
+ `;
5216
+ const PresentationPanelWrapper = styled(PresentationWrapper) `
5217
+ margin-top: 0.75rem;
5218
+ transition: background-color ${uilibGl.transition.toggle};
5219
+ `;
5220
+ const PresentationHeader = styled.div `
5221
+ margin: -1.5rem -1.5rem 0 -1.5rem;
5222
+ padding: 1.5rem;
5223
+ // background: url(images.presentationHeader) 0 0 no-repeat;
5224
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
5225
+ transition: background-color ${uilibGl.transition.toggle};
5226
+
5223
5227
  ${({ image }) => !!image &&
5224
- styled.css `
5225
- padding-top: 7rem;
5226
- `};
5227
- `;
5228
- const PresentationHeaderTools = styled(uilibGl.Flex) `
5229
- justify-content: space-between;
5230
- align-items: center;
5231
- margin-bottom: -0.5rem;
5232
- margin-right: -0.5rem;
5233
-
5234
- span[kind="sun"],
5235
- span[kind="moon"] {
5236
- :after {
5237
- font-size: 0.85rem;
5238
- color: ${({ theme: { palette } }) => palette.iconDisabled};
5239
- }
5240
-
5241
- :hover:after {
5242
- color: ${({ theme: { palette } }) => palette.icon};
5243
- }
5244
- }
5245
- `;
5246
- const LayerGroupList = styled(uilibGl.Flex) `
5247
- flex-direction: column;
5248
- height: 100%;
5249
- flex-wrap: nowrap;
5250
- overflow-x: ${({ $noScroll }) => ($noScroll ? "visible" : "hidden")};
5251
- overflow-y: ${({ $noScroll }) => ($noScroll ? "visible" : "auto")};
5252
- padding: 0 0.125rem 0 0.75rem;
5253
- scrollbar-gutter: stable;
5254
-
5255
- > * {
5256
- flex-grow: 1;
5257
- }
5228
+ styled.css `
5229
+ padding-top: 7rem;
5230
+ `};
5231
+ `;
5232
+ const PresentationHeaderTools = styled(uilibGl.Flex) `
5233
+ justify-content: space-between;
5234
+ align-items: center;
5235
+ margin-bottom: -0.5rem;
5236
+ margin-right: -0.5rem;
5237
+
5238
+ span[kind="sun"],
5239
+ span[kind="moon"] {
5240
+ :after {
5241
+ font-size: 0.85rem;
5242
+ color: ${({ theme: { palette } }) => palette.iconDisabled};
5243
+ }
5244
+
5245
+ :hover:after {
5246
+ color: ${({ theme: { palette } }) => palette.icon};
5247
+ }
5248
+ }
5249
+ `;
5250
+ const LayerGroupList = styled(uilibGl.Flex) `
5251
+ flex-direction: column;
5252
+ height: 100%;
5253
+ flex-wrap: nowrap;
5254
+ overflow-x: ${({ $noScroll }) => ($noScroll ? "visible" : "hidden")};
5255
+ overflow-y: ${({ $noScroll }) => ($noScroll ? "visible" : "auto")};
5256
+ padding: 0 0.125rem 0 0.75rem;
5257
+ scrollbar-gutter: stable;
5258
+
5259
+ > * {
5260
+ flex-grow: 1;
5261
+ }
5258
5262
  `;
5259
5263
  const PresentationHeaderButtons = styled(uilibGl.Flex) ``;
5260
- const PresentationPanelContainer = styled.div `
5261
- position: absolute;
5262
- top: 0;
5263
- left: calc(${({ left }) => left || 0}px + 0.75rem);
5264
- bottom: 0;
5265
- z-index: 3;
5266
- display: flex;
5267
- flex-direction: column;
5268
- width: ${LEFT_PANEL_HEADER_HEIGHT}px;
5269
- padding-right: 0.5rem;
5270
- scrollbar-gutter: stable;
5271
- overflow-y: hidden;
5272
-
5273
- :hover {
5274
- overflow-y: auto;
5275
- }
5276
-
5264
+ const PresentationPanelContainer = styled.div `
5265
+ position: absolute;
5266
+ top: 0;
5267
+ left: calc(${({ left }) => left || 0}px + 0.75rem);
5268
+ bottom: 0;
5269
+ z-index: 3;
5270
+ display: flex;
5271
+ flex-direction: column;
5272
+ width: ${LEFT_PANEL_HEADER_HEIGHT}px;
5273
+ padding-right: 0.5rem;
5274
+ scrollbar-gutter: stable;
5275
+ overflow-y: hidden;
5276
+
5277
+ :hover {
5278
+ overflow-y: auto;
5279
+ }
5280
+
5277
5281
  ${({ showLayers }) => !showLayers &&
5278
- styled.css `
5279
- > :first-child {
5280
- padding-bottom: 0;
5281
- }
5282
- `};
5283
-
5284
- ${PresentationHeader} > * {
5285
- position: relative;
5286
- z-index: 2;
5287
- }
5288
-
5289
- /* PaginationWrapper {
5290
- ${PresentationWrapperCss};
5291
- width: calc(100% - 2rem);
5292
- min-height: 8.625rem;
5293
- padding-top: 0.5rem;
5294
- padding-bottom: 0.5rem;
5295
- margin-bottom: 0.75rem;
5296
- }*/
5297
-
5298
- ${DashboardWrapper} {
5299
- width: 100%;
5300
- margin-top: 0;
5301
-
5302
- ${DashboardContent} {
5303
- padding: 0;
5304
- overflow-y: unset;
5305
-
5306
- > * > ${ContainerWrapper} > * > ${ContainerWrapper} {
5307
- ${PresentationWrapperCss};
5308
- width: calc(100% - 3rem);
5309
- }
5310
- }
5311
- }
5312
-
5313
- ${DashboardPlaceholder} {
5314
- ${PresentationWrapperCss};
5315
- width: 18.5rem;
5316
- height: 10.75rem;
5317
- }
5318
-
5319
- ${LayerListContainer} {
5320
- height: auto;
5321
- margin: 0 -1.125rem -1.5rem;
5322
- padding: 0;
5323
-
5324
- ${LayerGroupList} {
5325
- padding: 0;
5326
- }
5327
- }
5328
- `;
5329
- const DataSourceErrorContainer = styled(uilibGl.Flex) `
5330
- align-items: center;
5331
- justify-content: center;
5332
- flex-wrap: nowrap;
5333
- flex-grow: 1;
5334
- padding: 1rem;
5335
- border: 1px ${({ theme: { palette } }) => palette.element} solid;
5336
- border-radius: 10px;
5337
- font-size: 0.875rem;
5338
- color: ${({ theme: { palette } }) => palette.textDisabled};
5339
-
5340
- span[kind] {
5341
- margin-right: 1rem;
5342
-
5343
- :after {
5344
- color: ${({ theme: { palette } }) => palette.iconDisabled};
5345
- }
5346
- }
5347
- `;
5348
- const AttributeLabel = styled(uilibGl.Description) `
5349
- margin-top: 0 !important;
5350
- margin-bottom: ${({ forCheckbox }) => (forCheckbox ? "0.75rem" : "0.25rem")} !important;
5351
- padding-left: ${({ isEdit }) => (isEdit ? "0.5rem" : "0")};
5352
- `;
5353
- const FeatureControls = styled(uilibGl.Flex) `
5354
- align-items: center;
5355
- gap: 1rem;
5356
- flex-wrap: nowrap;
5357
- position: relative;
5358
- flex-shrink: 0;
5359
-
5360
- button {
5361
- padding: 0;
5362
- width: auto;
5363
- }
5282
+ styled.css `
5283
+ > :first-child {
5284
+ padding-bottom: 0;
5285
+ }
5286
+ `};
5287
+
5288
+ ${PresentationHeader} > * {
5289
+ position: relative;
5290
+ z-index: 2;
5291
+ }
5292
+
5293
+ /* PaginationWrapper {
5294
+ ${PresentationWrapperCss};
5295
+ width: calc(100% - 2rem);
5296
+ min-height: 8.625rem;
5297
+ padding-top: 0.5rem;
5298
+ padding-bottom: 0.5rem;
5299
+ margin-bottom: 0.75rem;
5300
+ }*/
5301
+
5302
+ ${DashboardWrapper} {
5303
+ width: 100%;
5304
+ margin-top: 0;
5305
+
5306
+ ${DashboardContent} {
5307
+ padding: 0;
5308
+ overflow-y: unset;
5309
+
5310
+ > * > ${ContainerWrapper} > * > ${ContainerWrapper} {
5311
+ ${PresentationWrapperCss};
5312
+ width: calc(100% - 3rem);
5313
+ }
5314
+ }
5315
+ }
5316
+
5317
+ ${DashboardPlaceholder} {
5318
+ ${PresentationWrapperCss};
5319
+ width: 18.5rem;
5320
+ height: 10.75rem;
5321
+ }
5322
+
5323
+ ${LayerListContainer} {
5324
+ height: auto;
5325
+ margin: 0 -1.125rem -1.5rem;
5326
+ padding: 0;
5327
+
5328
+ ${LayerGroupList} {
5329
+ padding: 0;
5330
+ }
5331
+ }
5332
+ `;
5333
+ const DataSourceErrorContainer = styled(uilibGl.Flex) `
5334
+ align-items: center;
5335
+ justify-content: center;
5336
+ flex-wrap: nowrap;
5337
+ flex-grow: 1;
5338
+ padding: 1rem;
5339
+ border: 1px ${({ theme: { palette } }) => palette.element} solid;
5340
+ border-radius: 10px;
5341
+ font-size: 0.875rem;
5342
+ color: ${({ theme: { palette } }) => palette.textDisabled};
5343
+
5344
+ span[kind] {
5345
+ margin-right: 1rem;
5346
+
5347
+ :after {
5348
+ color: ${({ theme: { palette } }) => palette.iconDisabled};
5349
+ }
5350
+ }
5351
+ `;
5352
+ const AttributeLabel = styled(uilibGl.Description) `
5353
+ margin-top: 0 !important;
5354
+ margin-bottom: ${({ forCheckbox }) => (forCheckbox ? "0.75rem" : "0.25rem")} !important;
5355
+ padding-left: ${({ isEdit }) => (isEdit ? "0.5rem" : "0")};
5356
+ `;
5357
+ const FeatureControls = styled(uilibGl.Flex) `
5358
+ align-items: center;
5359
+ gap: 1rem;
5360
+ flex-wrap: nowrap;
5361
+ position: relative;
5362
+ flex-shrink: 0;
5363
+
5364
+ button {
5365
+ padding: 0;
5366
+ width: auto;
5367
+ }
5364
5368
  `;
5365
5369
 
5366
5370
  const getAttributeByName = (attributeName, attributes) => {
@@ -5496,10 +5500,10 @@ const TwoColumnContainer = React.memo(({ config, elementConfig, type, renderElem
5496
5500
  return renderAttributes?.length ? (jsxRuntime.jsx(jsxRuntime.Fragment, { children: renderAttributes.map(attribute => renderContainer(elementConfig, attribute)) })) : (renderContainer(elementConfig));
5497
5501
  });
5498
5502
 
5499
- const InnerContainerWrapper = styled.div `
5500
- cursor: ${({ onClick }) => (onClick ? "pointer" : "default")};
5501
- width: ${({ column }) => (column ? "100%" : "auto")};
5502
- opacity: ${({ hasAnyFilter, isFiltered }) => (isFiltered ? 1 : hasAnyFilter ? FILTERED_VALUE_OPACITY / 100 : 1)};
5503
+ const InnerContainerWrapper = styled.div `
5504
+ cursor: ${({ onClick }) => (onClick ? "pointer" : "default")};
5505
+ width: ${({ column }) => (column ? "100%" : "auto")};
5506
+ opacity: ${({ hasAnyFilter, isFiltered }) => (isFiltered ? 1 : hasAnyFilter ? FILTERED_VALUE_OPACITY / 100 : 1)};
5503
5507
  `;
5504
5508
 
5505
5509
  const DataSourceInnerContainer = React.memo(({ config, elementConfig, feature, maxValue, type, index, innerComponent }) => {
@@ -5570,107 +5574,107 @@ const DataSourceInnerContainer = React.memo(({ config, elementConfig, feature, m
5570
5574
  return (jsxRuntime.jsx(InnerContainerWrapper, { hasAnyFilter: hasAnyFilter, isFiltered: isFiltered(value), column: column === undefined || column, onClick: filterName ? () => onFilter(value) : undefined, children: jsxRuntime.jsx(InnerContainer, { config: config, elementConfig: elementConfig, feature: feature, maxValue: maxValue, type: type, index: index, renderElement: render }) }));
5571
5575
  });
5572
5576
 
5573
- const DataSourceProgressContainerWrapper = styled.div `
5574
- width: 100%;
5575
- `;
5576
- const ContainerToggler = styled(uilibGl.LegendToggler) `
5577
- width: auto;
5578
- margin-left: -1rem;
5579
- `;
5580
-
5581
- const ProgressContainerWrapper = styled(uilibGl.Flex) `
5582
- align-items: center;
5583
- width: 100%;
5584
- margin-bottom: 1rem;
5585
- `;
5586
- const ProgressIcon = styled.div `
5587
- margin-right: 0.5rem;
5588
- `;
5589
- const ProgressContent = styled(uilibGl.Flex) `
5590
- flex: 1;
5591
- flex-direction: column;
5592
- `;
5593
- const ProgressAlias = styled(uilibGl.Flex) `
5594
- flex: 1;
5595
- justify-content: space-between;
5596
- margin-bottom: 0.25rem;
5597
- font-size: 0.75rem;
5598
- color: ${({ theme: { palette } }) => palette.textSecondary};
5599
- `;
5600
- const ProgressValue = styled(uilibGl.Flex) `
5601
- align-items: center;
5602
- width: auto;
5603
- font-size: 1rem;
5604
- color: ${({ theme: { palette } }) => palette.textPrimary};
5605
- `;
5606
- const ProgressInnerValue = styled(ProgressValue) `
5607
- justify-content: flex-end;
5608
- width: 4rem;
5609
- margin-left: 0.5rem;
5610
- `;
5611
- const ProgressUnits = styled(uilibGl.Flex) `
5612
- margin-left: 0.25rem;
5613
- font-size: 0.75rem;
5614
- color: ${({ theme: { palette } }) => palette.textSecondary};
5615
- `;
5616
- const ProgressBarWrapper = styled.div `
5617
- flex-grow: 1;
5618
- height: 0.5rem;
5619
- background-color: ${({ theme: { palette } }) => palette.element};
5620
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.xSmall};
5621
- `;
5622
- const ProgressBarContainer = styled(uilibGl.Flex) `
5623
- position: relative;
5624
- align-items: center;
5625
- width: 100%;
5626
-
5577
+ const DataSourceProgressContainerWrapper = styled.div `
5578
+ width: 100%;
5579
+ `;
5580
+ const ContainerToggler = styled(uilibGl.LegendToggler) `
5581
+ width: auto;
5582
+ margin-left: -1rem;
5583
+ `;
5584
+
5585
+ const ProgressContainerWrapper = styled(uilibGl.Flex) `
5586
+ align-items: center;
5587
+ width: 100%;
5588
+ margin-bottom: 1rem;
5589
+ `;
5590
+ const ProgressIcon = styled.div `
5591
+ margin-right: 0.5rem;
5592
+ `;
5593
+ const ProgressContent = styled(uilibGl.Flex) `
5594
+ flex: 1;
5595
+ flex-direction: column;
5596
+ `;
5597
+ const ProgressAlias = styled(uilibGl.Flex) `
5598
+ flex: 1;
5599
+ justify-content: space-between;
5600
+ margin-bottom: 0.25rem;
5601
+ font-size: 0.75rem;
5602
+ color: ${({ theme: { palette } }) => palette.textSecondary};
5603
+ `;
5604
+ const ProgressValue = styled(uilibGl.Flex) `
5605
+ align-items: center;
5606
+ width: auto;
5607
+ font-size: 1rem;
5608
+ color: ${({ theme: { palette } }) => palette.textPrimary};
5609
+ `;
5610
+ const ProgressInnerValue = styled(ProgressValue) `
5611
+ justify-content: flex-end;
5612
+ width: 4rem;
5613
+ margin-left: 0.5rem;
5614
+ `;
5615
+ const ProgressUnits = styled(uilibGl.Flex) `
5616
+ margin-left: 0.25rem;
5617
+ font-size: 0.75rem;
5618
+ color: ${({ theme: { palette } }) => palette.textSecondary};
5619
+ `;
5620
+ const ProgressBarWrapper = styled.div `
5621
+ flex-grow: 1;
5622
+ height: 0.5rem;
5623
+ background-color: ${({ theme: { palette } }) => palette.element};
5624
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.xSmall};
5625
+ `;
5626
+ const ProgressBarContainer = styled(uilibGl.Flex) `
5627
+ position: relative;
5628
+ align-items: center;
5629
+ width: 100%;
5630
+
5627
5631
  ${({ innerValue }) => innerValue &&
5628
- styled.css `
5629
- ${ProgressBarWrapper} {
5630
- height: 1.125rem;
5631
- }
5632
-
5633
- ${ProgressInnerValue} {
5634
- z-index: 1;
5635
- position: absolute;
5636
- right: 0.25rem;
5637
- }
5638
- `}
5639
- `;
5640
- const ProgressBar = styled.div `
5641
- width: ${({ $width }) => $width};
5642
- height: inherit;
5643
- background-color: ${({ $color }) => $color || "#a7d759"};
5644
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.xSmall};
5645
- `;
5646
- const ProgressTooltipAlias = styled.div `
5647
- margin-bottom: 0.25rem;
5648
- text-align: left;
5649
- color: ${({ theme: { palette } }) => palette.primary};
5632
+ styled.css `
5633
+ ${ProgressBarWrapper} {
5634
+ height: 1.125rem;
5635
+ }
5636
+
5637
+ ${ProgressInnerValue} {
5638
+ z-index: 1;
5639
+ position: absolute;
5640
+ right: 0.25rem;
5641
+ }
5642
+ `}
5643
+ `;
5644
+ const ProgressBar = styled.div `
5645
+ width: ${({ $width }) => $width};
5646
+ height: inherit;
5647
+ background-color: ${({ $color }) => $color || "#a7d759"};
5648
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.xSmall};
5649
+ `;
5650
+ const ProgressTooltipAlias = styled.div `
5651
+ margin-bottom: 0.25rem;
5652
+ text-align: left;
5653
+ color: ${({ theme: { palette } }) => palette.primary};
5650
5654
  `;
5651
5655
  const ProgressTooltipValue = styled.div ``;
5652
- const ProgressTooltipValueContainer = styled(uilibGl.Flex) `
5653
- align-items: center;
5654
-
5655
- > * {
5656
- opacity: 0.65;
5657
- }
5658
-
5659
- ${ProgressTooltipValue} {
5660
- opacity: 1;
5661
- }
5662
- `;
5663
- const ProgressTooltipValueOf = styled.div `
5664
- margin: 0 0.25rem;
5665
- `;
5666
- const ProgressTotalTitle = styled.div `
5667
- font-size: 0.75rem;
5668
- font-weight: bold;
5669
- `;
5670
- const ProgressTotal = styled(uilibGl.Flex) `
5671
- align-items: center;
5672
- justify-content: space-between;
5673
- margin-top: 1rem;
5656
+ const ProgressTooltipValueContainer = styled(uilibGl.Flex) `
5657
+ align-items: center;
5658
+
5659
+ > * {
5660
+ opacity: 0.65;
5661
+ }
5662
+
5663
+ ${ProgressTooltipValue} {
5664
+ opacity: 1;
5665
+ }
5666
+ `;
5667
+ const ProgressTooltipValueOf = styled.div `
5668
+ margin: 0 0.25rem;
5669
+ `;
5670
+ const ProgressTotalTitle = styled.div `
5671
+ font-size: 0.75rem;
5672
+ font-weight: bold;
5673
+ `;
5674
+ const ProgressTotal = styled(uilibGl.Flex) `
5675
+ align-items: center;
5676
+ justify-content: space-between;
5677
+ margin-top: 1rem;
5674
5678
  `;
5675
5679
 
5676
5680
  const DataSourceProgressContainer = React.memo(({ config, elementConfig, type, innerComponent, renderElement }) => {
@@ -5767,166 +5771,166 @@ const DEFAULT_BAR_CHART_MARGINS = {
5767
5771
  right: 0,
5768
5772
  };
5769
5773
 
5770
- const FiltersContainerWrapper = styled(uilibGl.Flex) `
5771
- flex-direction: column;
5772
- padding: ${({ $padding }) => $padding ?? "0.75rem"};
5773
- background-color: ${({ $bgColor, $fontColor, theme: { palette } }) => $bgColor || ($fontColor ? transparentizeColor($fontColor, 6) : palette.element)};
5774
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
5775
-
5776
- ${uilibGl.DropdownField}, input {
5777
- background-color: ${({ theme: { palette } }) => palette.background};
5778
- }
5779
-
5780
- > div:not(:last-child) {
5781
- margin-bottom: 0.5rem;
5782
- }
5783
-
5784
- > label {
5785
- align-items: flex-start;
5786
- font-size: ${({ $fontSize }) => $fontSize || "0.875rem"};
5787
-
5788
- &.active {
5789
- color: ${({ $fontColor }) => $fontColor};
5790
-
5791
- svg rect {
5792
- fill: ${({ $fontColor }) => $fontColor} !important;
5793
- }
5794
- }
5795
-
5796
- &:not(:last-child) {
5797
- margin-bottom: 0.75rem;
5798
- }
5799
-
5800
- &:last-child {
5801
- margin-bottom: 0;
5802
- }
5803
- }
5804
- `;
5805
- const StyledIconButton = styled(uilibGl.IconButton) `
5806
- width: 0.75rem;
5807
- height: 0.75rem;
5808
-
5809
- span[kind] {
5810
- height: 0.75rem;
5811
-
5812
- :after {
5813
- font-size: 0.75rem;
5814
- }
5815
- }
5816
- `;
5817
- const TextFilterContainer = styled.div `
5818
- width: 15.85rem;
5819
-
5820
- ${uilibGl.MultiSelectContainer} {
5821
- color: ${({ theme: { palette } }) => palette.textPrimary};
5822
-
5823
- ${uilibGl.IconButtonButton} {
5824
- span[kind]:after {
5825
- color: ${({ theme: { palette } }) => palette.textPrimary};
5826
- }
5827
- }
5828
- }
5829
- `;
5830
- const BarChartContainer = styled.div `
5831
- width: 100%;
5832
- overflow-x: hidden;
5833
-
5774
+ const FiltersContainerWrapper = styled(uilibGl.Flex) `
5775
+ flex-direction: column;
5776
+ padding: ${({ $padding }) => $padding ?? "0.75rem"};
5777
+ background-color: ${({ $bgColor, $fontColor, theme: { palette } }) => $bgColor || ($fontColor ? transparentizeColor($fontColor, 6) : palette.element)};
5778
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
5779
+
5780
+ ${uilibGl.DropdownField}, input {
5781
+ background-color: ${({ theme: { palette } }) => palette.background};
5782
+ }
5783
+
5784
+ > div:not(:last-child) {
5785
+ margin-bottom: 0.5rem;
5786
+ }
5787
+
5788
+ > label {
5789
+ align-items: flex-start;
5790
+ font-size: ${({ $fontSize }) => $fontSize || "0.875rem"};
5791
+
5792
+ &.active {
5793
+ color: ${({ $fontColor }) => $fontColor};
5794
+
5795
+ svg rect {
5796
+ fill: ${({ $fontColor }) => $fontColor} !important;
5797
+ }
5798
+ }
5799
+
5800
+ &:not(:last-child) {
5801
+ margin-bottom: 0.75rem;
5802
+ }
5803
+
5804
+ &:last-child {
5805
+ margin-bottom: 0;
5806
+ }
5807
+ }
5808
+ `;
5809
+ const StyledIconButton = styled(uilibGl.IconButton) `
5810
+ width: 0.75rem;
5811
+ height: 0.75rem;
5812
+
5813
+ span[kind] {
5814
+ height: 0.75rem;
5815
+
5816
+ :after {
5817
+ font-size: 0.75rem;
5818
+ }
5819
+ }
5820
+ `;
5821
+ const TextFilterContainer = styled.div `
5822
+ width: 15.85rem;
5823
+
5824
+ ${uilibGl.MultiSelectContainer} {
5825
+ color: ${({ theme: { palette } }) => palette.textPrimary};
5826
+
5827
+ ${uilibGl.IconButtonButton} {
5828
+ span[kind]:after {
5829
+ color: ${({ theme: { palette } }) => palette.textPrimary};
5830
+ }
5831
+ }
5832
+ }
5833
+ `;
5834
+ const BarChartContainer = styled.div `
5835
+ width: 100%;
5836
+ overflow-x: hidden;
5837
+
5834
5838
  ${({ barHeight, marginBottom }) => !!barHeight &&
5835
- styled.css `
5836
- .barChartBarGlobal rect {
5837
- height: ${barHeight}px;
5838
- y: calc(100% - ${barHeight + marginBottom}px);
5839
- }
5840
- `}
5841
- `;
5842
- const AnyChartWrapper = styled.div `
5843
- width: 100%;
5844
- height: ${({ height }) => height}px;
5845
- `;
5846
- const BarChartWrapper = styled(AnyChartWrapper) `
5847
- width: 100%;
5848
- margin: 0 auto ${BAR_CHART_FOOTER_MARGIN}px;
5849
-
5850
- :hover {
5851
- ${BarChartContainer} {
5852
- overflow-x: auto;
5853
- }
5854
- }
5855
- `;
5856
- const BarChartFilterHeader = styled(uilibGl.Flex) `
5857
- justify-content: space-between;
5858
- align-items: center;
5859
- height: ${({ height }) => `calc(${typeof height === "number" ? `${height}px` : height} - 0.5rem)`};
5860
- padding: 0.25rem 0;
5861
- `;
5862
- const BarChartFilterArrows = styled(uilibGl.Flex) `
5863
- margin-left: -0.5rem;
5864
-
5865
- span[kind] {
5866
- display: flex;
5867
- align-items: center;
5868
-
5869
- :after {
5870
- font-size: 0.75rem;
5871
- }
5872
- }
5873
- `;
5874
- const BarChartFilterSelected = styled.div `
5875
- font-size: 0.75rem;
5876
- font-weight: bold;
5877
- color: ${({ theme: { palette } }) => palette.textPrimary};
5878
- `;
5879
- styled.div `
5880
- color: ${({ theme: { palette } }) => palette.textSecondary};
5881
- `;
5882
- const BarChart = styled(charts.BarChart) `
5883
- .${charts.barChartClassNames.barChartXAxis} {
5884
- .domain,
5885
- line {
5886
- display: none;
5887
- }
5888
-
5889
- .tick {
5890
- text {
5891
- text-anchor: start;
5892
- font-size: 12px;
5893
- color: rgba(48, 69, 79, 0.46);
5894
- }
5895
-
5896
- :last-of-type {
5897
- text {
5898
- text-anchor: end;
5899
- }
5900
- }
5901
- }
5902
- }
5903
-
5904
- .marker {
5905
- font-size: 12px;
5906
- }
5907
- `;
5908
- const TooltipContainer = styled.div `
5909
- position: relative;
5910
- font-size: 0.75rem;
5911
- color: #ffffff;
5912
- margin-bottom: 0.5rem;
5913
- padding: 0.375rem;
5914
- background-color: rgba(0, 0, 0, 1);
5915
- border-radius: 0.25rem;
5916
- box-shadow: 0 0.1875rem 0.5rem rgba(48, 69, 79, 0.06);
5917
-
5918
- :before {
5919
- content: "";
5920
- position: absolute;
5921
- bottom: 0;
5922
- left: 50%;
5923
- transform: translate(-50%, 100%);
5924
- width: 0;
5925
- height: 0;
5926
- border-style: solid;
5927
- border-width: 0.25rem 0.1875rem 0 0.1875rem;
5928
- border-color: rgba(48, 69, 79, 1) transparent transparent transparent;
5929
- }
5839
+ styled.css `
5840
+ .barChartBarGlobal rect {
5841
+ height: ${barHeight}px;
5842
+ y: calc(100% - ${barHeight + marginBottom}px);
5843
+ }
5844
+ `}
5845
+ `;
5846
+ const AnyChartWrapper = styled.div `
5847
+ width: 100%;
5848
+ height: ${({ height }) => height}px;
5849
+ `;
5850
+ const BarChartWrapper = styled(AnyChartWrapper) `
5851
+ width: 100%;
5852
+ margin: 0 auto ${BAR_CHART_FOOTER_MARGIN}px;
5853
+
5854
+ :hover {
5855
+ ${BarChartContainer} {
5856
+ overflow-x: auto;
5857
+ }
5858
+ }
5859
+ `;
5860
+ const BarChartFilterHeader = styled(uilibGl.Flex) `
5861
+ justify-content: space-between;
5862
+ align-items: center;
5863
+ height: ${({ height }) => `calc(${typeof height === "number" ? `${height}px` : height} - 0.5rem)`};
5864
+ padding: 0.25rem 0;
5865
+ `;
5866
+ const BarChartFilterArrows = styled(uilibGl.Flex) `
5867
+ margin-left: -0.5rem;
5868
+
5869
+ span[kind] {
5870
+ display: flex;
5871
+ align-items: center;
5872
+
5873
+ :after {
5874
+ font-size: 0.75rem;
5875
+ }
5876
+ }
5877
+ `;
5878
+ const BarChartFilterSelected = styled.div `
5879
+ font-size: 0.75rem;
5880
+ font-weight: bold;
5881
+ color: ${({ theme: { palette } }) => palette.textPrimary};
5882
+ `;
5883
+ styled.div `
5884
+ color: ${({ theme: { palette } }) => palette.textSecondary};
5885
+ `;
5886
+ const BarChart = styled(charts.BarChart) `
5887
+ .${charts.barChartClassNames.barChartXAxis} {
5888
+ .domain,
5889
+ line {
5890
+ display: none;
5891
+ }
5892
+
5893
+ .tick {
5894
+ text {
5895
+ text-anchor: start;
5896
+ font-size: 12px;
5897
+ color: rgba(48, 69, 79, 0.46);
5898
+ }
5899
+
5900
+ :last-of-type {
5901
+ text {
5902
+ text-anchor: end;
5903
+ }
5904
+ }
5905
+ }
5906
+ }
5907
+
5908
+ .marker {
5909
+ font-size: 12px;
5910
+ }
5911
+ `;
5912
+ const TooltipContainer = styled.div `
5913
+ position: relative;
5914
+ font-size: 0.75rem;
5915
+ color: #ffffff;
5916
+ margin-bottom: 0.5rem;
5917
+ padding: 0.375rem;
5918
+ background-color: rgba(0, 0, 0, 1);
5919
+ border-radius: 0.25rem;
5920
+ box-shadow: 0 0.1875rem 0.5rem rgba(48, 69, 79, 0.06);
5921
+
5922
+ :before {
5923
+ content: "";
5924
+ position: absolute;
5925
+ bottom: 0;
5926
+ left: 50%;
5927
+ transform: translate(-50%, 100%);
5928
+ width: 0;
5929
+ height: 0;
5930
+ border-style: solid;
5931
+ border-width: 0.25rem 0.1875rem 0 0.1875rem;
5932
+ border-color: rgba(48, 69, 79, 1) transparent transparent transparent;
5933
+ }
5930
5934
  `;
5931
5935
 
5932
5936
  const FiltersContainer = React.memo(({ elementConfig, config, type, renderElement }) => {
@@ -6006,64 +6010,64 @@ const TwoColumnsInnerContainer = React.memo(({ renderElement }) => {
6006
6010
  return (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.jsxs(TwoColumnContainerWrapper, { children: [jsxRuntime.jsxs(Container, { children: [jsxRuntime.jsx(ContainerAlias, { children: renderElement({ id: "firstAlias" }) }), jsxRuntime.jsx(ContainerValue, { big: true, children: renderElement({ id: "firstValue" }) })] }), jsxRuntime.jsxs(Container, { children: [jsxRuntime.jsx(ContainerAlias, { children: renderElement({ id: "secondAlias" }) }), jsxRuntime.jsx(ContainerValue, { big: true, children: renderElement({ id: "secondValue" }) })] })] }), renderElement({ id: "thirdContainer" })] }));
6007
6011
  });
6008
6012
 
6009
- const ImageContainerBg$1 = styled.div `
6010
- position: absolute;
6011
- top: 0;
6012
- bottom: 0;
6013
- left: 0;
6014
- right: 0;
6015
-
6016
- img {
6017
- width: 100%;
6018
- height: 100%;
6019
- object-position: center;
6020
- object-fit: cover;
6021
- }
6022
- `;
6023
- const ImageContainerTitle = styled.div `
6024
- width: 100%;
6025
- overflow-wrap: break-word;
6026
- font-size: 1rem;
6027
- font-weight: 500;
6028
- `;
6029
- const ImageContainerText = styled.div `
6030
- width: 100%;
6031
- overflow-wrap: break-word;
6032
- margin-top: 0.5rem;
6033
- font-size: 0.75rem;
6034
- `;
6035
- const ImageContainerButton$1 = styled(uilibGl.FlatButton) `
6036
- min-height: 1.5rem;
6037
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.large};
6038
- background-color: ${({ theme: { palette } }) => palette.primary};
6039
- text-transform: none;
6040
-
6041
- :hover {
6042
- background-color: ${({ theme: { palette } }) => palette.primaryDeep};
6043
- }
6044
- `;
6045
- const ImageContainerWrapper = styled(uilibGl.Flex) `
6046
- flex-direction: column;
6047
- justify-content: flex-end;
6048
- position: relative;
6049
- padding: 1rem;
6050
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
6051
- overflow: hidden;
6052
-
6053
- ${ImageContainerTitle}, ${ImageContainerText}, ${ImageContainerButton$1} {
6054
- z-index: 1;
6055
- color: ${({ theme: { palette } }) => palette.textContrast};
6056
- }
6057
-
6058
- :after {
6059
- content: "";
6060
- position: absolute;
6061
- top: 0;
6062
- bottom: 0;
6063
- left: 0;
6064
- right: 0;
6065
- background-color: rgba(0, 0, 0, 0.4);
6066
- }
6013
+ const ImageContainerBg$1 = styled.div `
6014
+ position: absolute;
6015
+ top: 0;
6016
+ bottom: 0;
6017
+ left: 0;
6018
+ right: 0;
6019
+
6020
+ img {
6021
+ width: 100%;
6022
+ height: 100%;
6023
+ object-position: center;
6024
+ object-fit: cover;
6025
+ }
6026
+ `;
6027
+ const ImageContainerTitle = styled.div `
6028
+ width: 100%;
6029
+ overflow-wrap: break-word;
6030
+ font-size: 1rem;
6031
+ font-weight: 500;
6032
+ `;
6033
+ const ImageContainerText = styled.div `
6034
+ width: 100%;
6035
+ overflow-wrap: break-word;
6036
+ margin-top: 0.5rem;
6037
+ font-size: 0.75rem;
6038
+ `;
6039
+ const ImageContainerButton$1 = styled(uilibGl.FlatButton) `
6040
+ min-height: 1.5rem;
6041
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.large};
6042
+ background-color: ${({ theme: { palette } }) => palette.primary};
6043
+ text-transform: none;
6044
+
6045
+ :hover {
6046
+ background-color: ${({ theme: { palette } }) => palette.primaryDeep};
6047
+ }
6048
+ `;
6049
+ const ImageContainerWrapper = styled(uilibGl.Flex) `
6050
+ flex-direction: column;
6051
+ justify-content: flex-end;
6052
+ position: relative;
6053
+ padding: 1rem;
6054
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
6055
+ overflow: hidden;
6056
+
6057
+ ${ImageContainerTitle}, ${ImageContainerText}, ${ImageContainerButton$1} {
6058
+ z-index: 1;
6059
+ color: ${({ theme: { palette } }) => palette.textContrast};
6060
+ }
6061
+
6062
+ :after {
6063
+ content: "";
6064
+ position: absolute;
6065
+ top: 0;
6066
+ bottom: 0;
6067
+ left: 0;
6068
+ right: 0;
6069
+ background-color: rgba(0, 0, 0, 0.4);
6070
+ }
6067
6071
  `;
6068
6072
 
6069
6073
  const ImageContainer = React.memo(({ elementConfig, renderElement }) => {
@@ -6071,52 +6075,52 @@ const ImageContainer = React.memo(({ elementConfig, renderElement }) => {
6071
6075
  return (jsxRuntime.jsxs(ImageContainerWrapper, { style: style, children: [jsxRuntime.jsx(ImageContainerTitle, { children: renderElement({ id: "alias" }) }), jsxRuntime.jsx(ImageContainerText, { children: renderElement({ id: "text" }) }), renderElement({ id: "button" }), jsxRuntime.jsx(ImageContainerBg$1, { children: renderElement({ id: "image" }) })] }));
6072
6076
  });
6073
6077
 
6074
- const IconContainerWrapper = styled(uilibGl.Flex) `
6075
- flex-direction: column;
6076
- justify-content: center;
6077
- position: relative;
6078
- padding: 0.5rem 1rem 1rem;
6079
- background-color: ${({ theme: { palette } }) => palette.element};
6080
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
6081
- overflow: hidden;
6082
- `;
6083
- const IconContainerHeaderWrapper = styled(uilibGl.Flex) `
6084
- justify-content: space-between;
6085
- align-items: center;
6086
- flex-wrap: nowrap;
6087
- width: 100%;
6088
- margin-bottom: 0.25rem;
6089
- `;
6090
- const IconContainerHeader = styled(uilibGl.Flex) `
6091
- align-items: center;
6092
- flex-wrap: nowrap;
6093
- width: 100%;
6094
- margin-right: 0.5rem;
6095
- font-size: 0.875rem;
6096
-
6097
- ${uilibGl.Icon} {
6098
- margin-right: 0.5rem;
6099
-
6100
- :after {
6101
- font-size: 1.15rem;
6102
- color: ${({ theme: { palette } }) => palette.textSecondary};
6103
- }
6104
- }
6105
- `;
6106
- const IconContainerTitle = styled(uilibGl.Flex) `
6107
- > * {
6108
- width: 13rem;
6109
- white-space: nowrap;
6110
- overflow: hidden;
6111
- font-weight: bold;
6112
- text-overflow: ellipsis;
6113
- }
6114
- `;
6115
- const IconContainerText = styled.div `
6116
- width: 100%;
6117
- overflow-wrap: break-word;
6118
- font-size: 0.75rem;
6119
- color: ${({ theme: { palette } }) => palette.textSecondary};
6078
+ const IconContainerWrapper = styled(uilibGl.Flex) `
6079
+ flex-direction: column;
6080
+ justify-content: center;
6081
+ position: relative;
6082
+ padding: 0.5rem 1rem 1rem;
6083
+ background-color: ${({ theme: { palette } }) => palette.element};
6084
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
6085
+ overflow: hidden;
6086
+ `;
6087
+ const IconContainerHeaderWrapper = styled(uilibGl.Flex) `
6088
+ justify-content: space-between;
6089
+ align-items: center;
6090
+ flex-wrap: nowrap;
6091
+ width: 100%;
6092
+ margin-bottom: 0.25rem;
6093
+ `;
6094
+ const IconContainerHeader = styled(uilibGl.Flex) `
6095
+ align-items: center;
6096
+ flex-wrap: nowrap;
6097
+ width: 100%;
6098
+ margin-right: 0.5rem;
6099
+ font-size: 0.875rem;
6100
+
6101
+ ${uilibGl.Icon} {
6102
+ margin-right: 0.5rem;
6103
+
6104
+ :after {
6105
+ font-size: 1.15rem;
6106
+ color: ${({ theme: { palette } }) => palette.textSecondary};
6107
+ }
6108
+ }
6109
+ `;
6110
+ const IconContainerTitle = styled(uilibGl.Flex) `
6111
+ > * {
6112
+ width: 13rem;
6113
+ white-space: nowrap;
6114
+ overflow: hidden;
6115
+ font-weight: bold;
6116
+ text-overflow: ellipsis;
6117
+ }
6118
+ `;
6119
+ const IconContainerText = styled.div `
6120
+ width: 100%;
6121
+ overflow-wrap: break-word;
6122
+ font-size: 0.75rem;
6123
+ color: ${({ theme: { palette } }) => palette.textSecondary};
6120
6124
  `;
6121
6125
 
6122
6126
  const IconContainer = React.memo(({ elementConfig, renderElement }) => {
@@ -6138,83 +6142,83 @@ const DataSourceContainer = React.memo(({ config, elementConfig, type, innerComp
6138
6142
  return (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.jsx(ExpandableTitle, { elementConfig: elementConfig, type: type, renderElement: renderElement }), !isVisible ? null : dataSource ? (jsxRuntime.jsx(Container, { isColumn: column, style: { height: isLoading ? "3rem" : "auto", ...style }, children: dataSource.features?.map((feature, index) => (jsxRuntime.jsx(DataSourceInnerContainer, { index: index, type: type, config: config, feature: feature, elementConfig: elementConfig, innerComponent: innerComponent }, index))) })) : (jsxRuntime.jsx(ContainerLoading, {}))] }));
6139
6143
  });
6140
6144
 
6141
- const SvgContainerColorMixin = styled.css `
6142
- path,
6143
- line,
6144
- circle {
6145
- fill: ${({ $fontColor }) => $fontColor};
6146
- }
6147
- `;
6148
- const SvgContainer = styled.div `
6149
- &&& {
6150
- min-width: ${({ $width }) => ($width ? `${$width}px` : "1rem")};
6151
- max-width: ${({ $width }) => ($width ? `${$width}px` : "1rem")};
6152
-
6153
- ${({ $fontColor }) => !!$fontColor && SvgContainerColorMixin};
6154
-
6155
- > * {
6156
- min-width: inherit;
6157
- }
6158
- }
6159
- `;
6160
-
6161
- const ContainerIconTitle = styled(uilibGl.Flex) `
6162
- align-items: center;
6163
- flex-wrap: nowrap;
6164
- color: ${({ fontColor, theme: { palette } }) => fontColor || palette.textSecondary};
6165
-
6166
- svg,
6167
- img,
6168
- span[kind],
6169
- ${SvgContainer} {
6170
- margin-right: 0.5rem;
6171
- }
6172
-
6145
+ const SvgContainerColorMixin = styled.css `
6146
+ path,
6147
+ line,
6148
+ circle {
6149
+ fill: ${({ $fontColor }) => $fontColor};
6150
+ }
6151
+ `;
6152
+ const SvgContainer = styled.div `
6153
+ &&& {
6154
+ min-width: ${({ $width }) => ($width ? `${$width}px` : "1rem")};
6155
+ max-width: ${({ $width }) => ($width ? `${$width}px` : "1rem")};
6156
+
6157
+ ${({ $fontColor }) => !!$fontColor && SvgContainerColorMixin};
6158
+
6159
+ > * {
6160
+ min-width: inherit;
6161
+ }
6162
+ }
6163
+ `;
6164
+
6165
+ const ContainerIconTitle = styled(uilibGl.Flex) `
6166
+ align-items: center;
6167
+ flex-wrap: nowrap;
6168
+ color: ${({ fontColor, theme: { palette } }) => fontColor || palette.textSecondary};
6169
+
6170
+ svg,
6171
+ img,
6172
+ span[kind],
6173
+ ${SvgContainer} {
6174
+ margin-right: 0.5rem;
6175
+ }
6176
+
6173
6177
  ${({ fontColor }) => !!fontColor &&
6174
- styled.css `
6175
- span[kind] {
6176
- color: ${fontColor};
6177
- }
6178
-
6179
- ${SvgContainer} {
6180
- path,
6181
- circle {
6182
- fill: ${fontColor};
6183
- }
6184
- }
6185
- `};
6186
-
6187
- ${uilibGl.LegendToggler} {
6188
- margin-left: 0.25rem;
6189
- }
6190
- `;
6191
- const ContainerTitle = styled(uilibGl.Flex) `
6192
- align-items: center;
6193
- justify-content: space-between;
6194
- width: 100%;
6195
-
6196
- > * {
6197
- font-size: 1.125rem;
6198
- font-weight: 500;
6199
- }
6200
-
6201
- ${uilibGl.LegendToggler} {
6202
- padding-right: 0;
6203
- }
6204
-
6178
+ styled.css `
6179
+ span[kind] {
6180
+ color: ${fontColor};
6181
+ }
6182
+
6183
+ ${SvgContainer} {
6184
+ path,
6185
+ circle {
6186
+ fill: ${fontColor};
6187
+ }
6188
+ }
6189
+ `};
6190
+
6191
+ ${uilibGl.LegendToggler} {
6192
+ margin-left: 0.25rem;
6193
+ }
6194
+ `;
6195
+ const ContainerTitle = styled(uilibGl.Flex) `
6196
+ align-items: center;
6197
+ justify-content: space-between;
6198
+ width: 100%;
6199
+
6200
+ > * {
6201
+ font-size: 1.125rem;
6202
+ font-weight: 500;
6203
+ }
6204
+
6205
+ ${uilibGl.LegendToggler} {
6206
+ padding-right: 0;
6207
+ }
6208
+
6205
6209
  ${({ simple }) => simple &&
6206
- styled.css `
6207
- justify-content: flex-start;
6208
-
6209
- ${ContainerIconTitle} {
6210
- font-size: 0.75rem;
6211
- }
6212
-
6213
- ${uilibGl.LegendToggler} {
6214
- margin-left: 0;
6215
- padding-left: 0.25rem;
6216
- }
6217
- `}
6210
+ styled.css `
6211
+ justify-content: flex-start;
6212
+
6213
+ ${ContainerIconTitle} {
6214
+ font-size: 0.75rem;
6215
+ }
6216
+
6217
+ ${uilibGl.LegendToggler} {
6218
+ margin-left: 0;
6219
+ padding-left: 0.25rem;
6220
+ }
6221
+ `}
6218
6222
  `;
6219
6223
 
6220
6224
  const TitleContainer = React.memo(({ containerId, templateName, layerNames, fontColor, expandable, expanded, isVisible, elementConfig, renderElement, type, }) => {
@@ -6241,9 +6245,9 @@ const TitleContainer = React.memo(({ containerId, templateName, layerNames, font
6241
6245
  return (jsxRuntime.jsx(Container, { isTitle: isVisible, style: style, children: jsxRuntime.jsxs(ContainerTitle, { simple: simple, children: [jsxRuntime.jsxs(ContainerIconTitle, { fontColor: fontColor, children: [renderElement({ id: "titleIcon", wrap: false }), renderElement({ id: "title" }), isLayers && renderToggler] }), !isLayers && renderToggler, renderVisibility] }) }));
6242
6246
  });
6243
6247
 
6244
- const ContainerDivider = styled(uilibGl.Divider) `
6245
- width: 100%;
6246
- border-color: ${({ theme: { palette }, $bgColor }) => $bgColor || palette.elementDeep};
6248
+ const ContainerDivider = styled(uilibGl.Divider) `
6249
+ width: 100%;
6250
+ border-color: ${({ theme: { palette }, $bgColor }) => $bgColor || palette.elementDeep};
6247
6251
  `;
6248
6252
 
6249
6253
  const DividerContainer = React.memo(({ elementConfig, config }) => {
@@ -6296,82 +6300,82 @@ const CameraContainer = React.memo(({ elementConfig, type, renderElement }) => {
6296
6300
  return (jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [jsxRuntime.jsx(ExpandableTitle, { elementConfig: elementConfig, type: type, renderElement: renderElement }), isVisible && (jsxRuntime.jsxs(Container, { style: style, children: [jsxRuntime.jsx(ContainerAlias, { hasBottomMargin: true, children: renderElement({ id: "alias" }) }), jsxRuntime.jsx(ContainerValue, { children: renderElement({ id: "value", wrap: false }) })] }))] }));
6297
6301
  });
6298
6302
 
6299
- const TabAnchor = styled.div `
6300
- position: absolute;
6301
- top: -1.5rem;
6302
- right: 0;
6303
- `;
6304
- const TabValue = styled(uilibGl.Flex) `
6305
- flex-wrap: nowrap;
6306
- `;
6307
- const noBgMixin = styled.css `
6308
- background-color: transparent;
6309
- border-radius: 0;
6310
- border-bottom: 0.125rem solid
6311
- ${({ active, bgColor, theme: { palette } }) => (active ? bgColor || palette.primary : palette.element)};
6312
-
6313
- ${TabValue},
6314
- span[kind] {
6315
- color: ${({ active, bgColor, theme: { palette } }) => active ? bgColor || palette.primary : palette.textSecondary};
6316
- }
6317
-
6318
- &&& svg {
6319
- path,
6320
- line,
6321
- circle {
6322
- fill: ${({ active, bgColor, theme: { palette } }) => active ? bgColor || palette.primary : palette.textSecondary};
6323
- }
6324
- }
6325
-
6326
- :not(:last-child) {
6327
- margin-right: 0;
6328
- }
6329
- `;
6330
- const TabContainer = styled.a `
6331
- display: flex;
6332
- flex-direction: ${({ column }) => (column ? "column" : "row")};
6333
- align-items: center;
6334
- justify-content: center;
6335
- flex-wrap: nowrap;
6336
- padding: ${({ onlyIcon }) => (onlyIcon ? 1 : 0.5)}rem 1rem;
6337
- background-color: ${({ active, bgColor, theme: { palette } }) => active ? bgColor || palette.primary : palette.element};
6338
- border-radius: ${({ column, radius, theme: { borderRadius } }) => radius ? `${radius}px` : column ? borderRadius.medium : borderRadius.xLarge};
6339
- text-decoration: none;
6340
-
6341
- :not(:last-child) {
6342
- margin-right: 0.5rem;
6343
- }
6344
-
6345
- ${TabValue} {
6346
- margin-top: ${({ column }) => (column ? 0.5 : 0)}rem;
6347
- margin-left: ${({ column, hasIcon }) => (column || !hasIcon ? 0 : 0.5)}rem;
6348
- font-size: ${({ column }) => (column ? 0.75 : 0.875)}rem;
6349
- white-space: nowrap;
6350
- }
6351
-
6352
- ${TabValue},
6353
- span[kind] {
6354
- color: ${({ active, theme: { palette } }) => (active ? palette.textContrast : palette.textSecondary)};
6355
- }
6356
-
6357
- ${SvgContainer$1} {
6358
- height: 1rem;
6359
- }
6360
-
6361
- svg,
6362
- img {
6363
- max-width: 1rem;
6364
- max-height: 1rem;
6365
- }
6366
-
6367
- ${({ noBg }) => noBg && noBgMixin};
6368
- `;
6369
- const SwiperContainer = styled.div `
6370
- width: 100%;
6371
-
6372
- .swiper-wrapper {
6373
- display: flex;
6374
- }
6303
+ const TabAnchor = styled.div `
6304
+ position: absolute;
6305
+ top: -1.5rem;
6306
+ right: 0;
6307
+ `;
6308
+ const TabValue = styled(uilibGl.Flex) `
6309
+ flex-wrap: nowrap;
6310
+ `;
6311
+ const noBgMixin = styled.css `
6312
+ background-color: transparent;
6313
+ border-radius: 0;
6314
+ border-bottom: 0.125rem solid
6315
+ ${({ active, bgColor, theme: { palette } }) => (active ? bgColor || palette.primary : palette.element)};
6316
+
6317
+ ${TabValue},
6318
+ span[kind] {
6319
+ color: ${({ active, bgColor, theme: { palette } }) => active ? bgColor || palette.primary : palette.textSecondary};
6320
+ }
6321
+
6322
+ &&& svg {
6323
+ path,
6324
+ line,
6325
+ circle {
6326
+ fill: ${({ active, bgColor, theme: { palette } }) => active ? bgColor || palette.primary : palette.textSecondary};
6327
+ }
6328
+ }
6329
+
6330
+ :not(:last-child) {
6331
+ margin-right: 0;
6332
+ }
6333
+ `;
6334
+ const TabContainer = styled.a `
6335
+ display: flex;
6336
+ flex-direction: ${({ column }) => (column ? "column" : "row")};
6337
+ align-items: center;
6338
+ justify-content: center;
6339
+ flex-wrap: nowrap;
6340
+ padding: ${({ onlyIcon }) => (onlyIcon ? 1 : 0.5)}rem 1rem;
6341
+ background-color: ${({ active, bgColor, theme: { palette } }) => active ? bgColor || palette.primary : palette.element};
6342
+ border-radius: ${({ column, radius, theme: { borderRadius } }) => radius ? `${radius}px` : column ? borderRadius.medium : borderRadius.xLarge};
6343
+ text-decoration: none;
6344
+
6345
+ :not(:last-child) {
6346
+ margin-right: 0.5rem;
6347
+ }
6348
+
6349
+ ${TabValue} {
6350
+ margin-top: ${({ column }) => (column ? 0.5 : 0)}rem;
6351
+ margin-left: ${({ column, hasIcon }) => (column || !hasIcon ? 0 : 0.5)}rem;
6352
+ font-size: ${({ column }) => (column ? 0.75 : 0.875)}rem;
6353
+ white-space: nowrap;
6354
+ }
6355
+
6356
+ ${TabValue},
6357
+ span[kind] {
6358
+ color: ${({ active, theme: { palette } }) => (active ? palette.textContrast : palette.textSecondary)};
6359
+ }
6360
+
6361
+ ${SvgContainer$1} {
6362
+ height: 1rem;
6363
+ }
6364
+
6365
+ svg,
6366
+ img {
6367
+ max-width: 1rem;
6368
+ max-height: 1rem;
6369
+ }
6370
+
6371
+ ${({ noBg }) => noBg && noBgMixin};
6372
+ `;
6373
+ const SwiperContainer = styled.div `
6374
+ width: 100%;
6375
+
6376
+ .swiper-wrapper {
6377
+ display: flex;
6378
+ }
6375
6379
  `;
6376
6380
 
6377
6381
  const TabsContainer = React.memo(({ elementConfig, type }) => {
@@ -6399,96 +6403,96 @@ const TabsContainer = React.memo(({ elementConfig, type }) => {
6399
6403
  });
6400
6404
 
6401
6405
  const ContainerIconValue = styled(uilibGl.Flex) ``;
6402
- const RoundedBackgroundContainerWrapper = styled(uilibGl.Flex) `
6403
- position: relative;
6404
- flex-direction: ${({ $bigIcon }) => ($bigIcon ? "row" : "column")};
6405
- width: 9rem;
6406
- padding: 0.75rem 0.75rem 0.5rem;
6407
- background-color: ${({ theme: { palette } }) => palette.element};
6408
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.large};
6409
- flex-wrap: nowrap;
6410
-
6411
- && {
6412
- margin-bottom: 0.5rem;
6413
- }
6414
-
6406
+ const RoundedBackgroundContainerWrapper = styled(uilibGl.Flex) `
6407
+ position: relative;
6408
+ flex-direction: ${({ $bigIcon }) => ($bigIcon ? "row" : "column")};
6409
+ width: 9rem;
6410
+ padding: 0.75rem 0.75rem 0.5rem;
6411
+ background-color: ${({ theme: { palette } }) => palette.element};
6412
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.large};
6413
+ flex-wrap: nowrap;
6414
+
6415
+ && {
6416
+ margin-bottom: 0.5rem;
6417
+ }
6418
+
6415
6419
  ${({ $center }) => $center &&
6416
- styled.css `
6417
- align-items: center;
6418
-
6419
- > * {
6420
- display: flex;
6421
- justify-content: center;
6422
- text-align: center;
6423
- width: 100%;
6424
- }
6425
- `};
6426
-
6420
+ styled.css `
6421
+ align-items: center;
6422
+
6423
+ > * {
6424
+ display: flex;
6425
+ justify-content: center;
6426
+ text-align: center;
6427
+ width: 100%;
6428
+ }
6429
+ `};
6430
+
6427
6431
  ${({ $color }) => $color &&
6428
- styled.css `
6429
- background-color: ${transparentizeColor($color, 6)};
6430
-
6431
- * {
6432
- color: ${$color};
6433
- }
6434
- `};
6435
-
6436
- ${ContainerIcon}, ${SvgContainer$1} {
6437
- margin-bottom: 0.25rem;
6438
- }
6439
-
6432
+ styled.css `
6433
+ background-color: ${transparentizeColor($color, 6)};
6434
+
6435
+ * {
6436
+ color: ${$color};
6437
+ }
6438
+ `};
6439
+
6440
+ ${ContainerIcon}, ${SvgContainer$1} {
6441
+ margin-bottom: 0.25rem;
6442
+ }
6443
+
6440
6444
  ${({ $bigIcon }) => $bigIcon &&
6441
- styled.css `
6442
- ${ContainerIcon}, ${SvgContainer$1} {
6443
- position: absolute;
6444
- top: 0.75rem;
6445
- right: 0.75rem;
6446
- width: 3rem;
6447
- opacity: 0.12;
6448
-
6449
- :after {
6450
- font-size: 3rem;
6451
- }
6452
- }
6453
- `};
6454
-
6455
- ${ContainerIconValue} {
6456
- align-items: center;
6457
- flex-direction: column;
6458
-
6445
+ styled.css `
6446
+ ${ContainerIcon}, ${SvgContainer$1} {
6447
+ position: absolute;
6448
+ top: 0.75rem;
6449
+ right: 0.75rem;
6450
+ width: 3rem;
6451
+ opacity: 0.12;
6452
+
6453
+ :after {
6454
+ font-size: 3rem;
6455
+ }
6456
+ }
6457
+ `};
6458
+
6459
+ ${ContainerIconValue} {
6460
+ align-items: center;
6461
+ flex-direction: column;
6462
+
6459
6463
  ${({ $big }) => $big &&
6460
- styled.css `
6461
- flex-direction: row;
6462
- margin-bottom: 0.5rem;
6463
-
6464
- > * {
6465
- text-align: left;
6466
- }
6467
-
6468
- span[kind] {
6469
- margin-right: 0.5rem;
6470
- }
6471
-
6472
- ${ContainerValue} {
6473
- width: auto;
6474
- }
6475
- `};
6476
- }
6477
-
6478
- ${ContainerValue} {
6479
- flex-direction: ${({ $inlineUnits }) => ($inlineUnits ? "row" : "column")};
6480
- justify-content: ${({ $big }) => ($big ? "flex-start" : "center")};
6481
- align-items: ${({ $inlineUnits }) => ($inlineUnits ? "center" : "flex-start")};
6482
- line-height: 1;
6483
- }
6484
-
6485
- ${ContainerUnits} {
6486
- margin-left: ${({ $inlineUnits }) => ($inlineUnits ? "0.25rem" : 0)};
6487
- }
6488
-
6489
- ${ContainerAlias} {
6490
- margin-top: 0.25rem;
6491
- }
6464
+ styled.css `
6465
+ flex-direction: row;
6466
+ margin-bottom: 0.5rem;
6467
+
6468
+ > * {
6469
+ text-align: left;
6470
+ }
6471
+
6472
+ span[kind] {
6473
+ margin-right: 0.5rem;
6474
+ }
6475
+
6476
+ ${ContainerValue} {
6477
+ width: auto;
6478
+ }
6479
+ `};
6480
+ }
6481
+
6482
+ ${ContainerValue} {
6483
+ flex-direction: ${({ $inlineUnits }) => ($inlineUnits ? "row" : "column")};
6484
+ justify-content: ${({ $big }) => ($big ? "flex-start" : "center")};
6485
+ align-items: ${({ $inlineUnits }) => ($inlineUnits ? "center" : "flex-start")};
6486
+ line-height: 1;
6487
+ }
6488
+
6489
+ ${ContainerUnits} {
6490
+ margin-left: ${({ $inlineUnits }) => ($inlineUnits ? "0.25rem" : 0)};
6491
+ }
6492
+
6493
+ ${ContainerAlias} {
6494
+ margin-top: 0.25rem;
6495
+ }
6492
6496
  `;
6493
6497
 
6494
6498
  const ALIAS_DEFAULT_MAX_LENGTH = 28;
@@ -6535,20 +6539,20 @@ const AddFeatureContainer = React.memo(({ elementConfig }) => {
6535
6539
  .map(({ options }, index) => (jsxRuntime.jsx(AddFeatureButton, { icon: options?.icon, title: options?.title, layerName: options?.layerName, geometryType: options?.geometryType }, index))) }));
6536
6540
  });
6537
6541
 
6538
- const LayersContainerWrapper = styled(Container) `
6539
- ${uilibGl.DraggableTreeContainer} {
6540
- width: calc(100% + 3rem);
6541
- margin: -0.75rem -1.5rem 0;
6542
- }
6543
-
6544
- ${LayerListContainer} {
6545
- height: auto;
6546
- }
6547
-
6548
- ${LayerGroupList} {
6549
- margin: ${({ isPresentationMode }) => (isPresentationMode ? 0 : "0 -1.25rem 0 -1rem")};
6550
- padding: 0;
6551
- }
6542
+ const LayersContainerWrapper = styled(Container) `
6543
+ ${uilibGl.DraggableTreeContainer} {
6544
+ width: calc(100% + 3rem);
6545
+ margin: -0.75rem -1.5rem 0;
6546
+ }
6547
+
6548
+ ${LayerListContainer} {
6549
+ height: auto;
6550
+ }
6551
+
6552
+ ${LayerGroupList} {
6553
+ margin: ${({ isPresentationMode }) => (isPresentationMode ? 0 : "0 -1.25rem 0 -1rem")};
6554
+ padding: 0;
6555
+ }
6552
6556
  `;
6553
6557
 
6554
6558
  const LayersContainer = React.memo(({ type, elementConfig, renderElement }) => {
@@ -6596,99 +6600,99 @@ const getContainerComponent = (innerTemplateName) => innerTemplateName ? contain
6596
6600
  var img$3 = "";
6597
6601
 
6598
6602
  const getMaskColor = (isDark) => (isDark ? "0, 0, 0" : "255, 255, 255");
6599
- const DefaultHeaderContainer = styled(uilibGl.Flex) `
6600
- flex-direction: column;
6601
- position: relative;
6602
- flex-shrink: 0;
6603
- min-height: 8.375rem;
6604
- margin-bottom: -1.5rem;
6605
- padding: 1.5rem 1.5rem 0;
6606
- border-top-left-radius: 0.5rem;
6607
- border-top-right-radius: 0.5rem;
6608
- overflow: hidden;
6609
-
6610
- > * {
6611
- z-index: 1;
6612
- }
6613
-
6614
- &::before {
6615
- content: "";
6616
- position: absolute;
6617
- top: 0;
6618
- left: 0;
6619
- width: 100%;
6620
- height: 100%;
6621
-
6603
+ const DefaultHeaderContainer = styled(uilibGl.Flex) `
6604
+ flex-direction: column;
6605
+ position: relative;
6606
+ flex-shrink: 0;
6607
+ min-height: 8.375rem;
6608
+ margin-bottom: -1.5rem;
6609
+ padding: 1.5rem 1.5rem 0;
6610
+ border-top-left-radius: 0.5rem;
6611
+ border-top-right-radius: 0.5rem;
6612
+ overflow: hidden;
6613
+
6614
+ > * {
6615
+ z-index: 1;
6616
+ }
6617
+
6618
+ &::before {
6619
+ content: "";
6620
+ position: absolute;
6621
+ top: 0;
6622
+ left: 0;
6623
+ width: 100%;
6624
+ height: 100%;
6625
+
6622
6626
  ${({ image, isDark }) => image
6623
- ? styled.css `
6624
- background: url(${image}) 0 0 no-repeat;
6625
- background-size: cover;
6627
+ ? styled.css `
6628
+ background: url(${image}) 0 0 no-repeat;
6629
+ background-size: cover;
6626
6630
  `
6627
- : styled.css `
6628
- background: url(${img$3}) 50% 0 no-repeat;
6629
- opacity: ${isDark ? 1 : 0.5};
6630
- `}
6631
- }
6632
-
6631
+ : styled.css `
6632
+ background: url(${img$3}) 50% 0 no-repeat;
6633
+ opacity: ${isDark ? 1 : 0.5};
6634
+ `}
6635
+ }
6636
+
6633
6637
  ${({ image, isDark }) => image &&
6634
- styled.css `
6635
- &::before {
6636
- -webkit-mask-image: linear-gradient(
6637
- to bottom,
6638
- rgba(${getMaskColor(isDark)}, 1),
6639
- rgba(${getMaskColor(isDark)}, 0)
6640
- );
6641
- mask-image: linear-gradient(to bottom, rgba(${getMaskColor(isDark)}, 1), rgba(${getMaskColor(isDark)}, 0));
6642
- }
6643
- `}
6644
- ${uilibGl.LinearProgress} {
6645
- position: absolute;
6646
- top: 0;
6647
- left: 0;
6648
- }
6649
- `;
6650
- const TopContainer = styled(uilibGl.Flex) `
6651
- z-index: 1;
6652
- position: relative;
6653
- justify-content: space-between;
6654
- flex-wrap: nowrap;
6655
- width: 100%;
6656
- align-items: flex-start;
6657
- `;
6658
- const TopContainerButtons = styled(uilibGl.Flex) `
6659
- align-items: center;
6660
- width: auto;
6661
- margin-right: -0.5rem;
6662
-
6663
- button {
6664
- width: auto;
6665
- height: 1rem;
6666
- padding: 0 0.5rem;
6667
- }
6668
- `;
6669
- const LogoContainer = styled(uilibGl.Flex) `
6670
- max-width: calc(100% - 1.4rem);
6671
- flex-grow: 1;
6672
- font-size: 0;
6673
-
6674
- & > span::after {
6675
- font-size: 2rem;
6676
- }
6677
-
6678
- img {
6679
- max-height: 1.875rem;
6680
- }
6681
- `;
6682
- const PageTitle = styled(uilibGl.H2) `
6683
- display: -webkit-box;
6684
- -webkit-line-clamp: 3;
6685
- -webkit-box-orient: vertical;
6686
- overflow: hidden;
6687
- margin: 0;
6688
- font-size: 1.25rem;
6689
- font-weight: 600;
6690
- pointer-events: initial;
6691
- font-family: "Nunito Sans", serif;
6638
+ styled.css `
6639
+ &::before {
6640
+ -webkit-mask-image: linear-gradient(
6641
+ to bottom,
6642
+ rgba(${getMaskColor(isDark)}, 1),
6643
+ rgba(${getMaskColor(isDark)}, 0)
6644
+ );
6645
+ mask-image: linear-gradient(to bottom, rgba(${getMaskColor(isDark)}, 1), rgba(${getMaskColor(isDark)}, 0));
6646
+ }
6647
+ `}
6648
+ ${uilibGl.LinearProgress} {
6649
+ position: absolute;
6650
+ top: 0;
6651
+ left: 0;
6652
+ }
6653
+ `;
6654
+ const TopContainer = styled(uilibGl.Flex) `
6655
+ z-index: 1;
6656
+ position: relative;
6657
+ justify-content: space-between;
6658
+ flex-wrap: nowrap;
6659
+ width: 100%;
6660
+ align-items: flex-start;
6661
+ `;
6662
+ const TopContainerButtons = styled(uilibGl.Flex) `
6663
+ align-items: center;
6664
+ width: auto;
6665
+ margin-right: -0.5rem;
6666
+
6667
+ button {
6668
+ width: auto;
6669
+ height: 1rem;
6670
+ padding: 0 0.5rem;
6671
+ }
6672
+ `;
6673
+ const LogoContainer = styled(uilibGl.Flex) `
6674
+ max-width: calc(100% - 1.4rem);
6675
+ flex-grow: 1;
6676
+ font-size: 0;
6677
+
6678
+ & > span::after {
6679
+ font-size: 2rem;
6680
+ }
6681
+
6682
+ img {
6683
+ max-height: 1.875rem;
6684
+ }
6685
+ `;
6686
+ const PageTitle = styled(uilibGl.H2) `
6687
+ display: -webkit-box;
6688
+ -webkit-line-clamp: 3;
6689
+ -webkit-box-orient: vertical;
6690
+ overflow: hidden;
6691
+ margin: 0;
6692
+ font-size: 1.25rem;
6693
+ font-weight: 600;
6694
+ pointer-events: initial;
6695
+ font-family: "Nunito Sans", serif;
6692
6696
  `;
6693
6697
 
6694
6698
  exports.ThemeName = void 0;
@@ -6714,82 +6718,82 @@ const DashboardDefaultHeader = React.memo(() => {
6714
6718
  return (jsxRuntime.jsxs(DefaultHeaderContainer, { image: image, isDark: themeName === exports.ThemeName.Dark, children: [!pageId && jsxRuntime.jsx(uilibGl.LinearProgress, {}), jsxRuntime.jsxs(uilibGl.Flex, { column: true, gap: "1rem", children: [jsxRuntime.jsx(uilibGl.FlexSpan, { children: jsxRuntime.jsxs(TopContainer, { children: [jsxRuntime.jsx(LogoContainer, { children: icon }), jsxRuntime.jsxs(TopContainerButtons, { children: [jsxRuntime.jsx(ProjectCatalogMenu, {}), jsxRuntime.jsx(ProjectPanelMenu, {})] })] }) }), jsxRuntime.jsx(uilibGl.FlexSpan, { children: jsxRuntime.jsx(uilibGl.Flex, { column: true, gap: "0.25rem", children: jsxRuntime.jsx(uilibGl.FlexSpan, { children: jsxRuntime.jsxs(uilibGl.Flex, { alignItems: "center", children: [jsxRuntime.jsx(uilibGl.FlexSpan, { flexGrow: 1, children: jsxRuntime.jsx(uilibGl.Tooltip, { arrow: true, content: tooltip, children: ref => (jsxRuntime.jsx(PageTitle, { ref: ref, children: jsxRuntime.jsx(ProjectPagesMenu, {}) })) }) }), jsxRuntime.jsx(uilibGl.FlexSpan, { children: jsxRuntime.jsx(Pagination, {}) })] }) }) }) })] })] }));
6715
6719
  });
6716
6720
 
6717
- const HeaderFrontView = styled(uilibGl.Flex) `
6718
- z-index: 10;
6719
- position: relative;
6720
- justify-content: space-between;
6721
- align-items: ${({ isDefault }) => (isDefault ? "center" : "flex-start")};
6722
- width: 100%;
6723
- font: ${({ theme: { fonts } }) => fonts.subtitle};
6724
- `;
6725
- const HeaderContainer = styled(uilibGl.FlexSpan) `
6726
- display: flex;
6727
- flex-grow: 1;
6728
- flex-wrap: nowrap;
6729
- width: calc(100% - 48px);
6730
- `;
6731
- const FeatureTitleContainer = styled.div `
6732
- display: -webkit-box;
6733
- max-width: 100%;
6734
- width: 100%;
6735
- margin: 0.5rem 0;
6736
- -webkit-line-clamp: 2;
6737
- -webkit-box-orient: vertical;
6738
- overflow: hidden;
6739
- text-overflow: ellipsis;
6740
- color: ${({ theme: { palette } }) => palette.textPrimary};
6741
-
6742
- & > ${uilibGl.FlexSpan} {
6743
- cursor: ${({ clickable }) => clickable && "pointer"};
6744
-
6745
- &:hover {
6746
- color: ${({ clickable, theme: { palette } }) => clickable && palette.primary};
6747
- }
6748
- }
6749
- `;
6750
- const LayerDescription = styled(uilibGl.Description) `
6751
- width: calc(100% - 4rem);
6752
- display: -webkit-box;
6753
- -webkit-line-clamp: 2;
6754
- -webkit-box-orient: vertical;
6755
- overflow: hidden;
6756
- text-overflow: ellipsis;
6757
- `;
6758
- const HeaderTitleContainer = styled(uilibGl.Flex) `
6759
- flex-direction: column;
6760
- width: 100%;
6761
- `;
6762
- const RowHeaderMixin = styled.css `
6763
- &&& {
6764
- min-height: auto;
6765
-
6766
- ${FeatureTitleContainer}, ${LayerDescription} {
6767
- text-align: left;
6768
- }
6769
- }
6770
-
6771
- ${HeaderContainer} {
6772
- flex-direction: row;
6773
- }
6774
-
6775
- ${FeatureTitleContainer} {
6776
- max-width: calc(100% - 3.8rem);
6777
- }
6778
- `;
6779
- const Header = styled(uilibGl.Flex) `
6780
- z-index: 1;
6781
- position: relative;
6782
- top: 0;
6783
- flex-shrink: 0;
6784
- overflow: hidden;
6785
- width: 100%;
6786
- padding: 0.5rem;
6787
-
6788
- ${HeaderContainer} {
6789
- flex-direction: column;
6790
- }
6791
-
6792
- ${({ $isRow }) => $isRow && RowHeaderMixin};
6721
+ const HeaderFrontView = styled(uilibGl.Flex) `
6722
+ z-index: 10;
6723
+ position: relative;
6724
+ justify-content: space-between;
6725
+ align-items: ${({ isDefault }) => (isDefault ? "center" : "flex-start")};
6726
+ width: 100%;
6727
+ font: ${({ theme: { fonts } }) => fonts.subtitle};
6728
+ `;
6729
+ const HeaderContainer = styled(uilibGl.FlexSpan) `
6730
+ display: flex;
6731
+ flex-grow: 1;
6732
+ flex-wrap: nowrap;
6733
+ width: calc(100% - 48px);
6734
+ `;
6735
+ const FeatureTitleContainer = styled.div `
6736
+ display: -webkit-box;
6737
+ max-width: 100%;
6738
+ width: 100%;
6739
+ margin: 0.5rem 0;
6740
+ -webkit-line-clamp: 2;
6741
+ -webkit-box-orient: vertical;
6742
+ overflow: hidden;
6743
+ text-overflow: ellipsis;
6744
+ color: ${({ theme: { palette } }) => palette.textPrimary};
6745
+
6746
+ & > ${uilibGl.FlexSpan} {
6747
+ cursor: ${({ clickable }) => clickable && "pointer"};
6748
+
6749
+ &:hover {
6750
+ color: ${({ clickable, theme: { palette } }) => clickable && palette.primary};
6751
+ }
6752
+ }
6753
+ `;
6754
+ const LayerDescription = styled(uilibGl.Description) `
6755
+ width: calc(100% - 4rem);
6756
+ display: -webkit-box;
6757
+ -webkit-line-clamp: 2;
6758
+ -webkit-box-orient: vertical;
6759
+ overflow: hidden;
6760
+ text-overflow: ellipsis;
6761
+ `;
6762
+ const HeaderTitleContainer = styled(uilibGl.Flex) `
6763
+ flex-direction: column;
6764
+ width: 100%;
6765
+ `;
6766
+ const RowHeaderMixin = styled.css `
6767
+ &&& {
6768
+ min-height: auto;
6769
+
6770
+ ${FeatureTitleContainer}, ${LayerDescription} {
6771
+ text-align: left;
6772
+ }
6773
+ }
6774
+
6775
+ ${HeaderContainer} {
6776
+ flex-direction: row;
6777
+ }
6778
+
6779
+ ${FeatureTitleContainer} {
6780
+ max-width: calc(100% - 3.8rem);
6781
+ }
6782
+ `;
6783
+ const Header = styled(uilibGl.Flex) `
6784
+ z-index: 1;
6785
+ position: relative;
6786
+ top: 0;
6787
+ flex-shrink: 0;
6788
+ overflow: hidden;
6789
+ width: 100%;
6790
+ padding: 0.5rem;
6791
+
6792
+ ${HeaderContainer} {
6793
+ flex-direction: column;
6794
+ }
6795
+
6796
+ ${({ $isRow }) => $isRow && RowHeaderMixin};
6793
6797
  `;
6794
6798
 
6795
6799
  const HeaderTitle = ({ noFeature }) => {
@@ -6817,22 +6821,22 @@ const HeaderTitle = ({ noFeature }) => {
6817
6821
  return (jsxRuntime.jsxs(HeaderTitleContainer, { children: [noFeature ? (jsxRuntime.jsx(FeatureTitleContainer, { children: t("noObjectFound", { ns: "dashboard", defaultValue: "Объектов не найдено" }) })) : (jsxRuntime.jsx(FeatureTitleContainer, { clickable: true, children: jsxRuntime.jsx(uilibGl.Tooltip, { arrow: true, placement: "top", content: t("zoomToFeature", { ns: "dashboard", defaultValue: "Приблизить к объекту" }), delay: [600, 0], children: ref => (jsxRuntime.jsx(uilibGl.FlexSpan, { ref: ref, onClick: () => zoomToFeatures([feature]), children: resultTitle })) }) })), jsxRuntime.jsx(LayerDescription, { title: resultDescription, children: resultDescription })] }));
6818
6822
  };
6819
6823
 
6820
- const LayerIconContainer = styled.div `
6821
- display: flex;
6822
- align-items: center;
6823
- margin-right: 0.75rem;
6824
+ const LayerIconContainer = styled.div `
6825
+ display: flex;
6826
+ align-items: center;
6827
+ margin-right: 0.75rem;
6824
6828
  `;
6825
- const AlertIconContainer = styled(uilibGl.Flex) `
6826
- align-items: center;
6827
- justify-content: center;
6828
- width: 2rem;
6829
- height: 2rem;
6830
-
6831
- ${uilibGl.Icon} {
6832
- :after {
6833
- color: ${({ theme: { palette } }) => palette.error};
6834
- }
6835
- }
6829
+ const AlertIconContainer = styled(uilibGl.Flex) `
6830
+ align-items: center;
6831
+ justify-content: center;
6832
+ width: 2rem;
6833
+ height: 2rem;
6834
+
6835
+ ${uilibGl.Icon} {
6836
+ :after {
6837
+ color: ${({ theme: { palette } }) => palette.error};
6838
+ }
6839
+ }
6836
6840
  `;
6837
6841
 
6838
6842
  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";
@@ -6864,54 +6868,54 @@ const FeatureCardDefaultHeader = ({ noFeature }) => {
6864
6868
  return (jsxRuntime.jsx(Header, { "$isRow": true, children: jsxRuntime.jsxs(HeaderFrontView, { isDefault: true, children: [jsxRuntime.jsxs(HeaderContainer, { children: [!!layerInfo?.name && jsxRuntime.jsx(LayerIcon, { layerInfo: layerInfo }), jsxRuntime.jsx(HeaderTitle, { noFeature: noFeature })] }), jsxRuntime.jsx(FeatureCardButtons, {})] }) }));
6865
6869
  };
6866
6870
 
6867
- const HeaderFontColorMixin$1 = styled.css `
6868
- ${HeaderTitleContainer}, ${LayerDescription} {
6869
- color: ${({ $fontColor }) => $fontColor};
6870
- }
6871
- `;
6872
- const HeaderWrapperMixin$1 = styled.css `
6873
- ${Header} {
6874
- min-height: 5.25rem;
6875
- }
6876
-
6877
- ${HeaderContainer} {
6878
- max-width: 100%;
6879
- width: 100%;
6880
- }
6881
-
6882
- ${FeatureControls} {
6883
- max-width: calc(100% - 2rem);
6884
- width: calc(100% - 2rem);
6885
- margin-top: -0.5rem;
6886
- padding-top: 1rem;
6887
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
6888
- }
6889
-
6890
- ${({ $fontColor }) => !!$fontColor && HeaderFontColorMixin$1};
6891
- `;
6892
- const GradientHeaderWrapper = styled.div `
6893
- ${Header} {
6894
- background: ${({ $bgColor }) => $bgColor || "radial-gradient(129.21% 133.22% at 51.94% 0%, #e8fffe 9.48%, #5fcaff 100%)"};
6895
- }
6896
-
6897
- ${HeaderContainer} {
6898
- align-items: center;
6899
- }
6900
-
6901
- ${HeaderTitleContainer} {
6902
- margin-left: 0;
6903
- text-align: center;
6904
- }
6905
-
6906
- ${FeatureTitleContainer} {
6907
- text-align: center;
6908
- }
6909
-
6910
- ${LayerDescription} {
6911
- text-align: center;
6912
- }
6913
-
6914
- ${HeaderWrapperMixin$1};
6871
+ const HeaderFontColorMixin$1 = styled.css `
6872
+ ${HeaderTitleContainer}, ${LayerDescription} {
6873
+ color: ${({ $fontColor }) => $fontColor};
6874
+ }
6875
+ `;
6876
+ const HeaderWrapperMixin$1 = styled.css `
6877
+ ${Header} {
6878
+ min-height: 5.25rem;
6879
+ }
6880
+
6881
+ ${HeaderContainer} {
6882
+ max-width: 100%;
6883
+ width: 100%;
6884
+ }
6885
+
6886
+ ${FeatureControls} {
6887
+ max-width: calc(100% - 2rem);
6888
+ width: calc(100% - 2rem);
6889
+ margin-top: -0.5rem;
6890
+ padding-top: 1rem;
6891
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
6892
+ }
6893
+
6894
+ ${({ $fontColor }) => !!$fontColor && HeaderFontColorMixin$1};
6895
+ `;
6896
+ const GradientHeaderWrapper = styled.div `
6897
+ ${Header} {
6898
+ background: ${({ $bgColor }) => $bgColor || "radial-gradient(129.21% 133.22% at 51.94% 0%, #e8fffe 9.48%, #5fcaff 100%)"};
6899
+ }
6900
+
6901
+ ${HeaderContainer} {
6902
+ align-items: center;
6903
+ }
6904
+
6905
+ ${HeaderTitleContainer} {
6906
+ margin-left: 0;
6907
+ text-align: center;
6908
+ }
6909
+
6910
+ ${FeatureTitleContainer} {
6911
+ text-align: center;
6912
+ }
6913
+
6914
+ ${LayerDescription} {
6915
+ text-align: center;
6916
+ }
6917
+
6918
+ ${HeaderWrapperMixin$1};
6915
6919
  `;
6916
6920
 
6917
6921
  const FeatureCardGradientHeader = ({ isRow }) => {
@@ -6928,80 +6932,80 @@ const FeatureCardGradientHeader = ({ isRow }) => {
6928
6932
  }) })] }), jsxRuntime.jsx(FeatureCardButtons, {})] }) }) }) }));
6929
6933
  };
6930
6934
 
6931
- const HeaderFontColorMixin = styled.css `
6932
- ${HeaderTitleContainer}, ${LayerDescription} {
6933
- color: ${({ $fontColor }) => $fontColor};
6934
- }
6935
- `;
6936
- const HeaderWrapperMixin = styled.css `
6937
- ${Header} {
6938
- min-height: 5.25rem;
6939
- }
6940
-
6941
- ${HeaderContainer} {
6942
- max-width: 100%;
6943
- width: 100%;
6944
- }
6945
-
6946
- ${FeatureControls} {
6947
- max-width: calc(100% - 2rem);
6948
- width: calc(100% - 2rem);
6949
- margin-top: -0.5rem;
6950
- padding-top: 1rem;
6951
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
6952
- }
6953
-
6954
- ${({ $fontColor }) => !!$fontColor && HeaderFontColorMixin};
6955
- `;
6956
- const HeaderIcon = styled(uilibGl.Flex) `
6957
- position: absolute;
6958
- top: 0;
6959
- right: 0;
6960
- justify-content: flex-end;
6961
- align-items: center;
6962
- min-width: 7.5rem;
6963
- height: 100%;
6964
-
6965
- span[kind]:after {
6966
- font-size: 7.5rem;
6967
- }
6968
-
6969
- span[kind]:after,
6970
- path,
6971
- line,
6972
- circle {
6973
- fill: rgba(255, 255, 255, 0.36);
6974
- }
6975
-
6976
- && > * {
6977
- display: flex;
6978
- align-items: center;
6979
- height: 100%;
6980
- }
6981
- `;
6982
- const BigIconHeaderMixin = styled.css `
6983
- ${HeaderIcon} {
6984
- min-width: 14rem;
6985
- right: -3rem;
6986
-
6987
- span[kind]:after {
6988
- font-size: 14rem;
6989
- }
6990
- }
6991
- `;
6992
- const IconHeaderWrapper = styled.div `
6993
- ${Header} {
6994
- width: calc(100% + 1.5rem);
6995
- margin: -1.5rem -1.5rem 0 -1.5rem;
6996
- padding: 1.5rem;
6997
- border-top-left-radius: 0.5rem;
6998
- border-top-right-radius: 0.5rem;
6999
- background: ${({ $bgColor }) => $bgColor || "linear-gradient(96.55deg, #FFFCD3 0%, #B4DC47 100%)"};
7000
- }
7001
-
7002
- ${HeaderWrapperMixin};
7003
-
7004
- ${({ $bigIcon }) => $bigIcon && BigIconHeaderMixin};
6935
+ const HeaderFontColorMixin = styled.css `
6936
+ ${HeaderTitleContainer}, ${LayerDescription} {
6937
+ color: ${({ $fontColor }) => $fontColor};
6938
+ }
6939
+ `;
6940
+ const HeaderWrapperMixin = styled.css `
6941
+ ${Header} {
6942
+ min-height: 5.25rem;
6943
+ }
6944
+
6945
+ ${HeaderContainer} {
6946
+ max-width: 100%;
6947
+ width: 100%;
6948
+ }
6949
+
6950
+ ${FeatureControls} {
6951
+ max-width: calc(100% - 2rem);
6952
+ width: calc(100% - 2rem);
6953
+ margin-top: -0.5rem;
6954
+ padding-top: 1rem;
6955
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
6956
+ }
6957
+
6958
+ ${({ $fontColor }) => !!$fontColor && HeaderFontColorMixin};
6959
+ `;
6960
+ const HeaderIcon = styled(uilibGl.Flex) `
6961
+ position: absolute;
6962
+ top: 0;
6963
+ right: 0;
6964
+ justify-content: flex-end;
6965
+ align-items: center;
6966
+ min-width: 7.5rem;
6967
+ height: 100%;
6968
+
6969
+ span[kind]:after {
6970
+ font-size: 7.5rem;
6971
+ }
6972
+
6973
+ span[kind]:after,
6974
+ path,
6975
+ line,
6976
+ circle {
6977
+ fill: rgba(255, 255, 255, 0.36);
6978
+ }
6979
+
6980
+ && > * {
6981
+ display: flex;
6982
+ align-items: center;
6983
+ height: 100%;
6984
+ }
6985
+ `;
6986
+ const BigIconHeaderMixin = styled.css `
6987
+ ${HeaderIcon} {
6988
+ min-width: 14rem;
6989
+ right: -3rem;
6990
+
6991
+ span[kind]:after {
6992
+ font-size: 14rem;
6993
+ }
6994
+ }
6995
+ `;
6996
+ const IconHeaderWrapper = styled.div `
6997
+ ${Header} {
6998
+ width: calc(100% + 1.5rem);
6999
+ margin: -1.5rem -1.5rem 0 -1.5rem;
7000
+ padding: 1.5rem;
7001
+ border-top-left-radius: 0.5rem;
7002
+ border-top-right-radius: 0.5rem;
7003
+ background: ${({ $bgColor }) => $bgColor || "linear-gradient(96.55deg, #FFFCD3 0%, #B4DC47 100%)"};
7004
+ }
7005
+
7006
+ ${HeaderWrapperMixin};
7007
+
7008
+ ${({ $bigIcon }) => $bigIcon && BigIconHeaderMixin};
7005
7009
  `;
7006
7010
 
7007
7011
  const FeatureCardIconHeader = ({ isRow }) => {
@@ -7021,15 +7025,15 @@ const FeatureCardIconHeader = ({ isRow }) => {
7021
7025
  }) })] }) }) }));
7022
7026
  };
7023
7027
 
7024
- const ImageContainerButton = styled(uilibGl.FlatButton) `
7025
- min-height: 1.5rem;
7026
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.large};
7027
- background-color: ${({ theme: { palette } }) => palette.primary};
7028
- text-transform: none;
7029
-
7030
- :hover {
7031
- background-color: ${({ theme: { palette } }) => palette.primaryDeep};
7032
- }
7028
+ const ImageContainerButton = styled(uilibGl.FlatButton) `
7029
+ min-height: 1.5rem;
7030
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.large};
7031
+ background-color: ${({ theme: { palette } }) => palette.primary};
7032
+ text-transform: none;
7033
+
7034
+ :hover {
7035
+ background-color: ${({ theme: { palette } }) => palette.primaryDeep};
7036
+ }
7033
7037
  `;
7034
7038
 
7035
7039
  const ElementButton = React.memo(({ type, elementConfig }) => {
@@ -7041,157 +7045,157 @@ const ElementButton = React.memo(({ type, elementConfig }) => {
7041
7045
  return (jsxRuntime.jsx(ImageContainerButton, { onClick: () => window.open(attribute?.value), children: elementConfig.value || "" }));
7042
7046
  });
7043
7047
 
7044
- const AttributeGalleryContainer = styled.div `
7045
- && {
7046
- width: calc(100% + 3rem);
7047
- }
7048
-
7049
- min-height: 12.625rem;
7050
- background-color: ${({ theme: { palette } }) => palette.element};
7051
-
7052
- img {
7053
- width: 100%;
7054
- }
7055
- `;
7056
- const LinearProgressContainer = styled(uilibGl.Flex) `
7057
- align-items: center;
7058
- justify-content: center;
7059
- min-height: inherit;
7060
-
7061
- ${uilibGl.LinearProgress} {
7062
- max-width: 4rem;
7063
- }
7064
- `;
7065
- const NoLiveSnapshotContainer = styled(uilibGl.Flex) `
7066
- flex-direction: column;
7067
- align-items: center;
7068
-
7069
- span[kind="alert"] {
7070
- width: 2rem;
7071
- height: 2rem;
7072
-
7073
- &:after {
7074
- font-size: 2rem;
7075
- color: ${({ theme: { palette } }) => palette.elementDeep};
7076
- }
7077
- }
7078
-
7079
- ${uilibGl.Description} {
7080
- font-size: 0.75rem;
7081
- color: ${({ theme: { palette } }) => palette.textDisabled};
7082
- }
7083
- `;
7084
- const SmallPreviewControl = styled(uilibGl.IconButton) `
7085
- cursor: ${({ $isDisabled }) => ($isDisabled ? "default" : "pointer")};
7086
- z-index: 3;
7087
- position: absolute;
7088
- top: 50%;
7089
- width: 2.5rem;
7090
- height: 2.5rem;
7091
- margin-top: -1.25rem;
7092
- background-color: rgba(61, 61, 61, 0.8);
7093
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.smallest};
7094
-
7095
- span:after {
7096
- color: ${({ $isDisabled }) => ($isDisabled ? "rgba(255, 255, 255, 0.28)" : "rgba(255, 255, 255, 1)")};
7097
- transition: color ${uilibGl.transition.hover};
7098
- }
7099
- `;
7100
- const SmallPreviewCounter = styled(uilibGl.Flex) `
7101
- z-index: 3;
7102
- position: absolute;
7103
- bottom: 0.625rem;
7104
- left: 0;
7105
- width: 100%;
7106
- height: 1rem;
7107
- justify-content: center;
7108
-
7109
- > div {
7110
- background-color: rgba(61, 61, 61, 0.8);
7111
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
7112
- padding: 0 0.5rem;
7113
- font-size: 0.625rem;
7114
- line-height: 1rem;
7115
- color: #fff;
7116
- }
7048
+ const AttributeGalleryContainer = styled.div `
7049
+ && {
7050
+ width: calc(100% + 3rem);
7051
+ }
7052
+
7053
+ min-height: 12.625rem;
7054
+ background-color: ${({ theme: { palette } }) => palette.element};
7055
+
7056
+ img {
7057
+ width: 100%;
7058
+ }
7059
+ `;
7060
+ const LinearProgressContainer = styled(uilibGl.Flex) `
7061
+ align-items: center;
7062
+ justify-content: center;
7063
+ min-height: inherit;
7064
+
7065
+ ${uilibGl.LinearProgress} {
7066
+ max-width: 4rem;
7067
+ }
7068
+ `;
7069
+ const NoLiveSnapshotContainer = styled(uilibGl.Flex) `
7070
+ flex-direction: column;
7071
+ align-items: center;
7072
+
7073
+ span[kind="alert"] {
7074
+ width: 2rem;
7075
+ height: 2rem;
7076
+
7077
+ &:after {
7078
+ font-size: 2rem;
7079
+ color: ${({ theme: { palette } }) => palette.elementDeep};
7080
+ }
7081
+ }
7082
+
7083
+ ${uilibGl.Description} {
7084
+ font-size: 0.75rem;
7085
+ color: ${({ theme: { palette } }) => palette.textDisabled};
7086
+ }
7087
+ `;
7088
+ const SmallPreviewControl = styled(uilibGl.IconButton) `
7089
+ cursor: ${({ $isDisabled }) => ($isDisabled ? "default" : "pointer")};
7090
+ z-index: 3;
7091
+ position: absolute;
7092
+ top: 50%;
7093
+ width: 2.5rem;
7094
+ height: 2.5rem;
7095
+ margin-top: -1.25rem;
7096
+ background-color: rgba(61, 61, 61, 0.8);
7097
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.smallest};
7098
+
7099
+ span:after {
7100
+ color: ${({ $isDisabled }) => ($isDisabled ? "rgba(255, 255, 255, 0.28)" : "rgba(255, 255, 255, 1)")};
7101
+ transition: color ${uilibGl.transition.hover};
7102
+ }
7103
+ `;
7104
+ const SmallPreviewCounter = styled(uilibGl.Flex) `
7105
+ z-index: 3;
7106
+ position: absolute;
7107
+ bottom: 0.625rem;
7108
+ left: 0;
7109
+ width: 100%;
7110
+ height: 1rem;
7111
+ justify-content: center;
7112
+
7113
+ > div {
7114
+ background-color: rgba(61, 61, 61, 0.8);
7115
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
7116
+ padding: 0 0.5rem;
7117
+ font-size: 0.625rem;
7118
+ line-height: 1rem;
7119
+ color: #fff;
7120
+ }
7117
7121
  `;
7118
7122
  const SmallPreviewLeft = styled(SmallPreviewControl).attrs(() => ({
7119
7123
  kind: "prev",
7120
- })) `
7121
- left: 1.5rem;
7124
+ })) `
7125
+ left: 1.5rem;
7122
7126
  `;
7123
7127
  const SmallPreviewRight = styled(SmallPreviewControl).attrs(() => ({
7124
7128
  kind: "next",
7125
- })) `
7126
- right: 1.5rem;
7127
- `;
7128
- const imgSlideShowMixin = styled.css `
7129
- &:nth-child(${({ prevIndex }) => prevIndex}) {
7130
- z-index: 2;
7131
- position: absolute;
7132
- top: 0;
7133
- left: 0;
7134
- right: 0;
7135
- bottom: 0;
7136
- opacity: 0;
7137
-
7138
- animation-duration: 0.25s;
7139
- animation-name: fadeOut;
7140
- animation-timing-function: linear;
7141
-
7142
- @keyframes fadeOut {
7143
- from {
7144
- opacity: 1;
7145
- }
7146
-
7147
- to {
7148
- opacity: 0;
7149
- }
7150
- }
7151
- }
7152
- `;
7153
- const SmallPreviewContainer$1 = styled.div `
7154
- cursor: ${({ onClick }) => (onClick ? "pointer" : "default")};
7155
- position: relative;
7156
- width: 100%;
7157
- height: 100%;
7158
- min-height: inherit;
7159
- line-height: 0;
7160
-
7161
- ${uilibGl.LinearProgress} {
7162
- z-index: 3;
7163
- position: absolute;
7164
- }
7165
-
7166
- ${SmallPreviewControl}, ${SmallPreviewCounter} {
7167
- opacity: 0;
7168
- transition: opacity ${uilibGl.transition.hover};
7169
- }
7170
-
7171
- &:hover {
7172
- ${SmallPreviewControl}, ${SmallPreviewCounter} {
7173
- opacity: 1;
7174
- }
7175
- }
7176
-
7177
- img {
7178
- z-index: 0;
7179
- cursor: pointer;
7180
- position: absolute;
7181
- top: 0;
7182
- left: 0;
7183
- width: 100%;
7184
- height: 100%;
7185
- min-height: inherit;
7186
- object-position: center;
7187
- object-fit: cover;
7188
-
7189
- &:nth-child(${({ currentIndex }) => currentIndex}) {
7190
- z-index: 1;
7191
- }
7192
-
7193
- ${({ prevIndex, currentIndex }) => prevIndex !== currentIndex && imgSlideShowMixin}
7194
- }
7129
+ })) `
7130
+ right: 1.5rem;
7131
+ `;
7132
+ const imgSlideShowMixin = styled.css `
7133
+ &:nth-child(${({ prevIndex }) => prevIndex}) {
7134
+ z-index: 2;
7135
+ position: absolute;
7136
+ top: 0;
7137
+ left: 0;
7138
+ right: 0;
7139
+ bottom: 0;
7140
+ opacity: 0;
7141
+
7142
+ animation-duration: 0.25s;
7143
+ animation-name: fadeOut;
7144
+ animation-timing-function: linear;
7145
+
7146
+ @keyframes fadeOut {
7147
+ from {
7148
+ opacity: 1;
7149
+ }
7150
+
7151
+ to {
7152
+ opacity: 0;
7153
+ }
7154
+ }
7155
+ }
7156
+ `;
7157
+ const SmallPreviewContainer$1 = styled.div `
7158
+ cursor: ${({ onClick }) => (onClick ? "pointer" : "default")};
7159
+ position: relative;
7160
+ width: 100%;
7161
+ height: 100%;
7162
+ min-height: inherit;
7163
+ line-height: 0;
7164
+
7165
+ ${uilibGl.LinearProgress} {
7166
+ z-index: 3;
7167
+ position: absolute;
7168
+ }
7169
+
7170
+ ${SmallPreviewControl}, ${SmallPreviewCounter} {
7171
+ opacity: 0;
7172
+ transition: opacity ${uilibGl.transition.hover};
7173
+ }
7174
+
7175
+ &:hover {
7176
+ ${SmallPreviewControl}, ${SmallPreviewCounter} {
7177
+ opacity: 1;
7178
+ }
7179
+ }
7180
+
7181
+ img {
7182
+ z-index: 0;
7183
+ cursor: pointer;
7184
+ position: absolute;
7185
+ top: 0;
7186
+ left: 0;
7187
+ width: 100%;
7188
+ height: 100%;
7189
+ min-height: inherit;
7190
+ object-position: center;
7191
+ object-fit: cover;
7192
+
7193
+ &:nth-child(${({ currentIndex }) => currentIndex}) {
7194
+ z-index: 1;
7195
+ }
7196
+
7197
+ ${({ prevIndex, currentIndex }) => prevIndex !== currentIndex && imgSlideShowMixin}
7198
+ }
7195
7199
  `;
7196
7200
  const SmallPreviewImages = styled.div ``;
7197
7201
 
@@ -7367,21 +7371,21 @@ const ElementChips = React.memo(({ type, elementConfig }) => {
7367
7371
  return (jsxRuntime.jsx(DashboardChipsContainer, { style: style, children: tags?.map(tag => (jsxRuntime.jsx(DashboardChip$1, { text: tag, "$bgColor": bgColor, "$fontColor": fontColor, "$fontSize": fontSize, "$isDefault": true }, tag))) }));
7368
7372
  });
7369
7373
 
7370
- const StyledIconFontSizeMixin = styled.css `
7371
- height: ${({ fontSize }) => `${fontSize}px`};
7372
-
7373
- &&:after {
7374
- font-size: ${({ fontSize }) => `${fontSize}px`};
7375
- }
7374
+ const StyledIconFontSizeMixin = styled.css `
7375
+ height: ${({ fontSize }) => `${fontSize}px`};
7376
+
7377
+ &&:after {
7378
+ font-size: ${({ fontSize }) => `${fontSize}px`};
7379
+ }
7376
7380
  `;
7377
- const StyledIconFontColorMixin = styled.css `
7378
- &&:after {
7379
- color: ${({ fontColor }) => fontColor};
7380
- }
7381
+ const StyledIconFontColorMixin = styled.css `
7382
+ &&:after {
7383
+ color: ${({ fontColor }) => fontColor};
7384
+ }
7381
7385
  `;
7382
- const StyledIcon = styled(uilibGl.Icon) `
7383
- ${({ fontSize }) => !!fontSize && StyledIconFontSizeMixin};
7384
- ${({ fontColor }) => !!fontColor && StyledIconFontColorMixin};
7386
+ const StyledIcon = styled(uilibGl.Icon) `
7387
+ ${({ fontSize }) => !!fontSize && StyledIconFontSizeMixin};
7388
+ ${({ fontColor }) => !!fontColor && StyledIconFontColorMixin};
7385
7389
  `;
7386
7390
 
7387
7391
  const ElementIcon = React.memo(({ type, elementConfig }) => {
@@ -7435,51 +7439,51 @@ const ElementLegend = React.memo(({ type, element, elementConfig, expandedContai
7435
7439
 
7436
7440
  const ExternalLink = styled(uilibGl.IconButton).attrs(() => ({
7437
7441
  kind: "external_link",
7438
- })) `
7439
- ${uilibGl.Icon} {
7440
- color: ${({ theme: { palette } }) => palette.primary};
7441
- }
7442
-
7443
- &:hover ${uilibGl.Icon} {
7444
- color: ${({ theme: { palette } }) => palette.primaryDeep};
7445
- }
7446
- `;
7447
- const LocalLinkBlank = styled(uilibGl.Blank) `
7448
- min-width: 13.5rem;
7449
- padding: 0.5rem 0.75rem 0;
7450
-
7451
- a {
7452
- text-decoration: none;
7453
- font-size: 0.75rem;
7454
- color: ${({ theme: { palette } }) => palette.primary};
7455
- }
7456
-
7457
- ${uilibGl.IconButtonButton} {
7458
- font-size: 0.75rem;
7459
- }
7442
+ })) `
7443
+ ${uilibGl.Icon} {
7444
+ color: ${({ theme: { palette } }) => palette.primary};
7445
+ }
7446
+
7447
+ &:hover ${uilibGl.Icon} {
7448
+ color: ${({ theme: { palette } }) => palette.primaryDeep};
7449
+ }
7450
+ `;
7451
+ const LocalLinkBlank = styled(uilibGl.Blank) `
7452
+ min-width: 13.5rem;
7453
+ padding: 0.5rem 0.75rem 0;
7454
+
7455
+ a {
7456
+ text-decoration: none;
7457
+ font-size: 0.75rem;
7458
+ color: ${({ theme: { palette } }) => palette.primary};
7459
+ }
7460
+
7461
+ ${uilibGl.IconButtonButton} {
7462
+ font-size: 0.75rem;
7463
+ }
7460
7464
  `;
7461
7465
  const LocalLinkButton = styled(uilibGl.IconButton).attrs(() => ({
7462
7466
  kind: "link",
7463
- })) `
7464
- width: 1rem;
7465
- height: 1rem;
7466
- background-color: ${({ theme: { palette } }) => palette.primary};
7467
- border-radius: 50%;
7468
-
7469
- span[kind] {
7470
- display: flex;
7471
- justify-content: center;
7472
- align-items: center;
7473
-
7474
- :after {
7475
- position: relative;
7476
- font-size: 0.6rem;
7477
- color: white;
7478
- }
7479
- }
7480
- `;
7481
- const LocalLinkCopy = styled(uilibGl.Flex) `
7482
- justify-content: center;
7467
+ })) `
7468
+ width: 1rem;
7469
+ height: 1rem;
7470
+ background-color: ${({ theme: { palette } }) => palette.primary};
7471
+ border-radius: 50%;
7472
+
7473
+ span[kind] {
7474
+ display: flex;
7475
+ justify-content: center;
7476
+ align-items: center;
7477
+
7478
+ :after {
7479
+ position: relative;
7480
+ font-size: 0.6rem;
7481
+ color: white;
7482
+ }
7483
+ }
7484
+ `;
7485
+ const LocalLinkCopy = styled(uilibGl.Flex) `
7486
+ justify-content: center;
7483
7487
  `;
7484
7488
 
7485
7489
  const LocalLink = React.memo(({ link }) => {
@@ -7501,9 +7505,9 @@ const ElementLink = React.memo(({ type, elementConfig }) => {
7501
7505
  return link.startsWith("http") ? jsxRuntime.jsx(ExternalLink, { onClick: () => window.open(link) }) : jsxRuntime.jsx(LocalLink, { link: link });
7502
7506
  });
7503
7507
 
7504
- const SmallPreviewContainer = styled.div `
7505
- width: 100%;
7506
- height: 100%;
7508
+ const SmallPreviewContainer = styled.div `
7509
+ width: 100%;
7510
+ height: 100%;
7507
7511
  `;
7508
7512
 
7509
7513
  const ElementSlideshow = ({ elementConfig, type, renderElement }) => {
@@ -7539,18 +7543,18 @@ const ElementSvg = React.memo(({ type, elementConfig }) => {
7539
7543
  return (jsxRuntime.jsx(SvgImage, { url: getSvgUrl({ elementConfig, layerInfo, attributes }), width: width, height: height, fontColor: fontColor }));
7540
7544
  });
7541
7545
 
7542
- const TooltipIcon = styled(uilibGl.Icon) `
7543
- &&& {
7544
- :after {
7545
- font-size: 0.75rem;
7546
- color: ${({ theme: { palette } }) => palette.iconDisabled};
7547
- transition: color ${uilibGl.transition.hover};
7548
- }
7549
-
7550
- :hover:after {
7551
- color: ${({ theme: { palette } }) => palette.icon};
7552
- }
7553
- }
7546
+ const TooltipIcon = styled(uilibGl.Icon) `
7547
+ &&& {
7548
+ :after {
7549
+ font-size: 0.75rem;
7550
+ color: ${({ theme: { palette } }) => palette.iconDisabled};
7551
+ transition: color ${uilibGl.transition.hover};
7552
+ }
7553
+
7554
+ :hover:after {
7555
+ color: ${({ theme: { palette } }) => palette.icon};
7556
+ }
7557
+ }
7554
7558
  `;
7555
7559
 
7556
7560
  const ElementTooltip = React.memo(({ type, elementConfig }) => {
@@ -7562,76 +7566,76 @@ const ElementTooltip = React.memo(({ type, elementConfig }) => {
7562
7566
  return text ? (jsxRuntime.jsx(uilibGl.Tooltip, { placement: "top", arrow: true, content: text, children: ref => jsxRuntime.jsx(TooltipIcon, { kind: icon || "question", ref: ref }) })) : null;
7563
7567
  });
7564
7568
 
7565
- const SlideshowHeaderWrapper = styled.div `
7566
- padding: ${({ withPadding }) => (withPadding ? "0.5rem 0.5rem 0" : 0)};
7567
-
7568
- ${Header} {
7569
- align-items: flex-start;
7570
- width: calc(100% + 2rem);
7571
- height: ${({ big }) => (big ? "15.5rem" : "auto")};
7572
- padding: 1.5rem;
7573
- margin: -1rem -1rem 0 -1rem;
7574
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
7575
-
7576
- ${SmallPreviewCounter} {
7577
- bottom: ${({ withPadding }) => (withPadding ? 0.625 : 1.125)}rem;
7578
- }
7579
-
7580
- :before,
7581
- :after {
7582
- content: "";
7583
- z-index: 2;
7584
- position: absolute;
7585
- top: 0;
7586
- left: 0;
7587
- width: 100%;
7588
- }
7589
-
7590
- :before {
7591
- height: 100%;
7592
- background: rgba(32, 46, 53, 0.25);
7593
- }
7594
-
7595
- :after {
7596
- height: 4.5rem;
7597
- background: linear-gradient(180deg, #000000 0%, rgba(0, 0, 0, 0) 100%);
7598
- }
7599
-
7600
- :hover {
7601
- ${SmallPreviewControl}, ${SmallPreviewCounter} {
7602
- opacity: 1;
7603
- }
7604
- }
7605
- }
7606
- `;
7607
- const ImageContainerBg = styled.div `
7608
- position: absolute;
7609
- top: 0;
7610
- bottom: 0;
7611
- left: 0;
7612
- right: 0;
7613
-
7614
- img {
7615
- width: 100%;
7616
- height: 100%;
7617
- object-position: center;
7618
- object-fit: cover;
7619
- }
7620
- `;
7621
- const HeaderSlideshow = styled.div `
7622
- position: absolute;
7623
- top: 0;
7624
- bottom: ${({ height }) => (height ? `${height}px` : 0)};
7625
- left: 0;
7626
- right: 0;
7627
-
7628
- img {
7629
- width: 100%;
7630
- height: 100%;
7631
- min-height: inherit;
7632
- object-position: center;
7633
- object-fit: cover;
7634
- }
7569
+ const SlideshowHeaderWrapper = styled.div `
7570
+ padding: ${({ withPadding }) => (withPadding ? "0.5rem 0.5rem 0" : 0)};
7571
+
7572
+ ${Header} {
7573
+ align-items: flex-start;
7574
+ width: calc(100% + 2rem);
7575
+ height: ${({ big }) => (big ? "15.5rem" : "auto")};
7576
+ padding: 1.5rem;
7577
+ margin: -1rem -1rem 0 -1rem;
7578
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
7579
+
7580
+ ${SmallPreviewCounter} {
7581
+ bottom: ${({ withPadding }) => (withPadding ? 0.625 : 1.125)}rem;
7582
+ }
7583
+
7584
+ :before,
7585
+ :after {
7586
+ content: "";
7587
+ z-index: 2;
7588
+ position: absolute;
7589
+ top: 0;
7590
+ left: 0;
7591
+ width: 100%;
7592
+ }
7593
+
7594
+ :before {
7595
+ height: 100%;
7596
+ background: rgba(32, 46, 53, 0.25);
7597
+ }
7598
+
7599
+ :after {
7600
+ height: 4.5rem;
7601
+ background: linear-gradient(180deg, #000000 0%, rgba(0, 0, 0, 0) 100%);
7602
+ }
7603
+
7604
+ :hover {
7605
+ ${SmallPreviewControl}, ${SmallPreviewCounter} {
7606
+ opacity: 1;
7607
+ }
7608
+ }
7609
+ }
7610
+ `;
7611
+ const ImageContainerBg = styled.div `
7612
+ position: absolute;
7613
+ top: 0;
7614
+ bottom: 0;
7615
+ left: 0;
7616
+ right: 0;
7617
+
7618
+ img {
7619
+ width: 100%;
7620
+ height: 100%;
7621
+ object-position: center;
7622
+ object-fit: cover;
7623
+ }
7624
+ `;
7625
+ const HeaderSlideshow = styled.div `
7626
+ position: absolute;
7627
+ top: 0;
7628
+ bottom: ${({ height }) => (height ? `${height}px` : 0)};
7629
+ left: 0;
7630
+ right: 0;
7631
+
7632
+ img {
7633
+ width: 100%;
7634
+ height: 100%;
7635
+ min-height: inherit;
7636
+ object-position: center;
7637
+ object-fit: cover;
7638
+ }
7635
7639
  `;
7636
7640
 
7637
7641
  const FeatureCardSlideshowHeader = ({ isRow }) => {
@@ -9473,8 +9477,8 @@ const Dashboard = React.memo(({ type = exports.WidgetType.Dashboard, config, noB
9473
9477
  return (jsxRuntime.jsx(PagesContainer, { type: type, config: config, noBorders: noBorders }));
9474
9478
  });
9475
9479
 
9476
- const CardCheckbox = styled(uilibGl.Checkbox) `
9477
- padding-left: 0.5rem;
9480
+ const CardCheckbox = styled(uilibGl.Checkbox) `
9481
+ padding-left: 0.5rem;
9478
9482
  `;
9479
9483
 
9480
9484
  const DashboardCheckbox = ({ title, checked, onChange, }) => {
@@ -9549,15 +9553,15 @@ const FeatureCardTitle = ({ title, description }) => {
9549
9553
  return (jsxRuntime.jsxs(HeaderTitleContainer, { children: [jsxRuntime.jsx(FeatureTitleContainer, { clickable: true, children: jsxRuntime.jsx(uilibGl.Tooltip, { arrow: true, placement: "top", content: t("zoomToFeature", { ns: "dashboard", defaultValue: "Приблизить к объекту" }), delay: [600, 0], children: ref => (jsxRuntime.jsx(uilibGl.FlexSpan, { ref: ref, onClick: () => zoomToFeatures([feature]), children: resultTitle })) }) }), jsxRuntime.jsx(LayerDescription, { title: resultDescription, children: resultDescription })] }));
9550
9554
  };
9551
9555
 
9552
- const HiddenFilters = styled(uilibGl.Flex) `
9553
- flex-wrap: wrap;
9554
- margin-top: -1.25rem;
9555
-
9556
- ${DashboardChip$1} {
9557
- height: 1.5rem;
9558
- margin: 0 0.25rem 0.25rem 0;
9559
- padding: 0 0 0 0.5rem;
9560
- }
9556
+ const HiddenFilters = styled(uilibGl.Flex) `
9557
+ flex-wrap: wrap;
9558
+ margin-top: -1.25rem;
9559
+
9560
+ ${DashboardChip$1} {
9561
+ height: 1.5rem;
9562
+ margin: 0 0.25rem 0.25rem 0;
9563
+ padding: 0 0 0 0.5rem;
9564
+ }
9561
9565
  `;
9562
9566
 
9563
9567
  function spliceValue(filterValue, splicingValue) {
@@ -9627,24 +9631,24 @@ const HiddenTitleItems = React.memo(({ elementConfig, config, type, filter }) =>
9627
9631
  getConfigFilter(filterName, configFilters)?.defaultValue, index)) }));
9628
9632
  });
9629
9633
 
9630
- const PageNavigator = styled(uilibGl.Flex) `
9631
- margin-right: -0.5rem;
9632
- align-items: center;
9633
-
9634
- button {
9635
- width: auto;
9636
- height: 1.5rem;
9637
- padding: 0 0.5rem;
9638
-
9639
- span[kind]:after {
9640
- color: ${({ theme: { palette } }) => palette.textDisabled};
9641
- transition: color ${uilibGl.transition.hover};
9642
- }
9643
-
9644
- :hover span[kind]:after {
9645
- color: ${({ theme: { palette } }) => palette.textSecondary};
9646
- }
9647
- }
9634
+ const PageNavigator = styled(uilibGl.Flex) `
9635
+ margin-right: -0.5rem;
9636
+ align-items: center;
9637
+
9638
+ button {
9639
+ width: auto;
9640
+ height: 1.5rem;
9641
+ padding: 0 0.5rem;
9642
+
9643
+ span[kind]:after {
9644
+ color: ${({ theme: { palette } }) => palette.textDisabled};
9645
+ transition: color ${uilibGl.transition.hover};
9646
+ }
9647
+
9648
+ :hover span[kind]:after {
9649
+ color: ${({ theme: { palette } }) => palette.textSecondary};
9650
+ }
9651
+ }
9648
9652
  `;
9649
9653
 
9650
9654
  const Pagination = React.memo(({ type = exports.WidgetType.Dashboard }) => {
@@ -9653,34 +9657,34 @@ const Pagination = React.memo(({ type = exports.WidgetType.Dashboard }) => {
9653
9657
  return (jsxRuntime.jsxs(PageNavigator, { children: [jsxRuntime.jsx(uilibGl.IconButton, { kind: "prev", onClick: () => prevPage(pages.length) }), jsxRuntime.jsx(uilibGl.IconButton, { kind: "next", onClick: () => nextPage(pages.length) })] }));
9654
9658
  });
9655
9659
 
9656
- const StyledSvgWidthMixin = styled.css `
9657
- &&& {
9658
- svg {
9659
- width: ${({ $width }) => $width}px;
9660
- }
9661
- }
9662
- `;
9663
- const StyledSvgHeightMixin = styled.css `
9664
- &&& {
9665
- svg {
9666
- height: ${({ $height }) => $height}px;
9667
- }
9668
- }
9669
- `;
9670
- const StyledSvgColorMixin = styled.css `
9671
- svg {
9672
- path,
9673
- line,
9674
- circle {
9675
- fill: ${({ $fontColor }) => $fontColor} !important;
9676
- }
9677
- }
9678
- `;
9679
- const StyledSvg = styled(uilibGl.Flex) `
9680
- align-items: center;
9681
- ${({ $width }) => !!$width && StyledSvgWidthMixin};
9682
- ${({ $height }) => !!$height && StyledSvgHeightMixin};
9683
- ${({ $fontColor }) => !!$fontColor && StyledSvgColorMixin};
9660
+ const StyledSvgWidthMixin = styled.css `
9661
+ &&& {
9662
+ svg {
9663
+ width: ${({ $width }) => $width}px;
9664
+ }
9665
+ }
9666
+ `;
9667
+ const StyledSvgHeightMixin = styled.css `
9668
+ &&& {
9669
+ svg {
9670
+ height: ${({ $height }) => $height}px;
9671
+ }
9672
+ }
9673
+ `;
9674
+ const StyledSvgColorMixin = styled.css `
9675
+ svg {
9676
+ path,
9677
+ line,
9678
+ circle {
9679
+ fill: ${({ $fontColor }) => $fontColor} !important;
9680
+ }
9681
+ }
9682
+ `;
9683
+ const StyledSvg = styled(uilibGl.Flex) `
9684
+ align-items: center;
9685
+ ${({ $width }) => !!$width && StyledSvgWidthMixin};
9686
+ ${({ $height }) => !!$height && StyledSvgHeightMixin};
9687
+ ${({ $fontColor }) => !!$fontColor && StyledSvgColorMixin};
9684
9688
  `;
9685
9689
 
9686
9690
  const SvgImage = React.memo(({ url, width, height, fontColor }) => {
@@ -9909,28 +9913,28 @@ const Layer = ({ layer, layerType, visible, beforeId, tileUrl, getLayerTempStyle
9909
9913
  return (jsxRuntime.jsx(VectorLayer, { layer: layer, tileUrl: tileUrl, visible: visible, beforeId: beforeId, getLayerTempStyle: getLayerTempStyle }));
9910
9914
  };
9911
9915
 
9912
- const MapWrapper = styled.div `
9913
- position: relative;
9914
- width: 100%;
9915
- height: 100%;
9916
- box-sizing: border-box;
9917
- z-index: ${({ $zIndex }) => $zIndex ?? 1};
9918
-
9919
- .mapbox-gl-draw_trash {
9920
- display: none;
9921
- }
9922
-
9923
- .mapboxgl-ctrl-logo {
9924
- display: none;
9925
- }
9926
-
9927
- .mapboxgl-ctrl.mapboxgl-ctrl-attrib {
9928
- display: none;
9929
- }
9930
-
9931
- .mapboxgl-ctrl-geocoder.mapboxgl-ctrl {
9932
- width: 350px;
9933
- }
9916
+ const MapWrapper = styled.div `
9917
+ position: relative;
9918
+ width: 100%;
9919
+ height: 100%;
9920
+ box-sizing: border-box;
9921
+ z-index: ${({ $zIndex }) => $zIndex ?? 1};
9922
+
9923
+ .mapbox-gl-draw_trash {
9924
+ display: none;
9925
+ }
9926
+
9927
+ .mapboxgl-ctrl-logo {
9928
+ display: none;
9929
+ }
9930
+
9931
+ .mapboxgl-ctrl.mapboxgl-ctrl-attrib {
9932
+ display: none;
9933
+ }
9934
+
9935
+ .mapboxgl-ctrl-geocoder.mapboxgl-ctrl {
9936
+ width: 350px;
9937
+ }
9934
9938
  `;
9935
9939
 
9936
9940
  const Map$1 = ({ zIndex, lowerSiblings, upperSiblings, onError, children, ...rest }) => {