@evergis/react 3.1.20 → 3.1.22

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/index.js CHANGED
@@ -27,181 +27,181 @@ const AddFeatureButton = ({ title, icon = "feature_add" /* , layerName, geometry
27
27
  return (jsxRuntime.jsx(uilibGl.IconButton, { kind: icon, primary: true, onClick: handleAddFeature, children: title }));
28
28
  };
29
29
 
30
- const ChartTooltipTable = styled.table `
31
- td {
32
- padding: 0;
33
- }
34
-
35
- tr:not(:last-child) td {
36
- padding-bottom: 0.375rem;
37
- }
38
- `;
39
- const ChartTooltip = styled(uilibGl.Flex) `
40
- flex-wrap: nowrap;
41
- background: rgb(48, 69, 79);
42
- border-radius: 0.25rem;
43
- color: white;
44
-
45
- :not(:last-child) {
46
- margin-bottom: 0.25rem;
47
- }
48
- `;
49
- const ChartTooltipLabel = styled.div `
50
- margin-right: 0.25rem;
51
- `;
52
- const ChartTooltipColor = styled.div `
53
- width: 0.625rem;
54
- height: 0.625rem;
55
- background-color: ${({ $color }) => $color};
56
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.smallest};
57
- margin-right: 0.25rem;
58
- `;
59
- const ChartLegendColor$1 = styled.div `
60
- width: 0.5rem;
61
- height: 0.5rem;
62
- background-color: ${({ $color }) => $color};
63
- border-radius: 0.125rem;
64
- `;
65
- const ChartLegendValue = styled.div `
66
- opacity: 0.65;
67
- `;
68
- const ChartTooltipRow = styled(uilibGl.Flex) `
69
- display: flex;
70
- flex-direction: row;
71
- flex-wrap: nowrap;
72
- align-items: center;
73
- margin-top: 0.25rem;
74
- line-height: 0;
75
-
76
- ${ChartLegendColor$1} {
77
- margin-right: 0.25rem;
78
- }
79
- `;
80
- const ChartTooltipName = styled.div `
81
- margin-right: 1rem;
82
- opacity: 0.65;
83
- `;
84
- const PieChartCenter = styled.div `
85
- position: absolute;
86
- top: 50%;
87
- left: 50%;
88
- transform: translate(-50%, -50%);
89
- text-align: center;
90
- font-weight: bold;
91
- font-size: 1.5rem;
92
- `;
93
- const ChartWrapperContainer = styled.div `
94
- position: relative;
95
- width: 100%;
96
- `;
97
- const Tooltip = styled.div `
98
- position: relative;
99
- border-radius: 0.25rem;
100
- background-color: rgba(28, 33, 48);
101
- padding: 0.5rem;
102
- box-shadow: 0 0.125rem 0.25rem 0 rgba(0, 0, 0, 0.15);
103
- font-size: 0.75rem;
104
- transform: ${({ transform }) => transform};
105
- color: white;
106
-
107
- :before {
108
- position: absolute;
109
- display: block;
110
- content: "";
111
- width: 0;
112
- height: 0;
113
- }
114
- `;
115
- const LineChartStyles = styled.createGlobalStyle `
116
- .dashboardLineChartTooltip.${charts.lineChartClassNames.lineChartMouseLabel} {
117
- .${charts.lineChartClassNames.lineChartLabelFlex} {
118
- justify-content: center;
119
- align-items: flex-end;
120
-
121
- ${Tooltip} {
122
- margin: 0 0 12px 0;
123
-
124
- :before {
125
- top: auto;
126
- bottom: 0;
127
- left: 50%;
128
- transform: translate(-50%, 100%);
129
- border-left: 4px solid transparent;
130
- border-right: 4px solid transparent;
131
- border-top: 4px solid rgba(28, 33, 48, 0.9);
132
- }
133
- }
134
- }
135
- }
136
-
137
- .${charts.lineChartClassNames.lineChartYScaleGlobal}, .${charts.lineChartClassNames.lineChartXScaleGlobal} {
138
- .domain {
139
- visibility: hidden;
140
- }
141
-
142
- .tick {
143
- text {
144
- fill: ${({ theme: { palette } }) => palette.textDisabled};
145
- }
146
-
147
- line {
148
- visibility: hidden;
149
- }
150
- }
151
- }
152
-
153
- .${charts.lineChartClassNames.lineChartXScaleGlobal} {
154
- .tick {
155
- :first-of-type {
156
- text {
157
- text-anchor: start;
158
- }
159
- }
160
-
161
- :last-of-type {
162
- text {
163
- text-anchor: end;
164
- }
165
- }
166
- }
167
- }
168
-
169
- .${charts.lineChartClassNames.lineChartLine} {
170
- stroke-width: 2px;
171
- }
172
-
173
- .${charts.lineChartClassNames.lineChartLabel} {
174
- color: ${({ theme: { palette } }) => palette.textPrimary};
175
- }
176
-
177
- .${charts.lineChartClassNames.lineChartMouseCircle} {
178
- stroke: #ffffff;
179
- stroke-width: 2px;
180
- }
181
-
182
- .${charts.lineChartClassNames.lineChartGridLineX} {
183
- stroke: ${({ theme: { palette } }) => palette.element};
184
- }
185
-
186
- text {
187
- fill: ${({ theme: { palette } }) => palette.textDisabled};
188
- }
189
- `;
190
- const StyledBarChart = styled(charts.BarChart) `
191
- .domain,
192
- line {
193
- display: none;
194
- }
195
-
196
- .tick {
197
- text {
198
- fill: ${({ theme: { palette } }) => palette.textDisabled};
199
- }
200
-
201
- line {
202
- visibility: hidden;
203
- }
204
- }
30
+ const ChartTooltipTable = styled.table `
31
+ td {
32
+ padding: 0;
33
+ }
34
+
35
+ tr:not(:last-child) td {
36
+ padding-bottom: 0.375rem;
37
+ }
38
+ `;
39
+ const ChartTooltip = styled(uilibGl.Flex) `
40
+ flex-wrap: nowrap;
41
+ background: rgb(48, 69, 79);
42
+ border-radius: 0.25rem;
43
+ color: white;
44
+
45
+ :not(:last-child) {
46
+ margin-bottom: 0.25rem;
47
+ }
48
+ `;
49
+ const ChartTooltipLabel = styled.div `
50
+ margin-right: 0.25rem;
51
+ `;
52
+ const ChartTooltipColor = styled.div `
53
+ width: 0.625rem;
54
+ height: 0.625rem;
55
+ background-color: ${({ $color }) => $color};
56
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.smallest};
57
+ margin-right: 0.25rem;
58
+ `;
59
+ const ChartLegendColor$1 = styled.div `
60
+ width: 0.5rem;
61
+ height: 0.5rem;
62
+ background-color: ${({ $color }) => $color};
63
+ border-radius: 0.125rem;
64
+ `;
65
+ const ChartLegendValue = styled.div `
66
+ opacity: 0.65;
67
+ `;
68
+ const ChartTooltipRow = styled(uilibGl.Flex) `
69
+ display: flex;
70
+ flex-direction: row;
71
+ flex-wrap: nowrap;
72
+ align-items: center;
73
+ margin-top: 0.25rem;
74
+ line-height: 0;
75
+
76
+ ${ChartLegendColor$1} {
77
+ margin-right: 0.25rem;
78
+ }
79
+ `;
80
+ const ChartTooltipName = styled.div `
81
+ margin-right: 1rem;
82
+ opacity: 0.65;
83
+ `;
84
+ const PieChartCenter = styled.div `
85
+ position: absolute;
86
+ top: 50%;
87
+ left: 50%;
88
+ transform: translate(-50%, -50%);
89
+ text-align: center;
90
+ font-weight: bold;
91
+ font-size: 1.5rem;
92
+ `;
93
+ const ChartWrapperContainer = styled.div `
94
+ position: relative;
95
+ width: 100%;
96
+ `;
97
+ const Tooltip = styled.div `
98
+ position: relative;
99
+ border-radius: 0.25rem;
100
+ background-color: rgba(28, 33, 48);
101
+ padding: 0.5rem;
102
+ box-shadow: 0 0.125rem 0.25rem 0 rgba(0, 0, 0, 0.15);
103
+ font-size: 0.75rem;
104
+ transform: ${({ transform }) => transform};
105
+ color: white;
106
+
107
+ :before {
108
+ position: absolute;
109
+ display: block;
110
+ content: "";
111
+ width: 0;
112
+ height: 0;
113
+ }
114
+ `;
115
+ const LineChartStyles = styled.createGlobalStyle `
116
+ .dashboardLineChartTooltip.${charts.lineChartClassNames.lineChartMouseLabel} {
117
+ .${charts.lineChartClassNames.lineChartLabelFlex} {
118
+ justify-content: center;
119
+ align-items: flex-end;
120
+
121
+ ${Tooltip} {
122
+ margin: 0 0 12px 0;
123
+
124
+ :before {
125
+ top: auto;
126
+ bottom: 0;
127
+ left: 50%;
128
+ transform: translate(-50%, 100%);
129
+ border-left: 4px solid transparent;
130
+ border-right: 4px solid transparent;
131
+ border-top: 4px solid rgba(28, 33, 48, 0.9);
132
+ }
133
+ }
134
+ }
135
+ }
136
+
137
+ .${charts.lineChartClassNames.lineChartYScaleGlobal}, .${charts.lineChartClassNames.lineChartXScaleGlobal} {
138
+ .domain {
139
+ visibility: hidden;
140
+ }
141
+
142
+ .tick {
143
+ text {
144
+ fill: ${({ theme: { palette } }) => palette.textDisabled};
145
+ }
146
+
147
+ line {
148
+ visibility: hidden;
149
+ }
150
+ }
151
+ }
152
+
153
+ .${charts.lineChartClassNames.lineChartXScaleGlobal} {
154
+ .tick {
155
+ :first-of-type {
156
+ text {
157
+ text-anchor: start;
158
+ }
159
+ }
160
+
161
+ :last-of-type {
162
+ text {
163
+ text-anchor: end;
164
+ }
165
+ }
166
+ }
167
+ }
168
+
169
+ .${charts.lineChartClassNames.lineChartLine} {
170
+ stroke-width: 2px;
171
+ }
172
+
173
+ .${charts.lineChartClassNames.lineChartLabel} {
174
+ color: ${({ theme: { palette } }) => palette.textPrimary};
175
+ }
176
+
177
+ .${charts.lineChartClassNames.lineChartMouseCircle} {
178
+ stroke: #ffffff;
179
+ stroke-width: 2px;
180
+ }
181
+
182
+ .${charts.lineChartClassNames.lineChartGridLineX} {
183
+ stroke: ${({ theme: { palette } }) => palette.element};
184
+ }
185
+
186
+ text {
187
+ fill: ${({ theme: { palette } }) => palette.textDisabled};
188
+ }
189
+ `;
190
+ const StyledBarChart = styled(charts.BarChart) `
191
+ .domain,
192
+ line {
193
+ display: none;
194
+ }
195
+
196
+ .tick {
197
+ text {
198
+ fill: ${({ theme: { palette } }) => palette.textDisabled};
199
+ }
200
+
201
+ line {
202
+ visibility: hidden;
203
+ }
204
+ }
205
205
  `;
206
206
 
207
207
  function range(start, stop, step) {
@@ -3429,42 +3429,42 @@ const NUMERIC_ATTRIBUTE_TYPES = [api.AttributeType.Double, api.AttributeType.Int
3429
3429
  const GEOMETRY_ATTRIBUTE = "geometry";
3430
3430
  const DEFAULT_ID_ATTRIBUTE_NAME = "gid";
3431
3431
 
3432
- const StackBarContainer = styled(uilibGl.Flex) `
3433
- flex-wrap: nowrap;
3434
- width: 100%;
3435
- `;
3436
- const StackBarHeader = styled(uilibGl.Flex) `
3437
- justify-content: space-between;
3438
- margin-bottom: 0.375rem;
3439
- font-size: 0.75rem;
3440
- `;
3441
- const StackBarSection = styled.div `
3442
- cursor: ${({ onClick }) => (onClick ? "pointer" : "default")};
3443
- width: ${({ $width }) => $width}%;
3444
- height: ${({ $height }) => ($height ? `${$height}px` : "0.5rem")};
3445
- margin: 0 0.5px;
3446
- background-color: ${({ $color }) => $color};
3447
- opacity: ${({ hasAnyFilter, isFiltered }) => (isFiltered ? 1 : hasAnyFilter ? FILTERED_VALUE_OPACITY / 100 : 1)};
3448
- transition: opacity ${uilibGl.transition.release};
3449
-
3450
- :first-child {
3451
- border-top-left-radius: ${({ cornerRadius }) => (cornerRadius ? `${cornerRadius}px` : "0.5rem")};
3452
- border-bottom-left-radius: ${({ cornerRadius }) => (cornerRadius ? `${cornerRadius}px` : "0.5rem")};
3453
- }
3454
-
3455
- :last-child {
3456
- border-top-right-radius: ${({ cornerRadius }) => (cornerRadius ? `${cornerRadius}px` : "0.5rem")};
3457
- border-bottom-right-radius: ${({ cornerRadius }) => (cornerRadius ? `${cornerRadius}px` : "0.5rem")};
3458
- }
3459
- `;
3460
- const StackBarAlias = styled.div `
3461
- color: ${({ theme: { palette } }) => palette.textSecondary};
3432
+ const StackBarContainer = styled(uilibGl.Flex) `
3433
+ flex-wrap: nowrap;
3434
+ width: 100%;
3435
+ `;
3436
+ const StackBarHeader = styled(uilibGl.Flex) `
3437
+ justify-content: space-between;
3438
+ margin-bottom: 0.375rem;
3439
+ font-size: 0.75rem;
3440
+ `;
3441
+ const StackBarSection = styled.div `
3442
+ cursor: ${({ onClick }) => (onClick ? "pointer" : "default")};
3443
+ width: ${({ $width }) => $width}%;
3444
+ height: ${({ $height }) => ($height ? `${$height}px` : "0.5rem")};
3445
+ margin: 0 0.5px;
3446
+ background-color: ${({ $color }) => $color};
3447
+ opacity: ${({ hasAnyFilter, isFiltered }) => (isFiltered ? 1 : hasAnyFilter ? FILTERED_VALUE_OPACITY / 100 : 1)};
3448
+ transition: opacity ${uilibGl.transition.release};
3449
+
3450
+ :first-child {
3451
+ border-top-left-radius: ${({ cornerRadius }) => (cornerRadius ? `${cornerRadius}px` : "0.5rem")};
3452
+ border-bottom-left-radius: ${({ cornerRadius }) => (cornerRadius ? `${cornerRadius}px` : "0.5rem")};
3453
+ }
3454
+
3455
+ :last-child {
3456
+ border-top-right-radius: ${({ cornerRadius }) => (cornerRadius ? `${cornerRadius}px` : "0.5rem")};
3457
+ border-bottom-right-radius: ${({ cornerRadius }) => (cornerRadius ? `${cornerRadius}px` : "0.5rem")};
3458
+ }
3459
+ `;
3460
+ const StackBarAlias = styled.div `
3461
+ color: ${({ theme: { palette } }) => palette.textSecondary};
3462
3462
  `;
3463
3463
  const StackBarTotal = styled(uilibGl.Flex) ``;
3464
3464
  const StackBarValue = styled.div ``;
3465
- const StackBarUnits = styled.div `
3466
- margin-left: 0.25rem;
3467
- color: ${({ theme: { palette } }) => palette.textSecondary};
3465
+ const StackBarUnits = styled.div `
3466
+ margin-left: 0.25rem;
3467
+ color: ${({ theme: { palette } }) => palette.textSecondary};
3468
3468
  `;
3469
3469
 
3470
3470
  const transparentizeColor = (originalColor, percent) => {
@@ -3721,17 +3721,19 @@ const formatNumberValue = (stringFormat, value, type, noUnits = false) => {
3721
3721
  };
3722
3722
  const formatAttributeValue = ({ t, type, value, stringFormat, noUnits = false }) => {
3723
3723
  if (type === api.AttributeType.Point) {
3724
- if (!(stringFormat && stringFormat.format) || !value)
3724
+ if (!stringFormat?.format || !value)
3725
3725
  return null;
3726
3726
  const { coordinates } = value;
3727
3727
  return formatPointValue({ t, stringFormat, value: coordinates });
3728
3728
  }
3729
3729
  if (type === api.AttributeType.DateTime) {
3730
- if (!(stringFormat && stringFormat.format) || !value)
3730
+ if (!stringFormat?.format || !value)
3731
3731
  return null;
3732
3732
  return formatDateValue(stringFormat, value);
3733
3733
  }
3734
3734
  if (numberFormatTypes.includes(type) && !isNaN(value)) {
3735
+ if (!stringFormat?.format)
3736
+ return value.toString();
3735
3737
  return formatNumberValue(stringFormat, value, type, noUnits);
3736
3738
  }
3737
3739
  if (type === api.AttributeType.Json) {
@@ -4026,8 +4028,8 @@ const useChartChange = ({ dataSources, chartId, width, height, relatedAttributes
4026
4028
  const customize = React.useCallback(({ svg }) => {
4027
4029
  svg.style("overflow", "visible");
4028
4030
  svg
4029
- .selectAll(`.${charts.lineChartClassNames.lineChartXScaleGlobal} line,
4030
- .${charts.lineChartClassNames.lineChartYScaleGlobal} line,
4031
+ .selectAll(`.${charts.lineChartClassNames.lineChartXScaleGlobal} line,
4032
+ .${charts.lineChartClassNames.lineChartYScaleGlobal} line,
4031
4033
  .domain`)
4032
4034
  .each((_, index, nodes) => {
4033
4035
  nodes[index].remove();
@@ -4081,11 +4083,11 @@ const useChartChange = ({ dataSources, chartId, width, height, relatedAttributes
4081
4083
  .attr("fill", `url(#${gradientId})`)
4082
4084
  .attr("stroke-width", "0")
4083
4085
  .attr("fill-opacity", FILL_OPACITY);
4084
- defs.push(`
4085
- <linearGradient id="${gradientId}" x1="0" y1="0" x2="0" y2="1">
4086
- <stop offset="0" stop-color="${color}" stop-opacity="1" />
4087
- <stop offset="1" stop-color="${color}" stop-opacity="0" />
4088
- </linearGradient>
4086
+ defs.push(`
4087
+ <linearGradient id="${gradientId}" x1="0" y1="0" x2="0" y2="1">
4088
+ <stop offset="0" stop-color="${color}" stop-opacity="1" />
4089
+ <stop offset="1" stop-color="${color}" stop-opacity="0" />
4090
+ </linearGradient>
4089
4091
  `);
4090
4092
  ref.current = {
4091
4093
  path: newPath,
@@ -4434,247 +4436,247 @@ const formatDataSourceCondition = ({ condition, configFilters, filters, attribut
4434
4436
  : conditionSection.join(splitter);
4435
4437
  };
4436
4438
 
4437
- const DashboardChipsContainer = styled(uilibGl.Flex) `
4438
- flex-wrap: wrap;
4439
- `;
4440
- const DashboardChip$1 = styled(uilibGl.Chip) `
4441
- margin: 0 0.25rem 0.25rem 0;
4442
- background: ${({ $isDefault, $bgColor, theme: { palette } }) => $isDefault ? palette.element : $bgColor || palette.primary};
4443
- border-radius: ${({ $radius, theme: { borderRadius } }) => $radius || borderRadius.medium};
4444
- white-space: nowrap;
4445
- font-size: ${({ $fontSize }) => $fontSize || "0.875rem"};
4446
- color: ${({ $isDefault, $fontColor, theme: { palette } }) => $isDefault ? palette.textPrimary : $fontColor || "#fff"};
4447
-
4448
- > * {
4449
- font-size: ${({ $fontSize }) => $fontSize || "0.875rem"};
4450
- color: ${({ $isDefault, $fontColor, theme: { palette } }) => $isDefault ? palette.textPrimary : $fontColor || "#fff"};
4451
- }
4452
-
4453
- span[kind] {
4454
- height: 0.875rem;
4455
-
4456
- :after {
4457
- color: ${({ $isDefault, $fontColor, theme: { palette } }) => ($isDefault ? palette.icon : $fontColor || "#fff")};
4458
- font-size: 0.875rem;
4459
- }
4460
- }
4461
-
4462
- button {
4463
- width: auto;
4464
- padding: 0 0.5rem;
4465
- }
4466
- `;
4467
-
4468
- const ChartLegendContainer = styled(uilibGl.Flex) `
4469
- flex-direction: column;
4470
- flex-wrap: wrap;
4471
- justify-content: ${({ twoColumns }) => (twoColumns ? "flex-start" : "center")};
4472
- `;
4473
- const ChartLegendItem = styled(uilibGl.Flex) `
4474
- cursor: ${({ onClick }) => (onClick ? "pointer" : "default")};
4475
- align-items: center;
4476
- flex-wrap: nowrap;
4477
- width: auto;
4478
- margin-right: 0.375rem;
4479
- margin-bottom: 0.25rem;
4480
- opacity: ${({ isFiltered, hasAnyFilter }) => (isFiltered ? 1 : hasAnyFilter ? FILTERED_VALUE_OPACITY / 100 : 1)};
4481
- `;
4482
- const ChartLegendColor = styled.div `
4483
- width: 0.5rem;
4484
- height: 0.5rem;
4485
- margin-right: 0.375rem;
4486
- background-color: ${({ color }) => color};
4487
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.tiny};
4488
- `;
4489
- const ChartLegendName = styled.div `
4490
- flex: 1;
4491
- font-size: 0.625rem;
4492
- color: ${({ theme: { palette }, $fontColor }) => $fontColor || palette.textPrimary};
4493
- `;
4494
-
4495
- const Container = styled(uilibGl.Flex) `
4496
- flex-direction: column;
4497
- width: 100%;
4498
-
4439
+ const DashboardChipsContainer = styled(uilibGl.Flex) `
4440
+ flex-wrap: wrap;
4441
+ `;
4442
+ const DashboardChip$1 = styled(uilibGl.Chip) `
4443
+ margin: 0 0.25rem 0.25rem 0;
4444
+ background: ${({ $isDefault, $bgColor, theme: { palette } }) => $isDefault ? palette.element : $bgColor || palette.primary};
4445
+ border-radius: ${({ $radius, theme: { borderRadius } }) => $radius || borderRadius.medium};
4446
+ white-space: nowrap;
4447
+ font-size: ${({ $fontSize }) => $fontSize || "0.875rem"};
4448
+ color: ${({ $isDefault, $fontColor, theme: { palette } }) => $isDefault ? palette.textPrimary : $fontColor || "#fff"};
4449
+
4450
+ > * {
4451
+ font-size: ${({ $fontSize }) => $fontSize || "0.875rem"};
4452
+ color: ${({ $isDefault, $fontColor, theme: { palette } }) => $isDefault ? palette.textPrimary : $fontColor || "#fff"};
4453
+ }
4454
+
4455
+ span[kind] {
4456
+ height: 0.875rem;
4457
+
4458
+ :after {
4459
+ color: ${({ $isDefault, $fontColor, theme: { palette } }) => ($isDefault ? palette.icon : $fontColor || "#fff")};
4460
+ font-size: 0.875rem;
4461
+ }
4462
+ }
4463
+
4464
+ button {
4465
+ width: auto;
4466
+ padding: 0 0.5rem;
4467
+ }
4468
+ `;
4469
+
4470
+ const ChartLegendContainer = styled(uilibGl.Flex) `
4471
+ flex-direction: column;
4472
+ flex-wrap: wrap;
4473
+ justify-content: ${({ twoColumns }) => (twoColumns ? "flex-start" : "center")};
4474
+ `;
4475
+ const ChartLegendItem = styled(uilibGl.Flex) `
4476
+ cursor: ${({ onClick }) => (onClick ? "pointer" : "default")};
4477
+ align-items: center;
4478
+ flex-wrap: nowrap;
4479
+ width: auto;
4480
+ margin-right: 0.375rem;
4481
+ margin-bottom: 0.25rem;
4482
+ opacity: ${({ isFiltered, hasAnyFilter }) => (isFiltered ? 1 : hasAnyFilter ? FILTERED_VALUE_OPACITY / 100 : 1)};
4483
+ `;
4484
+ const ChartLegendColor = styled.div `
4485
+ width: 0.5rem;
4486
+ height: 0.5rem;
4487
+ margin-right: 0.375rem;
4488
+ background-color: ${({ color }) => color};
4489
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.tiny};
4490
+ `;
4491
+ const ChartLegendName = styled.div `
4492
+ flex: 1;
4493
+ font-size: 0.625rem;
4494
+ color: ${({ theme: { palette }, $fontColor }) => $fontColor || palette.textPrimary};
4495
+ `;
4496
+
4497
+ const Container = styled(uilibGl.Flex) `
4498
+ flex-direction: column;
4499
+ width: 100%;
4500
+
4499
4501
  ${({ isColumn }) => isColumn
4500
- ? styled.css `
4501
- > * {
4502
- width: 100%;
4503
- }
4502
+ ? styled.css `
4503
+ > * {
4504
+ width: 100%;
4505
+ }
4504
4506
  `
4505
- : styled.css `
4506
- flex-direction: row;
4507
- justify-content: space-between;
4508
- align-items: center;
4509
- `}
4510
-
4507
+ : styled.css `
4508
+ flex-direction: row;
4509
+ justify-content: space-between;
4510
+ align-items: center;
4511
+ `}
4512
+
4511
4513
  ${({ isMain, isColumn }) => (isMain || isColumn) &&
4512
- styled.css `
4513
- > :not(:last-child) {
4514
- margin-bottom: 0.5rem;
4515
- }
4516
- `}
4517
-
4514
+ styled.css `
4515
+ > :not(:last-child) {
4516
+ margin-bottom: 0.5rem;
4517
+ }
4518
+ `}
4519
+
4518
4520
  ${({ isTitle }) => isTitle &&
4519
- styled.css `
4520
- &&&& {
4521
- margin-bottom: 0.75rem;
4522
- }
4523
- `}
4524
- `;
4525
- const ContainerAlias = styled(uilibGl.Flex) `
4526
- align-items: center;
4527
- flex-wrap: nowrap;
4528
- margin-bottom: ${({ hasBottomMargin }) => (hasBottomMargin ? 0.25 : 0)}rem;
4529
- font-size: 0.75rem;
4530
- color: ${({ theme: { palette } }) => palette.textSecondary};
4531
-
4532
- span[kind] {
4533
- margin-right: 0.5rem;
4534
-
4535
- :after {
4536
- color: ${({ theme: { palette } }) => palette.primary};
4537
- }
4538
- }
4539
- `;
4540
- const ContainerAliasIcon = styled.div `
4541
- margin-right: 0.5rem;
4542
- `;
4543
- const ContainerChart = styled(uilibGl.Flex) `
4544
- justify-content: flex-start;
4545
-
4546
- > * {
4547
- display: flex;
4548
- justify-content: center;
4549
- width: 100%;
4550
- }
4521
+ styled.css `
4522
+ &&&& {
4523
+ margin-bottom: 0.75rem;
4524
+ }
4525
+ `}
4526
+ `;
4527
+ const ContainerAlias = styled(uilibGl.Flex) `
4528
+ align-items: center;
4529
+ flex-wrap: nowrap;
4530
+ margin-bottom: ${({ hasBottomMargin }) => (hasBottomMargin ? 0.25 : 0)}rem;
4531
+ font-size: 0.75rem;
4532
+ color: ${({ theme: { palette } }) => palette.textSecondary};
4533
+
4534
+ span[kind] {
4535
+ margin-right: 0.5rem;
4536
+
4537
+ :after {
4538
+ color: ${({ theme: { palette } }) => palette.primary};
4539
+ }
4540
+ }
4541
+ `;
4542
+ const ContainerAliasIcon = styled.div `
4543
+ margin-right: 0.5rem;
4544
+ `;
4545
+ const ContainerChart = styled(uilibGl.Flex) `
4546
+ justify-content: flex-start;
4547
+
4548
+ > * {
4549
+ display: flex;
4550
+ justify-content: center;
4551
+ width: 100%;
4552
+ }
4551
4553
  `;
4552
4554
  const ContainerLegend = styled(uilibGl.Flex) ``;
4553
- const ContainerUnits = styled.div `
4554
- margin-left: 0.5rem;
4555
- white-space: nowrap;
4556
- font-size: 0.75rem;
4557
- `;
4558
- const ContainerValue = styled(uilibGl.Flex) `
4559
- justify-content: flex-end;
4560
- align-items: center;
4561
- flex-wrap: nowrap;
4562
- width: 100%;
4563
- font-size: ${({ big }) => (big ? 1.5 : 1)}rem;
4564
- color: ${({ fontColor, theme: { palette } }) => fontColor || palette.textPrimary};
4565
-
4566
- > * {
4567
- width: ${({ column }) => (column ? "100%" : "auto")};
4568
- }
4569
-
4570
- ${ContainerChart}, ${ContainerLegend} {
4571
- width: ${({ column }) => (column ? "100%" : "50%")};
4572
- }
4573
-
4574
- ${ContainerLegend} {
4575
- margin-left: ${({ column }) => (column ? 0 : "1rem")};
4576
- }
4577
-
4578
- ${ChartLegendContainer} {
4579
- flex-direction: ${({ column }) => (column ? "row" : "column")};
4580
- margin-top: ${({ column }) => (column ? "1rem" : 0)};
4581
- }
4582
- `;
4583
- const ColorIconMixin = styled.css `
4584
- :after {
4585
- color: ${({ $fontColor }) => $fontColor} !important;
4586
- }
4587
- `;
4588
- const SizeIconMixin = styled.css `
4589
- :after {
4590
- font-size: ${({ $fontSize }) => $fontSize}px !important;
4591
- }
4592
- `;
4593
- const ContainerIcon = styled(uilibGl.Icon) `
4594
- width: auto;
4595
- height: auto;
4596
- margin-bottom: 0.5rem;
4597
- ${({ $fontColor }) => !!$fontColor && ColorIconMixin};
4598
- ${({ $fontSize }) => !!$fontSize && SizeIconMixin};
4599
- `;
4600
- const SvgContainerColorMixin$1 = styled.css `
4601
- path,
4602
- line,
4603
- circle {
4604
- fill: ${({ $fontColor }) => $fontColor};
4605
- }
4606
- `;
4607
- const SvgContainer$1 = styled.div `
4608
- &&& {
4609
- min-width: ${({ $width }) => ($width ? `${$width}px` : "1rem")};
4610
- max-width: ${({ $width }) => ($width ? `${$width}px` : "1rem")};
4611
-
4612
- ${({ $fontColor }) => !!$fontColor && SvgContainerColorMixin$1};
4613
-
4614
- > * {
4615
- min-width: inherit;
4616
- }
4617
- }
4618
- `;
4619
- const TwoColumnContainerWrapper = styled(uilibGl.Flex) `
4620
- width: 100%;
4621
- flex-direction: row;
4622
- flex-wrap: nowrap;
4623
- align-items: center;
4624
-
4625
- > * {
4626
- flex: 1;
4627
- }
4628
-
4629
- > ${ContainerValue} {
4630
- justify-content: flex-end;
4631
-
4632
- > * {
4633
- text-align: right;
4634
- }
4635
- }
4636
- `;
4637
-
4638
- const LayerGroupContainer = styled(uilibGl.Flex) `
4639
- display: flex;
4640
- justify-content: center;
4641
- position: relative;
4642
- flex-direction: column;
4643
- padding: 0 0.25rem 0 1rem;
4644
- box-sizing: border-box;
4645
- transition: opacity ${uilibGl.transition.hover}, background-color ${uilibGl.transition.hover};
4646
- font-family: "NunitoSans", sans-serif;
4647
- `;
4648
- const LayerGroupMain = styled(uilibGl.Flex) `
4649
- flex-direction: row;
4650
- flex-wrap: nowrap;
4651
- align-items: center;
4652
- justify-content: space-between;
4653
- width: 100%;
4654
-
4655
- ${uilibGl.Icon} {
4656
- width: 2rem;
4657
- min-width: 2rem;
4658
- height: 2rem;
4659
- display: inline-flex;
4660
- align-items: center;
4661
- justify-content: center;
4662
- margin-right: 0.75rem;
4663
- }
4664
-
4665
- ${uilibGl.Description} {
4666
- display: flex;
4667
- align-items: center;
4668
- flex-grow: 1;
4669
- width: 100%;
4670
- margin-right: 0.25rem;
4671
- color: ${({ theme }) => theme.palette.textPrimary};
4672
- }
4673
-
4674
- button {
4675
- width: 2.25rem;
4676
- justify-content: flex-start;
4677
- }
4555
+ const ContainerUnits = styled.div `
4556
+ margin-left: 0.5rem;
4557
+ white-space: nowrap;
4558
+ font-size: 0.75rem;
4559
+ `;
4560
+ const ContainerValue = styled(uilibGl.Flex) `
4561
+ justify-content: flex-end;
4562
+ align-items: center;
4563
+ flex-wrap: nowrap;
4564
+ width: 100%;
4565
+ font-size: ${({ big }) => (big ? 1.5 : 1)}rem;
4566
+ color: ${({ fontColor, theme: { palette } }) => fontColor || palette.textPrimary};
4567
+
4568
+ > * {
4569
+ width: ${({ column }) => (column ? "100%" : "auto")};
4570
+ }
4571
+
4572
+ ${ContainerChart}, ${ContainerLegend} {
4573
+ width: ${({ column }) => (column ? "100%" : "50%")};
4574
+ }
4575
+
4576
+ ${ContainerLegend} {
4577
+ margin-left: ${({ column }) => (column ? 0 : "1rem")};
4578
+ }
4579
+
4580
+ ${ChartLegendContainer} {
4581
+ flex-direction: ${({ column }) => (column ? "row" : "column")};
4582
+ margin-top: ${({ column }) => (column ? "1rem" : 0)};
4583
+ }
4584
+ `;
4585
+ const ColorIconMixin = styled.css `
4586
+ :after {
4587
+ color: ${({ $fontColor }) => $fontColor} !important;
4588
+ }
4589
+ `;
4590
+ const SizeIconMixin = styled.css `
4591
+ :after {
4592
+ font-size: ${({ $fontSize }) => $fontSize}px !important;
4593
+ }
4594
+ `;
4595
+ const ContainerIcon = styled(uilibGl.Icon) `
4596
+ width: auto;
4597
+ height: auto;
4598
+ margin-bottom: 0.5rem;
4599
+ ${({ $fontColor }) => !!$fontColor && ColorIconMixin};
4600
+ ${({ $fontSize }) => !!$fontSize && SizeIconMixin};
4601
+ `;
4602
+ const SvgContainerColorMixin$1 = styled.css `
4603
+ path,
4604
+ line,
4605
+ circle {
4606
+ fill: ${({ $fontColor }) => $fontColor};
4607
+ }
4608
+ `;
4609
+ const SvgContainer$1 = styled.div `
4610
+ &&& {
4611
+ min-width: ${({ $width }) => ($width ? `${$width}px` : "1rem")};
4612
+ max-width: ${({ $width }) => ($width ? `${$width}px` : "1rem")};
4613
+
4614
+ ${({ $fontColor }) => !!$fontColor && SvgContainerColorMixin$1};
4615
+
4616
+ > * {
4617
+ min-width: inherit;
4618
+ }
4619
+ }
4620
+ `;
4621
+ const TwoColumnContainerWrapper = styled(uilibGl.Flex) `
4622
+ width: 100%;
4623
+ flex-direction: row;
4624
+ flex-wrap: nowrap;
4625
+ align-items: center;
4626
+
4627
+ > * {
4628
+ flex: 1;
4629
+ }
4630
+
4631
+ > ${ContainerValue} {
4632
+ justify-content: flex-end;
4633
+
4634
+ > * {
4635
+ text-align: right;
4636
+ }
4637
+ }
4638
+ `;
4639
+
4640
+ const LayerGroupContainer = styled(uilibGl.Flex) `
4641
+ display: flex;
4642
+ justify-content: center;
4643
+ position: relative;
4644
+ flex-direction: column;
4645
+ padding: 0 0.25rem 0 1rem;
4646
+ box-sizing: border-box;
4647
+ transition: opacity ${uilibGl.transition.hover}, background-color ${uilibGl.transition.hover};
4648
+ font-family: "NunitoSans", sans-serif;
4649
+ `;
4650
+ const LayerGroupMain = styled(uilibGl.Flex) `
4651
+ flex-direction: row;
4652
+ flex-wrap: nowrap;
4653
+ align-items: center;
4654
+ justify-content: space-between;
4655
+ width: 100%;
4656
+
4657
+ ${uilibGl.Icon} {
4658
+ width: 2rem;
4659
+ min-width: 2rem;
4660
+ height: 2rem;
4661
+ display: inline-flex;
4662
+ align-items: center;
4663
+ justify-content: center;
4664
+ margin-right: 0.75rem;
4665
+ }
4666
+
4667
+ ${uilibGl.Description} {
4668
+ display: flex;
4669
+ align-items: center;
4670
+ flex-grow: 1;
4671
+ width: 100%;
4672
+ margin-right: 0.25rem;
4673
+ color: ${({ theme }) => theme.palette.textPrimary};
4674
+ }
4675
+
4676
+ button {
4677
+ width: 2.25rem;
4678
+ justify-content: flex-start;
4679
+ }
4678
4680
  `;
4679
4681
 
4680
4682
  const customModes = MapboxDraw.modes;
@@ -4942,6 +4944,19 @@ const useServerNotificationsContext = () => {
4942
4944
  return React.useContext(ServerNotificationsContext);
4943
4945
  };
4944
4946
 
4947
+ const useAppHeight = () => {
4948
+ React.useEffect(() => {
4949
+ const setAppHeight = () => {
4950
+ document.documentElement.style.setProperty("--app-height", `${window.innerHeight}px`);
4951
+ };
4952
+ window.addEventListener("resize", setAppHeight);
4953
+ setAppHeight();
4954
+ return () => {
4955
+ window.removeEventListener("resize", setAppHeight);
4956
+ };
4957
+ }, []);
4958
+ };
4959
+
4945
4960
  const useDebouncedCallback = (interval) => {
4946
4961
  return React.useMemo(() => debounce((cb) => {
4947
4962
  cb();
@@ -5052,286 +5067,286 @@ const LayerTree = ({ layers, onlyMainTools }) => {
5052
5067
  return (jsxRuntime.jsx(uilibGl.DraggableTree, { nodes: nodes, disableDrag: onlyMainTools, options: { pastePlaceholderHeight: "0.0625rem" }, onUpdate: onUpdate }));
5053
5068
  };
5054
5069
 
5055
- const LayersListWrapper = styled(uilibGl.Flex) `
5056
- flex-direction: column;
5057
- height: 100%;
5058
- width: 100%;
5059
- box-sizing: border-box;
5060
- `;
5061
- const LayerListContainer = styled(uilibGl.Flex) `
5062
- flex-grow: 1;
5063
- height: 100%;
5064
- box-sizing: border-box;
5065
- `;
5066
-
5067
- const ElementValueWrapper = styled.div `
5068
- transition: background-color ${uilibGl.transition.toggle};
5069
- `;
5070
- const ContainerWrapper = styled(uilibGl.Flex) `
5071
- position: relative;
5072
- min-height: 1rem;
5073
- box-sizing: border-box;
5074
- width: 100%;
5075
- background: ${({ theme: { palette } }) => palette.backgroundAlpha};
5076
- box-shadow: rgb(0 0 0 / 15%) 0 0.1875rem 0.625rem;
5077
- padding: 1.5rem;
5078
- border-radius: 0.5rem;
5079
- backdrop-filter: blur(20px);
5080
- color: ${({ theme: { palette } }) => palette.textPrimary};
5081
- z-index: ${({ $zIndex }) => $zIndex ?? 1};
5082
- transition: background-color ${uilibGl.transition.toggle};
5083
-
5084
- ${Container} > ${ElementValueWrapper}:not(:last-child) {
5085
- margin-bottom: 1.5rem;
5086
- }
5087
- `;
5088
- const DashboardChip = styled(uilibGl.Chip) `
5089
- margin: 0 0.25rem 0.25rem 0;
5090
- background: ${({ $isDefault, $bgColor, theme: { palette } }) => $isDefault ? palette.element : $bgColor || palette.primary};
5091
- border-radius: ${({ $radius, theme: { borderRadius } }) => $radius || borderRadius.medium};
5092
- font-size: ${({ $fontSize }) => $fontSize || "0.875rem"};
5093
- color: ${({ $isDefault, $fontColor, theme: { palette } }) => $isDefault ? palette.textPrimary : $fontColor || "#fff"};
5094
-
5095
- > * {
5096
- font-size: ${({ $fontSize }) => $fontSize || "0.875rem"};
5097
- color: ${({ $isDefault, $fontColor, theme: { palette } }) => $isDefault ? palette.textPrimary : $fontColor || "#fff"};
5098
- }
5099
-
5100
- span[kind]:after {
5101
- color: ${({ $isDefault, $fontColor, theme: { palette } }) => ($isDefault ? palette.icon : $fontColor || "#fff")};
5102
- }
5103
- `;
5104
- const DashboardPlaceholderWrap = styled(uilibGl.Flex) `
5105
- flex-grow: 1;
5106
- flex-direction: column;
5107
- justify-content: center;
5108
- align-items: center;
5109
- width: 100%;
5110
- margin-bottom: 2rem;
5111
- `;
5112
- const DashboardPlaceholder = styled(uilibGl.Flex) `
5113
- flex-direction: column;
5114
- justify-content: center;
5115
- align-items: center;
5116
- margin-top: 2rem;
5117
-
5070
+ const LayersListWrapper = styled(uilibGl.Flex) `
5071
+ flex-direction: column;
5072
+ height: 100%;
5073
+ width: 100%;
5074
+ box-sizing: border-box;
5075
+ `;
5076
+ const LayerListContainer = styled(uilibGl.Flex) `
5077
+ flex-grow: 1;
5078
+ height: 100%;
5079
+ box-sizing: border-box;
5080
+ `;
5081
+
5082
+ const ElementValueWrapper = styled.div `
5083
+ transition: background-color ${uilibGl.transition.toggle};
5084
+ `;
5085
+ const ContainerWrapper = styled(uilibGl.Flex) `
5086
+ position: relative;
5087
+ min-height: 1rem;
5088
+ box-sizing: border-box;
5089
+ width: 100%;
5090
+ background: ${({ theme: { palette } }) => palette.backgroundAlpha};
5091
+ box-shadow: rgb(0 0 0 / 15%) 0 0.1875rem 0.625rem;
5092
+ padding: 1.5rem;
5093
+ border-radius: 0.5rem;
5094
+ backdrop-filter: blur(20px);
5095
+ color: ${({ theme: { palette } }) => palette.textPrimary};
5096
+ z-index: ${({ $zIndex }) => $zIndex ?? 1};
5097
+ transition: background-color ${uilibGl.transition.toggle};
5098
+
5099
+ ${Container} > ${ElementValueWrapper}:not(:last-child) {
5100
+ margin-bottom: 1.5rem;
5101
+ }
5102
+ `;
5103
+ const DashboardChip = styled(uilibGl.Chip) `
5104
+ margin: 0 0.25rem 0.25rem 0;
5105
+ background: ${({ $isDefault, $bgColor, theme: { palette } }) => $isDefault ? palette.element : $bgColor || palette.primary};
5106
+ border-radius: ${({ $radius, theme: { borderRadius } }) => $radius || borderRadius.medium};
5107
+ font-size: ${({ $fontSize }) => $fontSize || "0.875rem"};
5108
+ color: ${({ $isDefault, $fontColor, theme: { palette } }) => $isDefault ? palette.textPrimary : $fontColor || "#fff"};
5109
+
5110
+ > * {
5111
+ font-size: ${({ $fontSize }) => $fontSize || "0.875rem"};
5112
+ color: ${({ $isDefault, $fontColor, theme: { palette } }) => $isDefault ? palette.textPrimary : $fontColor || "#fff"};
5113
+ }
5114
+
5115
+ span[kind]:after {
5116
+ color: ${({ $isDefault, $fontColor, theme: { palette } }) => ($isDefault ? palette.icon : $fontColor || "#fff")};
5117
+ }
5118
+ `;
5119
+ const DashboardPlaceholderWrap = styled(uilibGl.Flex) `
5120
+ flex-grow: 1;
5121
+ flex-direction: column;
5122
+ justify-content: center;
5123
+ align-items: center;
5124
+ width: 100%;
5125
+ margin-bottom: 2rem;
5126
+ `;
5127
+ const DashboardPlaceholder = styled(uilibGl.Flex) `
5128
+ flex-direction: column;
5129
+ justify-content: center;
5130
+ align-items: center;
5131
+ margin-top: 2rem;
5132
+
5118
5133
  ${({ isLoading }) => isLoading &&
5119
- styled.css `
5120
- width: 6.25rem;
5121
- `}
5122
- &&& > * {
5123
- margin-bottom: 0;
5124
- }
5125
-
5126
- > div {
5127
- width: 100%;
5128
- margin-top: 1rem;
5129
- font-size: 0.75rem;
5130
- text-align: center;
5131
- color: ${({ theme: { palette } }) => palette.textDisabled};
5132
- }
5133
-
5134
- span[kind] {
5135
- width: 2.25rem;
5136
- height: 2.25rem;
5137
- opacity: 0.28;
5138
-
5139
- :after {
5140
- font-size: 32px;
5141
- }
5142
- }
5143
- `;
5144
- const DashboardWrapper = styled(uilibGl.Flex) `
5145
- flex-direction: column;
5146
- flex-wrap: nowrap;
5147
- flex-grow: 1;
5148
- width: calc(100% - 3rem);
5149
- height: calc(100% - ${LEFT_PANEL_HEADER_HEIGHT});
5150
-
5151
- > ${ContainerWrapper} {
5152
- > * {
5153
- margin-bottom: 2rem;
5154
- }
5155
- }
5156
-
5134
+ styled.css `
5135
+ width: 6.25rem;
5136
+ `}
5137
+ &&& > * {
5138
+ margin-bottom: 0;
5139
+ }
5140
+
5141
+ > div {
5142
+ width: 100%;
5143
+ margin-top: 1rem;
5144
+ font-size: 0.75rem;
5145
+ text-align: center;
5146
+ color: ${({ theme: { palette } }) => palette.textDisabled};
5147
+ }
5148
+
5149
+ span[kind] {
5150
+ width: 2.25rem;
5151
+ height: 2.25rem;
5152
+ opacity: 0.28;
5153
+
5154
+ :after {
5155
+ font-size: 32px;
5156
+ }
5157
+ }
5158
+ `;
5159
+ const DashboardWrapper = styled(uilibGl.Flex) `
5160
+ flex-direction: column;
5161
+ flex-wrap: nowrap;
5162
+ flex-grow: 1;
5163
+ width: calc(100% - 3rem);
5164
+ height: calc(100% - ${LEFT_PANEL_HEADER_HEIGHT});
5165
+
5166
+ > ${ContainerWrapper} {
5167
+ > * {
5168
+ margin-bottom: 2rem;
5169
+ }
5170
+ }
5171
+
5157
5172
  ${({ hasImage, isPresentationMode }) => hasImage &&
5158
5173
  !isPresentationMode &&
5159
- styled.css `
5160
- margin-top: -0.35rem;
5161
- `}
5162
- `;
5163
- const DashboardContent = styled(uilibGl.Flex) `
5164
- flex-grow: 1;
5165
- width: 100%;
5166
- padding: 1.5rem 1.5rem 2rem;
5167
- overflow-y: auto;
5168
- scrollbar-gutter: stable;
5169
- `;
5170
- const PresentationWrapperCss = styled.css `
5171
- margin-bottom: 0.75rem;
5172
- padding: 1.5rem;
5173
- background-color: ${({ theme: { palette } }) => palette.panelBackground};
5174
- backdrop-filter: blur(10px);
5175
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
5176
- box-shadow: ${uilibGl.shadows.raised};
5177
- `;
5178
- const PresentationWrapper = styled.div `
5179
- ${PresentationWrapperCss};
5180
- position: relative;
5181
- z-index: 1;
5182
- `;
5183
- const PresentationPanelWrapper = styled(PresentationWrapper) `
5184
- margin-top: 0.75rem;
5185
- transition: background-color ${uilibGl.transition.toggle};
5186
- `;
5187
- const PresentationHeader = styled.div `
5188
- margin: -1.5rem -1.5rem 0 -1.5rem;
5189
- padding: 1.5rem;
5190
- // background: url(images.presentationHeader) 0 0 no-repeat;
5191
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
5192
- transition: background-color ${uilibGl.transition.toggle};
5193
-
5174
+ styled.css `
5175
+ margin-top: -0.35rem;
5176
+ `}
5177
+ `;
5178
+ const DashboardContent = styled(uilibGl.Flex) `
5179
+ flex-grow: 1;
5180
+ width: 100%;
5181
+ padding: 1.5rem 1.5rem 2rem;
5182
+ overflow-y: auto;
5183
+ scrollbar-gutter: stable;
5184
+ `;
5185
+ const PresentationWrapperCss = styled.css `
5186
+ margin-bottom: 0.75rem;
5187
+ padding: 1.5rem;
5188
+ background-color: ${({ theme: { palette } }) => palette.panelBackground};
5189
+ backdrop-filter: blur(10px);
5190
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
5191
+ box-shadow: ${uilibGl.shadows.raised};
5192
+ `;
5193
+ const PresentationWrapper = styled.div `
5194
+ ${PresentationWrapperCss};
5195
+ position: relative;
5196
+ z-index: 1;
5197
+ `;
5198
+ const PresentationPanelWrapper = styled(PresentationWrapper) `
5199
+ margin-top: 0.75rem;
5200
+ transition: background-color ${uilibGl.transition.toggle};
5201
+ `;
5202
+ const PresentationHeader = styled.div `
5203
+ margin: -1.5rem -1.5rem 0 -1.5rem;
5204
+ padding: 1.5rem;
5205
+ // background: url(images.presentationHeader) 0 0 no-repeat;
5206
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
5207
+ transition: background-color ${uilibGl.transition.toggle};
5208
+
5194
5209
  ${({ image }) => !!image &&
5195
- styled.css `
5196
- padding-top: 7rem;
5197
- `};
5198
- `;
5199
- const PresentationHeaderTools = styled(uilibGl.Flex) `
5200
- justify-content: space-between;
5201
- align-items: center;
5202
- margin-bottom: -0.5rem;
5203
- margin-right: -0.5rem;
5204
-
5205
- span[kind="sun"],
5206
- span[kind="moon"] {
5207
- :after {
5208
- font-size: 0.85rem;
5209
- color: ${({ theme: { palette } }) => palette.iconDisabled};
5210
- }
5211
-
5212
- :hover:after {
5213
- color: ${({ theme: { palette } }) => palette.icon};
5214
- }
5215
- }
5216
- `;
5217
- const LayerGroupList = styled(uilibGl.Flex) `
5218
- flex-direction: column;
5219
- height: 100%;
5220
- flex-wrap: nowrap;
5221
- overflow-x: ${({ $noScroll }) => ($noScroll ? "visible" : "hidden")};
5222
- overflow-y: ${({ $noScroll }) => ($noScroll ? "visible" : "auto")};
5223
- padding: 0 0.125rem 0 0.75rem;
5224
- scrollbar-gutter: stable;
5225
-
5226
- > * {
5227
- flex-grow: 1;
5228
- }
5210
+ styled.css `
5211
+ padding-top: 7rem;
5212
+ `};
5213
+ `;
5214
+ const PresentationHeaderTools = styled(uilibGl.Flex) `
5215
+ justify-content: space-between;
5216
+ align-items: center;
5217
+ margin-bottom: -0.5rem;
5218
+ margin-right: -0.5rem;
5219
+
5220
+ span[kind="sun"],
5221
+ span[kind="moon"] {
5222
+ :after {
5223
+ font-size: 0.85rem;
5224
+ color: ${({ theme: { palette } }) => palette.iconDisabled};
5225
+ }
5226
+
5227
+ :hover:after {
5228
+ color: ${({ theme: { palette } }) => palette.icon};
5229
+ }
5230
+ }
5231
+ `;
5232
+ const LayerGroupList = styled(uilibGl.Flex) `
5233
+ flex-direction: column;
5234
+ height: 100%;
5235
+ flex-wrap: nowrap;
5236
+ overflow-x: ${({ $noScroll }) => ($noScroll ? "visible" : "hidden")};
5237
+ overflow-y: ${({ $noScroll }) => ($noScroll ? "visible" : "auto")};
5238
+ padding: 0 0.125rem 0 0.75rem;
5239
+ scrollbar-gutter: stable;
5240
+
5241
+ > * {
5242
+ flex-grow: 1;
5243
+ }
5229
5244
  `;
5230
5245
  const PresentationHeaderButtons = styled(uilibGl.Flex) ``;
5231
- const PresentationPanelContainer = styled.div `
5232
- position: absolute;
5233
- top: 0;
5234
- left: calc(${({ left }) => left || 0}px + 0.75rem);
5235
- bottom: 0;
5236
- z-index: 3;
5237
- display: flex;
5238
- flex-direction: column;
5239
- width: ${LEFT_PANEL_HEADER_HEIGHT}px;
5240
- padding-right: 0.5rem;
5241
- scrollbar-gutter: stable;
5242
- overflow-y: hidden;
5243
-
5244
- :hover {
5245
- overflow-y: auto;
5246
- }
5247
-
5246
+ const PresentationPanelContainer = styled.div `
5247
+ position: absolute;
5248
+ top: 0;
5249
+ left: calc(${({ left }) => left || 0}px + 0.75rem);
5250
+ bottom: 0;
5251
+ z-index: 3;
5252
+ display: flex;
5253
+ flex-direction: column;
5254
+ width: ${LEFT_PANEL_HEADER_HEIGHT}px;
5255
+ padding-right: 0.5rem;
5256
+ scrollbar-gutter: stable;
5257
+ overflow-y: hidden;
5258
+
5259
+ :hover {
5260
+ overflow-y: auto;
5261
+ }
5262
+
5248
5263
  ${({ showLayers }) => !showLayers &&
5249
- styled.css `
5250
- > :first-child {
5251
- padding-bottom: 0;
5252
- }
5253
- `};
5254
-
5255
- ${PresentationHeader} > * {
5256
- position: relative;
5257
- z-index: 2;
5258
- }
5259
-
5260
- /* PaginationWrapper {
5261
- ${PresentationWrapperCss};
5262
- width: calc(100% - 2rem);
5263
- min-height: 8.625rem;
5264
- padding-top: 0.5rem;
5265
- padding-bottom: 0.5rem;
5266
- margin-bottom: 0.75rem;
5267
- }*/
5268
-
5269
- ${DashboardWrapper} {
5270
- width: 100%;
5271
- margin-top: 0;
5272
-
5273
- ${DashboardContent} {
5274
- padding: 0;
5275
- overflow-y: unset;
5276
-
5277
- > * > ${ContainerWrapper} > * > ${ContainerWrapper} {
5278
- ${PresentationWrapperCss};
5279
- width: calc(100% - 3rem);
5280
- }
5281
- }
5282
- }
5283
-
5284
- ${DashboardPlaceholder} {
5285
- ${PresentationWrapperCss};
5286
- width: 18.5rem;
5287
- height: 10.75rem;
5288
- }
5289
-
5290
- ${LayerListContainer} {
5291
- height: auto;
5292
- margin: 0 -1.125rem -1.5rem;
5293
- padding: 0;
5294
-
5295
- ${LayerGroupList} {
5296
- padding: 0;
5297
- }
5298
- }
5299
- `;
5300
- const DataSourceErrorContainer = styled(uilibGl.Flex) `
5301
- align-items: center;
5302
- justify-content: center;
5303
- flex-wrap: nowrap;
5304
- flex-grow: 1;
5305
- padding: 1rem;
5306
- border: 1px ${({ theme: { palette } }) => palette.element} solid;
5307
- border-radius: 10px;
5308
- font-size: 0.875rem;
5309
- color: ${({ theme: { palette } }) => palette.textDisabled};
5310
-
5311
- span[kind] {
5312
- margin-right: 1rem;
5313
-
5314
- :after {
5315
- color: ${({ theme: { palette } }) => palette.iconDisabled};
5316
- }
5317
- }
5318
- `;
5319
- const AttributeLabel = styled(uilibGl.Description) `
5320
- margin-top: 0 !important;
5321
- margin-bottom: ${({ forCheckbox }) => (forCheckbox ? "0.75rem" : "0.25rem")} !important;
5322
- padding-left: ${({ isEdit }) => (isEdit ? "0.5rem" : "0")};
5323
- `;
5324
- const FeatureControls = styled(uilibGl.Flex) `
5325
- align-items: center;
5326
- gap: 1rem;
5327
- flex-wrap: nowrap;
5328
- position: relative;
5329
- flex-shrink: 0;
5330
-
5331
- button {
5332
- padding: 0;
5333
- width: auto;
5334
- }
5264
+ styled.css `
5265
+ > :first-child {
5266
+ padding-bottom: 0;
5267
+ }
5268
+ `};
5269
+
5270
+ ${PresentationHeader} > * {
5271
+ position: relative;
5272
+ z-index: 2;
5273
+ }
5274
+
5275
+ /* PaginationWrapper {
5276
+ ${PresentationWrapperCss};
5277
+ width: calc(100% - 2rem);
5278
+ min-height: 8.625rem;
5279
+ padding-top: 0.5rem;
5280
+ padding-bottom: 0.5rem;
5281
+ margin-bottom: 0.75rem;
5282
+ }*/
5283
+
5284
+ ${DashboardWrapper} {
5285
+ width: 100%;
5286
+ margin-top: 0;
5287
+
5288
+ ${DashboardContent} {
5289
+ padding: 0;
5290
+ overflow-y: unset;
5291
+
5292
+ > * > ${ContainerWrapper} > * > ${ContainerWrapper} {
5293
+ ${PresentationWrapperCss};
5294
+ width: calc(100% - 3rem);
5295
+ }
5296
+ }
5297
+ }
5298
+
5299
+ ${DashboardPlaceholder} {
5300
+ ${PresentationWrapperCss};
5301
+ width: 18.5rem;
5302
+ height: 10.75rem;
5303
+ }
5304
+
5305
+ ${LayerListContainer} {
5306
+ height: auto;
5307
+ margin: 0 -1.125rem -1.5rem;
5308
+ padding: 0;
5309
+
5310
+ ${LayerGroupList} {
5311
+ padding: 0;
5312
+ }
5313
+ }
5314
+ `;
5315
+ const DataSourceErrorContainer = styled(uilibGl.Flex) `
5316
+ align-items: center;
5317
+ justify-content: center;
5318
+ flex-wrap: nowrap;
5319
+ flex-grow: 1;
5320
+ padding: 1rem;
5321
+ border: 1px ${({ theme: { palette } }) => palette.element} solid;
5322
+ border-radius: 10px;
5323
+ font-size: 0.875rem;
5324
+ color: ${({ theme: { palette } }) => palette.textDisabled};
5325
+
5326
+ span[kind] {
5327
+ margin-right: 1rem;
5328
+
5329
+ :after {
5330
+ color: ${({ theme: { palette } }) => palette.iconDisabled};
5331
+ }
5332
+ }
5333
+ `;
5334
+ const AttributeLabel = styled(uilibGl.Description) `
5335
+ margin-top: 0 !important;
5336
+ margin-bottom: ${({ forCheckbox }) => (forCheckbox ? "0.75rem" : "0.25rem")} !important;
5337
+ padding-left: ${({ isEdit }) => (isEdit ? "0.5rem" : "0")};
5338
+ `;
5339
+ const FeatureControls = styled(uilibGl.Flex) `
5340
+ align-items: center;
5341
+ gap: 1rem;
5342
+ flex-wrap: nowrap;
5343
+ position: relative;
5344
+ flex-shrink: 0;
5345
+
5346
+ button {
5347
+ padding: 0;
5348
+ width: auto;
5349
+ }
5335
5350
  `;
5336
5351
 
5337
5352
  const getAttributeByName = (attributeName, attributes) => {
@@ -5461,10 +5476,10 @@ const TwoColumnContainer = React.memo(({ config, elementConfig, type, renderElem
5461
5476
  return renderAttributes?.length ? (jsxRuntime.jsx(jsxRuntime.Fragment, { children: renderAttributes.map(attribute => renderContainer(elementConfig, attribute)) })) : (renderContainer(elementConfig));
5462
5477
  });
5463
5478
 
5464
- const InnerContainerWrapper = styled.div `
5465
- cursor: ${({ onClick }) => (onClick ? "pointer" : "default")};
5466
- width: ${({ column }) => (column ? "100%" : "auto")};
5467
- opacity: ${({ hasAnyFilter, isFiltered }) => (isFiltered ? 1 : hasAnyFilter ? FILTERED_VALUE_OPACITY / 100 : 1)};
5479
+ const InnerContainerWrapper = styled.div `
5480
+ cursor: ${({ onClick }) => (onClick ? "pointer" : "default")};
5481
+ width: ${({ column }) => (column ? "100%" : "auto")};
5482
+ opacity: ${({ hasAnyFilter, isFiltered }) => (isFiltered ? 1 : hasAnyFilter ? FILTERED_VALUE_OPACITY / 100 : 1)};
5468
5483
  `;
5469
5484
 
5470
5485
  const DataSourceInnerContainer = React.memo(({ config, elementConfig, feature, maxValue, type, index, innerComponent }) => {
@@ -5535,107 +5550,107 @@ const DataSourceInnerContainer = React.memo(({ config, elementConfig, feature, m
5535
5550
  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 }) }));
5536
5551
  });
