@evergis/react 3.1.106 → 3.1.108

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/react.esm.js CHANGED
@@ -16,7 +16,7 @@ import { jsPDF } from 'jspdf';
16
16
  import html2canvas from 'html2canvas';
17
17
  import MapboxDraw from '@mapbox/mapbox-gl-draw';
18
18
  import { geometryCollection, multiPolygon, polygon, multiLineString, multiPoint, point as point$1, bbox } from '@turf/turf';
19
- import MapGL, { Source, Layer as Layer$1 } from 'react-map-gl/mapbox';
19
+ import MapGL, { Source, Layer as Layer$1 } from 'react-map-gl/maplibre';
20
20
  import '@mapbox/mapbox-gl-draw/dist/mapbox-gl-draw.css';
21
21
  import 'mapbox-gl/dist/mapbox-gl.css';
22
22
  import { Swiper, SwiperSlide } from 'swiper/react';
@@ -34,180 +34,180 @@ const AddFeatureButton = ({ title, icon = "feature_add" /* , layerName, geometry
34
34
  return (jsx(IconButton, { kind: icon, primary: true, onClick: handleAddFeature, children: title }));
35
35
  };
36
36
 
37
- const ChartTooltipTable = styled.table `
38
- td {
39
- padding: 0;
40
- }
41
-
42
- tr:not(:last-child) td {
43
- padding-bottom: 0.375rem;
44
- }
37
+ const ChartTooltipTable = styled.table `
38
+ td {
39
+ padding: 0;
40
+ }
41
+
42
+ tr:not(:last-child) td {
43
+ padding-bottom: 0.375rem;
44
+ }
45
45
  `;
46
- const ChartTooltip = styled(Flex) `
47
- flex-wrap: nowrap;
48
- background: rgb(48, 69, 79);
49
- border-radius: 0.25rem;
50
- color: white;
51
-
52
- :not(:last-child) {
53
- margin-bottom: 0.25rem;
54
- }
46
+ const ChartTooltip = styled(Flex) `
47
+ flex-wrap: nowrap;
48
+ background: rgb(48, 69, 79);
49
+ border-radius: 0.25rem;
50
+ color: white;
51
+
52
+ :not(:last-child) {
53
+ margin-bottom: 0.25rem;
54
+ }
55
55
  `;
56
- const ChartTooltipLabel = styled.div `
57
- margin-right: 0.25rem;
58
- `;
59
- const ChartTooltipColor = styled.div `
60
- width: 0.625rem;
61
- height: 0.625rem;
62
- background-color: ${({ $color }) => $color};
63
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.smallest};
64
- margin-right: 0.25rem;
65
- `;
66
- const ChartLegendColor$1 = styled.div `
67
- width: 0.5rem;
68
- height: 0.5rem;
69
- background-color: ${({ $color }) => $color};
70
- border-radius: 0.125rem;
71
- `;
72
- const ChartLegendValue = styled.div `
73
- opacity: 0.65;
74
- `;
75
- const ChartTooltipRow = styled(Flex) `
76
- display: flex;
77
- flex-direction: row;
78
- flex-wrap: nowrap;
79
- align-items: center;
80
- margin-top: 0.5rem;
81
- line-height: 0;
82
-
83
- ${ChartLegendColor$1} {
84
- margin-right: 0.25rem;
85
- }
56
+ const ChartTooltipLabel = styled.div `
57
+ margin-right: 0.25rem;
58
+ `;
59
+ const ChartTooltipColor = styled.div `
60
+ width: 0.625rem;
61
+ height: 0.625rem;
62
+ background-color: ${({ $color }) => $color};
63
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.smallest};
64
+ margin-right: 0.25rem;
65
+ `;
66
+ const ChartLegendColor$1 = styled.div `
67
+ width: 0.5rem;
68
+ height: 0.5rem;
69
+ background-color: ${({ $color }) => $color};
70
+ border-radius: 0.125rem;
71
+ `;
72
+ const ChartLegendValue = styled.div `
73
+ opacity: 0.65;
74
+ `;
75
+ const ChartTooltipRow = styled(Flex) `
76
+ display: flex;
77
+ flex-direction: row;
78
+ flex-wrap: nowrap;
79
+ align-items: center;
80
+ margin-top: 0.5rem;
81
+ line-height: 0;
82
+
83
+ ${ChartLegendColor$1} {
84
+ margin-right: 0.25rem;
85
+ }
86
86
  `;
87
- const ChartTooltipName = styled.div `
88
- margin-right: 1rem;
89
- opacity: 0.65;
90
- `;
91
- const PieChartCenter = styled.div `
92
- position: absolute;
93
- top: 50%;
94
- left: 50%;
95
- transform: translate(-50%, -50%);
96
- text-align: center;
97
- font-weight: bold;
98
- font-size: 1.5rem;
99
- `;
100
- const ChartWrapperContainer = styled.div `
101
- position: relative;
102
- width: 100%;
103
- `;
104
- const Tooltip = styled.div `
105
- position: relative;
106
- border-radius: 0.25rem;
107
- background-color: rgba(28, 33, 48);
108
- padding: 0.5rem;
109
- box-shadow: 0 0.125rem 0.25rem 0 rgba(0, 0, 0, 0.15);
110
- font-size: 0.75rem;
111
- transform: ${({ transform }) => transform};
112
- color: white;
113
-
114
- :before {
115
- position: absolute;
116
- display: block;
117
- content: "";
118
- width: 0;
119
- height: 0;
120
- }
87
+ const ChartTooltipName = styled.div `
88
+ margin-right: 1rem;
89
+ opacity: 0.65;
90
+ `;
91
+ const PieChartCenter = styled.div `
92
+ position: absolute;
93
+ top: 50%;
94
+ left: 50%;
95
+ transform: translate(-50%, -50%);
96
+ text-align: center;
97
+ font-weight: bold;
98
+ font-size: 1.5rem;
99
+ `;
100
+ const ChartWrapperContainer = styled.div `
101
+ position: relative;
102
+ width: 100%;
103
+ `;
104
+ const Tooltip = styled.div `
105
+ position: relative;
106
+ border-radius: 0.25rem;
107
+ background-color: rgba(28, 33, 48);
108
+ padding: 0.5rem;
109
+ box-shadow: 0 0.125rem 0.25rem 0 rgba(0, 0, 0, 0.15);
110
+ font-size: 0.75rem;
111
+ transform: ${({ transform }) => transform};
112
+ color: white;
113
+
114
+ :before {
115
+ position: absolute;
116
+ display: block;
117
+ content: "";
118
+ width: 0;
119
+ height: 0;
120
+ }
121
121
  `;
122
- const LineChartStyles = createGlobalStyle `
123
- .dashboardLineChartTooltip.${lineChartClassNames.lineChartMouseLabel} {
124
- .${lineChartClassNames.lineChartLabelFlex} {
125
- justify-content: center;
126
- align-items: flex-end;
127
-
128
- ${Tooltip} {
129
- margin: 0 0 12px 0;
130
-
131
- :before {
132
- top: auto;
133
- bottom: 0;
134
- left: 50%;
135
- transform: translate(-50%, 100%);
136
- border-left: 4px solid transparent;
137
- border-right: 4px solid transparent;
138
- border-top: 4px solid rgba(28, 33, 48, 0.9);
139
- }
140
- }
141
- }
142
- }
143
-
144
- .${lineChartClassNames.lineChartYScaleGlobal}, .${lineChartClassNames.lineChartXScaleGlobal} {
145
- .domain {
146
- visibility: hidden;
147
- }
148
-
149
- .tick {
150
- text {
151
- fill: ${({ theme: { palette } }) => palette.textDisabled};
152
- }
153
-
154
- line {
155
- visibility: hidden;
156
- }
157
- }
158
- }
159
-
160
- .${lineChartClassNames.lineChartXScaleGlobal} {
161
- .tick {
162
- :first-of-type {
163
- text {
164
- text-anchor: start;
165
- }
166
- }
167
-
168
- :last-of-type {
169
- text {
170
- text-anchor: end;
171
- }
172
- }
173
- }
174
- }
175
-
176
- .${lineChartClassNames.lineChartLine} {
177
- stroke-width: 2px;
178
- }
179
-
180
- .${lineChartClassNames.lineChartLabel} {
181
- color: ${({ theme: { palette } }) => palette.textPrimary};
182
- }
183
-
184
- .${lineChartClassNames.lineChartMouseCircle} {
185
- stroke: #ffffff;
186
- stroke-width: 2px;
187
- }
188
-
189
- .${lineChartClassNames.lineChartGridLineX} {
190
- stroke: ${({ theme: { palette } }) => palette.element};
191
- }
192
-
193
- text {
194
- fill: ${({ theme: { palette } }) => palette.textDisabled};
195
- }
122
+ const LineChartStyles = createGlobalStyle `
123
+ .dashboardLineChartTooltip.${lineChartClassNames.lineChartMouseLabel} {
124
+ .${lineChartClassNames.lineChartLabelFlex} {
125
+ justify-content: center;
126
+ align-items: flex-end;
127
+
128
+ ${Tooltip} {
129
+ margin: 0 0 12px 0;
130
+
131
+ :before {
132
+ top: auto;
133
+ bottom: 0;
134
+ left: 50%;
135
+ transform: translate(-50%, 100%);
136
+ border-left: 4px solid transparent;
137
+ border-right: 4px solid transparent;
138
+ border-top: 4px solid rgba(28, 33, 48, 0.9);
139
+ }
140
+ }
141
+ }
142
+ }
143
+
144
+ .${lineChartClassNames.lineChartYScaleGlobal}, .${lineChartClassNames.lineChartXScaleGlobal} {
145
+ .domain {
146
+ visibility: hidden;
147
+ }
148
+
149
+ .tick {
150
+ text {
151
+ fill: ${({ theme: { palette } }) => palette.textDisabled};
152
+ }
153
+
154
+ line {
155
+ visibility: hidden;
156
+ }
157
+ }
158
+ }
159
+
160
+ .${lineChartClassNames.lineChartXScaleGlobal} {
161
+ .tick {
162
+ :first-of-type {
163
+ text {
164
+ text-anchor: start;
165
+ }
166
+ }
167
+
168
+ :last-of-type {
169
+ text {
170
+ text-anchor: end;
171
+ }
172
+ }
173
+ }
174
+ }
175
+
176
+ .${lineChartClassNames.lineChartLine} {
177
+ stroke-width: 2px;
178
+ }
179
+
180
+ .${lineChartClassNames.lineChartLabel} {
181
+ color: ${({ theme: { palette } }) => palette.textPrimary};
182
+ }
183
+
184
+ .${lineChartClassNames.lineChartMouseCircle} {
185
+ stroke: #ffffff;
186
+ stroke-width: 2px;
187
+ }
188
+
189
+ .${lineChartClassNames.lineChartGridLineX} {
190
+ stroke: ${({ theme: { palette } }) => palette.element};
191
+ }
192
+
193
+ text {
194
+ fill: ${({ theme: { palette } }) => palette.textDisabled};
195
+ }
196
196
  `;
197
- const StyledBarChart = styled(BarChart$1) `
198
- .domain {
199
- display: none;
200
- }
201
-
202
- .tick {
203
- text {
204
- fill: ${({ theme: { palette } }) => palette.textDisabled};
205
- }
206
-
207
- line {
208
- visibility: hidden;
209
- }
210
- }
197
+ const StyledBarChart = styled(BarChart$1) `
198
+ .domain {
199
+ display: none;
200
+ }
201
+
202
+ .tick {
203
+ text {
204
+ fill: ${({ theme: { palette } }) => palette.textDisabled};
205
+ }
206
+
207
+ line {
208
+ visibility: hidden;
209
+ }
210
+ }
211
211
  `;
212
212
 
213
213
  function range(start, stop, step) {
@@ -3441,42 +3441,42 @@ const DEFAULT_ID_ATTRIBUTE_NAME = "gid";
3441
3441
  const DEFAULT_DROPDOWN_WIDTH = 312;
3442
3442
  const DEFAULT_FILTER_PADDING = 12;
3443
3443
 
3444
- const StackBarContainer = styled(Flex) `
3445
- flex-wrap: nowrap;
3446
- width: 100%;
3447
- `;
3448
- const StackBarHeader = styled(Flex) `
3449
- justify-content: space-between;
3450
- margin-bottom: 0.375rem;
3451
- font-size: 0.75rem;
3452
- `;
3453
- const StackBarSection = styled.div `
3454
- cursor: ${({ onClick }) => (onClick ? "pointer" : "default")};
3455
- width: ${({ $width }) => $width}%;
3456
- height: ${({ $height }) => ($height ? `${$height}px` : "0.5rem")};
3457
- margin: 0 0.5px;
3458
- background-color: ${({ $color }) => $color};
3459
- opacity: ${({ hasAnyFilter, isFiltered }) => (isFiltered ? 1 : hasAnyFilter ? FILTERED_VALUE_OPACITY / 100 : 1)};
3460
- transition: opacity ${transition.release};
3461
-
3462
- :first-child {
3463
- border-top-left-radius: ${({ cornerRadius }) => (cornerRadius ? `${cornerRadius}px` : "0.5rem")};
3464
- border-bottom-left-radius: ${({ cornerRadius }) => (cornerRadius ? `${cornerRadius}px` : "0.5rem")};
3465
- }
3466
-
3467
- :last-child {
3468
- border-top-right-radius: ${({ cornerRadius }) => (cornerRadius ? `${cornerRadius}px` : "0.5rem")};
3469
- border-bottom-right-radius: ${({ cornerRadius }) => (cornerRadius ? `${cornerRadius}px` : "0.5rem")};
3470
- }
3444
+ const StackBarContainer = styled(Flex) `
3445
+ flex-wrap: nowrap;
3446
+ width: 100%;
3447
+ `;
3448
+ const StackBarHeader = styled(Flex) `
3449
+ justify-content: space-between;
3450
+ margin-bottom: 0.375rem;
3451
+ font-size: 0.75rem;
3452
+ `;
3453
+ const StackBarSection = styled.div `
3454
+ cursor: ${({ onClick }) => (onClick ? "pointer" : "default")};
3455
+ width: ${({ $width }) => $width}%;
3456
+ height: ${({ $height }) => ($height ? `${$height}px` : "0.5rem")};
3457
+ margin: 0 0.5px;
3458
+ background-color: ${({ $color }) => $color};
3459
+ opacity: ${({ hasAnyFilter, isFiltered }) => (isFiltered ? 1 : hasAnyFilter ? FILTERED_VALUE_OPACITY / 100 : 1)};
3460
+ transition: opacity ${transition.release};
3461
+
3462
+ :first-child {
3463
+ border-top-left-radius: ${({ cornerRadius }) => (cornerRadius ? `${cornerRadius}px` : "0.5rem")};
3464
+ border-bottom-left-radius: ${({ cornerRadius }) => (cornerRadius ? `${cornerRadius}px` : "0.5rem")};
3465
+ }
3466
+
3467
+ :last-child {
3468
+ border-top-right-radius: ${({ cornerRadius }) => (cornerRadius ? `${cornerRadius}px` : "0.5rem")};
3469
+ border-bottom-right-radius: ${({ cornerRadius }) => (cornerRadius ? `${cornerRadius}px` : "0.5rem")};
3470
+ }
3471
3471
  `;
3472
- const StackBarAlias = styled.div `
3473
- color: ${({ theme: { palette } }) => palette.textSecondary};
3472
+ const StackBarAlias = styled.div `
3473
+ color: ${({ theme: { palette } }) => palette.textSecondary};
3474
3474
  `;
3475
3475
  const StackBarTotal = styled(Flex) ``;
3476
3476
  const StackBarValue = styled.div ``;
3477
- const StackBarUnits = styled.div `
3478
- margin-left: 0.25rem;
3479
- color: ${({ theme: { palette } }) => palette.textSecondary};
3477
+ const StackBarUnits = styled.div `
3478
+ margin-left: 0.25rem;
3479
+ color: ${({ theme: { palette } }) => palette.textSecondary};
3480
3480
  `;
3481
3481
 
3482
3482
  const transparentizeColor = (originalColor, percent) => {
@@ -4132,8 +4132,8 @@ const useChartChange = ({ dataSources, chartId, width, height, relatedAttributes
4132
4132
  const customize = useCallback(({ svg }) => {
4133
4133
  svg.style("overflow", "visible");
4134
4134
  svg
4135
- .selectAll(`.${lineChartClassNames.lineChartXScaleGlobal} line,
4136
- .${lineChartClassNames.lineChartYScaleGlobal} line,
4135
+ .selectAll(`.${lineChartClassNames.lineChartXScaleGlobal} line,
4136
+ .${lineChartClassNames.lineChartYScaleGlobal} line,
4137
4137
  .domain`)
4138
4138
  .each((_, index, nodes) => {
4139
4139
  nodes[index].remove();
@@ -4190,11 +4190,11 @@ const useChartChange = ({ dataSources, chartId, width, height, relatedAttributes
4190
4190
  .attr("fill", `url(#${gradientId})`)
4191
4191
  .attr("stroke-width", "0")
4192
4192
  .attr("fill-opacity", FILL_OPACITY);
4193
- defs.push(`
4194
- <linearGradient id="${gradientId}" x1="0" y1="0" x2="0" y2="1">
4195
- <stop offset="0" stop-color="${color}" stop-opacity="1" />
4196
- <stop offset="1" stop-color="${color}" stop-opacity="0" />
4197
- </linearGradient>
4193
+ defs.push(`
4194
+ <linearGradient id="${gradientId}" x1="0" y1="0" x2="0" y2="1">
4195
+ <stop offset="0" stop-color="${color}" stop-opacity="1" />
4196
+ <stop offset="1" stop-color="${color}" stop-opacity="0" />
4197
+ </linearGradient>
4198
4198
  `);
4199
4199
  ref.current = {
4200
4200
  path: newPath,
@@ -4549,104 +4549,104 @@ const formatDataSourceCondition = ({ condition, configFilters, filters, attribut
4549
4549
  : conditionSection.join(splitter);
4550
4550
  };
4551
4551
 
4552
- const DashboardChipsContainer = styled(Flex) `
4553
- flex-wrap: wrap;
4554
- `;
4555
- const DefaultChipColorMixin = css `
4556
- && {
4557
- color: ${({ theme: { palette } }) => palette.textPrimary};
4558
- }
4559
-
4560
- && > * {
4561
- color: ${({ theme: { palette } }) => palette.textPrimary};
4562
- }
4563
-
4564
- && span[kind]:after {
4565
- color: ${({ theme: { palette } }) => palette.icon};
4566
- }
4552
+ const DashboardChipsContainer = styled(Flex) `
4553
+ flex-wrap: wrap;
4567
4554
  `;
4568
- const CustomChipColorMixin = css `
4569
- && {
4570
- color: ${({ $fontColor }) => $fontColor};
4571
- }
4572
-
4573
- && > * {
4574
- color: ${({ $fontColor }) => $fontColor};
4575
- }
4576
-
4577
- && span[kind]:after {
4578
- color: ${({ $fontColor }) => $fontColor};
4579
- }
4555
+ const DefaultChipColorMixin = css `
4556
+ && {
4557
+ color: ${({ theme: { palette } }) => palette.textPrimary};
4558
+ }
4559
+
4560
+ && > * {
4561
+ color: ${({ theme: { palette } }) => palette.textPrimary};
4562
+ }
4563
+
4564
+ && span[kind]:after {
4565
+ color: ${({ theme: { palette } }) => palette.icon};
4566
+ }
4580
4567
  `;
4581
- const DashboardChip$1 = styled(Chip) `
4582
- margin: 0 0.25rem 0.25rem 0;
4583
- background: ${({ $isDefault, $bgColor, theme: { palette } }) => $isDefault ? palette.element : $bgColor || palette.primary};
4584
- border-radius: ${({ $radius, theme: { borderRadius } }) => $radius || borderRadius.medium};
4585
- white-space: nowrap;
4586
- font-size: ${({ $fontSize }) => $fontSize || "0.875rem"};
4587
- color: ${({ theme: { palette } }) => palette.iconContrast};
4588
-
4589
- > * {
4590
- font-size: ${({ $fontSize }) => $fontSize || "0.875rem"};
4591
- }
4592
-
4593
- span[kind] {
4594
- height: 0.875rem;
4595
-
4596
- :after {
4597
- font-size: 0.875rem;
4598
- }
4599
- }
4600
-
4601
- button {
4602
- width: auto;
4603
- padding: 0 0.5rem;
4604
- }
4605
-
4606
- ${({ $isDefault }) => $isDefault && DefaultChipColorMixin}
4607
- ${({ $fontColor, $isDefault }) => !!$fontColor && !$isDefault && CustomChipColorMixin}
4568
+ const CustomChipColorMixin = css `
4569
+ && {
4570
+ color: ${({ $fontColor }) => $fontColor};
4571
+ }
4572
+
4573
+ && > * {
4574
+ color: ${({ $fontColor }) => $fontColor};
4575
+ }
4576
+
4577
+ && span[kind]:after {
4578
+ color: ${({ $fontColor }) => $fontColor};
4579
+ }
4608
4580
  `;
4581
+ const DashboardChip$1 = styled(Chip) `
4582
+ margin: 0 0.25rem 0.25rem 0;
4583
+ background: ${({ $isDefault, $bgColor, theme: { palette } }) => $isDefault ? palette.element : $bgColor || palette.primary};
4584
+ border-radius: ${({ $radius, theme: { borderRadius } }) => $radius || borderRadius.medium};
4585
+ white-space: nowrap;
4586
+ font-size: ${({ $fontSize }) => $fontSize || "0.875rem"};
4587
+ color: ${({ theme: { palette } }) => palette.iconContrast};
4609
4588
 
4610
- const LayerGroupContainer = styled(Flex) `
4611
- display: flex;
4612
- justify-content: center;
4613
- position: relative;
4614
- flex-direction: column;
4615
- padding: 0 0.25rem 0 1rem;
4616
- box-sizing: border-box;
4617
- transition: opacity ${transition.hover}, background-color ${transition.hover};
4618
- font-family: "NunitoSans", sans-serif;
4619
- `;
4620
- const LayerGroupMain = styled(Flex) `
4621
- flex-direction: row;
4622
- flex-wrap: nowrap;
4623
- align-items: center;
4624
- justify-content: space-between;
4625
- width: 100%;
4626
-
4627
- ${Icon} {
4628
- width: 2rem;
4629
- min-width: 2rem;
4630
- height: 2rem;
4631
- display: inline-flex;
4632
- align-items: center;
4633
- justify-content: center;
4634
- margin-right: 0.75rem;
4635
- }
4636
-
4637
- ${Description} {
4638
- display: flex;
4639
- align-items: center;
4640
- flex-grow: 1;
4641
- width: 100%;
4642
- margin-right: 0.25rem;
4643
- color: ${({ theme }) => theme.palette.textPrimary};
4644
- }
4645
-
4646
- button {
4647
- width: 2.25rem;
4648
- justify-content: flex-start;
4649
- }
4589
+ > * {
4590
+ font-size: ${({ $fontSize }) => $fontSize || "0.875rem"};
4591
+ }
4592
+
4593
+ span[kind] {
4594
+ height: 0.875rem;
4595
+
4596
+ :after {
4597
+ font-size: 0.875rem;
4598
+ }
4599
+ }
4600
+
4601
+ button {
4602
+ width: auto;
4603
+ padding: 0 0.5rem;
4604
+ }
4605
+
4606
+ ${({ $isDefault }) => $isDefault && DefaultChipColorMixin}
4607
+ ${({ $fontColor, $isDefault }) => !!$fontColor && !$isDefault && CustomChipColorMixin}
4608
+ `;
4609
+
4610
+ const LayerGroupContainer = styled(Flex) `
4611
+ display: flex;
4612
+ justify-content: center;
4613
+ position: relative;
4614
+ flex-direction: column;
4615
+ padding: 0 0.25rem 0 1rem;
4616
+ box-sizing: border-box;
4617
+ transition: opacity ${transition.hover}, background-color ${transition.hover};
4618
+ font-family: "NunitoSans", sans-serif;
4619
+ `;
4620
+ const LayerGroupMain = styled(Flex) `
4621
+ flex-direction: row;
4622
+ flex-wrap: nowrap;
4623
+ align-items: center;
4624
+ justify-content: space-between;
4625
+ width: 100%;
4626
+
4627
+ ${Icon} {
4628
+ width: 2rem;
4629
+ min-width: 2rem;
4630
+ height: 2rem;
4631
+ display: inline-flex;
4632
+ align-items: center;
4633
+ justify-content: center;
4634
+ margin-right: 0.75rem;
4635
+ }
4636
+
4637
+ ${Description} {
4638
+ display: flex;
4639
+ align-items: center;
4640
+ flex-grow: 1;
4641
+ width: 100%;
4642
+ margin-right: 0.25rem;
4643
+ color: ${({ theme }) => theme.palette.textPrimary};
4644
+ }
4645
+
4646
+ button {
4647
+ width: 2.25rem;
4648
+ justify-content: flex-start;
4649
+ }
4650
4650
  `;
4651
4651
 
4652
4652
  const customModes = MapboxDraw.modes;
@@ -4896,12 +4896,10 @@ const useMapImages = ({ images }) => {
4896
4896
  if (isSvgUrl(config.url)) {
4897
4897
  // SVG: растеризуем через canvas
4898
4898
  try {
4899
- const { data, width, height } = await loadSvgAsImage(config.url, size, pixelRatio);
4899
+ const { data } = await loadSvgAsImage(config.url, size, pixelRatio);
4900
4900
  map.current.addImage(config.name, data, {
4901
4901
  sdf,
4902
4902
  pixelRatio,
4903
- width,
4904
- height,
4905
4903
  });
4906
4904
  loadedImagesRef.current.add(config.name);
4907
4905
  }
@@ -4914,12 +4912,7 @@ const useMapImages = ({ images }) => {
4914
4912
  else {
4915
4913
  // PNG/другие форматы: используем стандартную загрузку Mapbox
4916
4914
  return new Promise((resolve, reject) => {
4917
- map.current.loadImage(config.url, (error, image) => {
4918
- if (error) {
4919
- setErrors(prev => ({ ...prev, [config.name]: error.message }));
4920
- reject(error);
4921
- return;
4922
- }
4915
+ map.current.loadImage(config.url).then((image) => {
4923
4916
  if (image) {
4924
4917
  map.current.addImage(config.name, image, {
4925
4918
  sdf,
@@ -4928,6 +4921,9 @@ const useMapImages = ({ images }) => {
4928
4921
  loadedImagesRef.current.add(config.name);
4929
4922
  resolve();
4930
4923
  }
4924
+ }).catch(error => {
4925
+ setErrors(prev => ({ ...prev, [config.name]: error.message }));
4926
+ reject(error);
4931
4927
  });
4932
4928
  });
4933
4929
  }
@@ -5530,326 +5526,326 @@ const LayerTree = ({ layers, onlyMainTools }) => {
5530
5526
  return (jsx(DraggableTree, { nodes: nodes, disableDrag: onlyMainTools, options: { pastePlaceholderHeight: "0.0625rem" }, onUpdate: onUpdate }));
5531
5527
  };
5532
5528
 
5533
- const LayersListWrapper = styled(Flex) `
5534
- flex-direction: column;
5535
- height: 100%;
5536
- width: 100%;
5537
- box-sizing: border-box;
5529
+ const LayersListWrapper = styled(Flex) `
5530
+ flex-direction: column;
5531
+ height: 100%;
5532
+ width: 100%;
5533
+ box-sizing: border-box;
5538
5534
  `;
5539
- const LayerListContainer = styled(Flex) `
5540
- flex-grow: 1;
5541
- height: 100%;
5542
- box-sizing: border-box;
5535
+ const LayerListContainer = styled(Flex) `
5536
+ flex-grow: 1;
5537
+ height: 100%;
5538
+ box-sizing: border-box;
5543
5539
  `;
5544
5540
 
5545
- const ElementValueWrapper = styled.div `
5546
- transition: background-color ${transition.toggle};
5547
-
5548
- ${({ noMargin }) => css `
5549
- &&&& {
5550
- margin-bottom: 0;
5551
- }
5552
- `};
5541
+ const ElementValueWrapper = styled.div `
5542
+ transition: background-color ${transition.toggle};
5543
+
5544
+ ${({ noMargin }) => css `
5545
+ &&&& {
5546
+ margin-bottom: 0;
5547
+ }
5548
+ `};
5553
5549
  `;
5554
- const Container = styled(Flex) `
5555
- flex-direction: column;
5556
- width: 100%;
5557
-
5550
+ const Container = styled(Flex) `
5551
+ flex-direction: column;
5552
+ width: 100%;
5553
+
5558
5554
  ${({ isColumn }) => isColumn
5559
- ? css `
5560
- &&& > * {
5561
- justify-content: flex-start;
5562
- }
5563
- > * {
5564
- width: 100%;
5565
-
5566
- :not(:last-child) {
5567
- margin-bottom: 1.5rem;
5568
- }
5569
- }
5555
+ ? css `
5556
+ &&& > * {
5557
+ justify-content: flex-start;
5558
+ }
5559
+ > * {
5560
+ width: 100%;
5561
+
5562
+ :not(:last-child) {
5563
+ margin-bottom: 1.5rem;
5564
+ }
5565
+ }
5570
5566
  `
5571
- : css `
5572
- flex-direction: row;
5573
- justify-content: space-between;
5574
- align-items: center;
5575
- `}
5576
-
5567
+ : css `
5568
+ flex-direction: row;
5569
+ justify-content: space-between;
5570
+ align-items: center;
5571
+ `}
5572
+
5577
5573
  ${({ isTitle }) => isTitle &&
5578
- css `
5579
- &&&& {
5580
- margin-bottom: 0.75rem;
5581
- }
5582
- `}
5583
-
5584
- ${({ noBorders }) => noBorders && css `
5585
- ${ContainerWrapper} {
5586
- box-shadow: none;
5587
- padding: 0;
5588
- }
5589
- `}
5590
- `;
5591
- const ContainerWrapper = styled(Flex) `
5592
- position: relative;
5593
- box-sizing: border-box;
5594
- width: 100%;
5595
- background: ${({ theme: { palette } }) => palette.backgroundAlpha};
5596
- box-shadow: rgb(0 0 0 / 15%) 0 0.1875rem 0.625rem;
5597
- margin-bottom: 2rem;
5598
- padding: 1.5rem;
5599
- border-radius: 0.5rem;
5600
- backdrop-filter: blur(20px);
5601
- color: ${({ theme: { palette } }) => palette.textPrimary};
5602
- z-index: ${({ $zIndex }) => $zIndex ?? 1};
5603
- transition: background-color ${transition.toggle};
5604
-
5605
- ${({ $noMargin }) => $noMargin && css `
5606
- &&&& {
5607
- margin-bottom: 0;
5608
- }
5609
- `}
5610
- `;
5611
- const DashboardChip = styled(Chip) `
5612
- margin: 0 0.25rem 0.25rem 0;
5613
- background: ${({ $isDefault, $bgColor, theme: { palette } }) => $isDefault ? palette.element : $bgColor || palette.primary};
5614
- border-radius: ${({ $radius, theme: { borderRadius } }) => $radius || borderRadius.medium};
5615
- font-size: ${({ $fontSize }) => $fontSize || "0.875rem"};
5616
- color: ${({ $isDefault, $fontColor, theme: { palette } }) => $isDefault ? palette.textPrimary : $fontColor || "#fff"};
5617
-
5618
- > * {
5619
- font-size: ${({ $fontSize }) => $fontSize || "0.875rem"};
5620
- color: ${({ $isDefault, $fontColor, theme: { palette } }) => $isDefault ? palette.textPrimary : $fontColor || "#fff"};
5621
- }
5622
-
5623
- span[kind]:after {
5624
- color: ${({ $isDefault, $fontColor, theme: { palette } }) => ($isDefault ? palette.icon : $fontColor || "#fff")};
5625
- }
5574
+ css `
5575
+ &&&& {
5576
+ margin-bottom: 0.75rem;
5577
+ }
5578
+ `}
5579
+
5580
+ ${({ noBorders }) => noBorders && css `
5581
+ ${ContainerWrapper} {
5582
+ box-shadow: none;
5583
+ padding: 0;
5584
+ }
5585
+ `}
5586
+ `;
5587
+ const ContainerWrapper = styled(Flex) `
5588
+ position: relative;
5589
+ box-sizing: border-box;
5590
+ width: 100%;
5591
+ background: ${({ theme: { palette } }) => palette.backgroundAlpha};
5592
+ box-shadow: rgb(0 0 0 / 15%) 0 0.1875rem 0.625rem;
5593
+ margin-bottom: 2rem;
5594
+ padding: 1.5rem;
5595
+ border-radius: 0.5rem;
5596
+ backdrop-filter: blur(20px);
5597
+ color: ${({ theme: { palette } }) => palette.textPrimary};
5598
+ z-index: ${({ $zIndex }) => $zIndex ?? 1};
5599
+ transition: background-color ${transition.toggle};
5600
+
5601
+ ${({ $noMargin }) => $noMargin && css `
5602
+ &&&& {
5603
+ margin-bottom: 0;
5604
+ }
5605
+ `}
5606
+ `;
5607
+ const DashboardChip = styled(Chip) `
5608
+ margin: 0 0.25rem 0.25rem 0;
5609
+ background: ${({ $isDefault, $bgColor, theme: { palette } }) => $isDefault ? palette.element : $bgColor || palette.primary};
5610
+ border-radius: ${({ $radius, theme: { borderRadius } }) => $radius || borderRadius.medium};
5611
+ font-size: ${({ $fontSize }) => $fontSize || "0.875rem"};
5612
+ color: ${({ $isDefault, $fontColor, theme: { palette } }) => $isDefault ? palette.textPrimary : $fontColor || "#fff"};
5613
+
5614
+ > * {
5615
+ font-size: ${({ $fontSize }) => $fontSize || "0.875rem"};
5616
+ color: ${({ $isDefault, $fontColor, theme: { palette } }) => $isDefault ? palette.textPrimary : $fontColor || "#fff"};
5617
+ }
5618
+
5619
+ span[kind]:after {
5620
+ color: ${({ $isDefault, $fontColor, theme: { palette } }) => ($isDefault ? palette.icon : $fontColor || "#fff")};
5621
+ }
5626
5622
  `;
5627
- const DashboardPlaceholderWrap = styled(Flex) `
5628
- flex-grow: 1;
5629
- flex-direction: column;
5630
- justify-content: center;
5631
- align-items: center;
5632
- width: 100%;
5633
- margin-bottom: 2rem;
5634
- `;
5635
- const DashboardPlaceholder = styled(Flex) `
5636
- flex-direction: column;
5637
- justify-content: center;
5638
- align-items: center;
5639
- margin-top: 2rem;
5640
-
5623
+ const DashboardPlaceholderWrap = styled(Flex) `
5624
+ flex-grow: 1;
5625
+ flex-direction: column;
5626
+ justify-content: center;
5627
+ align-items: center;
5628
+ width: 100%;
5629
+ margin-bottom: 2rem;
5630
+ `;
5631
+ const DashboardPlaceholder = styled(Flex) `
5632
+ flex-direction: column;
5633
+ justify-content: center;
5634
+ align-items: center;
5635
+ margin-top: 2rem;
5636
+
5641
5637
  ${({ isLoading }) => isLoading &&
5642
- css `
5643
- width: 6.25rem;
5644
- `}
5645
-
5646
- &&& > * {
5647
- margin-bottom: 0;
5648
- }
5649
-
5650
- > div {
5651
- width: 100%;
5652
- margin-top: 1rem;
5653
- font-size: 0.75rem;
5654
- text-align: center;
5655
- color: ${({ theme: { palette } }) => palette.textDisabled};
5656
- }
5657
-
5658
- span[kind] {
5659
- width: 2.25rem;
5660
- height: 2.25rem;
5661
- opacity: 0.28;
5662
-
5663
- :after {
5664
- font-size: 32px;
5665
- }
5666
- }
5638
+ css `
5639
+ width: 6.25rem;
5640
+ `}
5641
+
5642
+ &&& > * {
5643
+ margin-bottom: 0;
5644
+ }
5645
+
5646
+ > div {
5647
+ width: 100%;
5648
+ margin-top: 1rem;
5649
+ font-size: 0.75rem;
5650
+ text-align: center;
5651
+ color: ${({ theme: { palette } }) => palette.textDisabled};
5652
+ }
5653
+
5654
+ span[kind] {
5655
+ width: 2.25rem;
5656
+ height: 2.25rem;
5657
+ opacity: 0.28;
5658
+
5659
+ :after {
5660
+ font-size: 32px;
5661
+ }
5662
+ }
5667
5663
  `;
5668
- const DashboardWrapper = styled(Flex) `
5669
- flex-direction: column;
5670
- flex-wrap: nowrap;
5671
- flex-grow: 1;
5672
- width: calc(100% - 3rem);
5673
- height: calc(100% - ${LEFT_PANEL_HEADER_HEIGHT});
5674
-
5664
+ const DashboardWrapper = styled(Flex) `
5665
+ flex-direction: column;
5666
+ flex-wrap: nowrap;
5667
+ flex-grow: 1;
5668
+ width: calc(100% - 3rem);
5669
+ height: calc(100% - ${LEFT_PANEL_HEADER_HEIGHT});
5670
+
5675
5671
  ${({ hasImage, isPresentationMode }) => hasImage &&
5676
5672
  !isPresentationMode &&
5677
- css `
5678
- margin-top: -0.35rem;
5679
- `}
5680
- `;
5681
- const DashboardContent = styled(Flex) `
5682
- flex-grow: 1;
5683
- width: 100%;
5684
- padding: 1.5rem 1.5rem 2rem;
5685
- overflow-y: auto;
5686
- scrollbar-gutter: stable;
5687
- `;
5688
- const PresentationWrapperCss = css `
5689
- margin-bottom: 0.75rem;
5690
- padding: 1.5rem;
5691
- background-color: ${({ theme: { palette } }) => palette.panelBackground};
5692
- backdrop-filter: blur(10px);
5693
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
5694
- box-shadow: ${shadows.raised};
5695
- `;
5696
- const PresentationWrapper = styled.div `
5697
- ${PresentationWrapperCss};
5698
- position: relative;
5699
- z-index: 1;
5700
- `;
5701
- const PresentationPanelWrapper = styled(PresentationWrapper) `
5702
- margin-top: 0.75rem;
5703
- transition: background-color ${transition.toggle};
5704
- `;
5705
- const PresentationHeader = styled.div `
5706
- margin: -1.5rem -1.5rem 0 -1.5rem;
5707
- padding: 1.5rem;
5708
- // background: url(images.presentationHeader) 0 0 no-repeat;
5709
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
5710
- transition: background-color ${transition.toggle};
5711
-
5673
+ css `
5674
+ margin-top: -0.35rem;
5675
+ `}
5676
+ `;
5677
+ const DashboardContent = styled(Flex) `
5678
+ flex-grow: 1;
5679
+ width: 100%;
5680
+ padding: 1.5rem 1.5rem 2rem;
5681
+ overflow-y: auto;
5682
+ scrollbar-gutter: stable;
5683
+ `;
5684
+ const PresentationWrapperCss = css `
5685
+ margin-bottom: 0.75rem;
5686
+ padding: 1.5rem;
5687
+ background-color: ${({ theme: { palette } }) => palette.panelBackground};
5688
+ backdrop-filter: blur(10px);
5689
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
5690
+ box-shadow: ${shadows.raised};
5691
+ `;
5692
+ const PresentationWrapper = styled.div `
5693
+ ${PresentationWrapperCss};
5694
+ position: relative;
5695
+ z-index: 1;
5696
+ `;
5697
+ const PresentationPanelWrapper = styled(PresentationWrapper) `
5698
+ margin-top: 0.75rem;
5699
+ transition: background-color ${transition.toggle};
5700
+ `;
5701
+ const PresentationHeader = styled.div `
5702
+ margin: -1.5rem -1.5rem 0 -1.5rem;
5703
+ padding: 1.5rem;
5704
+ // background: url(images.presentationHeader) 0 0 no-repeat;
5705
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
5706
+ transition: background-color ${transition.toggle};
5707
+
5712
5708
  ${({ image }) => !!image &&
5713
- css `
5714
- padding-top: 7rem;
5715
- `};
5716
- `;
5717
- const PresentationHeaderTools = styled(Flex) `
5718
- justify-content: space-between;
5719
- align-items: center;
5720
- margin-bottom: -0.5rem;
5721
- margin-right: -0.5rem;
5722
-
5723
- span[kind="sun"],
5724
- span[kind="moon"] {
5725
- :after {
5726
- font-size: 0.85rem;
5727
- color: ${({ theme: { palette } }) => palette.iconDisabled};
5728
- }
5729
-
5730
- :hover:after {
5731
- color: ${({ theme: { palette } }) => palette.icon};
5732
- }
5733
- }
5709
+ css `
5710
+ padding-top: 7rem;
5711
+ `};
5734
5712
  `;
5735
- const LayerGroupList = styled(Flex) `
5736
- flex-direction: column;
5737
- height: 100%;
5738
- flex-wrap: nowrap;
5739
- overflow-x: ${({ $noScroll }) => ($noScroll ? "visible" : "hidden")};
5740
- overflow-y: ${({ $noScroll }) => ($noScroll ? "visible" : "auto")};
5741
- padding: 0 0.125rem 0 0.75rem;
5742
- scrollbar-gutter: stable;
5743
-
5744
- > * {
5745
- flex-grow: 1;
5746
- }
5713
+ const PresentationHeaderTools = styled(Flex) `
5714
+ justify-content: space-between;
5715
+ align-items: center;
5716
+ margin-bottom: -0.5rem;
5717
+ margin-right: -0.5rem;
5718
+
5719
+ span[kind="sun"],
5720
+ span[kind="moon"] {
5721
+ :after {
5722
+ font-size: 0.85rem;
5723
+ color: ${({ theme: { palette } }) => palette.iconDisabled};
5724
+ }
5725
+
5726
+ :hover:after {
5727
+ color: ${({ theme: { palette } }) => palette.icon};
5728
+ }
5729
+ }
5730
+ `;
5731
+ const LayerGroupList = styled(Flex) `
5732
+ flex-direction: column;
5733
+ height: 100%;
5734
+ flex-wrap: nowrap;
5735
+ overflow-x: ${({ $noScroll }) => ($noScroll ? "visible" : "hidden")};
5736
+ overflow-y: ${({ $noScroll }) => ($noScroll ? "visible" : "auto")};
5737
+ padding: 0 0.125rem 0 0.75rem;
5738
+ scrollbar-gutter: stable;
5739
+
5740
+ > * {
5741
+ flex-grow: 1;
5742
+ }
5747
5743
  `;
5748
5744
  const PresentationHeaderButtons = styled(Flex) ``;
5749
- const PresentationPanelContainer = styled.div `
5750
- position: absolute;
5751
- top: 0;
5752
- left: calc(${({ left }) => left || 0}px + 0.75rem);
5753
- bottom: 0;
5754
- z-index: 3;
5755
- display: flex;
5756
- flex-direction: column;
5757
- width: ${LEFT_PANEL_HEADER_HEIGHT}px;
5758
- padding-right: 0.5rem;
5759
- scrollbar-gutter: stable;
5760
- overflow-y: hidden;
5761
-
5762
- :hover {
5763
- overflow-y: auto;
5764
- }
5765
-
5745
+ const PresentationPanelContainer = styled.div `
5746
+ position: absolute;
5747
+ top: 0;
5748
+ left: calc(${({ left }) => left || 0}px + 0.75rem);
5749
+ bottom: 0;
5750
+ z-index: 3;
5751
+ display: flex;
5752
+ flex-direction: column;
5753
+ width: ${LEFT_PANEL_HEADER_HEIGHT}px;
5754
+ padding-right: 0.5rem;
5755
+ scrollbar-gutter: stable;
5756
+ overflow-y: hidden;
5757
+
5758
+ :hover {
5759
+ overflow-y: auto;
5760
+ }
5761
+
5766
5762
  ${({ showLayers }) => !showLayers &&
5767
- css `
5768
- > :first-child {
5769
- padding-bottom: 0;
5770
- }
5771
- `};
5772
-
5773
- ${PresentationHeader} > * {
5774
- position: relative;
5775
- z-index: 2;
5776
- }
5777
-
5778
- /* PaginationWrapper {
5779
- ${PresentationWrapperCss};
5780
- width: calc(100% - 2rem);
5781
- min-height: 8.625rem;
5782
- padding-top: 0.5rem;
5783
- padding-bottom: 0.5rem;
5784
- margin-bottom: 0.75rem;
5785
- }*/
5786
-
5787
- ${DashboardWrapper} {
5788
- width: 100%;
5789
- margin-top: 0;
5790
-
5791
- ${DashboardContent} {
5792
- padding: 0;
5793
- overflow-y: unset;
5794
-
5795
- > * > ${ContainerWrapper} > * > ${ContainerWrapper} {
5796
- ${PresentationWrapperCss};
5797
- width: calc(100% - 3rem);
5798
- }
5799
- }
5800
- }
5801
-
5802
- ${DashboardPlaceholder} {
5803
- ${PresentationWrapperCss};
5804
- width: 18.5rem;
5805
- height: 10.75rem;
5806
- }
5807
-
5808
- ${LayerListContainer} {
5809
- height: auto;
5810
- margin: 0 -1.125rem -1.5rem;
5811
- padding: 0;
5812
-
5813
- ${LayerGroupList} {
5814
- padding: 0;
5815
- }
5816
- }
5763
+ css `
5764
+ > :first-child {
5765
+ padding-bottom: 0;
5766
+ }
5767
+ `};
5768
+
5769
+ ${PresentationHeader} > * {
5770
+ position: relative;
5771
+ z-index: 2;
5772
+ }
5773
+
5774
+ /* PaginationWrapper {
5775
+ ${PresentationWrapperCss};
5776
+ width: calc(100% - 2rem);
5777
+ min-height: 8.625rem;
5778
+ padding-top: 0.5rem;
5779
+ padding-bottom: 0.5rem;
5780
+ margin-bottom: 0.75rem;
5781
+ }*/
5782
+
5783
+ ${DashboardWrapper} {
5784
+ width: 100%;
5785
+ margin-top: 0;
5786
+
5787
+ ${DashboardContent} {
5788
+ padding: 0;
5789
+ overflow-y: unset;
5790
+
5791
+ > * > ${ContainerWrapper} > * > ${ContainerWrapper} {
5792
+ ${PresentationWrapperCss};
5793
+ width: calc(100% - 3rem);
5794
+ }
5795
+ }
5796
+ }
5797
+
5798
+ ${DashboardPlaceholder} {
5799
+ ${PresentationWrapperCss};
5800
+ width: 18.5rem;
5801
+ height: 10.75rem;
5802
+ }
5803
+
5804
+ ${LayerListContainer} {
5805
+ height: auto;
5806
+ margin: 0 -1.125rem -1.5rem;
5807
+ padding: 0;
5808
+
5809
+ ${LayerGroupList} {
5810
+ padding: 0;
5811
+ }
5812
+ }
5817
5813
  `;
5818
- const DataSourceErrorContainer = styled(Flex) `
5819
- align-items: center;
5820
- justify-content: center;
5821
- flex-wrap: nowrap;
5822
- flex-grow: 1;
5823
- padding: 1rem;
5824
- border: 1px ${({ theme: { palette } }) => palette.element} solid;
5825
- border-radius: 10px;
5826
- font-size: 0.875rem;
5827
- color: ${({ theme: { palette } }) => palette.textDisabled};
5828
-
5829
- span[kind] {
5830
- margin-right: 1rem;
5831
-
5832
- :after {
5833
- color: ${({ theme: { palette } }) => palette.iconDisabled};
5834
- }
5835
- }
5814
+ const DataSourceErrorContainer = styled(Flex) `
5815
+ align-items: center;
5816
+ justify-content: center;
5817
+ flex-wrap: nowrap;
5818
+ flex-grow: 1;
5819
+ padding: 1rem;
5820
+ border: 1px ${({ theme: { palette } }) => palette.element} solid;
5821
+ border-radius: 10px;
5822
+ font-size: 0.875rem;
5823
+ color: ${({ theme: { palette } }) => palette.textDisabled};
5824
+
5825
+ span[kind] {
5826
+ margin-right: 1rem;
5827
+
5828
+ :after {
5829
+ color: ${({ theme: { palette } }) => palette.iconDisabled};
5830
+ }
5831
+ }
5836
5832
  `;
5837
- const AttributeLabel = styled(Description) `
5838
- margin-top: 0 !important;
5839
- margin-bottom: ${({ forCheckbox }) => (forCheckbox ? "0.75rem" : "0.25rem")} !important;
5840
- padding-left: ${({ isEdit }) => (isEdit ? "0.5rem" : "0")};
5841
- `;
5842
- const FeatureControls = styled(Flex) `
5843
- align-items: center;
5844
- gap: 1rem;
5845
- flex-wrap: nowrap;
5846
- position: relative;
5847
- flex-shrink: 0;
5848
-
5849
- button {
5850
- padding: 0;
5851
- width: auto;
5852
- }
5833
+ const AttributeLabel = styled(Description) `
5834
+ margin-top: 0 !important;
5835
+ margin-bottom: ${({ forCheckbox }) => (forCheckbox ? "0.75rem" : "0.25rem")} !important;
5836
+ padding-left: ${({ isEdit }) => (isEdit ? "0.5rem" : "0")};
5837
+ `;
5838
+ const FeatureControls = styled(Flex) `
5839
+ align-items: center;
5840
+ gap: 1rem;
5841
+ flex-wrap: nowrap;
5842
+ position: relative;
5843
+ flex-shrink: 0;
5844
+
5845
+ button {
5846
+ padding: 0;
5847
+ width: auto;
5848
+ }
5853
5849
  `;
5854
5850
 
5855
5851
  const getAttributeByName = (attributeName, attributes) => {
@@ -5930,148 +5926,148 @@ const ContainersGroupContainer = memo(({ elementConfig, type, renderElement }) =
5930
5926
  return (jsxs(Fragment$1, { children: [jsx(ExpandableTitle, { elementConfig: elementConfig, type: type, renderElement: renderElement }), isVisible && (jsx(Container, { id: id, isColumn: isColumn, children: jsx(ContainerChildren, { type: type, items: children, elementConfig: elementConfig, isColumn: isColumn, isMain: id?.startsWith(CONFIG_PAGE_ID), renderElement: renderElement }) }))] }));
5931
5927
  });
5932
5928
 
5933
- const ChartLegendContainer = styled(Flex) `
5934
- flex-direction: column;
5935
- flex-wrap: wrap;
5936
- justify-content: ${({ twoColumns }) => (twoColumns ? "flex-start" : "center")};
5937
- `;
5938
- const ChartLegendItem = styled(Flex) `
5939
- cursor: ${({ onClick }) => (onClick ? "pointer" : "default")};
5940
- align-items: center;
5941
- flex-wrap: nowrap;
5942
- width: auto;
5943
- margin-right: 0.375rem;
5944
- margin-bottom: 0.25rem;
5945
- line-height: 0.75rem;
5946
- opacity: ${({ isFiltered, hasAnyFilter }) => (isFiltered ? 1 : hasAnyFilter ? FILTERED_VALUE_OPACITY / 100 : 1)};
5947
- `;
5948
- const ChartLegendColor = styled.div `
5949
- width: 0.5rem;
5950
- height: 0.5rem;
5951
- margin-right: 0.375rem;
5952
- background-color: ${({ color }) => color};
5953
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.tiny};
5954
- `;
5955
- const ChartLegendName = styled.div `
5956
- flex: 1;
5957
- font-size: ${({ $fontSize }) => $fontSize || "0.625rem"};
5958
- color: ${({ theme: { palette }, $fontColor }) => $fontColor || palette.textPrimary};
5959
- `;
5929
+ const ChartLegendContainer = styled(Flex) `
5930
+ flex-direction: column;
5931
+ flex-wrap: wrap;
5932
+ justify-content: ${({ twoColumns }) => (twoColumns ? "flex-start" : "center")};
5933
+ `;
5934
+ const ChartLegendItem = styled(Flex) `
5935
+ cursor: ${({ onClick }) => (onClick ? "pointer" : "default")};
5936
+ align-items: center;
5937
+ flex-wrap: nowrap;
5938
+ width: auto;
5939
+ margin-right: 0.375rem;
5940
+ margin-bottom: 0.25rem;
5941
+ line-height: 0.75rem;
5942
+ opacity: ${({ isFiltered, hasAnyFilter }) => (isFiltered ? 1 : hasAnyFilter ? FILTERED_VALUE_OPACITY / 100 : 1)};
5943
+ `;
5944
+ const ChartLegendColor = styled.div `
5945
+ width: 0.5rem;
5946
+ height: 0.5rem;
5947
+ margin-right: 0.375rem;
5948
+ background-color: ${({ color }) => color};
5949
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.tiny};
5950
+ `;
5951
+ const ChartLegendName = styled.div `
5952
+ flex: 1;
5953
+ font-size: ${({ $fontSize }) => $fontSize || "0.625rem"};
5954
+ color: ${({ theme: { palette }, $fontColor }) => $fontColor || palette.textPrimary};
5955
+ `;
5956
+
5957
+ const ContainerAlias = styled(Flex) `
5958
+ align-items: center;
5959
+ flex-wrap: nowrap;
5960
+ font-size: 0.75rem;
5961
+ color: ${({ theme: { palette } }) => palette.textSecondary};
5962
+
5963
+ &&& {
5964
+ margin-bottom: ${({ hasBottomMargin }) => (hasBottomMargin ? 0.25 : 0)}rem;
5965
+ }
5966
+
5967
+ span[kind] {
5968
+ margin-right: 0.5rem;
5960
5969
 
5961
- const ContainerAlias = styled(Flex) `
5962
- align-items: center;
5963
- flex-wrap: nowrap;
5964
- font-size: 0.75rem;
5965
- color: ${({ theme: { palette } }) => palette.textSecondary};
5966
-
5967
- &&& {
5968
- margin-bottom: ${({ hasBottomMargin }) => (hasBottomMargin ? 0.25 : 0)}rem;
5969
- }
5970
-
5971
- span[kind] {
5972
- margin-right: 0.5rem;
5973
-
5974
- :after {
5975
- color: ${({ theme: { palette } }) => palette.primary};
5976
- }
5977
- }
5970
+ :after {
5971
+ color: ${({ theme: { palette } }) => palette.primary};
5972
+ }
5973
+ }
5978
5974
  `;
5979
- const ContainerAliasIcon = styled.div `
5980
- margin-right: 0.5rem;
5975
+ const ContainerAliasIcon = styled.div `
5976
+ margin-right: 0.5rem;
5981
5977
  `;
5982
- const ContainerChart = styled(Flex) `
5983
- justify-content: flex-start;
5984
-
5985
- > * {
5986
- display: flex;
5987
- justify-content: center;
5988
- width: 100%;
5989
- }
5978
+ const ContainerChart = styled(Flex) `
5979
+ justify-content: flex-start;
5980
+
5981
+ > * {
5982
+ display: flex;
5983
+ justify-content: center;
5984
+ width: 100%;
5985
+ }
5990
5986
  `;
5991
5987
  const ContainerLegend = styled(Flex) ``;
5992
- const ContainerUnits = styled.div `
5993
- margin-left: 0.5rem;
5994
- white-space: nowrap;
5995
- font-size: 0.75rem;
5996
- `;
5997
- const ContainerValue = styled(Flex) `
5998
- justify-content: flex-end;
5999
- align-items: center;
6000
- flex-wrap: nowrap;
6001
- width: 100%;
6002
- font-size: ${({ big }) => (big ? 1.5 : 1)}rem;
6003
- color: ${({ fontColor, theme: { palette } }) => fontColor || palette.textPrimary};
6004
-
6005
- > * {
6006
- width: ${({ column }) => (column ? "100%" : "auto")};
6007
- }
6008
-
6009
- ${ContainerChart}, ${ContainerLegend} {
6010
- width: ${({ column }) => (column ? "100%" : "50%")};
6011
- }
6012
-
6013
- ${ContainerLegend} {
6014
- margin-left: ${({ column }) => (column ? 0 : "1rem")};
6015
- }
6016
-
6017
- ${ChartLegendContainer} {
6018
- flex-direction: ${({ column }) => (column ? "row" : "column")};
6019
- margin-top: ${({ column }) => (column ? "1rem" : 0)};
6020
- }
6021
- `;
6022
- const ColorIconMixin = css `
6023
- :after {
6024
- color: ${({ $fontColor }) => $fontColor} !important;
6025
- }
6026
- `;
6027
- const SizeIconMixin = css `
6028
- :after {
6029
- font-size: ${({ $fontSize }) => $fontSize}px !important;
6030
- }
5988
+ const ContainerUnits = styled.div `
5989
+ margin-left: 0.5rem;
5990
+ white-space: nowrap;
5991
+ font-size: 0.75rem;
5992
+ `;
5993
+ const ContainerValue = styled(Flex) `
5994
+ justify-content: flex-end;
5995
+ align-items: center;
5996
+ flex-wrap: nowrap;
5997
+ width: 100%;
5998
+ font-size: ${({ big }) => (big ? 1.5 : 1)}rem;
5999
+ color: ${({ fontColor, theme: { palette } }) => fontColor || palette.textPrimary};
6000
+
6001
+ > * {
6002
+ width: ${({ column }) => (column ? "100%" : "auto")};
6003
+ }
6004
+
6005
+ ${ContainerChart}, ${ContainerLegend} {
6006
+ width: ${({ column }) => (column ? "100%" : "50%")};
6007
+ }
6008
+
6009
+ ${ContainerLegend} {
6010
+ margin-left: ${({ column }) => (column ? 0 : "1rem")};
6011
+ }
6012
+
6013
+ ${ChartLegendContainer} {
6014
+ flex-direction: ${({ column }) => (column ? "row" : "column")};
6015
+ margin-top: ${({ column }) => (column ? "1rem" : 0)};
6016
+ }
6031
6017
  `;
6032
- const ContainerIcon = styled(Icon) `
6033
- width: auto;
6034
- height: auto;
6035
- margin-bottom: 0.5rem;
6036
- ${({ $fontColor }) => !!$fontColor && ColorIconMixin};
6037
- ${({ $fontSize }) => !!$fontSize && SizeIconMixin};
6038
- `;
6039
- const SvgContainerColorMixin$1 = css `
6040
- path,
6041
- line,
6042
- circle {
6043
- fill: ${({ $fontColor }) => $fontColor};
6044
- }
6018
+ const ColorIconMixin = css `
6019
+ :after {
6020
+ color: ${({ $fontColor }) => $fontColor} !important;
6021
+ }
6045
6022
  `;
6046
- const SvgContainer$1 = styled.div `
6047
- &&& {
6048
- min-width: ${({ $width }) => ($width ? `${$width}px` : "1rem")};
6049
- max-width: ${({ $width }) => ($width ? `${$width}px` : "1rem")};
6050
-
6051
- ${({ $fontColor }) => !!$fontColor && SvgContainerColorMixin$1};
6052
-
6053
- > * {
6054
- min-width: inherit;
6055
- }
6056
- }
6023
+ const SizeIconMixin = css `
6024
+ :after {
6025
+ font-size: ${({ $fontSize }) => $fontSize}px !important;
6026
+ }
6057
6027
  `;
6058
- const TwoColumnContainerWrapper = styled(Flex) `
6059
- width: 100%;
6060
- flex-direction: row;
6061
- flex-wrap: nowrap;
6062
- align-items: center;
6063
-
6064
- > * {
6065
- flex: 1;
6066
- }
6067
-
6068
- > ${ContainerValue} {
6069
- justify-content: flex-end;
6070
-
6071
- > * {
6072
- text-align: right;
6073
- }
6074
- }
6028
+ const ContainerIcon = styled(Icon) `
6029
+ width: auto;
6030
+ height: auto;
6031
+ margin-bottom: 0.5rem;
6032
+ ${({ $fontColor }) => !!$fontColor && ColorIconMixin};
6033
+ ${({ $fontSize }) => !!$fontSize && SizeIconMixin};
6034
+ `;
6035
+ const SvgContainerColorMixin$1 = css `
6036
+ path,
6037
+ line,
6038
+ circle {
6039
+ fill: ${({ $fontColor }) => $fontColor};
6040
+ }
6041
+ `;
6042
+ const SvgContainer$1 = styled.div `
6043
+ &&& {
6044
+ min-width: ${({ $width }) => ($width ? `${$width}px` : "1rem")};
6045
+ max-width: ${({ $width }) => ($width ? `${$width}px` : "1rem")};
6046
+
6047
+ ${({ $fontColor }) => !!$fontColor && SvgContainerColorMixin$1};
6048
+
6049
+ > * {
6050
+ min-width: inherit;
6051
+ }
6052
+ }
6053
+ `;
6054
+ const TwoColumnContainerWrapper = styled(Flex) `
6055
+ width: 100%;
6056
+ flex-direction: row;
6057
+ flex-wrap: nowrap;
6058
+ align-items: center;
6059
+
6060
+ > * {
6061
+ flex: 1;
6062
+ }
6063
+
6064
+ > ${ContainerValue} {
6065
+ justify-content: flex-end;
6066
+
6067
+ > * {
6068
+ text-align: right;
6069
+ }
6070
+ }
6075
6071
  `;
6076
6072
 
6077
6073
  const OneColumnContainer = memo(({ elementConfig, renderElement }) => {
@@ -6132,10 +6128,10 @@ const TwoColumnContainer = memo(({ config, elementConfig, type, renderElement })
6132
6128
  return renderAttributes?.length ? (jsx(Fragment$1, { children: renderAttributes.map(attribute => renderContainer(attribute)) })) : (renderContainer());
6133
6129
  });
6134
6130
 
6135
- const InnerContainerWrapper = styled.div `
6136
- cursor: ${({ onClick }) => (onClick ? "pointer" : "default")};
6137
- width: ${({ column }) => (column ? "100%" : "auto")};
6138
- opacity: ${({ hasAnyFilter, isFiltered }) => (isFiltered ? 1 : hasAnyFilter ? FILTERED_VALUE_OPACITY / 100 : 1)};
6131
+ const InnerContainerWrapper = styled.div `
6132
+ cursor: ${({ onClick }) => (onClick ? "pointer" : "default")};
6133
+ width: ${({ column }) => (column ? "100%" : "auto")};
6134
+ opacity: ${({ hasAnyFilter, isFiltered }) => (isFiltered ? 1 : hasAnyFilter ? FILTERED_VALUE_OPACITY / 100 : 1)};
6139
6135
  `;
6140
6136
 
6141
6137
  const DataSourceInnerContainer = memo(({ config, elementConfig, feature, maxValue, type, index, innerComponent }) => {
@@ -6206,107 +6202,107 @@ const DataSourceInnerContainer = memo(({ config, elementConfig, feature, maxValu
6206
6202
  return (jsx(InnerContainerWrapper, { hasAnyFilter: hasAnyFilter, isFiltered: isFiltered(value), column: column === undefined || column, onClick: filterName ? () => onFilter(value) : undefined, children: jsx(InnerContainer, { config: config, elementConfig: elementConfig, feature: feature, maxValue: maxValue, type: type, index: index, renderElement: render }) }));
6207
6203
  });
6208
6204
 
6209
- const DataSourceProgressContainerWrapper = styled.div `
6210
- width: 100%;
6205
+ const DataSourceProgressContainerWrapper = styled.div `
6206
+ width: 100%;
6211
6207
  `;
6212
- const ContainerToggler = styled(LegendToggler) `
6213
- width: auto;
6214
- margin-left: -1rem;
6208
+ const ContainerToggler = styled(LegendToggler) `
6209
+ width: auto;
6210
+ margin-left: -1rem;
6215
6211
  `;
6216
6212
 
6217
- const ProgressContainerWrapper = styled(Flex) `
6218
- align-items: center;
6219
- width: 100%;
6220
- margin-bottom: 1rem;
6213
+ const ProgressContainerWrapper = styled(Flex) `
6214
+ align-items: center;
6215
+ width: 100%;
6216
+ margin-bottom: 1rem;
6221
6217
  `;
6222
- const ProgressIcon = styled.div `
6223
- margin-right: 0.5rem;
6218
+ const ProgressIcon = styled.div `
6219
+ margin-right: 0.5rem;
6224
6220
  `;
6225
- const ProgressContent = styled(Flex) `
6226
- flex: 1;
6227
- flex-direction: column;
6221
+ const ProgressContent = styled(Flex) `
6222
+ flex: 1;
6223
+ flex-direction: column;
6228
6224
  `;
6229
- const ProgressAlias = styled(Flex) `
6230
- flex: 1;
6231
- justify-content: space-between;
6232
- margin-bottom: 0.25rem;
6233
- font-size: 0.75rem;
6234
- color: ${({ theme: { palette } }) => palette.textSecondary};
6235
- `;
6236
- const ProgressValue = styled(Flex) `
6237
- align-items: center;
6238
- width: auto;
6239
- font-size: 1rem;
6240
- color: ${({ theme: { palette } }) => palette.textPrimary};
6241
- `;
6242
- const ProgressInnerValue = styled(ProgressValue) `
6243
- justify-content: flex-end;
6244
- width: 4rem;
6245
- margin-left: 0.5rem;
6246
- `;
6247
- const ProgressUnits = styled(Flex) `
6248
- margin-left: 0.25rem;
6249
- font-size: 0.75rem;
6250
- color: ${({ theme: { palette } }) => palette.textSecondary};
6251
- `;
6252
- const ProgressBarWrapper = styled.div `
6253
- flex-grow: 1;
6254
- height: 0.5rem;
6255
- background-color: ${({ theme: { palette } }) => palette.element};
6256
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.xSmall};
6257
- `;
6258
- const ProgressBarContainer = styled(Flex) `
6259
- position: relative;
6260
- align-items: center;
6261
- width: 100%;
6262
-
6225
+ const ProgressAlias = styled(Flex) `
6226
+ flex: 1;
6227
+ justify-content: space-between;
6228
+ margin-bottom: 0.25rem;
6229
+ font-size: 0.75rem;
6230
+ color: ${({ theme: { palette } }) => palette.textSecondary};
6231
+ `;
6232
+ const ProgressValue = styled(Flex) `
6233
+ align-items: center;
6234
+ width: auto;
6235
+ font-size: 1rem;
6236
+ color: ${({ theme: { palette } }) => palette.textPrimary};
6237
+ `;
6238
+ const ProgressInnerValue = styled(ProgressValue) `
6239
+ justify-content: flex-end;
6240
+ width: 4rem;
6241
+ margin-left: 0.5rem;
6242
+ `;
6243
+ const ProgressUnits = styled(Flex) `
6244
+ margin-left: 0.25rem;
6245
+ font-size: 0.75rem;
6246
+ color: ${({ theme: { palette } }) => palette.textSecondary};
6247
+ `;
6248
+ const ProgressBarWrapper = styled.div `
6249
+ flex-grow: 1;
6250
+ height: 0.5rem;
6251
+ background-color: ${({ theme: { palette } }) => palette.element};
6252
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.xSmall};
6253
+ `;
6254
+ const ProgressBarContainer = styled(Flex) `
6255
+ position: relative;
6256
+ align-items: center;
6257
+ width: 100%;
6258
+
6263
6259
  ${({ innerValue }) => innerValue &&
6264
- css `
6265
- ${ProgressBarWrapper} {
6266
- height: 1.125rem;
6267
- }
6268
-
6269
- ${ProgressInnerValue} {
6270
- z-index: 1;
6271
- position: absolute;
6272
- right: 0.25rem;
6273
- }
6274
- `}
6275
- `;
6276
- const ProgressBar = styled.div `
6277
- width: ${({ $width }) => $width};
6278
- height: inherit;
6279
- background-color: ${({ $color }) => $color || "#a7d759"};
6280
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.xSmall};
6281
- `;
6282
- const ProgressTooltipAlias = styled.div `
6283
- margin-bottom: 0.25rem;
6284
- text-align: left;
6285
- color: ${({ theme: { palette } }) => palette.primary};
6260
+ css `
6261
+ ${ProgressBarWrapper} {
6262
+ height: 1.125rem;
6263
+ }
6264
+
6265
+ ${ProgressInnerValue} {
6266
+ z-index: 1;
6267
+ position: absolute;
6268
+ right: 0.25rem;
6269
+ }
6270
+ `}
6271
+ `;
6272
+ const ProgressBar = styled.div `
6273
+ width: ${({ $width }) => $width};
6274
+ height: inherit;
6275
+ background-color: ${({ $color }) => $color || "#a7d759"};
6276
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.xSmall};
6277
+ `;
6278
+ const ProgressTooltipAlias = styled.div `
6279
+ margin-bottom: 0.25rem;
6280
+ text-align: left;
6281
+ color: ${({ theme: { palette } }) => palette.primary};
6286
6282
  `;
6287
6283
  const ProgressTooltipValue = styled.div ``;
6288
- const ProgressTooltipValueContainer = styled(Flex) `
6289
- align-items: center;
6290
-
6291
- > * {
6292
- opacity: 0.65;
6293
- }
6294
-
6295
- ${ProgressTooltipValue} {
6296
- opacity: 1;
6297
- }
6284
+ const ProgressTooltipValueContainer = styled(Flex) `
6285
+ align-items: center;
6286
+
6287
+ > * {
6288
+ opacity: 0.65;
6289
+ }
6290
+
6291
+ ${ProgressTooltipValue} {
6292
+ opacity: 1;
6293
+ }
6298
6294
  `;
