@evergis/react 3.1.14 → 3.1.15

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 (40) hide show
  1. package/dist/components/Dashboard/components/DashboardHeader/index.d.ts +3 -0
  2. package/dist/components/Dashboard/components/FeatureCardButtons/index.d.ts +2 -0
  3. package/dist/components/Dashboard/components/FeatureCardHeader/index.d.ts +2 -0
  4. package/dist/components/Dashboard/components/FeatureCardTitle/index.d.ts +5 -0
  5. package/dist/components/Dashboard/components/Pagination/index.d.ts +1 -1
  6. package/dist/components/Dashboard/components/index.d.ts +4 -0
  7. package/dist/components/Dashboard/headers/DashboardDefaultHeader/index.d.ts +3 -0
  8. package/dist/components/Dashboard/headers/DashboardDefaultHeader/styled.d.ts +8 -0
  9. package/dist/components/Dashboard/headers/FeatureCardDefaultHeader/components/HeaderTitle.d.ts +4 -0
  10. package/dist/components/Dashboard/headers/FeatureCardDefaultHeader/index.d.ts +5 -0
  11. package/dist/components/Dashboard/headers/FeatureCardDefaultHeader/styled.d.ts +12 -0
  12. package/dist/components/Dashboard/headers/FeatureCardGradientHeader/index.d.ts +3 -0
  13. package/dist/components/Dashboard/headers/FeatureCardGradientHeader/styled.d.ts +4 -0
  14. package/dist/components/Dashboard/headers/FeatureCardIconHeader/index.d.ts +3 -0
  15. package/dist/components/Dashboard/headers/FeatureCardIconHeader/styled.d.ts +6 -0
  16. package/dist/components/Dashboard/headers/FeatureCardSlideshowHeader/index.d.ts +3 -0
  17. package/dist/components/Dashboard/headers/FeatureCardSlideshowHeader/styled.d.ts +8 -0
  18. package/dist/components/Dashboard/headers/index.d.ts +7 -0
  19. package/dist/components/Dashboard/hooks/index.d.ts +1 -0
  20. package/dist/components/Dashboard/hooks/useDashboardHeader.d.ts +2 -2
  21. package/dist/components/Dashboard/hooks/useGlobalContext.d.ts +0 -1
  22. package/dist/components/Dashboard/hooks/useHeaderRender.d.ts +2 -0
  23. package/dist/components/Dashboard/hooks/useWidgetContext.d.ts +8 -0
  24. package/dist/components/Dashboard/index.d.ts +1 -0
  25. package/dist/components/Dashboard/styled.d.ts +1 -0
  26. package/dist/components/Dashboard/utils/getDashboardHeader.d.ts +2 -0
  27. package/dist/components/Dashboard/utils/getFeatureCardHeader.d.ts +2 -0
  28. package/dist/components/Dashboard/utils/index.d.ts +2 -0
  29. package/dist/components/LayerIcon/index.d.ts +5 -0
  30. package/dist/components/LayerIcon/styled.d.ts +2 -0
  31. package/dist/components/LayerTree/types.d.ts +0 -2
  32. package/dist/components/index.d.ts +1 -0
  33. package/dist/contexts/DashboardContext/types.d.ts +8 -2
  34. package/dist/contexts/FeatureCardContext/types.d.ts +3 -1
  35. package/dist/contexts/GlobalContext/types.d.ts +1 -3
  36. package/dist/index.js +1342 -707
  37. package/dist/index.js.map +1 -1
  38. package/dist/react.esm.js +1038 -428
  39. package/dist/react.esm.js.map +1 -1
  40. package/package.json +2 -2
package/dist/react.esm.js CHANGED
@@ -1,5 +1,5 @@
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, 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
4
  import styled, { css, useTheme } from 'styled-components';
5
5
  import { lineChartClassNames, barChartClassNames, BarChart as BarChart$1, LineChart, PieChart } from '@evergis/charts';
@@ -3800,8 +3800,8 @@ const ServerNotificationsProvider = ({ url, initialized, children }) => {
3800
3800
  };
3801
3801
 
3802
3802
  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) || {};
3803
+ 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) || {};
3804
+ 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
3805
  return {
3806
3806
  projectInfo,
3807
3807
  layerInfos,
@@ -3811,6 +3811,9 @@ const useWidgetContext = (type = WidgetType.Dashboard) => {
3811
3811
  geometryFilter,
3812
3812
  layerInfo,
3813
3813
  attributes,
3814
+ feature,
3815
+ closeFeatureCard,
3816
+ components: dashboardComponents,
3814
3817
  isLoading: type === WidgetType.Dashboard ? projectLoading : featureLoading,
3815
3818
  pageIndex: type === WidgetType.Dashboard ? projectPageIndex : featurePageIndex,
3816
3819
  filters: type === WidgetType.Dashboard ? projectFilters : featureFilters,
@@ -3827,15 +3830,14 @@ const useWidgetContext = (type = WidgetType.Dashboard) => {
3827
3830
  };
3828
3831
 
3829
3832
  const useGlobalContext = () => {
3830
- const { t, language, themeName, api, ewktGeometry, LayerItemComponent } = useContext(GlobalContext) || {};
3833
+ const { t, language, themeName, api, ewktGeometry } = useContext(GlobalContext) || {};
3831
3834
  return useMemo(() => ({
3832
3835
  t,
3833
3836
  language,
3834
3837
  themeName,
3835
3838
  api,
3836
3839
  ewktGeometry,
3837
- LayerItemComponent,
3838
- }), [language, t, api, ewktGeometry, themeName, LayerItemComponent]);
3840
+ }), [language, t, api, ewktGeometry, themeName]);
3839
3841
  };
3840
3842
 
3841
3843
  const HEIGHT_OFFSET = 20;
@@ -4942,10 +4944,10 @@ const treeNodesToProjectItems = (currentProjectItems, treeNodes) => {
4942
4944
  return combineProjectItems(treeNodes);
4943
4945
  };
4944
4946
 
4945
- const LayerTree = ({ layers, LayerItemComponent, onlyMainTools }) => {
4946
- const { projectInfo, updateProject } = useWidgetContext();
4947
+ const LayerTree = ({ layers, onlyMainTools }) => {
4948
+ const { projectInfo, updateProject, components: { LayerItem } } = useWidgetContext();
4947
4949
  const { pageIndex } = useWidgetPage();
4948
- const nodes = useMemo(() => layers?.map(layer => createTreeNode(layer, LayerItemComponent, onlyMainTools)), [LayerItemComponent, layers, onlyMainTools]);
4950
+ const nodes = useMemo(() => layers?.map(layer => createTreeNode(layer, LayerItem, onlyMainTools)), [LayerItem, layers, onlyMainTools]);
4949
4951
  const onUpdate = useCallback((updatedNodes) => {
4950
4952
  const newProjectInfo = JSON.parse(JSON.stringify(projectInfo));
4951
4953
  const page = getPagesFromProjectInfo(newProjectInfo)?.[pageIndex - 1];
@@ -5227,6 +5229,18 @@ const AttributeLabel = styled(Description) `
5227
5229
  margin-bottom: ${({ forCheckbox }) => (forCheckbox ? "0.75rem" : "0.25rem")} !important;
5228
5230
  padding-left: ${({ isEdit }) => (isEdit ? "0.5rem" : "0")};
5229
5231
  `;
5232
+ const FeatureControls = styled(Flex) `
5233
+ align-items: center;
5234
+ gap: 1rem;
5235
+ flex-wrap: nowrap;
5236
+ position: relative;
5237
+ flex-shrink: 0;
5238
+
5239
+ button {
5240
+ padding: 0;
5241
+ width: auto;
5242
+ }
5243
+ `;
5230
5244
 
5231
5245
  const getAttributeByName = (attributeName, attributes) => {
5232
5246
  return Array.isArray(attributeName)
@@ -5862,7 +5876,7 @@ const TwoColumnsInnerContainer = memo(({ renderElement }) => {
5862
5876
  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
5877
  });
5864
5878
 
5865
- const ImageContainerBg = styled.div `
5879
+ const ImageContainerBg$1 = styled.div `
5866
5880
  position: absolute;
5867
5881
  top: 0;
5868
5882
  bottom: 0;
@@ -5924,7 +5938,7 @@ const ImageContainerWrapper = styled(Flex) `
5924
5938
 
5925
5939
  const ImageContainer = memo(({ elementConfig, renderElement }) => {
5926
5940
  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" }) })] }));
5941
+ 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
5942
  });
5929
5943
 
5930
5944
  const IconContainerWrapper = styled(Flex) `
@@ -6370,7 +6384,6 @@ const LayersContainerWrapper = styled(Container) `
6370
6384
  `;
6371
6385
 
6372
6386
  const LayersContainer = memo(({ type, elementConfig, renderElement }) => {
6373
- const { LayerItemComponent } = useGlobalContext();
6374
6387
  const { expandedContainers } = useWidgetContext(type);
6375
6388
  const { currentPage } = useWidgetPage(type);
6376
6389
  const { id, options, style } = elementConfig || {};
@@ -6383,7 +6396,7 @@ const LayersContainer = memo(({ type, elementConfig, renderElement }) => {
6383
6396
  return currentPage.layers;
6384
6397
  return currentPage.layers.filter(({ name }) => layerNames.includes(name));
6385
6398
  }, [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 }) }))] }));