5537
5552
 
5538
- const DataSourceProgressContainerWrapper = styled.div `
5539
- width: 100%;
5540
- `;
5541
- const ContainerToggler = styled(uilibGl.LegendToggler) `
5542
- width: auto;
5543
- margin-left: -1rem;
5544
- `;
5545
-
5546
- const ProgressContainerWrapper = styled(uilibGl.Flex) `
5547
- align-items: center;
5548
- width: 100%;
5549
- margin-bottom: 1rem;
5550
- `;
5551
- const ProgressIcon = styled.div `
5552
- margin-right: 0.5rem;
5553
- `;
5554
- const ProgressContent = styled(uilibGl.Flex) `
5555
- flex: 1;
5556
- flex-direction: column;
5557
- `;
5558
- const ProgressAlias = styled(uilibGl.Flex) `
5559
- flex: 1;
5560
- justify-content: space-between;
5561
- margin-bottom: 0.25rem;
5562
- font-size: 0.75rem;
5563
- color: ${({ theme: { palette } }) => palette.textSecondary};
5564
- `;
5565
- const ProgressValue = styled(uilibGl.Flex) `
5566
- align-items: center;
5567
- width: auto;
5568
- font-size: 1rem;
5569
- color: ${({ theme: { palette } }) => palette.textPrimary};
5570
- `;
5571
- const ProgressInnerValue = styled(ProgressValue) `
5572
- justify-content: flex-end;
5573
- width: 4rem;
5574
- margin-left: 0.5rem;
5575
- `;
5576
- const ProgressUnits = styled(uilibGl.Flex) `
5577
- margin-left: 0.25rem;
5578
- font-size: 0.75rem;
5579
- color: ${({ theme: { palette } }) => palette.textSecondary};
5580
- `;
5581
- const ProgressBarWrapper = styled.div `
5582
- flex-grow: 1;
5583
- height: 0.5rem;
5584
- background-color: ${({ theme: { palette } }) => palette.element};
5585
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.xSmall};
5586
- `;
5587
- const ProgressBarContainer = styled(uilibGl.Flex) `
5588
- position: relative;
5589
- align-items: center;
5590
- width: 100%;
5591
-
5553
+ const DataSourceProgressContainerWrapper = styled.div `
5554
+ width: 100%;
5555
+ `;
5556
+ const ContainerToggler = styled(uilibGl.LegendToggler) `
5557
+ width: auto;
5558
+ margin-left: -1rem;
5559
+ `;
5560
+
5561
+ const ProgressContainerWrapper = styled(uilibGl.Flex) `
5562
+ align-items: center;
5563
+ width: 100%;
5564
+ margin-bottom: 1rem;
5565
+ `;
5566
+ const ProgressIcon = styled.div `
5567
+ margin-right: 0.5rem;
5568
+ `;
5569
+ const ProgressContent = styled(uilibGl.Flex) `
5570
+ flex: 1;
5571
+ flex-direction: column;
5572
+ `;
5573
+ const ProgressAlias = styled(uilibGl.Flex) `
5574
+ flex: 1;
5575
+ justify-content: space-between;
5576
+ margin-bottom: 0.25rem;
5577
+ font-size: 0.75rem;
5578
+ color: ${({ theme: { palette } }) => palette.textSecondary};
5579
+ `;
5580
+ const ProgressValue = styled(uilibGl.Flex) `
5581
+ align-items: center;
5582
+ width: auto;
5583
+ font-size: 1rem;
5584
+ color: ${({ theme: { palette } }) => palette.textPrimary};
5585
+ `;
5586
+ const ProgressInnerValue = styled(ProgressValue) `
5587
+ justify-content: flex-end;
5588
+ width: 4rem;
5589
+ margin-left: 0.5rem;
5590
+ `;
5591
+ const ProgressUnits = styled(uilibGl.Flex) `
5592
+ margin-left: 0.25rem;
5593
+ font-size: 0.75rem;
5594
+ color: ${({ theme: { palette } }) => palette.textSecondary};
5595
+ `;
5596
+ const ProgressBarWrapper = styled.div `
5597
+ flex-grow: 1;
5598
+ height: 0.5rem;
5599
+ background-color: ${({ theme: { palette } }) => palette.element};
5600
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.xSmall};
5601
+ `;
5602
+ const ProgressBarContainer = styled(uilibGl.Flex) `
5603
+ position: relative;
5604
+ align-items: center;
5605
+ width: 100%;
5606
+
5592
5607
  ${({ innerValue }) => innerValue &&
5593
- styled.css `
5594
- ${ProgressBarWrapper} {
5595
- height: 1.125rem;
5596
- }
5597
-
5598
- ${ProgressInnerValue} {
5599
- z-index: 1;
5600
- position: absolute;
5601
- right: 0.25rem;
5602
- }
5603
- `}
5604
- `;
5605
- const ProgressBar = styled.div `
5606
- width: ${({ $width }) => $width};
5607
- height: inherit;
5608
- background-color: ${({ $color }) => $color || "#a7d759"};
5609
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.xSmall};
5610
- `;
5611
- const ProgressTooltipAlias = styled.div `
5612
- margin-bottom: 0.25rem;
5613
- text-align: left;
5614
- color: ${({ theme: { palette } }) => palette.primary};
5608
+ styled.css `
5609
+ ${ProgressBarWrapper} {
5610
+ height: 1.125rem;
5611
+ }
5612
+
5613
+ ${ProgressInnerValue} {
5614
+ z-index: 1;
5615
+ position: absolute;
5616
+ right: 0.25rem;
5617
+ }
5618
+ `}
5619
+ `;
5620
+ const ProgressBar = styled.div `
5621
+ width: ${({ $width }) => $width};
5622
+ height: inherit;
5623
+ background-color: ${({ $color }) => $color || "#a7d759"};
5624
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.xSmall};
5625
+ `;
5626
+ const ProgressTooltipAlias = styled.div `
5627
+ margin-bottom: 0.25rem;
5628
+ text-align: left;
5629
+ color: ${({ theme: { palette } }) => palette.primary};
5615
5630
  `;
5616
5631
  const ProgressTooltipValue = styled.div ``;
5617
- const ProgressTooltipValueContainer = styled(uilibGl.Flex) `
5618
- align-items: center;
5619
-
5620
- > * {
5621
- opacity: 0.65;
5622
- }
5623
-
5624
- ${ProgressTooltipValue} {
5625
- opacity: 1;
5626
- }
5627
- `;
5628
- const ProgressTooltipValueOf = styled.div `
5629
- margin: 0 0.25rem;
5630
- `;
5631
- const ProgressTotalTitle = styled.div `
5632
- font-size: 0.75rem;
5633
- font-weight: bold;
5634
- `;
5635
- const ProgressTotal = styled(uilibGl.Flex) `
5636
- align-items: center;
5637
- justify-content: space-between;
5638
- margin-top: 1rem;
5632
+ const ProgressTooltipValueContainer = styled(uilibGl.Flex) `
5633
+ align-items: center;
5634
+
5635
+ > * {
5636
+ opacity: 0.65;
5637
+ }
5638
+
5639
+ ${ProgressTooltipValue} {
5640
+ opacity: 1;
5641
+ }
5642
+ `;
5643
+ const ProgressTooltipValueOf = styled.div `
5644
+ margin: 0 0.25rem;
5645
+ `;
5646
+ const ProgressTotalTitle = styled.div `
5647
+ font-size: 0.75rem;
5648
+ font-weight: bold;
5649
+ `;
5650
+ const ProgressTotal = styled(uilibGl.Flex) `
5651
+ align-items: center;
5652
+ justify-content: space-between;
5653
+ margin-top: 1rem;
5639
5654
  `;
