@evergis/react 3.1.14 → 3.1.16

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.
Files changed (43) hide show
  1. package/dist/components/Dashboard/components/Chart/styled.d.ts +16 -0
  2. package/dist/components/Dashboard/components/DashboardHeader/index.d.ts +3 -0
  3. package/dist/components/Dashboard/components/FeatureCardButtons/index.d.ts +2 -0
  4. package/dist/components/Dashboard/components/FeatureCardHeader/index.d.ts +2 -0
  5. package/dist/components/Dashboard/components/FeatureCardTitle/index.d.ts +5 -0
  6. package/dist/components/Dashboard/components/Pagination/index.d.ts +1 -1
  7. package/dist/components/Dashboard/components/index.d.ts +4 -0
  8. package/dist/components/Dashboard/containers/RoundedBackgroundContainer/styled.d.ts +2 -0
  9. package/dist/components/Dashboard/headers/DashboardDefaultHeader/index.d.ts +3 -0
  10. package/dist/components/Dashboard/headers/DashboardDefaultHeader/styled.d.ts +8 -0
  11. package/dist/components/Dashboard/headers/FeatureCardDefaultHeader/components/HeaderTitle.d.ts +4 -0
  12. package/dist/components/Dashboard/headers/FeatureCardDefaultHeader/index.d.ts +5 -0
  13. package/dist/components/Dashboard/headers/FeatureCardDefaultHeader/styled.d.ts +12 -0
  14. package/dist/components/Dashboard/headers/FeatureCardGradientHeader/index.d.ts +3 -0
  15. package/dist/components/Dashboard/headers/FeatureCardGradientHeader/styled.d.ts +4 -0
  16. package/dist/components/Dashboard/headers/FeatureCardIconHeader/index.d.ts +3 -0
  17. package/dist/components/Dashboard/headers/FeatureCardIconHeader/styled.d.ts +6 -0
  18. package/dist/components/Dashboard/headers/FeatureCardSlideshowHeader/index.d.ts +3 -0
  19. package/dist/components/Dashboard/headers/FeatureCardSlideshowHeader/styled.d.ts +8 -0
  20. package/dist/components/Dashboard/headers/index.d.ts +7 -0
  21. package/dist/components/Dashboard/hooks/index.d.ts +1 -0
  22. package/dist/components/Dashboard/hooks/useDashboardHeader.d.ts +2 -2
  23. package/dist/components/Dashboard/hooks/useGlobalContext.d.ts +0 -1
  24. package/dist/components/Dashboard/hooks/useHeaderRender.d.ts +2 -0
  25. package/dist/components/Dashboard/hooks/useWidgetContext.d.ts +8 -0
  26. package/dist/components/Dashboard/index.d.ts +1 -0
  27. package/dist/components/Dashboard/styled.d.ts +1 -0
  28. package/dist/components/Dashboard/types.d.ts +2 -0
  29. package/dist/components/Dashboard/utils/getDashboardHeader.d.ts +2 -0
  30. package/dist/components/Dashboard/utils/getFeatureCardHeader.d.ts +2 -0
  31. package/dist/components/Dashboard/utils/index.d.ts +2 -0
  32. package/dist/components/LayerIcon/index.d.ts +5 -0
  33. package/dist/components/LayerIcon/styled.d.ts +2 -0
  34. package/dist/components/LayerTree/types.d.ts +0 -2
  35. package/dist/components/index.d.ts +1 -0
  36. package/dist/contexts/DashboardContext/types.d.ts +8 -2
  37. package/dist/contexts/FeatureCardContext/types.d.ts +3 -1
  38. package/dist/contexts/GlobalContext/types.d.ts +1 -3
  39. package/dist/index.js +1460 -701
  40. package/dist/index.js.map +1 -1
  41. package/dist/react.esm.js +1185 -451
  42. package/dist/react.esm.js.map +1 -1
  43. package/package.json +3 -3
package/dist/react.esm.js CHANGED
@@ -1,7 +1,7 @@
1
1
  import { jsx, jsxs, Fragment as Fragment$1 } from 'react/jsx-runtime';
2
- import { IconButton, Flex, transition, Chip, Icon, Description, FlexSpan, IconToggle, Popup, Menu, DraggableTree, shadows, Divider, LegendToggler, Tooltip, DropdownField, MultiSelectContainer, IconButtonButton, FlatButton, DraggableTreeContainer, LinearProgress, Preview, Blank, Popover, NumberRangeSlider, useAsyncAutocomplete, AutoComplete, Dropdown, Checkbox, CircularProgress, ThemeProvider, RangeNumberInput, dateFormat } from '@evergis/uilib-gl';
2
+ import { IconButton, Flex, transition, Chip, Icon, Description, FlexSpan, IconToggle, Popup, Menu, DraggableTree, shadows, Divider, LegendToggler, Tooltip as Tooltip$1, DropdownField, MultiSelectContainer, IconButtonButton, FlatButton, DraggableTreeContainer, LinearProgress, H2, ThemeProvider, defaultTheme, Preview, Blank, Popover, darkTheme, NumberRangeSlider, useAsyncAutocomplete, AutoComplete, Dropdown, Checkbox, CircularProgress, RangeNumberInput, dateFormat } from '@evergis/uilib-gl';
3
3
  import { createContext, memo, useRef, useState, useEffect, useCallback, useContext, useMemo, Fragment } from 'react';
4
- import styled, { css, useTheme } from 'styled-components';
4
+ import styled, { createGlobalStyle, css, useTheme } from 'styled-components';
5
5
  import { lineChartClassNames, barChartClassNames, BarChart as BarChart$1, LineChart, PieChart } from '@evergis/charts';
6
6
  import { AttributeType, GeometryType } from '@evergis/api';
7
7
  import Gradient from 'javascript-color-gradient';
@@ -35,14 +35,18 @@ const ChartTooltipTable = styled.table `
35
35
  }
36
36
  `;
37
37
  const ChartTooltip = styled(Flex) `
38
- flex-direction: row;
39
- align-items: center;
40
38
  flex-wrap: nowrap;
39
+ background: rgb(48, 69, 79);
40
+ border-radius: 0.25rem;
41
+ color: white;
41
42
 
42
43
  :not(:last-child) {
43
44
  margin-bottom: 0.25rem;
44
45
  }
45
46
  `;
47
+ const ChartTooltipLabel = styled.div `
48
+ margin-right: 0.25rem;
49
+ `;
46
50
  const ChartTooltipColor = styled.div `
47
51
  width: 0.625rem;
48
52
  height: 0.625rem;
@@ -88,6 +92,107 @@ const ChartWrapperContainer = styled.div `
88
92
  position: relative;
89
93
  width: 100%;
90
94
  `;
95
+ const Tooltip = styled.div `
96
+ position: relative;
97
+ border-radius: 0.25rem;
98
+ background-color: rgba(28, 33, 48);
99
+ padding: 0.5rem;
100
+ box-shadow: 0 0.125rem 0.25rem 0 rgba(0, 0, 0, 0.15);
101
+ font-size: 0.75rem;
102
+ transform: ${({ transform }) => transform};
103
+ color: white;
104
+
105
+ :before {
106
+ position: absolute;
107
+ display: block;
108
+ content: "";
109
+ width: 0;
110
+ height: 0;
111
+ }
112
+ `;
113
+ const LineChartTooltipStyles = createGlobalStyle `
114
+ .dashboardLineChartTooltip.${lineChartClassNames.lineChartMouseLabel} {
115
+ .${lineChartClassNames.lineChartLabelFlex} {
116
+ justify-content: center;
117
+ align-items: flex-end;
118
+
119
+ ${Tooltip} {
120
+ margin: 0 0 12px 0;
121
+
122
+ :before {
123
+ top: auto;
124
+ bottom: 0;
125
+ left: 50%;
126
+ transform: translate(-50%, 100%);
127
+ border-left: 4px solid transparent;
128
+ border-right: 4px solid transparent;
129
+ border-top: 4px solid rgba(28, 33, 48, 0.9);
130
+ }
131
+ }
132
+ }
133
+ }
134
+
135
+ .${lineChartClassNames.lineChartYScaleGlobal}, .${lineChartClassNames.lineChartXScaleGlobal} {
136
+ .domain {
137
+ visibility: hidden;
138
+ }
139
+
140
+ .tick {
141
+ text {
142
+ fill: ${({ theme: { palette } }) => palette.textDisabled};
143
+ }
144
+
145
+ line {
146
+ visibility: hidden;
147
+ }
148
+ }
149
+ }
150
+
151
+ .${lineChartClassNames.lineChartXScaleGlobal} {
152
+ .tick {
153
+ :first-of-type {
154
+ text {
155
+ text-anchor: start;
156
+ }
157
+ }
158
+
159
+ :last-of-type {
160
+ text {
161
+ text-anchor: end;
162
+ }
163
+ }
164
+ }
165
+ }
166
+
167
+ .${lineChartClassNames.lineChartLine} {
168
+ stroke-width: 2px;
169
+ }
170
+
171
+ .${lineChartClassNames.lineChartLabel} {
172
+ color: ${({ theme: { palette } }) => palette.textPrimary};
173
+ }
174
+
175
+ .${lineChartClassNames.lineChartMouseCircle} {
176
+ stroke: #ffffff;
177
+ stroke-width: 2px;
178
+ }
179
+
180
+ .${lineChartClassNames.lineChartGridLineX} {
181
+ stroke: ${({ theme: { palette } }) => palette.element};
182
+ }
183
+
184
+ text {
185
+ fill: ${({ theme: { palette } }) => palette.textDisabled};
186
+ }
187
+ `;
188
+ const BarChartStyles = createGlobalStyle `
189
+ .dashboardBarChart {
190
+ .domain,
191
+ line {
192
+ display: none;
193
+ }
194
+ }
195
+ `;
91
196
 
92
197
  function range(start, stop, step) {
93
198
  start = +start, stop = +stop, step = (n = arguments.length) < 2 ? (stop = start, start = 0, 1) : n < 3 ? 1 : +step;
@@ -3800,8 +3905,8 @@ const ServerNotificationsProvider = ({ url, initialized, children }) => {
3800
3905
  };
3801
3906
 
3802
3907
  const useWidgetContext = (type = WidgetType.Dashboard) => {
3803
- const { projectInfo, updateProject, layerInfos, geometryFilter, dashboardLayers, setDashboardLayer, pageIndex: projectPageIndex, selectedTabId: projectSelectedTabId, setSelectedTabId: setProjectSelectedTabId, dataSources: projectDataSources, loading: projectLoading, filters: projectFilters, changeFilters: projectChangeFilters, expandContainer: projectExpandContainer, expandedContainers: projectExpandedContainers, nextPage: projectNextPage, prevPage: projectPrevPage, changePage: projectChangePage, } = useContext(DashboardContext) || {};
3804
- const { layerInfo, attributes, pageIndex: featurePageIndex, selectedTabId: featureSelectedTabId, setSelectedTabId: setFeatureSelectedTabId, dataSources: featureDataSources, loading: featureLoading, filters: featureFilters, changeFilters: featureChangeFilters, expandContainer: featureExpandContainer, expandedContainers: featureExpandedContainers, nextPage: featureNextPage, prevPage: featurePrevPage, changePage: featureChangePage, } = useContext(FeatureCardContext) || {};
3908
+ const { projectInfo, updateProject, layerInfos, geometryFilter, dashboardLayers, setDashboardLayer, components: dashboardComponents, pageIndex: projectPageIndex, selectedTabId: projectSelectedTabId, setSelectedTabId: setProjectSelectedTabId, dataSources: projectDataSources, loading: projectLoading, filters: projectFilters, changeFilters: projectChangeFilters, expandContainer: projectExpandContainer, expandedContainers: projectExpandedContainers, nextPage: projectNextPage, prevPage: projectPrevPage, changePage: projectChangePage, } = useContext(DashboardContext) || {};
3909
+ const { layerInfo, attributes, feature, closeFeatureCard, pageIndex: featurePageIndex, selectedTabId: featureSelectedTabId, setSelectedTabId: setFeatureSelectedTabId, dataSources: featureDataSources, loading: featureLoading, filters: featureFilters, changeFilters: featureChangeFilters, expandContainer: featureExpandContainer, expandedContainers: featureExpandedContainers, nextPage: featureNextPage, prevPage: featurePrevPage, changePage: featureChangePage, } = useContext(FeatureCardContext) || {};
3805
3910
  return {
3806
3911
  projectInfo,
3807
3912
  layerInfos,
@@ -3811,6 +3916,9 @@ const useWidgetContext = (type = WidgetType.Dashboard) => {
3811
3916
  geometryFilter,
3812
3917
  layerInfo,
3813
3918
  attributes,
3919
+ feature,
3920
+ closeFeatureCard,
3921
+ components: dashboardComponents,
3814
3922
  isLoading: type === WidgetType.Dashboard ? projectLoading : featureLoading,
3815
3923
  pageIndex: type === WidgetType.Dashboard ? projectPageIndex : featurePageIndex,
3816
3924
  filters: type === WidgetType.Dashboard ? projectFilters : featureFilters,
@@ -3827,15 +3935,14 @@ const useWidgetContext = (type = WidgetType.Dashboard) => {
3827
3935
  };
3828
3936
 
3829
3937
  const useGlobalContext = () => {
3830
- const { t, language, themeName, api, ewktGeometry, LayerItemComponent } = useContext(GlobalContext) || {};
3938
+ const { t, language, themeName, api, ewktGeometry } = useContext(GlobalContext) || {};
3831
3939
  return useMemo(() => ({
3832
3940
  t,
3833
3941
  language,
3834
3942
  themeName,
3835
3943
  api,
3836
3944
  ewktGeometry,
3837
- LayerItemComponent,
3838
- }), [language, t, api, ewktGeometry, themeName, LayerItemComponent]);
3945
+ }), [language, t, api, ewktGeometry, themeName]);
3839
3946
  };
3840
3947
 
3841
3948
  const HEIGHT_OFFSET = 20;
@@ -4942,10 +5049,10 @@ const treeNodesToProjectItems = (currentProjectItems, treeNodes) => {
4942
5049
  return combineProjectItems(treeNodes);
4943
5050
  };
4944
5051
 
4945
- const LayerTree = ({ layers, LayerItemComponent, onlyMainTools }) => {
4946
- const { projectInfo, updateProject } = useWidgetContext();
5052
+ const LayerTree = ({ layers, onlyMainTools }) => {
5053
+ const { projectInfo, updateProject, components: { LayerItem } } = useWidgetContext();
4947
5054
  const { pageIndex } = useWidgetPage();
4948
- const nodes = useMemo(() => layers?.map(layer => createTreeNode(layer, LayerItemComponent, onlyMainTools)), [LayerItemComponent, layers, onlyMainTools]);
5055
+ const nodes = useMemo(() => layers?.map(layer => createTreeNode(layer, LayerItem, onlyMainTools)), [LayerItem, layers, onlyMainTools]);
4949
5056
  const onUpdate = useCallback((updatedNodes) => {
4950
5057
  const newProjectInfo = JSON.parse(JSON.stringify(projectInfo));
4951
5058
  const page = getPagesFromProjectInfo(newProjectInfo)?.[pageIndex - 1];
@@ -5227,6 +5334,18 @@ const AttributeLabel = styled(Description) `
5227
5334
  margin-bottom: ${({ forCheckbox }) => (forCheckbox ? "0.75rem" : "0.25rem")} !important;
5228
5335
  padding-left: ${({ isEdit }) => (isEdit ? "0.5rem" : "0")};
5229
5336
  `;
5337
+ const FeatureControls = styled(Flex) `
5338
+ align-items: center;
5339
+ gap: 1rem;
5340
+ flex-wrap: nowrap;
5341
+ position: relative;
5342
+ flex-shrink: 0;
5343
+
5344
+ button {
5345
+ padding: 0;
5346
+ width: auto;
5347
+ }
5348
+ `;
5230
5349
 
5231
5350
  const getAttributeByName = (attributeName, attributes) => {
5232
5351
  return Array.isArray(attributeName)
@@ -5604,7 +5723,7 @@ const ProgressContainer = memo(({ type, elementConfig, feature, maxValue, index,
5604
5723
  const color = useMemo(() => colorAttribute
5605
5724
  ? attributes?.find(({ name }) => name === colorAttribute)?.value
5606
5725
  : colors?.[index] || bgColor, [attributes, bgColor, colorAttribute, colors, index]);
5607
- return (jsx(Tooltip, { content: renderTooltip, placement: "top", arrow: true, children: ref => (jsxs(ProgressContainerWrapper, { ref: ref, style: innerTemplateStyle || style, children: [renderIcon && jsx(ProgressIcon, { children: renderIcon }), jsxs(ProgressContent, { children: [!hideTitle && (jsxs(ProgressAlias, { children: [jsx("div", { children: renderAlias }), jsxs(ProgressValue, { children: [renderValue, unitsElement && jsx(ProgressUnits, { children: renderElement({ id: "units" }) })] })] })), jsxs(ProgressBarContainer, { innerValue: innerValue, children: [jsx(ProgressBarWrapper, { children: jsx(ProgressBar, { "$width": width, "$color": color }) }), !!(hideTitle || innerValue) && jsx(ProgressInnerValue, { children: renderValue })] })] })] })) }));
5726
+ return (jsx(Tooltip$1, { content: renderTooltip, placement: "top", arrow: true, children: ref => (jsxs(ProgressContainerWrapper, { ref: ref, style: innerTemplateStyle || style, children: [renderIcon && jsx(ProgressIcon, { children: renderIcon }), jsxs(ProgressContent, { children: [!hideTitle && (jsxs(ProgressAlias, { children: [jsx("div", { children: renderAlias }), jsxs(ProgressValue, { children: [renderValue, unitsElement && jsx(ProgressUnits, { children: renderElement({ id: "units" }) })] })] })), jsxs(ProgressBarContainer, { innerValue: innerValue, children: [jsx(ProgressBarWrapper, { children: jsx(ProgressBar, { "$width": width, "$color": color }) }), !!(hideTitle || innerValue) && jsx(ProgressInnerValue, { children: renderValue })] })] })] })) }));
5608
5727
  });
5609
5728
 
5610
5729
  const RANGE_MIN_VALUE = 0;
@@ -5700,7 +5819,6 @@ const AnyChartWrapper = styled.div `
5700
5819
  `;
5701
5820
  const BarChartWrapper = styled(AnyChartWrapper) `
