@evergis/react 3.1.34 → 3.1.36

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