@evergis/react 3.1.21 → 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) => {
@@ -4028,8 +4028,8 @@ const useChartChange = ({ dataSources, chartId, width, height, relatedAttributes
4028
4028
  const customize = React.useCallback(({ svg }) => {
4029
4029
  svg.style("overflow", "visible");
4030
4030
  svg
4031
- .selectAll(`.${charts.lineChartClassNames.lineChartXScaleGlobal} line,
4032
- .${charts.lineChartClassNames.lineChartYScaleGlobal} line,
4031
+ .selectAll(`.${charts.lineChartClassNames.lineChartXScaleGlobal} line,
4032
+ .${charts.lineChartClassNames.lineChartYScaleGlobal} line,
4033
4033
  .domain`)
4034
4034
  .each((_, index, nodes) => {
4035
4035
  nodes[index].remove();
@@ -4083,11 +4083,11 @@ const useChartChange = ({ dataSources, chartId, width, height, relatedAttributes
4083
4083
  .attr("fill", `url(#${gradientId})`)
4084
4084
  .attr("stroke-width", "0")
4085
4085
  .attr("fill-opacity", FILL_OPACITY);
4086
- defs.push(`
4087
- <linearGradient id="${gradientId}" x1="0" y1="0" x2="0" y2="1">
4088
- <stop offset="0" stop-color="${color}" stop-opacity="1" />
4089
- <stop offset="1" stop-color="${color}" stop-opacity="0" />
4090
- </linearGradient>
4086
+ defs.push(`
4087
+ <linearGradient id="${gradientId}" x1="0" y1="0" x2="0" y2="1">
4088
+ <stop offset="0" stop-color="${color}" stop-opacity="1" />
4089
+ <stop offset="1" stop-color="${color}" stop-opacity="0" />
4090
+ </linearGradient>
4091
4091
  `);
4092
4092
  ref.current = {
4093
4093
  path: newPath,
@@ -4436,247 +4436,247 @@ const formatDataSourceCondition = ({ condition, configFilters, filters, attribut
4436
4436
  : conditionSection.join(splitter);
4437
4437
  };
4438
4438
 
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
-
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
+
4501
4501
  ${({ isColumn }) => isColumn
4502
- ? styled.css `
4503
- > * {
4504
- width: 100%;
4505
- }
4502
+ ? styled.css `
4503
+ > * {
4504
+ width: 100%;
4505
+ }
4506
4506
  `
4507
- : styled.css `
4508
- flex-direction: row;
4509
- justify-content: space-between;
4510
- align-items: center;
4511
- `}
4512
-
4507
+ : styled.css `
4508
+ flex-direction: row;
4509
+ justify-content: space-between;
4510
+ align-items: center;
4511
+ `}
4512
+
4513
4513
  ${({ isMain, isColumn }) => (isMain || isColumn) &&
4514
- styled.css `
4515
- > :not(:last-child) {
4516
- margin-bottom: 0.5rem;
4517
- }
4518
- `}
4519
-
4514
+ styled.css `
4515
+ > :not(:last-child) {
4516
+ margin-bottom: 0.5rem;
4517
+ }
4518
+ `}
4519
+
4520
4520
  ${({ isTitle }) => isTitle &&
4521
- styled.css `
4522
- &&&& {
4523
- margin-bottom: 0.75rem;
4524
- }
4525
- `}
4526
- `;
4527
- const ContainerAlias = styled(uilibGl.Flex) `
4528
- align-items: center;
4529
- flex-wrap: nowrap;
4530
- margin-bottom: ${({ hasBottomMargin }) => (hasBottomMargin ? 0.25 : 0)}rem;
4531
- font-size: 0.75rem;
4532
- color: ${({ theme: { palette } }) => palette.textSecondary};
4533
-
4534
- span[kind] {
4535
- margin-right: 0.5rem;
4536
-
4537
- :after {
4538
- color: ${({ theme: { palette } }) => palette.primary};
4539
- }
4540
- }
4541
- `;
4542
- const ContainerAliasIcon = styled.div `
4543
- margin-right: 0.5rem;
4544
- `;
4545
- const ContainerChart = styled(uilibGl.Flex) `
4546
- justify-content: flex-start;
4547
-
4548
- > * {
4549
- display: flex;
4550
- justify-content: center;
4551
- width: 100%;
4552
- }
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
+ }
4553
4553
  `;
4554
4554
  const ContainerLegend = styled(uilibGl.Flex) ``;
4555
- const ContainerUnits = styled.div `
4556
- margin-left: 0.5rem;
4557
- white-space: nowrap;
4558
- font-size: 0.75rem;
4559
- `;
4560
- const ContainerValue = styled(uilibGl.Flex) `
4561
- justify-content: flex-end;
4562
- align-items: center;
4563
- flex-wrap: nowrap;
4564
- width: 100%;
4565
- font-size: ${({ big }) => (big ? 1.5 : 1)}rem;
4566
- color: ${({ fontColor, theme: { palette } }) => fontColor || palette.textPrimary};
4567
-
4568
- > * {
4569
- width: ${({ column }) => (column ? "100%" : "auto")};
4570
- }
4571
-
4572
- ${ContainerChart}, ${ContainerLegend} {
4573
- width: ${({ column }) => (column ? "100%" : "50%")};
4574
- }
4575
-
4576
- ${ContainerLegend} {
4577
- margin-left: ${({ column }) => (column ? 0 : "1rem")};
4578
- }
4579
-
4580
- ${ChartLegendContainer} {
4581
- flex-direction: ${({ column }) => (column ? "row" : "column")};
4582
- margin-top: ${({ column }) => (column ? "1rem" : 0)};
4583
- }
4584
- `;
4585
- const ColorIconMixin = styled.css `
4586
- :after {
4587
- color: ${({ $fontColor }) => $fontColor} !important;
4588
- }
4589
- `;
4590
- const SizeIconMixin = styled.css `
4591
- :after {
4592
- font-size: ${({ $fontSize }) => $fontSize}px !important;
4593
- }
4594
- `;
4595
- const ContainerIcon = styled(uilibGl.Icon) `
4596
- width: auto;
4597
- height: auto;
4598
- margin-bottom: 0.5rem;
4599
- ${({ $fontColor }) => !!$fontColor && ColorIconMixin};
4600
- ${({ $fontSize }) => !!$fontSize && SizeIconMixin};
4601
- `;
4602
- const SvgContainerColorMixin$1 = styled.css `
4603
- path,
4604
- line,
4605
- circle {
4606
- fill: ${({ $fontColor }) => $fontColor};
4607
- }
4608
- `;
4609
- const SvgContainer$1 = styled.div `
4610
- &&& {
4611
- min-width: ${({ $width }) => ($width ? `${$width}px` : "1rem")};
4612
- max-width: ${({ $width }) => ($width ? `${$width}px` : "1rem")};
4613
-
4614
- ${({ $fontColor }) => !!$fontColor && SvgContainerColorMixin$1};
4615
-
4616
- > * {
4617
- min-width: inherit;
4618
- }
4619
- }
4620
- `;
4621
- const TwoColumnContainerWrapper = styled(uilibGl.Flex) `
4622
- width: 100%;
4623
- flex-direction: row;
4624
- flex-wrap: nowrap;
4625
- align-items: center;
4626
-
4627
- > * {
4628
- flex: 1;
4629
- }
4630
-
4631
- > ${ContainerValue} {
4632
- justify-content: flex-end;
4633
-
4634
- > * {
4635
- text-align: right;
4636
- }
4637
- }
4638
- `;
4639
-
4640
- const LayerGroupContainer = styled(uilibGl.Flex) `
4641
- display: flex;
4642
- justify-content: center;
4643
- position: relative;
4644
- flex-direction: column;
4645
- padding: 0 0.25rem 0 1rem;
4646
- box-sizing: border-box;
4647
- transition: opacity ${uilibGl.transition.hover}, background-color ${uilibGl.transition.hover};
4648
- font-family: "NunitoSans", sans-serif;
4649
- `;
4650
- const LayerGroupMain = styled(uilibGl.Flex) `
4651
- flex-direction: row;
4652
- flex-wrap: nowrap;
4653
- align-items: center;
4654
- justify-content: space-between;
4655
- width: 100%;
4656
-
4657
- ${uilibGl.Icon} {
4658
- width: 2rem;
4659
- min-width: 2rem;
4660
- height: 2rem;
4661
- display: inline-flex;
4662
- align-items: center;
4663
- justify-content: center;
4664
- margin-right: 0.75rem;
4665
- }
4666
-
4667
- ${uilibGl.Description} {
4668
- display: flex;
4669
- align-items: center;
4670
- flex-grow: 1;
4671
- width: 100%;
4672
- margin-right: 0.25rem;
4673
- color: ${({ theme }) => theme.palette.textPrimary};
4674
- }
4675
-
4676
- button {
4677
- width: 2.25rem;
4678
- justify-content: flex-start;
4679
- }
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
+ }
4680
4680
  `;
4681
4681
 
4682
4682
  const customModes = MapboxDraw.modes;
@@ -4944,6 +4944,19 @@ const useServerNotificationsContext = () => {
4944
4944
  return React.useContext(ServerNotificationsContext);
4945
4945
  };
4946
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
+
4947
4960
  const useDebouncedCallback = (interval) => {
4948
4961
  return React.useMemo(() => debounce((cb) => {
4949
4962
  cb();
@@ -5054,286 +5067,286 @@ const LayerTree = ({ layers, onlyMainTools }) => {
5054
5067
  return (jsxRuntime.jsx(uilibGl.DraggableTree, { nodes: nodes, disableDrag: onlyMainTools, options: { pastePlaceholderHeight: "0.0625rem" }, onUpdate: onUpdate }));
5055
5068
  };
5056
5069
 
5057
- const LayersListWrapper = styled(uilibGl.Flex) `
5058
- flex-direction: column;
5059
- height: 100%;
5060
- width: 100%;
5061
- box-sizing: border-box;
5062
- `;
5063
- const LayerListContainer = styled(uilibGl.Flex) `
5064
- flex-grow: 1;
5065
- height: 100%;
5066
- box-sizing: border-box;
5067
- `;
5068
-
5069
- const ElementValueWrapper = styled.div `
5070
- transition: background-color ${uilibGl.transition.toggle};
5071
- `;
5072
- const ContainerWrapper = styled(uilibGl.Flex) `
5073
- position: relative;
5074
- min-height: 1rem;
5075
- box-sizing: border-box;
5076
- width: 100%;
5077
- background: ${({ theme: { palette } }) => palette.backgroundAlpha};
5078
- box-shadow: rgb(0 0 0 / 15%) 0 0.1875rem 0.625rem;
5079
- padding: 1.5rem;
5080
- border-radius: 0.5rem;
5081
- backdrop-filter: blur(20px);
5082
- color: ${({ theme: { palette } }) => palette.textPrimary};
5083
- z-index: ${({ $zIndex }) => $zIndex ?? 1};
5084
- transition: background-color ${uilibGl.transition.toggle};
5085
-
5086
- ${Container} > ${ElementValueWrapper}:not(:last-child) {
5087
- margin-bottom: 1.5rem;
5088
- }
5089
- `;
5090
- const DashboardChip = styled(uilibGl.Chip) `
5091
- margin: 0 0.25rem 0.25rem 0;
5092
- background: ${({ $isDefault, $bgColor, theme: { palette } }) => $isDefault ? palette.element : $bgColor || palette.primary};
5093
- border-radius: ${({ $radius, theme: { borderRadius } }) => $radius || borderRadius.medium};
5094
- font-size: ${({ $fontSize }) => $fontSize || "0.875rem"};
5095
- color: ${({ $isDefault, $fontColor, theme: { palette } }) => $isDefault ? palette.textPrimary : $fontColor || "#fff"};
5096
-
5097
- > * {
5098
- font-size: ${({ $fontSize }) => $fontSize || "0.875rem"};
5099
- color: ${({ $isDefault, $fontColor, theme: { palette } }) => $isDefault ? palette.textPrimary : $fontColor || "#fff"};
5100
- }
5101
-
5102
- span[kind]:after {
5103
- color: ${({ $isDefault, $fontColor, theme: { palette } }) => ($isDefault ? palette.icon : $fontColor || "#fff")};
5104
- }
5105
- `;
5106
- const DashboardPlaceholderWrap = styled(uilibGl.Flex) `
5107
- flex-grow: 1;
5108
- flex-direction: column;
5109
- justify-content: center;
5110
- align-items: center;
5111
- width: 100%;
5112
- margin-bottom: 2rem;
5113
- `;
5114
- const DashboardPlaceholder = styled(uilibGl.Flex) `
5115
- flex-direction: column;
5116
- justify-content: center;
5117
- align-items: center;
5118
- margin-top: 2rem;
5119
-
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
+
5120
5133
  ${({ isLoading }) => isLoading &&
5121
- styled.css `
5122
- width: 6.25rem;
5123
- `}
5124
- &&& > * {
5125
- margin-bottom: 0;
5126
- }
5127
-
5128
- > div {
5129
- width: 100%;
5130
- margin-top: 1rem;
5131
- font-size: 0.75rem;
5132
- text-align: center;
5133
- color: ${({ theme: { palette } }) => palette.textDisabled};
5134
- }
5135
-
5136
- span[kind] {
5137
- width: 2.25rem;
5138
- height: 2.25rem;
5139
- opacity: 0.28;
5140
-
5141
- :after {
5142
- font-size: 32px;
5143
- }
5144
- }
5145
- `;
5146
- const DashboardWrapper = styled(uilibGl.Flex) `
5147
- flex-direction: column;
5148
- flex-wrap: nowrap;
5149
- flex-grow: 1;
5150
- width: calc(100% - 3rem);
5151
- height: calc(100% - ${LEFT_PANEL_HEADER_HEIGHT});
5152
-
5153
- > ${ContainerWrapper} {
5154
- > * {
5155
- margin-bottom: 2rem;
5156
- }
5157
- }
5158
-
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
+
5159
5172
  ${({ hasImage, isPresentationMode }) => hasImage &&
5160
5173
  !isPresentationMode &&
5161
- styled.css `
5162
- margin-top: -0.35rem;
5163
- `}
5164
- `;
5165
- const DashboardContent = styled(uilibGl.Flex) `
5166
- flex-grow: 1;
5167
- width: 100%;
5168
- padding: 1.5rem 1.5rem 2rem;
5169
- overflow-y: auto;
5170
- scrollbar-gutter: stable;
5171
- `;
5172
- const PresentationWrapperCss = styled.css `
5173
- margin-bottom: 0.75rem;
5174
- padding: 1.5rem;
5175
- background-color: ${({ theme: { palette } }) => palette.panelBackground};
5176
- backdrop-filter: blur(10px);
5177
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
5178
- box-shadow: ${uilibGl.shadows.raised};
5179
- `;
5180
- const PresentationWrapper = styled.div `
5181
- ${PresentationWrapperCss};
5182
- position: relative;
5183
- z-index: 1;
5184
- `;
5185
- const PresentationPanelWrapper = styled(PresentationWrapper) `
5186
- margin-top: 0.75rem;
5187
- transition: background-color ${uilibGl.transition.toggle};
5188
- `;
5189
- const PresentationHeader = styled.div `
5190
- margin: -1.5rem -1.5rem 0 -1.5rem;
5191
- padding: 1.5rem;
5192
- // background: url(images.presentationHeader) 0 0 no-repeat;
5193
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
5194
- transition: background-color ${uilibGl.transition.toggle};
5195
-
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
+
5196
5209
  ${({ image }) => !!image &&
5197
- styled.css `
5198
- padding-top: 7rem;
5199
- `};
5200
- `;
5201
- const PresentationHeaderTools = styled(uilibGl.Flex) `
5202
- justify-content: space-between;
5203
- align-items: center;
5204
- margin-bottom: -0.5rem;
5205
- margin-right: -0.5rem;
5206
-
5207
- span[kind="sun"],
5208
- span[kind="moon"] {
5209
- :after {
5210
- font-size: 0.85rem;
5211
- color: ${({ theme: { palette } }) => palette.iconDisabled};
5212
- }
5213
-
5214
- :hover:after {
5215
- color: ${({ theme: { palette } }) => palette.icon};
5216
- }
5217
- }
5218
- `;
5219
- const LayerGroupList = styled(uilibGl.Flex) `
5220
- flex-direction: column;
5221
- height: 100%;
5222
- flex-wrap: nowrap;
5223
- overflow-x: ${({ $noScroll }) => ($noScroll ? "visible" : "hidden")};
5224
- overflow-y: ${({ $noScroll }) => ($noScroll ? "visible" : "auto")};
5225
- padding: 0 0.125rem 0 0.75rem;
5226
- scrollbar-gutter: stable;
5227
-
5228
- > * {
5229
- flex-grow: 1;
5230
- }
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
+ }
5231
5244
  `;
5232
5245
  const PresentationHeaderButtons = styled(uilibGl.Flex) ``;
5233
- const PresentationPanelContainer = styled.div `
5234
- position: absolute;
5235
- top: 0;
5236
- left: calc(${({ left }) => left || 0}px + 0.75rem);
5237
- bottom: 0;
5238
- z-index: 3;
5239
- display: flex;
5240
- flex-direction: column;
5241
- width: ${LEFT_PANEL_HEADER_HEIGHT}px;
5242
- padding-right: 0.5rem;
5243
- scrollbar-gutter: stable;
5244
- overflow-y: hidden;
5245
-
5246
- :hover {
5247
- overflow-y: auto;
5248
- }
5249
-
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
+
5250
5263
  ${({ showLayers }) => !showLayers &&
5251
- styled.css `
5252
- > :first-child {
5253
- padding-bottom: 0;
5254
- }
5255
- `};
5256
-
5257
- ${PresentationHeader} > * {
5258
- position: relative;
5259
- z-index: 2;
5260
- }
5261
-
5262
- /* PaginationWrapper {
5263
- ${PresentationWrapperCss};
5264
- width: calc(100% - 2rem);
5265
- min-height: 8.625rem;
5266
- padding-top: 0.5rem;
5267
- padding-bottom: 0.5rem;
5268
- margin-bottom: 0.75rem;
5269
- }*/
5270
-
5271
- ${DashboardWrapper} {
5272
- width: 100%;
5273
- margin-top: 0;
5274
-
5275
- ${DashboardContent} {
5276
- padding: 0;
5277
- overflow-y: unset;
5278
-
5279
- > * > ${ContainerWrapper} > * > ${ContainerWrapper} {
5280
- ${PresentationWrapperCss};
5281
- width: calc(100% - 3rem);
5282
- }
5283
- }
5284
- }
5285
-
5286
- ${DashboardPlaceholder} {
5287
- ${PresentationWrapperCss};
5288
- width: 18.5rem;
5289
- height: 10.75rem;
5290
- }
5291
-
5292
- ${LayerListContainer} {
5293
- height: auto;
5294
- margin: 0 -1.125rem -1.5rem;
5295
- padding: 0;
5296
-
5297
- ${LayerGroupList} {
5298
- padding: 0;
5299
- }
5300
- }
5301
- `;
5302
- const DataSourceErrorContainer = styled(uilibGl.Flex) `
5303
- align-items: center;
5304
- justify-content: center;
5305
- flex-wrap: nowrap;
5306
- flex-grow: 1;
5307
- padding: 1rem;
5308
- border: 1px ${({ theme: { palette } }) => palette.element} solid;
5309
- border-radius: 10px;
5310
- font-size: 0.875rem;
5311
- color: ${({ theme: { palette } }) => palette.textDisabled};
5312
-
5313
- span[kind] {
5314
- margin-right: 1rem;
5315
-
5316
- :after {
5317
- color: ${({ theme: { palette } }) => palette.iconDisabled};
5318
- }
5319
- }
5320
- `;
5321
- const AttributeLabel = styled(uilibGl.Description) `
5322
- margin-top: 0 !important;
5323
- margin-bottom: ${({ forCheckbox }) => (forCheckbox ? "0.75rem" : "0.25rem")} !important;
5324
- padding-left: ${({ isEdit }) => (isEdit ? "0.5rem" : "0")};
5325
- `;
5326
- const FeatureControls = styled(uilibGl.Flex) `
5327
- align-items: center;
5328
- gap: 1rem;
5329
- flex-wrap: nowrap;
5330
- position: relative;
5331
- flex-shrink: 0;
5332
-
5333
- button {
5334
- padding: 0;
5335
- width: auto;
5336
- }
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
+ }
5337
5350
  `;
5338
5351
 
5339
5352
  const getAttributeByName = (attributeName, attributes) => {
@@ -5463,10 +5476,10 @@ const TwoColumnContainer = React.memo(({ config, elementConfig, type, renderElem
5463
5476
  return renderAttributes?.length ? (jsxRuntime.jsx(jsxRuntime.Fragment, { children: renderAttributes.map(attribute => renderContainer(elementConfig, attribute)) })) : (renderContainer(elementConfig));
5464
5477
  });
5465
5478
 
5466
- const InnerContainerWrapper = styled.div `
5467
- cursor: ${({ onClick }) => (onClick ? "pointer" : "default")};
5468
- width: ${({ column }) => (column ? "100%" : "auto")};
5469
- 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)};
5470
5483
  `;
5471
5484
 
5472
5485
  const DataSourceInnerContainer = React.memo(({ config, elementConfig, feature, maxValue, type, index, innerComponent }) => {
@@ -5537,107 +5550,107 @@ const DataSourceInnerContainer = React.memo(({ config, elementConfig, feature, m
5537
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 }) }));
5538
5551
  });
5539
5552
 
5540
- const DataSourceProgressContainerWrapper = styled.div `
5541
- width: 100%;
5542
- `;
5543
- const ContainerToggler = styled(uilibGl.LegendToggler) `
5544
- width: auto;
5545
- margin-left: -1rem;
5546
- `;
5547
-
5548
- const ProgressContainerWrapper = styled(uilibGl.Flex) `
5549
- align-items: center;
5550
- width: 100%;
5551
- margin-bottom: 1rem;
5552
- `;
5553
- const ProgressIcon = styled.div `
5554
- margin-right: 0.5rem;
5555
- `;
5556
- const ProgressContent = styled(uilibGl.Flex) `
5557
- flex: 1;
5558
- flex-direction: column;
5559
- `;
5560
- const ProgressAlias = styled(uilibGl.Flex) `
5561
- flex: 1;
5562
- justify-content: space-between;
5563
- margin-bottom: 0.25rem;
5564
- font-size: 0.75rem;
5565
- color: ${({ theme: { palette } }) => palette.textSecondary};
5566
- `;
5567
- const ProgressValue = styled(uilibGl.Flex) `
5568
- align-items: center;
5569
- width: auto;
5570
- font-size: 1rem;
5571
- color: ${({ theme: { palette } }) => palette.textPrimary};
5572
- `;
5573
- const ProgressInnerValue = styled(ProgressValue) `
5574
- justify-content: flex-end;
5575
- width: 4rem;
5576
- margin-left: 0.5rem;
5577
- `;
5578
- const ProgressUnits = styled(uilibGl.Flex) `
5579
- margin-left: 0.25rem;
5580
- font-size: 0.75rem;
5581
- color: ${({ theme: { palette } }) => palette.textSecondary};
5582
- `;
5583
- const ProgressBarWrapper = styled.div `
5584
- flex-grow: 1;
5585
- height: 0.5rem;
5586
- background-color: ${({ theme: { palette } }) => palette.element};
5587
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.xSmall};
5588
- `;
5589
- const ProgressBarContainer = styled(uilibGl.Flex) `
5590
- position: relative;
5591
- align-items: center;
5592
- width: 100%;
5593
-
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
+
5594
5607
  ${({ innerValue }) => innerValue &&
5595
- styled.css `
5596
- ${ProgressBarWrapper} {
5597
- height: 1.125rem;
5598
- }
5599
-
5600
- ${ProgressInnerValue} {
5601
- z-index: 1;
5602
- position: absolute;
5603
- right: 0.25rem;
5604
- }
5605
- `}
5606
- `;
5607
- const ProgressBar = styled.div `
5608
- width: ${({ $width }) => $width};
5609
- height: inherit;
5610
- background-color: ${({ $color }) => $color || "#a7d759"};
5611
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.xSmall};
5612
- `;
5613
- const ProgressTooltipAlias = styled.div `
5614
- margin-bottom: 0.25rem;
5615
- text-align: left;
5616
- 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};
5617
5630
  `;
5618
5631
  const ProgressTooltipValue = styled.div ``;
5619
- const ProgressTooltipValueContainer = styled(uilibGl.Flex) `
5620
- align-items: center;
5621
-
5622
- > * {
5623
- opacity: 0.65;
5624
- }
5625
-
5626
- ${ProgressTooltipValue} {
5627
- opacity: 1;
5628
- }
5629
- `;
5630
- const ProgressTooltipValueOf = styled.div `
5631
- margin: 0 0.25rem;
5632
- `;
5633
- const ProgressTotalTitle = styled.div `
5634
- font-size: 0.75rem;
5635
- font-weight: bold;
5636
- `;
5637
- const ProgressTotal = styled(uilibGl.Flex) `
5638
- align-items: center;
5639
- justify-content: space-between;
5640
- 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;
5641
5654
  `;
5642
5655
 
5643
5656
  const DataSourceProgressContainer = React.memo(({ config, elementConfig, type, innerComponent, renderElement }) => {
@@ -5734,166 +5747,166 @@ const DEFAULT_BAR_CHART_MARGINS = {
5734
5747
  right: 0,
5735
5748
  };
5736
5749
 
5737
- const FiltersContainerWrapper = styled(uilibGl.Flex) `
5738
- flex-direction: column;
5739
- padding: ${({ $padding }) => $padding ?? "0.75rem"};
5740
- background-color: ${({ $bgColor, $fontColor, theme: { palette } }) => $bgColor || ($fontColor ? transparentizeColor($fontColor, 6) : palette.element)};
5741
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
5742
-
5743
- ${uilibGl.DropdownField}, input {
5744
- background-color: ${({ theme: { palette } }) => palette.background};
5745
- }
5746
-
5747
- > div:not(:last-child) {
5748
- margin-bottom: 0.5rem;
5749
- }
5750
-
5751
- > label {
5752
- align-items: flex-start;
5753
- font-size: ${({ $fontSize }) => $fontSize || "0.875rem"};
5754
-
5755
- &.active {
5756
- color: ${({ $fontColor }) => $fontColor};
5757
-
5758
- svg rect {
5759
- fill: ${({ $fontColor }) => $fontColor} !important;
5760
- }
5761
- }
5762
-
5763
- &:not(:last-child) {
5764
- margin-bottom: 0.75rem;
5765
- }
5766
-
5767
- &:last-child {
5768
- margin-bottom: 0;
5769
- }
5770
- }
5771
- `;
5772
- const StyledIconButton = styled(uilibGl.IconButton) `
5773
- width: 0.75rem;
5774
- height: 0.75rem;
5775
-
5776
- span[kind] {
5777
- height: 0.75rem;
5778
-
5779
- :after {
5780
- font-size: 0.75rem;
5781
- }
5782
- }
5783
- `;
5784
- const TextFilterContainer = styled.div `
5785
- width: 15.85rem;
5786
-
5787
- ${uilibGl.MultiSelectContainer} {
5788
- color: ${({ theme: { palette } }) => palette.textPrimary};
5789
-
5790
- ${uilibGl.IconButtonButton} {
5791
- span[kind]:after {
5792
- color: ${({ theme: { palette } }) => palette.textPrimary};
5793
- }
5794
- }
5795
- }
5796
- `;
5797
- const BarChartContainer = styled.div `
5798
- width: 100%;
5799
- overflow-x: hidden;
5800
-
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
+
5801
5814
  ${({ barHeight, marginBottom }) => !!barHeight &&
5802
- styled.css `
5803
- .barChartBarGlobal rect {
5804
- height: ${barHeight}px;
5805
- y: calc(100% - ${barHeight + marginBottom}px);
5806
- }
5807
- `}
5808
- `;
5809
- const AnyChartWrapper = styled.div `
5810
- width: 100%;
5811
- height: ${({ height }) => height}px;
5812
- `;
5813
- const BarChartWrapper = styled(AnyChartWrapper) `
5814
- width: 100%;
5815
- margin: 0 auto ${BAR_CHART_FOOTER_MARGIN}px;
5816
-
5817
- :hover {
5818
- ${BarChartContainer} {
5819
- overflow-x: auto;
5820
- }
5821
- }
5822
- `;
5823
- const BarChartFilterHeader = styled(uilibGl.Flex) `
5824
- justify-content: space-between;
5825
- align-items: center;
5826
- height: ${({ height }) => `calc(${typeof height === "number" ? `${height}px` : height} - 0.5rem)`};
5827
- padding: 0.25rem 0;
5828
- `;
5829
- const BarChartFilterArrows = styled(uilibGl.Flex) `
5830
- margin-left: -0.5rem;
5831
-
5832
- span[kind] {
5833
- display: flex;
5834
- align-items: center;
5835
-
5836
- :after {
5837
- font-size: 0.75rem;
5838
- }
5839
- }
5840
- `;
5841
- const BarChartFilterSelected = styled.div `
5842
- font-size: 0.75rem;
5843
- font-weight: bold;
5844
- color: ${({ theme: { palette } }) => palette.textPrimary};
5845
- `;
5846
- styled.div `
5847
- color: ${({ theme: { palette } }) => palette.textSecondary};
5848
- `;
5849
- const BarChart = styled(charts.BarChart) `
5850
- .${charts.barChartClassNames.barChartXAxis} {
5851
- .domain,
5852
- line {
5853
- display: none;
5854
- }
5855
-
5856
- .tick {
5857
- text {
5858
- text-anchor: start;
5859
- font-size: 12px;
5860
- color: rgba(48, 69, 79, 0.46);
5861
- }
5862
-
5863
- :last-of-type {
5864
- text {
5865
- text-anchor: end;
5866
- }
5867
- }
5868
- }
5869
- }
5870
-
5871
- .marker {
5872
- font-size: 12px;
5873
- }
5874
- `;
5875
- const TooltipContainer = styled.div `
5876
- position: relative;
5877
- font-size: 0.75rem;
5878
- color: #ffffff;
5879
- margin-bottom: 0.5rem;
5880
- padding: 0.375rem;
5881
- background-color: rgba(0, 0, 0, 1);
5882
- border-radius: 0.25rem;
5883
- box-shadow: 0 0.1875rem 0.5rem rgba(48, 69, 79, 0.06);
5884
-
5885
- :before {
5886
- content: "";
5887
- position: absolute;
5888
- bottom: 0;
5889
- left: 50%;
5890
- transform: translate(-50%, 100%);
5891
- width: 0;
5892
- height: 0;
5893
- border-style: solid;
5894
- border-width: 0.25rem 0.1875rem 0 0.1875rem;
5895
- border-color: rgba(48, 69, 79, 1) transparent transparent transparent;
5896
- }
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
+ }
5897
5910
  `;
5898
5911
 
5899
5912
  const FiltersContainer = React.memo(({ elementConfig, config, type, renderElement }) => {
@@ -5973,117 +5986,117 @@ const TwoColumnsInnerContainer = React.memo(({ renderElement }) => {
5973
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" })] }));
5974
5987
  });
5975
5988
 
5976
- const ImageContainerBg$1 = styled.div `
5977
- position: absolute;
5978
- top: 0;
5979
- bottom: 0;
5980
- left: 0;
5981
- right: 0;
5982
-
5983
- img {
5984
- width: 100%;
5985
- height: 100%;
5986
- object-position: center;
5987
- object-fit: cover;
5988
- }
5989
- `;
5990
- const ImageContainerTitle = styled.div `
5991
- width: 100%;
5992
- overflow-wrap: break-word;
5993
- font-size: 1rem;
5994
- font-weight: 500;
5995
- `;
5996
- const ImageContainerText = styled.div `
5997
- width: 100%;
5998
- overflow-wrap: break-word;
5999
- margin-top: 0.5rem;
6000
- font-size: 0.75rem;
6001
- `;
6002
- const ImageContainerButton$1 = styled(uilibGl.FlatButton) `
6003
- min-height: 1.5rem;
6004
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.large};
6005
- background-color: ${({ theme: { palette } }) => palette.primary};
6006
- text-transform: none;
6007
-
6008
- :hover {
6009
- background-color: ${({ theme: { palette } }) => palette.primaryDeep};
6010
- }
6011
- `;
6012
- const ImageContainerWrapper = styled(uilibGl.Flex) `
6013
- flex-direction: column;
6014
- justify-content: flex-end;
6015
- position: relative;
6016
- padding: 1rem;
6017
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
6018
- overflow: hidden;
6019
-
6020
- ${ImageContainerTitle}, ${ImageContainerText}, ${ImageContainerButton$1} {
6021
- z-index: 1;
6022
- color: ${({ theme: { palette } }) => palette.textContrast};
6023
- }
6024
-
6025
- :after {
6026
- content: "";
6027
- position: absolute;
6028
- top: 0;
6029
- bottom: 0;
6030
- left: 0;
6031
- right: 0;
6032
- background-color: rgba(0, 0, 0, 0.4);
6033
- }
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
+ }
6034
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
+ }
6035
6037
 