5702
5821
  width: 100%;
5703
- max-width: ${MAX_CHART_WIDTH}px;
5704
5822
  margin: 0 auto ${BAR_CHART_FOOTER_MARGIN}px;
5705
5823
 
5706
5824
  :hover {
@@ -5830,7 +5948,7 @@ const PagesContainer = memo(({ type }) => {
5830
5948
  const { pageIndex, currentPage } = useWidgetPage(type);
5831
5949
  const { selectedTabId, setSelectedTabId, expandedContainers, attributes } = useWidgetContext(type);
5832
5950
  const { options } = config || {};
5833
- const { column } = options || {};
5951
+ const { column, width } = options || {};
5834
5952
  const isColumn = column === undefined || column;
5835
5953
  const filteredChildren = useMemo(() => !selectedTabId
5836
5954
  ? currentPage.children
@@ -5855,14 +5973,14 @@ const PagesContainer = memo(({ type }) => {
5855
5973
  setSelectedTabId,
5856
5974
  type,
5857
5975
  ]);
5858
- return (jsxs(Fragment$1, { children: [jsx(ExpandableTitle, { elementConfig: config, type: type, renderElement: renderElement }), jsx(Container, { isColumn: isColumn, isMain: true, children: jsx(ContainerChildren, { items: filteredChildren, isMain: true, renderElement: renderElement }) })] }));
5976
+ return (jsxs("div", { style: { width }, children: [jsx(ExpandableTitle, { elementConfig: config, type: type, renderElement: renderElement }), jsx(Container, { isColumn: isColumn, isMain: true, children: jsx(ContainerChildren, { items: filteredChildren, isMain: true, renderElement: renderElement }) })] }));
5859
5977
  });
5860
5978
 
5861
5979
  const TwoColumnsInnerContainer = memo(({ renderElement }) => {
5862
5980
  return (jsxs(Fragment$1, { children: [jsxs(TwoColumnContainerWrapper, { children: [jsxs(Container, { children: [jsx(ContainerAlias, { children: renderElement({ id: "firstAlias" }) }), jsx(ContainerValue, { big: true, children: renderElement({ id: "firstValue" }) })] }), jsxs(Container, { children: [jsx(ContainerAlias, { children: renderElement({ id: "secondAlias" }) }), jsx(ContainerValue, { big: true, children: renderElement({ id: "secondValue" }) })] })] }), renderElement({ id: "thirdContainer" })] }));
5863
5981
  });
5864
5982
 
5865
- const ImageContainerBg = styled.div `
5983
+ const ImageContainerBg$1 = styled.div `
5866
5984
  position: absolute;
5867
5985
  top: 0;
5868
5986
  bottom: 0;
@@ -5924,7 +6042,7 @@ const ImageContainerWrapper = styled(Flex) `
5924
6042
 
5925
6043
  const ImageContainer = memo(({ elementConfig, renderElement }) => {
5926
6044
  const { style } = elementConfig || {};
5927
- return (jsxs(ImageContainerWrapper, { style: style, children: [jsx(ImageContainerTitle, { children: renderElement({ id: "alias" }) }), jsx(ImageContainerText, { children: renderElement({ id: "text" }) }), renderElement({ id: "button" }), jsx(ImageContainerBg, { children: renderElement({ id: "image" }) })] }));
6045
+ return (jsxs(ImageContainerWrapper, { 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" }) })] }));
5928
6046
  });
5929
6047
 
5930
6048
  const IconContainerWrapper = styled(Flex) `
@@ -6254,6 +6372,7 @@ const TabsContainer = memo(({ elementConfig, type }) => {
6254
6372
  return (jsx(SwiperContainer, { style: style, children: jsx(Swiper, { spaceBetween: 0, slidesPerView: shownItems || 2, children: tabs.map(({ id, value, options: tabOptions }) => (jsxs(SwiperSlide, { children: [jsxs(TabContainer, { href: `#${id}`, active: selectedTabId === id, column: column, bgColor: bgColor, noBg: noBg, radius: radius, onlyIcon: onlyIcon, hasIcon: !!tabOptions?.icon, onClick: () => onClick(id), children: [renderIcon(tabOptions?.icon, selectedTabId === id), !onlyIcon && (jsx(TabValue, { children: jsx(TextTrim, { maxLength: maxLength, children: value }) }))] }), jsx(TabAnchor, { id: id })] }, id))) }) }));
6255
6373
  });
6256
6374
 
6375
+ const ContainerIconValue = styled(Flex) ``;
6257
6376
  const RoundedBackgroundContainerWrapper = styled(Flex) `
6258
6377
  position: relative;
6259
6378
  flex-direction: ${({ $bigIcon }) => ($bigIcon ? "row" : "column")};
@@ -6271,13 +6390,10 @@ const RoundedBackgroundContainerWrapper = styled(Flex) `
6271
6390
  css `
6272
6391
  align-items: center;
6273
6392
 
6274
- * {
6393
+ > * {
6275
6394
  display: flex;
6276
6395
  justify-content: center;
6277
6396
  text-align: center;
6278
- }
6279
-
6280
- > * {
6281
6397
  width: 100%;
6282
6398
  }
6283
6399
  `};
@@ -6310,8 +6426,32 @@ const RoundedBackgroundContainerWrapper = styled(Flex) `
6310
6426
  }
6311
6427
  `};
6312
6428
 
6429
+ ${ContainerIconValue} {
6430
+ align-items: center;
6431
+ flex-direction: column;
6432
+
6433
+ ${({ $big }) => $big &&
6434
+ css `
6435
+ flex-direction: row;
6436
+ margin-bottom: 0.5rem;
6437
+
6438
+ > * {
6439
+ text-align: left;
6440
+ }
6441
+
6442
+ span[kind] {
6443
+ margin-right: 0.5rem;
6444
+ }
6445
+
6446
+ ${ContainerValue} {
6447
+ width: auto;
6448
+ }
6449
+ `};
6450
+ }
6451
+
6313
6452
  ${ContainerValue} {
6314
6453
  flex-direction: ${({ $inlineUnits }) => ($inlineUnits ? "row" : "column")};
6454
+ justify-content: ${({ $big }) => ($big ? "flex-start" : "flex-end")};
6315
6455
  align-items: ${({ $inlineUnits }) => ($inlineUnits ? "center" : "flex-start")};
6316
6456
  line-height: 1;
6317
6457
  }
@@ -6335,15 +6475,17 @@ const RoundedBackgroundContainer = memo(({ type, elementConfig, feature, renderE
6335
6475
  feature
6336
6476
  });
6337
6477
  const { options, style, children } = elementConfig || {};
6338
- const { maxLength, center, fontColor, innerTemplateStyle, inlineUnits, bigIcon, hideEmpty, colorAttribute } = options || {};
6478
+ const { maxLength, center, fontColor, innerTemplateStyle, inlineUnits, big, bigIcon, hideEmpty, colorAttribute } = options || {};
6339
6479
  const aliasElement = children?.find(({ id }) => id === "alias");
6340
6480
  const unitsElement = children?.find(({ id }) => id === "units");
6341
6481
  const valueElement = children?.find(({ id }) => id === "value");
6342
6482
  const value = renderElement({ id: "value" });
6343
6483
  const color = useMemo(() => attributes?.find(({ name }) => name === colorAttribute)?.value || fontColor, [attributes, colorAttribute, fontColor]);
6484
+ const renderAlias = useMemo(() => (jsx(ContainerAlias, { style: aliasElement?.style, children: jsx(TextTrim, { maxLength: maxLength || ALIAS_DEFAULT_MAX_LENGTH, children: renderElement({ id: "alias", wrap: false }) }) })), [aliasElement?.style, maxLength, renderElement]);
6485
+ const renderValue = useMemo(() => (jsxs(ContainerValue, { style: valueElement?.style, big: true, children: [value, !!unitsElement && (jsx(ContainerUnits, { style: unitsElement?.style, children: renderElement({ id: "units" }) }))] })), [valueElement?.style, value, unitsElement, renderElement]);
6344
6486
  if (!value && hideEmpty)
6345
6487
  return null;
6346
- return (jsxs(RoundedBackgroundContainerWrapper, { style: innerTemplateStyle || style, "$center": center, "$color": color, "$inlineUnits": inlineUnits, "$bigIcon": bigIcon, children: [renderElement({ id: "icon", wrap: false }), jsxs(ContainerValue, { style: valueElement?.style, big: true, children: [value, !!unitsElement && (jsx(ContainerUnits, { style: unitsElement?.style, children: renderElement({ id: "units" }) }))] }), jsx(ContainerAlias, { style: aliasElement?.style, children: jsx(TextTrim, { maxLength: maxLength || ALIAS_DEFAULT_MAX_LENGTH, children: renderElement({ id: "alias", wrap: false }) }) })] }));
6488
+ return (jsxs(RoundedBackgroundContainerWrapper, { style: innerTemplateStyle || style, "$center": center, "$color": color, "$inlineUnits": inlineUnits, "$big": big, "$bigIcon": bigIcon, children: [jsxs(ContainerIconValue, { children: [renderElement({ id: "icon", wrap: false }), big ? renderAlias : renderValue] }), big ? renderValue : renderAlias] }));
6347
6489
  });
6348
6490
 