6299
- const ProgressTooltipValueOf = styled.div `
6300
- margin: 0 0.25rem;
6295
+ const ProgressTooltipValueOf = styled.div `
6296
+ margin: 0 0.25rem;
6301
6297
  `;
6302
- const ProgressTotalTitle = styled.div `
6303
- font-size: 0.75rem;
6304
- font-weight: bold;
6298
+ const ProgressTotalTitle = styled.div `
6299
+ font-size: 0.75rem;
6300
+ font-weight: bold;
6305
6301
  `;
6306
- const ProgressTotal = styled(Flex) `
6307
- align-items: center;
6308
- justify-content: space-between;
6309
- margin-top: 1rem;
6302
+ const ProgressTotal = styled(Flex) `
6303
+ align-items: center;
6304
+ justify-content: space-between;
6305
+ margin-top: 1rem;
6310
6306
  `;
6311
6307
 
6312
6308
  const DataSourceProgressContainer = memo(({ config, elementConfig, type, innerComponent, renderElement }) => {
@@ -6403,166 +6399,166 @@ const DEFAULT_BAR_CHART_MARGINS = {
6403
6399
  right: 0,
6404
6400
  };
6405
6401
 
6406
- const FiltersContainerWrapper = styled(Flex) `
6407
- flex-direction: column;
6408
- padding: ${({ $padding }) => $padding ?? `${DEFAULT_FILTER_PADDING}px`};
6409
- background-color: ${({ $bgColor, $fontColor, theme: { palette } }) => $bgColor || ($fontColor ? transparentizeColor($fontColor, 6) : palette.element)};
6410
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
6411
-
6412
- ${DropdownField}, input {
6413
- background-color: ${({ theme: { palette } }) => palette.background};
6414
- }
6415
-
6416
- > div:not(:last-child) {
6417
- margin-bottom: 0.5rem;
6418
- }
6419
-
6420
- > label {
6421
- align-items: flex-start;
6422
- font-size: ${({ $fontSize }) => $fontSize || "0.875rem"};
6423
-
6424
- &.active {
6425
- color: ${({ $fontColor }) => $fontColor};
6426
-
6427
- svg rect {
6428
- fill: ${({ $fontColor }) => $fontColor} !important;
6429
- }
6430
- }
6431
-
6432
- &:not(:last-child) {
6433
- margin-bottom: 0.75rem;
6434
- }
6435
-
6436
- &:last-child {
6437
- margin-bottom: 0;
6438
- }
6439
- }
6402
+ const FiltersContainerWrapper = styled(Flex) `
6403
+ flex-direction: column;
6404
+ padding: ${({ $padding }) => $padding ?? `${DEFAULT_FILTER_PADDING}px`};
6405
+ background-color: ${({ $bgColor, $fontColor, theme: { palette } }) => $bgColor || ($fontColor ? transparentizeColor($fontColor, 6) : palette.element)};
6406
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
6407
+
6408
+ ${DropdownField}, input {
6409
+ background-color: ${({ theme: { palette } }) => palette.background};
6410
+ }
6411
+
6412
+ > div:not(:last-child) {
6413
+ margin-bottom: 0.5rem;
6414
+ }
6415
+
6416
+ > label {
6417
+ align-items: flex-start;
6418
+ font-size: ${({ $fontSize }) => $fontSize || "0.875rem"};
6419
+
6420
+ &.active {
6421
+ color: ${({ $fontColor }) => $fontColor};
6422
+
6423
+ svg rect {
6424
+ fill: ${({ $fontColor }) => $fontColor} !important;
6425
+ }
6426
+ }
6427
+
6428
+ &:not(:last-child) {
6429
+ margin-bottom: 0.75rem;
6430
+ }
6431
+
6432
+ &:last-child {
6433
+ margin-bottom: 0;
6434
+ }
6435
+ }
6440
6436
  `;