5640
5655
 
5641
5656
  const DataSourceProgressContainer = React.memo(({ config, elementConfig, type, innerComponent, renderElement }) => {
@@ -5732,166 +5747,166 @@ const DEFAULT_BAR_CHART_MARGINS = {
5732
5747
  right: 0,
5733
5748
  };
5734
5749
 
5735
- const FiltersContainerWrapper = styled(uilibGl.Flex) `
5736
- flex-direction: column;
5737
- padding: ${({ $padding }) => $padding ?? "0.75rem"};
5738
- background-color: ${({ $bgColor, $fontColor, theme: { palette } }) => $bgColor || ($fontColor ? transparentizeColor($fontColor, 6) : palette.element)};
5739
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
5740
-
5741
- ${uilibGl.DropdownField}, input {
5742
- background-color: ${({ theme: { palette } }) => palette.background};
5743
- }
5744
-
5745
- > div:not(:last-child) {
5746
- margin-bottom: 0.5rem;
5747
- }
5748
-
5749
- > label {
5750
- align-items: flex-start;
5751
- font-size: ${({ $fontSize }) => $fontSize || "0.875rem"};
5752
-
5753
- &.active {
5754
- color: ${({ $fontColor }) => $fontColor};
5755
-
5756
- svg rect {
5757
- fill: ${({ $fontColor }) => $fontColor} !important;
5758
- }
5759
- }
5760
-
5761
- &:not(:last-child) {
5762
- margin-bottom: 0.75rem;
5763
- }
5764
-
5765
- &:last-child {
5766
- margin-bottom: 0;
5767
- }
5768
- }
5769
- `;
5770
- const StyledIconButton = styled(uilibGl.IconButton) `
5771
- width: 0.75rem;
5772
- height: 0.75rem;
5773
-
5774
- span[kind] {
5775
- height: 0.75rem;
5776
-
5777
- :after {
5778
- font-size: 0.75rem;
5779
- }
5780
- }
5781
- `;
5782
- const TextFilterContainer = styled.div `
5783
- width: 15.85rem;
5784
-
5785
- ${uilibGl.MultiSelectContainer} {
5786
- color: ${({ theme: { palette } }) => palette.textPrimary};
5787
-
5788
- ${uilibGl.IconButtonButton} {
5789
- span[kind]:after {
5790
- color: ${({ theme: { palette } }) => palette.textPrimary};
5791
- }
5792
- }
5793
- }
5794
- `;
5795
- const BarChartContainer = styled.div `
5796
- width: 100%;
5797
- overflow-x: hidden;
5798
-
5750
+ const FiltersContainerWrapper = styled(uilibGl.Flex) `
5751
+ flex-direction: column;
5752
+ padding: ${({ $padding }) => $padding ?? "0.75rem"};
5753
+ background-color: ${({ $bgColor, $fontColor, theme: { palette } }) => $bgColor || ($fontColor ? transparentizeColor($fontColor, 6) : palette.element)};
5754
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
5755
+
5756
+ ${uilibGl.DropdownField}, input {
5757
+ background-color: ${({ theme: { palette } }) => palette.background};
5758
+ }
5759
+
5760
+ > div:not(:last-child) {
5761
+ margin-bottom: 0.5rem;
5762
+ }
5763
+
5764
+ > label {
5765
+ align-items: flex-start;
5766
+ font-size: ${({ $fontSize }) => $fontSize || "0.875rem"};
5767
+
5768
+ &.active {
5769
+ color: ${({ $fontColor }) => $fontColor};
5770
+
5771
+ svg rect {
5772
+ fill: ${({ $fontColor }) => $fontColor} !important;
5773
+ }
5774
+ }
5775
+
5776
+ &:not(:last-child) {
5777
+ margin-bottom: 0.75rem;
5778
+ }
5779
+
5780
+ &:last-child {
5781
+ margin-bottom: 0;
5782
+ }
5783
+ }
5784
+ `;
5785
+ const StyledIconButton = styled(uilibGl.IconButton) `
5786
+ width: 0.75rem;
5787
+ height: 0.75rem;
5788
+
5789
+ span[kind] {
5790
+ height: 0.75rem;
5791
+
5792
+ :after {
5793
+ font-size: 0.75rem;
5794
+ }
5795
+ }
5796
+ `;
5797
+ const TextFilterContainer = styled.div `
5798
+ width: 15.85rem;
5799
+
5800
+ ${uilibGl.MultiSelectContainer} {
5801
+ color: ${({ theme: { palette } }) => palette.textPrimary};
5802
+
5803
+ ${uilibGl.IconButtonButton} {
5804
+ span[kind]:after {
5805
+ color: ${({ theme: { palette } }) => palette.textPrimary};
5806
+ }
5807
+ }
5808
+ }
5809
+ `;
5810
+ const BarChartContainer = styled.div `
5811
+ width: 100%;
5812
+ overflow-x: hidden;
5813
+
5799
5814
  ${({ barHeight, marginBottom }) => !!barHeight &&
5800
- styled.css `
5801
- .barChartBarGlobal rect {
5802
- height: ${barHeight}px;
5803
- y: calc(100% - ${barHeight + marginBottom}px);
5804
- }
5805
- `}
5806
- `;
5807
- const AnyChartWrapper = styled.div `
5808
- width: 100%;
5809
- height: ${({ height }) => height}px;
5810
- `;
5811
- const BarChartWrapper = styled(AnyChartWrapper) `
5812
- width: 100%;
5813
- margin: 0 auto ${BAR_CHART_FOOTER_MARGIN}px;
5814
-
5815
- :hover {
5816
- ${BarChartContainer} {
5817
- overflow-x: auto;
5818
- }
5819
- }
5820
- `;
5821
- const BarChartFilterHeader = styled(uilibGl.Flex) `
5822
- justify-content: space-between;
5823
- align-items: center;
5824
- height: ${({ height }) => `calc(${typeof height === "number" ? `${height}px` : height} - 0.5rem)`};
5825
- padding: 0.25rem 0;
5826
- `;
5827
- const BarChartFilterArrows = styled(uilibGl.Flex) `
5828
- margin-left: -0.5rem;
5829
-
5830
- span[kind] {
5831
- display: flex;
5832
- align-items: center;
5833
-
5834
- :after {
5835
- font-size: 0.75rem;
5836
- }
5837
- }
5838
- `;
5839
- const BarChartFilterSelected = styled.div `
5840
- font-size: 0.75rem;
5841
- font-weight: bold;
5842
- color: ${({ theme: { palette } }) => palette.textPrimary};
5843
- `;
5844
- styled.div `
5845
- color: ${({ theme: { palette } }) => palette.textSecondary};
5846
- `;
5847
- const BarChart = styled(charts.BarChart) `
5848
- .${charts.barChartClassNames.barChartXAxis} {
5849
- .domain,
5850
- line {
5851
- display: none;
5852
- }
5853
-
5854
- .tick {
5855
- text {
5856
- text-anchor: start;
5857
- font-size: 12px;
5858
- color: rgba(48, 69, 79, 0.46);
5859
- }
5860
-
5861
- :last-of-type {
5862
- text {
5863
- text-anchor: end;
5864
- }
5865
- }
5866
- }
5867
- }
5868
-
5869
- .marker {
5870
- font-size: 12px;
5871
- }
5872
- `;
5873
- const TooltipContainer = styled.div `
5874
- position: relative;
5875
- font-size: 0.75rem;
5876
- color: #ffffff;
5877
- margin-bottom: 0.5rem;
5878
- padding: 0.375rem;
5879
- background-color: rgba(0, 0, 0, 1);
5880
- border-radius: 0.25rem;
5881
- box-shadow: 0 0.1875rem 0.5rem rgba(48, 69, 79, 0.06);
5882
-
5883
- :before {
5884
- content: "";
5885
- position: absolute;
5886
- bottom: 0;
5887
- left: 50%;
5888
- transform: translate(-50%, 100%);
5889
- width: 0;
5890
- height: 0;
5891
- border-style: solid;
5892
- border-width: 0.25rem 0.1875rem 0 0.1875rem;
5893
- border-color: rgba(48, 69, 79, 1) transparent transparent transparent;
5894
- }
5815
+ styled.css `
5816
+ .barChartBarGlobal rect {
5817
+ height: ${barHeight}px;
5818
+ y: calc(100% - ${barHeight + marginBottom}px);
5819
+ }
5820
+ `}
5821
+ `;
5822
+ const AnyChartWrapper = styled.div `
5823
+ width: 100%;
5824
+ height: ${({ height }) => height}px;
5825
+ `;
5826
+ const BarChartWrapper = styled(AnyChartWrapper) `
5827
+ width: 100%;
5828
+ margin: 0 auto ${BAR_CHART_FOOTER_MARGIN}px;
5829
+
5830
+ :hover {
5831
+ ${BarChartContainer} {
5832
+ overflow-x: auto;
5833
+ }
5834
+ }
5835
+ `;
5836
+ const BarChartFilterHeader = styled(uilibGl.Flex) `
5837
+ justify-content: space-between;
5838
+ align-items: center;
5839
+ height: ${({ height }) => `calc(${typeof height === "number" ? `${height}px` : height} - 0.5rem)`};
5840
+ padding: 0.25rem 0;
5841
+ `;
5842
+ const BarChartFilterArrows = styled(uilibGl.Flex) `
5843
+ margin-left: -0.5rem;
5844
+
5845
+ span[kind] {
5846
+ display: flex;
5847
+ align-items: center;
5848
+
5849
+ :after {
5850
+ font-size: 0.75rem;
5851
+ }
5852
+ }
5853
+ `;
5854
+ const BarChartFilterSelected = styled.div `
5855
+ font-size: 0.75rem;
5856
+ font-weight: bold;
5857
+ color: ${({ theme: { palette } }) => palette.textPrimary};
5858
+ `;
5859
+ styled.div `
5860
+ color: ${({ theme: { palette } }) => palette.textSecondary};
5861
+ `;
5862
+ const BarChart = styled(charts.BarChart) `
5863
+ .${charts.barChartClassNames.barChartXAxis} {
5864
+ .domain,
5865
+ line {
5866
+ display: none;
5867
+ }
5868
+
5869
+ .tick {
5870
+ text {
5871
+ text-anchor: start;
5872
+ font-size: 12px;
5873
+ color: rgba(48, 69, 79, 0.46);
5874
+ }
5875
+
5876
+ :last-of-type {
5877
+ text {
5878
+ text-anchor: end;
5879
+ }
5880
+ }
5881
+ }
5882
+ }
5883
+
5884
+ .marker {
5885
+ font-size: 12px;
5886
+ }
5887
+ `;
5888
+ const TooltipContainer = styled.div `
5889
+ position: relative;
5890
+ font-size: 0.75rem;
5891
+ color: #ffffff;
5892
+ margin-bottom: 0.5rem;
5893
+ padding: 0.375rem;
5894
+ background-color: rgba(0, 0, 0, 1);
5895
+ border-radius: 0.25rem;
5896
+ box-shadow: 0 0.1875rem 0.5rem rgba(48, 69, 79, 0.06);
5897
+
5898
+ :before {
5899
+ content: "";
5900
+ position: absolute;
5901
+ bottom: 0;
5902
+ left: 50%;
5903
+ transform: translate(-50%, 100%);
5904
+ width: 0;
5905
+ height: 0;
5906
+ border-style: solid;
5907
+ border-width: 0.25rem 0.1875rem 0 0.1875rem;
5908
+ border-color: rgba(48, 69, 79, 1) transparent transparent transparent;
5909
+ }
5895
5910
  `;
5896
5911
 
5897
5912
  const FiltersContainer = React.memo(({ elementConfig, config, type, renderElement }) => {
@@ -5971,64 +5986,64 @@ const TwoColumnsInnerContainer = React.memo(({ renderElement }) => {
5971
5986
  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" })] }));
5972
5987
  });
5973
5988
 
5974
- const ImageContainerBg$1 = styled.div `
5975
- position: absolute;
5976
- top: 0;
5977
- bottom: 0;
5978
- left: 0;
5979
- right: 0;
5980
-
5981
- img {
5982
- width: 100%;
5983
- height: 100%;
5984
- object-position: center;
5985
- object-fit: cover;
5986
- }
5987
- `;
5988
- const ImageContainerTitle = styled.div `
5989
- width: 100%;
5990
- overflow-wrap: break-word;
5991
- font-size: 1rem;
5992
- font-weight: 500;
5993
- `;
5994
- const ImageContainerText = styled.div `
5995
- width: 100%;
5996
- overflow-wrap: break-word;
5997
- margin-top: 0.5rem;
5998
- font-size: 0.75rem;
5999
- `;
6000
- const ImageContainerButton$1 = styled(uilibGl.FlatButton) `
6001
- min-height: 1.5rem;
6002
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.large};
6003
- background-color: ${({ theme: { palette } }) => palette.primary};
6004
- text-transform: none;
6005
-
6006
- :hover {
6007
- background-color: ${({ theme: { palette } }) => palette.primaryDeep};
6008
- }
6009
- `;
6010
- const ImageContainerWrapper = styled(uilibGl.Flex) `
6011
- flex-direction: column;
6012
- justify-content: flex-end;
6013
- position: relative;
6014
- padding: 1rem;
6015
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
6016
- overflow: hidden;
6017
-
6018
- ${ImageContainerTitle}, ${ImageContainerText}, ${ImageContainerButton$1} {
6019
- z-index: 1;
6020
- color: ${({ theme: { palette } }) => palette.textContrast};
6021
- }
6022
-
6023
- :after {
6024
- content: "";
6025
- position: absolute;
6026
- top: 0;
6027
- bottom: 0;
6028
- left: 0;
6029
- right: 0;
6030
- background-color: rgba(0, 0, 0, 0.4);
6031
- }
5989
+ const ImageContainerBg$1 = styled.div `
5990
+ position: absolute;
5991
+ top: 0;
5992
+ bottom: 0;
5993
+ left: 0;
5994
+ right: 0;
5995
+
5996
+ img {
5997
+ width: 100%;
5998
+ height: 100%;
5999
+ object-position: center;
6000
+ object-fit: cover;
6001
+ }
6002
+ `;
6003
+ const ImageContainerTitle = styled.div `
6004
+ width: 100%;
6005
+ overflow-wrap: break-word;
6006
+ font-size: 1rem;
6007
+ font-weight: 500;
6008
+ `;
6009
+ const ImageContainerText = styled.div `
6010
+ width: 100%;
6011
+ overflow-wrap: break-word;
6012
+ margin-top: 0.5rem;
6013
+ font-size: 0.75rem;
6014
+ `;
6015
+ const ImageContainerButton$1 = styled(uilibGl.FlatButton) `
6016
+ min-height: 1.5rem;
6017
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.large};
6018
+ background-color: ${({ theme: { palette } }) => palette.primary};
6019
+ text-transform: none;
6020
+
6021
+ :hover {
6022
+ background-color: ${({ theme: { palette } }) => palette.primaryDeep};
6023
+ }
6024
+ `;
6025
+ const ImageContainerWrapper = styled(uilibGl.Flex) `
6026
+ flex-direction: column;
6027
+ justify-content: flex-end;
6028
+ position: relative;
6029
+ padding: 1rem;
6030
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
6031
+ overflow: hidden;
6032
+
6033
+ ${ImageContainerTitle}, ${ImageContainerText}, ${ImageContainerButton$1} {
6034
+ z-index: 1;
6035
+ color: ${({ theme: { palette } }) => palette.textContrast};
6036
+ }
6037
+
6038
+ :after {
6039
+ content: "";
6040
+ position: absolute;
6041
+ top: 0;
6042
+ bottom: 0;
6043
+ left: 0;
6044
+ right: 0;
6045
+ background-color: rgba(0, 0, 0, 0.4);
6046
+ }
6032
6047
  `;