6036
- const ImageContainer = React.memo(({ elementConfig, renderElement }) => {
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
+ }
6047
+ `;
6048
+
6049
+ const ImageContainer = React.memo(({ elementConfig, renderElement }) => {
6037
6050
  const { style } = elementConfig || {};
6038
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" }) })] }));
6039
6052
  });
6040
6053
 
6041
- const IconContainerWrapper = styled(uilibGl.Flex) `
6042
- flex-direction: column;
6043
- justify-content: center;
6044
- position: relative;
6045
- padding: 0.5rem 1rem 1rem;
6046
- background-color: ${({ theme: { palette } }) => palette.element};
6047
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
6048
- overflow: hidden;
6049
- `;
6050
- const IconContainerHeaderWrapper = styled(uilibGl.Flex) `
6051
- justify-content: space-between;
6052
- align-items: center;
6053
- flex-wrap: nowrap;
6054
- width: 100%;
6055
- margin-bottom: 0.25rem;
6056
- `;
6057
- const IconContainerHeader = styled(uilibGl.Flex) `
6058
- align-items: center;
6059
- flex-wrap: nowrap;
6060
- width: 100%;
6061
- margin-right: 0.5rem;
6062
- font-size: 0.875rem;
6063
-
6064
- ${uilibGl.Icon} {
6065
- margin-right: 0.5rem;
6066
-
6067
- :after {
6068
- font-size: 1.15rem;
6069
- color: ${({ theme: { palette } }) => palette.textSecondary};
6070
- }
6071
- }
6072
- `;
6073
- const IconContainerTitle = styled(uilibGl.Flex) `
6074
- > * {
6075
- width: 13rem;
6076
- white-space: nowrap;
6077
- overflow: hidden;
6078
- font-weight: bold;
6079
- text-overflow: ellipsis;
6080
- }
6081
- `;
6082
- const IconContainerText = styled.div `
6083
- width: 100%;
6084
- overflow-wrap: break-word;
6085
- font-size: 0.75rem;
6086
- 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};
6087
6100
  `;
6088
6101
 
6089
6102
  const IconContainer = React.memo(({ elementConfig, renderElement }) => {
@@ -6105,83 +6118,83 @@ const DataSourceContainer = React.memo(({ config, elementConfig, type, innerComp
6105
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, {}))] }));
6106
6119
  });
6107
6120
 
6108
- const SvgContainerColorMixin = styled.css `
6109
- path,
6110
- line,
6111
- circle {
6112
- fill: ${({ $fontColor }) => $fontColor};
6113
- }
6114
- `;
6115
- const SvgContainer = styled.div `
6116
- &&& {
6117
- min-width: ${({ $width }) => ($width ? `${$width}px` : "1rem")};
6118
- max-width: ${({ $width }) => ($width ? `${$width}px` : "1rem")};
6119
-
6120
- ${({ $fontColor }) => !!$fontColor && SvgContainerColorMixin};
6121
-
6122
- > * {
6123
- min-width: inherit;
6124
- }
6125
- }
6126
- `;
6127
-
6128
- const ContainerIconTitle = styled(uilibGl.Flex) `
6129
- align-items: center;
6130
- flex-wrap: nowrap;
6131
- color: ${({ fontColor, theme: { palette } }) => fontColor || palette.textSecondary};
6132
-
6133
- svg,
6134
- img,
6135
- span[kind],
6136
- ${SvgContainer} {
6137
- margin-right: 0.5rem;
6138
- }
6139
-
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
+
6140
6153
  ${({ fontColor }) => !!fontColor &&
6141
- styled.css `
6142
- span[kind] {
6143
- color: ${fontColor};
6144
- }
6145
-
6146
- ${SvgContainer} {
6147
- path,
6148
- circle {
6149
- fill: ${fontColor};
6150
- }
6151
- }
6152
- `};
6153
-
6154
- ${uilibGl.LegendToggler} {
6155
- margin-left: 0.25rem;
6156
- }
6157
- `;
6158
- const ContainerTitle = styled(uilibGl.Flex) `
6159
- align-items: center;
6160
- justify-content: space-between;
6161
- width: 100%;
6162
-
6163
- > * {
6164
- font-size: 1.125rem;
6165
- font-weight: 500;
6166
- }
6167
-
6168
- ${uilibGl.LegendToggler} {
6169
- padding-right: 0;
6170
- }
6171
-
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
+
6172
6185
  ${({ simple }) => simple &&
6173
- styled.css `
6174
- justify-content: flex-start;
6175
-
6176
- ${ContainerIconTitle} {
6177
- font-size: 0.75rem;
6178
- }
6179
-
6180
- ${uilibGl.LegendToggler} {
6181
- margin-left: 0;
6182
- padding-left: 0.25rem;
6183
- }
6184
- `}
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
+ `}
6185
6198
  `;