6349
6491
  const AddFeatureContainer = memo(({ elementConfig }) => {
@@ -6370,7 +6512,6 @@ const LayersContainerWrapper = styled(Container) `
6370
6512
  `;
6371
6513
 
6372
6514
  const LayersContainer = memo(({ type, elementConfig, renderElement }) => {
6373
- const { LayerItemComponent } = useGlobalContext();
6374
6515
  const { expandedContainers } = useWidgetContext(type);
6375
6516
  const { currentPage } = useWidgetPage(type);
6376
6517
  const { id, options, style } = elementConfig || {};
@@ -6383,7 +6524,7 @@ const LayersContainer = memo(({ type, elementConfig, renderElement }) => {
6383
6524
  return currentPage.layers;
6384
6525
  return currentPage.layers.filter(({ name }) => layerNames.includes(name));
6385
6526
  }, [currentPage?.layers, layerNames]);
6386
- return (jsxs(Fragment$1, { children: [jsx(ExpandableTitle, { elementConfig: elementConfig, type: type, renderElement: renderElement }), isVisible && (jsx(LayersContainerWrapper, { style: style, children: jsx(LayerTree, { layers: layers, LayerItemComponent: LayerItemComponent, onlyMainTools: true }) }))] }));
6527
+ return (jsxs(Fragment$1, { children: [jsx(ExpandableTitle, { elementConfig: elementConfig, type: type, renderElement: renderElement }), isVisible && (jsx(LayersContainerWrapper, { style: style, children: jsx(LayerTree, { layers: layers, onlyMainTools: true }) }))] }));
6387
6528
  });
6388
6529
 
6389
6530
  const containerComponents = {
@@ -6412,157 +6553,480 @@ const containerComponents = {
6412
6553
 
6413
6554
  const getContainerComponent = (innerTemplateName) => innerTemplateName ? containerComponents[innerTemplateName] || containerComponents.default : null;
6414
6555
 
6415
- const getDataFromAttributes = (t, config, attributes) => {
6416
- const colors = config?.options?.colors || FEATURE_CARD_DEFAULT_COLORS;
6417
- const data = config?.children?.map(({ attributeName }, index) => {
6418
- const attribute = attributes?.find(({ name }) => name === attributeName);
6419
- return {
6420
- name: attribute?.name || "",
6421
- value: attribute ? Number(attribute.value) : 0,
6422
- color: colors[index] || FEATURE_CARD_OTHER_COLOR
6423
- };
6424
- });
6425
- if (config?.options?.orderByValue) {
6426
- data.sort((a, b) => b.value - a.value);
6427
- }
6428
- const isOtherSliced = config?.options?.otherItems && config.options.otherItems < data.length;
6429
- if (!isOtherSliced)
6430
- return data;
6431
- const otherValue = data
6432
- .slice(0, config?.options?.otherItems)
6433
- .reduce((prev, { value }) => prev + value, 0);
6434
- return [
6435
- ...data?.slice(0, config.options?.otherItems),
6436
- {
6437
- name: t("other", { ns: "dashboard" }),
6438
- color: FEATURE_CARD_OTHER_COLOR,
6439
- value: Number(otherValue)
6440
- }
6441
- ];
6442
- };
6443
-
6444
- const getDataFromRelatedFeatures = ({ t, config, filters, relatedConfig, dataSource, layerInfo }) => {
6445
- if (!dataSource || !dataSource?.features?.length) {
6446
- return [];
6447
- }
6448
- const { colors } = config.options;
6449
- const layerDefinition = getLayerDefinition(layerInfo);
6450
- let data = JSON.parse(JSON.stringify(dataSource?.features));
6451
- const sortAttribute = config?.options?.orderByValue
6452
- ? relatedConfig.attributeName
6453
- : config?.options?.orderByTitle
6454
- ? relatedConfig.attributeTitle
6455
- : null;
6456
- if (sortAttribute) {
6457
- data.sort((a, b) => b.attributes[sortAttribute] - a.attributes[sortAttribute]);
6458
- }
6459
- const isOtherSliced = config?.options?.otherItems && config.options.otherItems < data.length;
6460
- const otherValue = isOtherSliced
6461
- ? data
6462
- .slice(config.options.otherItems)
6463
- .reduce((prev, { attributes }) => prev + attributes[relatedConfig.attributeName], 0)
6464
- : null;
6465
- if (isOtherSliced) {
6466
- data = data.slice(0, config?.options?.otherItems);
6467
- }
6468
- const gradientArray = relatedConfig.chartAxis && colors?.length < data.length
6469
- ? new Gradient()
6470
- .setColorGradient(colors[0], colors[colors.length - 1])
6471
- .setMidpoint(data.length)
6472
- .getColors()
6473
- : colors;
6474
- const filter = getConfigFilter(relatedConfig?.filterName, filters);
6475
- const result = data.reduce((acc, feature, index) => {
6476
- if (relatedConfig?.filterName && !filter) {
6477
- return acc;
6478
- }
6479
- const attributeName = feature.attributes[relatedConfig.attributeName];
6480
- const attributeTitle = feature.attributes[relatedConfig.attributeTitle];
6481
- const attributeColor = feature.attributes[relatedConfig.attributeColor];
6482
- return [
6483
- ...acc,
6484
- {
6485
- name: formatAttributeValue({
6486
- t,
6487
- type: layerDefinition.attributes[relatedConfig.attributeTitle]?.type,
6488
- value: attributeTitle,
6489
- stringFormat: layerDefinition.attributes[relatedConfig.attributeTitle]?.stringFormat
6490
- }),
6491
- value: attributeName === null ? null : Number(attributeName),
6492
- color: attributeColor || gradientArray?.[index] || FEATURE_CARD_OTHER_COLOR,
6493
- min: filter?.attributeMin ? feature.attributes[filter.attributeMin] : null,
6494
- max: filter?.attributeMin ? feature.attributes[filter.attributeMax] : null
6495
- }
6496
- ];
6497
- }, []);
6498
- if (isOtherSliced) {
6499
- result.push({
6500
- name: t("other", { ns: "dashboard" }),
6501
- color: FEATURE_CARD_OTHER_COLOR,
6502
- value: Number(otherValue)
6503
- });
6504
- }
6505
- return result;
6506
- };
6507
-
6508
- const getDefaultConfig = ({ title, defaultTitle, items, baseMapName, position, resolution, srid, }) => {
6509
- const dashboardConfiguration = JSON.parse(JSON.stringify(DEFAULT_DASHBOARD_CONFIG));
6510
- const defaultPages = JSON.parse(JSON.stringify(DEFAULT_PAGES_CONFIG));
6511
- const defaultPage = createConfigPage({ title, baseMapName, position, resolution, defaultTitle });
6512
- if (items?.length) {
6513
- const contentItems = items.map(item => createConfigLayer(item.name));
6514
- defaultPage.layers.push(...contentItems);
6515
- }
6516
- defaultPages.children.push(defaultPage);
6517
- dashboardConfiguration.children.push(defaultPages);
6518
- return dashboardConfiguration;
6519
- };
6520
-
6521
- const ElementImage = memo(({ type, elementConfig }) => {
6522
- const { attributes } = useWidgetContext(type);
6523
- const { value, attributeName, options } = elementConfig || {};
6524
- const { width } = options || {};
6525
- const firstImage = useMemo(() => {
6526
- if (value) {
6527
- return value.toString();
6528
- }
6529
- if (!attributeName || Array.isArray(attributeName)) {
6530
- return null;
6531
- }
6532
- const attribute = attributes?.find(item => item.name === attributeName);
6533
- return attribute?.value?.split(";")?.[0];
6534
- }, [attributeName, attributes, value]);
6535
- return firstImage ? jsx("img", { src: firstImage, alt: firstImage, width: width }) : null;
6536
- });
6537
-
6538
- const SmallPreviewContainer$1 = styled.div `
6539
- width: 100%;
6540
- height: 100%;
6541
- `;
6556
+ var img$3 = "";
6542
6557
 
6543
- const AttributeGalleryContainer = styled.div `
6544
- && {
6545
- width: calc(100% + 3rem);
6546
- }
6558
+ const getMaskColor = (isDark) => (isDark ? "0, 0, 0" : "255, 255, 255");
6559
+ const DefaultHeaderContainer = styled(Flex) `
6560
+ flex-direction: column;
6561
+ position: relative;
6562
+ flex-shrink: 0;
6563
+ min-height: 8.375rem;
6564
+ margin-bottom: -1.5rem;
6565
+ padding: 1.5rem 1.5rem 0;
6566
+ border-top-left-radius: 0.5rem;
6567
+ border-top-right-radius: 0.5rem;
6568
+ overflow: hidden;
6547
6569
 
6548
- min-height: 12.625rem;
6549
- background-color: ${({ theme: { palette } }) => palette.element};
6570
+ > * {
6571
+ z-index: 1;
6572
+ }
6550
6573
 
6551
- img {
6574
+ &::before {
6575
+ content: "";
6576
+ position: absolute;
6577
+ top: 0;
6578
+ left: 0;
6552
6579
  width: 100%;
6580
+ height: 100%;
6581
+
6582
+ ${({ image, isDark }) => image
6583
+ ? css `
6584
+ background: url(${image}) 0 0 no-repeat;
6585
+ background-size: cover;
6586
+ `
6587
+ : css `
6588
+ background: url(${img$3}) 50% 0 no-repeat;
6589
+ opacity: ${isDark ? 1 : 0.5};
6590
+ `}
6553
6591
  }
6554
- `;
6555
- const LinearProgressContainer = styled(Flex) `
6556
- align-items: center;
6557
- justify-content: center;
6558
- min-height: inherit;
6559
6592
 
6593
+ ${({ image, isDark }) => image &&
6594
+ css `
6595
+ &::before {
6596
+ -webkit-mask-image: linear-gradient(
6597
+ to bottom,
6598
+ rgba(${getMaskColor(isDark)}, 1),
6599
+ rgba(${getMaskColor(isDark)}, 0)
6600
+ );
6601
+ mask-image: linear-gradient(to bottom, rgba(${getMaskColor(isDark)}, 1), rgba(${getMaskColor(isDark)}, 0));
6602
+ }
6603
+ `}
6560
6604
  ${LinearProgress} {
6561
- max-width: 4rem;
6605
+ position: absolute;
6606
+ top: 0;
6607
+ left: 0;
6562
6608
  }
6563
6609
  `;
6564
- const NoLiveSnapshotContainer = styled(Flex) `
6565
- flex-direction: column;
6610
+ const TopContainer = styled(Flex) `
6611
+ z-index: 1;
6612
+ position: relative;
6613
+ justify-content: space-between;
6614
+ flex-wrap: nowrap;
6615
+ width: 100%;
6616
+ align-items: flex-start;
6617
+ `;
6618
+ const TopContainerButtons = styled(Flex) `
6619
+ align-items: center;
6620
+ width: auto;
6621
+ margin-right: -0.5rem;
6622
+
6623
+ button {
6624
+ width: auto;
6625
+ height: 1rem;
6626
+ padding: 0 0.5rem;
6627
+ }
6628
+ `;
6629
+ const LogoContainer = styled(Flex) `
6630
+ max-width: calc(100% - 1.4rem);
6631
+ flex-grow: 1;
6632
+ font-size: 0;
6633
+
6634
+ & > span::after {
6635
+ font-size: 2rem;
6636
+ }
6637
+
6638
+ img {
6639
+ max-height: 1.875rem;
6640
+ }
6641
+ `;
6642
+ const PageTitle = styled(H2) `
6643
+ display: -webkit-box;
6644
+ -webkit-line-clamp: 3;
6645
+ -webkit-box-orient: vertical;
6646
+ overflow: hidden;
6647
+ margin: 0;
6648
+ font-size: 1.25rem;
6649
+ font-weight: 600;
6650
+ pointer-events: initial;
6651
+ font-family: "Nunito Sans", serif;
6652
+ `;
6653
+
6654
+ var ThemeName;
6655
+ (function (ThemeName) {
6656
+ ThemeName["Light"] = "light";
6657
+ ThemeName["Dark"] = "dark";
6658
+ })(ThemeName || (ThemeName = {}));
6659
+
6660
+ var TmsType;
6661
+ (function (TmsType) {
6662
+ TmsType["WMS"] = "WMS";
6663
+ TmsType["TMS"] = "TMS";
6664
+ TmsType["ArcGIS"] = "ArcGIS";
6665
+ })(TmsType || (TmsType = {}));
6666
+ var EditGeometryType;
6667
+ (function (EditGeometryType) {
6668
+ EditGeometryType["Raster"] = "raster";
6669
+ })(EditGeometryType || (EditGeometryType = {}));
6670
+
6671
+ const DashboardDefaultHeader = memo(() => {
6672
+ const { components: { ProjectCatalogMenu, ProjectPanelMenu, ProjectPagesMenu }, } = useWidgetContext();
6673
+ const { pageId, image, icon, tooltip, themeName } = useDashboardHeader();
6674
+ return (jsxs(DefaultHeaderContainer, { image: 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 }), jsxs(TopContainerButtons, { children: [jsx(ProjectCatalogMenu, {}), jsx(ProjectPanelMenu, {})] })] }) }), jsx(FlexSpan, { children: jsx(Flex, { column: true, gap: "0.25rem", children: jsx(FlexSpan, { children: jsxs(Flex, { alignItems: "center", children: [jsx(FlexSpan, { flexGrow: 1, children: jsx(Tooltip$1, { arrow: true, content: tooltip, children: ref => (jsx(PageTitle, { ref: ref, children: jsx(ProjectPagesMenu, {}) })) }) }), jsx(FlexSpan, { children: jsx(Pagination, {}) })] }) }) }) })] })] }));
6675
+ });
6676
+
6677
+ const HeaderFrontView = styled(Flex) `
6678
+ z-index: 10;
6679
+ position: relative;
6680
+ justify-content: space-between;
6681
+ align-items: ${({ isDefault }) => (isDefault ? "center" : "flex-start")};
6682
+ width: 100%;
6683
+ font: ${({ theme: { fonts } }) => fonts.subtitle};
6684
+ `;
6685
+ const HeaderContainer = styled(FlexSpan) `
6686
+ display: flex;
6687
+ flex-grow: 1;
6688
+ flex-wrap: nowrap;
6689
+ width: calc(100% - 48px);
6690
+ `;
6691
+ const FeatureTitleContainer = styled.div `
6692
+ display: -webkit-box;
6693
+ max-width: 100%;
6694
+ width: 100%;
6695
+ margin: 0.5rem 0;
6696
+ -webkit-line-clamp: 2;
6697
+ -webkit-box-orient: vertical;
6698
+ overflow: hidden;
6699
+ text-overflow: ellipsis;
6700
+ color: ${({ theme: { palette } }) => palette.textPrimary};
6701
+
6702
+ & > ${FlexSpan} {
6703
+ cursor: ${({ clickable }) => clickable && "pointer"};
6704
+
6705
+ &:hover {
6706
+ color: ${({ clickable, theme: { palette } }) => clickable && palette.primary};
6707
+ }
6708
+ }
6709
+ `;
6710
+ const LayerDescription = styled(Description) `
6711
+ width: calc(100% - 4rem);
6712
+ display: -webkit-box;
6713
+ -webkit-line-clamp: 2;
6714
+ -webkit-box-orient: vertical;
6715
+ overflow: hidden;
6716
+ text-overflow: ellipsis;
6717
+ `;
6718
+ const HeaderTitleContainer = styled(Flex) `
6719
+ flex-direction: column;
6720
+ width: 100%;
6721
+ `;
6722
+ const RowHeaderMixin = css `
6723
+ &&& {
6724
+ min-height: auto;
6725
+
6726
+ ${FeatureTitleContainer}, ${LayerDescription} {
6727
+ text-align: left;
6728
+ }
6729
+ }
6730
+
6731
+ ${HeaderContainer} {
6732
+ flex-direction: row;
6733
+ }
6734
+
6735
+ ${FeatureTitleContainer} {
6736
+ max-width: calc(100% - 3.8rem);
6737
+ }
6738
+ `;
6739
+ const Header = styled(Flex) `
6740
+ z-index: 1;
6741
+ position: relative;
6742
+ top: 0;
6743
+ flex-shrink: 0;
6744
+ overflow: hidden;
6745
+ padding: 0.5rem;
6746
+
6747
+ ${HeaderContainer} {
6748
+ flex-direction: column;
6749
+ }
6750
+
6751
+ ${({ $isRow }) => $isRow && RowHeaderMixin};
6752
+ `;
6753
+
6754
+ const HeaderTitle = ({ noFeature }) => {
6755
+ const { t } = useGlobalContext();
6756
+ const { attributes, layerInfo, feature } = useWidgetContext(WidgetType.FeatureCard);
6757
+ const zoomToFeatures = useZoomToFeatures();
6758
+ const { alias, name, layerDefinition } = layerInfo || {};
6759
+ const resultDescription = alias || name || "";
6760
+ const resultTitle = useMemo(() => {
6761
+ const layerDefinitionAttribute = layerDefinition && attributes?.length
6762
+ ? attributes.find(item => item.name === layerDefinition.titleAttribute)
6763
+ : null;
6764
+ const layerDefinitionTitle = layerDefinition?.titleAttribute && layerDefinitionAttribute?.value
6765
+ ? layerDefinitionAttribute.value
6766
+ : null;
6767
+ return ((!!layerDefinitionTitle &&
6768
+ formatAttributeValue({
6769
+ t,
6770
+ type: layerDefinitionAttribute.type,
6771
+ value: layerDefinitionTitle,
6772
+ stringFormat: layerDefinitionAttribute.stringFormat,
6773
+ })) ||
6774
+ feature?.id);
6775
+ }, [attributes, feature, layerDefinition]);
6776
+ return (jsxs(HeaderTitleContainer, { children: [noFeature ? (jsx(FeatureTitleContainer, { children: t("noObjectFound", { ns: "dashboard" }) })) : (jsx(FeatureTitleContainer, { clickable: true, children: jsx(Tooltip$1, { arrow: true, placement: "top", content: t("zoomToFeature", { ns: "dashboard" }), delay: [600, 0], children: ref => (jsx(FlexSpan, { ref: ref, onClick: () => zoomToFeatures([feature]), children: resultTitle })) }) })), jsx(LayerDescription, { title: resultDescription, children: resultDescription })] }));
6777
+ };
6778
+
6779
+ const LayerIconContainer = styled.div `
6780
+ display: flex;
6781
+ align-items: center;
6782
+ margin-right: 0.75rem;
6783
+ `;
6784
+ const AlertIconContainer = styled(Flex) `
6785
+ align-items: center;
6786
+ justify-content: center;
6787
+ width: 2rem;
6788
+ height: 2rem;
6789
+
6790
+ ${Icon} {
6791
+ :after {
6792
+ color: ${({ theme: { palette } }) => palette.error};
6793
+ }
6794
+ }
6795
+ `;
6796
+
6797
+ 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";
6798
+
6799
+ var img$1 = "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='M4 17.9574H10.1538L13.5385 12L18.4615 20L22 13.8723H28' stroke='url(%23paint0_linear_6459_10369)' stroke-width='2' stroke-linejoin='round'/%3e %3cdefs%3e %3clinearGradient id='paint0_linear_6459_10369' x1='4' y1='9.54167' x2='28.7229' y2='20.1484' gradientUnits='userSpaceOnUse'%3e %3cstop offset='0.525942' stop-color='%2306AAFF'/%3e %3cstop offset='0.526042' stop-color='%230184D7'/%3e %3c/linearGradient%3e %3c/defs%3e%3c/svg%3e";
6800
+
6801
+ var img = "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 %3crect x='8' y='8' width='16' height='16' rx='2' fill='url(%23paint0_linear_6459_10399)'/%3e %3cdefs%3e %3clinearGradient id='paint0_linear_6459_10399' x1='8' y1='8' x2='24' y2='24' 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";
6802
+
6803
+ const LayerIcon = ({ layerInfo }) => {
6804
+ const renderSymbol = useMemo(() => {
6805
+ if (!layerInfo.geometryType) {
6806
+ return (jsx(AlertIconContainer, { children: jsx(Icon, { kind: "warning" }) }));
6807
+ }
6808
+ switch (layerInfo.geometryType) {
6809
+ case GeometryType.Polyline:
6810
+ return jsx("img", { src: img$1, alt: "" });
6811
+ case GeometryType.Polygon:
6812
+ return jsx("img", { src: img, alt: "" });
6813
+ case GeometryType.Point:
6814
+ default:
6815
+ return jsx("img", { src: img$2, alt: "" });
6816
+ }
6817
+ }, [layerInfo.geometryType]);
6818
+ return jsx(LayerIconContainer, { children: renderSymbol });
6819
+ };
6820
+
6821
+ const FeatureCardDefaultHeader = ({ noFeature }) => {
6822
+ const { layerInfo } = useWidgetContext(WidgetType.FeatureCard);
6823
+ return (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, {})] }) }));
6824
+ };
6825
+
6826
+ const HeaderFontColorMixin$1 = css `
6827
+ ${HeaderTitleContainer}, ${LayerDescription} {
6828
+ color: ${({ $fontColor }) => $fontColor};
6829
+ }
6830
+ `;
6831
+ const HeaderWrapperMixin$1 = css `
6832
+ padding: 0.5rem 0.5rem 0;
6833
+
6834
+ ${Header} {
6835
+ min-height: 5.25rem;
6836
+ }
6837
+
6838
+ ${HeaderContainer} {
6839
+ max-width: 100%;
6840
+ width: 100%;
6841
+ }
6842
+
6843
+ ${FeatureControls} {
6844
+ max-width: calc(100% - 2rem);
6845
+ width: calc(100% - 2rem);
6846
+ margin-top: -0.5rem;
6847
+ padding-top: 1rem;
6848
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
6849
+ }
6850
+
6851
+ ${({ $fontColor }) => !!$fontColor && HeaderFontColorMixin$1};
6852
+ `;
6853
+ const GradientHeaderWrapper = styled.div `
6854
+ ${Header} {
6855
+ background: ${({ $bgColor }) => $bgColor || "radial-gradient(129.21% 133.22% at 51.94% 0%, #e8fffe 9.48%, #5fcaff 100%)"};
6856
+ }
6857
+
6858
+ ${HeaderContainer} {
6859
+ align-items: center;
6860
+ }
6861
+
6862
+ ${HeaderTitleContainer} {
6863
+ margin-left: 0;
6864
+ text-align: center;
6865
+ }
6866
+
6867
+ ${FeatureTitleContainer} {
6868
+ text-align: center;
6869
+ }
6870
+
6871
+ ${LayerDescription} {
6872
+ text-align: center;
6873
+ }
6874
+
6875
+ ${HeaderWrapperMixin$1};
6876
+ `;
6877
+
6878
+ const FeatureCardGradientHeader = ({ isRow }) => {
6879
+ const { layerInfo } = useWidgetContext(WidgetType.FeatureCard);
6880
+ const { config } = useWidgetConfig(WidgetType.FeatureCard);
6881
+ const { header, options } = config || {};
6882
+ const renderElement = useHeaderRender(header);
6883
+ return (jsx(GradientHeaderWrapper, { "$fontColor": options?.fontColor, "$bgColor": options?.bgColor, children: jsx(ThemeProvider, { theme: defaultTheme, children: jsx(Header, { "$isRow": isRow, children: jsxs(HeaderFrontView, { children: [jsxs(HeaderContainer, { children: [jsx(LayerIcon, { layerInfo: layerInfo }), jsx(FeatureCardTitle, { title: renderElement({
6884
+ id: "title",
6885
+ wrap: false,
6886
+ }), description: renderElement({
6887
+ id: "description",
6888
+ wrap: false,
6889
+ }) })] }), jsx(FeatureCardButtons, {})] }) }) }) }));
6890
+ };
6891
+
6892
+ const HeaderFontColorMixin = css `
6893
+ ${HeaderTitleContainer}, ${LayerDescription} {
6894
+ color: ${({ $fontColor }) => $fontColor};
6895
+ }
6896
+ `;
6897
+ const HeaderWrapperMixin = css `
6898
+ padding: 0.5rem 0.5rem 0;
6899
+
6900
+ ${Header} {
6901
+ min-height: 5.25rem;
6902
+ }
6903
+
6904
+ ${HeaderContainer} {
6905
+ max-width: 100%;
6906
+ width: 100%;
6907
+ }
6908
+
6909
+ ${FeatureControls} {
6910
+ max-width: calc(100% - 2rem);
6911
+ width: calc(100% - 2rem);
6912
+ margin-top: -0.5rem;
6913
+ padding-top: 1rem;
6914
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
6915
+ }
6916
+
6917
+ ${({ $fontColor }) => !!$fontColor && HeaderFontColorMixin};
6918
+ `;
6919
+ const HeaderIcon = styled(Flex) `
6920
+ position: absolute;
6921
+ top: 0;
6922
+ right: 0;
6923
+ justify-content: flex-end;
6924
+ align-items: center;
6925
+ min-width: 7.5rem;
6926
+ height: 100%;
6927
+
6928
+ span[kind]:after {
6929
+ font-size: 7.5rem;
6930
+ }
6931
+
6932
+ span[kind]:after,
6933
+ path,
6934
+ line,
6935
+ circle {
6936
+ fill: rgba(255, 255, 255, 0.36);
6937
+ }
6938
+
6939
+ && > * {
6940
+ display: flex;
6941
+ align-items: center;
6942
+ height: 100%;
6943
+ }
6944
+ `;
6945
+ const BigIconHeaderMixin = css `
6946
+ ${HeaderIcon} {
6947
+ min-width: 14rem;
6948
+ right: -3rem;
6949
+
6950
+ span[kind]:after {
6951
+ font-size: 14rem;
6952
+ }
6953
+ }
6954
+ `;
6955
+ const IconHeaderWrapper = styled.div `
6956
+ ${Header} {
6957
+ width: calc(100% + 3rem);
6958
+ margin: -1.5rem -1.5rem 0 -1.5rem;
6959
+ padding: 1.5rem;
6960
+ border-top-left-radius: 0.5rem;
6961
+ border-top-right-radius: 0.5rem;
6962
+ background: ${({ $bgColor }) => $bgColor || "linear-gradient(96.55deg, #FFFCD3 0%, #B4DC47 100%)"};
6963
+ }
6964
+
6965
+ ${HeaderWrapperMixin};
6966
+
6967
+ ${({ $bigIcon }) => $bigIcon && BigIconHeaderMixin};
6968
+ `;
6969
+
6970
+ const FeatureCardIconHeader = ({ isRow }) => {
6971
+ const { layerInfo } = useWidgetContext(WidgetType.FeatureCard);
6972
+ const { config } = useWidgetConfig(WidgetType.FeatureCard);
6973
+ const { header, options } = config || {};
6974
+ const renderElement = useHeaderRender(header);
6975
+ return (jsx(IconHeaderWrapper, { "$fontColor": options?.fontColor, "$bgColor": options?.bgColor, "$bigIcon": options?.bigIcon, children: jsx(ThemeProvider, { theme: defaultTheme, children: jsxs(Header, { "$isRow": isRow, children: [jsxs(HeaderFrontView, { children: [jsxs(HeaderContainer, { children: [jsx(LayerIcon, { layerInfo: layerInfo }), jsx(FeatureCardTitle, { title: renderElement({
6976
+ id: "title",
6977
+ wrap: false,
6978
+ }), description: renderElement({
6979
+ id: "description",
6980
+ wrap: false,
6981
+ }) })] }), jsx(FeatureCardButtons, {})] }), jsx(HeaderIcon, { children: renderElement({
6982
+ id: "icon",
6983
+ wrap: false,
6984
+ }) })] }) }) }));
6985
+ };
6986
+
6987
+ const ImageContainerButton = styled(FlatButton) `
6988
+ min-height: 1.5rem;
6989
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.large};
6990
+ background-color: ${({ theme: { palette } }) => palette.primary};
6991
+ text-transform: none;
6992
+
6993
+ :hover {
6994
+ background-color: ${({ theme: { palette } }) => palette.primaryDeep};
6995
+ }
6996
+ `;
6997
+
6998
+ const ElementButton = memo(({ type, elementConfig }) => {
6999
+ const { attributes } = useWidgetContext(type);
7000
+ const attribute = getAttributeByName(elementConfig?.attributeName, attributes);
7001
+ const link = attribute?.value;
7002
+ if (!link || typeof link !== "string")
7003
+ return null;
7004
+ return (jsx(ImageContainerButton, { onClick: () => window.open(attribute?.value), children: elementConfig.value || "" }));
7005
+ });
7006
+
7007
+ const AttributeGalleryContainer = styled.div `
7008
+ && {
7009
+ width: calc(100% + 3rem);
7010
+ }
7011
+
7012
+ min-height: 12.625rem;
7013
+ background-color: ${({ theme: { palette } }) => palette.element};
7014
+
7015
+ img {
7016
+ width: 100%;
7017
+ }
7018
+ `;
7019
+ const LinearProgressContainer = styled(Flex) `
7020
+ align-items: center;
7021
+ justify-content: center;
7022
+ min-height: inherit;
7023
+
7024
+ ${LinearProgress} {
7025
+ max-width: 4rem;
7026
+ }
7027
+ `;
7028
+ const NoLiveSnapshotContainer = styled(Flex) `
7029
+ flex-direction: column;
6566
7030
  align-items: center;
6567
7031
 
6568
7032
  span[kind="alert"] {
@@ -6649,7 +7113,7 @@ const imgSlideShowMixin = css `
6649
7113
  }