6399
+ 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
6400
  });
6388
6401
 
6389
6402
  const containerComponents = {
@@ -6412,197 +6425,520 @@ const containerComponents = {
6412
6425
 
6413
6426
  const getContainerComponent = (innerTemplateName) => innerTemplateName ? containerComponents[innerTemplateName] || containerComponents.default : null;
6414
6427
 
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
- `;
6428
+ var img$3 = "";
6542
6429
 
6543
- const AttributeGalleryContainer = styled.div `
6544
- && {
6545
- width: calc(100% + 3rem);
6546
- }
6430
+ const getMaskColor = (isDark) => (isDark ? "0, 0, 0" : "255, 255, 255");
6431
+ const DefaultHeaderContainer = styled(Flex) `
6432
+ flex-direction: column;
6433
+ position: relative;
6434
+ flex-shrink: 0;
6435
+ min-height: 8.375rem;
6436
+ margin-bottom: -1.5rem;
6437
+ padding: 1.5rem 1.5rem 0;
6438
+ border-top-left-radius: 0.5rem;
6439
+ border-top-right-radius: 0.5rem;
6440
+ overflow: hidden;
6547
6441
 
6548
- min-height: 12.625rem;
6549
- background-color: ${({ theme: { palette } }) => palette.element};
6442
+ > * {
6443
+ z-index: 1;
6444
+ }
6550
6445
 
6551
- img {
6446
+ &::before {
6447
+ content: "";
6448
+ position: absolute;
6449
+ top: 0;
6450
+ left: 0;
6552
6451
  width: 100%;
6452
+ height: 100%;
6453
+
6454
+ ${({ image, isDark }) => image
6455
+ ? css `
6456
+ background: url(${image}) 0 0 no-repeat;
6457
+ background-size: cover;
6458
+ `
6459
+ : css `
6460
+ background: url(${img$3}) 50% 0 no-repeat;
6461
+ opacity: ${isDark ? 1 : 0.5};
6462
+ `}
6553
6463
  }
6554
- `;
6555
- const LinearProgressContainer = styled(Flex) `
6556
- align-items: center;
6557
- justify-content: center;
6558
- min-height: inherit;
6559
6464
 
6465
+ ${({ image, isDark }) => image &&
6466
+ css `
6467
+ &::before {
6468
+ -webkit-mask-image: linear-gradient(
6469
+ to bottom,
6470
+ rgba(${getMaskColor(isDark)}, 1),
6471
+ rgba(${getMaskColor(isDark)}, 0)
6472
+ );
6473
+ mask-image: linear-gradient(to bottom, rgba(${getMaskColor(isDark)}, 1), rgba(${getMaskColor(isDark)}, 0));
6474
+ }
6475
+ `}
6560
6476
  ${LinearProgress} {
6561
- max-width: 4rem;
6477
+ position: absolute;
6478
+ top: 0;
6479
+ left: 0;
6562
6480
  }
6563
6481
  `;
6564
- const NoLiveSnapshotContainer = styled(Flex) `
6565
- flex-direction: column;
6482
+ const TopContainer = styled(Flex) `
6483
+ z-index: 1;
6484
+ position: relative;
6485
+ justify-content: space-between;
6486
+ flex-wrap: nowrap;
6487
+ width: 100%;
6488
+ align-items: flex-start;
6489
+ `;
6490
+ const TopContainerButtons = styled(Flex) `
6566
6491
  align-items: center;
6492
+ width: auto;
6493
+ margin-right: -0.5rem;
6567
6494
 
6568
- span[kind="alert"] {
6569
- width: 2rem;
6570
- height: 2rem;
6495
+ button {
6496
+ width: auto;
6497
+ height: 1rem;
6498
+ padding: 0 0.5rem;
6499
+ }
6500
+ `;
6501
+ const LogoContainer = styled(Flex) `
6502
+ max-width: calc(100% - 1.4rem);
6503
+ flex-grow: 1;
6504
+ font-size: 0;
6571
6505
 
6572
- &:after {
6573
- font-size: 2rem;
6574
- color: ${({ theme: { palette } }) => palette.elementDeep};
6575
- }
6506
+ & > span::after {
6507
+ font-size: 2rem;
6576
6508
  }
6577
6509
 
6578
- ${Description} {
6579
- font-size: 0.75rem;
6580
- color: ${({ theme: { palette } }) => palette.textDisabled};
6510
+ img {
6511
+ max-height: 1.875rem;
6581
6512
  }
6582
6513
  `;
6583
- const SmallPreviewControl = styled(IconButton) `
6584
- cursor: ${({ $isDisabled }) => ($isDisabled ? "default" : "pointer")};
6585
- z-index: 3;
6586
- position: absolute;
6587
- top: 50%;
6588
- width: 2.5rem;
6589
- height: 2.5rem;
6590
- margin-top: -1.25rem;
6591
- background-color: rgba(61, 61, 61, 0.8);
6592
- border-radius: ${({ theme: { borderRadius } }) => borderRadius.smallest};
6514
+ const PageTitle = styled(H2) `
6515
+ display: -webkit-box;
6516
+ -webkit-line-clamp: 3;
6517
+ -webkit-box-orient: vertical;
6518
+ overflow: hidden;
6519
+ margin: 0;
6520
+ font-size: 1.25rem;
6521
+ font-weight: 600;
6522
+ pointer-events: initial;
6523
+ font-family: "Nunito Sans", serif;
6524
+ `;
6525
+
6526
+ var ThemeName;
6527
+ (function (ThemeName) {
6528
+ ThemeName["Light"] = "light";
6529
+ ThemeName["Dark"] = "dark";
6530
+ })(ThemeName || (ThemeName = {}));
6531
+
6532
+ var TmsType;
6533
+ (function (TmsType) {
6534
+ TmsType["WMS"] = "WMS";
6535
+ TmsType["TMS"] = "TMS";
6536
+ TmsType["ArcGIS"] = "ArcGIS";
6537
+ })(TmsType || (TmsType = {}));
6538
+ var EditGeometryType;
6539
+ (function (EditGeometryType) {
6540
+ EditGeometryType["Raster"] = "raster";
6541
+ })(EditGeometryType || (EditGeometryType = {}));
6542
+
6543
+ const DashboardDefaultHeader = memo(() => {
6544
+ const { components: { ProjectCatalogMenu, ProjectPanelMenu, ProjectPagesMenu }, } = useWidgetContext();
6545
+ const { pageId, image, icon, tooltip, themeName } = useDashboardHeader();
6546
+ 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, { arrow: true, content: tooltip, children: ref => (jsx(PageTitle, { ref: ref, children: jsx(ProjectPagesMenu, {}) })) }) }), jsx(FlexSpan, { children: jsx(Pagination, {}) })] }) }) }) })] })] }));
6547
+ });
6548
+
6549
+ const HeaderFrontView = styled(Flex) `
6550
+ z-index: 10;
6551
+ position: relative;
6552
+ justify-content: space-between;
6553
+ align-items: ${({ isDefault }) => (isDefault ? "center" : "flex-start")};
6554
+ width: 100%;
6555
+ font: ${({ theme: { fonts } }) => fonts.subtitle};
6556
+ `;
6557
+ const HeaderContainer = styled(FlexSpan) `
6558
+ display: flex;
6559
+ flex-grow: 1;
6560
+ flex-wrap: nowrap;
6561
+ width: calc(100% - 48px);
6562
+ `;
6563
+ const FeatureTitleContainer = styled.div `
6564
+ display: -webkit-box;
6565
+ max-width: 100%;
6566
+ width: 100%;
6567
+ margin: 0.5rem 0;
6568
+ -webkit-line-clamp: 2;
6569
+ -webkit-box-orient: vertical;
6570
+ overflow: hidden;
6571
+ text-overflow: ellipsis;
6572
+ color: ${({ theme: { palette } }) => palette.textPrimary};
6593
6573
 
6594
- span:after {
6595
- color: ${({ $isDisabled }) => ($isDisabled ? "rgba(255, 255, 255, 0.28)" : "rgba(255, 255, 255, 1)")};
6596
- transition: color ${transition.hover};
6574
+ & > ${FlexSpan} {
6575
+ cursor: ${({ clickable }) => clickable && "pointer"};
6576
+
6577
+ &:hover {
6578
+ color: ${({ clickable, theme: { palette } }) => clickable && palette.primary};
6579
+ }
6597
6580
  }
6598
6581
  `;