6186
6199
 
6187
6200
  const TitleContainer = React.memo(({ containerId, templateName, layerNames, fontColor, expandable, expanded, isVisible, elementConfig, renderElement, type, }) => {
@@ -6208,9 +6221,9 @@ const TitleContainer = React.memo(({ containerId, templateName, layerNames, font
6208
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] }) }));
6209
6222
  });
6210
6223
 
6211
- const ContainerDivider = styled(uilibGl.Divider) `
6212
- width: 100%;
6213
- 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};
6214
6227
  `;
6215
6228
 
6216
6229
  const DividerContainer = React.memo(({ elementConfig, config }) => {
@@ -6263,82 +6276,82 @@ const CameraContainer = React.memo(({ elementConfig, type, renderElement }) => {
6263
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 }) })] }))] }));
6264
6277
  });
6265
6278
 
6266
- const TabAnchor = styled.div `
6267
- position: absolute;
6268
- top: -1.5rem;
6269
- right: 0;
6270
- `;
6271
- const TabValue = styled(uilibGl.Flex) `
6272
- flex-wrap: nowrap;
6273
- `;
6274
- const noBgMixin = styled.css `
6275
- background-color: transparent;
6276
- border-radius: 0;
6277
- border-bottom: 0.125rem solid
6278
- ${({ active, bgColor, theme: { palette } }) => (active ? bgColor || palette.primary : palette.element)};
6279
-
6280
- ${TabValue},
6281
- span[kind] {
6282
- color: ${({ active, bgColor, theme: { palette } }) => active ? bgColor || palette.primary : palette.textSecondary};
6283
- }
6284
-
6285
- &&& svg {
6286
- path,
6287
- line,
6288
- circle {
6289
- fill: ${({ active, bgColor, theme: { palette } }) => active ? bgColor || palette.primary : palette.textSecondary};
6290
- }
6291
- }
6292
-
6293
- :not(:last-child) {
6294
- margin-right: 0;
6295
- }
6296
- `;
6297
- const TabContainer = styled.a `
6298
- display: flex;
6299
- flex-direction: ${({ column }) => (column ? "column" : "row")};
6300
- align-items: center;
6301
- justify-content: center;
6302
- flex-wrap: nowrap;
6303
- padding: ${({ onlyIcon }) => (onlyIcon ? 1 : 0.5)}rem 1rem;
6304
- background-color: ${({ active, bgColor, theme: { palette } }) => active ? bgColor || palette.primary : palette.element};
6305
- border-radius: ${({ column, radius, theme: { borderRadius } }) => radius ? `${radius}px` : column ? borderRadius.medium : borderRadius.xLarge};
6306
- text-decoration: none;
6307
-
6308
- :not(:last-child) {
6309
- margin-right: 0.5rem;
6310
- }
6311
-
6312
- ${TabValue} {
6313
- margin-top: ${({ column }) => (column ? 0.5 : 0)}rem;
6314
- margin-left: ${({ column, hasIcon }) => (column || !hasIcon ? 0 : 0.5)}rem;
6315
- font-size: ${({ column }) => (column ? 0.75 : 0.875)}rem;
6316
- white-space: nowrap;
6317
- }
6318
-
6319
- ${TabValue},
6320
- span[kind] {
6321
- color: ${({ active, theme: { palette } }) => (active ? palette.textContrast : palette.textSecondary)};
6322
- }
6323
-
6324
- ${SvgContainer$1} {
6325
- height: 1rem;
6326
- }
6327
-
6328
- svg,
6329
- img {
6330
- max-width: 1rem;
6331
- max-height: 1rem;
6332
- }
6333
-
6334
- ${({ noBg }) => noBg && noBgMixin};
6335
- `;
6336
- const SwiperContainer = styled.div `
6337
- width: 100%;
6338
-
6339
- .swiper-wrapper {
6340
- display: flex;
6341
- }
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
+ }
6342
6355
  `;