6441
- const StyledIconButton = styled(IconButton) `
6442
- width: 0.75rem;
6443
- height: 0.75rem;
6444
-
6445
- span[kind] {
6446
- height: 0.75rem;
6447
-
6448
- :after {
6449
- font-size: 0.75rem;
6450
- }
6451
- }
6437
+ const StyledIconButton = styled(IconButton) `
6438
+ width: 0.75rem;
6439
+ height: 0.75rem;
6440
+
6441
+ span[kind] {
6442
+ height: 0.75rem;
6443
+
6444
+ :after {
6445
+ font-size: 0.75rem;
6446
+ }
6447
+ }
6452
6448
  `;
6453
- const TextFilterContainer = styled.div `
6454
- width: 15.85rem;
6455
-
6456
- ${MultiSelectContainer} {
6457
- color: ${({ theme: { palette } }) => palette.textPrimary};
6458
-
6459
- ${IconButtonButton} {
6460
- span[kind]:after {
6461
- color: ${({ theme: { palette } }) => palette.textPrimary};
6462
- }
6463
- }
6464
- }
6449
+ const TextFilterContainer = styled.div `
6450
+ width: 15.85rem;
6451
+
6452
+ ${MultiSelectContainer} {
6453
+ color: ${({ theme: { palette } }) => palette.textPrimary};
6454
+
6455
+ ${IconButtonButton} {
6456
+ span[kind]:after {
6457
+ color: ${({ theme: { palette } }) => palette.textPrimary};
6458
+ }
6459
+ }
6460
+ }
6465
6461
  `;