6650
7114
  }
6651
7115
  `;
6652
- const SmallPreviewContainer = styled.div `
7116
+ const SmallPreviewContainer$1 = styled.div `
6653
7117
  cursor: ${({ onClick }) => (onClick ? "pointer" : "default")};
6654
7118
  position: relative;
6655
7119
  width: 100%;
@@ -6694,6 +7158,10 @@ const SmallPreviewContainer = styled.div `
6694
7158
  `;
6695
7159
  const SmallPreviewImages = styled.div ``;
6696
7160
 
7161
+ const NoLiveSnapshot = () => {
7162
+ return (jsxs(NoLiveSnapshotContainer, { children: [jsx(Icon, { kind: "alert" }), jsx(Description, { children: "\u0421\u043D\u0438\u043C\u043E\u043A \u043D\u0435 \u0434\u043E\u0441\u0442\u0443\u043F\u0435\u043D" })] }));
7163
+ };
7164
+
6697
7165
  const SmallPreview = ({ images, totalCount, currentIndex, isLoading, setCurrentIndex, onClick, onNextPage }) => {
6698
7166
  const { t } = useGlobalContext();
6699
7167
  const [prevIndex, setPrevIndex] = useState(currentIndex + 1);
@@ -6715,40 +7183,151 @@ const SmallPreview = ({ images, totalCount, currentIndex, isLoading, setCurrentI
6715
7183
  onNextPage();
6716
7184
  }
6717
7185
  }, [currentIndex, images, isNextDisabled, onNextPage, setCurrentIndex]);
6718
- return (jsxs(SmallPreviewContainer, { currentIndex: currentIndex + 1, prevIndex: prevIndex + 1, children: [isLoading && jsx(LinearProgress, {}), images.length > 1 && (jsxs(Fragment$1, { children: [jsx(SmallPreviewLeft, { "$isDisabled": isPrevDisabled, onClick: prev }), jsx(SmallPreviewRight, { "$isDisabled": isNextDisabled, onClick: next }), jsx(SmallPreviewCounter, { children: jsxs("div", { children: [currentIndex + 1, " ", t("of", { ns: "dashboard" }), " ", total] }) })] })), jsx(SmallPreviewImages, { onClick: onClick, children: images.map(image => (jsx("img", { src: image.src, alt: "" }, image.src))) })] }));
7186
+ return (jsxs(SmallPreviewContainer$1, { currentIndex: currentIndex + 1, prevIndex: prevIndex + 1, children: [isLoading && jsx(LinearProgress, {}), images.length > 1 && (jsxs(Fragment$1, { children: [jsx(SmallPreviewLeft, { "$isDisabled": isPrevDisabled, onClick: prev }), jsx(SmallPreviewRight, { "$isDisabled": isNextDisabled, onClick: next }), jsx(SmallPreviewCounter, { children: jsxs("div", { children: [currentIndex + 1, " ", t("of", { ns: "dashboard" }), " ", total] }) })] })), jsx(SmallPreviewImages, { onClick: onClick, children: images.map(image => (jsx("img", { src: image.src, alt: "" }, image.src))) })] }));
6719
7187
  };
6720
7188
 
6721
- const ElementSlideshow = ({ elementConfig, type, renderElement }) => {
6722
- const { expandedContainers, dataSources, attributes } = useWidgetContext(type);
7189
+ const DEFAULT_ARCHIVED_PERIOD = "#24h";
7190
+ const SNAPSHOTS_PER_PAGE = 10;
7191
+ const getDuration = (archivePeriod) => {
7192
+ const lastLetter = archivePeriod[archivePeriod.length - 1];
7193
+ const value = archivePeriod.slice(1, -1);
7194
+ const prop = lastLetter === "d"
7195
+ ? "days"
7196
+ : lastLetter === "h"
7197
+ ? "hours"
7198
+ : lastLetter === "m"
7199
+ ? "minutes"
7200
+ : lastLetter === "s"
7201
+ ? "seconds"
7202
+ : null;
7203
+ if (!lastLetter || !value || !prop)
7204
+ return {};
7205
+ return { [prop]: Number(value) };
7206
+ };
7207
+ const useCameraAttribute = (cameraId) => {
7208
+ const { api } = useGlobalContext();
6723
7209
  const [currentIndex, setCurrentIndex] = useState(0);
6724
- const [isOpenGallery, toggleGallery] = useToggle();
6725
- const { id, options, attributeName } = elementConfig || {};
6726
- const { expandable, expanded, relatedDataSource } = options || {};
6727
- const isVisible = isVisibleContainer(id, expandable, expanded, expandedContainers);
6728
- const images = useMemo(() => {
6729
- const dataSource = relatedDataSource ? dataSources?.find(({ name }) => name === relatedDataSource) : null;
6730
- const array = dataSource
6731
- ? dataSource.features.map(feature => feature.attributes[attributeName])
6732
- : getSlideshowImages({
6733
- element: elementConfig,
6734
- attribute: attributes?.find(({ name }) => name === attributeName),
7210
+ const [currentPage, setCurrentPage] = useState(0);
7211
+ const [timeline, setTimeline] = useState([]);
7212
+ const [isLoadingSnapshot, setLoadingSnapshot] = useState(false);
7213
+ const [isLoadingTimeline, setLoadingTimeline] = useState(false);
7214
+ const [isOpenGallery, toggleGallery] = useToggle();
7215
+ const [galleryImages, setGalleryImages] = useState([]);
7216
+ const imagesRef = useRef([]);
7217
+ // Todo get archivePeriod from project configuration
7218
+ const archivePeriod = /* appConfig?.settings?.cameraAttribute?.archivePeriod ||*/ DEFAULT_ARCHIVED_PERIOD;
7219
+ const onNextPage = useCallback(() => {
7220
+ setCurrentPage(currentPage + 1);
7221
+ }, [currentPage]);
7222
+ useEffect(() => {
7223
+ (async () => {
7224
+ if (!cameraId)
7225
+ return;
7226
+ setLoadingSnapshot(true);
7227
+ const snapshot = null; // await api.cameras.getLiveSnapshot(cameraId);
7228
+ const url = URL.createObjectURL(snapshot);
7229
+ setLoadingSnapshot(false);
7230
+ setLoadingTimeline(true);
7231
+ imagesRef.current = [
7232
+ {
7233
+ src: url,
7234
+ startTime: new Date(),
7235
+ },
7236
+ ];
7237
+ setGalleryImages([
7238
+ {
7239
+ src: url,
7240
+ fileName: formatDate$1(new Date()),
7241
+ },
7242
+ ]);
7243
+ const formatDateOptions = { dateFormat: DateFormat.UTC };
7244
+ const startTime = formatDate$1(sub(new Date(), getDuration(archivePeriod)), formatDateOptions);
7245
+ const endTime = formatDate$1(new Date(), formatDateOptions);
7246
+ const timelineResponse = await api.cameras.getArchiveTimeline({ cameraId, startTime, endTime });
7247
+ if (!timelineResponse.success || !timelineResponse.timeline.length)
7248
+ return;
7249
+ timelineResponse.timeline.reverse();
7250
+ setTimeline(timelineResponse.timeline);
7251
+ })();
7252
+ }, [cameraId]);
7253
+ useEffect(() => {
7254
+ if (!timeline.length)
7255
+ return;
7256
+ const timelinePage = timeline.slice(currentPage * SNAPSHOTS_PER_PAGE, (currentPage + 1) * SNAPSHOTS_PER_PAGE);
7257
+ for (const item of timelinePage) {
7258
+ if (!item)
7259
+ continue;
7260
+ api.cameras
7261
+ .getArchiveSnapshot({
7262
+ cameraId,
7263
+ time: item.startTime,
7264
+ })
7265
+ .then(response => {
7266
+ const newImages = [
7267
+ ...imagesRef.current,
7268
+ { src: URL.createObjectURL(response), startTime: new Date(item.startTime) },
7269
+ ];
7270
+ newImages.sort((a, b) => (a.startTime < b.startTime ? 1 : a.startTime > b.startTime ? -1 : 0));
7271
+ imagesRef.current = newImages;
7272
+ setGalleryImages(newImages.map(newImage => ({
7273
+ src: newImage.src,
7274
+ fileName: formatDate$1(newImage.startTime, { dateFormat: DateFormat.DateTime }),
7275
+ })));
7276
+ if (newImages.length === timelinePage.length) {
7277
+ setLoadingTimeline(false);
7278
+ }
6735
7279
  });
6736
- return (array?.map(image => ({
6737
- src: image,
6738
- fileName: image,
6739
- })) || []);
6740
- }, [attributeName, attributes, dataSources, elementConfig, relatedDataSource]);
6741
- return (jsxs(Fragment$1, { children: [jsx(ExpandableTitle, { elementConfig: elementConfig, type: type, renderElement: renderElement }), isVisible && (jsxs(SmallPreviewContainer$1, { children: [jsx(SmallPreview, { images: images, currentIndex: currentIndex, setCurrentIndex: setCurrentIndex, onClick: toggleGallery }), isOpenGallery && (jsx(Preview, { images: images,
7280
+ }
7281
+ }, [timeline, currentPage]);
7282
+ return [
7283
+ {
7284
+ currentIndex,
7285
+ currentPage,
7286
+ totalCount: timeline.length,
7287
+ galleryImages,
7288
+ isLoadingSnapshot,
7289
+ isLoadingTimeline,
7290
+ isOpenGallery,
7291
+ },
7292
+ {
7293
+ toggleGallery,
7294
+ setGalleryImages,
7295
+ setCurrentIndex,
7296
+ onNextPage,
7297
+ },
7298
+ ];
7299
+ };
7300
+
7301
+ const ElementCamera = ({ type, renderElement, elementConfig, field }) => {
7302
+ const { expandedContainers, attributes } = useWidgetContext(type);
7303
+ const attribute = getAttributeByName(elementConfig?.attributeName, attributes);
7304
+ const value = attribute?.value;
7305
+ const { id, options } = elementConfig || {};
7306
+ const { expandable, expanded } = options || {};
7307
+ const isVisible = isVisibleContainer(id, expandable, expanded, expandedContainers);
7308
+ const [{ currentIndex /* , currentPage*/, totalCount, galleryImages, isLoadingSnapshot, isLoadingTimeline, isOpenGallery }, { setCurrentIndex, toggleGallery, onNextPage },] = useCameraAttribute(value);
7309
+ return (jsxs(Fragment$1, { children: [jsx(ExpandableTitle, { elementConfig: elementConfig, type: type, renderElement: renderElement }), isVisible && (jsxs(Fragment$1, { children: [!!field && jsx(AttributeLabel, { children: field }), jsx(AttributeGalleryContainer, { children: isLoadingSnapshot ? (jsx(LinearProgressContainer, { children: jsx(LinearProgress, {}) })) : !galleryImages?.length && !isLoadingTimeline ? (jsx(NoLiveSnapshot, {})) : (jsx(SmallPreview, { images: galleryImages, totalCount: totalCount, currentIndex: currentIndex, isLoading: isLoadingTimeline, setCurrentIndex: setCurrentIndex, onClick: toggleGallery, onNextPage: onNextPage })) }), isOpenGallery && (jsx(Preview, { images: galleryImages,
6742
7310
  // currentIndex={currentIndex}
6743
- // totalCount={images.length}
6744
- isOpen: isOpenGallery, onClose: toggleGallery }))] }))] }));
7311
+ // currentPage={currentPage}
7312
+ // totalCount={totalCount}
7313
+ isOpen: isOpenGallery,
7314
+ // isLoading={isLoadingTimeline}
7315
+ // hasSidebar
7316
+ onClose: toggleGallery }))] }))] }));
6745
7317
  };
6746
7318
 
6747
- const ElementSvg = memo(({ type, elementConfig }) => {
6748
- const { layerInfo, attributes } = useWidgetContext(type);
6749
- const { options } = elementConfig || {};
6750
- const { width, height, fontColor } = options || {};
6751
- return (jsx(SvgImage, { url: getSvgUrl({ elementConfig, layerInfo, attributes }), width: width, height: height, fontColor: fontColor }));
7319
+ const ElementChart = memo(({ type, elementConfig, renderElement }) => {
7320
+ const { config } = useWidgetConfig(type);
7321
+ return (jsx(Chart, { type: type, config: config, elementConfig: elementConfig, element: elementConfig, renderElement: renderElement }));
7322
+ });
7323
+
7324
+ const ElementChips = memo(({ type, elementConfig }) => {
7325
+ const { attributes } = useWidgetContext(type);
7326
+ const { attributeName, options, style } = elementConfig || {};
7327
+ const { separator, bgColor, fontColor, fontSize } = options || {};
7328
+ const attribute = getAttributeByName(attributeName, attributes);
7329
+ const tags = attribute?.value?.split(separator || ",");
7330
+ return (jsx(DashboardChipsContainer, { style: style, children: tags?.map(tag => (jsx(DashboardChip$1, { text: tag, "$bgColor": bgColor, "$fontColor": fontColor, "$fontSize": fontSize, "$isDefault": true }, tag))) }));
6752
7331
  });
6753
7332
 
6754
7333
  const StyledIconFontSizeMixin = css `