6599
- const SmallPreviewCounter = styled(Flex) `
6600
- z-index: 3;
6601
- position: absolute;
6602
- bottom: 0.625rem;
6603
- left: 0;
6582
+ const LayerDescription = styled(Description) `
6583
+ width: calc(100% - 4rem);
6584
+ display: -webkit-box;
6585
+ -webkit-line-clamp: 2;
6586
+ -webkit-box-orient: vertical;
6587
+ overflow: hidden;
6588
+ text-overflow: ellipsis;
6589
+ `;
6590
+ const HeaderTitleContainer = styled(Flex) `
6591
+ flex-direction: column;
6604
6592
  width: 100%;
6605
- height: 1rem;
6593
+ `;
6594
+ const RowHeaderMixin = css `
6595
+ &&& {
6596
+ min-height: auto;
6597
+
6598
+ ${FeatureTitleContainer}, ${LayerDescription} {
6599
+ text-align: left;
6600
+ }
6601
+ }
6602
+
6603
+ ${HeaderContainer} {
6604
+ flex-direction: row;
6605
+ }
6606
+
6607
+ ${FeatureTitleContainer} {
6608
+ max-width: calc(100% - 3.8rem);
6609
+ }
6610
+ `;
6611
+ const Header = styled(Flex) `
6612
+ z-index: 1;
6613
+ position: relative;
6614
+ top: 0;
6615
+ flex-shrink: 0;
6616
+ overflow: hidden;
6617
+ padding: 0.5rem;
6618
+
6619
+ ${HeaderContainer} {
6620
+ flex-direction: column;
6621
+ }
6622
+
6623
+ ${({ $isRow }) => $isRow && RowHeaderMixin};
6624
+ `;
6625
+
6626
+ const HeaderTitle = ({ noFeature }) => {
6627
+ const { t } = useGlobalContext();
6628
+ const { attributes, layerInfo, feature } = useWidgetContext(WidgetType.FeatureCard);
6629
+ const zoomToFeatures = useZoomToFeatures();
6630
+ const { alias, name, layerDefinition } = layerInfo || {};
6631
+ const resultDescription = alias || name || "";
6632
+ const resultTitle = useMemo(() => {
6633
+ const layerDefinitionAttribute = layerDefinition && attributes?.length
6634
+ ? attributes.find(item => item.name === layerDefinition.titleAttribute)
6635
+ : null;
6636
+ const layerDefinitionTitle = layerDefinition?.titleAttribute && layerDefinitionAttribute?.value
6637
+ ? layerDefinitionAttribute.value
6638
+ : null;
6639
+ return ((!!layerDefinitionTitle &&
6640
+ formatAttributeValue({
6641
+ t,
6642
+ type: layerDefinitionAttribute.type,
6643
+ value: layerDefinitionTitle,
6644
+ stringFormat: layerDefinitionAttribute.stringFormat,
6645
+ })) ||
6646
+ feature?.id);
6647
+ }, [attributes, feature, layerDefinition]);
6648
+ return (jsxs(HeaderTitleContainer, { children: [noFeature ? (jsx(FeatureTitleContainer, { children: t("noObjectFound", { ns: "dashboard" }) })) : (jsx(FeatureTitleContainer, { clickable: true, children: jsx(Tooltip, { 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 })] }));
6649
+ };
6650
+
6651
+ const LayerIconContainer = styled.div `
6652
+ display: flex;
6653
+ align-items: center;
6654
+ margin-right: 0.75rem;
6655
+ `;
6656
+ const AlertIconContainer = styled(Flex) `
6657
+ align-items: center;
6658
+ justify-content: center;
6659
+ width: 2rem;
6660
+ height: 2rem;
6661
+
6662
+ ${Icon} {
6663
+ :after {
6664
+ color: ${({ theme: { palette } }) => palette.error};
6665
+ }
6666
+ }
6667
+ `;
6668
+
6669
+ 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";
6670
+
6671
+ 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";
6672
+
6673
+ 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";
6674
+
6675
+ const LayerIcon = ({ layerInfo }) => {
6676
+ const renderSymbol = useMemo(() => {
6677
+ if (!layerInfo.geometryType) {
6678
+ return (jsx(AlertIconContainer, { children: jsx(Icon, { kind: "warning" }) }));
6679
+ }
6680
+ switch (layerInfo.geometryType) {
6681
+ case GeometryType.Polyline:
6682
+ return jsx("img", { src: img$1, alt: "" });
6683
+ case GeometryType.Polygon:
6684
+ return jsx("img", { src: img, alt: "" });
6685
+ case GeometryType.Point:
6686
+ default:
6687
+ return jsx("img", { src: img$2, alt: "" });
6688
+ }
6689
+ }, [layerInfo.geometryType]);
6690
+ return jsx(LayerIconContainer, { children: renderSymbol });
6691
+ };
6692
+
6693
+ const FeatureCardDefaultHeader = ({ noFeature }) => {
6694
+ const { layerInfo } = useWidgetContext(WidgetType.FeatureCard);
6695
+ 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, {})] }) }));
6696
+ };
6697
+
6698
+ const HeaderFontColorMixin$1 = css `
6699
+ ${HeaderTitleContainer}, ${LayerDescription} {
6700
+ color: ${({ $fontColor }) => $fontColor};
6701
+ }
6702
+ `;
6703
+ const HeaderWrapperMixin$1 = css `
6704
+ padding: 0.5rem 0.5rem 0;
6705
+
6706
+ ${Header} {
6707
+ min-height: 5.25rem;
6708
+ }
6709
+
6710
+ ${HeaderContainer} {
6711
+ max-width: 100%;
6712
+ width: 100%;
6713
+ }
6714
+
6715
+ ${FeatureControls} {
6716
+ max-width: calc(100% - 2rem);
6717
+ width: calc(100% - 2rem);
6718
+ margin-top: -0.5rem;
6719
+ padding-top: 1rem;
6720
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
6721
+ }
6722
+
6723
+ ${({ $fontColor }) => !!$fontColor && HeaderFontColorMixin$1};
6724
+ `;
6725
+ const GradientHeaderWrapper = styled.div `
6726
+ ${Header} {
6727
+ background: ${({ $bgColor }) => $bgColor || "radial-gradient(129.21% 133.22% at 51.94% 0%, #e8fffe 9.48%, #5fcaff 100%)"};
6728
+ }
6729
+
6730
+ ${HeaderContainer} {
6731
+ align-items: center;
6732
+ }
6733
+
6734
+ ${HeaderTitleContainer} {
6735
+ margin-left: 0;
6736
+ text-align: center;
6737
+ }
6738
+
6739
+ ${FeatureTitleContainer} {
6740
+ text-align: center;
6741
+ }
6742
+
6743
+ ${LayerDescription} {
6744
+ text-align: center;
6745
+ }
6746
+
6747
+ ${HeaderWrapperMixin$1};
6748
+ `;
6749
+
6750
+ const FeatureCardGradientHeader = ({ isRow }) => {
6751
+ const { layerInfo } = useWidgetContext(WidgetType.FeatureCard);
6752
+ const { config } = useWidgetConfig(WidgetType.FeatureCard);
6753
+ const { header, options } = config || {};
6754
+ const renderElement = useHeaderRender(header);
6755
+ 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({
6756
+ id: "title",
6757
+ wrap: false,
6758
+ }), description: renderElement({
6759
+ id: "description",
6760
+ wrap: false,
6761
+ }) })] }), jsx(FeatureCardButtons, {})] }) }) }) }));
6762
+ };
6763
+
6764
+ const HeaderFontColorMixin = css `
6765
+ ${HeaderTitleContainer}, ${LayerDescription} {
6766
+ color: ${({ $fontColor }) => $fontColor};
6767
+ }
6768
+ `;
6769
+ const HeaderWrapperMixin = css `
6770
+ padding: 0.5rem 0.5rem 0;
6771
+
6772
+ ${Header} {
6773
+ min-height: 5.25rem;
6774
+ }
6775
+
6776
+ ${HeaderContainer} {
6777
+ max-width: 100%;
6778
+ width: 100%;
6779
+ }
6780
+
6781
+ ${FeatureControls} {
6782
+ max-width: calc(100% - 2rem);
6783
+ width: calc(100% - 2rem);
6784
+ margin-top: -0.5rem;
6785
+ padding-top: 1rem;
6786
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
6787
+ }
6788
+
6789
+ ${({ $fontColor }) => !!$fontColor && HeaderFontColorMixin};
6790
+ `;
6791
+ const HeaderIcon = styled(Flex) `
6792
+ position: absolute;
6793
+ top: 0;
6794
+ right: 0;
6795
+ justify-content: flex-end;
6796
+ align-items: center;
6797
+ min-width: 7.5rem;
6798
+ height: 100%;
6799
+
6800
+ span[kind]:after {
6801
+ font-size: 7.5rem;
6802
+ }
6803
+
6804
+ span[kind]:after,
6805
+ path,
6806
+ line,
6807
+ circle {
6808
+ fill: rgba(255, 255, 255, 0.36);
6809
+ }
6810
+
6811
+ && > * {
6812
+ display: flex;
6813
+ align-items: center;
6814
+ height: 100%;
6815
+ }
6816
+ `;
6817
+ const BigIconHeaderMixin = css `
6818
+ ${HeaderIcon} {
6819
+ min-width: 14rem;
6820
+ right: -3rem;
6821
+
6822
+ span[kind]:after {
6823
+ font-size: 14rem;
6824
+ }
6825
+ }
6826
+ `;
6827
+ const IconHeaderWrapper = styled.div `
6828
+ ${Header} {
6829
+ width: calc(100% + 3rem);
6830
+ margin: -1.5rem -1.5rem 0 -1.5rem;
6831
+ padding: 1.5rem;
6832
+ border-top-left-radius: 0.5rem;
6833
+ border-top-right-radius: 0.5rem;
6834
+ background: ${({ $bgColor }) => $bgColor || "linear-gradient(96.55deg, #FFFCD3 0%, #B4DC47 100%)"};
6835
+ }
6836
+
6837
+ ${HeaderWrapperMixin};
6838
+
6839
+ ${({ $bigIcon }) => $bigIcon && BigIconHeaderMixin};
6840
+ `;
6841
+
6842
+ const FeatureCardIconHeader = ({ isRow }) => {
6843
+ const { layerInfo } = useWidgetContext(WidgetType.FeatureCard);
6844
+ const { config } = useWidgetConfig(WidgetType.FeatureCard);
6845
+ const { header, options } = config || {};
6846
+ const renderElement = useHeaderRender(header);
6847
+ 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({
6848
+ id: "title",
6849
+ wrap: false,
6850
+ }), description: renderElement({
6851
+ id: "description",
6852
+ wrap: false,
6853
+ }) })] }), jsx(FeatureCardButtons, {})] }), jsx(HeaderIcon, { children: renderElement({
6854
+ id: "icon",
6855
+ wrap: false,
6856
+ }) })] }) }) }));
6857
+ };
6858
+
6859
+ const ImageContainerButton = styled(FlatButton) `
6860
+ min-height: 1.5rem;
6861
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.large};
6862
+ background-color: ${({ theme: { palette } }) => palette.primary};
6863
+ text-transform: none;
6864
+
6865
+ :hover {
6866
+ background-color: ${({ theme: { palette } }) => palette.primaryDeep};
6867
+ }
6868
+ `;
6869
+
6870
+ const ElementButton = memo(({ type, elementConfig }) => {
6871
+ const { attributes } = useWidgetContext(type);
6872
+ const attribute = getAttributeByName(elementConfig?.attributeName, attributes);
6873
+ const link = attribute?.value;
6874
+ if (!link || typeof link !== "string")
6875
+ return null;
6876
+ return (jsx(ImageContainerButton, { onClick: () => window.open(attribute?.value), children: elementConfig.value || "" }));
6877
+ });
6878
+
6879
+ const AttributeGalleryContainer = styled.div `
6880
+ && {
6881
+ width: calc(100% + 3rem);
6882
+ }
6883
+
6884
+ min-height: 12.625rem;
6885
+ background-color: ${({ theme: { palette } }) => palette.element};
6886
+
6887
+ img {
6888
+ width: 100%;
6889
+ }
6890
+ `;
6891
+ const LinearProgressContainer = styled(Flex) `
6892
+ align-items: center;
6893
+ justify-content: center;
6894
+ min-height: inherit;
6895
+
6896
+ ${LinearProgress} {
6897
+ max-width: 4rem;
6898
+ }
6899
+ `;
6900
+ const NoLiveSnapshotContainer = styled(Flex) `
6901
+ flex-direction: column;
6902
+ align-items: center;
6903
+
6904
+ span[kind="alert"] {
6905
+ width: 2rem;
6906
+ height: 2rem;
6907
+
6908
+ &:after {
6909
+ font-size: 2rem;
6910
+ color: ${({ theme: { palette } }) => palette.elementDeep};
6911
+ }
6912
+ }
6913
+
6914
+ ${Description} {
6915
+ font-size: 0.75rem;
6916
+ color: ${({ theme: { palette } }) => palette.textDisabled};
6917
+ }
6918
+ `;
6919
+ const SmallPreviewControl = styled(IconButton) `
6920
+ cursor: ${({ $isDisabled }) => ($isDisabled ? "default" : "pointer")};
6921
+ z-index: 3;
6922
+ position: absolute;
6923
+ top: 50%;
6924
+ width: 2.5rem;
6925
+ height: 2.5rem;
6926
+ margin-top: -1.25rem;
6927
+ background-color: rgba(61, 61, 61, 0.8);
6928
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.smallest};
6929
+
6930
+ span:after {
6931
+ color: ${({ $isDisabled }) => ($isDisabled ? "rgba(255, 255, 255, 0.28)" : "rgba(255, 255, 255, 1)")};
6932
+ transition: color ${transition.hover};
6933
+ }
6934
+ `;
6935
+ const SmallPreviewCounter = styled(Flex) `
6936
+ z-index: 3;
6937
+ position: absolute;
6938
+ bottom: 0.625rem;
6939
+ left: 0;
6940
+ width: 100%;
6941
+ height: 1rem;
6606
6942
  justify-content: center;