6033
6048
 
6034
6049
  const ImageContainer = React.memo(({ elementConfig, renderElement }) => {
@@ -6036,52 +6051,52 @@ const ImageContainer = React.memo(({ elementConfig, renderElement }) => {
6036
6051
  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" }) })] }));
6037
6052
  });
6038
6053
 
6039
- const IconContainerWrapper = styled(uilibGl.Flex) `
6040
- flex-direction: column;
6041
- justify-content: center;
6042
- position: relative;
6043
- padding: 0.5rem 1rem 1rem;
6044
- background-color: ${({ theme: { palette } }) => palette.element};
6045
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
6046
- overflow: hidden;
6047
- `;
6048
- const IconContainerHeaderWrapper = styled(uilibGl.Flex) `
6049
- justify-content: space-between;
6050
- align-items: center;
6051
- flex-wrap: nowrap;
6052
- width: 100%;
6053
- margin-bottom: 0.25rem;
6054
- `;
6055
- const IconContainerHeader = styled(uilibGl.Flex) `
6056
- align-items: center;
6057
- flex-wrap: nowrap;
6058
- width: 100%;
6059
- margin-right: 0.5rem;
6060
- font-size: 0.875rem;
6061
-
6062
- ${uilibGl.Icon} {
6063
- margin-right: 0.5rem;
6064
-
6065
- :after {
6066
- font-size: 1.15rem;
6067
- color: ${({ theme: { palette } }) => palette.textSecondary};
6068
- }
6069
- }
6070
- `;
6071
- const IconContainerTitle = styled(uilibGl.Flex) `
6072
- > * {
6073
- width: 13rem;
6074
- white-space: nowrap;
6075
- overflow: hidden;
6076
- font-weight: bold;
6077
- text-overflow: ellipsis;
6078
- }
6079
- `;
6080
- const IconContainerText = styled.div `
6081
- width: 100%;
6082
- overflow-wrap: break-word;
6083
- font-size: 0.75rem;
6084
- color: ${({ theme: { palette } }) => palette.textSecondary};
6054
+ const IconContainerWrapper = styled(uilibGl.Flex) `
6055
+ flex-direction: column;
6056
+ justify-content: center;
6057
+ position: relative;
6058
+ padding: 0.5rem 1rem 1rem;
6059
+ background-color: ${({ theme: { palette } }) => palette.element};
6060
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
6061
+ overflow: hidden;
6062
+ `;
6063
+ const IconContainerHeaderWrapper = styled(uilibGl.Flex) `
6064
+ justify-content: space-between;
6065
+ align-items: center;
6066
+ flex-wrap: nowrap;
6067
+ width: 100%;
6068
+ margin-bottom: 0.25rem;
6069
+ `;
6070
+ const IconContainerHeader = styled(uilibGl.Flex) `
6071
+ align-items: center;
6072
+ flex-wrap: nowrap;
6073
+ width: 100%;
6074
+ margin-right: 0.5rem;
6075
+ font-size: 0.875rem;
6076
+
6077
+ ${uilibGl.Icon} {
6078
+ margin-right: 0.5rem;
6079
+
6080
+ :after {
6081
+ font-size: 1.15rem;
6082
+ color: ${({ theme: { palette } }) => palette.textSecondary};
6083
+ }
6084
+ }
6085
+ `;
6086
+ const IconContainerTitle = styled(uilibGl.Flex) `
6087
+ > * {
6088
+ width: 13rem;
6089
+ white-space: nowrap;
6090
+ overflow: hidden;
6091
+ font-weight: bold;
6092
+ text-overflow: ellipsis;
6093
+ }
6094
+ `;
6095
+ const IconContainerText = styled.div `
6096
+ width: 100%;
6097
+ overflow-wrap: break-word;
6098
+ font-size: 0.75rem;
6099
+ color: ${({ theme: { palette } }) => palette.textSecondary};
6085
6100
  `;
6086
6101
 
6087
6102
  const IconContainer = React.memo(({ elementConfig, renderElement }) => {
@@ -6103,83 +6118,83 @@ const DataSourceContainer = React.memo(({ config, elementConfig, type, innerComp
6103
6118
  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, {}))] }));
6104
6119
  });
6105
6120
 
6106
- const SvgContainerColorMixin = styled.css `
6107
- path,
6108
- line,
6109
- circle {
6110
- fill: ${({ $fontColor }) => $fontColor};
6111
- }
6112
- `;
6113
- const SvgContainer = styled.div `
6114
- &&& {
6115
- min-width: ${({ $width }) => ($width ? `${$width}px` : "1rem")};
6116
- max-width: ${({ $width }) => ($width ? `${$width}px` : "1rem")};
6117
-
6118
- ${({ $fontColor }) => !!$fontColor && SvgContainerColorMixin};
6119
-
6120
- > * {
6121
- min-width: inherit;
6122
- }
6123
- }
6124
- `;
6125
-
6126
- const ContainerIconTitle = styled(uilibGl.Flex) `
6127
- align-items: center;
6128
- flex-wrap: nowrap;
6129
- color: ${({ fontColor, theme: { palette } }) => fontColor || palette.textSecondary};
6130
-
6131
- svg,
6132
- img,
6133
- span[kind],
6134
- ${SvgContainer} {
6135
- margin-right: 0.5rem;
6136
- }
6137
-
6121
+ const SvgContainerColorMixin = styled.css `
6122
+ path,
6123
+ line,
6124
+ circle {
6125
+ fill: ${({ $fontColor }) => $fontColor};
6126
+ }
6127
+ `;
6128
+ const SvgContainer = styled.div `
6129
+ &&& {
6130
+ min-width: ${({ $width }) => ($width ? `${$width}px` : "1rem")};
6131
+ max-width: ${({ $width }) => ($width ? `${$width}px` : "1rem")};
6132
+
6133
+ ${({ $fontColor }) => !!$fontColor && SvgContainerColorMixin};
6134
+
6135
+ > * {
6136
+ min-width: inherit;
6137
+ }
6138
+ }
6139
+ `;
6140
+
6141
+ const ContainerIconTitle = styled(uilibGl.Flex) `
6142
+ align-items: center;
6143
+ flex-wrap: nowrap;
6144
+ color: ${({ fontColor, theme: { palette } }) => fontColor || palette.textSecondary};
6145
+
6146
+ svg,
6147
+ img,
6148
+ span[kind],
6149
+ ${SvgContainer} {
6150
+ margin-right: 0.5rem;
6151
+ }
6152
+
6138
6153
  ${({ fontColor }) => !!fontColor &&
6139
- styled.css `
6140
- span[kind] {
6141
- color: ${fontColor};
6142
- }
6143
-
6144
- ${SvgContainer} {
6145
- path,
6146
- circle {
6147
- fill: ${fontColor};
6148
- }
6149
- }
6150
- `};
6151
-
6152
- ${uilibGl.LegendToggler} {
6153
- margin-left: 0.25rem;
6154
- }
6155
- `;
6156
- const ContainerTitle = styled(uilibGl.Flex) `
6157
- align-items: center;
6158
- justify-content: space-between;
6159
- width: 100%;
6160
-
6161
- > * {
6162
- font-size: 1.125rem;
6163
- font-weight: 500;
6164
- }
6165
-
6166
- ${uilibGl.LegendToggler} {
6167
- padding-right: 0;
6168
- }
6169
-
6154
+ styled.css `
6155
+ span[kind] {
6156
+ color: ${fontColor};
6157
+ }
6158
+
6159
+ ${SvgContainer} {
6160
+ path,
6161
+ circle {
6162
+ fill: ${fontColor};
6163
+ }
6164
+ }
6165
+ `};
6166
+
6167
+ ${uilibGl.LegendToggler} {
6168
+ margin-left: 0.25rem;
6169
+ }
6170
+ `;
6171
+ const ContainerTitle = styled(uilibGl.Flex) `
6172
+ align-items: center;
6173
+ justify-content: space-between;
6174
+ width: 100%;
6175
+
6176
+ > * {
6177
+ font-size: 1.125rem;
6178
+ font-weight: 500;
6179
+ }
6180
+
6181
+ ${uilibGl.LegendToggler} {
6182
+ padding-right: 0;
6183
+ }
6184
+
6170
6185
  ${({ simple }) => simple &&
6171
- styled.css `
6172
- justify-content: flex-start;
6173
-
6174
- ${ContainerIconTitle} {
6175
- font-size: 0.75rem;
6176
- }
6177
-
6178
- ${uilibGl.LegendToggler} {
6179
- margin-left: 0;
6180
- padding-left: 0.25rem;
6181
- }
6182
- `}
6186
+ styled.css `
6187
+ justify-content: flex-start;
6188
+
6189
+ ${ContainerIconTitle} {
6190
+ font-size: 0.75rem;
6191
+ }
6192
+
6193
+ ${uilibGl.LegendToggler} {
6194
+ margin-left: 0;
6195
+ padding-left: 0.25rem;
6196
+ }
6197
+ `}
6183
6198
  `;
6184
6199
 
6185
6200
  const TitleContainer = React.memo(({ containerId, templateName, layerNames, fontColor, expandable, expanded, isVisible, elementConfig, renderElement, type, }) => {
@@ -6206,9 +6221,9 @@ const TitleContainer = React.memo(({ containerId, templateName, layerNames, font
6206
6221
  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] }) }));
6207
6222
  });