6343
6356
 
6344
6357
  const TabsContainer = React.memo(({ elementConfig, type }) => {
@@ -6366,96 +6379,96 @@ const TabsContainer = React.memo(({ elementConfig, type }) => {
6366
6379
  });
6367
6380
 
6368
6381
  const ContainerIconValue = styled(uilibGl.Flex) ``;
6369
- const RoundedBackgroundContainerWrapper = styled(uilibGl.Flex) `
6370
- position: relative;
6371
- flex-direction: ${({ $bigIcon }) => ($bigIcon ? "row" : "column")};
6372
- width: 9rem;
6373
- padding: 0.75rem 0.75rem 0.5rem;
6374
- background-color: ${({ theme: { palette } }) => palette.element};
6375
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.large};
6376
- flex-wrap: nowrap;
6377
-
6378
- && {
6379
- margin-bottom: 0.5rem;
6380
- }
6381
-
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
+
6382
6395
  ${({ $center }) => $center &&
6383
- styled.css `
6384
- align-items: center;
6385
-
6386
- > * {
6387
- display: flex;
6388
- justify-content: center;
6389
- text-align: center;
6390
- width: 100%;
6391
- }
6392
- `};
6393
-
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
+
6394
6407
  ${({ $color }) => $color &&
6395
- styled.css `
6396
- background-color: ${transparentizeColor($color, 6)};
6397
-
6398
- * {
6399
- color: ${$color};
6400
- }
6401
- `};
6402
-
6403
- ${ContainerIcon}, ${SvgContainer$1} {
6404
- margin-bottom: 0.25rem;
6405
- }
6406
-
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
+
6407
6420
  ${({ $bigIcon }) => $bigIcon &&
6408
- styled.css `
6409
- ${ContainerIcon}, ${SvgContainer$1} {
6410
- position: absolute;
6411
- top: 0.75rem;
6412
- right: 0.75rem;
6413
- width: 3rem;
6414
- opacity: 0.12;
6415
-
6416
- :after {
6417
- font-size: 3rem;
6418
- }
6419
- }
6420
- `};
6421
-
6422
- ${ContainerIconValue} {
6423
- align-items: center;
6424
- flex-direction: column;
6425
-
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
+
6426
6439
  ${({ $big }) => $big &&
6427
- styled.css `
6428
- flex-direction: row;
6429
- margin-bottom: 0.5rem;
6430
-
6431
- > * {
6432
- text-align: left;
6433
- }
6434
-
6435
- span[kind] {
6436
- margin-right: 0.5rem;
6437
- }
6438
-
6439
- ${ContainerValue} {
6440
- width: auto;
6441
- }
6442
- `};
6443
- }
6444
-
6445
- ${ContainerValue} {
6446
- flex-direction: ${({ $inlineUnits }) => ($inlineUnits ? "row" : "column")};
6447
- justify-content: ${({ $big }) => ($big ? "flex-start" : "flex-end")};
6448
- align-items: ${({ $inlineUnits }) => ($inlineUnits ? "center" : "flex-start")};
6449
- line-height: 1;
6450
- }
6451
-
6452
- ${ContainerUnits} {
6453
- margin-left: ${({ $inlineUnits }) => ($inlineUnits ? "0.25rem" : 0)};
6454
- }
6455
-
6456
- ${ContainerAlias} {
6457
- margin-top: 0.25rem;
6458
- }
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
+ }
6459
6472
  `;
6460
6473
 
6461
6474
  const ALIAS_DEFAULT_MAX_LENGTH = 28;
@@ -6494,20 +6507,20 @@ const AddFeatureContainer = React.memo(({ elementConfig }) => {
6494
6507
  .map(({ options }, index) => (jsxRuntime.jsx(AddFeatureButton, { icon: options?.icon, title: options?.title, layerName: options?.layerName, geometryType: options?.geometryType }, index))) }));
6495
6508
  });