6607
6943
 
6608
6944
  > div {
@@ -6649,7 +6985,7 @@ const imgSlideShowMixin = css `
6649
6985
  }
6650
6986
  }
6651
6987
  `;
6652
- const SmallPreviewContainer = styled.div `
6988
+ const SmallPreviewContainer$1 = styled.div `
6653
6989
  cursor: ${({ onClick }) => (onClick ? "pointer" : "default")};
6654
6990
  position: relative;
6655
6991
  width: 100%;
@@ -6694,6 +7030,10 @@ const SmallPreviewContainer = styled.div `
6694
7030
  `;
6695
7031
  const SmallPreviewImages = styled.div ``;
6696
7032
 
7033
+ const NoLiveSnapshot = () => {
7034
+ 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" })] }));
7035
+ };
7036
+
6697
7037
  const SmallPreview = ({ images, totalCount, currentIndex, isLoading, setCurrentIndex, onClick, onNextPage }) => {
6698
7038
  const { t } = useGlobalContext();
6699
7039
  const [prevIndex, setPrevIndex] = useState(currentIndex + 1);
@@ -6715,40 +7055,151 @@ const SmallPreview = ({ images, totalCount, currentIndex, isLoading, setCurrentI
6715
7055
  onNextPage();
6716
7056
  }
6717
7057
  }, [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))) })] }));