6208
6223
 
6209
- const ContainerDivider = styled(uilibGl.Divider) `
6210
- width: 100%;
6211
- border-color: ${({ theme: { palette }, $bgColor }) => $bgColor || palette.elementDeep};
6224
+ const ContainerDivider = styled(uilibGl.Divider) `
6225
+ width: 100%;
6226
+ border-color: ${({ theme: { palette }, $bgColor }) => $bgColor || palette.elementDeep};
6212
6227
  `;
6213
6228
 
6214
6229
  const DividerContainer = React.memo(({ elementConfig, config }) => {
@@ -6261,82 +6276,82 @@ const CameraContainer = React.memo(({ elementConfig, type, renderElement }) => {
6261
6276
  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 }) })] }))] }));
6262
6277
  });
6263
6278
 
6264
- const TabAnchor = styled.div `
6265
- position: absolute;
6266
- top: -1.5rem;
6267
- right: 0;
6268
- `;
6269
- const TabValue = styled(uilibGl.Flex) `
6270
- flex-wrap: nowrap;
6271
- `;
6272
- const noBgMixin = styled.css `
6273
- background-color: transparent;
6274
- border-radius: 0;
6275
- border-bottom: 0.125rem solid
6276
- ${({ active, bgColor, theme: { palette } }) => (active ? bgColor || palette.primary : palette.element)};
6277
-
6278
- ${TabValue},
6279
- span[kind] {
6280
- color: ${({ active, bgColor, theme: { palette } }) => active ? bgColor || palette.primary : palette.textSecondary};
6281
- }
6282
-
6283
- &&& svg {
6284
- path,
6285
- line,
6286
- circle {
6287
- fill: ${({ active, bgColor, theme: { palette } }) => active ? bgColor || palette.primary : palette.textSecondary};
6288
- }
6289
- }
6290
-
6291
- :not(:last-child) {
6292
- margin-right: 0;
6293
- }
6294
- `;
6295
- const TabContainer = styled.a `
6296
- display: flex;
6297
- flex-direction: ${({ column }) => (column ? "column" : "row")};
6298
- align-items: center;
6299
- justify-content: center;
6300
- flex-wrap: nowrap;
6301
- padding: ${({ onlyIcon }) => (onlyIcon ? 1 : 0.5)}rem 1rem;
6302
- background-color: ${({ active, bgColor, theme: { palette } }) => active ? bgColor || palette.primary : palette.element};
6303
- border-radius: ${({ column, radius, theme: { borderRadius } }) => radius ? `${radius}px` : column ? borderRadius.medium : borderRadius.xLarge};
6304
- text-decoration: none;
6305
-
6306
- :not(:last-child) {
6307
- margin-right: 0.5rem;
6308
- }
6309
-
6310
- ${TabValue} {
6311
- margin-top: ${({ column }) => (column ? 0.5 : 0)}rem;
6312
- margin-left: ${({ column, hasIcon }) => (column || !hasIcon ? 0 : 0.5)}rem;
6313
- font-size: ${({ column }) => (column ? 0.75 : 0.875)}rem;
6314
- white-space: nowrap;
6315
- }
6316
-
6317
- ${TabValue},
6318
- span[kind] {
6319
- color: ${({ active, theme: { palette } }) => (active ? palette.textContrast : palette.textSecondary)};
6320
- }
6321
-
6322
- ${SvgContainer$1} {
6323
- height: 1rem;
6324
- }
6325
-
6326
- svg,
6327
- img {
6328
- max-width: 1rem;
6329
- max-height: 1rem;
6330
- }
6331
-
6332
- ${({ noBg }) => noBg && noBgMixin};
6333
- `;
6334
- const SwiperContainer = styled.div `
6335
- width: 100%;
6336
-
6337
- .swiper-wrapper {
6338
- display: flex;
6339
- }
6279
+ const TabAnchor = styled.div `
6280
+ position: absolute;
6281
+ top: -1.5rem;
6282
+ right: 0;
6283
+ `;
6284
+ const TabValue = styled(uilibGl.Flex) `
6285
+ flex-wrap: nowrap;
6286
+ `;
6287
+ const noBgMixin = styled.css `
6288
+ background-color: transparent;
6289
+ border-radius: 0;
6290
+ border-bottom: 0.125rem solid
6291
+ ${({ active, bgColor, theme: { palette } }) => (active ? bgColor || palette.primary : palette.element)};
6292
+
6293
+ ${TabValue},
6294
+ span[kind] {
6295
+ color: ${({ active, bgColor, theme: { palette } }) => active ? bgColor || palette.primary : palette.textSecondary};
6296
+ }
6297
+
6298
+ &&& svg {
6299
+ path,
6300
+ line,
6301
+ circle {
6302
+ fill: ${({ active, bgColor, theme: { palette } }) => active ? bgColor || palette.primary : palette.textSecondary};
6303
+ }
6304
+ }
6305
+
6306
+ :not(:last-child) {
6307
+ margin-right: 0;
6308
+ }
6309
+ `;
6310
+ const TabContainer = styled.a `
6311
+ display: flex;
6312
+ flex-direction: ${({ column }) => (column ? "column" : "row")};
6313
+ align-items: center;
6314
+ justify-content: center;
6315
+ flex-wrap: nowrap;
6316
+ padding: ${({ onlyIcon }) => (onlyIcon ? 1 : 0.5)}rem 1rem;
6317
+ background-color: ${({ active, bgColor, theme: { palette } }) => active ? bgColor || palette.primary : palette.element};
6318
+ border-radius: ${({ column, radius, theme: { borderRadius } }) => radius ? `${radius}px` : column ? borderRadius.medium : borderRadius.xLarge};
6319
+ text-decoration: none;
6320
+
6321
+ :not(:last-child) {
6322
+ margin-right: 0.5rem;
6323
+ }
6324
+
6325
+ ${TabValue} {
6326
+ margin-top: ${({ column }) => (column ? 0.5 : 0)}rem;
6327
+ margin-left: ${({ column, hasIcon }) => (column || !hasIcon ? 0 : 0.5)}rem;
6328
+ font-size: ${({ column }) => (column ? 0.75 : 0.875)}rem;
6329
+ white-space: nowrap;
6330
+ }
6331
+
6332
+ ${TabValue},
6333
+ span[kind] {
6334
+ color: ${({ active, theme: { palette } }) => (active ? palette.textContrast : palette.textSecondary)};
6335
+ }
6336
+
6337
+ ${SvgContainer$1} {
6338
+ height: 1rem;
6339
+ }
6340
+
6341
+ svg,
6342
+ img {
6343
+ max-width: 1rem;
6344
+ max-height: 1rem;
6345
+ }
6346
+
6347
+ ${({ noBg }) => noBg && noBgMixin};
6348
+ `;
6349
+ const SwiperContainer = styled.div `
6350
+ width: 100%;
6351
+
6352
+ .swiper-wrapper {
6353
+ display: flex;
6354
+ }
6340
6355
  `;
6341
6356
 
6342
6357
  const TabsContainer = React.memo(({ elementConfig, type }) => {
@@ -6364,96 +6379,96 @@ const TabsContainer = React.memo(({ elementConfig, type }) => {
6364
6379
  });
6365
6380
 
6366
6381
  const ContainerIconValue = styled(uilibGl.Flex) ``;
6367
- const RoundedBackgroundContainerWrapper = styled(uilibGl.Flex) `
6368
- position: relative;
6369
- flex-direction: ${({ $bigIcon }) => ($bigIcon ? "row" : "column")};
6370
- width: 9rem;
6371
- padding: 0.75rem 0.75rem 0.5rem;
6372
- background-color: ${({ theme: { palette } }) => palette.element};
6373
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.large};
6374
- flex-wrap: nowrap;
6375
-
6376
- && {
6377
- margin-bottom: 0.5rem;
6378
- }
6379
-
6382
+ const RoundedBackgroundContainerWrapper = styled(uilibGl.Flex) `
6383
+ position: relative;
6384
+ flex-direction: ${({ $bigIcon }) => ($bigIcon ? "row" : "column")};
6385
+ width: 9rem;
6386
+ padding: 0.75rem 0.75rem 0.5rem;
6387
+ background-color: ${({ theme: { palette } }) => palette.element};
6388
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.large};
6389
+ flex-wrap: nowrap;
6390
+
6391
+ && {
6392
+ margin-bottom: 0.5rem;
6393
+ }
6394
+
6380
6395
  ${({ $center }) => $center &&
6381
- styled.css `
6382
- align-items: center;
6383
-
6384
- > * {
6385
- display: flex;
6386
- justify-content: center;
6387
- text-align: center;
6388
- width: 100%;
6389
- }
6390
- `};
6391
-
6396
+ styled.css `
6397
+ align-items: center;
6398
+
6399
+ > * {
6400
+ display: flex;
6401
+ justify-content: center;
6402
+ text-align: center;
6403
+ width: 100%;
6404
+ }
6405
+ `};
6406
+
6392
6407
  ${({ $color }) => $color &&
6393
- styled.css `
6394
- background-color: ${transparentizeColor($color, 6)};
6395
-
6396
- * {
6397
- color: ${$color};
6398
- }
6399
- `};
6400
-
6401
- ${ContainerIcon}, ${SvgContainer$1} {
6402
- margin-bottom: 0.25rem;
6403
- }
6404
-
6408
+ styled.css `
6409
+ background-color: ${transparentizeColor($color, 6)};
6410
+
6411
+ * {
6412
+ color: ${$color};
6413
+ }
6414
+ `};
6415
+
6416
+ ${ContainerIcon}, ${SvgContainer$1} {
6417
+ margin-bottom: 0.25rem;
6418
+ }
6419
+
6405
6420
  ${({ $bigIcon }) => $bigIcon &&
6406
- styled.css `
6407
- ${ContainerIcon}, ${SvgContainer$1} {
6408
- position: absolute;
6409
- top: 0.75rem;
6410
- right: 0.75rem;
6411
- width: 3rem;
6412
- opacity: 0.12;
6413
-
6414
- :after {
6415
- font-size: 3rem;
6416
- }
6417
- }
6418
- `};
6419
-
6420
- ${ContainerIconValue} {
6421
- align-items: center;
6422
- flex-direction: column;
6423
-
6421
+ styled.css `
6422
+ ${ContainerIcon}, ${SvgContainer$1} {
6423
+ position: absolute;
6424
+ top: 0.75rem;
6425
+ right: 0.75rem;
6426
+ width: 3rem;
6427
+ opacity: 0.12;
6428
+
6429
+ :after {
6430
+ font-size: 3rem;
6431
+ }
6432
+ }
6433
+ `};
6434
+
6435
+ ${ContainerIconValue} {
6436
+ align-items: center;
6437
+ flex-direction: column;
6438
+
6424
6439
  ${({ $big }) => $big &&
6425
- styled.css `
6426
- flex-direction: row;
6427
- margin-bottom: 0.5rem;
6428
-
6429
- > * {
6430
- text-align: left;
6431
- }
6432
-
6433
- span[kind] {
6434
- margin-right: 0.5rem;
6435
- }
6436
-
6437
- ${ContainerValue} {
6438
- width: auto;
6439
- }
6440
- `};
6441
- }
6442
-
6443
- ${ContainerValue} {
6444
- flex-direction: ${({ $inlineUnits }) => ($inlineUnits ? "row" : "column")};
6445
- justify-content: ${({ $big }) => ($big ? "flex-start" : "flex-end")};
6446
- align-items: ${({ $inlineUnits }) => ($inlineUnits ? "center" : "flex-start")};
6447
- line-height: 1;
6448
- }
6449
-
6450
- ${ContainerUnits} {
6451
- margin-left: ${({ $inlineUnits }) => ($inlineUnits ? "0.25rem" : 0)};
6452
- }
6453
-
6454
- ${ContainerAlias} {
6455
- margin-top: 0.25rem;
6456
- }
6440
+ styled.css `
6441
+ flex-direction: row;
6442
+ margin-bottom: 0.5rem;
6443
+
6444
+ > * {
6445
+ text-align: left;
6446
+ }
6447
+
6448
+ span[kind] {
6449
+ margin-right: 0.5rem;
6450
+ }
6451
+
6452
+ ${ContainerValue} {
6453
+ width: auto;
6454
+ }
6455
+ `};
6456
+ }
6457
+
6458
+ ${ContainerValue} {
6459
+ flex-direction: ${({ $inlineUnits }) => ($inlineUnits ? "row" : "column")};
6460
+ justify-content: ${({ $big }) => ($big ? "flex-start" : "flex-end")};
6461
+ align-items: ${({ $inlineUnits }) => ($inlineUnits ? "center" : "flex-start")};
6462
+ line-height: 1;
6463
+ }
6464
+
6465
+ ${ContainerUnits} {
6466
+ margin-left: ${({ $inlineUnits }) => ($inlineUnits ? "0.25rem" : 0)};
6467
+ }
6468
+
6469
+ ${ContainerAlias} {
6470
+ margin-top: 0.25rem;
6471
+ }
6457
6472
  `;
6458
6473
 
6459
6474
  const ALIAS_DEFAULT_MAX_LENGTH = 28;
@@ -6492,20 +6507,20 @@ const AddFeatureContainer = React.memo(({ elementConfig }) => {
6492
6507
  .map(({ options }, index) => (jsxRuntime.jsx(AddFeatureButton, { icon: options?.icon, title: options?.title, layerName: options?.layerName, geometryType: options?.geometryType }, index))) }));
6493
6508
  });
6494
6509
 
6495
- const LayersContainerWrapper = styled(Container) `
6496
- ${uilibGl.DraggableTreeContainer} {
6497
- width: calc(100% + 3rem);
6498
- margin: -0.75rem -1.5rem 0;
6499
- }
6500
-
6501
- ${LayerListContainer} {
6502
- height: auto;
6503
- }
6504
-
6505
- ${LayerGroupList} {
6506
- margin: ${({ isPresentationMode }) => (isPresentationMode ? 0 : "0 -1.25rem 0 -1rem")};
6507
- padding: 0;
6508
- }
6510
+ const LayersContainerWrapper = styled(Container) `
6511
+ ${uilibGl.DraggableTreeContainer} {
6512
+ width: calc(100% + 3rem);
6513
+ margin: -0.75rem -1.5rem 0;
6514
+ }
6515
+
6516
+ ${LayerListContainer} {
6517
+ height: auto;
6518
+ }
6519
+
6520
+ ${LayerGroupList} {
6521
+ margin: ${({ isPresentationMode }) => (isPresentationMode ? 0 : "0 -1.25rem 0 -1rem")};
6522
+ padding: 0;
6523
+ }
6509
6524
  `;