6496
6509
 
6497
- const LayersContainerWrapper = styled(Container) `
6498
- ${uilibGl.DraggableTreeContainer} {
6499
- width: calc(100% + 3rem);
6500
- margin: -0.75rem -1.5rem 0;
6501
- }
6502
-
6503
- ${LayerListContainer} {
6504
- height: auto;
6505
- }
6506
-
6507
- ${LayerGroupList} {
6508
- margin: ${({ isPresentationMode }) => (isPresentationMode ? 0 : "0 -1.25rem 0 -1rem")};
6509
- padding: 0;
6510
- }
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
+ }
6511
6524
  `;
6512
6525
 
6513
6526
  const LayersContainer = React.memo(({ type, elementConfig, renderElement }) => {
@@ -6555,99 +6568,99 @@ const getContainerComponent = (innerTemplateName) => innerTemplateName ? contain
6555
6568
  var img$3 = "";
6556
6569
 
6557
6570
  const getMaskColor = (isDark) => (isDark ? "0, 0, 0" : "255, 255, 255");
6558
- const DefaultHeaderContainer = styled(uilibGl.Flex) `
6559
- flex-direction: column;
6560
- position: relative;
6561
- flex-shrink: 0;
6562
- min-height: 8.375rem;
6563
- margin-bottom: -1.5rem;
6564
- padding: 1.5rem 1.5rem 0;
6565
- border-top-left-radius: 0.5rem;
6566
- border-top-right-radius: 0.5rem;
6567
- overflow: hidden;
6568
-
6569
- > * {
6570
- z-index: 1;
6571
- }
6572
-
6573
- &::before {
6574
- content: "";
6575
- position: absolute;
6576
- top: 0;
6577
- left: 0;
6578
- width: 100%;
6579
- height: 100%;
6580
-
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
+
6581
6594
  ${({ image, isDark }) => image
6582
- ? styled.css `
6583
- background: url(${image}) 0 0 no-repeat;
6584
- background-size: cover;
6595
+ ? styled.css `
6596
+ background: url(${image}) 0 0 no-repeat;
6597
+ background-size: cover;
6585
6598
  `
6586
- : styled.css `
6587
- background: url(${img$3}) 50% 0 no-repeat;
6588
- opacity: ${isDark ? 1 : 0.5};
6589
- `}
6590
- }
6591
-
6599
+ : styled.css `
6600
+ background: url(${img$3}) 50% 0 no-repeat;
6601
+ opacity: ${isDark ? 1 : 0.5};
6602
+ `}
6603
+ }
6604
+
6592
6605
  ${({ image, isDark }) => image &&
6593
- styled.css `
6594
- &::before {
6595
- -webkit-mask-image: linear-gradient(
6596
- to bottom,
6597
- rgba(${getMaskColor(isDark)}, 1),
6598
- rgba(${getMaskColor(isDark)}, 0)
6599
- );
6600
- mask-image: linear-gradient(to bottom, rgba(${getMaskColor(isDark)}, 1), rgba(${getMaskColor(isDark)}, 0));
6601
- }
6602
- `}
6603
- ${uilibGl.LinearProgress} {
6604
- position: absolute;
6605
- top: 0;
6606
- left: 0;
6607
- }
6608
- `;
6609
- const TopContainer = styled(uilibGl.Flex) `
6610
- z-index: 1;
6611
- position: relative;
6612
- justify-content: space-between;
6613
- flex-wrap: nowrap;
6614
- width: 100%;
6615
- align-items: flex-start;
6616
- `;
6617
- const TopContainerButtons = styled(uilibGl.Flex) `
6618
- align-items: center;
6619
- width: auto;
6620
- margin-right: -0.5rem;
6621
-
6622
- button {
6623
- width: auto;
6624
- height: 1rem;
6625
- padding: 0 0.5rem;
6626
- }
6627
- `;
6628
- const LogoContainer = styled(uilibGl.Flex) `
6629
- max-width: calc(100% - 1.4rem);
6630
- flex-grow: 1;
6631
- font-size: 0;
6632
-
6633
- & > span::after {
6634
- font-size: 2rem;
6635
- }
6636
-
6637
- img {
6638
- max-height: 1.875rem;
6639
- }
6640
- `;
6641
- const PageTitle = styled(uilibGl.H2) `
6642
- display: -webkit-box;
6643
- -webkit-line-clamp: 3;
6644
- -webkit-box-orient: vertical;
6645
- overflow: hidden;
6646
- margin: 0;
6647
- font-size: 1.25rem;
6648
- font-weight: 600;
6649
- pointer-events: initial;
6650
- 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;
6651
6664
  `;
6652
6665
 
6653
6666
  exports.ThemeName = void 0;
@@ -6673,81 +6686,81 @@ const DashboardDefaultHeader = React.memo(() => {
6673
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, {}) })] }) }) }) })] })] }));
6674
6687
  });
6675
6688
 
6676
- const HeaderFrontView = styled(uilibGl.Flex) `
6677
- z-index: 10;
6678
- position: relative;
6679
- justify-content: space-between;
6680
- align-items: ${({ isDefault }) => (isDefault ? "center" : "flex-start")};
6681
- width: 100%;
6682
- font: ${({ theme: { fonts } }) => fonts.subtitle};
6683
- `;
6684
- const HeaderContainer = styled(uilibGl.FlexSpan) `
6685
- display: flex;
6686
- flex-grow: 1;
6687
- flex-wrap: nowrap;
6688
- width: calc(100% - 48px);
6689
- `;
6690
- const FeatureTitleContainer = styled.div `
6691
- display: -webkit-box;
6692
- max-width: 100%;
6693
- width: 100%;
6694
- margin: 0.5rem 0;
6695
- -webkit-line-clamp: 2;
6696
- -webkit-box-orient: vertical;
6697
- overflow: hidden;
6698
- text-overflow: ellipsis;
6699
- color: ${({ theme: { palette } }) => palette.textPrimary};
6700
-
6701
- & > ${uilibGl.FlexSpan} {
6702
- cursor: ${({ clickable }) => clickable && "pointer"};
6703
-
6704
- &:hover {
6705
- color: ${({ clickable, theme: { palette } }) => clickable && palette.primary};
6706
- }
6707
- }
6708
- `;
6709
- const LayerDescription = styled(uilibGl.Description) `
6710
- width: calc(100% - 4rem);
6711
- display: -webkit-box;
6712
- -webkit-line-clamp: 2;
6713
- -webkit-box-orient: vertical;
6714
- overflow: hidden;
6715
- text-overflow: ellipsis;
6716
- `;
6717
- const HeaderTitleContainer = styled(uilibGl.Flex) `
6718
- flex-direction: column;
6719
- width: 100%;
6720
- `;
6721
- const RowHeaderMixin = styled.css `
6722
- &&& {
6723
- min-height: auto;
6724
-
6725
- ${FeatureTitleContainer}, ${LayerDescription} {
6726
- text-align: left;
6727
- }
6728
- }
6729
-
6730
- ${HeaderContainer} {
6731
- flex-direction: row;
6732
- }
6733
-
6734
- ${FeatureTitleContainer} {
6735
- max-width: calc(100% - 3.8rem);
6736
- }
6737
- `;
6738
- const Header = styled(uilibGl.Flex) `
6739
- z-index: 1;
6740
- position: relative;
6741
- top: 0;
6742
- flex-shrink: 0;
6743
- overflow: hidden;
6744
- padding: 0.5rem;
6745
-
6746
- ${HeaderContainer} {
6747
- flex-direction: column;
6748
- }
6749
-
6750
- ${({ $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};
6751
6764
  `;
6752
6765
 
6753
6766
  const HeaderTitle = ({ noFeature }) => {
@@ -6775,22 +6788,22 @@ const HeaderTitle = ({ noFeature }) => {
6775
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 })] }));
6776
6789
  };
6777
6790
 
6778
- const LayerIconContainer = styled.div `
6779
- display: flex;
6780
- align-items: center;
6781
- margin-right: 0.75rem;
6791
+ const LayerIconContainer = styled.div `
6792
+ display: flex;
6793
+ align-items: center;
6794
+ margin-right: 0.75rem;
6782
6795
  `;
6783
- const AlertIconContainer = styled(uilibGl.Flex) `
6784
- align-items: center;
6785
- justify-content: center;
6786
- width: 2rem;
6787
- height: 2rem;
6788
-
6789
- ${uilibGl.Icon} {
6790
- :after {
6791
- color: ${({ theme: { palette } }) => palette.error};
6792
- }
6793
- }
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
+ }
6794
6807
  `;
6795
6808
 
6796
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";
@@ -6822,56 +6835,56 @@ const FeatureCardDefaultHeader = ({ noFeature }) => {
6822
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, {})] }) }));
6823
6836
  };