6466
- const BarChartContainer = styled.div `
6467
- width: 100%;
6468
- overflow-x: hidden;
6469
-
6462
+ const BarChartContainer = styled.div `
6463
+ width: 100%;
6464
+ overflow-x: hidden;
6465
+
6470
6466
  ${({ barHeight, marginBottom }) => !!barHeight &&
6471
- css `
6472
- .barChartBarGlobal rect {
6473
- height: ${barHeight}px;
6474
- y: calc(100% - ${barHeight + marginBottom}px);
6475
- }
6476
- `}
6477
- `;
6478
- const AnyChartWrapper = styled.div `
6479
- width: 100%;
6480
- height: ${({ height }) => height}px;
6481
- `;
6482
- const BarChartWrapper = styled(AnyChartWrapper) `
6483
- width: 100%;
6484
- margin: 0 auto ${BAR_CHART_FOOTER_MARGIN}px;
6485
-
6486
- :hover {
6487
- ${BarChartContainer} {
6488
- overflow-x: auto;
6489
- }
6490
- }
6467
+ css `
6468
+ .barChartBarGlobal rect {
6469
+ height: ${barHeight}px;
6470
+ y: calc(100% - ${barHeight + marginBottom}px);
6471
+ }
6472
+ `}
6491
6473
  `;
6492
- const BarChartFilterHeader = styled(Flex) `
6493
- justify-content: space-between;
6494
- align-items: center;
6495
- height: ${({ height }) => `calc(${typeof height === "number" ? `${height}px` : height} - 0.5rem)`};
6496
- padding: 0.25rem 0;
6474
+ const AnyChartWrapper = styled.div `
6475
+ width: 100%;
6476
+ height: ${({ height }) => height}px;
6497
6477
  `;
6498
- const BarChartFilterArrows = styled(Flex) `
6499
- margin-left: -0.5rem;
6500
-
6501
- span[kind] {
6502
- display: flex;
6503
- align-items: center;
6504
-
6505
- :after {
6506
- font-size: 0.75rem;
6507
- }
6508
- }
6478
+ const BarChartWrapper = styled(AnyChartWrapper) `
6479
+ width: 100%;
6480
+ margin: 0 auto ${BAR_CHART_FOOTER_MARGIN}px;
6481
+
6482
+ :hover {
6483
+ ${BarChartContainer} {
6484
+ overflow-x: auto;
6485
+ }
6486
+ }
6509
6487
  `;
6510
- const BarChartFilterSelected = styled.div `
6511
- font-size: 0.75rem;
6512
- font-weight: bold;
6513
- color: ${({ theme: { palette } }) => palette.textPrimary};
6488
+ const BarChartFilterHeader = styled(Flex) `
6489
+ justify-content: space-between;
6490
+ align-items: center;
6491
+ height: ${({ height }) => `calc(${typeof height === "number" ? `${height}px` : height} - 0.5rem)`};
6492
+ padding: 0.25rem 0;
6514
6493
  `;
6515
- styled.div `
6516
- color: ${({ theme: { palette } }) => palette.textSecondary};
6494
+ const BarChartFilterArrows = styled(Flex) `
6495
+ margin-left: -0.5rem;
6496
+
6497
+ span[kind] {
6498
+ display: flex;
6499
+ align-items: center;
6500
+
6501
+ :after {
6502
+ font-size: 0.75rem;
6503
+ }
6504
+ }
6517
6505
  `;
6518
- const BarChart = styled(BarChart$1) `
6519
- .${barChartClassNames.barChartXAxis} {
6520
- .domain,
6521
- line {
6522
- display: none;
6523
- }
6524
-
6525
- .tick {
6526
- text {
6527
- text-anchor: start;
6528
- font-size: 12px;
6529
- color: rgba(48, 69, 79, 0.46);
6530
- }
6531
-
6532
- :last-of-type {
6533
- text {
6534
- text-anchor: end;
6535
- }
6536
- }
6537
- }
6538
- }
6539
-
6540
- .marker {
6541
- font-size: 12px;
6542
- }
6506
+ const BarChartFilterSelected = styled.div `
6507
+ font-size: 0.75rem;
6508
+ font-weight: bold;
6509
+ color: ${({ theme: { palette } }) => palette.textPrimary};
6543
6510
  `;
6544
- const TooltipContainer = styled.div `
6545
- position: relative;
6546
- font-size: 0.75rem;
6547
- color: #ffffff;
6548
- margin-bottom: 0.5rem;
6549
- padding: 0.375rem;
6550
- background-color: rgba(0, 0, 0, 1);
6551
- border-radius: 0.25rem;
6552
- box-shadow: 0 0.1875rem 0.5rem rgba(48, 69, 79, 0.06);
6553
-
6554
- :before {
6555
- content: "";
6556
- position: absolute;
6557
- bottom: 0;
6558
- left: 50%;
6559
- transform: translate(-50%, 100%);
6560
- width: 0;
6561
- height: 0;
6562
- border-style: solid;
6563
- border-width: 0.25rem 0.1875rem 0 0.1875rem;
6564
- border-color: rgba(48, 69, 79, 1) transparent transparent transparent;
6565
- }
6511
+ styled.div `
6512
+ color: ${({ theme: { palette } }) => palette.textSecondary};
6513
+ `;
6514
+ const BarChart = styled(BarChart$1) `
6515
+ .${barChartClassNames.barChartXAxis} {
6516
+ .domain,
6517
+ line {
6518
+ display: none;
6519
+ }
6520
+
6521
+ .tick {
6522
+ text {
6523
+ text-anchor: start;
6524
+ font-size: 12px;
6525
+ color: rgba(48, 69, 79, 0.46);
6526
+ }
6527
+
6528
+ :last-of-type {
6529
+ text {
6530
+ text-anchor: end;
6531
+ }
6532
+ }
6533
+ }
6534
+ }
6535
+
6536
+ .marker {
6537
+ font-size: 12px;
6538
+ }
6539
+ `;
6540
+ const TooltipContainer = styled.div `
6541
+ position: relative;
6542
+ font-size: 0.75rem;
6543
+ color: #ffffff;
6544
+ margin-bottom: 0.5rem;
6545
+ padding: 0.375rem;
6546
+ background-color: rgba(0, 0, 0, 1);
6547
+ border-radius: 0.25rem;
6548
+ box-shadow: 0 0.1875rem 0.5rem rgba(48, 69, 79, 0.06);
6549
+
6550
+ :before {
6551
+ content: "";
6552
+ position: absolute;
6553
+ bottom: 0;
6554
+ left: 50%;
6555
+ transform: translate(-50%, 100%);
6556
+ width: 0;
6557
+ height: 0;
6558
+ border-style: solid;
6559
+ border-width: 0.25rem 0.1875rem 0 0.1875rem;
6560
+ border-color: rgba(48, 69, 79, 1) transparent transparent transparent;
6561
+ }
6566
6562
  `;
6567
6563
 
6568
6564
  const FiltersContainer = memo(({ elementConfig, config, type, renderElement }) => {
@@ -6639,64 +6635,64 @@ const PagesContainer = memo(({ type = WidgetType.Dashboard, noBorders }) => {
6639
6635
  return (jsx(Container, { id: getRootElementId(type), style: { width }, isMain: true, isColumn: isColumn, noBorders: noBorders, children: jsx(ContainerChildren, { type: type, items: filteredChildren, isMain: true, renderElement: renderElement }) }));
6640
6636
  });
6641
6637
 
6642
- const ImageContainerBg$1 = styled.div `
6643
- position: absolute;
6644
- top: 0;
6645
- bottom: 0;
6646
- left: 0;
6647
- right: 0;
6648
-
6649
- img {
6650
- width: 100%;
6651
- height: 100%;
6652
- object-position: center;
6653
- object-fit: cover;
6654
- }
6638
+ const ImageContainerBg$1 = styled.div `
6639
+ position: absolute;
6640
+ top: 0;
6641
+ bottom: 0;
6642
+ left: 0;
6643
+ right: 0;
6644
+
6645
+ img {
6646
+ width: 100%;
6647
+ height: 100%;
6648
+ object-position: center;
6649
+ object-fit: cover;
6650
+ }
6655
6651
  `;
6656
- const ImageContainerTitle = styled.div `
6657
- width: 100%;
6658
- overflow-wrap: break-word;
6659
- font-size: 1rem;
6660
- font-weight: 500;
6661
- `;
6662
- const ImageContainerText = styled.div `
6663
- width: 100%;
6664
- overflow-wrap: break-word;
6665
- margin-top: 0.5rem;
6666
- font-size: 0.75rem;
6667
- `;
6668
- const ImageContainerButton$1 = styled(FlatButton) `
6669
- min-height: 1.5rem;
6670
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.large};
6671
- background-color: ${({ theme: { palette } }) => palette.primary};
6672
- text-transform: none;
6673
-
6674
- :hover {
6675
- background-color: ${({ theme: { palette } }) => palette.primaryDeep};
6676
- }
6652
+ const ImageContainerTitle = styled.div `
6653
+ width: 100%;
6654
+ overflow-wrap: break-word;
6655
+ font-size: 1rem;
6656
+ font-weight: 500;
6657
+ `;
6658
+ const ImageContainerText = styled.div `
6659
+ width: 100%;
6660
+ overflow-wrap: break-word;
6661
+ margin-top: 0.5rem;
6662
+ font-size: 0.75rem;
6663
+ `;
6664
+ const ImageContainerButton$1 = styled(FlatButton) `
6665
+ min-height: 1.5rem;
6666
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.large};
6667
+ background-color: ${({ theme: { palette } }) => palette.primary};
6668
+ text-transform: none;
6669
+
6670
+ :hover {
6671
+ background-color: ${({ theme: { palette } }) => palette.primaryDeep};
6672
+ }
6677
6673
  `;
6678
- const ImageContainerWrapper = styled(Flex) `
6679
- flex-direction: column;
6680
- justify-content: flex-end;
6681
- position: relative;
6682
- padding: 1rem;
6683
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
6684
- overflow: hidden;
6685
-
6686
- ${ImageContainerTitle}, ${ImageContainerText}, ${ImageContainerButton$1} {
6687
- z-index: 1;
6688
- color: ${({ theme: { palette } }) => palette.textContrast};
6689
- }
6690
-
6691
- :after {
6692
- content: "";
6693
- position: absolute;
6694
- top: 0;
6695
- bottom: 0;
6696
- left: 0;
6697
- right: 0;
6698
- background-color: rgba(0, 0, 0, 0.4);
6699
- }
6674
+ const ImageContainerWrapper = styled(Flex) `
6675
+ flex-direction: column;
6676
+ justify-content: flex-end;
6677
+ position: relative;
6678
+ padding: 1rem;
6679
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
6680
+ overflow: hidden;
6681
+
6682
+ ${ImageContainerTitle}, ${ImageContainerText}, ${ImageContainerButton$1} {
6683
+ z-index: 1;
6684
+ color: ${({ theme: { palette } }) => palette.textContrast};
6685
+ }
6686
+
6687
+ :after {
6688
+ content: "";
6689
+ position: absolute;
6690
+ top: 0;
6691
+ bottom: 0;
6692
+ left: 0;
6693
+ right: 0;
6694
+ background-color: rgba(0, 0, 0, 0.4);
6695
+ }
6700
6696
  `;
6701
6697
 