6510
6525
 
6511
6526
  const LayersContainer = React.memo(({ type, elementConfig, renderElement }) => {
@@ -6553,99 +6568,99 @@ const getContainerComponent = (innerTemplateName) => innerTemplateName ? contain
6553
6568
  var img$3 = "";
6554
6569
 
6555
6570
  const getMaskColor = (isDark) => (isDark ? "0, 0, 0" : "255, 255, 255");
6556
- const DefaultHeaderContainer = styled(uilibGl.Flex) `
6557
- flex-direction: column;
6558
- position: relative;
6559
- flex-shrink: 0;
6560
- min-height: 8.375rem;
6561
- margin-bottom: -1.5rem;
6562
- padding: 1.5rem 1.5rem 0;
6563
- border-top-left-radius: 0.5rem;
6564
- border-top-right-radius: 0.5rem;
6565
- overflow: hidden;
6566
-
6567
- > * {
6568
- z-index: 1;
6569
- }
6570
-
6571
- &::before {
6572
- content: "";
6573
- position: absolute;
6574
- top: 0;
6575
- left: 0;
6576
- width: 100%;
6577
- height: 100%;
6578
-
6571
+ const DefaultHeaderContainer = styled(uilibGl.Flex) `
6572
+ flex-direction: column;
6573
+ position: relative;
6574
+ flex-shrink: 0;
6575
+ min-height: 8.375rem;
6576
+ margin-bottom: -1.5rem;
6577
+ padding: 1.5rem 1.5rem 0;
6578
+ border-top-left-radius: 0.5rem;
6579
+ border-top-right-radius: 0.5rem;
6580
+ overflow: hidden;
6581
+
6582
+ > * {
6583
+ z-index: 1;
6584
+ }
6585
+
6586
+ &::before {
6587
+ content: "";
6588
+ position: absolute;
6589
+ top: 0;
6590
+ left: 0;
6591
+ width: 100%;
6592
+ height: 100%;
6593
+
6579
6594
  ${({ image, isDark }) => image
6580
- ? styled.css `
6581
- background: url(${image}) 0 0 no-repeat;
6582
- background-size: cover;
6595
+ ? styled.css `
6596
+ background: url(${image}) 0 0 no-repeat;
6597
+ background-size: cover;
6583
6598
  `
6584
- : styled.css `
6585
- background: url(${img$3}) 50% 0 no-repeat;
6586
- opacity: ${isDark ? 1 : 0.5};
6587
- `}
6588
- }
6589
-
6599
+ : styled.css `
6600
+ background: url(${img$3}) 50% 0 no-repeat;
6601
+ opacity: ${isDark ? 1 : 0.5};
6602
+ `}
6603
+ }
6604
+
6590
6605
  ${({ image, isDark }) => image &&
6591
- styled.css `
6592
- &::before {
6593
- -webkit-mask-image: linear-gradient(
6594
- to bottom,
6595
- rgba(${getMaskColor(isDark)}, 1),
6596
- rgba(${getMaskColor(isDark)}, 0)
6597
- );
6598
- mask-image: linear-gradient(to bottom, rgba(${getMaskColor(isDark)}, 1), rgba(${getMaskColor(isDark)}, 0));
6599
- }
6600
- `}
6601
- ${uilibGl.LinearProgress} {
6602
- position: absolute;
6603
- top: 0;
6604
- left: 0;
6605
- }
6606
- `;
6607
- const TopContainer = styled(uilibGl.Flex) `
6608
- z-index: 1;
6609
- position: relative;
6610
- justify-content: space-between;
6611
- flex-wrap: nowrap;
6612
- width: 100%;
6613
- align-items: flex-start;
6614
- `;
6615
- const TopContainerButtons = styled(uilibGl.Flex) `
6616
- align-items: center;
6617
- width: auto;
6618
- margin-right: -0.5rem;
6619
-
6620
- button {
6621
- width: auto;
6622
- height: 1rem;
6623
- padding: 0 0.5rem;
6624
- }
6625
- `;
6626
- const LogoContainer = styled(uilibGl.Flex) `
6627
- max-width: calc(100% - 1.4rem);
6628
- flex-grow: 1;
6629
- font-size: 0;
6630
-
6631
- & > span::after {
6632
- font-size: 2rem;
6633
- }
6634
-
6635
- img {
6636
- max-height: 1.875rem;
6637
- }
6638
- `;
6639
- const PageTitle = styled(uilibGl.H2) `
6640
- display: -webkit-box;
6641
- -webkit-line-clamp: 3;
6642
- -webkit-box-orient: vertical;
6643
- overflow: hidden;
6644
- margin: 0;
6645
- font-size: 1.25rem;
6646
- font-weight: 600;
6647
- pointer-events: initial;
6648
- font-family: "Nunito Sans", serif;
6606
+ styled.css `
6607
+ &::before {
6608
+ -webkit-mask-image: linear-gradient(
6609
+ to bottom,
6610
+ rgba(${getMaskColor(isDark)}, 1),
6611
+ rgba(${getMaskColor(isDark)}, 0)
6612
+ );
6613
+ mask-image: linear-gradient(to bottom, rgba(${getMaskColor(isDark)}, 1), rgba(${getMaskColor(isDark)}, 0));
6614
+ }
6615
+ `}
6616
+ ${uilibGl.LinearProgress} {
6617
+ position: absolute;
6618
+ top: 0;
6619
+ left: 0;
6620
+ }
6621
+ `;
6622
+ const TopContainer = styled(uilibGl.Flex) `
6623
+ z-index: 1;
6624
+ position: relative;
6625
+ justify-content: space-between;
6626
+ flex-wrap: nowrap;
6627
+ width: 100%;
6628
+ align-items: flex-start;
6629
+ `;
6630
+ const TopContainerButtons = styled(uilibGl.Flex) `
6631
+ align-items: center;
6632
+ width: auto;
6633
+ margin-right: -0.5rem;
6634
+
6635
+ button {
6636
+ width: auto;
6637
+ height: 1rem;
6638
+ padding: 0 0.5rem;
6639
+ }
6640
+ `;
6641
+ const LogoContainer = styled(uilibGl.Flex) `
6642
+ max-width: calc(100% - 1.4rem);
6643
+ flex-grow: 1;
6644
+ font-size: 0;
6645
+
6646
+ & > span::after {
6647
+ font-size: 2rem;
6648
+ }
6649
+
6650
+ img {
6651
+ max-height: 1.875rem;
6652
+ }
6653
+ `;
6654
+ const PageTitle = styled(uilibGl.H2) `
6655
+ display: -webkit-box;
6656
+ -webkit-line-clamp: 3;
6657
+ -webkit-box-orient: vertical;
6658
+ overflow: hidden;
6659
+ margin: 0;
6660
+ font-size: 1.25rem;
6661
+ font-weight: 600;
6662
+ pointer-events: initial;
6663
+ font-family: "Nunito Sans", serif;
6649
6664
  `;
6650
6665
 
6651
6666
  exports.ThemeName = void 0;
@@ -6671,81 +6686,81 @@ const DashboardDefaultHeader = React.memo(() => {
6671
6686
  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, {}) })] }) }) }) })] })] }));
6672
6687
  });
6673
6688
 
6674
- const HeaderFrontView = styled(uilibGl.Flex) `
6675
- z-index: 10;
6676
- position: relative;
6677
- justify-content: space-between;
6678
- align-items: ${({ isDefault }) => (isDefault ? "center" : "flex-start")};
6679
- width: 100%;
6680
- font: ${({ theme: { fonts } }) => fonts.subtitle};
6681
- `;
6682
- const HeaderContainer = styled(uilibGl.FlexSpan) `
6683
- display: flex;
6684
- flex-grow: 1;
6685
- flex-wrap: nowrap;
6686
- width: calc(100% - 48px);
6687
- `;
6688
- const FeatureTitleContainer = styled.div `
6689
- display: -webkit-box;
6690
- max-width: 100%;
6691
- width: 100%;
6692
- margin: 0.5rem 0;
6693
- -webkit-line-clamp: 2;
6694
- -webkit-box-orient: vertical;
6695
- overflow: hidden;
6696
- text-overflow: ellipsis;
6697
- color: ${({ theme: { palette } }) => palette.textPrimary};
6698
-
6699
- & > ${uilibGl.FlexSpan} {
6700
- cursor: ${({ clickable }) => clickable && "pointer"};
6701
-
6702
- &:hover {
6703
- color: ${({ clickable, theme: { palette } }) => clickable && palette.primary};
6704
- }
6705
- }
6706
- `;
6707
- const LayerDescription = styled(uilibGl.Description) `
6708
- width: calc(100% - 4rem);
6709
- display: -webkit-box;
6710
- -webkit-line-clamp: 2;
6711
- -webkit-box-orient: vertical;
6712
- overflow: hidden;
6713
- text-overflow: ellipsis;
6714
- `;
6715
- const HeaderTitleContainer = styled(uilibGl.Flex) `
6716
- flex-direction: column;
6717
- width: 100%;
6718
- `;
6719
- const RowHeaderMixin = styled.css `
6720
- &&& {
6721
- min-height: auto;
6722
-
6723
- ${FeatureTitleContainer}, ${LayerDescription} {
6724
- text-align: left;
6725
- }
6726
- }
6727
-
6728
- ${HeaderContainer} {
6729
- flex-direction: row;
6730
- }
6731
-
6732
- ${FeatureTitleContainer} {
6733
- max-width: calc(100% - 3.8rem);
6734
- }
6735
- `;
6736
- const Header = styled(uilibGl.Flex) `
6737
- z-index: 1;
6738
- position: relative;
6739
- top: 0;
6740
- flex-shrink: 0;
6741
- overflow: hidden;
6742
- padding: 0.5rem;
6743
-
6744
- ${HeaderContainer} {
6745
- flex-direction: column;
6746
- }
6747
-
6748
- ${({ $isRow }) => $isRow && RowHeaderMixin};
6689
+ const HeaderFrontView = styled(uilibGl.Flex) `
6690
+ z-index: 10;
6691
+ position: relative;
6692
+ justify-content: space-between;
6693
+ align-items: ${({ isDefault }) => (isDefault ? "center" : "flex-start")};
6694
+ width: 100%;
6695
+ font: ${({ theme: { fonts } }) => fonts.subtitle};
6696
+ `;
6697
+ const HeaderContainer = styled(uilibGl.FlexSpan) `
6698
+ display: flex;
6699
+ flex-grow: 1;
6700
+ flex-wrap: nowrap;
6701
+ width: calc(100% - 48px);
6702
+ `;
6703
+ const FeatureTitleContainer = styled.div `
6704
+ display: -webkit-box;
6705
+ max-width: 100%;
6706
+ width: 100%;
6707
+ margin: 0.5rem 0;
6708
+ -webkit-line-clamp: 2;
6709
+ -webkit-box-orient: vertical;
6710
+ overflow: hidden;
6711
+ text-overflow: ellipsis;
6712
+ color: ${({ theme: { palette } }) => palette.textPrimary};
6713
+
6714
+ & > ${uilibGl.FlexSpan} {
6715
+ cursor: ${({ clickable }) => clickable && "pointer"};
6716
+
6717
+ &:hover {
6718
+ color: ${({ clickable, theme: { palette } }) => clickable && palette.primary};
6719
+ }
6720
+ }
6721
+ `;
6722
+ const LayerDescription = styled(uilibGl.Description) `
6723
+ width: calc(100% - 4rem);
6724
+ display: -webkit-box;
6725
+ -webkit-line-clamp: 2;
6726
+ -webkit-box-orient: vertical;
6727
+ overflow: hidden;
6728
+ text-overflow: ellipsis;
6729
+ `;
6730
+ const HeaderTitleContainer = styled(uilibGl.Flex) `
6731
+ flex-direction: column;
6732
+ width: 100%;
6733
+ `;
6734
+ const RowHeaderMixin = styled.css `
6735
+ &&& {
6736
+ min-height: auto;
6737
+
6738
+ ${FeatureTitleContainer}, ${LayerDescription} {
6739
+ text-align: left;
6740
+ }
6741
+ }
6742
+
6743
+ ${HeaderContainer} {
6744
+ flex-direction: row;
6745
+ }
6746
+
6747
+ ${FeatureTitleContainer} {
6748
+ max-width: calc(100% - 3.8rem);
6749
+ }
6750
+ `;
6751
+ const Header = styled(uilibGl.Flex) `
6752
+ z-index: 1;
6753
+ position: relative;
6754
+ top: 0;
6755
+ flex-shrink: 0;
6756
+ overflow: hidden;
6757
+ padding: 0.5rem;
6758
+
6759
+ ${HeaderContainer} {
6760
+ flex-direction: column;
6761
+ }
6762
+
6763
+ ${({ $isRow }) => $isRow && RowHeaderMixin};
6749
6764
  `;
6750
6765
 
6751
6766
  const HeaderTitle = ({ noFeature }) => {
@@ -6773,22 +6788,22 @@ const HeaderTitle = ({ noFeature }) => {
6773
6788
  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 })] }));
6774
6789
  };
6775
6790
 
6776
- const LayerIconContainer = styled.div `
6777
- display: flex;
6778
- align-items: center;
6779
- margin-right: 0.75rem;
6791
+ const LayerIconContainer = styled.div `
6792
+ display: flex;
6793
+ align-items: center;
6794
+ margin-right: 0.75rem;
6780
6795
  `;
6781
- const AlertIconContainer = styled(uilibGl.Flex) `
6782
- align-items: center;
6783
- justify-content: center;
6784
- width: 2rem;
6785
- height: 2rem;
6786
-
6787
- ${uilibGl.Icon} {
6788
- :after {
6789
- color: ${({ theme: { palette } }) => palette.error};
6790
- }
6791
- }
6796
+ const AlertIconContainer = styled(uilibGl.Flex) `
6797
+ align-items: center;
6798
+ justify-content: center;
6799
+ width: 2rem;
6800
+ height: 2rem;
6801
+
6802
+ ${uilibGl.Icon} {
6803
+ :after {
6804
+ color: ${({ theme: { palette } }) => palette.error};
6805
+ }
6806
+ }
6792
6807
  `;
6793
6808
 
6794
6809
  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";
@@ -6820,56 +6835,56 @@ const FeatureCardDefaultHeader = ({ noFeature }) => {
6820
6835
  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, {})] }) }));
6821
6836
  };
6822
6837
 
6823
- const HeaderFontColorMixin$1 = styled.css `
6824
- ${HeaderTitleContainer}, ${LayerDescription} {
6825
- color: ${({ $fontColor }) => $fontColor};
6826
- }
6827
- `;
6828
- const HeaderWrapperMixin$1 = styled.css `
6829
- padding: 0.5rem 0.5rem 0;
6830
-
6831
- ${Header} {
6832
- min-height: 5.25rem;
6833
- }
6834
-
6835
- ${HeaderContainer} {
6836
- max-width: 100%;
6837
- width: 100%;
6838
- }
6839
-
6840
- ${FeatureControls} {
6841
- max-width: calc(100% - 2rem);
6842
- width: calc(100% - 2rem);
6843
- margin-top: -0.5rem;
6844
- padding-top: 1rem;
6845
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
6846
- }
6847
-
6848
- ${({ $fontColor }) => !!$fontColor && HeaderFontColorMixin$1};
6849
- `;
6850
- const GradientHeaderWrapper = styled.div `
6851
- ${Header} {
6852
- background: ${({ $bgColor }) => $bgColor || "radial-gradient(129.21% 133.22% at 51.94% 0%, #e8fffe 9.48%, #5fcaff 100%)"};
6853
- }
6854
-
6855
- ${HeaderContainer} {
6856
- align-items: center;
6857
- }
6858
-
6859
- ${HeaderTitleContainer} {
6860
- margin-left: 0;
6861
- text-align: center;
6862
- }
6863
-
6864
- ${FeatureTitleContainer} {
6865
- text-align: center;
6866
- }
6867
-
6868
- ${LayerDescription} {
6869
- text-align: center;
6870
- }
6871
-
6872
- ${HeaderWrapperMixin$1};
6838
+ const HeaderFontColorMixin$1 = styled.css `
6839
+ ${HeaderTitleContainer}, ${LayerDescription} {
6840
+ color: ${({ $fontColor }) => $fontColor};
6841
+ }
6842
+ `;
6843
+ const HeaderWrapperMixin$1 = styled.css `
6844
+ padding: 0.5rem 0.5rem 0;
6845
+
6846
+ ${Header} {
6847
+ min-height: 5.25rem;
6848
+ }
6849
+
6850
+ ${HeaderContainer} {
6851
+ max-width: 100%;
6852
+ width: 100%;
6853
+ }
6854
+
6855
+ ${FeatureControls} {
6856
+ max-width: calc(100% - 2rem);
6857
+ width: calc(100% - 2rem);
6858
+ margin-top: -0.5rem;
6859
+ padding-top: 1rem;
6860
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
6861
+ }
6862
+
6863
+ ${({ $fontColor }) => !!$fontColor && HeaderFontColorMixin$1};
6864
+ `;
6865
+ const GradientHeaderWrapper = styled.div `
6866
+ ${Header} {
6867
+ background: ${({ $bgColor }) => $bgColor || "radial-gradient(129.21% 133.22% at 51.94% 0%, #e8fffe 9.48%, #5fcaff 100%)"};
6868
+ }
6869
+
6870
+ ${HeaderContainer} {
6871
+ align-items: center;
6872
+ }
6873
+
6874
+ ${HeaderTitleContainer} {
6875
+ margin-left: 0;
6876
+ text-align: center;
6877
+ }
6878
+
6879
+ ${FeatureTitleContainer} {
6880
+ text-align: center;
6881
+ }
6882
+
6883
+ ${LayerDescription} {
6884
+ text-align: center;
6885
+ }
6886
+
6887
+ ${HeaderWrapperMixin$1};
6873
6888
  `;