6824
6837
 
6825
- const HeaderFontColorMixin$1 = styled.css `
6826
- ${HeaderTitleContainer}, ${LayerDescription} {
6827
- color: ${({ $fontColor }) => $fontColor};
6828
- }
6829
- `;
6830
- const HeaderWrapperMixin$1 = styled.css `
6831
- padding: 0.5rem 0.5rem 0;
6832
-
6833
- ${Header} {
6834
- min-height: 5.25rem;
6835
- }
6836
-
6837
- ${HeaderContainer} {
6838
- max-width: 100%;
6839
- width: 100%;
6840
- }
6841
-
6842
- ${FeatureControls} {
6843
- max-width: calc(100% - 2rem);
6844
- width: calc(100% - 2rem);
6845
- margin-top: -0.5rem;
6846
- padding-top: 1rem;
6847
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
6848
- }
6849
-
6850
- ${({ $fontColor }) => !!$fontColor && HeaderFontColorMixin$1};
6851
- `;
6852
- const GradientHeaderWrapper = styled.div `
6853
- ${Header} {
6854
- background: ${({ $bgColor }) => $bgColor || "radial-gradient(129.21% 133.22% at 51.94% 0%, #e8fffe 9.48%, #5fcaff 100%)"};
6855
- }
6856
-
6857
- ${HeaderContainer} {
6858
- align-items: center;
6859
- }
6860
-
6861
- ${HeaderTitleContainer} {
6862
- margin-left: 0;
6863
- text-align: center;
6864
- }
6865
-
6866
- ${FeatureTitleContainer} {
6867
- text-align: center;
6868
- }
6869
-
6870
- ${LayerDescription} {
6871
- text-align: center;
6872
- }
6873
-
6874
- ${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};
6875
6888
  `;
6876
6889
 
6877
6890
  const FeatureCardGradientHeader = ({ isRow }) => {
@@ -6888,82 +6901,82 @@ const FeatureCardGradientHeader = ({ isRow }) => {
6888
6901
  }) })] }), jsxRuntime.jsx(FeatureCardButtons, {})] }) }) }) }));
6889
6902
  };
6890
6903
 
6891
- const HeaderFontColorMixin = styled.css `
6892
- ${HeaderTitleContainer}, ${LayerDescription} {
6893
- color: ${({ $fontColor }) => $fontColor};
6894
- }
6895
- `;
6896
- const HeaderWrapperMixin = styled.css `
6897
- padding: 0.5rem 0.5rem 0;
6898
-
6899
- ${Header} {
6900
- min-height: 5.25rem;
6901
- }
6902
-
6903
- ${HeaderContainer} {
6904
- max-width: 100%;
6905
- width: 100%;
6906
- }
6907
-
6908
- ${FeatureControls} {
6909
- max-width: calc(100% - 2rem);
6910
- width: calc(100% - 2rem);
6911
- margin-top: -0.5rem;
6912
- padding-top: 1rem;
6913
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
6914
- }
6915
-
6916
- ${({ $fontColor }) => !!$fontColor && HeaderFontColorMixin};
6917
- `;
6918
- const HeaderIcon = styled(uilibGl.Flex) `
6919
- position: absolute;
6920
- top: 0;
6921
- right: 0;
6922
- justify-content: flex-end;
6923
- align-items: center;
6924
- min-width: 7.5rem;
6925
- height: 100%;
6926
-
6927
- span[kind]:after {
6928
- font-size: 7.5rem;
6929
- }
6930
-
6931
- span[kind]:after,
6932
- path,
6933
- line,
6934
- circle {
6935
- fill: rgba(255, 255, 255, 0.36);
6936
- }
6937
-
6938
- && > * {
6939
- display: flex;
6940
- align-items: center;
6941
- height: 100%;
6942
- }
6943
- `;
6944
- const BigIconHeaderMixin = styled.css `
6945
- ${HeaderIcon} {
6946
- min-width: 14rem;
6947
- right: -3rem;
6948
-
6949
- span[kind]:after {
6950
- font-size: 14rem;
6951
- }
6952
- }
6953
- `;
6954
- const IconHeaderWrapper = styled.div `
6955
- ${Header} {
6956
- width: calc(100% + 3rem);
6957
- margin: -1.5rem -1.5rem 0 -1.5rem;
6958
- padding: 1.5rem;
6959
- border-top-left-radius: 0.5rem;
6960
- border-top-right-radius: 0.5rem;
6961
- background: ${({ $bgColor }) => $bgColor || "linear-gradient(96.55deg, #FFFCD3 0%, #B4DC47 100%)"};
6962
- }
6963
-
6964
- ${HeaderWrapperMixin};
6965
-
6966
- ${({ $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};
6967
6980
  `;
6968
6981
 
6969
6982
  const FeatureCardIconHeader = ({ isRow }) => {
@@ -6983,15 +6996,15 @@ const FeatureCardIconHeader = ({ isRow }) => {
6983
6996
  }) })] }) }) }));
6984
6997
  };
6985
6998
 
6986
- const ImageContainerButton = styled(uilibGl.FlatButton) `
6987
- min-height: 1.5rem;
6988
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.large};
6989
- background-color: ${({ theme: { palette } }) => palette.primary};
6990
- text-transform: none;
6991
-
6992
- :hover {
6993
- background-color: ${({ theme: { palette } }) => palette.primaryDeep};
6994
- }
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
+ }
6995
7008
  `;
6996
7009
 