7058
+ 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
7059
  };
6720
7060
 
6721
- const ElementSlideshow = ({ elementConfig, type, renderElement }) => {
6722
- const { expandedContainers, dataSources, attributes } = useWidgetContext(type);
7061
+ const DEFAULT_ARCHIVED_PERIOD = "#24h";
7062
+ const SNAPSHOTS_PER_PAGE = 10;
7063
+ const getDuration = (archivePeriod) => {
7064
+ const lastLetter = archivePeriod[archivePeriod.length - 1];
7065
+ const value = archivePeriod.slice(1, -1);
7066
+ const prop = lastLetter === "d"
7067
+ ? "days"
7068
+ : lastLetter === "h"
7069
+ ? "hours"
7070
+ : lastLetter === "m"
7071
+ ? "minutes"
7072
+ : lastLetter === "s"
7073
+ ? "seconds"
7074
+ : null;
7075
+ if (!lastLetter || !value || !prop)
7076
+ return {};
7077
+ return { [prop]: Number(value) };
7078
+ };
7079
+ const useCameraAttribute = (cameraId) => {
7080
+ const { api } = useGlobalContext();
6723
7081
  const [currentIndex, setCurrentIndex] = useState(0);
7082
+ const [currentPage, setCurrentPage] = useState(0);
7083
+ const [timeline, setTimeline] = useState([]);
7084
+ const [isLoadingSnapshot, setLoadingSnapshot] = useState(false);
7085
+ const [isLoadingTimeline, setLoadingTimeline] = useState(false);
6724
7086
  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),
6735
- });
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,
7087
+ const [galleryImages, setGalleryImages] = useState([]);
7088
+ const imagesRef = useRef([]);
7089
+ // Todo get archivePeriod from project configuration
7090
+ const archivePeriod = /* appConfig?.settings?.cameraAttribute?.archivePeriod ||*/ DEFAULT_ARCHIVED_PERIOD;
7091
+ const onNextPage = useCallback(() => {
7092
+ setCurrentPage(currentPage + 1);
7093
+ }, [currentPage]);
7094
+ useEffect(() => {
7095
+ (async () => {
7096
+ if (!cameraId)
7097
+ return;
7098
+ setLoadingSnapshot(true);
7099
+ const snapshot = null; // await api.cameras.getLiveSnapshot(cameraId);
7100
+ const url = URL.createObjectURL(snapshot);
7101
+ setLoadingSnapshot(false);
7102
+ setLoadingTimeline(true);
7103
+ imagesRef.current = [
7104
+ {
7105
+ src: url,
7106
+ startTime: new Date(),
7107
+ },
7108
+ ];
7109
+ setGalleryImages([
7110
+ {
7111
+ src: url,
7112
+ fileName: formatDate$1(new Date()),
7113
+ },
7114
+ ]);
7115
+ const formatDateOptions = { dateFormat: DateFormat.UTC };
7116
+ const startTime = formatDate$1(sub(new Date(), getDuration(archivePeriod)), formatDateOptions);
7117
+ const endTime = formatDate$1(new Date(), formatDateOptions);
7118
+ const timelineResponse = await api.cameras.getArchiveTimeline({ cameraId, startTime, endTime });
7119
+ if (!timelineResponse.success || !timelineResponse.timeline.length)
7120
+ return;
7121
+ timelineResponse.timeline.reverse();
7122
+ setTimeline(timelineResponse.timeline);
7123
+ })();
7124
+ }, [cameraId]);
7125
+ useEffect(() => {
7126
+ if (!timeline.length)
7127
+ return;
7128
+ const timelinePage = timeline.slice(currentPage * SNAPSHOTS_PER_PAGE, (currentPage + 1) * SNAPSHOTS_PER_PAGE);
7129
+ for (const item of timelinePage) {
7130
+ if (!item)
7131
+ continue;
7132
+ api.cameras
7133
+ .getArchiveSnapshot({
7134
+ cameraId,
7135
+ time: item.startTime,
7136
+ })
7137
+ .then(response => {
7138
+ const newImages = [
7139
+ ...imagesRef.current,
7140
+ { src: URL.createObjectURL(response), startTime: new Date(item.startTime) },
7141
+ ];
7142
+ newImages.sort((a, b) => (a.startTime < b.startTime ? 1 : a.startTime > b.startTime ? -1 : 0));
7143
+ imagesRef.current = newImages;
7144
+ setGalleryImages(newImages.map(newImage => ({
7145
+ src: newImage.src,
7146
+ fileName: formatDate$1(newImage.startTime, { dateFormat: DateFormat.DateTime }),
7147
+ })));
7148
+ if (newImages.length === timelinePage.length) {
7149
+ setLoadingTimeline(false);
7150
+ }
7151
+ });
7152
+ }
7153
+ }, [timeline, currentPage]);
7154
+ return [
7155
+ {
7156
+ currentIndex,
7157
+ currentPage,
7158
+ totalCount: timeline.length,
7159
+ galleryImages,
7160
+ isLoadingSnapshot,
7161
+ isLoadingTimeline,
7162
+ isOpenGallery,
7163
+ },
7164
+ {
7165
+ toggleGallery,
7166
+ setGalleryImages,
7167
+ setCurrentIndex,
7168
+ onNextPage,
7169
+ },
7170
+ ];
7171
+ };
7172
+
7173
+ const ElementCamera = ({ type, renderElement, elementConfig, field }) => {
7174
+ const { expandedContainers, attributes } = useWidgetContext(type);
7175
+ const attribute = getAttributeByName(elementConfig?.attributeName, attributes);
7176
+ const value = attribute?.value;
7177
+ const { id, options } = elementConfig || {};
7178
+ const { expandable, expanded } = options || {};
7179
+ const isVisible = isVisibleContainer(id, expandable, expanded, expandedContainers);
7180
+ const [{ currentIndex /* , currentPage*/, totalCount, galleryImages, isLoadingSnapshot, isLoadingTimeline, isOpenGallery }, { setCurrentIndex, toggleGallery, onNextPage },] = useCameraAttribute(value);
7181
+ 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
7182
  // currentIndex={currentIndex}
6743
- // totalCount={images.length}
6744
- isOpen: isOpenGallery, onClose: toggleGallery }))] }))] }));
7183
+ // currentPage={currentPage}
7184
+ // totalCount={totalCount}
7185
+ isOpen: isOpenGallery,
7186
+ // isLoading={isLoadingTimeline}
7187
+ // hasSidebar
7188
+ onClose: toggleGallery }))] }))] }));
6745
7189
  };
6746
7190
 
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 }));
7191
+ const ElementChart = memo(({ type, elementConfig, renderElement }) => {
7192
+ const { config } = useWidgetConfig(type);
7193
+ return (jsx(Chart, { type: type, config: config, elementConfig: elementConfig, element: elementConfig, renderElement: renderElement }));
7194
+ });
7195
+
7196
+ const ElementChips = memo(({ type, elementConfig }) => {
7197
+ const { attributes } = useWidgetContext(type);
7198
+ const { attributeName, options, style } = elementConfig || {};
7199
+ const { separator, bgColor, fontColor, fontSize } = options || {};
7200
+ const attribute = getAttributeByName(attributeName, attributes);
7201
+ const tags = attribute?.value?.split(separator || ",");
7202
+ return (jsx(DashboardChipsContainer, { style: style, children: tags?.map(tag => (jsx(DashboardChip$1, { text: tag, "$bgColor": bgColor, "$fontColor": fontColor, "$fontSize": fontSize, "$isDefault": true }, tag))) }));
6752
7203
  });