6874
6889
 
6875
6890
  const FeatureCardGradientHeader = ({ isRow }) => {
@@ -6886,82 +6901,82 @@ const FeatureCardGradientHeader = ({ isRow }) => {
6886
6901
  }) })] }), jsxRuntime.jsx(FeatureCardButtons, {})] }) }) }) }));
6887
6902
  };
6888
6903
 
6889
- const HeaderFontColorMixin = styled.css `
6890
- ${HeaderTitleContainer}, ${LayerDescription} {
6891
- color: ${({ $fontColor }) => $fontColor};
6892
- }
6893
- `;
6894
- const HeaderWrapperMixin = styled.css `
6895
- padding: 0.5rem 0.5rem 0;
6896
-
6897
- ${Header} {
6898
- min-height: 5.25rem;
6899
- }
6900
-
6901
- ${HeaderContainer} {
6902
- max-width: 100%;
6903
- width: 100%;
6904
- }
6905
-
6906
- ${FeatureControls} {
6907
- max-width: calc(100% - 2rem);
6908
- width: calc(100% - 2rem);
6909
- margin-top: -0.5rem;
6910
- padding-top: 1rem;
6911
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
6912
- }
6913
-
6914
- ${({ $fontColor }) => !!$fontColor && HeaderFontColorMixin};
6915
- `;
6916
- const HeaderIcon = styled(uilibGl.Flex) `
6917
- position: absolute;
6918
- top: 0;
6919
- right: 0;
6920
- justify-content: flex-end;
6921
- align-items: center;
6922
- min-width: 7.5rem;
6923
- height: 100%;
6924
-
6925
- span[kind]:after {
6926
- font-size: 7.5rem;
6927
- }
6928
-
6929
- span[kind]:after,
6930
- path,
6931
- line,
6932
- circle {
6933
- fill: rgba(255, 255, 255, 0.36);
6934
- }
6935
-
6936
- && > * {
6937
- display: flex;
6938
- align-items: center;
6939
- height: 100%;
6940
- }
6941
- `;
6942
- const BigIconHeaderMixin = styled.css `
6943
- ${HeaderIcon} {
6944
- min-width: 14rem;
6945
- right: -3rem;
6946
-
6947
- span[kind]:after {
6948
- font-size: 14rem;
6949
- }
6950
- }
6951
- `;
6952
- const IconHeaderWrapper = styled.div `
6953
- ${Header} {
6954
- width: calc(100% + 3rem);
6955
- margin: -1.5rem -1.5rem 0 -1.5rem;
6956
- padding: 1.5rem;
6957
- border-top-left-radius: 0.5rem;
6958
- border-top-right-radius: 0.5rem;
6959
- background: ${({ $bgColor }) => $bgColor || "linear-gradient(96.55deg, #FFFCD3 0%, #B4DC47 100%)"};
6960
- }
6961
-
6962
- ${HeaderWrapperMixin};
6963
-
6964
- ${({ $bigIcon }) => $bigIcon && BigIconHeaderMixin};
6904
+ const HeaderFontColorMixin = styled.css `
6905
+ ${HeaderTitleContainer}, ${LayerDescription} {
6906
+ color: ${({ $fontColor }) => $fontColor};
6907
+ }
6908
+ `;
6909
+ const HeaderWrapperMixin = styled.css `
6910
+ padding: 0.5rem 0.5rem 0;
6911
+
6912
+ ${Header} {
6913
+ min-height: 5.25rem;
6914
+ }
6915
+
6916
+ ${HeaderContainer} {
6917
+ max-width: 100%;
6918
+ width: 100%;
6919
+ }
6920
+
6921
+ ${FeatureControls} {
6922
+ max-width: calc(100% - 2rem);
6923
+ width: calc(100% - 2rem);
6924
+ margin-top: -0.5rem;
6925
+ padding-top: 1rem;
6926
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
6927
+ }
6928
+
6929
+ ${({ $fontColor }) => !!$fontColor && HeaderFontColorMixin};
6930
+ `;
6931
+ const HeaderIcon = styled(uilibGl.Flex) `
6932
+ position: absolute;
6933
+ top: 0;
6934
+ right: 0;
6935
+ justify-content: flex-end;
6936
+ align-items: center;
6937
+ min-width: 7.5rem;
6938
+ height: 100%;
6939
+
6940
+ span[kind]:after {
6941
+ font-size: 7.5rem;
6942
+ }
6943
+
6944
+ span[kind]:after,
6945
+ path,
6946
+ line,
6947
+ circle {
6948
+ fill: rgba(255, 255, 255, 0.36);
6949
+ }
6950
+
6951
+ && > * {
6952
+ display: flex;
6953
+ align-items: center;
6954
+ height: 100%;
6955
+ }
6956
+ `;
6957
+ const BigIconHeaderMixin = styled.css `
6958
+ ${HeaderIcon} {
6959
+ min-width: 14rem;
6960
+ right: -3rem;
6961
+
6962
+ span[kind]:after {
6963
+ font-size: 14rem;
6964
+ }
6965
+ }
6966
+ `;
6967
+ const IconHeaderWrapper = styled.div `
6968
+ ${Header} {
6969
+ width: calc(100% + 3rem);
6970
+ margin: -1.5rem -1.5rem 0 -1.5rem;
6971
+ padding: 1.5rem;
6972
+ border-top-left-radius: 0.5rem;
6973
+ border-top-right-radius: 0.5rem;
6974
+ background: ${({ $bgColor }) => $bgColor || "linear-gradient(96.55deg, #FFFCD3 0%, #B4DC47 100%)"};
6975
+ }
6976
+
6977
+ ${HeaderWrapperMixin};
6978
+
6979
+ ${({ $bigIcon }) => $bigIcon && BigIconHeaderMixin};
6965
6980
  `;
6966
6981
 
6967
6982
  const FeatureCardIconHeader = ({ isRow }) => {
@@ -6981,15 +6996,15 @@ const FeatureCardIconHeader = ({ isRow }) => {
6981
6996
  }) })] }) }) }));
6982
6997
  };
6983
6998
 
6984
- const ImageContainerButton = styled(uilibGl.FlatButton) `
6985
- min-height: 1.5rem;
6986
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.large};
6987
- background-color: ${({ theme: { palette } }) => palette.primary};
6988
- text-transform: none;
6989
-
6990
- :hover {
6991
- background-color: ${({ theme: { palette } }) => palette.primaryDeep};
6992
- }
6999
+ const ImageContainerButton = styled(uilibGl.FlatButton) `
7000
+ min-height: 1.5rem;
7001
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.large};
7002
+ background-color: ${({ theme: { palette } }) => palette.primary};
7003
+ text-transform: none;
7004
+
7005
+ :hover {
7006
+ background-color: ${({ theme: { palette } }) => palette.primaryDeep};
7007
+ }
6993
7008
  `;
6994
7009
 
6995
7010
  const ElementButton = React.memo(({ type, elementConfig }) => {
@@ -7001,157 +7016,157 @@ const ElementButton = React.memo(({ type, elementConfig }) => {
7001
7016
  return (jsxRuntime.jsx(ImageContainerButton, { onClick: () => window.open(attribute?.value), children: elementConfig.value || "" }));
7002
7017
  });
7003
7018
 
7004
- const AttributeGalleryContainer = styled.div `
7005
- && {
7006
- width: calc(100% + 3rem);
7007
- }
7008
-
7009
- min-height: 12.625rem;
7010
- background-color: ${({ theme: { palette } }) => palette.element};
7011
-
7012
- img {
7013
- width: 100%;
7014
- }
7015
- `;
7016
- const LinearProgressContainer = styled(uilibGl.Flex) `
7017
- align-items: center;
7018
- justify-content: center;
7019
- min-height: inherit;
7020
-
7021
- ${uilibGl.LinearProgress} {
7022
- max-width: 4rem;
7023
- }
7024
- `;
7025
- const NoLiveSnapshotContainer = styled(uilibGl.Flex) `
7026
- flex-direction: column;
7027
- align-items: center;
7028
-
7029
- span[kind="alert"] {
7030
- width: 2rem;
7031
- height: 2rem;
7032
-
7033
- &:after {
7034
- font-size: 2rem;
7035
- color: ${({ theme: { palette } }) => palette.elementDeep};
7036
- }
7037
- }
7038
-
7039
- ${uilibGl.Description} {
7040
- font-size: 0.75rem;
7041
- color: ${({ theme: { palette } }) => palette.textDisabled};
7042
- }
7043
- `;
7044
- const SmallPreviewControl = styled(uilibGl.IconButton) `
7045
- cursor: ${({ $isDisabled }) => ($isDisabled ? "default" : "pointer")};
7046
- z-index: 3;
7047
- position: absolute;
7048
- top: 50%;
7049
- width: 2.5rem;
7050
- height: 2.5rem;
7051
- margin-top: -1.25rem;
7052
- background-color: rgba(61, 61, 61, 0.8);
7053
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.smallest};
7054
-
7055
- span:after {
7056
- color: ${({ $isDisabled }) => ($isDisabled ? "rgba(255, 255, 255, 0.28)" : "rgba(255, 255, 255, 1)")};
7057
- transition: color ${uilibGl.transition.hover};
7058
- }
7059
- `;
7060
- const SmallPreviewCounter = styled(uilibGl.Flex) `
7061
- z-index: 3;
7062
- position: absolute;
7063
- bottom: 0.625rem;
7064
- left: 0;
7065
- width: 100%;
7066
- height: 1rem;
7067
- justify-content: center;
7068
-
7069
- > div {
7070
- background-color: rgba(61, 61, 61, 0.8);
7071
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
7072
- padding: 0 0.5rem;
7073
- font-size: 0.625rem;
7074
- line-height: 1rem;
7075
- color: #fff;
7076
- }
7019
+ const AttributeGalleryContainer = styled.div `
7020
+ && {
7021
+ width: calc(100% + 3rem);
7022
+ }
7023
+
7024
+ min-height: 12.625rem;
7025
+ background-color: ${({ theme: { palette } }) => palette.element};
7026
+
7027
+ img {
7028
+ width: 100%;
7029
+ }
7030
+ `;
7031
+ const LinearProgressContainer = styled(uilibGl.Flex) `
7032
+ align-items: center;
7033
+ justify-content: center;
7034
+ min-height: inherit;
7035
+
7036
+ ${uilibGl.LinearProgress} {
7037
+ max-width: 4rem;
7038
+ }
7039
+ `;
7040
+ const NoLiveSnapshotContainer = styled(uilibGl.Flex) `
7041
+ flex-direction: column;
7042
+ align-items: center;
7043
+
7044
+ span[kind="alert"] {
7045
+ width: 2rem;
7046
+ height: 2rem;
7047
+
7048
+ &:after {
7049
+ font-size: 2rem;
7050
+ color: ${({ theme: { palette } }) => palette.elementDeep};
7051
+ }
7052
+ }
7053
+
7054
+ ${uilibGl.Description} {
7055
+ font-size: 0.75rem;
7056
+ color: ${({ theme: { palette } }) => palette.textDisabled};
7057
+ }
7058
+ `;
7059
+ const SmallPreviewControl = styled(uilibGl.IconButton) `
7060
+ cursor: ${({ $isDisabled }) => ($isDisabled ? "default" : "pointer")};
7061
+ z-index: 3;
7062
+ position: absolute;
7063
+ top: 50%;
7064
+ width: 2.5rem;
7065
+ height: 2.5rem;
7066
+ margin-top: -1.25rem;
7067
+ background-color: rgba(61, 61, 61, 0.8);
7068
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.smallest};
7069
+
7070
+ span:after {
7071
+ color: ${({ $isDisabled }) => ($isDisabled ? "rgba(255, 255, 255, 0.28)" : "rgba(255, 255, 255, 1)")};
7072
+ transition: color ${uilibGl.transition.hover};
7073
+ }
7074
+ `;
7075
+ const SmallPreviewCounter = styled(uilibGl.Flex) `
7076
+ z-index: 3;
7077
+ position: absolute;
7078
+ bottom: 0.625rem;
7079
+ left: 0;
7080
+ width: 100%;
7081
+ height: 1rem;
7082
+ justify-content: center;
7083
+
7084
+ > div {
7085
+ background-color: rgba(61, 61, 61, 0.8);
7086
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
7087
+ padding: 0 0.5rem;
7088
+ font-size: 0.625rem;
7089
+ line-height: 1rem;
7090
+ color: #fff;
7091
+ }
7077
7092
  `;
7078
7093
  const SmallPreviewLeft = styled(SmallPreviewControl).attrs(() => ({
7079
7094
  kind: "prev",
7080
- })) `
7081
- left: 1.5rem;
7095
+ })) `
7096
+ left: 1.5rem;
7082
7097
  `;
7083
7098
  const SmallPreviewRight = styled(SmallPreviewControl).attrs(() => ({
7084
7099
  kind: "next",
7085
- })) `
7086
- right: 1.5rem;
7087
- `;
7088
- const imgSlideShowMixin = styled.css `
7089
- &:nth-child(${({ prevIndex }) => prevIndex}) {
7090
- z-index: 2;
7091
- position: absolute;
7092
- top: 0;
7093
- left: 0;
7094
- right: 0;
7095
- bottom: 0;
7096
- opacity: 0;
7097
-
7098
- animation-duration: 0.25s;
7099
- animation-name: fadeOut;
7100
- animation-timing-function: linear;
7101
-
7102
- @keyframes fadeOut {
7103
- from {
7104
- opacity: 1;
7105
- }
7106
-
7107
- to {
7108
- opacity: 0;
7109
- }
7110
- }
7111
- }
7112
- `;
7113
- const SmallPreviewContainer$1 = styled.div `
7114
- cursor: ${({ onClick }) => (onClick ? "pointer" : "default")};
7115
- position: relative;
7116
- width: 100%;
7117
- height: 100%;
7118
- min-height: inherit;
7119
- line-height: 0;
7120
-
7121
- ${uilibGl.LinearProgress} {
7122
- z-index: 3;
7123
- position: absolute;
7124
- }
7125
-
7126
- ${SmallPreviewControl}, ${SmallPreviewCounter} {
7127
- opacity: 0;
7128
- transition: opacity ${uilibGl.transition.hover};
7129
- }
7130
-
7131
- &:hover {
7132
- ${SmallPreviewControl}, ${SmallPreviewCounter} {
7133
- opacity: 1;
7134
- }
7135
- }
7136
-
7137
- img {
7138
- z-index: 0;
7139
- cursor: pointer;
7140
- position: absolute;
7141
- top: 0;
7142
- left: 0;
7143
- width: 100%;
7144
- height: 100%;
7145
- min-height: inherit;
7146
- object-position: center;
7147
- object-fit: cover;
7148
-
7149
- &:nth-child(${({ currentIndex }) => currentIndex}) {
7150
- z-index: 1;
7151
- }
7152
-
7153
- ${({ prevIndex, currentIndex }) => prevIndex !== currentIndex && imgSlideShowMixin}
7154
- }
7100
+ })) `
7101
+ right: 1.5rem;
7102
+ `;
7103
+ const imgSlideShowMixin = styled.css `
7104
+ &:nth-child(${({ prevIndex }) => prevIndex}) {
7105
+ z-index: 2;
7106
+ position: absolute;
7107
+ top: 0;
7108
+ left: 0;
7109
+ right: 0;
7110
+ bottom: 0;
7111
+ opacity: 0;
7112
+
7113
+ animation-duration: 0.25s;
7114
+ animation-name: fadeOut;
7115
+ animation-timing-function: linear;
7116
+
7117
+ @keyframes fadeOut {
7118
+ from {
7119
+ opacity: 1;
7120
+ }
7121
+
7122
+ to {
7123
+ opacity: 0;
7124
+ }
7125
+ }
7126
+ }
7127
+ `;
7128
+ const SmallPreviewContainer$1 = styled.div `
7129
+ cursor: ${({ onClick }) => (onClick ? "pointer" : "default")};
7130
+ position: relative;
7131
+ width: 100%;
7132
+ height: 100%;
7133
+ min-height: inherit;
7134
+ line-height: 0;
7135
+
7136
+ ${uilibGl.LinearProgress} {
7137
+ z-index: 3;
7138
+ position: absolute;
7139
+ }
7140
+
7141
+ ${SmallPreviewControl}, ${SmallPreviewCounter} {
7142
+ opacity: 0;
7143
+ transition: opacity ${uilibGl.transition.hover};
7144
+ }
7145
+
7146
+ &:hover {
7147
+ ${SmallPreviewControl}, ${SmallPreviewCounter} {
7148
+ opacity: 1;
7149
+ }
7150
+ }
7151
+
7152
+ img {
7153
+ z-index: 0;
7154
+ cursor: pointer;
7155
+ position: absolute;
7156
+ top: 0;
7157
+ left: 0;
7158
+ width: 100%;
7159
+ height: 100%;
7160
+ min-height: inherit;
7161
+ object-position: center;
7162
+ object-fit: cover;
7163
+
7164
+ &:nth-child(${({ currentIndex }) => currentIndex}) {
7165
+ z-index: 1;
7166
+ }
7167
+
7168
+ ${({ prevIndex, currentIndex }) => prevIndex !== currentIndex && imgSlideShowMixin}
7169
+ }
7155
7170
  `;
7156
7171
  const SmallPreviewImages = styled.div ``;
7157
7172
 
@@ -7327,21 +7342,21 @@ const ElementChips = React.memo(({ type, elementConfig }) => {
7327
7342
  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))) }));
7328
7343
  });
7329
7344
 
7330
- const StyledIconFontSizeMixin = styled.css `
7331
- height: ${({ fontSize }) => `${fontSize}px`};
7332
-
7333
- &&:after {
7334
- font-size: ${({ fontSize }) => `${fontSize}px`};
7335
- }
7345
+ const StyledIconFontSizeMixin = styled.css `
7346
+ height: ${({ fontSize }) => `${fontSize}px`};
7347
+
7348
+ &&:after {
7349
+ font-size: ${({ fontSize }) => `${fontSize}px`};
7350
+ }
7336
7351
  `;
7337
- const StyledIconFontColorMixin = styled.css `
7338
- &&:after {
7339
- color: ${({ fontColor }) => fontColor};
7340
- }
7352
+ const StyledIconFontColorMixin = styled.css `
7353
+ &&:after {
7354
+ color: ${({ fontColor }) => fontColor};
7355
+ }
7341
7356
  `;
7342
- const StyledIcon = styled(uilibGl.Icon) `
7343
- ${({ fontSize }) => !!fontSize && StyledIconFontSizeMixin};
7344
- ${({ fontColor }) => !!fontColor && StyledIconFontColorMixin};
7357
+ const StyledIcon = styled(uilibGl.Icon) `
7358
+ ${({ fontSize }) => !!fontSize && StyledIconFontSizeMixin};
7359
+ ${({ fontColor }) => !!fontColor && StyledIconFontColorMixin};
7345
7360
  `;
7346
7361
 