6997
7010
  const ElementButton = React.memo(({ type, elementConfig }) => {
@@ -7003,157 +7016,157 @@ const ElementButton = React.memo(({ type, elementConfig }) => {
7003
7016
  return (jsxRuntime.jsx(ImageContainerButton, { onClick: () => window.open(attribute?.value), children: elementConfig.value || "" }));
7004
7017
  });
7005
7018
 
7006
- const AttributeGalleryContainer = styled.div `
7007
- && {
7008
- width: calc(100% + 3rem);
7009
- }
7010
-
7011
- min-height: 12.625rem;
7012
- background-color: ${({ theme: { palette } }) => palette.element};
7013
-
7014
- img {
7015
- width: 100%;
7016
- }
7017
- `;
7018
- const LinearProgressContainer = styled(uilibGl.Flex) `
7019
- align-items: center;
7020
- justify-content: center;
7021
- min-height: inherit;
7022
-
7023
- ${uilibGl.LinearProgress} {
7024
- max-width: 4rem;
7025
- }
7026
- `;
7027
- const NoLiveSnapshotContainer = styled(uilibGl.Flex) `
7028
- flex-direction: column;
7029
- align-items: center;
7030
-
7031
- span[kind="alert"] {
7032
- width: 2rem;
7033
- height: 2rem;
7034
-
7035
- &:after {
7036
- font-size: 2rem;
7037
- color: ${({ theme: { palette } }) => palette.elementDeep};
7038
- }
7039
- }
7040
-
7041
- ${uilibGl.Description} {
7042
- font-size: 0.75rem;
7043
- color: ${({ theme: { palette } }) => palette.textDisabled};
7044
- }
7045
- `;
7046
- const SmallPreviewControl = styled(uilibGl.IconButton) `
7047
- cursor: ${({ $isDisabled }) => ($isDisabled ? "default" : "pointer")};
7048
- z-index: 3;
7049
- position: absolute;
7050
- top: 50%;
7051
- width: 2.5rem;
7052
- height: 2.5rem;
7053
- margin-top: -1.25rem;
7054
- background-color: rgba(61, 61, 61, 0.8);
7055
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.smallest};
7056
-
7057
- span:after {
7058
- color: ${({ $isDisabled }) => ($isDisabled ? "rgba(255, 255, 255, 0.28)" : "rgba(255, 255, 255, 1)")};
7059
- transition: color ${uilibGl.transition.hover};
7060
- }
7061
- `;
7062
- const SmallPreviewCounter = styled(uilibGl.Flex) `
7063
- z-index: 3;
7064
- position: absolute;
7065
- bottom: 0.625rem;
7066
- left: 0;
7067
- width: 100%;
7068
- height: 1rem;
7069
- justify-content: center;
7070
-
7071
- > div {
7072
- background-color: rgba(61, 61, 61, 0.8);
7073
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
7074
- padding: 0 0.5rem;
7075
- font-size: 0.625rem;
7076
- line-height: 1rem;
7077
- color: #fff;
7078
- }
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
+ }
7079
7092
  `;
7080
7093
  const SmallPreviewLeft = styled(SmallPreviewControl).attrs(() => ({
7081
7094
  kind: "prev",
7082
- })) `
7083
- left: 1.5rem;
7095
+ })) `
7096
+ left: 1.5rem;
7084
7097
  `;
7085
7098
  const SmallPreviewRight = styled(SmallPreviewControl).attrs(() => ({
7086
7099
  kind: "next",
7087
- })) `
7088
- right: 1.5rem;
7089
- `;
7090
- const imgSlideShowMixin = styled.css `
7091
- &:nth-child(${({ prevIndex }) => prevIndex}) {
7092
- z-index: 2;
7093
- position: absolute;
7094
- top: 0;
7095
- left: 0;
7096
- right: 0;
7097
- bottom: 0;
7098
- opacity: 0;
7099
-
7100
- animation-duration: 0.25s;
7101
- animation-name: fadeOut;
7102
- animation-timing-function: linear;
7103
-
7104
- @keyframes fadeOut {
7105
- from {
7106
- opacity: 1;
7107
- }
7108
-
7109
- to {
7110
- opacity: 0;
7111
- }
7112
- }
7113
- }
7114
- `;
7115
- const SmallPreviewContainer$1 = styled.div `
7116
- cursor: ${({ onClick }) => (onClick ? "pointer" : "default")};
7117
- position: relative;
7118
- width: 100%;
7119
- height: 100%;
7120
- min-height: inherit;
7121
- line-height: 0;
7122
-
7123
- ${uilibGl.LinearProgress} {
7124
- z-index: 3;
7125
- position: absolute;
7126
- }
7127
-
7128
- ${SmallPreviewControl}, ${SmallPreviewCounter} {
7129
- opacity: 0;
7130
- transition: opacity ${uilibGl.transition.hover};
7131
- }
7132
-
7133
- &:hover {
7134
- ${SmallPreviewControl}, ${SmallPreviewCounter} {
7135
- opacity: 1;
7136
- }
7137
- }
7138
-
7139
- img {
7140
- z-index: 0;
7141
- cursor: pointer;
7142
- position: absolute;
7143
- top: 0;
7144
- left: 0;
7145
- width: 100%;
7146
- height: 100%;
7147
- min-height: inherit;
7148
- object-position: center;
7149
- object-fit: cover;
7150
-
7151
- &:nth-child(${({ currentIndex }) => currentIndex}) {
7152
- z-index: 1;
7153
- }
7154
-
7155
- ${({ prevIndex, currentIndex }) => prevIndex !== currentIndex && imgSlideShowMixin}
7156
- }
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
+ }
7157
7170
  `;
7158
7171
  const SmallPreviewImages = styled.div ``;
7159
7172
 
@@ -7329,21 +7342,21 @@ const ElementChips = React.memo(({ type, elementConfig }) => {
7329
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))) }));
7330
7343
  });
7331
7344
 
7332
- const StyledIconFontSizeMixin = styled.css `
7333
- height: ${({ fontSize }) => `${fontSize}px`};
7334
-
7335
- &&:after {
7336
- font-size: ${({ fontSize }) => `${fontSize}px`};
7337
- }
7345
+ const StyledIconFontSizeMixin = styled.css `
7346
+ height: ${({ fontSize }) => `${fontSize}px`};
7347
+
7348
+ &&:after {
7349
+ font-size: ${({ fontSize }) => `${fontSize}px`};
7350
+ }
7338
7351
  `;
7339
- const StyledIconFontColorMixin = styled.css `
7340
- &&:after {
7341
- color: ${({ fontColor }) => fontColor};
7342
- }
7352
+ const StyledIconFontColorMixin = styled.css `
7353
+ &&:after {
7354
+ color: ${({ fontColor }) => fontColor};
7355
+ }
7343
7356
  `;
7344
- const StyledIcon = styled(uilibGl.Icon) `
7345
- ${({ fontSize }) => !!fontSize && StyledIconFontSizeMixin};
7346
- ${({ fontColor }) => !!fontColor && StyledIconFontColorMixin};
7357
+ const StyledIcon = styled(uilibGl.Icon) `
7358
+ ${({ fontSize }) => !!fontSize && StyledIconFontSizeMixin};
7359
+ ${({ fontColor }) => !!fontColor && StyledIconFontColorMixin};
7347
7360
  `;
7348
7361
 
7349
7362
  const ElementIcon = React.memo(({ type, elementConfig }) => {
@@ -7397,51 +7410,51 @@ const ElementLegend = React.memo(({ type, element, elementConfig, expandedContai
7397
7410
 
7398
7411
  const ExternalLink = styled(uilibGl.IconButton).attrs(() => ({
7399
7412
  kind: "external_link",
7400
- })) `
7401
- ${uilibGl.Icon} {
7402
- color: ${({ theme: { palette } }) => palette.primary};
7403
- }
7404
-
7405
- &:hover ${uilibGl.Icon} {
7406
- color: ${({ theme: { palette } }) => palette.primaryDeep};
7407
- }
7408
- `;
7409
- const LocalLinkBlank = styled(uilibGl.Blank) `
7410
- min-width: 13.5rem;
7411
- padding: 0.5rem 0.75rem 0;
7412
-
7413
- a {
7414
- text-decoration: none;
7415
- font-size: 0.75rem;
7416
- color: ${({ theme: { palette } }) => palette.primary};
7417
- }
7418
-
7419
- ${uilibGl.IconButtonButton} {
7420
- font-size: 0.75rem;
7421
- }
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
+ }
7422
7435
  `;
7423
7436
  const LocalLinkButton = styled(uilibGl.IconButton).attrs(() => ({
7424
7437
  kind: "link",
7425
- })) `
7426
- width: 1rem;
7427
- height: 1rem;
7428
- background-color: ${({ theme: { palette } }) => palette.primary};
7429
- border-radius: 50%;
7430
-
7431
- span[kind] {
7432
- display: flex;
7433
- justify-content: center;
7434
- align-items: center;
7435
-
7436
- :after {
7437
- position: relative;
7438
- font-size: 0.6rem;
7439
- color: white;
7440
- }
7441
- }
7442
- `;
7443
- const LocalLinkCopy = styled(uilibGl.Flex) `
7444
- 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;
7445
7458
  `;
7446
7459
 
7447
7460
  const LocalLink = React.memo(({ link }) => {
@@ -7463,9 +7476,9 @@ const ElementLink = React.memo(({ type, elementConfig }) => {
7463
7476
  return link.startsWith("http") ? jsxRuntime.jsx(ExternalLink, { onClick: () => window.open(link) }) : jsxRuntime.jsx(LocalLink, { link: link });
7464
7477
  });
7465
7478
 
7466
- const SmallPreviewContainer = styled.div `
7467
- width: 100%;
7468
- height: 100%;
7479
+ const SmallPreviewContainer = styled.div `
7480
+ width: 100%;
7481
+ height: 100%;
7469
7482
  `;
7470
7483
 
7471
7484
  const ElementSlideshow = ({ elementConfig, type, renderElement }) => {
@@ -7501,18 +7514,18 @@ const ElementSvg = React.memo(({ type, elementConfig }) => {
7501
7514
  return (jsxRuntime.jsx(SvgImage, { url: getSvgUrl({ elementConfig, layerInfo, attributes }), width: width, height: height, fontColor: fontColor }));
7502
7515
  });
7503
7516
 
7504
- const TooltipIcon = styled(uilibGl.Icon) `
7505
- &&& {
7506
- :after {
7507
- font-size: 0.75rem;
7508
- color: ${({ theme: { palette } }) => palette.iconDisabled};
7509
- transition: color ${uilibGl.transition.hover};
7510
- }
7511
-
7512
- :hover:after {
7513
- color: ${({ theme: { palette } }) => palette.icon};
7514
- }
7515
- }
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
+ }
7516
7529
  `;
7517
7530
 
7518
7531
  const ElementTooltip = React.memo(({ type, elementConfig }) => {
@@ -7524,76 +7537,76 @@ const ElementTooltip = React.memo(({ type, elementConfig }) => {
7524
7537
  return text ? (jsxRuntime.jsx(uilibGl.Tooltip, { placement: "top", arrow: true, content: text, children: ref => jsxRuntime.jsx(TooltipIcon, { kind: icon || "question", ref: ref }) })) : null;
7525
7538
  });
7526
7539
 
7527
- const SlideshowHeaderWrapper = styled.div `
7528
- padding: ${({ withPadding }) => (withPadding ? "0.5rem 0.5rem 0" : 0)};
7529
-
7530
- ${Header} {
7531
- align-items: flex-start;
7532
- width: calc(100% + 2rem);
7533
- height: ${({ big }) => (big ? "15.5rem" : "auto")};
7534
- padding: 1.5rem;
7535
- margin: -1rem -1rem 0 -1rem;
7536
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
7537
-
7538
- ${SmallPreviewCounter} {
7539
- bottom: ${({ withPadding }) => (withPadding ? 0.625 : 1.125)}rem;
7540
- }
7541
-
7542
- :before,
7543
- :after {
7544
- content: "";
7545
- z-index: 2;
7546
- position: absolute;
7547
- top: 0;
7548
- left: 0;
7549
- width: 100%;
7550
- }
7551
-
7552
- :before {
7553
- height: 100%;
7554
- background: rgba(32, 46, 53, 0.25);
7555
- }
7556
-
7557
- :after {
7558
- height: 4.5rem;
7559
- background: linear-gradient(180deg, #000000 0%, rgba(0, 0, 0, 0) 100%);
7560
- }
7561
-
7562
- :hover {
7563
- ${SmallPreviewControl}, ${SmallPreviewCounter} {
7564
- opacity: 1;
7565
- }
7566
- }
7567
- }
7568
- `;
7569
- const ImageContainerBg = styled.div `
7570
- position: absolute;
7571
- top: 0;
7572
- bottom: 0;
7573
- left: 0;
7574
- right: 0;
7575
-
7576
- img {
7577
- width: 100%;
7578
- height: 100%;
7579
- object-position: center;
7580
- object-fit: cover;
7581
- }
7582
- `;
7583
- const HeaderSlideshow = styled.div `
7584
- position: absolute;
7585
- top: 0;
7586
- bottom: ${({ height }) => (height ? `${height}px` : 0)};
7587
- left: 0;
7588
- right: 0;
7589
-
7590
- img {
7591
- width: 100%;
7592
- height: 100%;
7593
- min-height: inherit;
7594
- object-position: center;
7595
- object-fit: cover;
7596
- }
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
+ }
7597
7610
  `;
7598
7611
 
7599
7612
  const FeatureCardSlideshowHeader = ({ isRow }) => {
@@ -9338,8 +9351,8 @@ const Dashboard = React.memo(({ type = exports.WidgetType.Dashboard, config }) =
9338
9351
  return (jsxRuntime.jsx(ConfigProvider, { config: config, children: jsxRuntime.jsx(PagesContainer, { type: type }) }));
9339
9352
  });
9340
9353
 
9341
- const CardCheckbox = styled(uilibGl.Checkbox) `
9342
- padding-left: 0.5rem;
9354
+ const CardCheckbox = styled(uilibGl.Checkbox) `
9355
+ padding-left: 0.5rem;
9343
9356
  `;
9344
9357
 
9345
9358
  const DashboardCheckbox = ({ title, checked, onChange, }) => {
@@ -9414,15 +9427,15 @@ const FeatureCardTitle = ({ title, description }) => {
9414
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 })] }));
9415
9428
  };
9416
9429
 
9417
- const HiddenFilters = styled(uilibGl.Flex) `
9418
- flex-wrap: wrap;
9419
- margin-top: -1.25rem;
9420
-
9421
- ${DashboardChip$1} {
9422
- height: 1.5rem;
9423
- margin: 0 0.25rem 0.25rem 0;
9424
- padding: 0 0 0 0.5rem;
9425
- }
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
+ }
9426
9439
  `;
9427
9440
 
9428
9441
  function spliceValue(filterValue, splicingValue) {
@@ -9492,24 +9505,24 @@ const HiddenTitleItems = React.memo(({ elementConfig, config, type, filter }) =>
9492
9505
  getConfigFilter(filterName, configFilters)?.defaultValue, index)) }));