@@ -6776,27 +7355,45 @@ const ElementIcon = memo(({ type, elementConfig }) => {
6776
7355
  return jsx(StyledIcon, { kind: iconValue, fontSize: fontSize, fontColor: fontColor });
6777
7356
  });
6778
7357
 
6779
- const TooltipIcon = styled(Icon) `
6780
- &&& {
6781
- :after {
6782
- font-size: 0.75rem;
6783
- color: ${({ theme: { palette } }) => palette.iconDisabled};
6784
- transition: color ${transition.hover};
6785
- }
6786
-
6787
- :hover:after {
6788
- color: ${({ theme: { palette } }) => palette.icon};
6789
- }
6790
- }
6791
- `;
7358
+ const ElementImage = memo(({ type, elementConfig }) => {
7359
+ const { attributes } = useWidgetContext(type);
7360
+ const { value, attributeName, options } = elementConfig || {};
7361
+ const { width } = options || {};
7362
+ const firstImage = useMemo(() => {
7363
+ if (value) {
7364
+ return value.toString();
7365
+ }
7366
+ if (!attributeName || Array.isArray(attributeName)) {
7367
+ return null;
7368
+ }
7369
+ const attribute = attributes?.find(item => item.name === attributeName);
7370
+ return attribute?.value?.split(";")?.[0];
7371
+ }, [attributeName, attributes, value]);
7372
+ return firstImage ? jsx("img", { src: firstImage, alt: firstImage, width: width }) : null;
7373
+ });
6792
7374
 