7347
7362
  const ElementIcon = React.memo(({ type, elementConfig }) => {
@@ -7395,51 +7410,51 @@ const ElementLegend = React.memo(({ type, element, elementConfig, expandedContai
7395
7410
 
7396
7411
  const ExternalLink = styled(uilibGl.IconButton).attrs(() => ({
7397
7412
  kind: "external_link",
7398
- })) `
7399
- ${uilibGl.Icon} {
7400
- color: ${({ theme: { palette } }) => palette.primary};
7401
- }
7402
-
7403
- &:hover ${uilibGl.Icon} {
7404
- color: ${({ theme: { palette } }) => palette.primaryDeep};
7405
- }
7406
- `;
7407
- const LocalLinkBlank = styled(uilibGl.Blank) `
7408
- min-width: 13.5rem;
7409
- padding: 0.5rem 0.75rem 0;
7410
-
7411
- a {
7412
- text-decoration: none;
7413
- font-size: 0.75rem;
7414
- color: ${({ theme: { palette } }) => palette.primary};
7415
- }
7416
-
7417
- ${uilibGl.IconButtonButton} {
7418
- font-size: 0.75rem;
7419
- }
7413
+ })) `
7414
+ ${uilibGl.Icon} {
7415
+ color: ${({ theme: { palette } }) => palette.primary};
7416
+ }
7417
+
7418
+ &:hover ${uilibGl.Icon} {
7419
+ color: ${({ theme: { palette } }) => palette.primaryDeep};
7420
+ }
7421
+ `;
7422
+ const LocalLinkBlank = styled(uilibGl.Blank) `
7423
+ min-width: 13.5rem;
7424
+ padding: 0.5rem 0.75rem 0;
7425
+
7426
+ a {
7427
+ text-decoration: none;
7428
+ font-size: 0.75rem;
7429
+ color: ${({ theme: { palette } }) => palette.primary};
7430
+ }
7431
+
7432
+ ${uilibGl.IconButtonButton} {
7433
+ font-size: 0.75rem;
7434
+ }
7420
7435
  `;
7421
7436
  const LocalLinkButton = styled(uilibGl.IconButton).attrs(() => ({
7422
7437
  kind: "link",
7423
- })) `
7424
- width: 1rem;
7425
- height: 1rem;
7426
- background-color: ${({ theme: { palette } }) => palette.primary};
7427
- border-radius: 50%;
7428
-
7429
- span[kind] {
7430
- display: flex;
7431
- justify-content: center;
7432
- align-items: center;
7433
-
7434
- :after {
7435
- position: relative;
7436
- font-size: 0.6rem;
7437
- color: white;
7438
- }
7439
- }
7440
- `;
7441
- const LocalLinkCopy = styled(uilibGl.Flex) `
7442
- justify-content: center;
7438
+ })) `
7439
+ width: 1rem;
7440
+ height: 1rem;
7441
+ background-color: ${({ theme: { palette } }) => palette.primary};
7442
+ border-radius: 50%;
7443
+
7444
+ span[kind] {
7445
+ display: flex;
7446
+ justify-content: center;
7447
+ align-items: center;
7448
+
7449
+ :after {
7450
+ position: relative;
7451
+ font-size: 0.6rem;
7452
+ color: white;
7453
+ }
7454
+ }
7455
+ `;
7456
+ const LocalLinkCopy = styled(uilibGl.Flex) `
7457
+ justify-content: center;
7443
7458
  `;
7444
7459
 
7445
7460
  const LocalLink = React.memo(({ link }) => {
@@ -7461,9 +7476,9 @@ const ElementLink = React.memo(({ type, elementConfig }) => {
7461
7476
  return link.startsWith("http") ? jsxRuntime.jsx(ExternalLink, { onClick: () => window.open(link) }) : jsxRuntime.jsx(LocalLink, { link: link });
7462
7477
  });
7463
7478
 
7464
- const SmallPreviewContainer = styled.div `
7465
- width: 100%;
7466
- height: 100%;
7479
+ const SmallPreviewContainer = styled.div `
7480
+ width: 100%;
7481
+ height: 100%;
7467
7482
  `;
7468
7483
 
7469
7484
  const ElementSlideshow = ({ elementConfig, type, renderElement }) => {
@@ -7499,18 +7514,18 @@ const ElementSvg = React.memo(({ type, elementConfig }) => {
7499
7514
  return (jsxRuntime.jsx(SvgImage, { url: getSvgUrl({ elementConfig, layerInfo, attributes }), width: width, height: height, fontColor: fontColor }));
7500
7515
  });
7501
7516
 
7502
- const TooltipIcon = styled(uilibGl.Icon) `
7503
- &&& {
7504
- :after {
7505
- font-size: 0.75rem;
7506
- color: ${({ theme: { palette } }) => palette.iconDisabled};
7507
- transition: color ${uilibGl.transition.hover};
7508
- }
7509
-
7510
- :hover:after {
7511
- color: ${({ theme: { palette } }) => palette.icon};
7512
- }
7513
- }
7517
+ const TooltipIcon = styled(uilibGl.Icon) `
7518
+ &&& {
7519
+ :after {
7520
+ font-size: 0.75rem;
7521
+ color: ${({ theme: { palette } }) => palette.iconDisabled};
7522
+ transition: color ${uilibGl.transition.hover};
7523
+ }
7524
+
7525
+ :hover:after {
7526
+ color: ${({ theme: { palette } }) => palette.icon};
7527
+ }
7528
+ }
7514
7529
  `;
7515
7530
 
7516
7531
  const ElementTooltip = React.memo(({ type, elementConfig }) => {
@@ -7522,76 +7537,76 @@ const ElementTooltip = React.memo(({ type, elementConfig }) => {
7522
7537
  return text ? (jsxRuntime.jsx(uilibGl.Tooltip, { placement: "top", arrow: true, content: text, children: ref => jsxRuntime.jsx(TooltipIcon, { kind: icon || "question", ref: ref }) })) : null;
7523
7538
  });
7524
7539
 
7525
- const SlideshowHeaderWrapper = styled.div `
7526
- padding: ${({ withPadding }) => (withPadding ? "0.5rem 0.5rem 0" : 0)};
7527
-
7528
- ${Header} {
7529
- align-items: flex-start;
7530
- width: calc(100% + 2rem);
7531
- height: ${({ big }) => (big ? "15.5rem" : "auto")};
7532
- padding: 1.5rem;
7533
- margin: -1rem -1rem 0 -1rem;
7534
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
7535
-
7536
- ${SmallPreviewCounter} {
7537
- bottom: ${({ withPadding }) => (withPadding ? 0.625 : 1.125)}rem;
7538
- }
7539
-
7540
- :before,
7541
- :after {
7542
- content: "";
7543
- z-index: 2;
7544
- position: absolute;
7545
- top: 0;
7546
- left: 0;
7547
- width: 100%;
7548
- }
7549
-
7550
- :before {
7551
- height: 100%;
7552
- background: rgba(32, 46, 53, 0.25);
7553
- }
7554
-
7555
- :after {
7556
- height: 4.5rem;
7557
- background: linear-gradient(180deg, #000000 0%, rgba(0, 0, 0, 0) 100%);
7558
- }
7559
-
7560
- :hover {
7561
- ${SmallPreviewControl}, ${SmallPreviewCounter} {
7562
- opacity: 1;
7563
- }
7564
- }
7565
- }
7566
- `;
7567
- const ImageContainerBg = styled.div `
7568
- position: absolute;
7569
- top: 0;
7570
- bottom: 0;
7571
- left: 0;
7572
- right: 0;
7573
-
7574
- img {
7575
- width: 100%;
7576
- height: 100%;
7577
- object-position: center;
7578
- object-fit: cover;
7579
- }
7580
- `;
7581
- const HeaderSlideshow = styled.div `
7582
- position: absolute;
7583
- top: 0;
7584
- bottom: ${({ height }) => (height ? `${height}px` : 0)};
7585
- left: 0;
7586
- right: 0;
7587
-
7588
- img {
7589
- width: 100%;
7590
- height: 100%;
7591
- min-height: inherit;
7592
- object-position: center;
7593
- object-fit: cover;
7594
- }
7540
+ const SlideshowHeaderWrapper = styled.div `
7541
+ padding: ${({ withPadding }) => (withPadding ? "0.5rem 0.5rem 0" : 0)};
7542
+
7543
+ ${Header} {
7544
+ align-items: flex-start;
7545
+ width: calc(100% + 2rem);
7546
+ height: ${({ big }) => (big ? "15.5rem" : "auto")};
7547
+ padding: 1.5rem;
7548
+ margin: -1rem -1rem 0 -1rem;
7549
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
7550
+
7551
+ ${SmallPreviewCounter} {
7552
+ bottom: ${({ withPadding }) => (withPadding ? 0.625 : 1.125)}rem;
7553
+ }
7554
+
7555
+ :before,
7556
+ :after {
7557
+ content: "";
7558
+ z-index: 2;
7559
+ position: absolute;
7560
+ top: 0;
7561
+ left: 0;
7562
+ width: 100%;
7563
+ }
7564
+
7565
+ :before {
7566
+ height: 100%;
7567
+ background: rgba(32, 46, 53, 0.25);
7568
+ }
7569
+
7570
+ :after {
7571
+ height: 4.5rem;
7572
+ background: linear-gradient(180deg, #000000 0%, rgba(0, 0, 0, 0) 100%);
7573
+ }
7574
+
7575
+ :hover {
7576
+ ${SmallPreviewControl}, ${SmallPreviewCounter} {
7577
+ opacity: 1;
7578
+ }
7579
+ }
7580
+ }
7581
+ `;
7582
+ const ImageContainerBg = styled.div `
7583
+ position: absolute;
7584
+ top: 0;
7585
+ bottom: 0;
7586
+ left: 0;
7587
+ right: 0;
7588
+
7589
+ img {
7590
+ width: 100%;
7591
+ height: 100%;
7592
+ object-position: center;
7593
+ object-fit: cover;
7594
+ }
7595
+ `;
7596
+ const HeaderSlideshow = styled.div `
7597
+ position: absolute;
7598
+ top: 0;
7599
+ bottom: ${({ height }) => (height ? `${height}px` : 0)};
7600
+ left: 0;
7601
+ right: 0;
7602
+
7603
+ img {
7604
+ width: 100%;
7605
+ height: 100%;
7606
+ min-height: inherit;
7607
+ object-position: center;
7608
+ object-fit: cover;
7609
+ }
7595
7610
  `;
7596
7611
 
7597
7612
  const FeatureCardSlideshowHeader = ({ isRow }) => {
@@ -9193,6 +9208,9 @@ const Chart = React.memo(({ config, element, elementConfig, type, renderElement
9193
9208
  const formatTooltipValue = React.useCallback((value, name) => isRelated
9194
9209
  ? tooltipValueFromRelatedFeatures(t, value, relatedAttributes, data[0]?.layerInfo)
9195
9210
  : tooltipValueFromAttributes(t, value, name, formattedAttributes), [data, formattedAttributes, isRelated, relatedAttributes]);
9211
+ const customYAxisLeft = React.useCallback(yAxisLeft => {
9212
+ yAxisLeft.tickFormat((index) => index);
9213
+ }, []);
9196
9214
  const customXAxisBottom = React.useCallback((xAxisBottom, data) => {
9197
9215
  xAxisBottom.tickFormat((index) => (showMarkers
9198
9216
  ? index % (showMarkers || 1) === 0
@@ -9246,12 +9264,13 @@ const Chart = React.memo(({ config, element, elementConfig, type, renderElement
9246
9264
  bottom: markers?.length ? 20 : markersMargin,
9247
9265
  left: markersMargin
9248
9266
  };
9249
- return (jsxRuntime.jsx(BarChartWrapper, { height: height + margin.bottom, children: jsxRuntime.jsx(BarChartContainer, { children: jsxRuntime.jsx(StyledBarChart, { data: barChartData, colors: getColorsFromFilterItems(data[0]?.items, defaultColor, formatFilterColor), minValue: getMinValueFromFilterItems(data[0]?.items), markers: markers, width: +width, height: height, barWidth: barWidth, barPadding: padding, className: "dashboardBarChart", customXAxisBottom: xAxisBottom => customXAxisBottom(xAxisBottom, barChartData), customYAxis: axis => !showLabels && axis.remove(), customBars: ({ bars }) => {
9267
+ return (jsxRuntime.jsx(BarChartWrapper, { height: height + margin.bottom, children: jsxRuntime.jsx(BarChartContainer, { children: jsxRuntime.jsx(StyledBarChart, { data: barChartData, colors: getColorsFromFilterItems(data[0]?.items, defaultColor, formatFilterColor), minValue: getMinValueFromFilterItems(data[0]?.items), markers: markers, width: +width, height: height, barWidth: barWidth, barPadding: padding, customYAxisLeft: customYAxisLeft, customXAxisBottom: xAxisBottom => customXAxisBottom(xAxisBottom, barChartData), customYAxis: axis => !showLabels && axis.remove(), customBars: ({ bars }) => {
9250
9268
  bars.attr("rx", radius);
9251
9269
  bars.attr("ry", radius);
9252
9270
  }, margin: margin, xAxisPadding: 0, yAxisPadding: 0, formatTooltipValue: formatTooltipValue, formatTooltipName: formatTooltipName, hideTooltipGroupName: true, dynamicTooltipEnable: true, isBarTooltip: true, onBarClick: filterName ? item => onFilter(item.name) : undefined }) }) }));
9253
9271
  }, [
9254
9272
  customXAxisBottom,
9273
+ customYAxisLeft,
9255
9274
  element,
9256
9275
  isLineChart,
9257
9276
  isStackBar,
@@ -9332,8 +9351,8 @@ const Dashboard = React.memo(({ type = exports.WidgetType.Dashboard, config }) =
9332
9351
  return (jsxRuntime.jsx(ConfigProvider, { config: config, children: jsxRuntime.jsx(PagesContainer, { type: type }) }));
9333
9352
  });
9334
9353
 
9335
- const CardCheckbox = styled(uilibGl.Checkbox) `
9336
- padding-left: 0.5rem;
9354
+ const CardCheckbox = styled(uilibGl.Checkbox) `
9355
+ padding-left: 0.5rem;
9337
9356
  `;
9338
9357
 
9339
9358
  const DashboardCheckbox = ({ title, checked, onChange, }) => {
@@ -9408,15 +9427,15 @@ const FeatureCardTitle = ({ title, description }) => {
9408
9427
  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 })] }));
9409
9428
  };
9410
9429
 
9411
- const HiddenFilters = styled(uilibGl.Flex) `
9412
- flex-wrap: wrap;
9413
- margin-top: -1.25rem;
9414
-
9415
- ${DashboardChip$1} {
9416
- height: 1.5rem;
9417
- margin: 0 0.25rem 0.25rem 0;
9418
- padding: 0 0 0 0.5rem;
9419
- }
9430
+ const HiddenFilters = styled(uilibGl.Flex) `
9431
+ flex-wrap: wrap;
9432
+ margin-top: -1.25rem;
9433
+
9434
+ ${DashboardChip$1} {
9435
+ height: 1.5rem;
9436
+ margin: 0 0.25rem 0.25rem 0;
9437
+ padding: 0 0 0 0.5rem;
9438
+ }
9420
9439
  `;
9421
9440
 
9422
9441
  function spliceValue(filterValue, splicingValue) {
@@ -9486,24 +9505,24 @@ const HiddenTitleItems = React.memo(({ elementConfig, config, type, filter }) =>
9486
9505
  getConfigFilter(filterName, configFilters)?.defaultValue, index)) }));
9487
9506
  });
9488
9507
 
9489
- const PageNavigator = styled(uilibGl.Flex) `
9490
- margin-right: -0.5rem;
9491
- align-items: center;
9492
-
9493
- button {
9494
- width: auto;
9495
- height: 1.5rem;
9496
- padding: 0 0.5rem;
9497
-
9498
- span[kind]:after {
9499
- color: ${({ theme: { palette } }) => palette.textDisabled};
9500
- transition: color ${uilibGl.transition.hover};
9501
- }
9502
-
9503
- :hover span[kind]:after {
9504
- color: ${({ theme: { palette } }) => palette.textSecondary};
9505
- }
9506
- }
9508
+ const PageNavigator = styled(uilibGl.Flex) `
9509
+ margin-right: -0.5rem;
9510
+ align-items: center;
9511
+
9512
+ button {
9513
+ width: auto;
9514
+ height: 1.5rem;
9515
+ padding: 0 0.5rem;
9516
+
9517
+ span[kind]:after {
9518
+ color: ${({ theme: { palette } }) => palette.textDisabled};
9519
+ transition: color ${uilibGl.transition.hover};
9520
+ }
9521
+
9522
+ :hover span[kind]:after {
9523
+ color: ${({ theme: { palette } }) => palette.textSecondary};
9524
+ }
9525
+ }
9507
9526
  `;
9508
9527
 
9509
9528
  const Pagination = React.memo(({ type = exports.WidgetType.Dashboard }) => {
@@ -9512,34 +9531,34 @@ const Pagination = React.memo(({ type = exports.WidgetType.Dashboard }) => {
9512
9531
  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) })] }));
9513
9532
  });
9514
9533
 
9515
- const StyledSvgWidthMixin = styled.css `
9516
- &&& {
9517
- svg {
9518
- width: ${({ $width }) => $width}px;
9519
- }
9520
- }
9521
- `;
9522
- const StyledSvgHeightMixin = styled.css `
9523
- &&& {
9524
- svg {
9525
- height: ${({ $height }) => $height}px;
9526
- }
9527
- }
9528
- `;
9529
- const StyledSvgColorMixin = styled.css `
9530
- svg {
9531
- path,
9532
- line,
9533
- circle {
9534
- fill: ${({ $fontColor }) => $fontColor} !important;
9535
- }
9536
- }
9537
- `;
9538
- const StyledSvg = styled(uilibGl.Flex) `
9539
- align-items: center;
9540
- ${({ $width }) => !!$width && StyledSvgWidthMixin};
9541
- ${({ $height }) => !!$height && StyledSvgHeightMixin};
9542
- ${({ $fontColor }) => !!$fontColor && StyledSvgColorMixin};
9534
+ const StyledSvgWidthMixin = styled.css `
9535
+ &&& {
9536
+ svg {
9537
+ width: ${({ $width }) => $width}px;
9538
+ }
9539
+ }
9540
+ `;
9541
+ const StyledSvgHeightMixin = styled.css `
9542
+ &&& {
9543
+ svg {
9544
+ height: ${({ $height }) => $height}px;
9545
+ }
9546
+ }
9547
+ `;
9548
+ const StyledSvgColorMixin = styled.css `
9549
+ svg {
9550
+ path,
9551
+ line,
9552
+ circle {
9553
+ fill: ${({ $fontColor }) => $fontColor} !important;
9554
+ }
9555
+ }
9556
+ `;
9557
+ const StyledSvg = styled(uilibGl.Flex) `
9558
+ align-items: center;
9559
+ ${({ $width }) => !!$width && StyledSvgWidthMixin};
9560
+ ${({ $height }) => !!$height && StyledSvgHeightMixin};
9561
+ ${({ $fontColor }) => !!$fontColor && StyledSvgColorMixin};
9543
9562
  `;
9544
9563
 
9545
9564
  const SvgImage = React.memo(({ url, width, height, fontColor }) => {
@@ -9757,7 +9776,7 @@ const VectorLayer = ({ layer, tileUrl, visible, beforeId, getLayerTempStyle, })
9757
9776
  return (jsxRuntime.jsx(MapGL.Source, { promoteId: idAttribute, id: layer.name, type: "vector", tiles: [tileUrl], children: clientStyle?.items ? renderClientStyle() : renderLayerByGeometryType() }));
9758
9777
  };
9759
9778
 
9760
- const Layer = ({ layer, layerType, visible, beforeId, tileUrl, getLayerTempStyle, onMount = () => null, }) => {
9779
+ const Layer = ({ layer, layerType, visible, beforeId, tileUrl, getLayerTempStyle, onMount = () => { }, }) => {
9761
9780
  React.useEffect(onMount, []); // eslint-disable-line
9762
9781
  if (!layer) {
9763
9782
  return null;
@@ -9768,28 +9787,28 @@ const Layer = ({ layer, layerType, visible, beforeId, tileUrl, getLayerTempStyle
9768
9787
  return (jsxRuntime.jsx(VectorLayer, { layer: layer, tileUrl: tileUrl, visible: visible, beforeId: beforeId, getLayerTempStyle: getLayerTempStyle }));
9769
9788
  };
9770
9789
 
9771
- const MapWrapper = styled.div `
9772
- position: relative;
9773
- width: 100%;
9774
- height: 100%;
9775
- box-sizing: border-box;
9776
- z-index: ${({ $zIndex }) => $zIndex ?? 1};
9777
-
9778
- .mapbox-gl-draw_trash {
9779
- display: none;
9780
- }
9781
-
9782
- .mapboxgl-ctrl-logo {
9783
- display: none;
9784
- }
9785
-
9786
- .mapboxgl-ctrl.mapboxgl-ctrl-attrib {
9787
- display: none;
9788
- }
9789
-
9790
- .mapboxgl-ctrl-geocoder.mapboxgl-ctrl {
9791
- width: 350px;
9792
- }
9790
+ const MapWrapper = styled.div `
9791
+ position: relative;
9792
+ width: 100%;
9793
+ height: 100%;
9794
+ box-sizing: border-box;
9795
+ z-index: ${({ $zIndex }) => $zIndex ?? 1};
9796
+
9797
+ .mapbox-gl-draw_trash {
9798
+ display: none;
9799
+ }
9800
+
9801
+ .mapboxgl-ctrl-logo {
9802
+ display: none;
9803
+ }
9804
+
9805
+ .mapboxgl-ctrl.mapboxgl-ctrl-attrib {
9806
+ display: none;
9807
+ }
9808
+
9809
+ .mapboxgl-ctrl-geocoder.mapboxgl-ctrl {
9810
+ width: 350px;
9811
+ }
9793
9812
  `;
9794
9813
 
9795
9814
  const Map$1 = ({ zIndex, lowerSiblings, upperSiblings, onError, children, ...rest }) => {
@@ -10031,6 +10050,7 @@ exports.tooltipValueFromAttributes = tooltipValueFromAttributes;
10031
10050
  exports.tooltipValueFromRelatedFeatures = tooltipValueFromRelatedFeatures;
10032
10051
  exports.transparentizeColor = transparentizeColor;
10033
10052
  exports.treeNodesToProjectItems = treeNodesToProjectItems;
10053
+ exports.useAppHeight = useAppHeight;
10034
10054
  exports.useChartChange = useChartChange;
10035
10055
  exports.useChartData = useChartData;
10036
10056
  exports.useDashboardHeader = useDashboardHeader;