9493
9506
  });
9494
9507
 
9495
- const PageNavigator = styled(uilibGl.Flex) `
9496
- margin-right: -0.5rem;
9497
- align-items: center;
9498
-
9499
- button {
9500
- width: auto;
9501
- height: 1.5rem;
9502
- padding: 0 0.5rem;
9503
-
9504
- span[kind]:after {
9505
- color: ${({ theme: { palette } }) => palette.textDisabled};
9506
- transition: color ${uilibGl.transition.hover};
9507
- }
9508
-
9509
- :hover span[kind]:after {
9510
- color: ${({ theme: { palette } }) => palette.textSecondary};
9511
- }
9512
- }
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
+ }
9513
9526
  `;
9514
9527
 
9515
9528
  const Pagination = React.memo(({ type = exports.WidgetType.Dashboard }) => {
@@ -9518,34 +9531,34 @@ const Pagination = React.memo(({ type = exports.WidgetType.Dashboard }) => {
9518
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) })] }));
9519
9532
  });
9520
9533
 
9521
- const StyledSvgWidthMixin = styled.css `
9522
- &&& {
9523
- svg {
9524
- width: ${({ $width }) => $width}px;
9525
- }
9526
- }
9527
- `;
9528
- const StyledSvgHeightMixin = styled.css `
9529
- &&& {
9530
- svg {
9531
- height: ${({ $height }) => $height}px;
9532
- }
9533
- }
9534
- `;
9535
- const StyledSvgColorMixin = styled.css `
9536
- svg {
9537
- path,
9538
- line,
9539
- circle {
9540
- fill: ${({ $fontColor }) => $fontColor} !important;
9541
- }
9542
- }
9543
- `;
9544
- const StyledSvg = styled(uilibGl.Flex) `
9545
- align-items: center;
9546
- ${({ $width }) => !!$width && StyledSvgWidthMixin};
9547
- ${({ $height }) => !!$height && StyledSvgHeightMixin};
9548
- ${({ $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};
9549
9562
  `;
9550
9563
 
9551
9564
  const SvgImage = React.memo(({ url, width, height, fontColor }) => {
@@ -9763,7 +9776,7 @@ const VectorLayer = ({ layer, tileUrl, visible, beforeId, getLayerTempStyle, })
9763
9776
  return (jsxRuntime.jsx(MapGL.Source, { promoteId: idAttribute, id: layer.name, type: "vector", tiles: [tileUrl], children: clientStyle?.items ? renderClientStyle() : renderLayerByGeometryType() }));
9764
9777
  };
9765
9778
 
9766
- const Layer = ({ layer, layerType, visible, beforeId, tileUrl, getLayerTempStyle, onMount = () => null, }) => {
9779
+ const Layer = ({ layer, layerType, visible, beforeId, tileUrl, getLayerTempStyle, onMount = () => { }, }) => {
9767
9780
  React.useEffect(onMount, []); // eslint-disable-line
9768
9781
  if (!layer) {
9769
9782
  return null;
@@ -9774,28 +9787,28 @@ const Layer = ({ layer, layerType, visible, beforeId, tileUrl, getLayerTempStyle
9774
9787
  return (jsxRuntime.jsx(VectorLayer, { layer: layer, tileUrl: tileUrl, visible: visible, beforeId: beforeId, getLayerTempStyle: getLayerTempStyle }));
9775
9788
  };
9776
9789
 
9777
- const MapWrapper = styled.div `
9778
- position: relative;
9779
- width: 100%;
9780
- height: 100%;
9781
- box-sizing: border-box;
9782
- z-index: ${({ $zIndex }) => $zIndex ?? 1};
9783
-
9784
- .mapbox-gl-draw_trash {
9785
- display: none;
9786
- }
9787
-
9788
- .mapboxgl-ctrl-logo {
9789
- display: none;
9790
- }
9791
-
9792
- .mapboxgl-ctrl.mapboxgl-ctrl-attrib {
9793
- display: none;
9794
- }
9795
-
9796
- .mapboxgl-ctrl-geocoder.mapboxgl-ctrl {
9797
- width: 350px;
9798
- }
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
+ }
9799
9812
  `;
9800
9813
 
9801
9814
  const Map$1 = ({ zIndex, lowerSiblings, upperSiblings, onError, children, ...rest }) => {
@@ -10037,6 +10050,7 @@ exports.tooltipValueFromAttributes = tooltipValueFromAttributes;
10037
10050
  exports.tooltipValueFromRelatedFeatures = tooltipValueFromRelatedFeatures;
10038
10051
  exports.transparentizeColor = transparentizeColor;
10039
10052
  exports.treeNodesToProjectItems = treeNodesToProjectItems;
10053
+ exports.useAppHeight = useAppHeight;
10040
10054
  exports.useChartChange = useChartChange;
10041
10055
  exports.useChartData = useChartData;
10042
10056
  exports.useDashboardHeader = useDashboardHeader;