6753
7204
 
6754
7205
  const StyledIconFontSizeMixin = css `
@@ -6776,27 +7227,45 @@ const ElementIcon = memo(({ type, elementConfig }) => {
6776
7227
  return jsx(StyledIcon, { kind: iconValue, fontSize: fontSize, fontColor: fontColor });
6777
7228
  });
6778
7229
 
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
- `;
7230
+ const ElementImage = memo(({ type, elementConfig }) => {
7231
+ const { attributes } = useWidgetContext(type);
7232
+ const { value, attributeName, options } = elementConfig || {};
7233
+ const { width } = options || {};
7234
+ const firstImage = useMemo(() => {
7235
+ if (value) {
7236
+ return value.toString();
7237
+ }
7238
+ if (!attributeName || Array.isArray(attributeName)) {
7239
+ return null;
7240
+ }
7241
+ const attribute = attributes?.find(item => item.name === attributeName);
7242
+ return attribute?.value?.split(";")?.[0];
7243
+ }, [attributeName, attributes, value]);
7244
+ return firstImage ? jsx("img", { src: firstImage, alt: firstImage, width: width }) : null;
7245
+ });
6792
7246
 
6793
- const ElementTooltip = memo(({ type, elementConfig }) => {
7247
+ const ElementLegend = memo(({ type, element, elementConfig, expandedContainers }) => {
6794
7248
  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;
7249
+ const { options } = elementConfig || {};
7250
+ const { twoColumns, chartId, relatedDataSources } = options || {};
7251
+ const chartElement = useMemo(() => returnFound(element?.children, { id: chartId }), [chartId, element?.children]);
7252
+ const { data, loading } = useChartData({
7253
+ element: chartElement,
7254
+ type,
7255
+ });
7256
+ const legendData = useMemo(() => {
7257
+ if (!data[0]?.items?.length)
7258
+ return [];
7259
+ const relatedAttributes = relatedDataSources || [];
7260
+ const isRelated = !!relatedAttributes?.length;
7261
+ return isRelated
7262
+ ? data[0].items
7263
+ : data[0].items.map(item => {
7264
+ const attribute = attributes?.find(({ name }) => name === item.name);
7265
+ return { ...item, name: attribute?.alias || item.name };
7266
+ });
7267
+ }, [attributes, data, relatedDataSources]);
7268
+ return !chartElement?.options?.expanded || expandedContainers?.[chartElement.id] ? (jsx(ChartLegend, { data: legendData, loading: loading, chartElement: chartElement, twoColumns: twoColumns, type: type })) : null;
6800
7269
  });
6801
7270
 
6802
7271
  const ExternalLink = styled(IconButton).attrs(() => ({
@@ -6867,197 +7336,272 @@ const ElementLink = memo(({ type, elementConfig }) => {
6867
7336
  return link.startsWith("http") ? jsx(ExternalLink, { onClick: () => window.open(link) }) : jsx(LocalLink, { link: link });
6868
7337
  });
6869
7338
 
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;
7339
+ const SmallPreviewContainer = styled.div `
7340
+ width: 100%;
7341
+ height: 100%;
7342
+ `;
7343
+
7344
+ const ElementSlideshow = ({ elementConfig, type, renderElement }) => {
7345
+ const { expandedContainers, dataSources, attributes } = useWidgetContext(type);
7346
+ const [currentIndex, setCurrentIndex] = useState(0);
7347
+ const [isOpenGallery, toggleGallery] = useToggle();
7348
+ const { id, options, attributeName } = elementConfig || {};
7349
+ const { expandable, expanded, relatedDataSource } = options || {};
7350
+ const isVisible = isVisibleContainer(id, expandable, expanded, expandedContainers);
7351
+ const images = useMemo(() => {
7352
+ const dataSource = relatedDataSource ? dataSources?.find(({ name }) => name === relatedDataSource) : null;
7353
+ const array = dataSource
7354
+ ? dataSource.features.map(feature => feature.attributes[attributeName])
7355
+ : getSlideshowImages({
7356
+ element: elementConfig,
7357
+ attribute: attributes?.find(({ name }) => name === attributeName),
7358
+ });
7359
+ return (array?.map(image => ({
7360
+ src: image,
7361
+ fileName: image,
7362
+ })) || []);
7363
+ }, [attributeName, attributes, dataSources, elementConfig, relatedDataSource]);
7364
+ 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,
7365
+ // currentIndex={currentIndex}
7366
+ // totalCount={images.length}
7367
+ isOpen: isOpenGallery, onClose: toggleGallery }))] }))] }));
7368
+ };
7369
+
7370
+ const ElementSvg = memo(({ type, elementConfig }) => {
7371
+ const { layerInfo, attributes } = useWidgetContext(type);
7372
+ const { options } = elementConfig || {};
7373
+ const { width, height, fontColor } = options || {};
7374
+ return (jsx(SvgImage, { url: getSvgUrl({ elementConfig, layerInfo, attributes }), width: width, height: height, fontColor: fontColor }));
7375
+ });
7376
+
7377
+ const TooltipIcon = styled(Icon) `
7378
+ &&& {
7379
+ :after {
7380
+ font-size: 0.75rem;
7381
+ color: ${({ theme: { palette } }) => palette.iconDisabled};
7382
+ transition: color ${transition.hover};
7383
+ }
6875
7384
 
6876
- :hover {
6877
- background-color: ${({ theme: { palette } }) => palette.primaryDeep};
7385
+ :hover:after {
7386
+ color: ${({ theme: { palette } }) => palette.icon};
7387
+ }
6878
7388
  }
6879
7389
  `;
6880
7390
 
6881
- const ElementButton = memo(({ type, elementConfig }) => {
7391
+ const ElementTooltip = memo(({ type, elementConfig }) => {
6882
7392
  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 || "" }));
7393
+ const { attributeName, options } = elementConfig || {};
7394
+ const { icon } = options || {};
7395
+ const attribute = getAttributeByName(attributeName, attributes);
7396
+ const text = (attribute?.value || elementConfig?.value);
7397
+ return text ? (jsx(Tooltip, { placement: "top", arrow: true, content: text, children: ref => jsx(TooltipIcon, { kind: icon || "question", ref: ref }) })) : null;
6888
7398
  });