6793
- const ElementTooltip = memo(({ type, elementConfig }) => {
7375
+ const ElementLegend = memo(({ type, element, elementConfig, expandedContainers }) => {
6794
7376
  const { attributes } = useWidgetContext(type);
6795
- const { attributeName, options } = elementConfig || {};
6796
- const { icon } = options || {};
6797
- const attribute = getAttributeByName(attributeName, attributes);
6798
- const text = (attribute?.value || elementConfig?.value);
6799
- return text ? (jsx(Tooltip, { placement: "top", arrow: true, content: text, children: ref => jsx(TooltipIcon, { kind: icon || "question", ref: ref }) })) : null;
7377
+ const { options } = elementConfig || {};
7378
+ const { twoColumns, chartId, relatedDataSources } = options || {};
7379
+ const chartElement = useMemo(() => returnFound(element?.children, { id: chartId }), [chartId, element?.children]);
7380
+ const { data, loading } = useChartData({
7381
+ element: chartElement,
7382
+ type,
7383
+ });
7384
+ const legendData = useMemo(() => {
7385
+ if (!data[0]?.items?.length)
7386
+ return [];
7387
+ const relatedAttributes = relatedDataSources || [];
7388
+ const isRelated = !!relatedAttributes?.length;
7389
+ return isRelated
7390
+ ? data[0].items
7391
+ : data[0].items.map(item => {
7392
+ const attribute = attributes?.find(({ name }) => name === item.name);
7393
+ return { ...item, name: attribute?.alias || item.name };
7394
+ });
7395
+ }, [attributes, data, relatedDataSources]);
7396
+ return !chartElement?.options?.expanded || expandedContainers?.[chartElement.id] ? (jsx(ChartLegend, { data: legendData, loading: loading, chartElement: chartElement, twoColumns: twoColumns, type: type })) : null;
6800
7397
  });
6801
7398
 
6802
7399
  const ExternalLink = styled(IconButton).attrs(() => ({
@@ -6867,197 +7464,272 @@ const ElementLink = memo(({ type, elementConfig }) => {
6867
7464
  return link.startsWith("http") ? jsx(ExternalLink, { onClick: () => window.open(link) }) : jsx(LocalLink, { link: link });
6868
7465
  });
6869
7466
 
6870
- const ImageContainerButton = styled(FlatButton) `
6871
- min-height: 1.5rem;
6872
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.large};
6873
- background-color: ${({ theme: { palette } }) => palette.primary};
6874
- text-transform: none;
7467
+ const SmallPreviewContainer = styled.div `
7468
+ width: 100%;
7469
+ height: 100%;
7470
+ `;
7471
+
7472
+ const ElementSlideshow = ({ elementConfig, type, renderElement }) => {
7473
+ const { expandedContainers, dataSources, attributes } = useWidgetContext(type);
7474
+ const [currentIndex, setCurrentIndex] = useState(0);
7475
+ const [isOpenGallery, toggleGallery] = useToggle();
7476
+ const { id, options, attributeName } = elementConfig || {};
7477
+ const { expandable, expanded, relatedDataSource } = options || {};
7478
+ const isVisible = isVisibleContainer(id, expandable, expanded, expandedContainers);
7479
+ const images = useMemo(() => {
7480
+ const dataSource = relatedDataSource ? dataSources?.find(({ name }) => name === relatedDataSource) : null;
7481
+ const array = dataSource
7482
+ ? dataSource.features.map(feature => feature.attributes[attributeName])
7483
+ : getSlideshowImages({
7484
+ element: elementConfig,
7485
+ attribute: attributes?.find(({ name }) => name === attributeName),
7486
+ });
7487
+ return (array?.map(image => ({
7488
+ src: image,
7489
+ fileName: image,
7490
+ })) || []);
7491
+ }, [attributeName, attributes, dataSources, elementConfig, relatedDataSource]);
7492
+ return (jsxs(Fragment$1, { children: [jsx(ExpandableTitle, { elementConfig: elementConfig, type: type, renderElement: renderElement }), isVisible && (jsxs(SmallPreviewContainer, { children: [jsx(SmallPreview, { images: images, currentIndex: currentIndex, setCurrentIndex: setCurrentIndex, onClick: toggleGallery }), isOpenGallery && (jsx(Preview, { images: images,
7493
+ // currentIndex={currentIndex}
7494
+ // totalCount={images.length}
7495
+ isOpen: isOpenGallery, onClose: toggleGallery }))] }))] }));
7496
+ };
7497
+
7498
+ const ElementSvg = memo(({ type, elementConfig }) => {
7499
+ const { layerInfo, attributes } = useWidgetContext(type);
7500
+ const { options } = elementConfig || {};
7501
+ const { width, height, fontColor } = options || {};
7502
+ return (jsx(SvgImage, { url: getSvgUrl({ elementConfig, layerInfo, attributes }), width: width, height: height, fontColor: fontColor }));
7503
+ });
7504
+
7505
+ const TooltipIcon = styled(Icon) `
7506
+ &&& {
7507
+ :after {
7508
+ font-size: 0.75rem;
7509
+ color: ${({ theme: { palette } }) => palette.iconDisabled};
7510
+ transition: color ${transition.hover};
7511
+ }
6875
7512
 
6876
- :hover {
6877
- background-color: ${({ theme: { palette } }) => palette.primaryDeep};
7513
+ :hover:after {
7514
+ color: ${({ theme: { palette } }) => palette.icon};
7515
+ }
6878
7516
  }
6879
7517
  `;
6880
7518
 
6881
- const ElementButton = memo(({ type, elementConfig }) => {
7519
+ const ElementTooltip = memo(({ type, elementConfig }) => {
6882
7520
  const { attributes } = useWidgetContext(type);
6883
- const attribute = getAttributeByName(elementConfig?.attributeName, attributes);
6884
- const link = attribute?.value;
6885
- if (!link || typeof link !== "string")
6886
- return null;
6887
- return (jsx(ImageContainerButton, { onClick: () => window.open(attribute?.value), children: elementConfig.value || "" }));
7521
+ const { attributeName, options } = elementConfig || {};
7522
+ const { icon } = options || {};
7523
+ const attribute = getAttributeByName(attributeName, attributes);
7524
+ const text = (attribute?.value || elementConfig?.value);
7525
+ return text ? (jsx(Tooltip$1, { placement: "top", arrow: true, content: text, children: ref => jsx(TooltipIcon, { kind: icon || "question", ref: ref }) })) : null;
6888
7526
  });
6889
7527
 
6890
- const NoLiveSnapshot = () => {
6891
- return (jsxs(NoLiveSnapshotContainer, { children: [jsx(Icon, { kind: "alert" }), jsx(Description, { children: "\u0421\u043D\u0438\u043C\u043E\u043A \u043D\u0435 \u0434\u043E\u0441\u0442\u0443\u043F\u0435\u043D" })] }));
6892
- };
6893
-
6894
- const DEFAULT_ARCHIVED_PERIOD = "#24h";
6895
- const SNAPSHOTS_PER_PAGE = 10;
6896
- const getDuration = (archivePeriod) => {
6897
- const lastLetter = archivePeriod[archivePeriod.length - 1];
6898
- const value = archivePeriod.slice(1, -1);
6899
- const prop = lastLetter === "d"
6900
- ? "days"
6901
- : lastLetter === "h"
6902
- ? "hours"
6903
- : lastLetter === "m"
6904
- ? "minutes"
6905
- : lastLetter === "s"
6906
- ? "seconds"
6907
- : null;
6908
- if (!lastLetter || !value || !prop)
6909
- return {};
6910
- return { [prop]: Number(value) };
6911
- };
6912
- const useCameraAttribute = (cameraId) => {
6913
- const { api } = useGlobalContext();
6914
- const [currentIndex, setCurrentIndex] = useState(0);
6915
- const [currentPage, setCurrentPage] = useState(0);
6916
- const [timeline, setTimeline] = useState([]);
6917
- const [isLoadingSnapshot, setLoadingSnapshot] = useState(false);
6918
- const [isLoadingTimeline, setLoadingTimeline] = useState(false);
6919
- const [isOpenGallery, toggleGallery] = useToggle();
6920
- const [galleryImages, setGalleryImages] = useState([]);
6921
- const imagesRef = useRef([]);
6922
- // Todo get archivePeriod from project configuration
6923
- const archivePeriod = /* appConfig?.settings?.cameraAttribute?.archivePeriod ||*/ DEFAULT_ARCHIVED_PERIOD;
6924
- const onNextPage = useCallback(() => {
6925
- setCurrentPage(currentPage + 1);
6926
- }, [currentPage]);
6927
- useEffect(() => {
6928
- (async () => {
6929
- if (!cameraId)
6930
- return;
6931
- setLoadingSnapshot(true);
6932
- const snapshot = null; // await api.cameras.getLiveSnapshot(cameraId);
6933
- const url = URL.createObjectURL(snapshot);
6934
- setLoadingSnapshot(false);
6935
- setLoadingTimeline(true);
6936
- imagesRef.current = [
6937
- {
6938
- src: url,
6939
- startTime: new Date(),
6940
- },
6941
- ];
6942
- setGalleryImages([
6943
- {
6944
- src: url,
6945
- fileName: formatDate$1(new Date()),
6946
- },
6947
- ]);
6948
- const formatDateOptions = { dateFormat: DateFormat.UTC };
6949
- const startTime = formatDate$1(sub(new Date(), getDuration(archivePeriod)), formatDateOptions);
6950
- const endTime = formatDate$1(new Date(), formatDateOptions);
6951
- const timelineResponse = await api.cameras.getArchiveTimeline({ cameraId, startTime, endTime });
6952
- if (!timelineResponse.success || !timelineResponse.timeline.length)
6953
- return;
6954
- timelineResponse.timeline.reverse();
6955
- setTimeline(timelineResponse.timeline);
6956
- })();
6957
- }, [cameraId]);
6958
- useEffect(() => {
6959
- if (!timeline.length)
6960
- return;
6961
- const timelinePage = timeline.slice(currentPage * SNAPSHOTS_PER_PAGE, (currentPage + 1) * SNAPSHOTS_PER_PAGE);
6962
- for (const item of timelinePage) {
6963
- if (!item)
6964
- continue;
6965
- api.cameras
6966
- .getArchiveSnapshot({
6967
- cameraId,
6968
- time: item.startTime,
6969
- })
6970
- .then(response => {
6971
- const newImages = [
6972
- ...imagesRef.current,
6973
- { src: URL.createObjectURL(response), startTime: new Date(item.startTime) },
6974
- ];
6975
- newImages.sort((a, b) => (a.startTime < b.startTime ? 1 : a.startTime > b.startTime ? -1 : 0));
6976
- imagesRef.current = newImages;
6977
- setGalleryImages(newImages.map(newImage => ({
6978
- src: newImage.src,
6979
- fileName: formatDate$1(newImage.startTime, { dateFormat: DateFormat.DateTime }),
6980
- })));
6981
- if (newImages.length === timelinePage.length) {
6982
- setLoadingTimeline(false);
6983
- }
6984
- });
6985
- }
6986
- }, [timeline, currentPage]);
7528
+ const SlideshowHeaderWrapper = styled.div `
7529
+ padding: ${({ withPadding }) => (withPadding ? "0.5rem 0.5rem 0" : 0)};
7530
+
7531
+ ${Header} {
7532
+ align-items: flex-start;
7533
+ width: calc(100% + 2rem);
7534
+ height: ${({ big }) => (big ? "15.5rem" : "auto")};
7535
+ padding: 1.5rem;
7536
+ margin: -1rem -1rem 0 -1rem;
7537
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
7538
+
7539
+ ${SmallPreviewCounter} {
7540
+ bottom: ${({ withPadding }) => (withPadding ? 0.625 : 1.125)}rem;
7541
+ }
7542
+
7543
+ :before,
7544
+ :after {
7545
+ content: "";
7546
+ z-index: 2;
7547
+ position: absolute;
7548
+ top: 0;
7549
+ left: 0;
7550
+ width: 100%;
7551
+ }
7552
+
7553
+ :before {
7554
+ height: 100%;
7555
+ background: rgba(32, 46, 53, 0.25);
7556
+ }
7557
+
7558
+ :after {
7559
+ height: 4.5rem;
7560
+ background: linear-gradient(180deg, #000000 0%, rgba(0, 0, 0, 0) 100%);
7561
+ }
7562
+
7563
+ :hover {
7564
+ ${SmallPreviewControl}, ${SmallPreviewCounter} {
7565
+ opacity: 1;
7566
+ }
7567
+ }
7568
+ }
7569
+ `;
7570
+ const ImageContainerBg = styled.div `
7571
+ position: absolute;
7572
+ top: 0;
7573
+ bottom: 0;
7574
+ left: 0;
7575
+ right: 0;
7576
+
7577
+ img {
7578
+ width: 100%;
7579
+ height: 100%;
7580
+ object-position: center;
7581
+ object-fit: cover;
7582
+ }
7583
+ `;
7584
+ const HeaderSlideshow = styled.div `
7585
+ position: absolute;
7586
+ top: 0;
7587
+ bottom: ${({ height }) => (height ? `${height}px` : 0)};
7588
+ left: 0;
7589
+ right: 0;
7590
+
7591
+ img {
7592
+ width: 100%;
7593
+ height: 100%;
7594
+ min-height: inherit;
7595
+ object-position: center;
7596
+ object-fit: cover;
7597
+ }
7598
+ `;
7599
+
7600
+ const FeatureCardSlideshowHeader = ({ isRow }) => {
7601
+ const { layerInfo } = useWidgetContext(WidgetType.FeatureCard);
7602
+ const { config } = useWidgetConfig(WidgetType.FeatureCard);
7603
+ const { header, options } = config || {};
7604
+ const renderElement = useHeaderRender(header);
7605
+ return (jsx(SlideshowHeaderWrapper, { big: true, withPadding: options?.withPadding, children: jsx(ThemeProvider, { theme: darkTheme, children: jsxs(Header, { "$isRow": isRow, children: [jsxs(HeaderFrontView, { children: [jsxs(HeaderContainer, { children: [jsx(LayerIcon, { layerInfo: layerInfo }), jsx(FeatureCardTitle, { title: renderElement({
7606
+ id: "title",
7607
+ wrap: false,
7608
+ }), description: renderElement({
7609
+ id: "description",
7610
+ wrap: false,
7611
+ }) })] }), jsx(FeatureCardButtons, {})] }), jsx(ImageContainerBg, { children: renderElement({
7612
+ id: "bgImage",
7613
+ wrap: false,
7614
+ }) }), jsx(HeaderSlideshow, { height: options?.height, children: renderElement({
7615
+ id: "slideshow",
7616
+ wrap: false,
7617
+ }) })] }) }) }));
7618
+ };
7619
+
7620
+ const getDashboardHeader = (templateName) => {
7621
+ switch (templateName) {
7622
+ case HeaderTemplate.Default:
7623
+ default:
7624
+ return DashboardDefaultHeader;
7625
+ }
7626
+ };
7627
+
7628
+ const getDataFromAttributes = (t, config, attributes) => {
7629
+ const colors = config?.options?.colors || FEATURE_CARD_DEFAULT_COLORS;
7630
+ const data = config?.children?.map(({ attributeName }, index) => {
7631
+ const attribute = attributes?.find(({ name }) => name === attributeName);
7632
+ return {
7633
+ name: attribute?.name || "",
7634
+ value: attribute ? Number(attribute.value) : 0,
7635
+ color: colors[index] || FEATURE_CARD_OTHER_COLOR
7636
+ };
7637
+ });
7638
+ if (config?.options?.orderByValue) {
7639
+ data.sort((a, b) => b.value - a.value);
7640
+ }
7641
+ const isOtherSliced = config?.options?.otherItems && config.options.otherItems < data.length;
7642
+ if (!isOtherSliced)
7643
+ return data;
7644
+ const otherValue = data
7645
+ .slice(0, config?.options?.otherItems)
7646
+ .reduce((prev, { value }) => prev + value, 0);
6987
7647
  return [
7648
+ ...data?.slice(0, config.options?.otherItems),
6988
7649
  {
6989
- currentIndex,
6990
- currentPage,
6991
- totalCount: timeline.length,
6992
- galleryImages,
6993
- isLoadingSnapshot,
6994
- isLoadingTimeline,
6995
- isOpenGallery,
6996
- },
6997
- {
6998
- toggleGallery,
6999
- setGalleryImages,
7000
- setCurrentIndex,
7001
- onNextPage,
7002
- },
7650
+ name: t("other", { ns: "dashboard" }),
7651
+ color: FEATURE_CARD_OTHER_COLOR,
7652
+ value: Number(otherValue)
7653
+ }
7003
7654
  ];
7004
7655
  };
7005
7656
 
7006
- const ElementCamera = ({ type, renderElement, elementConfig, field }) => {
7007
- const { expandedContainers, attributes } = useWidgetContext(type);
7008
- const attribute = getAttributeByName(elementConfig?.attributeName, attributes);
7009
- const value = attribute?.value;
7010
- const { id, options } = elementConfig || {};
7011
- const { expandable, expanded } = options || {};
7012
- const isVisible = isVisibleContainer(id, expandable, expanded, expandedContainers);
7013
- const [{ currentIndex /* , currentPage*/, totalCount, galleryImages, isLoadingSnapshot, isLoadingTimeline, isOpenGallery }, { setCurrentIndex, toggleGallery, onNextPage },] = useCameraAttribute(value);
7014
- return (jsxs(Fragment$1, { children: [jsx(ExpandableTitle, { elementConfig: elementConfig, type: type, renderElement: renderElement }), isVisible && (jsxs(Fragment$1, { children: [!!field && jsx(AttributeLabel, { children: field }), jsx(AttributeGalleryContainer, { children: isLoadingSnapshot ? (jsx(LinearProgressContainer, { children: jsx(LinearProgress, {}) })) : !galleryImages?.length && !isLoadingTimeline ? (jsx(NoLiveSnapshot, {})) : (jsx(SmallPreview, { images: galleryImages, totalCount: totalCount, currentIndex: currentIndex, isLoading: isLoadingTimeline, setCurrentIndex: setCurrentIndex, onClick: toggleGallery, onNextPage: onNextPage })) }), isOpenGallery && (jsx(Preview, { images: galleryImages,
7015
- // currentIndex={currentIndex}
7016
- // currentPage={currentPage}
7017
- // totalCount={totalCount}
7018
- isOpen: isOpenGallery,
7019
- // isLoading={isLoadingTimeline}
7020
- // hasSidebar
7021
- onClose: toggleGallery }))] }))] }));
7657
+ const getDataFromRelatedFeatures = ({ t, config, filters, relatedConfig, dataSource, layerInfo }) => {
7658
+ if (!dataSource || !dataSource?.features?.length) {
7659
+ return [];
7660
+ }
7661
+ const { colors } = config.options;
7662
+ const layerDefinition = getLayerDefinition(layerInfo);
7663
+ let data = JSON.parse(JSON.stringify(dataSource?.features));
7664
+ const sortAttribute = config?.options?.orderByValue
7665
+ ? relatedConfig.attributeName
7666
+ : config?.options?.orderByTitle
7667
+ ? relatedConfig.attributeTitle
7668
+ : null;
7669
+ if (sortAttribute) {
7670
+ data.sort((a, b) => b.attributes[sortAttribute] - a.attributes[sortAttribute]);
7671
+ }
7672
+ const isOtherSliced = config?.options?.otherItems && config.options.otherItems < data.length;
7673
+ const otherValue = isOtherSliced
7674
+ ? data
7675
+ .slice(config.options.otherItems)
7676
+ .reduce((prev, { attributes }) => prev + attributes[relatedConfig.attributeName], 0)
7677
+ : null;
7678
+ if (isOtherSliced) {
7679
+ data = data.slice(0, config?.options?.otherItems);
7680
+ }
7681
+ const gradientArray = relatedConfig.chartAxis && colors?.length < data.length
7682
+ ? new Gradient()
7683
+ .setColorGradient(colors[0], colors[colors.length - 1])
7684
+ .setMidpoint(data.length)
7685
+ .getColors()
7686
+ : colors;
7687
+ const filter = getConfigFilter(relatedConfig?.filterName, filters);
7688
+ const result = data.reduce((acc, feature, index) => {
7689
+ if (relatedConfig?.filterName && !filter) {
7690
+ return acc;
7691
+ }
7692
+ const attributeName = feature.attributes[relatedConfig.attributeName];
7693
+ const attributeTitle = feature.attributes[relatedConfig.attributeTitle];
7694
+ const attributeColor = feature.attributes[relatedConfig.attributeColor];
7695
+ return [
7696
+ ...acc,
7697
+ {
7698
+ name: formatAttributeValue({
7699
+ t,
7700
+ type: layerDefinition.attributes[relatedConfig.attributeTitle]?.type,
7701
+ value: attributeTitle,
7702
+ stringFormat: layerDefinition.attributes[relatedConfig.attributeTitle]?.stringFormat
7703
+ }),
7704
+ value: attributeName === null ? null : Number(attributeName),
7705
+ color: attributeColor || gradientArray?.[index] || FEATURE_CARD_OTHER_COLOR,
7706
+ min: filter?.attributeMin ? feature.attributes[filter.attributeMin] : null,
7707
+ max: filter?.attributeMin ? feature.attributes[filter.attributeMax] : null
7708
+ }
7709
+ ];
7710
+ }, []);
7711
+ if (isOtherSliced) {
7712
+ result.push({
7713
+ name: t("other", { ns: "dashboard" }),
7714
+ color: FEATURE_CARD_OTHER_COLOR,
7715
+ value: Number(otherValue)
7716
+ });
7717
+ }
7718
+ return result;
7022
7719
  };
7023
7720
 
7024
- const ElementChart = memo(({ type, elementConfig, renderElement }) => {
7025
- const { config } = useWidgetConfig(type);
7026
- return (jsx(Chart, { type: type, config: config, elementConfig: elementConfig, element: elementConfig, renderElement: renderElement }));
7027
- });
7028
-
7029
- const ElementLegend = memo(({ type, element, elementConfig, expandedContainers }) => {
7030
- const { attributes } = useWidgetContext(type);
7031
- const { options } = elementConfig || {};
7032
- const { twoColumns, chartId, relatedDataSources } = options || {};
7033
- const chartElement = useMemo(() => returnFound(element?.children, { id: chartId }), [chartId, element?.children]);
7034
- const { data, loading } = useChartData({
7035
- element: chartElement,
7036
- type,
7037
- });
7038
- const legendData = useMemo(() => {
7039
- if (!data[0]?.items?.length)
7040
- return [];
7041
- const relatedAttributes = relatedDataSources || [];
7042
- const isRelated = !!relatedAttributes?.length;
7043
- return isRelated
7044
- ? data[0].items
7045
- : data[0].items.map(item => {
7046
- const attribute = attributes?.find(({ name }) => name === item.name);
7047
- return { ...item, name: attribute?.alias || item.name };
7048
- });
7049
- }, [attributes, data, relatedDataSources]);
7050
- return !chartElement?.options?.expanded || expandedContainers?.[chartElement.id] ? (jsx(ChartLegend, { data: legendData, loading: loading, chartElement: chartElement, twoColumns: twoColumns, type: type })) : null;
7051
- });
7052
-
7053
- const ElementChips = memo(({ type, elementConfig }) => {
7054
- const { attributes } = useWidgetContext(type);
7055
- const { attributeName, options, style } = elementConfig || {};
7056
- const { separator, bgColor, fontColor, fontSize } = options || {};
7057
- const attribute = getAttributeByName(attributeName, attributes);
7058
- const tags = attribute?.value?.split(separator || ",");
7059
- return (jsx(DashboardChipsContainer, { style: style, children: tags?.map(tag => (jsx(DashboardChip$1, { text: tag, "$bgColor": bgColor, "$fontColor": fontColor, "$fontSize": fontSize, "$isDefault": true }, tag))) }));
7060
- });
7721
+ const getDefaultConfig = ({ title, defaultTitle, items, baseMapName, position, resolution, srid, }) => {
7722
+ const dashboardConfiguration = JSON.parse(JSON.stringify(DEFAULT_DASHBOARD_CONFIG));
7723
+ const defaultPages = JSON.parse(JSON.stringify(DEFAULT_PAGES_CONFIG));
7724
+ const defaultPage = createConfigPage({ title, baseMapName, position, resolution, defaultTitle });
7725
+ if (items?.length) {
7726
+ const contentItems = items.map(item => createConfigLayer(item.name));
7727
+ defaultPage.layers.push(...contentItems);
7728
+ }
7729
+ defaultPages.children.push(defaultPage);
7730
+ dashboardConfiguration.children.push(defaultPages);
7731
+ return dashboardConfiguration;
7732
+ };
7061
7733
 
7062
7734
  const elementComponents = {
7063
7735
  image: ElementImage,
@@ -7150,6 +7822,20 @@ function getFeatureAttributes(feature = {}, layer, dataSource) {
7150
7822
  });
7151
7823
  }
7152
7824
 
7825
+ const getFeatureCardHeader = (templateName) => {
7826
+ switch (templateName) {
7827
+ case HeaderTemplate.Slideshow:
7828
+ return FeatureCardSlideshowHeader;
7829
+ case HeaderTemplate.Gradient:
7830
+ return FeatureCardGradientHeader;
7831
+ case HeaderTemplate.Icon:
7832
+ return FeatureCardIconHeader;
7833
+ case HeaderTemplate.Default:
7834
+ default:
7835
+ return FeatureCardDefaultHeader;
7836
+ }
7837
+ };
7838
+
7153
7839
  const RangeNumberFilter = ({ type, filter }) => {
7154
7840
  const { t } = useGlobalContext();
7155
7841
  const { filters, changeFilters } = useWidgetContext(type);
@@ -7848,7 +8534,7 @@ const pieChartTooltipFromAttributes = (t, data, attributes) => {
7848
8534
  const pieChartTooltipFromRelatedFeatures = (t, data, relatedAttributes, layerInfo) => {
7849
8535
  if (!data?.length)
7850
8536
  return "";
7851
- return (jsx(ThemeProvider, { children: jsxs(ChartTooltip, { children: [jsx(ChartTooltipColor, { "$color": data[0].color }), jsxs("div", { children: [data[0].name, " \u00A0 ", formatChartRelatedValue(t, data[0].value, layerInfo, relatedAttributes)] })] }) }));
8537
+ return (jsx(ThemeProvider, { children: jsxs(ChartTooltip, { alignItems: "center", children: [jsx(ChartTooltipColor, { "$color": data[0].color }), jsxs("div", { children: [data[0].name, " \u00A0 ", formatChartRelatedValue(t, data[0].value, layerInfo, relatedAttributes)] })] }) }));
7852
8538
  };
7853
8539
 
7854
8540
  const removeDataSource = (dashboardConfiguration, name, pageIndex) => {
@@ -7932,6 +8618,7 @@ const useWidgetPage = (type = WidgetType.Dashboard) => {
7932
8618
  const page = getPagesFromConfig(config)?.[pageIndex - 1];
7933
8619
  return {
7934
8620
  ...(page || {}),
8621
+ header: page?.header || config.header,
7935
8622
  dataSources: [
7936
8623
  ...(page?.dataSources?.filter(({ name }) => !config.dataSources?.some(item => item.name === name)) || []),
7937
8624
  ...(config.dataSources || [])
@@ -8046,12 +8733,29 @@ const useChartData = ({ element, type }) => {
8046
8733
  return { data, loading };
8047
8734
  };
8048
8735
 
8049
- const useDashboardHeader = (renderElement) => {
8736
+ const useHeaderRender = (elementConfig, type = WidgetType.Dashboard) => {
8737
+ const { layerInfo, attributes, expandedContainers, selectedTabId, setSelectedTabId } = useWidgetContext(type);
8738
+ const { config } = useWidgetConfig(type);
8739
+ const { pageIndex } = useWidgetPage(type);
8740
+ return useMemo(() => getRenderElement({
8741
+ config,
8742
+ elementConfig,
8743
+ attributes,
8744
+ layerInfo,
8745
+ expandedContainers,
8746
+ selectedTabId,
8747
+ setSelectedTabId,
8748
+ pageIndex,
8749
+ }), [config, elementConfig, attributes, layerInfo, expandedContainers, selectedTabId, setSelectedTabId, pageIndex]);
8750
+ };
8751
+
8752
+ const useDashboardHeader = () => {
8050
8753
  const { themeName } = useGlobalContext();
8051
8754
  const { projectInfo } = useWidgetContext();
8052
8755
  const { currentPage } = useWidgetPage();
8053
8756
  const { alias, name } = projectInfo || {};
8054
8757
  const { id: pageId, header } = currentPage || {};
8758
+ const renderElement = useHeaderRender(header);
8055
8759
  const image = useMemo(() => (header?.children?.some(({ id }) => id === "image") ? renderElement({ id: "image", wrap: false }) : null), [header?.children, renderElement]);
8056
8760
  const icon = useMemo(() => header?.children?.some(({ id }) => id === "icon") ? (renderElement({ id: "icon", wrap: false })) : (jsx(Icon, { kind: "logo", style: { width: "2rem", height: "2rem" } })), [header?.children, renderElement]);
8057
8761
  const title = useMemo(() => header?.children?.some(({ id }) => id === "title") ? renderElement({ id: "title" }) : currentPage?.options?.title, [header?.children, renderElement, currentPage?.options?.title]);
@@ -8065,6 +8769,7 @@ const useDashboardHeader = (renderElement) => {
8065
8769
  tooltip,
8066
8770
  description,
8067
8771
  themeName,
8772
+ renderElement,
8068
8773
  };
8069
8774
  };
8070
8775
 
@@ -8411,12 +9116,12 @@ const StackBar = ({ data, filterName, type, alias, options, renderElement, rende
8411
9116
  const units = attribute?.stringFormat?.unitsLabel;
8412
9117
  const total = useMemo(() => items?.reduce((result, { value }) => result + Number(value), 0) || 0, [items]);
8413
9118
  const getWidth = useCallback(value => ((Number(value) / total) * 100).toFixed(2), [total]);
8414
- const renderGroupTooltip = useMemo(() => (jsx(ThemeProvider, { children: jsx(ChartTooltipTable, { cellPadding: 0, cellSpacing: 0, children: items?.map(({ name, value, color }, index) => (jsxs("tr", { children: [jsx("td", { children: jsxs(ChartTooltip, { children: [jsx(ChartTooltipColor, { "$color": color }), jsx(ChartTooltipName, { children: name })] }) }), jsx("td", { children: value })] }, index))) }) })), [items]);
9119
+ const renderGroupTooltip = useMemo(() => (jsx(ThemeProvider, { children: jsx(ChartTooltipTable, { cellPadding: 0, cellSpacing: 0, children: items?.map(({ name, value, color }, index) => (jsxs("tr", { children: [jsx("td", { children: jsxs(ChartTooltip, { alignItems: "center", children: [jsx(ChartTooltipColor, { "$color": color }), jsx(ChartTooltipName, { children: name })] }) }), jsx("td", { children: value })] }, index))) }) })), [items]);
8415
9120
  const renderItem = useCallback(({ name, value, color }, ref) => (jsx(StackBarSection, { ref: ref, "$width": getWidth(value), "$height": height, "$color": color, cornerRadius: cornerRadius, hasAnyFilter: hasAnyFilter, isFiltered: isFiltered(name), onClick: filterName ? () => onFilter(name) : undefined })), [cornerRadius, filterName, getWidth, hasAnyFilter, height, isFiltered, onFilter]);
8416
- const renderItems = useMemo(() => (jsx(Fragment$1, { children: items?.map((item, index) => (jsx(Fragment, { children: groupTooltip ? (renderItem(item)) : (jsx(ThemeProvider, { children: jsx(Tooltip, { placement: "top", arrow: true, content: renderTooltip([item]), children: ref => renderItem(item, ref) }) })) }, index))) })), [groupTooltip, items, renderItem, renderTooltip]);
9121
+ const renderItems = useMemo(() => (jsx(Fragment$1, { children: items?.map((item, index) => (jsx(Fragment, { children: groupTooltip ? (renderItem(item)) : (jsx(ThemeProvider, { children: jsx(Tooltip$1, { placement: "top", arrow: true, content: renderTooltip([item]), children: ref => renderItem(item, ref) }) })) }, index))) })), [groupTooltip, items, renderItem, renderTooltip]);
8417
9122
  if (!total || !attribute)
8418
9123
  return null;
8419
- return (jsxs(Fragment$1, { children: [(alias || showTotal) && (jsxs(StackBarHeader, { children: [jsx(StackBarAlias, { children: renderElement({ id: "alias" }) }), showTotal && (jsxs(StackBarTotal, { children: [jsx(StackBarValue, { children: formatAttributeValue({ t, type: attribute.type, value: total, stringFormat: attribute.stringFormat, noUnits: true }) }), !!units && jsx(StackBarUnits, { children: units })] }))] })), groupTooltip ? (jsx(Tooltip, { placement: "top", arrow: true, content: renderGroupTooltip, children: ref => jsx(StackBarContainer, { ref: ref, children: renderItems }) })) : (jsx(StackBarContainer, { children: renderItems }))] }));
9124
+ return (jsxs(Fragment$1, { children: [(alias || showTotal) && (jsxs(StackBarHeader, { children: [jsx(StackBarAlias, { children: renderElement({ id: "alias" }) }), showTotal && (jsxs(StackBarTotal, { children: [jsx(StackBarValue, { children: formatAttributeValue({ t, type: attribute.type, value: total, stringFormat: attribute.stringFormat, noUnits: true }) }), !!units && jsx(StackBarUnits, { children: units })] }))] })), groupTooltip ? (jsx(Tooltip$1, { placement: "top", arrow: true, content: renderGroupTooltip, children: ref => jsx(StackBarContainer, { ref: ref, children: renderItems }) })) : (jsx(StackBarContainer, { children: renderItems }))] }));
8420
9125
  };
8421
9126
 
8422
9127
  const Chart = memo(({ config, element, elementConfig, type, renderElement }) => {
@@ -8444,16 +9149,11 @@ const Chart = memo(({ config, element, elementConfig, type, renderElement }) =>
8444
9149
  const isRelated = !!relatedAttributes?.length;
8445
9150
  const { data, loading } = useChartData({ element, type });
8446
9151
  const totalWidthFromBarWidth = (data[0]?.items?.length || 0) * (barWidth + padding);
8447
- const width = options?.width
8448
- ? options.width > MAX_CHART_WIDTH
8449
- ? MAX_CHART_WIDTH
8450
- : options.width
8451
- : isStackBar
9152
+ const width = options?.width ? options.width :
9153
+ isStackBar
8452
9154
  ? "100%"
8453
9155
  : isBarChart
8454
- ? totalWidthFromBarWidth < MAX_CHART_WIDTH
8455
- ? MAX_CHART_WIDTH
8456
- : totalWidthFromBarWidth
9156
+ ? totalWidthFromBarWidth || MAX_CHART_WIDTH
8457
9157
  : DEFAULT_CHART_WIDTH;
8458
9158
  const [customize] = useChartChange({
8459
9159
  dataSources: config.dataSources,
@@ -8482,13 +9182,13 @@ const Chart = memo(({ config, element, elementConfig, type, renderElement }) =>
8482
9182
  return result?.filter((name, index) => result.indexOf(name) === index);
8483
9183
  }, [data, isLineChart]);
8484
9184
  const renderLineChartTooltip = useCallback((items, { indexX }) => {
8485
- return (jsx(ThemeProvider, { children: jsxs(ChartTooltip, { children: [jsx("div", { children: labels[indexX] }), items
8486
- .filter(({ value }) => !isEmptyValue(value))
8487
- ?.map(({ layerName, attributeName, value, stroke }, index) => {
8488
- const layerInfo = layerInfos?.find(({ name }) => name === layerName);
8489
- const attribute = layerInfo?.layerDefinition.attributes[attributeName];
8490
- return (jsxs(ChartTooltipRow, { children: [jsx(ChartLegendColor$1, { "$color": stroke }), jsx(ChartLegendValue, { children: attribute ? formatAttributeValue({ t, type: attribute.type, value, stringFormat: attribute.stringFormat }) : value })] }, index));
8491
- })] }) }));
9185
+ return (jsxs(Tooltip, { children: [jsx(ChartTooltipLabel, { children: labels[indexX] }), items
9186
+ .filter(({ value }) => !isEmptyValue(value))
9187
+ ?.map(({ layerName, attributeName, value, stroke }, index) => {
9188
+ const layerInfo = layerInfos?.find(({ name }) => name === layerName);
9189
+ const attribute = layerInfo?.layerDefinition.attributes[attributeName];
9190
+ return (jsxs(ChartTooltipRow, { children: [jsx(ChartLegendColor$1, { "$color": stroke }), jsx(ChartLegendValue, { children: attribute ? formatAttributeValue({ t, type: attribute.type, value, stringFormat: attribute.stringFormat }) : value })] }, index));
9191
+ })] }));
8492
9192
  }, [labels, layerInfos]);
8493
9193
  const markers = useMemo(() => getChartMarkers(data[0]?.items, configMarkers), [data, configMarkers]);
8494
9194
  const formatTooltipName = useCallback((name) => (isRelated ? name : tooltipNameFromAttributes(name, formattedAttributes)), [formattedAttributes, isRelated]);
@@ -8512,16 +9212,16 @@ const Chart = memo(({ config, element, elementConfig, type, renderElement }) =>
8512
9212
  .flat()
8513
9213
  .map(({ values }) => values)
8514
9214
  .flat();
8515
- return (jsx(AnyChartWrapper, { height: height, children: jsx(LineChart, { data: lineChartData, labels: labels, width: +width, height: height, xAxisPadding: 15, yAxisPadding: 0, min: Math.min(...chartValues), customYAxisSelection: yAxis => {
8516
- if (isHidedY) {
8517
- yAxis.remove();
8518
- }
8519
- }, customYAxis: yAxis => yAxis.ticks(4), renderTooltip: renderLineChartTooltip, customize: customize, dynamicTooltipEnable: true, stackedTooltip: true, drawGridX: !isHidedY, margin: {
8520
- top: 0,
8521
- right: 0,
8522
- bottom: 0,
8523
- left: 0
8524
- } }) }));
9215
+ return (jsxs(AnyChartWrapper, { height: height, children: [jsx(LineChartTooltipStyles, {}), jsx(LineChart, { data: lineChartData, labels: labels, width: +width, height: height, xAxisPadding: 15, yAxisPadding: 0, min: Math.min(...chartValues), customYAxisSelection: yAxis => {
9216
+ if (isHidedY) {
9217
+ yAxis.remove();
9218
+ }
9219
+ }, customYAxis: yAxis => yAxis.ticks(4), renderTooltip: renderLineChartTooltip, customize: customize, dynamicTooltipEnable: true, stackedTooltip: true, tooltipClassName: "dashboardLineChartTooltip", drawGridX: !isHidedY, margin: {
9220
+ top: 0,
9221
+ right: 0,
9222
+ bottom: 0,
9223
+ left: 0
9224
+ } })] }));
8525
9225
  }
8526
9226
  if (isStackBar) {
8527
9227
  return (jsx(AnyChartWrapper, { height: height, children: jsx(StackBar, { data: data, filterName: filterName, type: type, alias: elementConfig?.children?.find(child => child.id === "alias"), options: options, renderTooltip: renderPieChartTooltip, renderElement: renderElement }) }));
@@ -8534,16 +9234,17 @@ const Chart = memo(({ config, element, elementConfig, type, renderElement }) =>
8534
9234
  color: formatFilterColor(item.name, item.color, defaultColor)
8535
9235
  })) || []), width: +width, height: +width, padAngle: angle, outerRadius: radius, cornerRadius: cornerRadius, renderTooltip: renderPieChartTooltip, withTooltip: true, onClick: filterName ? item => onFilter(item.name) : undefined, children: showTotal && jsx(PieChartCenter, { children: totalWord || roundTotalSum(+totalSum) }) }) }));
8536
9236
  }
9237
+ const markersMargin = options?.showMarkers ? 10 : 0;
8537
9238
  const margin = {
8538
- top: 0,
8539
- right: 0,
8540
- bottom: markers?.length ? 20 : 0,
8541
- left: 0
9239
+ top: markersMargin,
9240
+ right: markersMargin,
9241
+ bottom: markers?.length ? 20 : markersMargin,
9242
+ left: markersMargin
8542
9243
  };
8543
- return (jsx(BarChartWrapper, { height: height + margin.bottom, children: jsx(BarChartContainer, { children: jsx(BarChart$1, { data: getDataFromFilterItems(data[0]?.items), colors: getColorsFromFilterItems(data[0]?.items, defaultColor, formatFilterColor), minValue: getMinValueFromFilterItems(data[0]?.items), markers: markers, width: +width, height: height, barWidth: barWidth, barPadding: padding, customXAxis: axis => axis.remove(), customYAxis: axis => axis.remove(), customBars: ({ bars }) => {
8544
- bars.attr("rx", radius);
8545
- bars.attr("ry", radius);
8546
- }, margin: margin, xAxisPadding: 0, yAxisPadding: 0, formatTooltipValue: formatTooltipValue, formatTooltipName: formatTooltipName, onBarClick: filterName ? item => onFilter(item.name) : undefined, hideTooltipGroupName: true, dynamicTooltipEnable: true, isBarTooltip: true }) }) }));
9244
+ return (jsx(BarChartWrapper, { height: height + margin.bottom, children: jsxs(BarChartContainer, { children: [jsx(BarChartStyles, {}), jsx(BarChart$1, { data: getDataFromFilterItems(data[0]?.items), colors: getColorsFromFilterItems(data[0]?.items, defaultColor, formatFilterColor), minValue: getMinValueFromFilterItems(data[0]?.items), markers: markers, width: +width, height: height, barWidth: barWidth, barPadding: padding, className: "dashboardBarChart", customXAxis: axis => axis.remove(), customYAxis: axis => !options?.showMarkers && axis.remove(), customBars: ({ bars }) => {
9245
+ bars.attr("rx", radius);
9246
+ bars.attr("ry", radius);
9247
+ }, margin: margin, xAxisPadding: 0, yAxisPadding: 0, formatTooltipValue: formatTooltipValue, formatTooltipName: formatTooltipName, hideTooltipGroupName: true, dynamicTooltipEnable: true, isBarTooltip: true, onBarClick: filterName ? item => onFilter(item.name) : undefined })] }) }));
8547
9248
  }, [
8548
9249
  element,
8549
9250
  isLineChart,
@@ -8592,7 +9293,7 @@ const ChartLegend = ({ data, chartElement, type, twoColumns, loading }) => {
8592
9293
  const showMoreBtn = !!shownItems && data.length > shownItems;
8593
9294
  if (!loading && !data?.length && !!hideEmpty)
8594
9295
  return null;
8595
- return (jsxs(Flex, { opacity: loading ? FILTERED_VALUE_OPACITY / 100 : 1, children: [jsx(ChartLegendContainer, { twoColumns: twoColumns, children: sliceItems(data)?.map(({ name, color }, index) => (jsxs(ChartLegendItem, { hasAnyFilter: hasAnyFilter, isFiltered: isFiltered(name), onClick: axes?.[0]?.filterName ? () => onFilter(name) : undefined, children: [jsx(ChartLegendColor, { color: color }), jsx(ChartLegendName, { "$fontColor": fontColor, children: name })] }, index))) }), showMoreBtn && (jsx(LegendToggler, { onClick: onShowMore, toggled: showMore, children: t("other", { ns: "dashboard" }) }))] }));
9296
+ return (jsxs(Flex, { flexDirection: "column", opacity: loading ? FILTERED_VALUE_OPACITY / 100 : 1, children: [jsx(ChartLegendContainer, { twoColumns: twoColumns, children: sliceItems(data)?.map(({ name, color }, index) => (jsxs(ChartLegendItem, { hasAnyFilter: hasAnyFilter, isFiltered: isFiltered(name), onClick: axes?.[0]?.filterName ? () => onFilter(name) : undefined, children: [jsx(ChartLegendColor, { color: color }), jsx(ChartLegendName, { "$fontColor": fontColor, children: name })] }, index))) }), showMoreBtn && (jsx(LegendToggler, { onClick: onShowMore, toggled: showMore, children: t("other", { ns: "dashboard" }) }))] }));
8596
9297
  };
8597
9298
 
8598
9299
  const ContainerChildren = memo(({ items, isColumn, isMain, renderElement }) => {
@@ -8633,6 +9334,12 @@ const DashboardCheckbox = ({ title, checked, onChange, }) => {
8633
9334
  return (jsxs(Fragment$1, { children: [jsx(AttributeLabel, { isEdit: !!onChange, forCheckbox: !!onChange, children: title }), onChange ? jsx(CardCheckbox, { checked: checked, label: label, onChange: onChange }) : label] }));
8634
9335
  };
8635
9336
 
9337
+ const DashboardHeader = memo(() => {
9338
+ const { currentPage } = useWidgetPage();
9339
+ const HeaderTemplate = useMemo(() => getDashboardHeader(currentPage?.header?.templateName), [currentPage?.header?.templateName]);
9340
+ return jsx(HeaderTemplate, {});
9341
+ });
9342
+
8636
9343
  const DataSourceError = ({ name }) => {
8637
9344
  const { t } = useGlobalContext();
8638
9345
  return (jsxs(DataSourceErrorContainer, { children: [jsx(Icon, { kind: "alert" }), jsxs("div", { children: [t("block", { ns: "dashboard" }), " \"", name, "\" ", t("isNotLoaded", { ns: "dashboard" })] })] }));
@@ -8649,6 +9356,50 @@ const ExpandableTitle = memo(({ elementConfig, type, renderElement }) => {
8649
9356
  return (jsx(TitleContainer, { containerId: id, elementConfig: titleElement, templateName: templateName, layerNames: layerNames, fontColor: fontColor, expandable: expandable, expanded: expanded, type: type, isVisible: isVisible, renderElement: renderElement }));
8650
9357
  });
8651
9358
 
9359
+ const FeatureCardButtons = () => {
9360
+ const { closeFeatureCard } = useWidgetContext(WidgetType.FeatureCard);
9361
+ return (jsx(FlexSpan, { children: jsx(IconButton, { kind: "close", style: {
9362
+ padding: 0,
9363
+ width: "1rem",
9364
+ }, onClick: closeFeatureCard }) }));
9365
+ };
9366
+
9367
+ const FeatureCardHeader = () => {
9368
+ const { currentPage } = useWidgetPage(WidgetType.FeatureCard);
9369
+ const HeaderTemplate = getFeatureCardHeader(currentPage?.header?.templateName);
9370
+ return jsx(HeaderTemplate, {});
9371
+ };
9372
+
9373
+ const FeatureCardTitle = ({ title, description }) => {
9374
+ const { t } = useGlobalContext();
9375
+ const { attributes, layerInfo, feature } = useWidgetContext(WidgetType.FeatureCard);
9376
+ const zoomToFeatures = useZoomToFeatures();
9377
+ const { alias, name, layerDefinition, titleAttribute } = layerInfo || {};
9378
+ const resultDescription = description || alias || name || "";
9379
+ const resultTitle = useMemo(() => {
9380
+ const layerDefinitionAttribute = layerDefinition && attributes?.length
9381
+ ? attributes.find(item => item.name === layerDefinition.titleAttribute)
9382
+ : null;
9383
+ const layerDefinitionTitle = layerDefinition?.titleAttribute && layerDefinitionAttribute?.value
9384
+ ? layerDefinitionAttribute.value
9385
+ : null;
9386
+ const sourceTitleAttribute = titleAttribute && attributes?.length ? attributes.find(item => item.name === titleAttribute) : null;
9387
+ const sourceTitle = titleAttribute && sourceTitleAttribute?.value ? sourceTitleAttribute.value : null;
9388
+ return (title ||
9389
+ (!!sourceTitle &&
9390
+ formatAttributeValue({ t, type: sourceTitleAttribute.type, value: sourceTitle, stringFormat: sourceTitleAttribute.stringFormat })) ||
9391
+ (!!layerDefinitionTitle &&
9392
+ formatAttributeValue({
9393
+ t,
9394
+ type: layerDefinitionAttribute.type,
9395
+ value: layerDefinitionTitle,
9396
+ stringFormat: layerDefinitionAttribute.stringFormat,
9397
+ })) ||
9398
+ feature?.id);
9399
+ }, [attributes, feature?.id, layerDefinition, title, titleAttribute]);
9400
+ return (jsxs(HeaderTitleContainer, { children: [jsx(FeatureTitleContainer, { clickable: true, children: jsx(Tooltip$1, { arrow: true, placement: "top", content: t("zoomToFeature", { ns: "dashboard" }), delay: [600, 0], children: ref => (jsx(FlexSpan, { ref: ref, onClick: () => zoomToFeatures([feature]), children: resultTitle })) }) }), jsx(LayerDescription, { title: resultDescription, children: resultDescription })] }));
9401
+ };
9402
+
8652
9403
  const HiddenFilters = styled(Flex) `
8653
9404
  flex-wrap: wrap;
8654
9405
  margin-top: -1.25rem;
@@ -8747,7 +9498,7 @@ const PageNavigator = styled(Flex) `
8747
9498
  }
8748
9499
  `;
8749
9500
 
8750
- const Pagination = memo(({ type }) => {
9501
+ const Pagination = memo(({ type = WidgetType.Dashboard }) => {
8751
9502
  const { nextPage, prevPage } = useWidgetContext(type);
8752
9503
  const { pages } = useWidgetConfig(type);
8753
9504
  return (jsxs(PageNavigator, { children: [jsx(IconButton, { kind: "prev", onClick: () => prevPage(pages.length) }), jsx(IconButton, { kind: "next", onClick: () => nextPage(pages.length) })] }));
@@ -8820,7 +9571,7 @@ const TextTrim = memo(({ maxLength, expandable, lineBreak, children }) => {
8820
9571
  if (expandable) {
8821
9572
  return (jsxs(Fragment$1, { children: [formatValue(expanded ? text : substring), jsx(LegendToggler, { toggled: expanded, onClick: toggleExpanded, children: expanded ? t("hide", { ns: "dashboard" }) : t("more", { ns: "dashboard" }) })] }));
8822
9573
  }
8823
- return (jsx(Tooltip, { placement: "top", arrow: true, content: text, children: ref => jsx("div", { ref: ref, children: formatValue(substring) }) }));
9574
+ return (jsx(Tooltip$1, { placement: "top", arrow: true, content: text, children: ref => jsx("div", { ref: ref, children: formatValue(substring) }) }));
8824
9575
  });
8825
9576
 
8826
9577
  const DEFAULT_COLOR = "#00ffff";
@@ -9040,22 +9791,5 @@ const Map$1 = ({ zIndex, lowerSiblings, upperSiblings, onError, children, ...res
9040
9791
  }, children: children }), upperSiblings] }));
9041
9792
  };
9042
9793
 
9043
- var ThemeName;
9044
- (function (ThemeName) {
9045
- ThemeName["Light"] = "light";
9046
- ThemeName["Dark"] = "dark";
9047
- })(ThemeName || (ThemeName = {}));
9048
-
9049
- var TmsType;
9050
- (function (TmsType) {
9051
- TmsType["WMS"] = "WMS";
9052
- TmsType["TMS"] = "TMS";
9053
- TmsType["ArcGIS"] = "ArcGIS";
9054
- })(TmsType || (TmsType = {}));
9055
- var EditGeometryType;
9056
- (function (EditGeometryType) {
9057
- EditGeometryType["Raster"] = "raster";
9058
- })(EditGeometryType || (EditGeometryType = {}));
9059
-
9060
- export { AddFeatureButton, AddFeatureContainer, AttributeGalleryContainer, AttributeLabel, BaseMapTheme, CONFIG_PAGES_ID, CONFIG_PAGE_ID, CameraContainer, Chart, ChartContainer, ChartLegend, ChartLoading, ConfigContext, ConfigProvider, ContainerChildren, ContainerLoading, ContainerTemplate, ContainerWrapper, ContainersGroupContainer, DEFAULT_ATTRIBUTE_NAME, DEFAULT_BARCHART_RADIUS, DEFAULT_BASE_MAP, DEFAULT_CHART_ANGLE, DEFAULT_CHART_HEIGHT, DEFAULT_CHART_WIDTH, DEFAULT_CIRCLE_PAINT, DEFAULT_DASHBOARD_CONFIG, DEFAULT_DATA_SOURCE_LIMIT, DEFAULT_FILL_EXTRUSION_PAINT, DEFAULT_FILL_PAINT, DEFAULT_ID_ATTRIBUTE_NAME, DEFAULT_LAT, DEFAULT_LINE_PAINT, DEFAULT_LNG, DEFAULT_PAGES_CONFIG, DEFAULT_PIECHART_RADIUS, DEFAULT_ZOOM, Dashboard, DashboardCheckbox, DashboardChip, DashboardContent, DashboardContext, DashboardPlaceholder, DashboardPlaceholderWrap, DashboardProvider, DashboardWrapper, DataSourceContainer, DataSourceError, DataSourceErrorContainer, DataSourceInnerContainer, DataSourceProgressContainer, DateFormat, DefaultAttributesContainer, DividerContainer, EditGeometryType, ElementButton, ElementCamera, ElementChart, ElementChips, ElementIcon, ElementImage, ElementLegend, ElementLink, ElementSlideshow, ElementSvg, ElementTooltip, ElementValueWrapper, ExpandableTitle, FEATURE_CARD_DEFAULT_COLORS, FEATURE_CARD_OTHER_COLOR, FILTERED_VALUE_OPACITY, FILTER_PREFIX, FeatureCardContext, FeatureCardProvider, FiltersContainer, GEOMETRY_ATTRIBUTE, GlobalContext, GlobalProvider, HeaderTemplate, HiddenTitleItems, IconContainer, ImageContainer, LEFT_PANEL_HEADER_HEIGHT, Layer, LayerGroup, LayerGroupList, LayerListContainer, LayerTree, LayersContainer, LayersListWrapper, LinearProgressContainer, MAX_CHART_WIDTH, Map$1 as Map, MapContext, MapProvider, NO_CONTENT_VALUE, NUMERIC_ATTRIBUTE_TYPES, NoLiveSnapshotContainer, OneColumnContainer, PageNavigator, PagesContainer, Pagination, PresentationHeader, PresentationHeaderButtons, PresentationHeaderTools, PresentationPanelContainer, PresentationPanelWrapper, PresentationWrapper, ProgressContainer, RoundedBackgroundContainer, ScalingFactor, ServerNotificationsContext, ServerNotificationsProvider, SlideshowContainer, SmallPreviewContainer, SmallPreviewControl, SmallPreviewCounter, SmallPreviewImages, SmallPreviewLeft, SmallPreviewRight, StackBar, SvgImage, TIME_ZONE_FORMAT, TabsContainer, TextTrim, ThemeName, TitleContainer, TmsType, TwoColumnContainer, TwoColumnsInnerContainer, WidgetType, addDataSource, addDataSources, applyFiltersToCondition, applyQueryFilters, applyVarsToCondition, checkEqualOrIncludes, checkIsLoading, convertSpToTurfFeature, createConfigLayer, createConfigPage, createNewPageId, createTreeNode, dateOptions, debounce, decimalOpacityToHex, eqlParametersToPayload, findAttributeInExpression, formatArea, formatAttributeValue, formatChartRelatedValue, formatConditionValue, formatDataSourceCondition, formatDate$1 as formatDate, formatElementValue, formatLength, formatNumber, formatPolygonMeasure, getActualExtrusionHeight, getAttributeByName, getAttributeValue, getAttributesConfiguration, getChartFilterName, getChartMarkers, getConfigFilter, getContainerComponent, getDataFromAttributes, getDataFromRelatedFeatures, getDataSource, getDataSourceFilterValue, getDate, getDefaultConfig, getElementValue, getFeatureAttributes, getFilterComponent, getFilterSelectedItems, getFilterValue, getFormattedAttributes, getGradientColors, getLayerDefinition, getLayerInfoFromDataSources, getPagesFromConfig, getPagesFromProjectInfo, getRelatedAttribute, getRenderElement, getResourceUrl, getSelectedFilterValue, getSlideshowImages, getSvgUrl, getTotalFromAttributes, getTotalFromRelatedFeatures, hexToRgba, isEmptyElementValue, isEmptyValue, isHiddenEmptyValue, isLayerService, isNotValidSelectedTab, isNumeric, isObject, isVisibleContainer, numberOptions, parseClientStyle, pieChartTooltipFromAttributes, pieChartTooltipFromRelatedFeatures, pointOptions, removeDataSource, rgbToHex, roundTotalSum, sliceShownOtherItems, timeOptions, tooltipNameFromAttributes, tooltipValueFromAttributes, tooltipValueFromRelatedFeatures, transparentizeColor, treeNodesToProjectItems, useChartChange, useChartData, useDashboardHeader, useDataSources, useDebouncedCallback, useDiffPage, useExpandableContainers, useFeatureFilters, useGetConfigLayer, useGlobalContext, useLayerParams, useMapContext, useMapDraw, useProjectDashboardInit, useRedrawLayer, useRelatedDataSourceAttributes, useRenderElement, useServerNotificationsContext, useShownOtherItems, useToggle, useUpdateDataSource, useWidgetConfig, useWidgetContext, useWidgetPage, useWindowResize, useZoomToFeatures, useZoomToPoint };
9794
+ export { AddFeatureButton, AddFeatureContainer, AttributeGalleryContainer, AttributeLabel, BaseMapTheme, CONFIG_PAGES_ID, CONFIG_PAGE_ID, CameraContainer, Chart, ChartContainer, ChartLegend, ChartLoading, ConfigContext, ConfigProvider, ContainerChildren, ContainerLoading, ContainerTemplate, ContainerWrapper, ContainersGroupContainer, DEFAULT_ATTRIBUTE_NAME, DEFAULT_BARCHART_RADIUS, DEFAULT_BASE_MAP, DEFAULT_CHART_ANGLE, DEFAULT_CHART_HEIGHT, DEFAULT_CHART_WIDTH, DEFAULT_CIRCLE_PAINT, DEFAULT_DASHBOARD_CONFIG, DEFAULT_DATA_SOURCE_LIMIT, DEFAULT_FILL_EXTRUSION_PAINT, DEFAULT_FILL_PAINT, DEFAULT_ID_ATTRIBUTE_NAME, DEFAULT_LAT, DEFAULT_LINE_PAINT, DEFAULT_LNG, DEFAULT_PAGES_CONFIG, DEFAULT_PIECHART_RADIUS, DEFAULT_ZOOM, Dashboard, DashboardCheckbox, DashboardChip, DashboardContent, DashboardContext, DashboardDefaultHeader, DashboardHeader, DashboardPlaceholder, DashboardPlaceholderWrap, DashboardProvider, DashboardWrapper, DataSourceContainer, DataSourceError, DataSourceErrorContainer, DataSourceInnerContainer, DataSourceProgressContainer, DateFormat, DefaultAttributesContainer, DefaultHeaderContainer, DividerContainer, EditGeometryType, ElementButton, ElementCamera, ElementChart, ElementChips, ElementIcon, ElementImage, ElementLegend, ElementLink, ElementSlideshow, ElementSvg, ElementTooltip, ElementValueWrapper, ExpandableTitle, FEATURE_CARD_DEFAULT_COLORS, FEATURE_CARD_OTHER_COLOR, FILTERED_VALUE_OPACITY, FILTER_PREFIX, FeatureCardButtons, FeatureCardContext, FeatureCardDefaultHeader, FeatureCardGradientHeader, FeatureCardHeader, FeatureCardIconHeader, FeatureCardProvider, FeatureCardSlideshowHeader, FeatureCardTitle, FeatureControls, FeatureTitleContainer, FiltersContainer, GEOMETRY_ATTRIBUTE, GlobalContext, GlobalProvider, Header, HeaderContainer, HeaderFrontView, HeaderTemplate, HeaderTitleContainer, HiddenTitleItems, IconContainer, ImageContainer, LEFT_PANEL_HEADER_HEIGHT, Layer, LayerDescription, LayerGroup, LayerGroupList, LayerIcon, LayerListContainer, LayerTree, LayersContainer, LayersListWrapper, LinearProgressContainer, LogoContainer, MAX_CHART_WIDTH, Map$1 as Map, MapContext, MapProvider, NO_CONTENT_VALUE, NUMERIC_ATTRIBUTE_TYPES, NoLiveSnapshotContainer, OneColumnContainer, PageNavigator, PageTitle, PagesContainer, Pagination, PresentationHeader, PresentationHeaderButtons, PresentationHeaderTools, PresentationPanelContainer, PresentationPanelWrapper, PresentationWrapper, ProgressContainer, RoundedBackgroundContainer, ScalingFactor, ServerNotificationsContext, ServerNotificationsProvider, SlideshowContainer, SmallPreviewContainer$1 as SmallPreviewContainer, SmallPreviewControl, SmallPreviewCounter, SmallPreviewImages, SmallPreviewLeft, SmallPreviewRight, StackBar, SvgImage, TIME_ZONE_FORMAT, TabsContainer, TextTrim, ThemeName, TitleContainer, TmsType, TopContainer, TopContainerButtons, TwoColumnContainer, TwoColumnsInnerContainer, WidgetType, addDataSource, addDataSources, applyFiltersToCondition, applyQueryFilters, applyVarsToCondition, checkEqualOrIncludes, checkIsLoading, convertSpToTurfFeature, createConfigLayer, createConfigPage, createNewPageId, createTreeNode, dateOptions, debounce, decimalOpacityToHex, eqlParametersToPayload, findAttributeInExpression, formatArea, formatAttributeValue, formatChartRelatedValue, formatConditionValue, formatDataSourceCondition, formatDate$1 as formatDate, formatElementValue, formatLength, formatNumber, formatPolygonMeasure, getActualExtrusionHeight, getAttributeByName, getAttributeValue, getAttributesConfiguration, getChartFilterName, getChartMarkers, getConfigFilter, getContainerComponent, getDashboardHeader, getDataFromAttributes, getDataFromRelatedFeatures, getDataSource, getDataSourceFilterValue, getDate, getDefaultConfig, getElementValue, getFeatureAttributes, getFeatureCardHeader, getFilterComponent, getFilterSelectedItems, getFilterValue, getFormattedAttributes, getGradientColors, getLayerDefinition, getLayerInfoFromDataSources, getPagesFromConfig, getPagesFromProjectInfo, getRelatedAttribute, getRenderElement, getResourceUrl, getSelectedFilterValue, getSlideshowImages, getSvgUrl, getTotalFromAttributes, getTotalFromRelatedFeatures, hexToRgba, isEmptyElementValue, isEmptyValue, isHiddenEmptyValue, isLayerService, isNotValidSelectedTab, isNumeric, isObject, isVisibleContainer, numberOptions, parseClientStyle, pieChartTooltipFromAttributes, pieChartTooltipFromRelatedFeatures, pointOptions, removeDataSource, rgbToHex, roundTotalSum, sliceShownOtherItems, timeOptions, tooltipNameFromAttributes, tooltipValueFromAttributes, tooltipValueFromRelatedFeatures, transparentizeColor, treeNodesToProjectItems, useChartChange, useChartData, useDashboardHeader, useDataSources, useDebouncedCallback, useDiffPage, useExpandableContainers, useFeatureFilters, useGetConfigLayer, useGlobalContext, useHeaderRender, useLayerParams, useMapContext, useMapDraw, useProjectDashboardInit, useRedrawLayer, useRelatedDataSourceAttributes, useRenderElement, useServerNotificationsContext, useShownOtherItems, useToggle, useUpdateDataSource, useWidgetConfig, useWidgetContext, useWidgetPage, useWindowResize, useZoomToFeatures, useZoomToPoint };
9061
9795
  //# sourceMappingURL=react.esm.js.map