6702
6698
  const ImageContainer = memo(({ elementConfig, renderElement }) => {
@@ -6704,52 +6700,52 @@ const ImageContainer = memo(({ elementConfig, renderElement }) => {
6704
6700
  return (jsxs(ImageContainerWrapper, { id: id, style: style, children: [jsx(ImageContainerTitle, { children: renderElement({ id: "alias" }) }), jsx(ImageContainerText, { children: renderElement({ id: "text" }) }), renderElement({ id: "button" }), jsx(ImageContainerBg$1, { children: renderElement({ id: "image" }) })] }));
6705
6701
  });
6706
6702
 
6707
- const IconContainerWrapper = styled(Flex) `
6708
- flex-direction: column;
6709
- justify-content: center;
6710
- position: relative;
6711
- padding: 0.5rem 1rem 1rem;
6712
- background-color: ${({ theme: { palette } }) => palette.element};
6713
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
6714
- overflow: hidden;
6715
- `;
6716
- const IconContainerHeaderWrapper = styled(Flex) `
6717
- justify-content: space-between;
6718
- align-items: center;
6719
- flex-wrap: nowrap;
6720
- width: 100%;
6721
- margin-bottom: 0.25rem;
6722
- `;
6723
- const IconContainerHeader = styled(Flex) `
6724
- align-items: center;
6725
- flex-wrap: nowrap;
6726
- width: 100%;
6727
- margin-right: 0.5rem;
6728
- font-size: 0.875rem;
6729
-
6730
- ${Icon} {
6731
- margin-right: 0.5rem;
6732
-
6733
- :after {
6734
- font-size: 1.15rem;
6735
- color: ${({ theme: { palette } }) => palette.textSecondary};
6736
- }
6737
- }
6703
+ const IconContainerWrapper = styled(Flex) `
6704
+ flex-direction: column;
6705
+ justify-content: center;
6706
+ position: relative;
6707
+ padding: 0.5rem 1rem 1rem;
6708
+ background-color: ${({ theme: { palette } }) => palette.element};
6709
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
6710
+ overflow: hidden;
6711
+ `;
6712
+ const IconContainerHeaderWrapper = styled(Flex) `
6713
+ justify-content: space-between;
6714
+ align-items: center;
6715
+ flex-wrap: nowrap;
6716
+ width: 100%;
6717
+ margin-bottom: 0.25rem;
6718
+ `;
6719
+ const IconContainerHeader = styled(Flex) `
6720
+ align-items: center;
6721
+ flex-wrap: nowrap;
6722
+ width: 100%;
6723
+ margin-right: 0.5rem;
6724
+ font-size: 0.875rem;
6725
+
6726
+ ${Icon} {
6727
+ margin-right: 0.5rem;
6728
+
6729
+ :after {
6730
+ font-size: 1.15rem;
6731
+ color: ${({ theme: { palette } }) => palette.textSecondary};
6732
+ }
6733
+ }
6738
6734
  `;
6739
- const IconContainerTitle = styled(Flex) `
6740
- > * {
6741
- width: 13rem;
6742
- white-space: nowrap;
6743
- overflow: hidden;
6744
- font-weight: bold;
6745
- text-overflow: ellipsis;
6746
- }
6735
+ const IconContainerTitle = styled(Flex) `
6736
+ > * {
6737
+ width: 13rem;
6738
+ white-space: nowrap;
6739
+ overflow: hidden;
6740
+ font-weight: bold;
6741
+ text-overflow: ellipsis;
6742
+ }
6747
6743
  `;
6748
- const IconContainerText = styled.div `
6749
- width: 100%;
6750
- overflow-wrap: break-word;
6751
- font-size: 0.75rem;
6752
- color: ${({ theme: { palette } }) => palette.textSecondary};
6744
+ const IconContainerText = styled.div `
6745
+ width: 100%;
6746
+ overflow-wrap: break-word;
6747
+ font-size: 0.75rem;
6748
+ color: ${({ theme: { palette } }) => palette.textSecondary};
6753
6749
  `;
6754
6750
 
6755
6751
  const IconContainer = memo(({ elementConfig, renderElement }) => {
@@ -6772,107 +6768,107 @@ const DataSourceContainer = memo(({ config, elementConfig, type, innerComponent,
6772
6768
  return (jsxs(Fragment$1, { children: [jsx(ExpandableTitle, { elementConfig: elementConfig, type: type, renderElement: renderElement }), !isVisible ? null : dataSource ? (jsx(Container, { id: id, isColumn: column, style: { height: isLoading ? "3rem" : "auto", ...style }, children: dataSource.features?.map((feature, index) => (jsx(DataSourceInnerContainer, { index: index, type: type, config: config, feature: feature, elementConfig: elementConfig, innerComponent: innerComponent }, index))) })) : (jsx(ContainerLoading, {}))] }));
6773
6769
  });
6774
6770
 
6775
- const SvgContainerColorMixin = css `
6776
- path,
6777
- line,
6778
- circle {
6779
- fill: ${({ $fontColor }) => $fontColor};
6780
- }
6771
+ const SvgContainerColorMixin = css `
6772
+ path,
6773
+ line,
6774
+ circle {
6775
+ fill: ${({ $fontColor }) => $fontColor};
6776
+ }
6781
6777
  `;
6782
- const SvgContainer = styled.div `
6783
- &&& {
6784
- min-width: ${({ $width }) => ($width ? `${$width}px` : "1rem")};
6785
- max-width: ${({ $width }) => ($width ? `${$width}px` : "1rem")};
6786
-
6787
- ${({ $fontColor }) => !!$fontColor && SvgContainerColorMixin};
6788
-
6789
- > * {
6790
- min-width: inherit;
6791
- }
6792
- }
6778
+ const SvgContainer = styled.div `
6779
+ &&& {
6780
+ min-width: ${({ $width }) => ($width ? `${$width}px` : "1rem")};
6781
+ max-width: ${({ $width }) => ($width ? `${$width}px` : "1rem")};
6782
+
6783
+ ${({ $fontColor }) => !!$fontColor && SvgContainerColorMixin};
6784
+
6785
+ > * {
6786
+ min-width: inherit;
6787
+ }
6788
+ }
6793
6789
  `;
6794
6790
 
6795
- const ContainerIconTitle = styled(Flex) `
6796
- align-items: center;
6797
- flex-wrap: nowrap;
6798
- flex-shrink: 1;
6799
- flex-grow: 0;
6800
- color: ${({ fontColor, theme: { palette } }) => fontColor || palette.textSecondary};
6801
-
6802
- > div {
6803
- flex-shrink: 1;
6804
- flex-grow: 0;
6805
- width: auto;
6806
- }
6807
-
6808
- ${SvgContainer} {
6809
- flex-shrink: 0;
6810
- flex-grow: 0;
6811
- margin-right: 0.5rem;
6812
- }
6813
-
6814
- svg,
6815
- img,
6816
- span[kind] {
6817
- margin-right: 0.5rem;
6818
- }
6819
-
6791
+ const ContainerIconTitle = styled(Flex) `
6792
+ align-items: center;
6793
+ flex-wrap: nowrap;
6794
+ flex-shrink: 1;
6795
+ flex-grow: 0;
6796
+ color: ${({ fontColor, theme: { palette } }) => fontColor || palette.textSecondary};
6797
+
6798
+ > div {
6799
+ flex-shrink: 1;
6800
+ flex-grow: 0;
6801
+ width: auto;
6802
+ }
6803
+
6804
+ ${SvgContainer} {
6805
+ flex-shrink: 0;
6806
+ flex-grow: 0;
6807
+ margin-right: 0.5rem;
6808
+ }
6809
+
6810
+ svg,
6811
+ img,
6812
+ span[kind] {
6813
+ margin-right: 0.5rem;
6814
+ }
6815
+
6820
6816
  ${({ fontColor }) => !!fontColor &&
6821
- css `
6822
- span[kind] {
6823
- color: ${fontColor};
6824
- }
6825
-
6826
- ${SvgContainer} {
6827
- path,
6828
- circle {
6829
- fill: ${fontColor};
6830
- }
6831
- }
6832
- `};
6833
-
6834
- ${LegendToggler} {
6835
- margin-left: 0.25rem;
6836
- }
6837
-
6838
- span[kind="download"] {
6839
- opacity: 0;
6840
- transition: opacity ${transition.hover};
6841
- }
6842
-
6843
- :hover {
6844
- span[kind="download"] {
6845
- opacity: 1;
6846
- }
6847
- }
6817
+ css `
6818
+ span[kind] {
6819
+ color: ${fontColor};
6820
+ }
6821
+
6822
+ ${SvgContainer} {
6823
+ path,
6824
+ circle {
6825
+ fill: ${fontColor};
6826
+ }
6827
+ }
6828
+ `};
6829
+
6830
+ ${LegendToggler} {
6831
+ margin-left: 0.25rem;
6832
+ }
6833
+
6834
+ span[kind="download"] {
6835
+ opacity: 0;
6836
+ transition: opacity ${transition.hover};
6837
+ }
6838
+
6839
+ :hover {
6840
+ span[kind="download"] {
6841
+ opacity: 1;
6842
+ }
6843
+ }
6848
6844
  `;
6849
- const ContainerTitle = styled(Flex) `
6850
- align-items: center;
6851
- justify-content: space-between;
6852
- width: 100%;
6853
-
6854
- > * {
6855
- font-size: 1.125rem;
6856
- font-weight: 500;
6857
- }
6858
-
6859
- ${LegendToggler} {
6860
- padding-right: 0;
6861
- }
6862
-
6845
+ const ContainerTitle = styled(Flex) `
6846
+ align-items: center;
6847
+ justify-content: space-between;
6848
+ width: 100%;
6849
+
6850
+ > * {
6851
+ font-size: 1.125rem;
6852
+ font-weight: 500;
6853
+ }
6854
+
6855
+ ${LegendToggler} {
6856
+ padding-right: 0;
6857
+ }
6858
+
6863
6859
  ${({ simple }) => simple &&
6864
- css `
6865
- justify-content: flex-start;
6866
-
6867
- ${ContainerIconTitle} {
6868
- font-size: 0.75rem;
6869
- }
6870
-
6871
- ${LegendToggler} {
6872
- margin-left: 0;
6873
- padding-left: 0.25rem;
6874
- }
6875
- `}
6860
+ css `
6861
+ justify-content: flex-start;
6862
+
6863
+ ${ContainerIconTitle} {
6864
+ font-size: 0.75rem;
6865
+ }
6866
+
6867
+ ${LegendToggler} {
6868
+ margin-left: 0;
6869
+ padding-left: 0.25rem;
6870
+ }
6871
+ `}
6876
6872
  `;
6877
6873
 
6878
6874
  const TitleContainer = memo(({ containerId, templateName, layerNames, fontColor, expandable, expanded, isVisible, elementConfig, renderElement, type, }) => {
@@ -6946,82 +6942,82 @@ const CameraContainer = memo(({ elementConfig, type, renderElement }) => {
6946
6942
  return (jsxs(Fragment$1, { children: [jsx(ExpandableTitle, { elementConfig: elementConfig, type: type, renderElement: renderElement }), isVisible && (jsxs(Container, { id: id, style: style, children: [jsx(ContainerAlias, { hasBottomMargin: true, children: renderElement({ id: "alias" }) }), jsx(ContainerValue, { children: renderElement({ id: "value", wrap: false }) })] }))] }));
6947
6943
  });
6948
6944
 
6949
- const TabAnchor = styled.div `
6950
- position: absolute;
6951
- top: -1.5rem;
6952
- right: 0;
6945
+ const TabAnchor = styled.div `
6946
+ position: absolute;
6947
+ top: -1.5rem;
6948
+ right: 0;
6953
6949
  `;
6954
- const TabValue = styled(Flex) `
6955
- flex-wrap: nowrap;
6950
+ const TabValue = styled(Flex) `
6951
+ flex-wrap: nowrap;
6956
6952
  `;
6957
- const noBgMixin = css `
6958
- background-color: transparent;
6959
- border-radius: 0;
6960
- border-bottom: 0.125rem solid
6961
- ${({ active, bgColor, theme: { palette } }) => (active ? bgColor || palette.primary : palette.element)};
6962
-
6963
- ${TabValue},
6964
- span[kind] {
6965
- color: ${({ active, bgColor, theme: { palette } }) => active ? bgColor || palette.primary : palette.textSecondary};
6966
- }
6967
-
6968
- &&& svg {
6969
- path,
6970
- line,
6971
- circle {
6972
- fill: ${({ active, bgColor, theme: { palette } }) => active ? bgColor || palette.primary : palette.textSecondary};
6973
- }
6974
- }
6975
-
6976
- :not(:last-child) {
6977
- margin-right: 0;
6978
- }
6953
+ const noBgMixin = css `
6954
+ background-color: transparent;
6955
+ border-radius: 0;
6956
+ border-bottom: 0.125rem solid
6957
+ ${({ active, bgColor, theme: { palette } }) => (active ? bgColor || palette.primary : palette.element)};
6958
+
6959
+ ${TabValue},
6960
+ span[kind] {
6961
+ color: ${({ active, bgColor, theme: { palette } }) => active ? bgColor || palette.primary : palette.textSecondary};
6962
+ }
6963
+
6964
+ &&& svg {
6965
+ path,
6966
+ line,
6967
+ circle {
6968
+ fill: ${({ active, bgColor, theme: { palette } }) => active ? bgColor || palette.primary : palette.textSecondary};
6969
+ }
6970
+ }
6971
+
6972
+ :not(:last-child) {
6973
+ margin-right: 0;
6974
+ }
6979
6975
  `;
6980
- const TabContainer = styled.a `
6981
- display: flex;
6982
- flex-direction: ${({ column }) => (column ? "column" : "row")};
6983
- align-items: center;
6984
- justify-content: center;
6985
- flex-wrap: nowrap;
6986
- padding: ${({ onlyIcon }) => (onlyIcon ? 1 : 0.5)}rem 1rem;
6987
- background-color: ${({ active, bgColor, theme: { palette } }) => active ? bgColor || palette.primary : palette.element};
6988
- border-radius: ${({ column, radius, theme: { borderRadius } }) => radius ? `${radius}px` : column ? borderRadius.medium : borderRadius.xLarge};
6989
- text-decoration: none;
6990
-
6991
- :not(:last-child) {
6992
- margin-right: 0.5rem;
6993
- }
6994
-
6995
- ${TabValue} {
6996
- margin-top: ${({ column }) => (column ? 0.5 : 0)}rem;
6997
- margin-left: ${({ column, hasIcon }) => (column || !hasIcon ? 0 : 0.5)}rem;
6998
- font-size: ${({ column }) => (column ? 0.75 : 0.875)}rem;
6999
- white-space: nowrap;
7000
- }
7001
-
7002
- ${TabValue},
7003
- span[kind] {
7004
- color: ${({ active, theme: { palette } }) => (active ? palette.textContrast : palette.textSecondary)};
7005
- }
7006
-
7007
- ${SvgContainer$1} {
7008
- height: 1rem;
7009
- }
7010
-
7011
- svg,
7012
- img {
7013
- max-width: 1rem;
7014
- max-height: 1rem;
7015
- }
7016
-
7017
- ${({ noBg }) => noBg && noBgMixin};
6976
+ const TabContainer = styled.a `
6977
+ display: flex;
6978
+ flex-direction: ${({ column }) => (column ? "column" : "row")};
6979
+ align-items: center;
6980
+ justify-content: center;
6981
+ flex-wrap: nowrap;
6982
+ padding: ${({ onlyIcon }) => (onlyIcon ? 1 : 0.5)}rem 1rem;
6983
+ background-color: ${({ active, bgColor, theme: { palette } }) => active ? bgColor || palette.primary : palette.element};
6984
+ border-radius: ${({ column, radius, theme: { borderRadius } }) => radius ? `${radius}px` : column ? borderRadius.medium : borderRadius.xLarge};
6985
+ text-decoration: none;
6986
+
6987
+ :not(:last-child) {
6988
+ margin-right: 0.5rem;
6989
+ }
6990
+
6991
+ ${TabValue} {
6992
+ margin-top: ${({ column }) => (column ? 0.5 : 0)}rem;
6993
+ margin-left: ${({ column, hasIcon }) => (column || !hasIcon ? 0 : 0.5)}rem;
6994
+ font-size: ${({ column }) => (column ? 0.75 : 0.875)}rem;
6995
+ white-space: nowrap;
6996
+ }
6997
+
6998
+ ${TabValue},
6999
+ span[kind] {
7000
+ color: ${({ active, theme: { palette } }) => (active ? palette.textContrast : palette.textSecondary)};
7001
+ }
7002
+
7003
+ ${SvgContainer$1} {
7004
+ height: 1rem;
7005
+ }
7006
+
7007
+ svg,
7008
+ img {
7009
+ max-width: 1rem;
7010
+ max-height: 1rem;
7011
+ }
7012
+
7013
+ ${({ noBg }) => noBg && noBgMixin};
7018
7014
  `;
7019
- const SwiperContainer = styled.div `
7020
- width: 100%;
7021
-
7022
- .swiper-wrapper {
7023
- display: flex;
7024
- }
7015
+ const SwiperContainer = styled.div `
7016
+ width: 100%;
7017
+
7018
+ .swiper-wrapper {
7019
+ display: flex;
7020
+ }
7025
7021
  `;
7026
7022
 
7027
7023
  const TabsContainer = memo(({ elementConfig, type }) => {
@@ -7049,96 +7045,96 @@ const TabsContainer = memo(({ elementConfig, type }) => {
7049
7045
  });
7050
7046
 
7051
7047
  const ContainerIconValue = styled(Flex) ``;
7052
- const RoundedBackgroundContainerWrapper = styled(Flex) `
7053
- position: relative;
7054
- flex-direction: ${({ $bigIcon }) => ($bigIcon ? "row" : "column")};
7055
- width: 9rem;
7056
- padding: 0.75rem 0.75rem 0.5rem;
7057
- background-color: ${({ theme: { palette } }) => palette.element};
7058
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.large};
7059
- flex-wrap: nowrap;
7060
-
7061
- && {
7062
- margin-bottom: 0.5rem;
7063
- }
7064
-
7048
+ const RoundedBackgroundContainerWrapper = styled(Flex) `
7049
+ position: relative;
7050
+ flex-direction: ${({ $bigIcon }) => ($bigIcon ? "row" : "column")};
7051
+ width: 9rem;
7052
+ padding: 0.75rem 0.75rem 0.5rem;
7053
+ background-color: ${({ theme: { palette } }) => palette.element};
7054
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.large};
7055
+ flex-wrap: nowrap;
7056
+
7057
+ && {
7058
+ margin-bottom: 0.5rem;
7059
+ }
7060
+
7065
7061
  ${({ $center }) => $center &&
7066
- css `
7067
- align-items: center;
7068
-
7069
- > * {
7070
- display: flex;
7071
- justify-content: center;
7072
- text-align: center;
7073
- width: 100%;
7074
- }
7075
- `};
7076
-
7062
+ css `
7063
+ align-items: center;
7064
+
7065
+ > * {
7066
+ display: flex;
7067
+ justify-content: center;
7068
+ text-align: center;
7069
+ width: 100%;
7070
+ }
7071
+ `};
7072
+
7077
7073
  ${({ $color }) => $color &&
7078
- css `
7079
- background-color: ${transparentizeColor($color, 6)};
7080
-
7081
- * {
7082
- color: ${$color};
7083
- }
7084
- `};
7085
-
7086
- ${ContainerIcon}, ${SvgContainer$1} {
7087
- margin-bottom: 0.25rem;
7088
- }
7089
-
7074
+ css `
7075
+ background-color: ${transparentizeColor($color, 6)};
7076
+
7077
+ * {
7078
+ color: ${$color};
7079
+ }
7080
+ `};
7081
+
7082
+ ${ContainerIcon}, ${SvgContainer$1} {
7083
+ margin-bottom: 0.25rem;
7084
+ }
7085
+
7090
7086
  ${({ $bigIcon }) => $bigIcon &&
7091
- css `
7092
- ${ContainerIcon}, ${SvgContainer$1} {
7093
- position: absolute;
7094
- top: 0.75rem;
7095
- right: 0.75rem;
7096
- width: 3rem;
7097
- opacity: 0.12;
7098
-
7099
- :after {
7100
- font-size: 3rem;
7101
- }
7102
- }
7103
- `};
7104
-
7105
- ${ContainerIconValue} {
7106
- align-items: center;
7107
- flex-direction: column;
7108
-
7087
+ css `
7088
+ ${ContainerIcon}, ${SvgContainer$1} {
7089
+ position: absolute;
7090
+ top: 0.75rem;
7091
+ right: 0.75rem;
7092
+ width: 3rem;
7093
+ opacity: 0.12;
7094
+
7095
+ :after {
7096
+ font-size: 3rem;
7097
+ }
7098
+ }
7099
+ `};
7100
+
7101
+ ${ContainerIconValue} {
7102
+ align-items: center;
7103
+ flex-direction: column;
7104
+
7109
7105
  ${({ $big }) => $big &&
7110
- css `
7111
- flex-direction: row;
7112
- margin-bottom: 0.5rem;
7113
-
7114
- > * {
7115
- text-align: left;
7116
- }
7117
-
7118
- span[kind] {
7119
- margin-right: 0.5rem;
7120
- }
7121
-
7122
- ${ContainerValue} {
7123
- width: auto;
7124
- }
7125
- `};
7126
- }
7127
-
7128
- ${ContainerValue} {
7129
- flex-direction: ${({ $inlineUnits }) => ($inlineUnits ? "row" : "column")};
7130
- justify-content: ${({ $big }) => ($big ? "flex-start" : "center")};
7131
- align-items: ${({ $inlineUnits }) => ($inlineUnits ? "center" : "flex-start")};
7132
- line-height: 1;
7133
- }
7134
-
7135
- ${ContainerUnits} {
7136
- margin-left: ${({ $inlineUnits }) => ($inlineUnits ? "0.25rem" : 0)};
7137
- }
7138
-
7139
- ${ContainerAlias} {
7140
- margin-top: 0.25rem;
7141
- }
7106
+ css `
7107
+ flex-direction: row;
7108
+ margin-bottom: 0.5rem;
7109
+
7110
+ > * {
7111
+ text-align: left;
7112
+ }
7113
+
7114
+ span[kind] {
7115
+ margin-right: 0.5rem;
7116
+ }
7117
+
7118
+ ${ContainerValue} {
7119
+ width: auto;
7120
+ }
7121
+ `};
7122
+ }
7123
+
7124
+ ${ContainerValue} {
7125
+ flex-direction: ${({ $inlineUnits }) => ($inlineUnits ? "row" : "column")};
7126
+ justify-content: ${({ $big }) => ($big ? "flex-start" : "center")};
7127
+ align-items: ${({ $inlineUnits }) => ($inlineUnits ? "center" : "flex-start")};
7128
+ line-height: 1;
7129
+ }
7130
+
7131
+ ${ContainerUnits} {
7132
+ margin-left: ${({ $inlineUnits }) => ($inlineUnits ? "0.25rem" : 0)};
7133
+ }
7134
+
7135
+ ${ContainerAlias} {
7136
+ margin-top: 0.25rem;
7137
+ }
7142
7138
  `;
7143
7139
 
7144
7140
  const ALIAS_DEFAULT_MAX_LENGTH = 28;
@@ -7185,20 +7181,20 @@ const AddFeatureContainer = memo(({ elementConfig }) => {
7185
7181
  .map(({ options }, index) => (jsx(AddFeatureButton, { icon: options?.icon, title: options?.title, layerName: options?.layerName, geometryType: options?.geometryType }, index))) }));
7186
7182
  });
7187
7183
 
7188
- const LayersContainerWrapper = styled(Container) `
7189
- ${DraggableTreeContainer} {
7190
- width: calc(100% + 3rem);
7191
- margin: -0.75rem -1.5rem 0;
7192
- }
7193
-
7194
- ${LayerListContainer} {
7195
- height: auto;
7196
- }
7197
-
7198
- ${LayerGroupList} {
7199
- margin: ${({ isPresentationMode }) => (isPresentationMode ? 0 : "0 -1.25rem 0 -1rem")};
7200
- padding: 0;
7201
- }
7184
+ const LayersContainerWrapper = styled(Container) `
7185
+ ${DraggableTreeContainer} {
7186
+ width: calc(100% + 3rem);
7187
+ margin: -0.75rem -1.5rem 0;
7188
+ }
7189
+
7190
+ ${LayerListContainer} {
7191
+ height: auto;
7192
+ }
7193
+
7194
+ ${LayerGroupList} {
7195
+ margin: ${({ isPresentationMode }) => (isPresentationMode ? 0 : "0 -1.25rem 0 -1rem")};
7196
+ padding: 0;
7197
+ }
7202
7198
  `;
7203
7199
 
7204
7200
  const LayersContainer = memo(({ type, elementConfig, renderElement }) => {
@@ -7233,9 +7229,9 @@ const UploadContainer = memo(({ type, elementConfig, renderElement }) => {
7233
7229
  return (jsxs(Fragment$1, { children: [jsx(ExpandableTitle, { elementConfig: elementConfig, type: type, renderElement: renderElement }), isVisible && renderElement({ id: "uploader", wrap: false })] }));
7234
7230
  });
7235
7231
 
7236
- const StatusBadge = styled(Chip) `
7237
- background-color: ${({ bgColor }) => bgColor};
7238
- color: ${({ theme }) => theme.palette.iconContrast};
7232
+ const StatusBadge = styled(Chip) `
7233
+ background-color: ${({ bgColor }) => bgColor};
7234
+ color: ${({ theme }) => theme.palette.iconContrast};
7239
7235
  `;
7240
7236
 
7241
7237
  const STATUS_TRANSLATION_KEYS = {
@@ -7293,22 +7289,22 @@ var EditGeometryType;
7293
7289
  EditGeometryType["Raster"] = "raster";
7294
7290
  })(EditGeometryType || (EditGeometryType = {}));
7295
7291
 
7296
- const StyledButton = styled(FlatButton) `
7297
- display: flex;
7298
- align-items: center;
7299
-
7300
- ${({ status = RemoteTaskStatus.Unknown, statusColors, themeName }) => !!statusColors?.[status] && css `
7301
- transition: background-color ${transition.toggle};
7302
- background-color: ${statusColors[status]};
7303
-
7304
- :hover {
7305
- background-color: ${adjustColor(statusColors[status], themeName === ThemeName.Dark ? -5 : 5)};
7306
- }
7307
-
7308
- :active {
7309
- background-color: ${adjustColor(statusColors[status], themeName === ThemeName.Dark ? -10 : 10)};
7310
- }
7311
- `}
7292
+ const StyledButton = styled(FlatButton) `
7293
+ display: flex;
7294
+ align-items: center;
7295
+
7296
+ ${({ status = RemoteTaskStatus.Unknown, statusColors, themeName }) => !!statusColors?.[status] && css `
7297
+ transition: background-color ${transition.toggle};
7298
+ background-color: ${statusColors[status]};
7299
+
7300
+ :hover {
7301
+ background-color: ${adjustColor(statusColors[status], themeName === ThemeName.Dark ? -5 : 5)};
7302
+ }
7303
+
7304
+ :active {
7305
+ background-color: ${adjustColor(statusColors[status], themeName === ThemeName.Dark ? -10 : 10)};
7306
+ }
7307
+ `}
7312
7308
  `;
7313
7309
 
7314
7310
  const StatusWaitingButton = ({ title, icon = "play", status, statusColors, isWaiting, isDisabled, onClick }) => {
@@ -7357,9 +7353,9 @@ const EditContainer = ({ type, elementConfig, renderElement }) => {
7357
7353
  return (jsxs(Fragment$1, { children: [jsx(ExpandableTitle, { elementConfig: elementConfig, type: type, renderElement: renderElement }), jsxs(Container, { id: id, isColumn: true, style: style, children: [jsx(ContainerAlias, { hasBottomMargin: true, children: renderElement({ id: "alias" }) }), jsx(ContainerValue, { children: renderElement({ id: "value" }) })] })] }));
7358
7354
  };
7359
7355
 
7360
- const ContainerDivider = styled(Divider) `
7361
- width: 100%;
7362
- border-color: ${({ theme: { palette }, $bgColor }) => $bgColor || palette.elementDeep};
7356
+ const ContainerDivider = styled(Divider) `
7357
+ width: 100%;
7358
+ border-color: ${({ theme: { palette }, $bgColor }) => $bgColor || palette.elementDeep};
7363
7359
  `;
7364
7360
 
7365
7361
  const DividerContainer = memo(({ elementConfig, config }) => {
@@ -7399,148 +7395,148 @@ const getContainerComponent = (innerTemplateName) => innerTemplateName ? contain
7399
7395
  var img$3 = "";
7400
7396
 
7401
7397
  const getMaskColor = (isDark) => (isDark ? "0, 0, 0" : "255, 255, 255");
7402
- const DefaultHeaderContainer = styled(Flex) `
7403
- flex-direction: column;
7404
- position: relative;
7405
- flex-shrink: 0;
7406
- min-height: 8.175rem;
7407
- margin-bottom: -1.5rem;
7408
- padding: 1.5rem 1.5rem 0;
7409
- border-top-left-radius: 0.5rem;
7410
- border-top-right-radius: 0.5rem;
7411
- overflow: hidden;
7412
-
7413
- > * {
7414
- z-index: 1;
7415
- }
7416
-
7417
- &::before {
7418
- content: "";
7419
- position: absolute;
7420
- top: 0;
7421
- left: 0;
7422
- width: 100%;
7423
- height: 100%;
7424
-
7398
+ const DefaultHeaderContainer = styled(Flex) `
7399
+ flex-direction: column;
7400
+ position: relative;
7401
+ flex-shrink: 0;
7402
+ min-height: 8.175rem;
7403
+ margin-bottom: -1.5rem;
7404
+ padding: 1.5rem 1.5rem 0;
7405
+ border-top-left-radius: 0.5rem;
7406
+ border-top-right-radius: 0.5rem;
7407
+ overflow: hidden;
7408
+
7409
+ > * {
7410
+ z-index: 1;
7411
+ }
7412
+
7413
+ &::before {
7414
+ content: "";
7415
+ position: absolute;
7416
+ top: 0;
7417
+ left: 0;
7418
+ width: 100%;
7419
+ height: 100%;
7420
+
7425
7421
  ${({ image, isDark }) => image
7426
- ? css `
7427
- background: url(${image}) 0 0 no-repeat;
7428
- background-size: cover;
7422
+ ? css `
7423
+ background: url(${image}) 0 0 no-repeat;
7424
+ background-size: cover;
7429
7425
  `
7430
- : css `
7431
- background: url(${img$3}) 50% 0 no-repeat;
7432
- opacity: ${isDark ? 1 : 0.5};
7433
- `}
7434
- }
7435
-
7426
+ : css `
7427
+ background: url(${img$3}) 50% 0 no-repeat;
7428
+ opacity: ${isDark ? 1 : 0.5};
7429
+ `}
7430
+ }
7431
+
7436
7432
  ${({ image, isDark }) => image &&
7437
- css `
7438
- &::before {
7439
- -webkit-mask-image: linear-gradient(
7440
- to bottom,
7441
- rgba(${getMaskColor(isDark)}, 1),
7442
- rgba(${getMaskColor(isDark)}, 0)
7443
- );
7444
- mask-image: linear-gradient(to bottom, rgba(${getMaskColor(isDark)}, 1), rgba(${getMaskColor(isDark)}, 0));
7445
- }
7446
- `}
7447
- ${LinearProgress} {
7448
- position: absolute;
7449
- top: 0;
7450
- left: 0;
7451
- }
7433
+ css `
7434
+ &::before {
7435
+ -webkit-mask-image: linear-gradient(
7436
+ to bottom,
7437
+ rgba(${getMaskColor(isDark)}, 1),
7438
+ rgba(${getMaskColor(isDark)}, 0)
7439
+ );
7440
+ mask-image: linear-gradient(to bottom, rgba(${getMaskColor(isDark)}, 1), rgba(${getMaskColor(isDark)}, 0));
7441
+ }
7442
+ `}
7443
+ ${LinearProgress} {
7444
+ position: absolute;
7445
+ top: 0;
7446
+ left: 0;
7447
+ }
7452
7448
  `;
7453
- const TopContainer = styled(Flex) `
7454
- z-index: 1;
7455
- position: relative;
7456
- justify-content: space-between;
7457
- flex-wrap: nowrap;
7458
- width: 100%;
7459
- align-items: flex-start;
7460
- `;
7461
- const TopContainerButtons = styled(Flex) `
7462
- align-items: center;
7463
- width: auto;
7464
- margin-right: -0.5rem;
7465
-
7466
- button {
7467
- width: auto;
7468
- height: 1rem;
7469
- padding: 0 0.5rem;
7470
- }
7449
+ const TopContainer = styled(Flex) `
7450
+ z-index: 1;
7451
+ position: relative;
7452
+ justify-content: space-between;
7453
+ flex-wrap: nowrap;
7454
+ width: 100%;
7455
+ align-items: flex-start;
7456
+ `;
7457
+ const TopContainerButtons = styled(Flex) `
7458
+ align-items: center;
7459
+ width: auto;
7460
+ margin-right: -0.5rem;
7461
+
7462
+ button {
7463
+ width: auto;
7464
+ height: 1rem;
7465
+ padding: 0 0.5rem;
7466
+ }
7471
7467
  `;