6889
7399
 
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]);
7400
+ const SlideshowHeaderWrapper = styled.div `
7401
+ padding: ${({ withPadding }) => (withPadding ? "0.5rem 0.5rem 0" : 0)};
7402
+
7403
+ ${Header} {
7404
+ align-items: flex-start;
7405
+ width: calc(100% + 2rem);
7406
+ height: ${({ big }) => (big ? "15.5rem" : "auto")};
7407
+ padding: 1.5rem;
7408
+ margin: -1rem -1rem 0 -1rem;
7409
+ border-radius: ${({ theme: { borderRadius } }) => borderRadius.medium};
7410
+
7411
+ ${SmallPreviewCounter} {
7412
+ bottom: ${({ withPadding }) => (withPadding ? 0.625 : 1.125)}rem;
7413
+ }
7414
+
7415
+ :before,
7416
+ :after {
7417
+ content: "";
7418
+ z-index: 2;
7419
+ position: absolute;
7420
+ top: 0;
7421
+ left: 0;
7422
+ width: 100%;
7423
+ }
7424
+
7425
+ :before {
7426
+ height: 100%;
7427
+ background: rgba(32, 46, 53, 0.25);
7428
+ }
7429
+
7430
+ :after {
7431
+ height: 4.5rem;
7432
+ background: linear-gradient(180deg, #000000 0%, rgba(0, 0, 0, 0) 100%);
7433
+ }
7434
+
7435
+ :hover {
7436
+ ${SmallPreviewControl}, ${SmallPreviewCounter} {
7437
+ opacity: 1;
7438
+ }
7439
+ }
7440
+ }
7441
+ `;
7442
+ const ImageContainerBg = styled.div `
7443
+ position: absolute;
7444
+ top: 0;
7445
+ bottom: 0;
7446
+ left: 0;
7447
+ right: 0;
7448
+
7449
+ img {
7450
+ width: 100%;
7451
+ height: 100%;
7452
+ object-position: center;
7453
+ object-fit: cover;
7454
+ }
7455
+ `;
7456
+ const HeaderSlideshow = styled.div `
7457
+ position: absolute;
7458
+ top: 0;
7459
+ bottom: ${({ height }) => (height ? `${height}px` : 0)};
7460
+ left: 0;
7461
+ right: 0;
7462
+
7463
+ img {
7464
+ width: 100%;
7465
+ height: 100%;
7466
+ min-height: inherit;
7467
+ object-position: center;
7468
+ object-fit: cover;
7469
+ }
7470
+ `;
7471
+
7472
+ const FeatureCardSlideshowHeader = ({ isRow }) => {
7473
+ const { layerInfo } = useWidgetContext(WidgetType.FeatureCard);
7474
+ const { config } = useWidgetConfig(WidgetType.FeatureCard);
7475
+ const { header, options } = config || {};
7476
+ const renderElement = useHeaderRender(header);
7477
+ 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({
7478
+ id: "title",
7479
+ wrap: false,
7480
+ }), description: renderElement({
7481
+ id: "description",
7482
+ wrap: false,
7483
+ }) })] }), jsx(FeatureCardButtons, {})] }), jsx(ImageContainerBg, { children: renderElement({
7484
+ id: "bgImage",
7485
+ wrap: false,
7486
+ }) }), jsx(HeaderSlideshow, { height: options?.height, children: renderElement({
7487
+ id: "slideshow",
7488
+ wrap: false,
7489
+ }) })] }) }) }));
7490
+ };
7491
+
7492
+ const getDashboardHeader = (templateName) => {
7493
+ switch (templateName) {
7494
+ case HeaderTemplate.Default:
7495
+ default:
7496
+ return DashboardDefaultHeader;
7497
+ }
7498
+ };
7499
+
7500
+ const getDataFromAttributes = (t, config, attributes) => {
7501
+ const colors = config?.options?.colors || FEATURE_CARD_DEFAULT_COLORS;
7502
+ const data = config?.children?.map(({ attributeName }, index) => {
7503
+ const attribute = attributes?.find(({ name }) => name === attributeName);
7504
+ return {
7505
+ name: attribute?.name || "",
7506
+ value: attribute ? Number(attribute.value) : 0,
7507
+ color: colors[index] || FEATURE_CARD_OTHER_COLOR
7508
+ };
7509
+ });
7510
+ if (config?.options?.orderByValue) {
7511
+ data.sort((a, b) => b.value - a.value);
7512
+ }
7513
+ const isOtherSliced = config?.options?.otherItems && config.options.otherItems < data.length;
7514
+ if (!isOtherSliced)
7515
+ return data;
7516
+ const otherValue = data
7517
+ .slice(0, config?.options?.otherItems)
7518
+ .reduce((prev, { value }) => prev + value, 0);
6987
7519
  return [
7520
+ ...data?.slice(0, config.options?.otherItems),
6988
7521
  {
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
- },
7522
+ name: t("other", { ns: "dashboard" }),
7523
+ color: FEATURE_CARD_OTHER_COLOR,
7524
+ value: Number(otherValue)
7525
+ }
7003
7526
  ];
7004
7527
  };
7005
7528
 
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 }))] }))] }));
7529
+ const getDataFromRelatedFeatures = ({ t, config, filters, relatedConfig, dataSource, layerInfo }) => {
7530
+ if (!dataSource || !dataSource?.features?.length) {
7531
+ return [];
7532
+ }
7533
+ const { colors } = config.options;
7534
+ const layerDefinition = getLayerDefinition(layerInfo);
7535
+ let data = JSON.parse(JSON.stringify(dataSource?.features));
7536
+ const sortAttribute = config?.options?.orderByValue
7537
+ ? relatedConfig.attributeName
7538
+ : config?.options?.orderByTitle
7539
+ ? relatedConfig.attributeTitle
7540
+ : null;
7541
+ if (sortAttribute) {
7542
+ data.sort((a, b) => b.attributes[sortAttribute] - a.attributes[sortAttribute]);
7543
+ }
7544
+ const isOtherSliced = config?.options?.otherItems && config.options.otherItems < data.length;
7545
+ const otherValue = isOtherSliced
7546
+ ? data
7547
+ .slice(config.options.otherItems)
7548
+ .reduce((prev, { attributes }) => prev + attributes[relatedConfig.attributeName], 0)
7549
+ : null;
7550
+ if (isOtherSliced) {
7551
+ data = data.slice(0, config?.options?.otherItems);
7552
+ }
7553
+ const gradientArray = relatedConfig.chartAxis && colors?.length < data.length
7554
+ ? new Gradient()
7555
+ .setColorGradient(colors[0], colors[colors.length - 1])
7556
+ .setMidpoint(data.length)
7557
+ .getColors()
7558
+ : colors;
7559
+ const filter = getConfigFilter(relatedConfig?.filterName, filters);
7560
+ const result = data.reduce((acc, feature, index) => {
7561
+ if (relatedConfig?.filterName && !filter) {
7562
+ return acc;
7563
+ }
7564
+ const attributeName = feature.attributes[relatedConfig.attributeName];
7565
+ const attributeTitle = feature.attributes[relatedConfig.attributeTitle];
7566
+ const attributeColor = feature.attributes[relatedConfig.attributeColor];
7567
+ return [
7568
+ ...acc,
7569
+ {
7570
+ name: formatAttributeValue({
7571
+ t,
7572
+ type: layerDefinition.attributes[relatedConfig.attributeTitle]?.type,
7573
+ value: attributeTitle,
7574
+ stringFormat: layerDefinition.attributes[relatedConfig.attributeTitle]?.stringFormat
7575
+ }),
7576
+ value: attributeName === null ? null : Number(attributeName),
7577
+ color: attributeColor || gradientArray?.[index] || FEATURE_CARD_OTHER_COLOR,
7578
+ min: filter?.attributeMin ? feature.attributes[filter.attributeMin] : null,
7579
+ max: filter?.attributeMin ? feature.attributes[filter.attributeMax] : null
7580
+ }
7581
+ ];
7582
+ }, []);
7583
+ if (isOtherSliced) {
7584
+ result.push({
7585
+ name: t("other", { ns: "dashboard" }),
7586
+ color: FEATURE_CARD_OTHER_COLOR,
7587
+ value: Number(otherValue)
7588
+ });
7589
+ }
7590
+ return result;
7022
7591
  };
7023
7592
 
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
- });
7593
+ const getDefaultConfig = ({ title, defaultTitle, items, baseMapName, position, resolution, srid, }) => {
7594
+ const dashboardConfiguration = JSON.parse(JSON.stringify(DEFAULT_DASHBOARD_CONFIG));
7595
+ const defaultPages = JSON.parse(JSON.stringify(DEFAULT_PAGES_CONFIG));
7596
+ const defaultPage = createConfigPage({ title, baseMapName, position, resolution, defaultTitle });
7597
+ if (items?.length) {
7598
+ const contentItems = items.map(item => createConfigLayer(item.name));
7599
+ defaultPage.layers.push(...contentItems);
7600
+ }
7601
+ defaultPages.children.push(defaultPage);
7602
+ dashboardConfiguration.children.push(defaultPages);
7603
+ return dashboardConfiguration;
7604
+ };
7061
7605
 
7062
7606
  const elementComponents = {
7063
7607
  image: ElementImage,
@@ -7150,6 +7694,20 @@ function getFeatureAttributes(feature = {}, layer, dataSource) {
7150
7694
  });
7151
7695
  }
7152
7696
 
