@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.
- package/dist/components/Dashboard/components/DashboardHeader/index.d.ts +3 -0
- package/dist/components/Dashboard/components/FeatureCardButtons/index.d.ts +2 -0
- package/dist/components/Dashboard/components/FeatureCardHeader/index.d.ts +2 -0
- package/dist/components/Dashboard/components/FeatureCardTitle/index.d.ts +5 -0
- package/dist/components/Dashboard/components/Pagination/index.d.ts +1 -1
- package/dist/components/Dashboard/components/index.d.ts +4 -0
- package/dist/components/Dashboard/headers/DashboardDefaultHeader/index.d.ts +3 -0
- package/dist/components/Dashboard/headers/DashboardDefaultHeader/styled.d.ts +8 -0
- package/dist/components/Dashboard/headers/FeatureCardDefaultHeader/components/HeaderTitle.d.ts +4 -0
- package/dist/components/Dashboard/headers/FeatureCardDefaultHeader/index.d.ts +5 -0
- package/dist/components/Dashboard/headers/FeatureCardDefaultHeader/styled.d.ts +12 -0
- package/dist/components/Dashboard/headers/FeatureCardGradientHeader/index.d.ts +3 -0
- package/dist/components/Dashboard/headers/FeatureCardGradientHeader/styled.d.ts +4 -0
- package/dist/components/Dashboard/headers/FeatureCardIconHeader/index.d.ts +3 -0
- package/dist/components/Dashboard/headers/FeatureCardIconHeader/styled.d.ts +6 -0
- package/dist/components/Dashboard/headers/FeatureCardSlideshowHeader/index.d.ts +3 -0
- package/dist/components/Dashboard/headers/FeatureCardSlideshowHeader/styled.d.ts +8 -0
- package/dist/components/Dashboard/headers/index.d.ts +7 -0
- package/dist/components/Dashboard/hooks/index.d.ts +1 -0
- package/dist/components/Dashboard/hooks/useDashboardHeader.d.ts +2 -2
- package/dist/components/Dashboard/hooks/useGlobalContext.d.ts +0 -1
- package/dist/components/Dashboard/hooks/useHeaderRender.d.ts +2 -0
- package/dist/components/Dashboard/hooks/useWidgetContext.d.ts +8 -0
- package/dist/components/Dashboard/index.d.ts +1 -0
- package/dist/components/Dashboard/styled.d.ts +1 -0
- package/dist/components/Dashboard/utils/getDashboardHeader.d.ts +2 -0
- package/dist/components/Dashboard/utils/getFeatureCardHeader.d.ts +2 -0
- package/dist/components/Dashboard/utils/index.d.ts +2 -0
- package/dist/components/LayerIcon/index.d.ts +5 -0
- package/dist/components/LayerIcon/styled.d.ts +2 -0
- package/dist/components/LayerTree/types.d.ts +0 -2
- package/dist/components/index.d.ts +1 -0
- package/dist/contexts/DashboardContext/types.d.ts +8 -2
- package/dist/contexts/FeatureCardContext/types.d.ts +3 -1
- package/dist/contexts/GlobalContext/types.d.ts +1 -3
- package/dist/index.js +1342 -707
- package/dist/index.js.map +1 -1
- package/dist/react.esm.js +1038 -428
- package/dist/react.esm.js.map +1 -1
- 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,
|
|
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
|
|
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
|
-
|
|
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,
|
|
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,
|
|
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,
|
|
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
|
|
6544
|
-
|
|
6545
|
-
|
|
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
|
-
|
|
6549
|
-
|
|
6442
|
+
> * {
|
|
6443
|
+
z-index: 1;
|
|
6444
|
+
}
|
|
6550
6445
|
|
|
6551
|
-
|
|
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
|
-
|
|
6477
|
+
position: absolute;
|
|
6478
|
+
top: 0;
|
|
6479
|
+
left: 0;
|
|
6562
6480
|
}
|
|
6563
6481
|
`;
|
|
6564
|
-
const
|
|
6565
|
-
|
|
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
|
-
|
|
6569
|
-
width:
|
|
6570
|
-
height:
|
|
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
|
-
|
|
6573
|
-
|
|
6574
|
-
color: ${({ theme: { palette } }) => palette.elementDeep};
|
|
6575
|
-
}
|
|
6506
|
+
& > span::after {
|
|
6507
|
+
font-size: 2rem;
|
|
6576
6508
|
}
|
|
6577
6509
|
|
|
6578
|
-
|
|
6579
|
-
|
|
6580
|
-
color: ${({ theme: { palette } }) => palette.textDisabled};
|
|
6510
|
+
img {
|
|
6511
|
+
max-height: 1.875rem;
|
|
6581
6512
|
}
|
|
6582
6513
|
`;
|
|
6583
|
-
const
|
|
6584
|
-
|
|
6585
|
-
|
|
6586
|
-
|
|
6587
|
-
|
|
6588
|
-
|
|
6589
|
-
|
|
6590
|
-
|
|
6591
|
-
|
|
6592
|
-
|
|
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
|
-
|
|
6595
|
-
|
|
6596
|
-
|
|
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
|
|
6600
|
-
|
|
6601
|
-
|
|
6602
|
-
|
|
6603
|
-
|
|
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
|
-
|
|
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
|
|
6722
|
-
|
|
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
|
|
6726
|
-
const
|
|
6727
|
-
|
|
6728
|
-
const
|
|
6729
|
-
|
|
6730
|
-
|
|
6731
|
-
|
|
6732
|
-
|
|
6733
|
-
|
|
6734
|
-
|
|
6735
|
-
|
|
6736
|
-
|
|
6737
|
-
|
|
6738
|
-
|
|
6739
|
-
|
|
6740
|
-
|
|
6741
|
-
|
|
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
|
-
//
|
|
6744
|
-
|
|
7183
|
+
// currentPage={currentPage}
|
|
7184
|
+
// totalCount={totalCount}
|
|
7185
|
+
isOpen: isOpenGallery,
|
|
7186
|
+
// isLoading={isLoadingTimeline}
|
|
7187
|
+
// hasSidebar
|
|
7188
|
+
onClose: toggleGallery }))] }))] }));
|
|
6745
7189
|
};
|
|
6746
7190
|
|
|
6747
|
-
const
|
|
6748
|
-
const {
|
|
6749
|
-
|
|
6750
|
-
|
|
6751
|
-
|
|
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
|
|
6780
|
-
|
|
6781
|
-
|
|
6782
|
-
|
|
6783
|
-
|
|
6784
|
-
|
|
6785
|
-
|
|
6786
|
-
|
|
6787
|
-
|
|
6788
|
-
|
|
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
|
|
7247
|
+
const ElementLegend = memo(({ type, element, elementConfig, expandedContainers }) => {
|
|
6794
7248
|
const { attributes } = useWidgetContext(type);
|
|
6795
|
-
const {
|
|
6796
|
-
const {
|
|
6797
|
-
const
|
|
6798
|
-
const
|
|
6799
|
-
|
|
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
|
|
6871
|
-
|
|
6872
|
-
|
|
6873
|
-
|
|
6874
|
-
|
|
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
|
-
|
|
6877
|
-
|
|
7385
|
+
:hover:after {
|
|
7386
|
+
color: ${({ theme: { palette } }) => palette.icon};
|
|
7387
|
+
}
|
|
6878
7388
|
}
|
|
6879
7389
|
`;
|
|
6880
7390
|
|
|
6881
|
-
const
|
|
7391
|
+
const ElementTooltip = memo(({ type, elementConfig }) => {
|
|
6882
7392
|
const { attributes } = useWidgetContext(type);
|
|
6883
|
-
const
|
|
6884
|
-
const
|
|
6885
|
-
|
|
6886
|
-
|
|
6887
|
-
return (jsx(
|
|
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
|
|
6891
|
-
|
|
6892
|
-
|
|
6893
|
-
|
|
6894
|
-
|
|
6895
|
-
|
|
6896
|
-
|
|
6897
|
-
|
|
6898
|
-
|
|
6899
|
-
|
|
6900
|
-
|
|
6901
|
-
|
|
6902
|
-
|
|
6903
|
-
|
|
6904
|
-
|
|
6905
|
-
|
|
6906
|
-
|
|
6907
|
-
|
|
6908
|
-
|
|
6909
|
-
|
|
6910
|
-
|
|
6911
|
-
|
|
6912
|
-
|
|
6913
|
-
|
|
6914
|
-
|
|
6915
|
-
|
|
6916
|
-
|
|
6917
|
-
|
|
6918
|
-
|
|
6919
|
-
|
|
6920
|
-
|
|
6921
|
-
|
|
6922
|
-
|
|
6923
|
-
|
|
6924
|
-
|
|
6925
|
-
|
|
6926
|
-
|
|
6927
|
-
|
|
6928
|
-
|
|
6929
|
-
|
|
6930
|
-
|
|
6931
|
-
|
|
6932
|
-
|
|
6933
|
-
|
|
6934
|
-
|
|
6935
|
-
|
|
6936
|
-
|
|
6937
|
-
|
|
6938
|
-
|
|
6939
|
-
|
|
6940
|
-
|
|
6941
|
-
|
|
6942
|
-
|
|
6943
|
-
|
|
6944
|
-
|
|
6945
|
-
|
|
6946
|
-
|
|
6947
|
-
|
|
6948
|
-
|
|
6949
|
-
|
|
6950
|
-
|
|
6951
|
-
|
|
6952
|
-
|
|
6953
|
-
|
|
6954
|
-
|
|
6955
|
-
|
|
6956
|
-
|
|
6957
|
-
|
|
6958
|
-
|
|
6959
|
-
|
|
6960
|
-
|
|
6961
|
-
|
|
6962
|
-
|
|
6963
|
-
|
|
6964
|
-
|
|
6965
|
-
|
|
6966
|
-
|
|
6967
|
-
|
|
6968
|
-
|
|
6969
|
-
|
|
6970
|
-
|
|
6971
|
-
|
|
6972
|
-
|
|
6973
|
-
|
|
6974
|
-
|
|
6975
|
-
|
|
6976
|
-
|
|
6977
|
-
|
|
6978
|
-
|
|
6979
|
-
|
|
6980
|
-
|
|
6981
|
-
|
|
6982
|
-
|
|
6983
|
-
|
|
6984
|
-
|
|
6985
|
-
|
|
6986
|
-
|
|
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
|
-
|
|
6990
|
-
|
|
6991
|
-
|
|
6992
|
-
|
|
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
|
|
7007
|
-
|
|
7008
|
-
|
|
7009
|
-
|
|
7010
|
-
const {
|
|
7011
|
-
const
|
|
7012
|
-
|
|
7013
|
-
const
|
|
7014
|
-
|
|
7015
|
-
|
|
7016
|
-
|
|
7017
|
-
|
|
7018
|
-
|
|
7019
|
-
|
|
7020
|
-
|
|
7021
|
-
|
|
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
|
|
7025
|
-
const
|
|
7026
|
-
|
|
7027
|
-
});
|
|
7028
|
-
|
|
7029
|
-
const
|
|
7030
|
-
|
|
7031
|
-
|
|
7032
|
-
|
|
7033
|
-
|
|
7034
|
-
|
|
7035
|
-
|
|
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
|
|
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
|
-
|
|
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
|