7472
- const LogoContainer = styled(Flex) `
7473
- max-width: calc(100% - 1.4rem);
7474
- flex-grow: 1;
7475
- font-size: 0;
7476
-
7477
- & > span::after {
7478
- font-size: 2rem;
7479
- }
7480
-
7481
- img {
7482
- max-height: 1.875rem;
7483
- }
7468
+ const LogoContainer = styled(Flex) `
7469
+ max-width: calc(100% - 1.4rem);
7470
+ flex-grow: 1;
7471
+ font-size: 0;
7472
+
7473
+ & > span::after {
7474
+ font-size: 2rem;
7475
+ }
7476
+
7477
+ img {
7478
+ max-height: 1.875rem;
7479
+ }
7484
7480
  `;
7485
- const PageTitle = styled(H2) `
7486
- cursor: pointer;
7487
- text-align: left;
7488
- flex: 1 1 auto;
7489
- min-width: 0;
7490
- margin: 0;
7491
- font-size: 1.25rem;
7492
- font-weight: 600;
7493
- pointer-events: initial;
7494
- font-family: "Nunito Sans", serif;
7495
-
7496
- > * {
7497
- white-space: nowrap;
7498
- overflow: hidden;
7499
- text-overflow: ellipsis;
7500
- }
7481
+ const PageTitle = styled(H2) `
7482
+ cursor: pointer;
7483
+ text-align: left;
7484
+ flex: 1 1 auto;
7485
+ min-width: 0;
7486
+ margin: 0;
7487
+ font-size: 1.25rem;
7488
+ font-weight: 600;
7489
+ pointer-events: initial;
7490
+ font-family: "Nunito Sans", serif;
7491
+
7492
+ > * {
7493
+ white-space: nowrap;
7494
+ overflow: hidden;
7495
+ text-overflow: ellipsis;
7496
+ }
7501
7497
  `;
7502
- const PageTitleContainer = styled(Flex) `
7503
- flex-grow: 1;
7504
- align-items: center;
7505
-
7506
- ${PageTitle} {
7507
- max-width: 15.75rem;
7508
- }
7509
-
7510
- &&& button {
7511
- width: 0;
7512
- overflow: hidden;
7513
-
7514
- span[kind] {
7515
- display: flex;
7516
- align-items: center;
7517
- justify-content: center;
7518
- width: 0.75rem;
7519
-
7520
- :after {
7521
- font-size: 0.75rem;
7522
- color: ${({ theme: { palette } }) => palette.textDisabled};
7523
- transition: color ${transition.hover};
7524
- }
7525
- }
7526
-
7527
- &:hover,
7528
- &:active {
7529
- span[kind]:after {
7530
- color: ${({ theme: { palette } }) => palette.textPrimary};
7531
- }
7532
- }
7533
- }
7534
-
7535
- :hover {
7536
- ${PageTitle} {
7537
- max-width: 14.25rem;
7538
- }
7539
-
7540
- &&& button {
7541
- width: 1.5rem;
7542
- }
7543
- }
7498
+ const PageTitleContainer = styled(Flex) `
7499
+ flex-grow: 1;
7500
+ align-items: center;
7501
+
7502
+ ${PageTitle} {
7503
+ max-width: 15.75rem;
7504
+ }
7505
+
7506
+ &&& button {
7507
+ width: 0;
7508
+ overflow: hidden;
7509
+
7510
+ span[kind] {
7511
+ display: flex;
7512
+ align-items: center;
7513
+ justify-content: center;
7514
+ width: 0.75rem;
7515
+
7516
+ :after {
7517
+ font-size: 0.75rem;
7518
+ color: ${({ theme: { palette } }) => palette.textDisabled};
7519
+ transition: color ${transition.hover};
7520
+ }
7521
+ }
7522
+
7523
+ &:hover,
7524
+ &:active {
7525
+ span[kind]:after {
7526
+ color: ${({ theme: { palette } }) => palette.textPrimary};
7527
+ }
7528
+ }
7529
+ }
7530
+
7531
+ :hover {
7532
+ ${PageTitle} {
7533
+ max-width: 14.25rem;
7534
+ }
7535
+
7536
+ &&& button {
7537
+ width: 1.5rem;
7538
+ }
7539
+ }
7544
7540
  `;
7545
7541
 
7546
7542
  const DashboardDefaultHeader = memo(() => {
@@ -7550,87 +7546,87 @@ const DashboardDefaultHeader = memo(() => {
7550
7546
  return (jsxs(DefaultHeaderContainer, { image: getResourceUrl(image), isDark: themeName === ThemeName.Dark, children: [!pageId && jsx(LinearProgress, {}), jsxs(Flex, { column: true, gap: "1rem", children: [jsx(FlexSpan, { children: jsxs(TopContainer, { children: [jsx(LogoContainer, { children: icon }), jsx(TopContainerButtons, { children: jsx(ProjectPanelMenu, {}) })] }) }), jsx(FlexSpan, { children: jsx(Flex, { column: true, gap: "0.25rem", children: jsx(FlexSpan, { children: jsxs(Flex, { alignItems: "center", children: [jsxs(PageTitleContainer, { children: [jsx(Tooltip$1, { arrow: true, content: tooltip, children: ref => (jsx(PageTitle, { ref: ref, onClick: toggleLayersVisibility, children: title })) }), jsx(ProjectPagesMenu, {})] }), jsx(FlexSpan, { children: jsx(Pagination, {}) })] }) }) }) })] })] }));
7551
7547
  });
7552
7548
 
7553
- const HeaderFrontView = styled(Flex) `
7554
- z-index: 10;
7555
- position: relative;
7556
- justify-content: space-between;
7557
- align-items: ${({ isDefault }) => (isDefault ? "center" : "flex-start")};
7558
- width: 100%;
7559
- font: ${({ theme: { fonts } }) => fonts.subtitle};
7560
- `;
7561
- const HeaderContainer = styled(FlexSpan) `
7562
- display: flex;
7563
- flex-grow: 1;
7564
- flex-wrap: nowrap;
7565
- width: calc(100% - 48px);
7566
- `;
7567
- const FeatureTitleContainer = styled.div `
7568
- display: -webkit-box;
7569
- max-width: 100%;
7570
- width: 100%;
7571
- margin: 0.5rem 0;
7572
- -webkit-line-clamp: 2;
7573
- -webkit-box-orient: vertical;
7574
- overflow: hidden;
7575
- text-overflow: ellipsis;
7576
- color: ${({ theme: { palette } }) => palette.textPrimary};
7577
-
7578
- & > ${FlexSpan} {
7579
- cursor: ${({ clickable }) => clickable && "pointer"};
7580
-
7581
- &:hover {
7582
- color: ${({ clickable, theme: { palette } }) => clickable && palette.primary};
7583
- }
7584
- }
7549
+ const HeaderFrontView = styled(Flex) `
7550
+ z-index: 10;
7551
+ position: relative;
7552
+ justify-content: space-between;
7553
+ align-items: ${({ isDefault }) => (isDefault ? "center" : "flex-start")};
7554
+ width: 100%;
7555
+ font: ${({ theme: { fonts } }) => fonts.subtitle};
7556
+ `;
7557
+ const HeaderContainer = styled(FlexSpan) `
7558
+ display: flex;
7559
+ flex-grow: 1;
7560
+ flex-wrap: nowrap;
7561
+ width: calc(100% - 48px);
7562
+ `;
7563
+ const FeatureTitleContainer = styled.div `
7564
+ display: -webkit-box;
7565
+ max-width: 100%;
7566
+ width: 100%;
7567
+ margin: 0.5rem 0;
7568
+ -webkit-line-clamp: 2;
7569
+ -webkit-box-orient: vertical;
7570
+ overflow: hidden;
7571
+ text-overflow: ellipsis;
7572
+ color: ${({ theme: { palette } }) => palette.textPrimary};
7573
+
7574
+ & > ${FlexSpan} {
7575
+ cursor: ${({ clickable }) => clickable && "pointer"};
7576
+
7577
+ &:hover {
7578
+ color: ${({ clickable, theme: { palette } }) => clickable && palette.primary};
7579
+ }
7580
+ }
7585
7581
  `;
7586
- const LayerDescription = styled(Description) `
7587
- width: calc(100% - 4rem);
7588
- display: -webkit-box;
7589
- -webkit-line-clamp: 2;
7590
- -webkit-box-orient: vertical;
7591
- overflow: hidden;
7592
- text-overflow: ellipsis;
7582
+ const LayerDescription = styled(Description) `
7583
+ width: calc(100% - 4rem);
7584
+ display: -webkit-box;
7585
+ -webkit-line-clamp: 2;
7586
+ -webkit-box-orient: vertical;
7587
+ overflow: hidden;
7588
+ text-overflow: ellipsis;
7593
7589
  `;
7594
- const HeaderTitleContainer = styled(Flex) `
7595
- flex-direction: column;
7596
- width: 100%;
7590
+ const HeaderTitleContainer = styled(Flex) `
7591
+ flex-direction: column;
7592
+ width: 100%;
7597
7593
  `;
7598
- const RowHeaderMixin = css `
7599
- &&& {
7600
- min-height: auto;
7601
-
7602
- ${FeatureTitleContainer}, ${LayerDescription} {
7603
- text-align: left;
7604
- }
7605
- }
7606
-
7607
- ${HeaderContainer} {
7608
- flex-direction: row;
7609
- }
7610
-
7611
- ${FeatureTitleContainer} {
7612
- max-width: calc(100% - 3.8rem);
7613
- }
7594
+ const RowHeaderMixin = css `
7595
+ &&& {
7596
+ min-height: auto;
7597
+
7598
+ ${FeatureTitleContainer}, ${LayerDescription} {
7599
+ text-align: left;
7600
+ }
7601
+ }
7602
+
7603
+ ${HeaderContainer} {
7604
+ flex-direction: row;
7605
+ }
7606
+
7607
+ ${FeatureTitleContainer} {
7608
+ max-width: calc(100% - 3.8rem);
7609
+ }
7614
7610
  `;
7615
- const Header = styled(Flex) `
7616
- z-index: 1;
7617
- position: relative;
7618
- top: 0;
7619
- flex-shrink: 0;
7620
- overflow: hidden;
7621
- width: 100%;
7622
- padding: 0.5rem;
7623
-
7624
- ${HeaderContainer} {
7625
- flex-direction: column;
7626
- }
7627
-
7628
- ${({ $isRow }) => $isRow && RowHeaderMixin};
7611
+ const Header = styled(Flex) `
7612
+ z-index: 1;
7613
+ position: relative;
7614
+ top: 0;
7615
+ flex-shrink: 0;
7616
+ overflow: hidden;
7617
+ width: 100%;
7618
+ padding: 0.5rem;
7619
+
7620
+ ${HeaderContainer} {
7621
+ flex-direction: column;
7622
+ }
7623
+
7624
+ ${({ $isRow }) => $isRow && RowHeaderMixin};
7629
7625
  `;
7630
- const DefaultHeaderWrapper = styled.div `
7631
- ${Header} {
7632
- padding: 0 1.5rem 1.5rem 0;
7633
- }
7626
+ const DefaultHeaderWrapper = styled.div `
7627
+ ${Header} {
7628
+ padding: 0 1.5rem 1.5rem 0;
7629
+ }
7634
7630
  `;
7635
7631
 
7636
7632
  const HeaderTitle = ({ noFeature }) => {
@@ -7658,22 +7654,22 @@ const HeaderTitle = ({ noFeature }) => {
7658
7654
  return (jsxs(HeaderTitleContainer, { children: [noFeature ? (jsx(FeatureTitleContainer, { children: t("noObjectFound", { ns: "dashboard", defaultValue: "Объектов не найдено" }) })) : (jsx(FeatureTitleContainer, { clickable: true, children: jsx(Tooltip$1, { arrow: true, placement: "top", content: t("zoomToFeature", { ns: "dashboard", defaultValue: "Приблизить к объекту" }), delay: [600, 0], children: ref => (jsx(FlexSpan, { ref: ref, onClick: () => zoomToFeatures([feature]), children: resultTitle })) }) })), jsx(LayerDescription, { title: resultDescription, children: resultDescription })] }));
7659
7655
  };
7660
7656
 
7661
- const LayerIconContainer = styled.div `
7662
- display: flex;
7663
- align-items: center;
7664
- margin-right: 0.75rem;
7657
+ const LayerIconContainer = styled.div `
7658
+ display: flex;
7659
+ align-items: center;
7660
+ margin-right: 0.75rem;
7665
7661
  `;
7666
- const AlertIconContainer = styled(Flex) `
7667
- align-items: center;
7668
- justify-content: center;
7669
- width: 2rem;
7670
- height: 2rem;
7671
-
7672
- ${Icon} {
7673
- :after {
7674
- color: ${({ theme: { palette } }) => palette.error};
7675
- }
7676
- }
7662
+ const AlertIconContainer = styled(Flex) `
7663
+ align-items: center;
7664
+ justify-content: center;
7665
+ width: 2rem;
7666
+ height: 2rem;
7667
+
7668
+ ${Icon} {
7669
+ :after {
7670
+ color: ${({ theme: { palette } }) => palette.error};
7671
+ }
7672
+ }
7677
7673
  `;
7678
7674
 
7679
7675
  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";
@@ -7706,54 +7702,54 @@ const FeatureCardDefaultHeader = ({ noFeature }) => {
7706
7702
  return (jsx(DefaultHeaderWrapper, { children: jsx(Header, { "$isRow": true, children: jsxs(HeaderFrontView, { isDefault: true, children: [jsxs(HeaderContainer, { children: [!!layerInfo?.name && jsx(LayerIcon, { layerInfo: layerInfo }), jsx(HeaderTitle, { noFeature: noFeature })] }), jsx(FeatureCardButtons, {})] }) }) }));
7707
7703
  };
7708
7704
 
7709
- const HeaderFontColorMixin$1 = css `
7710
- ${HeaderTitleContainer}, ${LayerDescription} {
7711
- color: ${({ $fontColor }) => $fontColor};
7712
- }
7705
+ const HeaderFontColorMixin$1 = css `
7706
+ ${HeaderTitleContainer}, ${LayerDescription} {
7707
+ color: ${({ $fontColor }) => $fontColor};
7708
+ }
7713
7709
  `;
7714
- const HeaderWrapperMixin$1 = css `
7715
- ${Header} {
7716
- min-height: 5.25rem;
7717
- }
7718
-
7719
- ${HeaderContainer} {
7720
- max-width: 100%;
7721
- width: 100%;
7722
- }
7723
-
7724
- ${FeatureControls} {
7725
- max-width: calc(100% - 2rem);
7726
- width: calc(100% - 2rem);
7727
- margin-top: -0.5rem;
7728
- padding-top: 1rem;
7729
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
7730
- }
7731
-
7732
- ${({ $fontColor }) => !!$fontColor && HeaderFontColorMixin$1};
7710
+ const HeaderWrapperMixin$1 = css `
7711
+ ${Header} {
7712
+ min-height: 5.25rem;
7713
+ }
7714
+
7715
+ ${HeaderContainer} {
7716
+ max-width: 100%;
7717
+ width: 100%;
7718
+ }
7719
+
7720
+ ${FeatureControls} {
7721
+ max-width: calc(100% - 2rem);
7722
+ width: calc(100% - 2rem);
7723
+ margin-top: -0.5rem;
7724
+ padding-top: 1rem;
7725
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
7726
+ }
7727
+
7728
+ ${({ $fontColor }) => !!$fontColor && HeaderFontColorMixin$1};
7733
7729
  `;
7734
- const GradientHeaderWrapper = styled.div `
7735
- ${Header} {
7736
- background: ${({ $bgColor }) => $bgColor || "radial-gradient(129.21% 133.22% at 51.94% 0%, #e8fffe 9.48%, #5fcaff 100%)"};
7737
- }
7738
-
7739
- ${HeaderContainer} {
7740
- align-items: center;
7741
- }
7742
-
7743
- ${HeaderTitleContainer} {
7744
- margin-left: 0;
7745
- text-align: center;
7746
- }
7747
-
7748
- ${FeatureTitleContainer} {
7749
- text-align: center;
7750
- }
7751
-
7752
- ${LayerDescription} {
7753
- text-align: center;
7754
- }
7755
-
7756
- ${HeaderWrapperMixin$1};
7730
+ const GradientHeaderWrapper = styled.div `
7731
+ ${Header} {
7732
+ background: ${({ $bgColor }) => $bgColor || "radial-gradient(129.21% 133.22% at 51.94% 0%, #e8fffe 9.48%, #5fcaff 100%)"};
7733
+ }
7734
+
7735
+ ${HeaderContainer} {
7736
+ align-items: center;
7737
+ }
7738
+
7739
+ ${HeaderTitleContainer} {
7740
+ margin-left: 0;
7741
+ text-align: center;
7742
+ }
7743
+
7744
+ ${FeatureTitleContainer} {
7745
+ text-align: center;
7746
+ }
7747
+
7748
+ ${LayerDescription} {
7749
+ text-align: center;
7750
+ }
7751
+
7752
+ ${HeaderWrapperMixin$1};
7757
7753
  `;
7758
7754
 
7759
7755
  const FeatureCardGradientHeader = ({ isRow }) => {
@@ -7772,80 +7768,80 @@ const FeatureCardGradientHeader = ({ isRow }) => {
7772
7768
  }) })] }), jsx(FeatureCardButtons, {})] }) }) }) }));
7773
7769
  };
7774
7770
 
7775
- const HeaderFontColorMixin = css `
7776
- ${HeaderTitleContainer}, ${HeaderTitleContainer} *, ${LayerDescription} {
7777
- color: ${({ $fontColor }) => $fontColor};
7778
- }
7771
+ const HeaderFontColorMixin = css `
7772
+ ${HeaderTitleContainer}, ${HeaderTitleContainer} *, ${LayerDescription} {
7773
+ color: ${({ $fontColor }) => $fontColor};
7774
+ }
7779
7775
  `;
7780
- const HeaderWrapperMixin = css `
7781
- ${Header} {
7782
- min-height: 5.25rem;
7783
- }
7784
-
7785
- ${HeaderContainer} {
7786
- max-width: 100%;
7787
- width: 100%;
7788
- }
7789
-
7790
- ${FeatureControls} {
7791
- max-width: calc(100% - 2rem);
7792
- width: calc(100% - 2rem);
7793
- margin-top: -0.5rem;
7794
- padding-top: 1rem;
7795
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
7796
- }
7797
-
7798
- ${({ $fontColor }) => !!$fontColor && HeaderFontColorMixin};
7799
- `;
7800
- const HeaderIcon = styled(Flex) `
7801
- position: absolute;
7802
- top: 0;
7803
- right: 0;
7804
- justify-content: flex-end;
7805
- align-items: center;
7806
- min-width: 7.5rem;
7807
- height: 100%;
7808
-
7809
- span[kind]:after {
7810
- font-size: 7.5rem;
7811
- }
7812
-
7813
- span[kind]:after,
7814
- path,
7815
- line,
7816
- circle {
7817
- fill: rgba(255, 255, 255, 0.36);
7818
- }
7819
-
7820
- && > * {
7821
- display: flex;
7822
- align-items: center;
7823
- height: 100%;
7824
- }
7776
+ const HeaderWrapperMixin = css `
7777
+ ${Header} {
7778
+ min-height: 5.25rem;
7779
+ }
7780
+
7781
+ ${HeaderContainer} {
7782
+ max-width: 100%;
7783
+ width: 100%;
7784
+ }
7785
+
7786
+ ${FeatureControls} {
7787
+ max-width: calc(100% - 2rem);
7788
+ width: calc(100% - 2rem);
7789
+ margin-top: -0.5rem;
7790
+ padding-top: 1rem;
7791
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
7792
+ }
7793
+
7794
+ ${({ $fontColor }) => !!$fontColor && HeaderFontColorMixin};
7795
+ `;
7796
+ const HeaderIcon = styled(Flex) `
7797
+ position: absolute;
7798
+ top: 0;
7799
+ right: 0;
7800
+ justify-content: flex-end;
7801
+ align-items: center;
7802
+ min-width: 7.5rem;
7803
+ height: 100%;
7804
+
7805
+ span[kind]:after {
7806
+ font-size: 7.5rem;
7807
+ }
7808
+
7809
+ span[kind]:after,
7810
+ path,
7811
+ line,
7812
+ circle {
7813
+ fill: rgba(255, 255, 255, 0.36);
7814
+ }
7815
+
7816
+ && > * {
7817
+ display: flex;
7818
+ align-items: center;
7819
+ height: 100%;
7820
+ }
7825
7821
  `;
7826
- const BigIconHeaderMixin = css `
7827
- ${HeaderIcon} {
7828
- min-width: 14rem;
7829
- right: -3rem;
7830
-
7831
- span[kind]:after {
7832
- font-size: 14rem;
7833
- }
7834
- }
7822
+ const BigIconHeaderMixin = css `
7823
+ ${HeaderIcon} {
7824
+ min-width: 14rem;
7825
+ right: -3rem;
7826
+
7827
+ span[kind]:after {
7828
+ font-size: 14rem;
7829
+ }
7830
+ }
7835
7831
  `;
7836
- const IconHeaderWrapper = styled.div `
7837
- ${Header} {
7838
- width: calc(100% + 1.5rem);
7839
- margin: -1.5rem -1.5rem 0 -1.5rem;
7840
- padding: 1.5rem;
7841
- border-top-left-radius: 0.5rem;
7842
- border-top-right-radius: 0.5rem;
7843
- background: ${({ $bgColor }) => $bgColor || "linear-gradient(96.55deg, #FFFCD3 0%, #B4DC47 100%)"};
7844
- }
7845
-
7846
- ${HeaderWrapperMixin};
7847
-
7848
- ${({ $bigIcon }) => $bigIcon && BigIconHeaderMixin};
7832
+ const IconHeaderWrapper = styled.div `
7833
+ ${Header} {
7834
+ width: calc(100% + 1.5rem);
7835
+ margin: -1.5rem -1.5rem 0 -1.5rem;
7836
+ padding: 1.5rem;
7837
+ border-top-left-radius: 0.5rem;
7838
+ border-top-right-radius: 0.5rem;
7839
+ background: ${({ $bgColor }) => $bgColor || "linear-gradient(96.55deg, #FFFCD3 0%, #B4DC47 100%)"};
7840
+ }
7841
+
7842
+ ${HeaderWrapperMixin};
7843
+
7844
+ ${({ $bigIcon }) => $bigIcon && BigIconHeaderMixin};
7849
7845
  `;