7697
+ const getFeatureCardHeader = (templateName) => {
7698
+ switch (templateName) {
7699
+ case HeaderTemplate.Slideshow:
7700
+ return FeatureCardSlideshowHeader;
7701
+ case HeaderTemplate.Gradient:
7702
+ return FeatureCardGradientHeader;
7703
+ case HeaderTemplate.Icon:
7704
+ return FeatureCardIconHeader;
7705
+ case HeaderTemplate.Default:
7706
+ default:
7707
+ return FeatureCardDefaultHeader;
7708
+ }
7709
+ };
7710
+
7153
7711
  const RangeNumberFilter = ({ type, filter }) => {
7154
7712
  const { t } = useGlobalContext();
7155
7713
  const { filters, changeFilters } = useWidgetContext(type);
@@ -7932,6 +8490,7 @@ const useWidgetPage = (type = WidgetType.Dashboard) => {
7932
8490
  const page = getPagesFromConfig(config)?.[pageIndex - 1];
7933
8491
  return {
7934
8492
  ...(page || {}),
8493
+ header: page?.header || config.header,
7935
8494
  dataSources: [
7936
8495
  ...(page?.dataSources?.filter(({ name }) => !config.dataSources?.some(item => item.name === name)) || []),
7937
8496
  ...(config.dataSources || [])
@@ -8046,12 +8605,29 @@ const useChartData = ({ element, type }) => {
8046
8605
  return { data, loading };
8047
8606
  };
8048
8607
 
8049
- const useDashboardHeader = (renderElement) => {
8608
+ const useHeaderRender = (elementConfig, type = WidgetType.Dashboard) => {
8609
+ const { layerInfo, attributes, expandedContainers, selectedTabId, setSelectedTabId } = useWidgetContext(type);
8610
+ const { config } = useWidgetConfig(type);
8611
+ const { pageIndex } = useWidgetPage(type);
8612
+ return useMemo(() => getRenderElement({
8613
+ config,
8614
+ elementConfig,
8615
+ attributes,
8616
+ layerInfo,
8617
+ expandedContainers,
8618
+ selectedTabId,
8619
+ setSelectedTabId,
8620
+ pageIndex,
8621
+ }), [config, elementConfig, attributes, layerInfo, expandedContainers, selectedTabId, setSelectedTabId, pageIndex]);
8622
+ };
8623
+
8624
+ const useDashboardHeader = () => {
8050
8625
  const { themeName } = useGlobalContext();
8051
8626
  const { projectInfo } = useWidgetContext();
8052
8627
  const { currentPage } = useWidgetPage();
8053
8628
  const { alias, name } = projectInfo || {};
8054
8629
  const { id: pageId, header } = currentPage || {};
8630
+ const renderElement = useHeaderRender(header);
8055
8631
  const image = useMemo(() => (header?.children?.some(({ id }) => id === "image") ? renderElement({ id: "image", wrap: false }) : null), [header?.children, renderElement]);
8056
8632
  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
8633
  const title = useMemo(() => header?.children?.some(({ id }) => id === "title") ? renderElement({ id: "title" }) : currentPage?.options?.title, [header?.children, renderElement, currentPage?.options?.title]);
@@ -8065,6 +8641,7 @@ const useDashboardHeader = (renderElement) => {
8065
8641
  tooltip,
8066
8642
  description,
8067
8643
  themeName,
8644
+ renderElement,
8068
8645
  };
8069
8646
  };
8070
8647
 
@@ -8633,6 +9210,12 @@ const DashboardCheckbox = ({ title, checked, onChange, }) => {
8633
9210
  return (jsxs(Fragment$1, { children: [jsx(AttributeLabel, { isEdit: !!onChange, forCheckbox: !!onChange, children: title }), onChange ? jsx(CardCheckbox, { checked: checked, label: label, onChange: onChange }) : label] }));
8634
9211
  };
8635
9212
 
9213
+ const DashboardHeader = memo(() => {
9214
+ const { currentPage } = useWidgetPage();
9215
+ const HeaderTemplate = useMemo(() => getDashboardHeader(currentPage?.header?.templateName), [currentPage?.header?.templateName]);
9216
+ return jsx(HeaderTemplate, {});
9217
+ });
9218
+
8636
9219
  const DataSourceError = ({ name }) => {
8637
9220
  const { t } = useGlobalContext();
8638
9221
  return (jsxs(DataSourceErrorContainer, { children: [jsx(Icon, { kind: "alert" }), jsxs("div", { children: [t("block", { ns: "dashboard" }), " \"", name, "\" ", t("isNotLoaded", { ns: "dashboard" })] })] }));
@@ -8649,6 +9232,50 @@ const ExpandableTitle = memo(({ elementConfig, type, renderElement }) => {
8649
9232
  return (jsx(TitleContainer, { containerId: id, elementConfig: titleElement, templateName: templateName, layerNames: layerNames, fontColor: fontColor, expandable: expandable, expanded: expanded, type: type, isVisible: isVisible, renderElement: renderElement }));
8650
9233
  });
8651
9234
 
9235
+ const FeatureCardButtons = () => {
9236
+ const { closeFeatureCard } = useWidgetContext(WidgetType.FeatureCard);
9237
+ return (jsx(FlexSpan, { children: jsx(IconButton, { kind: "close", style: {
9238
+ padding: 0,
9239
+ width: "1rem",
9240
+ }, onClick: closeFeatureCard }) }));
9241
+ };
9242
+
9243
+ const FeatureCardHeader = () => {
9244
+ const { currentPage } = useWidgetPage(WidgetType.FeatureCard);
9245
+ const HeaderTemplate = getFeatureCardHeader(currentPage?.header?.templateName);
9246
+ return jsx(HeaderTemplate, {});
9247
+ };
9248
+
9249
+ const FeatureCardTitle = ({ title, description }) => {
9250
+ const { t } = useGlobalContext();
9251
+ const { attributes, layerInfo, feature } = useWidgetContext(WidgetType.FeatureCard);
9252
+ const zoomToFeatures = useZoomToFeatures();
9253
+ const { alias, name, layerDefinition, titleAttribute } = layerInfo || {};
9254
+ const resultDescription = description || alias || name || "";
9255
+ const resultTitle = useMemo(() => {
9256
+ const layerDefinitionAttribute = layerDefinition && attributes?.length
9257
+ ? attributes.find(item => item.name === layerDefinition.titleAttribute)
9258
+ : null;
9259
+ const layerDefinitionTitle = layerDefinition?.titleAttribute && layerDefinitionAttribute?.value
9260
+ ? layerDefinitionAttribute.value
9261
+ : null;
9262
+ const sourceTitleAttribute = titleAttribute && attributes?.length ? attributes.find(item => item.name === titleAttribute) : null;
9263
+ const sourceTitle = titleAttribute && sourceTitleAttribute?.value ? sourceTitleAttribute.value : null;
9264
+ return (title ||
9265
+ (!!sourceTitle &&
9266
+ formatAttributeValue({ t, type: sourceTitleAttribute.type, value: sourceTitle, stringFormat: sourceTitleAttribute.stringFormat })) ||
9267
+ (!!layerDefinitionTitle &&
9268
+ formatAttributeValue({
9269
+ t,
9270
+ type: layerDefinitionAttribute.type,
9271
+ value: layerDefinitionTitle,
9272
+ stringFormat: layerDefinitionAttribute.stringFormat,
9273
+ })) ||
9274
+ feature?.id);
9275
+ }, [attributes, feature?.id, layerDefinition, title, titleAttribute]);
9276
+ return (jsxs(HeaderTitleContainer, { children: [jsx(FeatureTitleContainer, { clickable: true, children: jsx(Tooltip, { 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 })] }));
9277
+ };
9278
+
8652
9279
  const HiddenFilters = styled(Flex) `
8653
9280
  flex-wrap: wrap;
8654
9281
  margin-top: -1.25rem;
@@ -8747,7 +9374,7 @@ const PageNavigator = styled(Flex) `
8747
9374
  }
8748
9375
  `;
8749
9376
 
8750
- const Pagination = memo(({ type }) => {
9377
+ const Pagination = memo(({ type = WidgetType.Dashboard }) => {
8751
9378
  const { nextPage, prevPage } = useWidgetContext(type);
8752
9379
  const { pages } = useWidgetConfig(type);
8753
9380
  return (jsxs(PageNavigator, { children: [jsx(IconButton, { kind: "prev", onClick: () => prevPage(pages.length) }), jsx(IconButton, { kind: "next", onClick: () => nextPage(pages.length) })] }));
@@ -9040,22 +9667,5 @@ const Map$1 = ({ zIndex, lowerSiblings, upperSiblings, onError, children, ...res
9040
9667
  }, children: children }), upperSiblings] }));
9041
9668
  };
9042
9669
 
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 };
9670
+ 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
9671
  //# sourceMappingURL=react.esm.js.map