7850
7846
 
7851
7847
  const FeatureCardIconHeader = ({ isRow }) => {
@@ -7867,15 +7863,15 @@ const FeatureCardIconHeader = ({ isRow }) => {
7867
7863
  }) })] }) }) }));
7868
7864
  };
7869
7865
 
7870
- const ImageContainerButton = styled(FlatButton) `
7871
- min-height: 1.5rem;
7872
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.large};
7873
- background-color: ${({ theme: { palette } }) => palette.primary};
7874
- text-transform: none;
7875
-
7876
- :hover {
7877
- background-color: ${({ theme: { palette } }) => palette.primaryDeep};
7878
- }
7866
+ const ImageContainerButton = styled(FlatButton) `
7867
+ min-height: 1.5rem;
7868
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.large};
7869
+ background-color: ${({ theme: { palette } }) => palette.primary};
7870
+ text-transform: none;
7871
+
7872
+ :hover {
7873
+ background-color: ${({ theme: { palette } }) => palette.primaryDeep};
7874
+ }
7879
7875
  `;
7880
7876
 
7881
7877
  const ElementButton = memo(({ type, elementConfig }) => {
@@ -7887,157 +7883,157 @@ const ElementButton = memo(({ type, elementConfig }) => {
7887
7883
  return (jsx(ImageContainerButton, { onClick: () => window.open(attribute?.value), children: elementConfig.value || "" }));
7888
7884
  });
7889
7885
 
7890
- const AttributeGalleryContainer = styled.div `
7891
- && {
7892
- width: calc(100% + 3rem);
7893
- }
7894
-
7895
- min-height: 12.625rem;
7896
- background-color: ${({ theme: { palette } }) => palette.element};
7897
-
7898
- img {
7899
- width: 100%;
7900
- }
7886
+ const AttributeGalleryContainer = styled.div `
7887
+ && {
7888
+ width: calc(100% + 3rem);
7889
+ }
7890
+
7891
+ min-height: 12.625rem;
7892
+ background-color: ${({ theme: { palette } }) => palette.element};
7893
+
7894
+ img {
7895
+ width: 100%;
7896
+ }
7901
7897
  `;
7902
- const LinearProgressContainer = styled(Flex) `
7903
- align-items: center;
7904
- justify-content: center;
7905
- min-height: inherit;
7906
-
7907
- ${LinearProgress} {
7908
- max-width: 4rem;
7909
- }
7898
+ const LinearProgressContainer = styled(Flex) `
7899
+ align-items: center;
7900
+ justify-content: center;
7901
+ min-height: inherit;
7902
+
7903
+ ${LinearProgress} {
7904
+ max-width: 4rem;
7905
+ }
7910
7906
  `;
7911
- const NoLiveSnapshotContainer = styled(Flex) `
7912
- flex-direction: column;
7913
- align-items: center;
7914
-
7915
- span[kind="alert"] {
7916
- width: 2rem;
7917
- height: 2rem;
7918
-
7919
- &:after {
7920
- font-size: 2rem;
7921
- color: ${({ theme: { palette } }) => palette.elementDeep};
7922
- }
7923
- }
7924
-
7925
- ${Description} {
7926
- font-size: 0.75rem;
7927
- color: ${({ theme: { palette } }) => palette.textDisabled};
7928
- }
7907
+ const NoLiveSnapshotContainer = styled(Flex) `
7908
+ flex-direction: column;
7909
+ align-items: center;
7910
+
7911
+ span[kind="alert"] {
7912
+ width: 2rem;
7913
+ height: 2rem;
7914
+
7915
+ &:after {
7916
+ font-size: 2rem;
7917
+ color: ${({ theme: { palette } }) => palette.elementDeep};
7918
+ }
7919
+ }
7920
+
7921
+ ${Description} {
7922
+ font-size: 0.75rem;
7923
+ color: ${({ theme: { palette } }) => palette.textDisabled};
7924
+ }
7929
7925
  `;
7930
- const SmallPreviewControl = styled(IconButton) `
7931
- cursor: ${({ $isDisabled }) => ($isDisabled ? "default" : "pointer")};
7932
- z-index: 3;
7933
- position: absolute;
7934
- top: 50%;
7935
- width: 2.5rem;
7936
- height: 2.5rem;
7937
- margin-top: -1.25rem;
7938
- background-color: rgba(61, 61, 61, 0.8);
7939
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.smallest};
7940
-
7941
- span:after {
7942
- color: ${({ $isDisabled }) => ($isDisabled ? "rgba(255, 255, 255, 0.28)" : "rgba(255, 255, 255, 1)")};
7943
- transition: color ${transition.hover};
7944
- }
7926
+ const SmallPreviewControl = styled(IconButton) `
7927
+ cursor: ${({ $isDisabled }) => ($isDisabled ? "default" : "pointer")};
7928
+ z-index: 3;
7929
+ position: absolute;
7930
+ top: 50%;
7931
+ width: 2.5rem;
7932
+ height: 2.5rem;
7933
+ margin-top: -1.25rem;
7934
+ background-color: rgba(61, 61, 61, 0.8);
7935
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.smallest};
7936
+
7937
+ span:after {
7938
+ color: ${({ $isDisabled }) => ($isDisabled ? "rgba(255, 255, 255, 0.28)" : "rgba(255, 255, 255, 1)")};
7939
+ transition: color ${transition.hover};
7940
+ }
7945
7941
  `;
7946
- const SmallPreviewCounter = styled(Flex) `
7947
- z-index: 3;
7948
- position: absolute;
7949
- bottom: 0.625rem;
7950
- left: 0;
7951
- width: 100%;
7952
- height: 1rem;
7953
- justify-content: center;
7954
-
7955
- > div {
7956
- background-color: rgba(61, 61, 61, 0.8);
7957
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
7958
- padding: 0 0.5rem;
7959
- font-size: 0.625rem;
7960
- line-height: 1rem;
7961
- color: #fff;
7962
- }
7942
+ const SmallPreviewCounter = styled(Flex) `
7943
+ z-index: 3;
7944
+ position: absolute;
7945
+ bottom: 0.625rem;
7946
+ left: 0;
7947
+ width: 100%;
7948
+ height: 1rem;
7949
+ justify-content: center;
7950
+
7951
+ > div {
7952
+ background-color: rgba(61, 61, 61, 0.8);
7953
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
7954
+ padding: 0 0.5rem;
7955
+ font-size: 0.625rem;
7956
+ line-height: 1rem;
7957
+ color: #fff;
7958
+ }
7963
7959
  `;
7964
7960
  const SmallPreviewLeft = styled(SmallPreviewControl).attrs(() => ({
7965
7961
  kind: "prev",
7966
- })) `
7967
- left: 1.5rem;
7962
+ })) `
7963
+ left: 1.5rem;
7968
7964
  `;
7969
7965
  const SmallPreviewRight = styled(SmallPreviewControl).attrs(() => ({
7970
7966
  kind: "next",
7971
- })) `
7972
- right: 1.5rem;
7973
- `;
7974
- const imgSlideShowMixin = css `
7975
- &:nth-child(${({ prevIndex }) => prevIndex}) {
7976
- z-index: 2;
7977
- position: absolute;
7978
- top: 0;
7979
- left: 0;
7980
- right: 0;
7981
- bottom: 0;
7982
- opacity: 0;
7983
-
7984
- animation-duration: 0.25s;
7985
- animation-name: fadeOut;
7986
- animation-timing-function: linear;
7987
-
7988
- @keyframes fadeOut {
7989
- from {
7990
- opacity: 1;
7991
- }
7992
-
7993
- to {
7994
- opacity: 0;
7995
- }
7996
- }
7997
- }
7967
+ })) `
7968
+ right: 1.5rem;
7969
+ `;
7970
+ const imgSlideShowMixin = css `
7971
+ &:nth-child(${({ prevIndex }) => prevIndex}) {
7972
+ z-index: 2;
7973
+ position: absolute;
7974
+ top: 0;
7975
+ left: 0;
7976
+ right: 0;
7977
+ bottom: 0;
7978
+ opacity: 0;
7979
+
7980
+ animation-duration: 0.25s;
7981
+ animation-name: fadeOut;
7982
+ animation-timing-function: linear;
7983
+
7984
+ @keyframes fadeOut {
7985
+ from {
7986
+ opacity: 1;
7987
+ }
7988
+
7989
+ to {
7990
+ opacity: 0;
7991
+ }
7992
+ }
7993
+ }
7998
7994
  `;
7999
- const SmallPreviewContainer$1 = styled.div `
8000
- cursor: ${({ onClick }) => (onClick ? "pointer" : "default")};
8001
- position: relative;
8002
- width: 100%;
8003
- height: 100%;
8004
- min-height: inherit;
8005
- line-height: 0;
8006
-
8007
- ${LinearProgress} {
8008
- z-index: 3;
8009
- position: absolute;
8010
- }
8011
-
8012
- ${SmallPreviewControl}, ${SmallPreviewCounter} {
8013
- opacity: 0;
8014
- transition: opacity ${transition.hover};
8015
- }
8016
-
8017
- &:hover {
8018
- ${SmallPreviewControl}, ${SmallPreviewCounter} {
8019
- opacity: 1;
8020
- }
8021
- }
8022
-
8023
- img {
8024
- z-index: 0;
8025
- cursor: pointer;
8026
- position: absolute;
8027
- top: 0;
8028
- left: 0;
8029
- width: 100%;
8030
- height: 100%;
8031
- min-height: inherit;
8032
- object-position: center;
8033
- object-fit: cover;
8034
-
8035
- &:nth-child(${({ currentIndex }) => currentIndex}) {
8036
- z-index: 1;
8037
- }
8038
-
8039
- ${({ prevIndex, currentIndex }) => prevIndex !== currentIndex && imgSlideShowMixin}
8040
- }
7995
+ const SmallPreviewContainer$1 = styled.div `
7996
+ cursor: ${({ onClick }) => (onClick ? "pointer" : "default")};
7997
+ position: relative;
7998
+ width: 100%;
7999
+ height: 100%;
8000
+ min-height: inherit;
8001
+ line-height: 0;
8002
+
8003
+ ${LinearProgress} {
8004
+ z-index: 3;
8005
+ position: absolute;
8006
+ }
8007
+
8008
+ ${SmallPreviewControl}, ${SmallPreviewCounter} {
8009
+ opacity: 0;
8010
+ transition: opacity ${transition.hover};
8011
+ }
8012
+
8013
+ &:hover {
8014
+ ${SmallPreviewControl}, ${SmallPreviewCounter} {
8015
+ opacity: 1;
8016
+ }
8017
+ }
8018
+
8019
+ img {
8020
+ z-index: 0;
8021
+ cursor: pointer;
8022
+ position: absolute;
8023
+ top: 0;
8024
+ left: 0;
8025
+ width: 100%;
8026
+ height: 100%;
8027
+ min-height: inherit;
8028
+ object-position: center;
8029
+ object-fit: cover;
8030
+
8031
+ &:nth-child(${({ currentIndex }) => currentIndex}) {
8032
+ z-index: 1;
8033
+ }
8034
+
8035
+ ${({ prevIndex, currentIndex }) => prevIndex !== currentIndex && imgSlideShowMixin}
8036
+ }
8041
8037
  `;
8042
8038
  const SmallPreviewImages = styled.div ``;
8043
8039
 
@@ -8244,21 +8240,21 @@ const ElementControl = ({ elementConfig }) => {
8244
8240
  return (jsx(Dropdown, { zIndex: 1000, width: `${width ?? DEFAULT_DROPDOWN_WIDTH}px`, label: label, options: items, value: controls?.[control?.targetAttributeName] ?? attribute?.value ?? defaultValue, placeholder: placeholder, disabled: isDisabled, onChange: handleChange }));
8245
8241
  };
8246
8242
 
8247
- const StyledIconFontSizeMixin = css `
8248
- height: ${({ fontSize }) => `${fontSize}px`};
8249
-
8250
- &&:after {
8251
- font-size: ${({ fontSize }) => `${fontSize}px`};
8252
- }
8243
+ const StyledIconFontSizeMixin = css `
8244
+ height: ${({ fontSize }) => `${fontSize}px`};
8245
+
8246
+ &&:after {
8247
+ font-size: ${({ fontSize }) => `${fontSize}px`};
8248
+ }
8253
8249
  `;
8254
- const StyledIconFontColorMixin = css `
8255
- &&:after {
8256
- color: ${({ fontColor }) => fontColor};
8257
- }
8250
+ const StyledIconFontColorMixin = css `
8251
+ &&:after {
8252
+ color: ${({ fontColor }) => fontColor};
8253
+ }
8258
8254
  `;
8259
- const StyledIcon = styled(Icon) `
8260
- ${({ fontSize }) => !!fontSize && StyledIconFontSizeMixin};
8261
- ${({ fontColor }) => !!fontColor && StyledIconFontColorMixin};
8255
+ const StyledIcon = styled(Icon) `
8256
+ ${({ fontSize }) => !!fontSize && StyledIconFontSizeMixin};
8257
+ ${({ fontColor }) => !!fontColor && StyledIconFontColorMixin};
8262
8258
  `;
8263
8259
 
8264
8260
  const ElementIcon = memo(({ type, elementConfig }) => {
@@ -8324,55 +8320,55 @@ const ElementLegend = memo(({ type, element, elementConfig }) => {
8324
8320
 
8325
8321
  const ExternalLink = styled(IconButton).attrs(() => ({
8326
8322
  kind: "external_link",
8327
- })) `
8328
- ${Icon} {
8329
- color: ${({ theme: { palette } }) => palette.primary};
8330
- }
8331
-
8332
- &:hover ${Icon} {
8333
- color: ${({ theme: { palette } }) => palette.primaryDeep};
8334
- }
8323
+ })) `
8324
+ ${Icon} {
8325
+ color: ${({ theme: { palette } }) => palette.primary};
8326
+ }
8327
+
8328
+ &:hover ${Icon} {
8329
+ color: ${({ theme: { palette } }) => palette.primaryDeep};
8330
+ }
8335
8331
  `;
8336
- const Link = styled.a `
8337
- text-decoration: none;
8338
- font-size: 0.75rem;
8339
- color: ${({ theme: { palette } }) => palette.primary};
8332
+ const Link = styled.a `
8333
+ text-decoration: none;
8334
+ font-size: 0.75rem;
8335
+ color: ${({ theme: { palette } }) => palette.primary};
8340
8336
  `;
8341
- const LocalLinkBlank = styled(Blank) `
8342
- min-width: 13.5rem;
8343
- padding: 0.5rem 0.75rem 0;
8344
-
8345
- ${IconButtonButton} {
8346
- font-size: 0.75rem;
8347
- }
8337
+ const LocalLinkBlank = styled(Blank) `
8338
+ min-width: 13.5rem;
8339
+ padding: 0.5rem 0.75rem 0;
8340
+
8341
+ ${IconButtonButton} {
8342
+ font-size: 0.75rem;
8343
+ }
8348
8344
  `;
8349
8345
  const LocalLinkButton = styled(IconButton).attrs(() => ({
8350
8346
  kind: "link",
8351
- })) `
8352
- width: 1rem;
8353
- height: 1rem;
8354
- background-color: ${({ theme: { palette } }) => palette.primary};
8355
- padding: 0;
8356
- border-radius: 50%;
8357
-
8358
- :hover {
8359
- background-color: ${({ theme: { palette } }) => palette.primary};
8360
- }
8361
-
8362
- span[kind] {
8363
- display: flex;
8364
- justify-content: center;
8365
- align-items: center;
8366
-
8367
- :after {
8368
- position: relative;
8369
- font-size: 0.6rem;
8370
- color: white;
8371
- }
8372
- }
8347
+ })) `
8348
+ width: 1rem;
8349
+ height: 1rem;
8350
+ background-color: ${({ theme: { palette } }) => palette.primary};
8351
+ padding: 0;
8352
+ border-radius: 50%;
8353
+
8354
+ :hover {
8355
+ background-color: ${({ theme: { palette } }) => palette.primary};
8356
+ }
8357
+
8358
+ span[kind] {
8359
+ display: flex;
8360
+ justify-content: center;
8361
+ align-items: center;
8362
+
8363
+ :after {
8364
+ position: relative;
8365
+ font-size: 0.6rem;
8366
+ color: white;
8367
+ }
8368
+ }
8373
8369
  `;
8374
- const LocalLinkCopy = styled(Flex) `
8375
- justify-content: center;
8370
+ const LocalLinkCopy = styled(Flex) `
8371
+ justify-content: center;
8376
8372
  `;
8377
8373
 
8378
8374
  const LocalLink = memo(({ link, style }) => {
@@ -8401,104 +8397,104 @@ const ElementLink = memo(({ type, elementConfig }) => {
8401
8397
  : jsx(LocalLink, { style: style, link: link });
8402
8398
  });
8403
8399
 
8404
- const MarkdownWrapper = styled.div `
8405
- padding: 0;
8406
- background: transparent;
8407
- border-radius: 0.5rem;
8408
- font-family: 'Nunito Sans', sans-serif;
8409
- color: ${({ theme: { palette } }) => palette.textPrimary};
8410
-
8411
- /* Paragraphs */
8412
- p {
8413
- font-size: 0.875rem;
8414
- line-height: 1rem;
8415
- letter-spacing: 0.0052rem;
8416
- margin: 0 0 1rem 0;
8417
- font-weight: 400;
8418
-
8419
- &:last-child {
8420
- margin-bottom: 0;
8421
- }
8422
- }
8423
-
8424
- /* Headings */
8425
- h1, h2, h3, h4, h5, h6 {
8426
- margin: 0 0 0.75rem 0;
8427
- font-weight: 300;
8428
- }
8429
-
8430
- h1 {
8431
- font-size: 1.5rem;
8432
- line-height: 1.75rem;
8433
- }
8434
-
8435
- h2 {
8436
- font-size: 1.25rem;
8437
- line-height: 1.5rem;
8438
- }
8439
-
8440
- h3 {
8441
- font-size: 1rem;
8442
- line-height: 1.25rem;
8443
- }
8444
-
8445
- /* Images */
8446
- img {
8447
- max-width: 100%;
8448
- height: auto;
8449
- border-radius: 0.5rem;
8450
- object-fit: cover;
8451
- margin: 0.75rem 0;
8452
- }
8453
-
8454
- /* Links */
8455
- a {
8456
- color: ${({ theme: { palette } }) => palette.primary};
8457
- text-decoration: none;
8458
-
8459
- &:hover {
8460
- text-decoration: underline;
8461
- }
8462
- }
8463
-
8464
- /* Lists */
8465
- ul, ol {
8466
- margin: 0 0 1rem 0;
8467
- padding-left: 1.25rem;
8468
-
8469
- li {
8470
- font-size: 0.875rem;
8471
- line-height: 1rem;
8472
- margin-bottom: 0.5rem;
8473
- }
8474
- }
8475
-
8476
- /* Code */
8477
- code {
8478
- background: ${({ theme: { palette } }) => palette.element};
8479
- padding: 0.125rem 0.375rem;
8480
- border-radius: 0.25rem;
8481
- font-family: monospace;
8482
- font-size: 0.8125rem;
8483
- }
8484
-
8485
- pre {
8486
- background: ${({ theme: { palette } }) => palette.element};
8487
- padding: 0.75rem;
8488
- border-radius: 0.25rem;
8489
- overflow-x: auto;
8490
- margin: 0.75rem 0;
8491
-
8492
- code {
8493
- background: transparent;
8494
- padding: 0;
8495
- }
8496
- }
8497
-
8498
- /* Hide horizontal rules */
8499
- hr {
8500
- display: none;
8501
- }
8400
+ const MarkdownWrapper = styled.div `
8401
+ padding: 0;
8402
+ background: transparent;
8403
+ border-radius: 0.5rem;
8404
+ font-family: 'Nunito Sans', sans-serif;
8405
+ color: ${({ theme: { palette } }) => palette.textPrimary};
8406
+
8407
+ /* Paragraphs */
8408
+ p {
8409
+ font-size: 0.875rem;
8410
+ line-height: 1rem;
8411
+ letter-spacing: 0.0052rem;
8412
+ margin: 0 0 1rem 0;
8413
+ font-weight: 400;
8414
+
8415
+ &:last-child {
8416
+ margin-bottom: 0;
8417
+ }
8418
+ }
8419
+
8420
+ /* Headings */
8421
+ h1, h2, h3, h4, h5, h6 {
8422
+ margin: 0 0 0.75rem 0;
8423
+ font-weight: 300;
8424
+ }
8425
+
8426
+ h1 {
8427
+ font-size: 1.5rem;
8428
+ line-height: 1.75rem;
8429
+ }
8430
+
8431
+ h2 {
8432
+ font-size: 1.25rem;
8433
+ line-height: 1.5rem;
8434
+ }
8435
+
8436
+ h3 {
8437
+ font-size: 1rem;
8438
+ line-height: 1.25rem;
8439
+ }
8440
+
8441
+ /* Images */
8442
+ img {
8443
+ max-width: 100%;
8444
+ height: auto;
8445
+ border-radius: 0.5rem;
8446
+ object-fit: cover;
8447
+ margin: 0.75rem 0;
8448
+ }
8449
+
8450
+ /* Links */
8451
+ a {
8452
+ color: ${({ theme: { palette } }) => palette.primary};
8453
+ text-decoration: none;
8454
+
8455
+ &:hover {
8456
+ text-decoration: underline;
8457
+ }
8458
+ }
8459
+
8460
+ /* Lists */
8461
+ ul, ol {
8462
+ margin: 0 0 1rem 0;
8463
+ padding-left: 1.25rem;
8464
+
8465
+ li {
8466
+ font-size: 0.875rem;
8467
+ line-height: 1rem;
8468
+ margin-bottom: 0.5rem;
8469
+ }
8470
+ }
8471
+
8472
+ /* Code */
8473
+ code {
8474
+ background: ${({ theme: { palette } }) => palette.element};
8475
+ padding: 0.125rem 0.375rem;
8476
+ border-radius: 0.25rem;
8477
+ font-family: monospace;
8478
+ font-size: 0.8125rem;
8479
+ }
8480
+
8481
+ pre {
8482
+ background: ${({ theme: { palette } }) => palette.element};
8483
+ padding: 0.75rem;
8484
+ border-radius: 0.25rem;
8485
+ overflow-x: auto;
8486
+ margin: 0.75rem 0;
8487
+
8488
+ code {
8489
+ background: transparent;
8490
+ padding: 0;
8491
+ }
8492
+ }
8493
+
8494
+ /* Hide horizontal rules */
8495
+ hr {
8496
+ display: none;
8497
+ }
8502
8498
  `;
8503
8499
 
8504
8500
  const sanitizeSchema = {
@@ -8540,9 +8536,9 @@ const ElementMarkdown = memo(({ elementConfig, type }) => {
8540
8536
  return (jsxs(MarkdownWrapper, { children: [jsx(ReactMarkdown, { remarkPlugins: [remarkGfm], rehypePlugins: [rehypeRaw, rehypeSanitize], children: markdownString }), jsx(LegendToggler, { toggled: true, onClick: () => setExpanded(false), children: t("hide", { ns: "dashboard", defaultValue: "Свернуть" }) })] }));
8541
8537
  });
8542
8538
 
8543
- const SmallPreviewContainer = styled.div `
8544
- width: 100%;
8545
- height: 100%;
8539
+ const SmallPreviewContainer = styled.div `
8540
+ width: 100%;
8541
+ height: 100%;
8546
8542
  `;
8547
8543
 
8548
8544
  const ElementSlideshow = ({ elementConfig, type, renderElement }) => {
@@ -8578,18 +8574,18 @@ const ElementSvg = memo(({ type, elementConfig }) => {
8578
8574
  return (jsx(SvgImage, { url: getSvgUrl({ elementConfig, layerInfo, attributes }), width: width, height: height, fontColor: fontColor }));
8579
8575
  });
8580
8576
 
8581
- const TooltipIcon = styled(Icon) `
8582
- &&& {
8583
- :after {
8584
- font-size: 0.75rem;
8585
- color: ${({ theme: { palette } }) => palette.iconDisabled};
8586
- transition: color ${transition.hover};
8587
- }
8588
-
8589
- :hover:after {
8590
- color: ${({ theme: { palette } }) => palette.icon};
8591
- }
8592
- }
8577
+ const TooltipIcon = styled(Icon) `
8578
+ &&& {
8579
+ :after {
8580
+ font-size: 0.75rem;
8581
+ color: ${({ theme: { palette } }) => palette.iconDisabled};
8582
+ transition: color ${transition.hover};
8583
+ }
8584
+
8585
+ :hover:after {
8586
+ color: ${({ theme: { palette } }) => palette.icon};
8587
+ }
8588
+ }
8593
8589
  `;
8594
8590
 
8595
8591
  const ElementTooltip = memo(({ type, elementConfig }) => {
@@ -8601,76 +8597,76 @@ const ElementTooltip = memo(({ type, elementConfig }) => {
8601
8597
  return text ? (jsx(Tooltip$1, { placement: "top", arrow: true, content: text, children: ref => jsx(TooltipIcon, { kind: icon || "question", ref: ref }) })) : null;
8602
8598
  });
8603
8599
 
8604
- const SlideshowHeaderWrapper = styled.div `
8605
- padding: ${({ withPadding }) => (withPadding ? "0.5rem 0.5rem 0" : 0)};
8606
-
8607
- ${Header} {
8608
- align-items: flex-start;
8609
- width: calc(100% + 2rem);
8610
- height: ${({ big }) => (big ? "15.5rem" : "auto")};
8611
- padding: 1.5rem;
8612
- margin: -1rem -1rem 0 -1rem;
8613
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
8614
-
8615
- ${SmallPreviewCounter} {
8616
- bottom: ${({ withPadding }) => (withPadding ? 0.625 : 1.125)}rem;
8617
- }
8618
-
8619
- :before,
8620
- :after {
8621
- content: "";
8622
- z-index: 2;
8623
- position: absolute;
8624
- top: 0;
8625
- left: 0;
8626
- width: 100%;
8627
- }
8628
-
8629
- :before {
8630
- height: 100%;
8631
- background: rgba(32, 46, 53, 0.25);
8632
- }
8633
-
8634
- :after {
8635
- height: 4.5rem;
8636
- background: linear-gradient(180deg, #000000 0%, rgba(0, 0, 0, 0) 100%);
8637
- }
8638
-
8639
- :hover {
8640
- ${SmallPreviewControl}, ${SmallPreviewCounter} {
8641
- opacity: 1;
8642
- }
8643
- }
8644
- }
8600
+ const SlideshowHeaderWrapper = styled.div `
8601
+ padding: ${({ withPadding }) => (withPadding ? "0.5rem 0.5rem 0" : 0)};
8602
+
8603
+ ${Header} {
8604
+ align-items: flex-start;
8605
+ width: calc(100% + 2rem);
8606
+ height: ${({ big }) => (big ? "15.5rem" : "auto")};
8607
+ padding: 1.5rem;
8608
+ margin: -1rem -1rem 0 -1rem;
8609
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
8610
+
8611
+ ${SmallPreviewCounter} {
8612
+ bottom: ${({ withPadding }) => (withPadding ? 0.625 : 1.125)}rem;
8613
+ }
8614
+
8615
+ :before,
8616
+ :after {
8617
+ content: "";
8618
+ z-index: 2;
8619
+ position: absolute;
8620
+ top: 0;
8621
+ left: 0;
8622
+ width: 100%;
8623
+ }
8624
+
8625
+ :before {
8626
+ height: 100%;
8627
+ background: rgba(32, 46, 53, 0.25);
8628
+ }
8629
+
8630
+ :after {
8631
+ height: 4.5rem;
8632
+ background: linear-gradient(180deg, #000000 0%, rgba(0, 0, 0, 0) 100%);
8633
+ }
8634
+
8635
+ :hover {
8636
+ ${SmallPreviewControl}, ${SmallPreviewCounter} {
8637
+ opacity: 1;
8638
+ }
8639
+ }
8640
+ }
8645
8641
  `;
8646
- const ImageContainerBg = styled.div `
8647
- position: absolute;
8648
- top: 0;
8649
- bottom: 0;
8650
- left: 0;
8651
- right: 0;
8652
-
8653
- img {
8654
- width: 100%;
8655
- height: 100%;
8656
- object-position: center;
8657
- object-fit: cover;
8658
- }
8642
+ const ImageContainerBg = styled.div `
8643
+ position: absolute;
8644
+ top: 0;
8645
+ bottom: 0;
8646
+ left: 0;
8647
+ right: 0;
8648
+
8649
+ img {
8650
+ width: 100%;
8651
+ height: 100%;
8652
+ object-position: center;
8653
+ object-fit: cover;
8654
+ }
8659
8655
  `;
8660
- const HeaderSlideshow = styled.div `
8661
- position: absolute;
8662
- top: 0;
8663
- bottom: ${({ height }) => (height ? `${height}px` : 0)};
8664
- left: 0;
8665
- right: 0;
8666
-
8667
- img {
8668
- width: 100%;
8669
- height: 100%;
8670
- min-height: inherit;
8671
- object-position: center;
8672
- object-fit: cover;
8673
- }
8656
+ const HeaderSlideshow = styled.div `
8657
+ position: absolute;
8658
+ top: 0;
8659
+ bottom: ${({ height }) => (height ? `${height}px` : 0)};
8660
+ left: 0;
8661
+ right: 0;
8662
+
8663
+ img {
8664
+ width: 100%;
8665
+ height: 100%;
8666
+ min-height: inherit;
8667
+ object-position: center;
8668
+ object-fit: cover;
8669
+ }
8674
8670
  `;
8675
8671
 
8676
8672
  const FeatureCardSlideshowHeader = ({ isRow }) => {
@@ -8809,40 +8805,40 @@ const getDefaultConfig = ({ title, defaultTitle, items, baseMapName, position, r
8809
8805
  return dashboardConfiguration;
8810
8806
  };
8811
8807
 
8812
- const UploaderContainer = styled(Container) `
8813
- ${UploaderItemArea} {
8814
- overflow: visible;
8815
- padding-top: 1rem;
8816
- padding-bottom: 1rem;
8817
- }
8818
-
8819
- ${UploaderTitleWrapper} {
8820
- top: 0;
8821
- padding-top: 0;
8822
- border: 0;
8823
- }
8808
+ const UploaderContainer = styled(Container) `
8809
+ ${UploaderItemArea} {
8810
+ overflow: visible;
8811
+ padding-top: 1rem;
8812
+ padding-bottom: 1rem;
8813
+ }
8814
+
8815
+ ${UploaderTitleWrapper} {
8816
+ top: 0;
8817
+ padding-top: 0;
8818
+ border: 0;
8819
+ }
8824
8820
  `;
8825
8821
 
8826
- const UploaderTitle = styled(Flex) `
8827
- flex-direction: column;
8828
- align-items: center;
8829
- width: 11rem;
8830
- margin: 0 auto;
8831
- text-align: center;
8832
- font-size: 0.625rem;
8833
- color: ${({ theme: { palette } }) => palette.textSecondary};
8834
-
8835
- span[kind] {
8836
- width: 1.5rem;
8837
- height: 1.5rem;
8838
- margin-bottom: 0.75rem;
8839
-
8840
- :after {
8841
- font-size: 1.5rem;
8842
- color: ${({ theme: { palette } }) => palette.textSecondary};
8843
- opacity: 0.12;
8844
- }
8845
- }
8822
+ const UploaderTitle = styled(Flex) `
8823
+ flex-direction: column;
8824
+ align-items: center;
8825
+ width: 11rem;
8826
+ margin: 0 auto;
8827
+ text-align: center;
8828
+ font-size: 0.625rem;
8829
+ color: ${({ theme: { palette } }) => palette.textSecondary};
8830
+
8831
+ span[kind] {
8832
+ width: 1.5rem;
8833
+ height: 1.5rem;
8834
+ margin-bottom: 0.75rem;
8835
+
8836
+ :after {
8837
+ font-size: 1.5rem;
8838
+ color: ${({ theme: { palette } }) => palette.textSecondary};
8839
+ opacity: 0.12;
8840
+ }
8841
+ }
8846
8842
  `;
8847
8843
 
8848
8844
  const DEFAULT_FILE_EXTENSIONS = ".txt,.csv,.py";
@@ -9507,64 +9503,64 @@ const getJustifyContent = (align) => {
9507
9503
  return "flex-start";
9508
9504
  }
9509
9505
  };
9510
- const ChipsContainer = styled(Flex) `
9511
- flex-wrap: wrap;
9512
- gap: 0.25rem;
9513
- background: transparent;
9514
- justify-content: ${({ $align }) => getJustifyContent($align)};
9506
+ const ChipsContainer = styled(Flex) `
9507
+ flex-wrap: wrap;
9508
+ gap: 0.25rem;
9509
+ background: transparent;
9510
+ justify-content: ${({ $align }) => getJustifyContent($align)};
9515
9511
  `;
9516
9512
 
9517
- const FilterChip = styled.div `
9518
- display: inline-flex;
9519
- align-items: center;
9520
- gap: 0.25rem;
9521
- padding: 0.3125rem 0.5rem;
9522
- height: 1.5rem;
9523
- border-radius: 0.25rem;
9513
+ const FilterChip = styled.div `
9514
+ display: inline-flex;
9515
+ align-items: center;
9516
+ gap: 0.25rem;
9517
+ padding: 0.3125rem 0.5rem;
9518
+ height: 1.5rem;
9519
+ border-radius: 0.25rem;
9524
9520
  background-color: ${({ $isActive, $bgColor, theme }) => $bgColor
9525
9521
  ? $bgColor
9526
9522
  : $isActive
9527
9523
  ? theme.palette?.primary
9528
- : theme.palette?.elementLight};
9524
+ : theme.palette?.elementLight};
9529
9525
  color: ${({ $isActive, $textColor, theme }) => $textColor
9530
9526
  ? $textColor
9531
9527
  : $isActive
9532
9528
  ? theme.palette?.textContrast
9533
- : theme.palette?.textSecondary};
9534
- cursor: pointer;
9535
- font-size: 0.75rem;
9536
- line-height: 0.875rem;
9537
- white-space: nowrap;
9538
- flex-shrink: 0;
9539
- transition: all 0.2s ease-in-out;
9540
- margin: 0 0.25rem 0 0;
9541
- box-sizing: border-box;
9542
-
9543
- &:hover {
9529
+ : theme.palette?.textSecondary};
9530
+ cursor: pointer;
9531
+ font-size: 0.75rem;
9532
+ line-height: 0.875rem;
9533
+ white-space: nowrap;
9534
+ flex-shrink: 0;
9535
+ transition: all 0.2s ease-in-out;
9536
+ margin: 0 0.25rem 0 0;
9537
+ box-sizing: border-box;
9538
+
9539
+ &:hover {
9544
9540
  background-color: ${({ $isActive, $bgColor, theme }) => $isActive
9545
9541
  ? $bgColor || 'inherit'
9546
- : $bgColor || theme.palette?.elementDark};
9547
- }
9542
+ : $bgColor || theme.palette?.elementDark};
9543
+ }
9548
9544
  `;
9549
- const ChipIconWrapper = styled.span `
9550
- display: inline-flex;
9551
- align-items: center;
9552
- justify-content: center;
9553
- width: 0.875rem;
9554
- height: 0.875rem;
9555
- flex-shrink: 0;
9556
-
9557
- svg, img {
9558
- width: 100%;
9559
- height: 100%;
9560
- display: block;
9561
- }
9545
+ const ChipIconWrapper = styled.span `
9546
+ display: inline-flex;
9547
+ align-items: center;
9548
+ justify-content: center;
9549
+ width: 0.875rem;
9550
+ height: 0.875rem;
9551
+ flex-shrink: 0;
9552
+
9553
+ svg, img {
9554
+ width: 100%;
9555
+ height: 100%;
9556
+ display: block;
9557
+ }
9562
9558
  `;
9563
- const ChipText = styled.span `
9564
- overflow: hidden;
9565
- text-overflow: ellipsis;
9566
- white-space: nowrap;
9567
- ${({ $maxTextWidth }) => $maxTextWidth && `max-width: ${$maxTextWidth / 16}rem;`}
9559
+ const ChipText = styled.span `
9560
+ overflow: hidden;
9561
+ text-overflow: ellipsis;
9562
+ white-space: nowrap;
9563
+ ${({ $maxTextWidth }) => $maxTextWidth && `max-width: ${$maxTextWidth / 16}rem;`}
9568
9564
  `;
9569
9565
 
9570
9566
  const CustomChip = ({ text, icon, color, primary, secondary, error, disabled, isActive, maxTextWidth, fontColor: customFontColor, backgroundColor: customBackgroundColor, ...props }) => {
@@ -11003,8 +10999,8 @@ const Dashboard = memo(({ type = WidgetType.Dashboard, noBorders }) => {
11003
10999
  return (jsx(PagesContainer, { type: type, noBorders: noBorders }));
11004
11000
  });
11005
11001
 
11006
- const CardCheckbox = styled(Checkbox) `
11007
- padding-left: 0.5rem;
11002
+ const CardCheckbox = styled(Checkbox) `
11003
+ padding-left: 0.5rem;
11008
11004
  `;
11009
11005
 
11010
11006
  const DashboardCheckbox = ({ title, checked, onChange, }) => {
@@ -11078,15 +11074,15 @@ const FeatureCardTitle = ({ title, description }) => {
11078
11074
  return (jsxs(HeaderTitleContainer, { children: [jsx(FeatureTitleContainer, { children: jsx(FlexSpan, { children: resultTitle }) }), jsx(LayerDescription, { title: resultDescription, children: resultDescription })] }));
11079
11075
  };
11080
11076
 
11081
- const HiddenFilters = styled(Flex) `
11082
- flex-wrap: wrap;
11083
- margin-top: -1.25rem;
11084
-
11085
- ${DashboardChip$1} {
11086
- height: 1.5rem;
11087
- margin: 0 0.25rem 0.25rem 0;
11088
- padding: 0 0 0 0.5rem;
11089
- }
11077
+ const HiddenFilters = styled(Flex) `
11078
+ flex-wrap: wrap;
11079
+ margin-top: -1.25rem;
11080
+
11081
+ ${DashboardChip$1} {
11082
+ height: 1.5rem;
11083
+ margin: 0 0.25rem 0.25rem 0;
11084
+ padding: 0 0 0 0.5rem;
11085
+ }
11090
11086
  `;
11091
11087
 
11092
11088
  function spliceValue(filterValue, splicingValue) {
@@ -11272,24 +11268,24 @@ const LogTerminal = ({ log, terminalOptions, className, styles }) => {
11272
11268
  return jsx(TerminalWrapper, { ref: terminalRef, className: className, style: styles });
11273
11269
  };
11274
11270
 
11275
- const PageNavigator = styled(Flex) `
11276
- margin-right: -0.5rem;
11277
- align-items: center;
11278
-
11279
- button {
11280
- width: auto;
11281
- height: 2rem;
11282
- padding: 0 0.5rem;
11283
-
11284
- span[kind]:after {
11285
- color: ${({ theme: { palette } }) => palette.textDisabled};
11286
- transition: color ${transition.hover};
11287
- }
11288
-
11289
- :hover span[kind]:after {
11290
- color: ${({ theme: { palette } }) => palette.textSecondary};
11291
- }
11292
- }
11271
+ const PageNavigator = styled(Flex) `
11272
+ margin-right: -0.5rem;
11273
+ align-items: center;
11274
+
11275
+ button {
11276
+ width: auto;
11277
+ height: 2rem;
11278
+ padding: 0 0.5rem;
11279
+
11280
+ span[kind]:after {
11281
+ color: ${({ theme: { palette } }) => palette.textDisabled};
11282
+ transition: color ${transition.hover};
11283
+ }
11284
+
11285
+ :hover span[kind]:after {
11286
+ color: ${({ theme: { palette } }) => palette.textSecondary};
11287
+ }
11288
+ }
11293
11289
  `;
11294
11290
 
11295
11291
  const Pagination = memo(({ type = WidgetType.Dashboard }) => {
@@ -11298,34 +11294,34 @@ const Pagination = memo(({ type = WidgetType.Dashboard }) => {
11298
11294
  return (jsxs(PageNavigator, { children: [jsx(IconButton, { kind: "prev", onClick: () => prevPage(pages.length) }), jsx(IconButton, { kind: "next", onClick: () => nextPage(pages.length) })] }));
11299
11295
  });
11300
11296
 
11301
- const StyledSvgWidthMixin = css `
11302
- &&& {
11303
- svg {
11304
- width: ${({ $width }) => $width}px;
11305
- }
11306
- }
11297
+ const StyledSvgWidthMixin = css `
11298
+ &&& {
11299
+ svg {
11300
+ width: ${({ $width }) => $width}px;
11301
+ }
11302
+ }
11307
11303
  `;
11308
- const StyledSvgHeightMixin = css `
11309
- &&& {
11310
- svg {
11311
- height: ${({ $height }) => $height}px;
11312
- }
11313
- }
11304
+ const StyledSvgHeightMixin = css `
11305
+ &&& {
11306
+ svg {
11307
+ height: ${({ $height }) => $height}px;
11308
+ }
11309
+ }
11314
11310
  `;
11315
- const StyledSvgColorMixin = css `
11316
- svg {
11317
- path,
11318
- line,
11319
- circle {
11320
- fill: ${({ $fontColor }) => $fontColor} !important;
11321
- }
11322
- }
11311
+ const StyledSvgColorMixin = css `
11312
+ svg {
11313
+ path,
11314
+ line,
11315
+ circle {
11316
+ fill: ${({ $fontColor }) => $fontColor} !important;
11317
+ }
11318
+ }
11323
11319
  `;
11324
- const StyledSvg = styled(Flex) `
11325
- align-items: center;
11326
- ${({ $width }) => !!$width && StyledSvgWidthMixin};
11327
- ${({ $height }) => !!$height && StyledSvgHeightMixin};
11328
- ${({ $fontColor }) => !!$fontColor && StyledSvgColorMixin};
11320
+ const StyledSvg = styled(Flex) `
11321
+ align-items: center;
11322
+ ${({ $width }) => !!$width && StyledSvgWidthMixin};
11323
+ ${({ $height }) => !!$height && StyledSvgHeightMixin};
11324
+ ${({ $fontColor }) => !!$fontColor && StyledSvgColorMixin};
11329
11325
  `;
11330
11326
 
11331
11327
  const SvgImage = memo(({ url, width, height, fontColor }) => {
@@ -11466,7 +11462,7 @@ const VectorLayer = ({ layer, tileUrl, visible, beforeId, getLayerTempStyle, fil
11466
11462
  return null;
11467
11463
  }).filter((config) => config !== null);
11468
11464
  }, [clientStyle]);
11469
- const { loaded: iconsLoaded } = useMapImages({ images: iconConfigs });
11465
+ useMapImages({ images: iconConfigs });
11470
11466
  const renderLayerByGeometryType = useCallback(() => {
11471
11467
  const visibility = visible ? "visible" : "none";
11472
11468
  switch (geometryType) {
@@ -11579,10 +11575,6 @@ const VectorLayer = ({ layer, tileUrl, visible, beforeId, getLayerTempStyle, fil
11579
11575
  if (!layer) {
11580
11576
  return null;
11581
11577
  }
11582
- // Ждём загрузки иконок перед рендерингом слоя
11583
- if (iconConfigs.length > 0 && !iconsLoaded) {
11584
- return null;
11585
- }
11586
11578
  return (jsx(Source, { promoteId: idAttribute, id: layer.name, type: "vector", tiles: [tileUrl], children: clientStyle?.items ? renderClientStyle() : renderLayerByGeometryType() }, `${layer.name}-${filterVersion || "v0"}`));
11587
11579
  };
11588
11580
 
@@ -11597,33 +11589,33 @@ const Layer = ({ layer, layerType, visible, beforeId, tileUrl, getLayerTempStyle
11597
11589
  return (jsx(VectorLayer, { layer: layer, tileUrl: tileUrl, visible: visible, beforeId: beforeId, getLayerTempStyle: getLayerTempStyle, filterVersion: filterVersion }));
11598
11590
  };
11599
11591
 
11600
- const MapWrapper = styled.div `
11601
- position: relative;
11602
- width: 100%;
11603
- height: 100%;
11604
- box-sizing: border-box;
11605
- z-index: ${({ $zIndex }) => $zIndex ?? 1};
11606
-
11607
- .mapbox-gl-draw_trash {
11608
- display: none;
11609
- }
11610
-
11611
- .mapboxgl-ctrl-logo {
11612
- display: none;
11613
- }
11614
-
11615
- .mapboxgl-ctrl.mapboxgl-ctrl-attrib {
11616
- display: none;
11617
- }
11618
-
11619
- .mapboxgl-ctrl-geocoder.mapboxgl-ctrl {
11620
- width: 350px;
11621
- }
11592
+ const MapWrapper = styled.div `
11593
+ position: relative;
11594
+ width: 100%;
11595
+ height: 100%;
11596
+ box-sizing: border-box;
11597
+ z-index: ${({ $zIndex }) => $zIndex ?? 1};
11598
+
11599
+ .mapbox-gl-draw_trash {
11600
+ display: none;
11601
+ }
11602
+
11603
+ .mapboxgl-ctrl-logo {
11604
+ display: none;
11605
+ }
11606
+
11607
+ .mapboxgl-ctrl.mapboxgl-ctrl-attrib {
11608
+ display: none;
11609
+ }
11610
+
11611
+ .mapboxgl-ctrl-geocoder.mapboxgl-ctrl {
11612
+ width: 350px;
11613
+ }
11622
11614
  `;
11623
11615
 
11624
11616
  const Map$1 = ({ zIndex, lowerSiblings, upperSiblings, onError, children, ...rest }) => {
11625
11617
  const { map, setLoaded } = useMapContext();
11626
- return (jsxs(MapWrapper, { "$zIndex": zIndex, children: [lowerSiblings, jsx(MapGL, { ...rest, renderWorldCopies: true, antialias: true, doubleClickZoom: false, cursor: "default", onLoad: e => {
11618
+ return (jsxs(MapWrapper, { "$zIndex": zIndex, children: [lowerSiblings, jsx(MapGL, { ...rest, renderWorldCopies: true, doubleClickZoom: false, cursor: "default", onLoad: e => {
11627
11619
  map.current = e.target;
11628
11620
  map.current.on("error", onError);
11629
11621
  setLoaded(true);