@kando-env/kando-ui 1.2.449-alpha.17 → 1.2.449-alpha.19
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/lib/components/Header/InfoBar/InfoBar.js +2 -2
- package/lib/components/Links/StyledLink/StyledLink.js +16 -3
- package/lib/i18n/en.json +1 -1
- package/lib/macros/getVersion.js +1 -1
- package/lib/ui-kit/HierarchyGraph/AutoFitTree.js +4 -4
- package/lib/ui-kit/HierarchyGraph/HierarchyGraph.js +29 -66
- package/lib/ui-kit/HierarchyGraph/LeafSign.js +39 -7
- package/lib/ui-kit/HierarchyGraph/MicroStackedBarNode.js +5 -5
- package/lib/ui-kit/HierarchyGraph/NodeLayout.js +12 -10
- package/lib/ui-kit/HierarchyGraph/utils.js +1 -1
- package/lib/utilities/Truncate.js +4 -3
- package/package.json +1 -1
|
@@ -199,7 +199,7 @@ var InfoBar = function InfoBar(_ref) {
|
|
|
199
199
|
color: activeTab === 'graph' ? '#D81B60' : '#757575',
|
|
200
200
|
className: 'me-2'
|
|
201
201
|
}), /*#__PURE__*/_react.default.createElement(_reactI18next.Trans, {
|
|
202
|
-
i18nKey: 'header.
|
|
202
|
+
i18nKey: 'header.hierarchy'
|
|
203
203
|
})));
|
|
204
204
|
};
|
|
205
205
|
exports.InfoBar = InfoBar;
|
|
@@ -219,4 +219,4 @@ var NavItem = (0, _styledComponents.default)(_reactBootstrap.Nav.Link).withConfi
|
|
|
219
219
|
$is_active = _ref6.$is_active;
|
|
220
220
|
return $is_active ? theme.colorScheme.natural.n90 : theme.colorScheme.natural.n60;
|
|
221
221
|
});
|
|
222
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_Breadcrumbs","_Search","_interopRequireDefault","_reactBootstrap","_Navbar","_TimeFilter","_dots","_TopNavbar","_Analytics","_reactRedux","_reactI18next","_useNavContext2","_useQueryURL","_reactRouterDom","_urls","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","classNamesTabs","dashboard","map_active","map","dashboard_active","graph","InfoBar","_ref","parts","_ref$mapDisable","mapDisable","_ref$showGraph","showGraph","_useState","useState","_useState2","_slicedToArray2","partList","setPartList","queryURL","useQueryURL","activeTab","_useSelector","useSelector","_ref2","global_data","waterAuthorityName","waterAuthorityId","views","includes","_useNavContext","useNavContext","isRtl","history","useHistory","focusedArea","state","wwtp_dashboard","isArea","area_id","dashboardName","is_virtual","breadcrumbsUrl","urls","areaID","siteID","id","name","fetchAreaData","_ref3","_asyncToGenerator2","_regenerator","mark","_callee","url","response","data","wrap","_callee$","_context","prev","next","fetch","sent","ok","json","link","concat","_toConsumableArray2","breadcrumbs","Error","status","stop","_x","apply","arguments","useEffect","catch","e","console","error","message","setNav","navKey","analyticsTrack","selection","page_name","window","location","pathname","utility_name","push","createElement","expand","className","Toggle","ReactComponent","Col","md","sm","xs","Collapse","Nav","Text","Breadcrumbs","NavItem","$is_active","onClick","disabled","MapSvg","MapActiveSvg","Trans","i18nKey","placement","DashboardSvg","DashboardActiveSvg","GraphHierarchyIcon","color","exports","styled","Link","withConfig","displayName","componentId","_ref4","theme","colorScheme","natural","n90","n60","_ref5","primary","p1","_ref6"],"sources":["../../../../src/components/Header/InfoBar/InfoBar.tsx"],"sourcesContent":["import React, { useEffect, useState } from 'react';\nimport { Breadcrumbs } from './Breadcrumbs/Breadcrumbs';\nimport Search from './Search';\nimport { Col, Nav } from 'react-bootstrap';\nimport Navbar from 'react-bootstrap/Navbar';\nimport TimeFilter from './TimeFilter';\nimport { ReactComponent as ToggleIconSvg } from 'src/assets/icons/3-dots.svg';\nimport {\n  DashboardActiveSvg,\n  DashboardSvg,\n  MapActiveSvg,\n  MapSvg,\n  GraphHierarchyIcon,\n} from 'src/assets/icons/TopNavbar';\nimport { analyticsTrack } from 'src/utilities/Analytics';\nimport { useSelector } from 'react-redux';\nimport { Trans } from 'react-i18next';\nimport styled from 'styled-components/macro';\nimport { useNavContext } from 'src/hooks/useNavContext';\nimport useQueryURL from 'src/hooks/useQueryURL';\nimport { useHistory } from 'react-router-dom';\nimport { urls } from 'src/utilities/urls';\nimport { Part } from './types';\n\ninterface InfoBarProps {\n  parts: Part[];\n  mapDisable?: boolean;\n  showGraph?: boolean;\n}\nconst classNamesTabs = {\n  dashboard: { dashboard: 'd-none', map_active: 'd-none' },\n  map: { dashboard_active: 'd-none', map: 'd-none' },\n  graph: { dashboard_active: 'd-none', map_active: 'd-none' },\n};\nexport const InfoBar: React.FC<InfoBarProps> = ({\n  parts,\n  mapDisable = true,\n  showGraph = false,\n}) => {\n  const [partList, setPartList] = useState(parts);\n  const queryURL = useQueryURL();\n  let activeTab = mapDisable\n    ? 'dashboard'\n    : queryURL.get('view') || 'dashboard';\n  const { waterAuthorityName, waterAuthorityId } = useSelector(\n    ({ global_data }) => global_data,\n  );\n  const views = ['map', 'dashboard', 'graph'];\n  if (!views.includes(activeTab)) {\n    activeTab = 'dashboard';\n    queryURL.set('view', 'dashboard');\n  }\n  const { isRtl } = useNavContext();\n  const history = useHistory();\n  const focusedArea = useSelector((state) => state.wwtp_dashboard.focusedArea);\n  const isArea = focusedArea?.area_id;\n  const dashboardName = isArea\n    ? focusedArea?.is_virtual\n      ? 'Varea'\n      : 'Area'\n    : 'Site';\n  const breadcrumbsUrl = urls({\n    areaID: focusedArea?.area_id,\n    siteID: focusedArea?.id,\n    waterAuthorityId,\n  }).dashboard[dashboardName].name;\n\n  const fetchAreaData = async (url: string) => {\n    const response = await fetch(url);\n    if (response.ok) {\n      const data = await response.json();\n      setPartList([\n        {\n          link: '/dashboard_v2/index',\n          name: waterAuthorityName,\n        },\n        ...data.data.breadcrumbs,\n      ]);\n    } else {\n      throw new Error(`HTTP error! status: ${response.status}`);\n    }\n  };\n  useEffect(() => {\n    if (focusedArea?.id || focusedArea?.area_id) {\n      fetchAreaData(breadcrumbsUrl).catch((e) => {\n        console.error('Request error: ' + e.message);\n      });\n    } else {\n      setPartList(parts);\n    }\n  }, [focusedArea?.id, focusedArea?.area_id]);\n\n  useEffect(() => {\n    setPartList(parts);\n  }, [parts]);\n\n  const setNav = (navKey) => {\n    if (activeTab === navKey) {\n      return;\n    }\n    queryURL.set('view', navKey);\n    analyticsTrack('Click top bar nav switch', {\n      selection: navKey,\n      page_name: window.location.pathname,\n      utility_name: waterAuthorityName,\n    });\n    history.push(`${window.location.pathname}?${queryURL}`);\n  };\n  return (\n    <Navbar\n      expand=\"md\"\n      className=\"bg-white mt-5 pt-3 pb-0 p-md-0 mt-md-1 my-md-0 border-bottom border-top\"\n    >\n      <Navbar.Toggle\n        aria-controls=\"basic-navbar-nav\"\n        className={'p-2 me-2 my-auto border-0'}\n      >\n        <ToggleIconSvg />\n      </Navbar.Toggle>\n      <Col md={'auto'} sm={'auto'} xs={'auto'}>\n        <Navbar.Collapse id=\"basic-navbar-nav\">\n          <Nav\n            className={`${\n              isRtl ? 'border-left' : 'border-right'\n            } py-md-1 mx-md-0 px-1`}\n          >\n            <Navbar.Text className={'me-2'}>\n              <Search />\n            </Navbar.Text>\n            <Navbar.Text className={'me-2'}>\n              <TimeFilter />\n            </Navbar.Text>\n          </Nav>\n        </Navbar.Collapse>\n      </Col>\n      {partList && (\n        <Navbar.Text\n          className={`d-none d-md-block my-auto mx-1 ${\n            isRtl ? 'ml-auto' : 'mr-auto'\n          }`}\n        >\n          <Breadcrumbs parts={partList} />\n        </Navbar.Text>\n      )}\n      <NavItem\n        $is_active={activeTab === 'map'}\n        onClick={() => setNav('map')}\n        disabled={mapDisable}\n        className={'mb-n1'}\n      >\n        <MapSvg className={`${classNamesTabs[activeTab].map} me-2`} />\n        <MapActiveSvg\n          className={`${classNamesTabs[activeTab].map_active} me-2`}\n        />\n        <Trans i18nKey={'header.map'} />\n      </NavItem>\n      <NavItem\n        placement=\"end\"\n        $is_active={activeTab === 'dashboard'}\n        disabled={mapDisable}\n        className={'mb-n1'}\n        onClick={() => setNav('dashboard')}\n      >\n        <DashboardSvg\n          className={`${classNamesTabs[activeTab].dashboard} me-2`}\n        />\n        <DashboardActiveSvg\n          className={`${classNamesTabs[activeTab].dashboard_active} me-2`}\n        />\n        <Trans i18nKey={'header.dashboard'} />\n      </NavItem>\n      {showGraph && (\n        <NavItem\n          $is_active={activeTab === 'graph'}\n          onClick={() => setNav('graph')}\n          className={'mb-n1'}\n        >\n          <GraphHierarchyIcon\n            color={activeTab === 'graph' ? '#D81B60' : '#757575'}\n            className={'me-2'}\n          />\n          <Trans i18nKey={'header.graph'} />\n        </NavItem>\n      )}\n    </Navbar>\n  );\n};\n\nconst NavItem = styled(Nav.Link)<{ $is_active: boolean }>`\n  padding-left: 20px;\n  padding-right: 20px;\n  margin-top: 12px;\n  color: ${({ theme, $is_active }) =>\n    $is_active ? theme.colorScheme.natural.n90 : theme.colorScheme.natural.n60};\n  ${({ theme, $is_active }) =>\n    $is_active && `border-bottom: 2px solid ${theme.colorScheme.primary.p1};`}\n  &:hover {\n    color: ${({ theme, $is_active }) =>\n      $is_active\n        ? theme.colorScheme.natural.n90\n        : theme.colorScheme.natural.n60};\n  }\n`;\n"],"mappings":"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"}
|
|
222
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_Breadcrumbs","_Search","_interopRequireDefault","_reactBootstrap","_Navbar","_TimeFilter","_dots","_TopNavbar","_Analytics","_reactRedux","_reactI18next","_useNavContext2","_useQueryURL","_reactRouterDom","_urls","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","classNamesTabs","dashboard","map_active","map","dashboard_active","graph","InfoBar","_ref","parts","_ref$mapDisable","mapDisable","_ref$showGraph","showGraph","_useState","useState","_useState2","_slicedToArray2","partList","setPartList","queryURL","useQueryURL","activeTab","_useSelector","useSelector","_ref2","global_data","waterAuthorityName","waterAuthorityId","views","includes","_useNavContext","useNavContext","isRtl","history","useHistory","focusedArea","state","wwtp_dashboard","isArea","area_id","dashboardName","is_virtual","breadcrumbsUrl","urls","areaID","siteID","id","name","fetchAreaData","_ref3","_asyncToGenerator2","_regenerator","mark","_callee","url","response","data","wrap","_callee$","_context","prev","next","fetch","sent","ok","json","link","concat","_toConsumableArray2","breadcrumbs","Error","status","stop","_x","apply","arguments","useEffect","catch","e","console","error","message","setNav","navKey","analyticsTrack","selection","page_name","window","location","pathname","utility_name","push","createElement","expand","className","Toggle","ReactComponent","Col","md","sm","xs","Collapse","Nav","Text","Breadcrumbs","NavItem","$is_active","onClick","disabled","MapSvg","MapActiveSvg","Trans","i18nKey","placement","DashboardSvg","DashboardActiveSvg","GraphHierarchyIcon","color","exports","styled","Link","withConfig","displayName","componentId","_ref4","theme","colorScheme","natural","n90","n60","_ref5","primary","p1","_ref6"],"sources":["../../../../src/components/Header/InfoBar/InfoBar.tsx"],"sourcesContent":["import React, { useEffect, useState } from 'react';\nimport { Breadcrumbs } from './Breadcrumbs/Breadcrumbs';\nimport Search from './Search';\nimport { Col, Nav } from 'react-bootstrap';\nimport Navbar from 'react-bootstrap/Navbar';\nimport TimeFilter from './TimeFilter';\nimport { ReactComponent as ToggleIconSvg } from 'src/assets/icons/3-dots.svg';\nimport {\n  DashboardActiveSvg,\n  DashboardSvg,\n  MapActiveSvg,\n  MapSvg,\n  GraphHierarchyIcon,\n} from 'src/assets/icons/TopNavbar';\nimport { analyticsTrack } from 'src/utilities/Analytics';\nimport { useSelector } from 'react-redux';\nimport { Trans } from 'react-i18next';\nimport styled from 'styled-components/macro';\nimport { useNavContext } from 'src/hooks/useNavContext';\nimport useQueryURL from 'src/hooks/useQueryURL';\nimport { useHistory } from 'react-router-dom';\nimport { urls } from 'src/utilities/urls';\nimport { Part } from './types';\n\ninterface InfoBarProps {\n  parts: Part[];\n  mapDisable?: boolean;\n  showGraph?: boolean;\n}\nconst classNamesTabs = {\n  dashboard: { dashboard: 'd-none', map_active: 'd-none' },\n  map: { dashboard_active: 'd-none', map: 'd-none' },\n  graph: { dashboard_active: 'd-none', map_active: 'd-none' },\n};\nexport const InfoBar: React.FC<InfoBarProps> = ({\n  parts,\n  mapDisable = true,\n  showGraph = false,\n}) => {\n  const [partList, setPartList] = useState(parts);\n  const queryURL = useQueryURL();\n  let activeTab = mapDisable\n    ? 'dashboard'\n    : queryURL.get('view') || 'dashboard';\n  const { waterAuthorityName, waterAuthorityId } = useSelector(\n    ({ global_data }) => global_data,\n  );\n  const views = ['map', 'dashboard', 'graph'];\n  if (!views.includes(activeTab)) {\n    activeTab = 'dashboard';\n    queryURL.set('view', 'dashboard');\n  }\n  const { isRtl } = useNavContext();\n  const history = useHistory();\n  const focusedArea = useSelector((state) => state.wwtp_dashboard.focusedArea);\n  const isArea = focusedArea?.area_id;\n  const dashboardName = isArea\n    ? focusedArea?.is_virtual\n      ? 'Varea'\n      : 'Area'\n    : 'Site';\n  const breadcrumbsUrl = urls({\n    areaID: focusedArea?.area_id,\n    siteID: focusedArea?.id,\n    waterAuthorityId,\n  }).dashboard[dashboardName].name;\n\n  const fetchAreaData = async (url: string) => {\n    const response = await fetch(url);\n    if (response.ok) {\n      const data = await response.json();\n      setPartList([\n        {\n          link: '/dashboard_v2/index',\n          name: waterAuthorityName,\n        },\n        ...data.data.breadcrumbs,\n      ]);\n    } else {\n      throw new Error(`HTTP error! status: ${response.status}`);\n    }\n  };\n  useEffect(() => {\n    if (focusedArea?.id || focusedArea?.area_id) {\n      fetchAreaData(breadcrumbsUrl).catch((e) => {\n        console.error('Request error: ' + e.message);\n      });\n    } else {\n      setPartList(parts);\n    }\n  }, [focusedArea?.id, focusedArea?.area_id]);\n\n  useEffect(() => {\n    setPartList(parts);\n  }, [parts]);\n\n  const setNav = (navKey) => {\n    if (activeTab === navKey) {\n      return;\n    }\n    queryURL.set('view', navKey);\n    analyticsTrack('Click top bar nav switch', {\n      selection: navKey,\n      page_name: window.location.pathname,\n      utility_name: waterAuthorityName,\n    });\n    history.push(`${window.location.pathname}?${queryURL}`);\n  };\n  return (\n    <Navbar\n      expand=\"md\"\n      className=\"bg-white mt-5 pt-3 pb-0 p-md-0 mt-md-1 my-md-0 border-bottom border-top\"\n    >\n      <Navbar.Toggle\n        aria-controls=\"basic-navbar-nav\"\n        className={'p-2 me-2 my-auto border-0'}\n      >\n        <ToggleIconSvg />\n      </Navbar.Toggle>\n      <Col md={'auto'} sm={'auto'} xs={'auto'}>\n        <Navbar.Collapse id=\"basic-navbar-nav\">\n          <Nav\n            className={`${\n              isRtl ? 'border-left' : 'border-right'\n            } py-md-1 mx-md-0 px-1`}\n          >\n            <Navbar.Text className={'me-2'}>\n              <Search />\n            </Navbar.Text>\n            <Navbar.Text className={'me-2'}>\n              <TimeFilter />\n            </Navbar.Text>\n          </Nav>\n        </Navbar.Collapse>\n      </Col>\n      {partList && (\n        <Navbar.Text\n          className={`d-none d-md-block my-auto mx-1 ${\n            isRtl ? 'ml-auto' : 'mr-auto'\n          }`}\n        >\n          <Breadcrumbs parts={partList} />\n        </Navbar.Text>\n      )}\n      <NavItem\n        $is_active={activeTab === 'map'}\n        onClick={() => setNav('map')}\n        disabled={mapDisable}\n        className={'mb-n1'}\n      >\n        <MapSvg className={`${classNamesTabs[activeTab].map} me-2`} />\n        <MapActiveSvg\n          className={`${classNamesTabs[activeTab].map_active} me-2`}\n        />\n        <Trans i18nKey={'header.map'} />\n      </NavItem>\n      <NavItem\n        placement=\"end\"\n        $is_active={activeTab === 'dashboard'}\n        disabled={mapDisable}\n        className={'mb-n1'}\n        onClick={() => setNav('dashboard')}\n      >\n        <DashboardSvg\n          className={`${classNamesTabs[activeTab].dashboard} me-2`}\n        />\n        <DashboardActiveSvg\n          className={`${classNamesTabs[activeTab].dashboard_active} me-2`}\n        />\n        <Trans i18nKey={'header.dashboard'} />\n      </NavItem>\n      {showGraph && (\n        <NavItem\n          $is_active={activeTab === 'graph'}\n          onClick={() => setNav('graph')}\n          className={'mb-n1'}\n        >\n          <GraphHierarchyIcon\n            color={activeTab === 'graph' ? '#D81B60' : '#757575'}\n            className={'me-2'}\n          />\n          <Trans i18nKey={'header.hierarchy'} />\n        </NavItem>\n      )}\n    </Navbar>\n  );\n};\n\nconst NavItem = styled(Nav.Link)<{ $is_active: boolean }>`\n  padding-left: 20px;\n  padding-right: 20px;\n  margin-top: 12px;\n  color: ${({ theme, $is_active }) =>\n    $is_active ? theme.colorScheme.natural.n90 : theme.colorScheme.natural.n60};\n  ${({ theme, $is_active }) =>\n    $is_active && `border-bottom: 2px solid ${theme.colorScheme.primary.p1};`}\n  &:hover {\n    color: ${({ theme, $is_active }) =>\n      $is_active\n        ? theme.colorScheme.natural.n90\n        : theme.colorScheme.natural.n60};\n  }\n`;\n"],"mappings":"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"}
|
|
@@ -5,25 +5,38 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
5
5
|
value: true
|
|
6
6
|
});
|
|
7
7
|
exports.StyledLink = exports.Link = void 0;
|
|
8
|
+
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/slicedToArray"));
|
|
8
9
|
var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/objectWithoutProperties"));
|
|
9
10
|
var _styledComponents = _interopRequireDefault(require("styled-components"));
|
|
10
11
|
var _react = _interopRequireDefault(require("react"));
|
|
11
12
|
var _reactRouterDom = require("react-router-dom");
|
|
12
|
-
var _excluded = ["to", "children", "newParams"];
|
|
13
|
+
var _excluded = ["to", "children", "newParams", "updateParams"];
|
|
13
14
|
var Link = function Link(_ref) {
|
|
14
15
|
var to = _ref.to,
|
|
15
16
|
children = _ref.children,
|
|
16
17
|
_ref$newParams = _ref.newParams,
|
|
17
18
|
newParams = _ref$newParams === void 0 ? '' : _ref$newParams,
|
|
19
|
+
_ref$updateParams = _ref.updateParams,
|
|
20
|
+
updateParams = _ref$updateParams === void 0 ? {} : _ref$updateParams,
|
|
18
21
|
props = (0, _objectWithoutProperties2.default)(_ref, _excluded);
|
|
19
22
|
var _useLocation = (0, _reactRouterDom.useLocation)(),
|
|
20
23
|
search = _useLocation.search;
|
|
24
|
+
var params = new URLSearchParams(search);
|
|
25
|
+
Object.entries(updateParams).forEach(function (_ref2) {
|
|
26
|
+
var _ref3 = (0, _slicedToArray2.default)(_ref2, 2),
|
|
27
|
+
key = _ref3[0],
|
|
28
|
+
value = _ref3[1];
|
|
29
|
+
params.set(key, value);
|
|
30
|
+
});
|
|
21
31
|
return /*#__PURE__*/_react.default.createElement(_reactRouterDom.Link, Object.assign({
|
|
22
32
|
style: {
|
|
23
33
|
color: '#1d1d1d',
|
|
24
34
|
width: props.width || 'auto'
|
|
25
35
|
},
|
|
26
|
-
to:
|
|
36
|
+
to: {
|
|
37
|
+
pathname: to,
|
|
38
|
+
search: params.toString() + newParams
|
|
39
|
+
}
|
|
27
40
|
}, props), children);
|
|
28
41
|
};
|
|
29
42
|
exports.Link = Link;
|
|
@@ -32,4 +45,4 @@ var StyledLink = (0, _styledComponents.default)(Link).withConfig({
|
|
|
32
45
|
componentId: "sc-1m280i2-0"
|
|
33
46
|
})(["text-decoration:none;cursor:pointer;&:focus,&:hover,&:visited,&:link,&:active{text-decoration:none;}"]);
|
|
34
47
|
exports.StyledLink = StyledLink;
|
|
35
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
48
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIl9yZWFjdFJvdXRlckRvbSIsIl9leGNsdWRlZCIsIkxpbmsiLCJfcmVmIiwidG8iLCJjaGlsZHJlbiIsIl9yZWYkbmV3UGFyYW1zIiwibmV3UGFyYW1zIiwiX3JlZiR1cGRhdGVQYXJhbXMiLCJ1cGRhdGVQYXJhbXMiLCJwcm9wcyIsIl9vYmplY3RXaXRob3V0UHJvcGVydGllczIiLCJkZWZhdWx0IiwiX3VzZUxvY2F0aW9uIiwidXNlTG9jYXRpb24iLCJzZWFyY2giLCJwYXJhbXMiLCJVUkxTZWFyY2hQYXJhbXMiLCJPYmplY3QiLCJlbnRyaWVzIiwiZm9yRWFjaCIsIl9yZWYyIiwiX3JlZjMiLCJfc2xpY2VkVG9BcnJheTIiLCJrZXkiLCJ2YWx1ZSIsInNldCIsImNyZWF0ZUVsZW1lbnQiLCJhc3NpZ24iLCJzdHlsZSIsImNvbG9yIiwid2lkdGgiLCJwYXRobmFtZSIsInRvU3RyaW5nIiwiZXhwb3J0cyIsIlN0eWxlZExpbmsiLCJzdHlsZWQiLCJ3aXRoQ29uZmlnIiwiZGlzcGxheU5hbWUiLCJjb21wb25lbnRJZCJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9jb21wb25lbnRzL0xpbmtzL1N0eWxlZExpbmsvU3R5bGVkTGluay50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IExpbmsgYXMgUm91dGVyTGluaywgdXNlTG9jYXRpb24gfSBmcm9tICdyZWFjdC1yb3V0ZXItZG9tJztcbmltcG9ydCBzdHlsZWQgZnJvbSAnc3R5bGVkLWNvbXBvbmVudHMvbWFjcm8nO1xuXG5leHBvcnQgY29uc3QgTGluayA9ICh7XG4gIHRvLFxuICBjaGlsZHJlbixcbiAgbmV3UGFyYW1zID0gJycsXG4gIHVwZGF0ZVBhcmFtcyA9IHt9LFxuICAuLi5wcm9wc1xufSkgPT4ge1xuICBjb25zdCB7IHNlYXJjaCB9ID0gdXNlTG9jYXRpb24oKTtcbiAgY29uc3QgcGFyYW1zID0gbmV3IFVSTFNlYXJjaFBhcmFtcyhzZWFyY2gpO1xuICBPYmplY3QuZW50cmllcyh1cGRhdGVQYXJhbXMpLmZvckVhY2goKFtrZXksIHZhbHVlXSkgPT4ge1xuICAgIHBhcmFtcy5zZXQoa2V5LCB2YWx1ZSk7XG4gIH0pO1xuXG4gIHJldHVybiAoXG4gICAgPFJvdXRlckxpbmtcbiAgICAgIHN0eWxlPXt7XG4gICAgICAgIGNvbG9yOiAnIzFkMWQxZCcsXG4gICAgICAgIHdpZHRoOiBwcm9wcy53aWR0aCB8fCAnYXV0bycsXG4gICAgICB9fVxuICAgICAgdG89e3sgcGF0aG5hbWU6IHRvLCBzZWFyY2g6IHBhcmFtcy50b1N0cmluZygpICsgbmV3UGFyYW1zIH19XG4gICAgICB7Li4ucHJvcHN9XG4gICAgPlxuICAgICAge2NoaWxkcmVufVxuICAgIDwvUm91dGVyTGluaz5cbiAgKTtcbn07XG5cbmV4cG9ydCBjb25zdCBTdHlsZWRMaW5rID0gc3R5bGVkKExpbmspYFxuICB0ZXh0LWRlY29yYXRpb246IG5vbmU7XG4gIGN1cnNvcjogcG9pbnRlcjtcbiAgJjpmb2N1cyxcbiAgJjpob3ZlcixcbiAgJjp2aXNpdGVkLFxuICAmOmxpbmssXG4gICY6YWN0aXZlIHtcbiAgICB0ZXh0LWRlY29yYXRpb246IG5vbmU7XG4gIH1cbmA7XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7QUFBQSxJQUFBQSxNQUFBLEdBQUFDLHNCQUFBLENBQUFDLE9BQUE7QUFDQSxJQUFBQyxlQUFBLEdBQUFELE9BQUE7QUFBbUUsSUFBQUUsU0FBQTtBQUc1RCxJQUFNQyxJQUFJLEdBQUcsU0FBUEEsSUFBSUEsQ0FBQUMsSUFBQSxFQU1YO0VBQUEsSUFMSkMsRUFBRSxHQUFBRCxJQUFBLENBQUZDLEVBQUU7SUFDRkMsUUFBUSxHQUFBRixJQUFBLENBQVJFLFFBQVE7SUFBQUMsY0FBQSxHQUFBSCxJQUFBLENBQ1JJLFNBQVM7SUFBVEEsU0FBUyxHQUFBRCxjQUFBLGNBQUcsRUFBRSxHQUFBQSxjQUFBO0lBQUFFLGlCQUFBLEdBQUFMLElBQUEsQ0FDZE0sWUFBWTtJQUFaQSxZQUFZLEdBQUFELGlCQUFBLGNBQUcsQ0FBQyxDQUFDLEdBQUFBLGlCQUFBO0lBQ2RFLEtBQUssT0FBQUMseUJBQUEsQ0FBQUMsT0FBQSxFQUFBVCxJQUFBLEVBQUFGLFNBQUE7RUFFUixJQUFBWSxZQUFBLEdBQW1CLElBQUFDLDJCQUFXLEVBQUMsQ0FBQztJQUF4QkMsTUFBTSxHQUFBRixZQUFBLENBQU5FLE1BQU07RUFDZCxJQUFNQyxNQUFNLEdBQUcsSUFBSUMsZUFBZSxDQUFDRixNQUFNLENBQUM7RUFDMUNHLE1BQU0sQ0FBQ0MsT0FBTyxDQUFDVixZQUFZLENBQUMsQ0FBQ1csT0FBTyxDQUFDLFVBQUFDLEtBQUEsRUFBa0I7SUFBQSxJQUFBQyxLQUFBLE9BQUFDLGVBQUEsQ0FBQVgsT0FBQSxFQUFBUyxLQUFBO01BQWhCRyxHQUFHLEdBQUFGLEtBQUE7TUFBRUcsS0FBSyxHQUFBSCxLQUFBO0lBQy9DTixNQUFNLENBQUNVLEdBQUcsQ0FBQ0YsR0FBRyxFQUFFQyxLQUFLLENBQUM7RUFDeEIsQ0FBQyxDQUFDO0VBRUYsb0JBQ0U1QixNQUFBLENBQUFlLE9BQUEsQ0FBQWUsYUFBQSxDQUFDM0IsZUFBQSxDQUFBRSxJQUFVLEVBQUFnQixNQUFBLENBQUFVLE1BQUE7SUFDVEMsS0FBSyxFQUFFO01BQ0xDLEtBQUssRUFBRSxTQUFTO01BQ2hCQyxLQUFLLEVBQUVyQixLQUFLLENBQUNxQixLQUFLLElBQUk7SUFDeEIsQ0FBRTtJQUNGM0IsRUFBRSxFQUFFO01BQUU0QixRQUFRLEVBQUU1QixFQUFFO01BQUVXLE1BQU0sRUFBRUMsTUFBTSxDQUFDaUIsUUFBUSxDQUFDLENBQUMsR0FBRzFCO0lBQVU7RUFBRSxHQUN4REcsS0FBSyxHQUVSTCxRQUNTLENBQUM7QUFFakIsQ0FBQztBQUFDNkIsT0FBQSxDQUFBaEMsSUFBQSxHQUFBQSxJQUFBO0FBRUssSUFBTWlDLFVBQVUsR0FBRyxJQUFBQyx5QkFBTSxFQUFDbEMsSUFBSSxDQUFDLENBQUFtQyxVQUFBO0VBQUFDLFdBQUE7RUFBQUMsV0FBQTtBQUFBLDRHQVVyQztBQUFDTCxPQUFBLENBQUFDLFVBQUEsR0FBQUEsVUFBQSJ9
|
package/lib/i18n/en.json
CHANGED
package/lib/macros/getVersion.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
var packageJsonVersion = "1.2.449-alpha.
|
|
3
|
+
var packageJsonVersion = "1.2.449-alpha.19";
|
|
4
4
|
if (typeof packageJsonVersion === 'string') {
|
|
5
5
|
// eslint-disable-next-line no-console
|
|
6
6
|
console.log("%c Kando UI %c v".concat(packageJsonVersion, " "), 'font-size: 15px; background-color: #fff; color: #e20f53;', 'font-weight: bold; font-size: 15px; background-color: #e20f53; color: #fff;', "with NODE_ENV=".concat(process.env.NODE_ENV));
|
|
@@ -42,13 +42,13 @@ function AutoFitTree(_ref) {
|
|
|
42
42
|
initialDepth = _ref.initialDepth,
|
|
43
43
|
nodeType = _ref.nodeType,
|
|
44
44
|
rest = (0, _objectWithoutProperties2.default)(_ref, _excluded);
|
|
45
|
-
var PADDING =
|
|
45
|
+
var PADDING = 35; // screen padding in px
|
|
46
46
|
var wrapperRef = (0, _react.useRef)(null);
|
|
47
47
|
var _useParams = (0, _reactRouterDom.useParams)(),
|
|
48
48
|
siteID = _useParams.siteID;
|
|
49
49
|
var nodeSize = {
|
|
50
50
|
x: 270,
|
|
51
|
-
y:
|
|
51
|
+
y: 270
|
|
52
52
|
}; // how much space each node occupies
|
|
53
53
|
var separation = {
|
|
54
54
|
siblings: 0.8,
|
|
@@ -157,8 +157,8 @@ function AutoFitTree(_ref) {
|
|
|
157
157
|
max: 2
|
|
158
158
|
},
|
|
159
159
|
renderCustomNodeElement: renderCustomNodeElement,
|
|
160
|
-
collapsible:
|
|
160
|
+
collapsible: true,
|
|
161
161
|
initialDepth: initialDepth
|
|
162
162
|
}, rest)));
|
|
163
163
|
}
|
|
164
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reactD3Tree","_interopRequireDefault","_reactRouterDom","_PieNode","_MicroStackedBarNode","_excluded","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","countDepthAndBreadth","root","maxDepth","breadthByDepth","dfs","n","_n$children","d","arguments","length","undefined","Math","max","children","forEach","c","maxBreadth","apply","AutoFitTree","_ref","data","_ref$orientation","orientation","initialDepth","nodeType","rest","_objectWithoutProperties2","PADDING","wrapperRef","useRef","_useParams","useParams","siteID","nodeSize","x","y","separation","siblings","nonSiblings","_useState","useState","width","height","_useState2","_slicedToArray2","dims","setDims","useEffect","current","ro","ResizeObserver","r","getBoundingClientRect","observe","disconnect","_useMemo","useMemo","_countDepthAndBreadth","reqW","reqH","availW","availH","fitZoom","min","z","isFinite","zoom","translate","setCollapsedByDepth","node","_node$children","collapsed","viewData","clone","JSON","parse","stringify","renderCustomNodeElement","rd3tProps","createElement","assign","onNodeClick","ref","style","overflow","pathFunc","zoomable","scaleExtent","collapsible"],"sources":["../../../src/ui-kit/HierarchyGraph/AutoFitTree.tsx"],"sourcesContent":["import React, { useRef, useState, useEffect, useMemo } from 'react';\nimport Tree, { RawNodeDatum } from 'react-d3-tree';\nimport { useParams } from 'react-router-dom';\nimport PieNode from './PieNode';\nimport MicroStackedBarNode from './MicroStackedBarNode';\nimport { NodeType } from './utils';\n\ntype Sep = { siblings: number; nonSiblings: number };\n\nfunction countDepthAndBreadth(root: RawNodeDatum) {\n  let maxDepth = 0;\n  const breadthByDepth: number[] = [];\n  const dfs = (n: RawNodeDatum, d = 0) => {\n    maxDepth = Math.max(maxDepth, d);\n    breadthByDepth[d] = (breadthByDepth[d] || 0) + 1;\n    n.children?.forEach((c) => dfs(c, d + 1));\n  };\n  dfs(root);\n  const maxBreadth = Math.max(...breadthByDepth);\n  return { maxDepth, maxBreadth };\n}\nexport default function AutoFitTree({\n  data,\n  orientation = 'vertical',\n  initialDepth,\n  nodeType,\n  ...rest\n}: {\n  data: any;\n  orientation?: 'vertical' | 'horizontal';\n  initialDepth: number;\n  onNodeClick?: (nodeData: any) => void;\n  nodeType: NodeType;\n}) {\n  const PADDING = 30; // screen padding in px\n  const wrapperRef = useRef<HTMLDivElement>(null);\n  const { siteID } = useParams();\n  const nodeSize = { x: 270, y: 250 }; // how much space each node occupies\n  const separation: Sep = { siblings: 0.8, nonSiblings: 0.9 }; // node spacing\n  const [dims, setDims] = useState({ width: 500, height: 100 });\n\n  // keep wrapper sized to the viewport\n  useEffect(() => {\n    if (!wrapperRef.current) return;\n    const ro = new ResizeObserver(() => {\n      const r = wrapperRef.current!.getBoundingClientRect();\n      setDims({ width: r.width, height: r.height });\n    });\n    ro.observe(wrapperRef.current);\n    return () => ro.disconnect();\n  }, []);\n\n  const { translate, zoom } = useMemo(() => {\n    const { maxDepth, maxBreadth } = countDepthAndBreadth(data);\n\n    // approximate required pixel size of the laid-out tree\n    const reqW =\n      orientation === 'horizontal'\n        ? (maxDepth + 1) * nodeSize.x\n        : maxBreadth * nodeSize.x * separation.siblings;\n    const reqH =\n      orientation === 'horizontal'\n        ? maxBreadth * nodeSize.y * separation.siblings\n        : (maxDepth + 1) * nodeSize.y;\n\n    const availW = Math.max(1, dims.width - PADDING * 2);\n    const availH = Math.max(1, dims.height - PADDING * 2);\n\n    const fitZoom = 0.7 * Math.min(availW / reqW, availH / reqH);\n    const z = isFinite(fitZoom) && fitZoom > 0 ? fitZoom : 1.2;\n\n    // anchor === \"edge\": put root at the leading edge + padding\n    if (orientation === 'horizontal') {\n      // root on the LEFT, vertically centered\n      return { zoom: z, translate: { x: PADDING, y: dims.height / 2 } };\n    } else {\n      // orientation === \"vertical\" → root on the TOP, horizontally centered\n      return { zoom: z, translate: { x: dims.width / 2, y: PADDING } };\n    }\n  }, [\n    data,\n    nodeSize.x,\n    nodeSize.y,\n    separation.siblings,\n    orientation,\n    dims.width,\n    dims.height,\n  ]);\n\n  function setCollapsedByDepth(node: any, maxDepth: number, d = 0) {\n    node.collapsed = d >= maxDepth;\n    node.children?.forEach((c) => setCollapsedByDepth(c, maxDepth, d + 1));\n    return node;\n  }\n\n  const viewData = useMemo(() => {\n    if (!data) return null;\n    const clone = JSON.parse(JSON.stringify(data));\n    return setCollapsedByDepth(clone, initialDepth);\n  }, [data, initialDepth]);\n\n  const renderCustomNodeElement = (rd3tProps) =>\n    nodeType === 'pie' ? (\n      <PieNode {...rd3tProps} siteID={siteID} onNodeClick={rest.onNodeClick} />\n    ) : (\n      <MicroStackedBarNode\n        {...rd3tProps}\n        siteID={siteID}\n        onNodeClick={rest.onNodeClick}\n      />\n    );\n\n  return (\n    <div\n      ref={wrapperRef}\n      style={{ width: '100vw', height: '100vh', overflow: 'hidden' }}\n    >\n      <Tree\n        data={viewData}\n        orientation={orientation}\n        pathFunc=\"step\"\n        nodeSize={nodeSize}\n        separation={separation}\n        translate={translate}\n        zoom={zoom}\n        zoomable\n        scaleExtent={{ min: 0.1, max: 2 }}\n        renderCustomNodeElement={renderCustomNodeElement}\n        collapsible={false}\n        initialDepth={initialDepth}\n        {...rest}\n      />\n    </div>\n  );\n}\n"],"mappings":"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"}
|
|
164
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reactD3Tree","_interopRequireDefault","_reactRouterDom","_PieNode","_MicroStackedBarNode","_excluded","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","countDepthAndBreadth","root","maxDepth","breadthByDepth","dfs","n","_n$children","d","arguments","length","undefined","Math","max","children","forEach","c","maxBreadth","apply","AutoFitTree","_ref","data","_ref$orientation","orientation","initialDepth","nodeType","rest","_objectWithoutProperties2","PADDING","wrapperRef","useRef","_useParams","useParams","siteID","nodeSize","x","y","separation","siblings","nonSiblings","_useState","useState","width","height","_useState2","_slicedToArray2","dims","setDims","useEffect","current","ro","ResizeObserver","r","getBoundingClientRect","observe","disconnect","_useMemo","useMemo","_countDepthAndBreadth","reqW","reqH","availW","availH","fitZoom","min","z","isFinite","zoom","translate","setCollapsedByDepth","node","_node$children","collapsed","viewData","clone","JSON","parse","stringify","renderCustomNodeElement","rd3tProps","createElement","assign","onNodeClick","ref","style","overflow","pathFunc","zoomable","scaleExtent","collapsible"],"sources":["../../../src/ui-kit/HierarchyGraph/AutoFitTree.tsx"],"sourcesContent":["import React, { useRef, useState, useEffect, useMemo } from 'react';\nimport Tree, { RawNodeDatum } from 'react-d3-tree';\nimport { useParams } from 'react-router-dom';\nimport PieNode from './PieNode';\nimport MicroStackedBarNode from './MicroStackedBarNode';\nimport { NodeType } from './utils';\n\ntype Sep = { siblings: number; nonSiblings: number };\n\nfunction countDepthAndBreadth(root: RawNodeDatum) {\n  let maxDepth = 0;\n  const breadthByDepth: number[] = [];\n  const dfs = (n: RawNodeDatum, d = 0) => {\n    maxDepth = Math.max(maxDepth, d);\n    breadthByDepth[d] = (breadthByDepth[d] || 0) + 1;\n    n.children?.forEach((c) => dfs(c, d + 1));\n  };\n  dfs(root);\n  const maxBreadth = Math.max(...breadthByDepth);\n  return { maxDepth, maxBreadth };\n}\nexport default function AutoFitTree({\n  data,\n  orientation = 'vertical',\n  initialDepth,\n  nodeType,\n  ...rest\n}: {\n  data: any;\n  orientation?: 'vertical' | 'horizontal';\n  initialDepth: number;\n  onNodeClick?: (nodeData: any) => void;\n  nodeType: NodeType;\n}) {\n  const PADDING = 35; // screen padding in px\n  const wrapperRef = useRef<HTMLDivElement>(null);\n  const { siteID } = useParams();\n  const nodeSize = { x: 270, y: 270 }; // how much space each node occupies\n  const separation: Sep = { siblings: 0.8, nonSiblings: 0.9 }; // node spacing\n  const [dims, setDims] = useState({ width: 500, height: 100 });\n\n  // keep wrapper sized to the viewport\n  useEffect(() => {\n    if (!wrapperRef.current) return;\n    const ro = new ResizeObserver(() => {\n      const r = wrapperRef.current!.getBoundingClientRect();\n      setDims({ width: r.width, height: r.height });\n    });\n    ro.observe(wrapperRef.current);\n    return () => ro.disconnect();\n  }, []);\n\n  const { translate, zoom } = useMemo(() => {\n    const { maxDepth, maxBreadth } = countDepthAndBreadth(data);\n\n    // approximate required pixel size of the laid-out tree\n    const reqW =\n      orientation === 'horizontal'\n        ? (maxDepth + 1) * nodeSize.x\n        : maxBreadth * nodeSize.x * separation.siblings;\n    const reqH =\n      orientation === 'horizontal'\n        ? maxBreadth * nodeSize.y * separation.siblings\n        : (maxDepth + 1) * nodeSize.y;\n\n    const availW = Math.max(1, dims.width - PADDING * 2);\n    const availH = Math.max(1, dims.height - PADDING * 2);\n\n    const fitZoom = 0.7 * Math.min(availW / reqW, availH / reqH);\n    const z = isFinite(fitZoom) && fitZoom > 0 ? fitZoom : 1.2;\n\n    // anchor === \"edge\": put root at the leading edge + padding\n    if (orientation === 'horizontal') {\n      // root on the LEFT, vertically centered\n      return { zoom: z, translate: { x: PADDING, y: dims.height / 2 } };\n    } else {\n      // orientation === \"vertical\" → root on the TOP, horizontally centered\n      return { zoom: z, translate: { x: dims.width / 2, y: PADDING } };\n    }\n  }, [\n    data,\n    nodeSize.x,\n    nodeSize.y,\n    separation.siblings,\n    orientation,\n    dims.width,\n    dims.height,\n  ]);\n\n  function setCollapsedByDepth(node: any, maxDepth: number, d = 0) {\n    node.collapsed = d >= maxDepth;\n    node.children?.forEach((c) => setCollapsedByDepth(c, maxDepth, d + 1));\n    return node;\n  }\n\n  const viewData = useMemo(() => {\n    if (!data) return null;\n    const clone = JSON.parse(JSON.stringify(data));\n    return setCollapsedByDepth(clone, initialDepth);\n  }, [data, initialDepth]);\n\n  const renderCustomNodeElement = (rd3tProps) =>\n    nodeType === 'pie' ? (\n      <PieNode {...rd3tProps} siteID={siteID} onNodeClick={rest.onNodeClick} />\n    ) : (\n      <MicroStackedBarNode\n        {...rd3tProps}\n        siteID={siteID}\n        onNodeClick={rest.onNodeClick}\n      />\n    );\n\n  return (\n    <div\n      ref={wrapperRef}\n      style={{ width: '100vw', height: '100vh', overflow: 'hidden' }}\n    >\n      <Tree\n        data={viewData}\n        orientation={orientation}\n        pathFunc=\"step\"\n        nodeSize={nodeSize}\n        separation={separation}\n        translate={translate}\n        zoom={zoom}\n        zoomable\n        scaleExtent={{ min: 0.1, max: 2 }}\n        renderCustomNodeElement={renderCustomNodeElement}\n        collapsible\n        initialDepth={initialDepth}\n        {...rest}\n      />\n    </div>\n  );\n}\n"],"mappings":";;;;;;;;;;AAAA,IAAAA,MAAA,GAAAC,uBAAA,CAAAC,OAAA;AACA,IAAAC,YAAA,GAAAC,sBAAA,CAAAF,OAAA;AACA,IAAAG,eAAA,GAAAH,OAAA;AACA,IAAAI,QAAA,GAAAF,sBAAA,CAAAF,OAAA;AACA,IAAAK,oBAAA,GAAAH,sBAAA,CAAAF,OAAA;AAAwD,IAAAM,SAAA;AAAA,SAAAC,yBAAAC,WAAA,eAAAC,OAAA,kCAAAC,iBAAA,OAAAD,OAAA,QAAAE,gBAAA,OAAAF,OAAA,YAAAF,wBAAA,YAAAA,yBAAAC,WAAA,WAAAA,WAAA,GAAAG,gBAAA,GAAAD,iBAAA,KAAAF,WAAA;AAAA,SAAAT,wBAAAa,GAAA,EAAAJ,WAAA,SAAAA,WAAA,IAAAI,GAAA,IAAAA,GAAA,CAAAC,UAAA,WAAAD,GAAA,QAAAA,GAAA,aAAAE,OAAA,CAAAF,GAAA,yBAAAA,GAAA,4BAAAG,OAAA,EAAAH,GAAA,UAAAI,KAAA,GAAAT,wBAAA,CAAAC,WAAA,OAAAQ,KAAA,IAAAA,KAAA,CAAAC,GAAA,CAAAL,GAAA,YAAAI,KAAA,CAAAE,GAAA,CAAAN,GAAA,SAAAO,MAAA,WAAAC,qBAAA,GAAAC,MAAA,CAAAC,cAAA,IAAAD,MAAA,CAAAE,wBAAA,WAAAC,GAAA,IAAAZ,GAAA,QAAAY,GAAA,kBAAAH,MAAA,CAAAI,SAAA,CAAAC,cAAA,CAAAC,IAAA,CAAAf,GAAA,EAAAY,GAAA,SAAAI,IAAA,GAAAR,qBAAA,GAAAC,MAAA,CAAAE,wBAAA,CAAAX,GAAA,EAAAY,GAAA,cAAAI,IAAA,KAAAA,IAAA,CAAAV,GAAA,IAAAU,IAAA,CAAAC,GAAA,KAAAR,MAAA,CAAAC,cAAA,CAAAH,MAAA,EAAAK,GAAA,EAAAI,IAAA,YAAAT,MAAA,CAAAK,GAAA,IAAAZ,GAAA,CAAAY,GAAA,SAAAL,MAAA,CAAAJ,OAAA,GAAAH,GAAA,MAAAI,KAAA,IAAAA,KAAA,CAAAa,GAAA,CAAAjB,GAAA,EAAAO,MAAA,YAAAA,MAAA;AAKxD,SAASW,oBAAoBA,CAACC,IAAkB,EAAE;EAChD,IAAIC,QAAQ,GAAG,CAAC;EAChB,IAAMC,cAAwB,GAAG,EAAE;EACnC,IAAMC,GAAG,GAAG,SAANA,GAAGA,CAAIC,CAAe,EAAY;IAAA,IAAAC,WAAA;IAAA,IAAVC,CAAC,GAAAC,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAE,SAAA,GAAAF,SAAA,MAAG,CAAC;IACjCN,QAAQ,GAAGS,IAAI,CAACC,GAAG,CAACV,QAAQ,EAAEK,CAAC,CAAC;IAChCJ,cAAc,CAACI,CAAC,CAAC,GAAG,CAACJ,cAAc,CAACI,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC;IAChD,CAAAD,WAAA,GAAAD,CAAC,CAACQ,QAAQ,cAAAP,WAAA,uBAAVA,WAAA,CAAYQ,OAAO,CAAC,UAACC,CAAC;MAAA,OAAKX,GAAG,CAACW,CAAC,EAAER,CAAC,GAAG,CAAC,CAAC;IAAA,EAAC;EAC3C,CAAC;EACDH,GAAG,CAACH,IAAI,CAAC;EACT,IAAMe,UAAU,GAAGL,IAAI,CAACC,GAAG,CAAAK,KAAA,CAARN,IAAI,EAAQR,cAAc,CAAC;EAC9C,OAAO;IAAED,QAAQ,EAARA,QAAQ;IAAEc,UAAU,EAAVA;EAAW,CAAC;AACjC;AACe,SAASE,WAAWA,CAAAC,IAAA,EAYhC;EAAA,IAXDC,IAAI,GAAAD,IAAA,CAAJC,IAAI;IAAAC,gBAAA,GAAAF,IAAA,CACJG,WAAW;IAAXA,WAAW,GAAAD,gBAAA,cAAG,UAAU,GAAAA,gBAAA;IACxBE,YAAY,GAAAJ,IAAA,CAAZI,YAAY;IACZC,QAAQ,GAAAL,IAAA,CAARK,QAAQ;IACLC,IAAI,OAAAC,yBAAA,CAAAzC,OAAA,EAAAkC,IAAA,EAAA3C,SAAA;EAQP,IAAMmD,OAAO,GAAG,EAAE,CAAC,CAAC;EACpB,IAAMC,UAAU,GAAG,IAAAC,aAAM,EAAiB,IAAI,CAAC;EAC/C,IAAAC,UAAA,GAAmB,IAAAC,yBAAS,EAAC,CAAC;IAAtBC,MAAM,GAAAF,UAAA,CAANE,MAAM;EACd,IAAMC,QAAQ,GAAG;IAAEC,CAAC,EAAE,GAAG;IAAEC,CAAC,EAAE;EAAI,CAAC,CAAC,CAAC;EACrC,IAAMC,UAAe,GAAG;IAAEC,QAAQ,EAAE,GAAG;IAAEC,WAAW,EAAE;EAAI,CAAC,CAAC,CAAC;EAC7D,IAAAC,SAAA,GAAwB,IAAAC,eAAQ,EAAC;MAAEC,KAAK,EAAE,GAAG;MAAEC,MAAM,EAAE;IAAI,CAAC,CAAC;IAAAC,UAAA,OAAAC,eAAA,CAAA3D,OAAA,EAAAsD,SAAA;IAAtDM,IAAI,GAAAF,UAAA;IAAEG,OAAO,GAAAH,UAAA;;EAEpB;EACA,IAAAI,gBAAS,EAAC,YAAM;IACd,IAAI,CAACnB,UAAU,CAACoB,OAAO,EAAE;IACzB,IAAMC,EAAE,GAAG,IAAIC,cAAc,CAAC,YAAM;MAClC,IAAMC,CAAC,GAAGvB,UAAU,CAACoB,OAAO,CAAEI,qBAAqB,CAAC,CAAC;MACrDN,OAAO,CAAC;QAAEL,KAAK,EAAEU,CAAC,CAACV,KAAK;QAAEC,MAAM,EAAES,CAAC,CAACT;MAAO,CAAC,CAAC;IAC/C,CAAC,CAAC;IACFO,EAAE,CAACI,OAAO,CAACzB,UAAU,CAACoB,OAAO,CAAC;IAC9B,OAAO;MAAA,OAAMC,EAAE,CAACK,UAAU,CAAC,CAAC;IAAA;EAC9B,CAAC,EAAE,EAAE,CAAC;EAEN,IAAAC,QAAA,GAA4B,IAAAC,cAAO,EAAC,YAAM;MACxC,IAAAC,qBAAA,GAAiCzD,oBAAoB,CAACoB,IAAI,CAAC;QAAnDlB,QAAQ,GAAAuD,qBAAA,CAARvD,QAAQ;QAAEc,UAAU,GAAAyC,qBAAA,CAAVzC,UAAU;;MAE5B;MACA,IAAM0C,IAAI,GACRpC,WAAW,KAAK,YAAY,GACxB,CAACpB,QAAQ,GAAG,CAAC,IAAI+B,QAAQ,CAACC,CAAC,GAC3BlB,UAAU,GAAGiB,QAAQ,CAACC,CAAC,GAAGE,UAAU,CAACC,QAAQ;MACnD,IAAMsB,IAAI,GACRrC,WAAW,KAAK,YAAY,GACxBN,UAAU,GAAGiB,QAAQ,CAACE,CAAC,GAAGC,UAAU,CAACC,QAAQ,GAC7C,CAACnC,QAAQ,GAAG,CAAC,IAAI+B,QAAQ,CAACE,CAAC;MAEjC,IAAMyB,MAAM,GAAGjD,IAAI,CAACC,GAAG,CAAC,CAAC,EAAEiC,IAAI,CAACJ,KAAK,GAAGd,OAAO,GAAG,CAAC,CAAC;MACpD,IAAMkC,MAAM,GAAGlD,IAAI,CAACC,GAAG,CAAC,CAAC,EAAEiC,IAAI,CAACH,MAAM,GAAGf,OAAO,GAAG,CAAC,CAAC;MAErD,IAAMmC,OAAO,GAAG,GAAG,GAAGnD,IAAI,CAACoD,GAAG,CAACH,MAAM,GAAGF,IAAI,EAAEG,MAAM,GAAGF,IAAI,CAAC;MAC5D,IAAMK,CAAC,GAAGC,QAAQ,CAACH,OAAO,CAAC,IAAIA,OAAO,GAAG,CAAC,GAAGA,OAAO,GAAG,GAAG;;MAE1D;MACA,IAAIxC,WAAW,KAAK,YAAY,EAAE;QAChC;QACA,OAAO;UAAE4C,IAAI,EAAEF,CAAC;UAAEG,SAAS,EAAE;YAAEjC,CAAC,EAAEP,OAAO;YAAEQ,CAAC,EAAEU,IAAI,CAACH,MAAM,GAAG;UAAE;QAAE,CAAC;MACnE,CAAC,MAAM;QACL;QACA,OAAO;UAAEwB,IAAI,EAAEF,CAAC;UAAEG,SAAS,EAAE;YAAEjC,CAAC,EAAEW,IAAI,CAACJ,KAAK,GAAG,CAAC;YAAEN,CAAC,EAAER;UAAQ;QAAE,CAAC;MAClE;IACF,CAAC,EAAE,CACDP,IAAI,EACJa,QAAQ,CAACC,CAAC,EACVD,QAAQ,CAACE,CAAC,EACVC,UAAU,CAACC,QAAQ,EACnBf,WAAW,EACXuB,IAAI,CAACJ,KAAK,EACVI,IAAI,CAACH,MAAM,CACZ,CAAC;IAnCMyB,SAAS,GAAAZ,QAAA,CAATY,SAAS;IAAED,IAAI,GAAAX,QAAA,CAAJW,IAAI;EAqCvB,SAASE,mBAAmBA,CAACC,IAAS,EAAEnE,QAAgB,EAAS;IAAA,IAAAoE,cAAA;IAAA,IAAP/D,CAAC,GAAAC,SAAA,CAAAC,MAAA,QAAAD,SAAA,QAAAE,SAAA,GAAAF,SAAA,MAAG,CAAC;IAC7D6D,IAAI,CAACE,SAAS,GAAGhE,CAAC,IAAIL,QAAQ;IAC9B,CAAAoE,cAAA,GAAAD,IAAI,CAACxD,QAAQ,cAAAyD,cAAA,uBAAbA,cAAA,CAAexD,OAAO,CAAC,UAACC,CAAC;MAAA,OAAKqD,mBAAmB,CAACrD,CAAC,EAAEb,QAAQ,EAAEK,CAAC,GAAG,CAAC,CAAC;IAAA,EAAC;IACtE,OAAO8D,IAAI;EACb;EAEA,IAAMG,QAAQ,GAAG,IAAAhB,cAAO,EAAC,YAAM;IAC7B,IAAI,CAACpC,IAAI,EAAE,OAAO,IAAI;IACtB,IAAMqD,KAAK,GAAGC,IAAI,CAACC,KAAK,CAACD,IAAI,CAACE,SAAS,CAACxD,IAAI,CAAC,CAAC;IAC9C,OAAOgD,mBAAmB,CAACK,KAAK,EAAElD,YAAY,CAAC;EACjD,CAAC,EAAE,CAACH,IAAI,EAAEG,YAAY,CAAC,CAAC;EAExB,IAAMsD,uBAAuB,GAAG,SAA1BA,uBAAuBA,CAAIC,SAAS;IAAA,OACxCtD,QAAQ,KAAK,KAAK,gBAChBxD,MAAA,CAAAiB,OAAA,CAAA8F,aAAA,CAACzG,QAAA,CAAAW,OAAO,EAAAM,MAAA,CAAAyF,MAAA,KAAKF,SAAS;MAAE9C,MAAM,EAAEA,MAAO;MAACiD,WAAW,EAAExD,IAAI,CAACwD;IAAY,EAAE,CAAC,gBAEzEjH,MAAA,CAAAiB,OAAA,CAAA8F,aAAA,CAACxG,oBAAA,CAAAU,OAAmB,EAAAM,MAAA,CAAAyF,MAAA,KACdF,SAAS;MACb9C,MAAM,EAAEA,MAAO;MACfiD,WAAW,EAAExD,IAAI,CAACwD;IAAY,EAC/B,CACF;EAAA;EAEH,oBACEjH,MAAA,CAAAiB,OAAA,CAAA8F,aAAA;IACEG,GAAG,EAAEtD,UAAW;IAChBuD,KAAK,EAAE;MAAE1C,KAAK,EAAE,OAAO;MAAEC,MAAM,EAAE,OAAO;MAAE0C,QAAQ,EAAE;IAAS;EAAE,gBAE/DpH,MAAA,CAAAiB,OAAA,CAAA8F,aAAA,CAAC5G,YAAA,CAAAc,OAAI,EAAAM,MAAA,CAAAyF,MAAA;IACH5D,IAAI,EAAEoD,QAAS;IACflD,WAAW,EAAEA,WAAY;IACzB+D,QAAQ,EAAC,MAAM;IACfpD,QAAQ,EAAEA,QAAS;IACnBG,UAAU,EAAEA,UAAW;IACvB+B,SAAS,EAAEA,SAAU;IACrBD,IAAI,EAAEA,IAAK;IACXoB,QAAQ;IACRC,WAAW,EAAE;MAAExB,GAAG,EAAE,GAAG;MAAEnD,GAAG,EAAE;IAAE,CAAE;IAClCiE,uBAAuB,EAAEA,uBAAwB;IACjDW,WAAW;IACXjE,YAAY,EAAEA;EAAa,GACvBE,IAAI,CACT,CACE,CAAC;AAEV"}
|
|
@@ -28,26 +28,25 @@ var HierarchyGraph = function HierarchyGraph() {
|
|
|
28
28
|
var ReduxState = (0, _reactRedux.useSelector)(function (state) {
|
|
29
29
|
return state;
|
|
30
30
|
});
|
|
31
|
-
|
|
31
|
+
// const [orientation, setOrientation] = useState<'horizontal' | 'vertical'>(
|
|
32
|
+
// 'vertical',
|
|
33
|
+
// );
|
|
34
|
+
var _useState = (0, _react.useState)(12),
|
|
32
35
|
_useState2 = (0, _slicedToArray2.default)(_useState, 2),
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
var _useState3 = (0, _react.useState)(
|
|
36
|
+
depth = _useState2[0],
|
|
37
|
+
setDepth = _useState2[1];
|
|
38
|
+
var _useState3 = (0, _react.useState)('pie'),
|
|
36
39
|
_useState4 = (0, _slicedToArray2.default)(_useState3, 2),
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
var _useState5 = (0, _react.useState)(
|
|
40
|
+
nodeType = _useState4[0],
|
|
41
|
+
setNodeType = _useState4[1];
|
|
42
|
+
var _useState5 = (0, _react.useState)(null),
|
|
40
43
|
_useState6 = (0, _slicedToArray2.default)(_useState5, 2),
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
var _useState7 = (0, _react.useState)(
|
|
44
|
+
selectedPoint = _useState6[0],
|
|
45
|
+
setSelectedPoint = _useState6[1];
|
|
46
|
+
var _useState7 = (0, _react.useState)(false),
|
|
44
47
|
_useState8 = (0, _slicedToArray2.default)(_useState7, 2),
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
var _useState9 = (0, _react.useState)(false),
|
|
48
|
-
_useState10 = (0, _slicedToArray2.default)(_useState9, 2),
|
|
49
|
-
showRightPanel = _useState10[0],
|
|
50
|
-
setShowRightPanel = _useState10[1];
|
|
48
|
+
showRightPanel = _useState8[0],
|
|
49
|
+
setShowRightPanel = _useState8[1];
|
|
51
50
|
var isGraphTab = searchQuery.get('view') === 'graph';
|
|
52
51
|
var points_data = ReduxState.points_data,
|
|
53
52
|
edges_data = ReduxState.edges_data,
|
|
@@ -63,34 +62,24 @@ var HierarchyGraph = function HierarchyGraph() {
|
|
|
63
62
|
var factoriesEndPoint = (0, _react.useMemo)(function () {
|
|
64
63
|
return (0, _urls.urls)().dashboard.Utility.factories;
|
|
65
64
|
}, []);
|
|
66
|
-
var
|
|
65
|
+
var paramsAll = (0, _react.useMemo)(function () {
|
|
67
66
|
return {
|
|
68
|
-
type: '
|
|
69
|
-
};
|
|
70
|
-
}, []);
|
|
71
|
-
var paramsCollectors = (0, _react.useMemo)(function () {
|
|
72
|
-
return {
|
|
73
|
-
type: 'Collectors'
|
|
67
|
+
type: 'All'
|
|
74
68
|
};
|
|
75
69
|
}, []);
|
|
76
70
|
|
|
77
71
|
// fetches
|
|
78
|
-
var _useApiWithDashboardQ = (0, _useApiWithDashboardQuery.useApiWithDashboardQuery)(factoriesEndPoint,
|
|
72
|
+
var _useApiWithDashboardQ = (0, _useApiWithDashboardQuery.useApiWithDashboardQuery)(factoriesEndPoint, paramsAll),
|
|
79
73
|
_useApiWithDashboardQ2 = (0, _slicedToArray2.default)(_useApiWithDashboardQ, 3),
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
var _useApiWithDashboardQ3 = (0, _useApiWithDashboardQuery.useApiWithDashboardQuery)(factoriesEndPoint, paramsCollectors),
|
|
84
|
-
_useApiWithDashboardQ4 = (0, _slicedToArray2.default)(_useApiWithDashboardQ3, 3),
|
|
85
|
-
responseCollectors = _useApiWithDashboardQ4[0],
|
|
86
|
-
isLoadingCollectors = _useApiWithDashboardQ4[1],
|
|
87
|
-
errorCollectors = _useApiWithDashboardQ4[2];
|
|
74
|
+
responseSites = _useApiWithDashboardQ2[0],
|
|
75
|
+
isLoadingSites = _useApiWithDashboardQ2[1],
|
|
76
|
+
errorSites = _useApiWithDashboardQ2[2];
|
|
88
77
|
|
|
89
78
|
// 1) Build a pollution map from both responses (no state; pure memo)
|
|
90
79
|
var pollutionBySiteId = (0, _react.useMemo)(function () {
|
|
91
80
|
var m = new Map();
|
|
92
|
-
if (
|
|
93
|
-
var _iterator = (0, _createForOfIteratorHelper2.default)(
|
|
81
|
+
if (responseSites === null || responseSites === void 0 ? void 0 : responseSites.data) {
|
|
82
|
+
var _iterator = (0, _createForOfIteratorHelper2.default)(responseSites.data),
|
|
94
83
|
_step;
|
|
95
84
|
try {
|
|
96
85
|
for (_iterator.s(); !(_step = _iterator.n()).done;) {
|
|
@@ -105,24 +94,8 @@ var HierarchyGraph = function HierarchyGraph() {
|
|
|
105
94
|
_iterator.f();
|
|
106
95
|
}
|
|
107
96
|
}
|
|
108
|
-
if (responseCollectors === null || responseCollectors === void 0 ? void 0 : responseCollectors.data) {
|
|
109
|
-
var _iterator2 = (0, _createForOfIteratorHelper2.default)(responseCollectors.data),
|
|
110
|
-
_step2;
|
|
111
|
-
try {
|
|
112
|
-
for (_iterator2.s(); !(_step2 = _iterator2.n()).done;) {
|
|
113
|
-
var _step2$value = _step2.value,
|
|
114
|
-
_site_id = _step2$value.site_id,
|
|
115
|
-
_pollution = _step2$value.pollution;
|
|
116
|
-
if (_pollution === null || _pollution === void 0 ? void 0 : _pollution.type_distribution) m.set(_site_id, _pollution.type_distribution);
|
|
117
|
-
}
|
|
118
|
-
} catch (err) {
|
|
119
|
-
_iterator2.e(err);
|
|
120
|
-
} finally {
|
|
121
|
-
_iterator2.f();
|
|
122
|
-
}
|
|
123
|
-
}
|
|
124
97
|
return m;
|
|
125
|
-
}, [
|
|
98
|
+
}, [responseSites === null || responseSites === void 0 ? void 0 : responseSites.data]);
|
|
126
99
|
|
|
127
100
|
// 2) Create a SAFE copy of point_map_data with pollution merged in (no mutations)
|
|
128
101
|
var decoratedPointsById = (0, _react.useMemo)(function () {
|
|
@@ -153,12 +126,9 @@ var HierarchyGraph = function HierarchyGraph() {
|
|
|
153
126
|
|
|
154
127
|
// 4) Build the tree ONLY when data is ready; keep referential stability
|
|
155
128
|
var treeData = (0, _react.useMemo)(function () {
|
|
156
|
-
|
|
157
|
-
var hasError = errorFactory || errorCollectors;
|
|
158
|
-
if (loading || hasError) return null;
|
|
129
|
+
if (isLoadingSites || errorSites) return null;
|
|
159
130
|
return (0, _utils.buildTree)(edgesWithDevice, decoratedPointsById, waterAuthorityName);
|
|
160
|
-
}, [
|
|
161
|
-
var isLoading = isLoadingFactory || isLoadingCollectors;
|
|
131
|
+
}, [edgesWithDevice, decoratedPointsById, waterAuthorityName, isLoadingSites, errorSites]);
|
|
162
132
|
if (!isGraphTab) {
|
|
163
133
|
return null;
|
|
164
134
|
}
|
|
@@ -185,13 +155,7 @@ var HierarchyGraph = function HierarchyGraph() {
|
|
|
185
155
|
onClick: function onClick() {
|
|
186
156
|
return setDepth(12);
|
|
187
157
|
}
|
|
188
|
-
}, 'Expand All'), /*#__PURE__*/_react.default.createElement(
|
|
189
|
-
onClick: function onClick() {
|
|
190
|
-
return setOrientation(function (prev) {
|
|
191
|
-
return prev === 'horizontal' ? 'vertical' : 'horizontal';
|
|
192
|
-
});
|
|
193
|
-
}
|
|
194
|
-
}, 'Toggle Orientation'), /*#__PURE__*/_react.default.createElement(_Select.Select, {
|
|
158
|
+
}, 'Expand All'), /*#__PURE__*/_react.default.createElement(_Select.Select, {
|
|
195
159
|
options: nodeTypeOptions,
|
|
196
160
|
value: nodeTypeOptions.find(function (option) {
|
|
197
161
|
return option.value === nodeType;
|
|
@@ -213,11 +177,10 @@ var HierarchyGraph = function HierarchyGraph() {
|
|
|
213
177
|
style: {
|
|
214
178
|
height: '85vh'
|
|
215
179
|
}
|
|
216
|
-
}, edges_data.isFetching || points_data.isFetching || !treeData ||
|
|
180
|
+
}, edges_data.isFetching || points_data.isFetching || !treeData || isLoadingSites ? /*#__PURE__*/_react.default.createElement(_Loader.Loader, null) : /*#__PURE__*/_react.default.createElement(_AutoFitTree.default, {
|
|
217
181
|
initialDepth: depth,
|
|
218
182
|
data: treeData,
|
|
219
183
|
nodeType: nodeType,
|
|
220
|
-
orientation: orientation,
|
|
221
184
|
onNodeClick: onNodeClick
|
|
222
185
|
}), /*#__PURE__*/_react.default.createElement(_RightPanel.default, {
|
|
223
186
|
className: "right-panel ".concat(showRightPanel ? 'open' : ''),
|
|
@@ -230,4 +193,4 @@ var HierarchyGraph = function HierarchyGraph() {
|
|
|
230
193
|
};
|
|
231
194
|
var _default = HierarchyGraph;
|
|
232
195
|
exports.default = _default;
|
|
233
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_useQueryURL","_interopRequireDefault","_utils","_reactRedux","_AutoFitTree","_reactBootstrap","_Loader","_Button","_RightPanel","_urls","_useApiWithDashboardQuery","_Select","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","HierarchyGraph","searchQuery","useQueryURL","ReduxState","useSelector","state","_useState","useState","_useState2","_slicedToArray2","orientation","setOrientation","_useState3","_useState4","depth","setDepth","_useState5","_useState6","nodeType","setNodeType","_useState7","_useState8","selectedPoint","setSelectedPoint","_useState9","_useState10","showRightPanel","setShowRightPanel","isGraphTab","points_data","edges_data","waterAuthorityName","global_data","onNodeClick","nodeData","items","find","p","id","attributes","point_id","factoriesEndPoint","useMemo","urls","dashboard","Utility","factories","paramsFactory","type","paramsCollectors","_useApiWithDashboardQ","useApiWithDashboardQuery","_useApiWithDashboardQ2","responseFactory","isLoadingFactory","errorFactory","_useApiWithDashboardQ3","_useApiWithDashboardQ4","responseCollectors","isLoadingCollectors","errorCollectors","pollutionBySiteId","m","Map","data","_iterator","_createForOfIteratorHelper2","_step","s","n","done","_step$value","value","site_id","pollution","type_distribution","err","e","f","_iterator2","_step2","_step2$value","decoratedPointsById","base","mapById","copy","_i","_Object$keys","keys","length","numId","Number","_objectSpread2","edgesWithDevice","pointsWithDevice","filter","has_device","edge","source_point_id","descendants_has_device","treeData","loading","hasError","buildTree","isLoading","nodeTypeOptions","label","createElement","style","marginTop","marginInlineStart","display","gap","zIndex","onClick","prev","Select","options","option","setValue","selected","menuWidth","Container","fluid","className","overflow","Row","sm","Col","height","isFetching","Loader","initialDepth","concat","point","onClose","_default","exports"],"sources":["../../../src/ui-kit/HierarchyGraph/HierarchyGraph.tsx"],"sourcesContent":["import React, { useMemo } from 'react';\n\nimport useQueryURL from '../../hooks/useQueryURL';\nimport { buildTree, mapById, NodeType } from './utils';\nimport { useSelector } from 'react-redux';\nimport { useState } from 'react';\nimport AutoFitTree from './AutoFitTree';\nimport { Container, Row, Col } from 'react-bootstrap';\nimport { Loader } from '../../pages/DashboardMap/Loader';\nimport Button from '../Button/Button';\nimport RightPanel from '../../pages/OperationsPage/RightPanel';\nimport { urls } from '../../utilities/urls';\nimport { useApiWithDashboardQuery } from '../../hooks/useApiWithDashboardQuery';\nimport { FactoriesResponse } from '../../Widgets/MostPolluting/Factories/factoriesResponse.interface';\nimport { Select } from '../../components/CustomInputs/Select/Select';\n\nconst HierarchyGraph = () => {\n  const searchQuery = useQueryURL();\n  const ReduxState = useSelector((state) => state);\n  const [orientation, setOrientation] = useState<'horizontal' | 'vertical'>(\n    'vertical',\n  );\n  const [depth, setDepth] = useState<number>(12);\n  const [nodeType, setNodeType] = useState<NodeType>('pie');\n  const [selectedPoint, setSelectedPoint] = useState(null);\n  const [showRightPanel, setShowRightPanel] = useState(false);\n  const isGraphTab = searchQuery.get('view') === 'graph';\n  const {\n    points_data,\n    edges_data,\n    global_data: { waterAuthorityName },\n  } = ReduxState;\n\n  const onNodeClick = (nodeData) => {\n    setSelectedPoint(\n      points_data.items.find((p) => p.id === nodeData.attributes.point_id),\n    );\n    setShowRightPanel(!showRightPanel);\n  };\n\n  // stable endpoints/params ✅\n  const factoriesEndPoint = useMemo(\n    () => urls().dashboard.Utility.factories,\n    [],\n  );\n  const paramsFactory = useMemo(() => ({ type: 'Factory' }), []);\n  const paramsCollectors = useMemo(() => ({ type: 'Collectors' }), []);\n\n  // fetches\n  const [responseFactory, isLoadingFactory, errorFactory] =\n    useApiWithDashboardQuery<FactoriesResponse>(\n      factoriesEndPoint,\n      paramsFactory,\n    );\n\n  const [responseCollectors, isLoadingCollectors, errorCollectors] =\n    useApiWithDashboardQuery<FactoriesResponse>(\n      factoriesEndPoint,\n      paramsCollectors,\n    );\n\n  // 1) Build a pollution map from both responses (no state; pure memo)\n  const pollutionBySiteId = useMemo(() => {\n    const m = new Map<number, any>();\n    if (responseFactory?.data) {\n      for (const { site_id, pollution } of responseFactory.data) {\n        if (pollution?.type_distribution)\n          m.set(site_id, pollution.type_distribution);\n      }\n    }\n    if (responseCollectors?.data) {\n      for (const { site_id, pollution } of responseCollectors.data) {\n        if (pollution?.type_distribution)\n          m.set(site_id, pollution.type_distribution);\n      }\n    }\n    return m;\n  }, [responseFactory?.data, responseCollectors?.data]);\n\n  // 2) Create a SAFE copy of point_map_data with pollution merged in (no mutations)\n  const decoratedPointsById = useMemo(() => {\n    // mapById(points_data.items) returns a plain object keyed by id; clone it\n    const base = mapById(points_data.items);\n    const copy: Record<number, any> = {};\n    for (const id of Object.keys(base)) {\n      const numId = Number(id);\n      const pollution = pollutionBySiteId.get(numId);\n      // shallow clone each point; add pollution if exists\n      copy[numId] = pollution\n        ? { ...base[numId], pollution }\n        : { ...base[numId] };\n    }\n    return copy;\n  }, [points_data.items, pollutionBySiteId]);\n\n  // 3) Compute edgesWithDevice safely/memoized (no extra renders)\n  const edgesWithDevice = useMemo(() => {\n    const pointsWithDevice = mapById(\n      points_data.items.filter((p) => p.has_device),\n    );\n    return edges_data.items.filter(\n      (edge) =>\n        pointsWithDevice[edge.source_point_id] || edge.descendants_has_device,\n    );\n  }, [points_data.items, edges_data.items]);\n\n  // 4) Build the tree ONLY when data is ready; keep referential stability\n  const treeData = useMemo(() => {\n    const loading = isLoadingFactory || isLoadingCollectors;\n    const hasError = errorFactory || errorCollectors;\n    if (loading || hasError) return null;\n\n    return buildTree(edgesWithDevice, decoratedPointsById, waterAuthorityName);\n  }, [\n    isLoadingFactory,\n    isLoadingCollectors,\n    errorFactory,\n    errorCollectors,\n    edgesWithDevice,\n    decoratedPointsById,\n    waterAuthorityName,\n  ]);\n\n  const isLoading = isLoadingFactory || isLoadingCollectors;\n\n  if (!isGraphTab) {\n    return null;\n  }\n\n  const nodeTypeOptions = [\n    { label: 'Pie Chart', value: 'pie' },\n    { label: 'Bar', value: 'bar' },\n  ];\n  return (\n    <div>\n      <div\n        style={{\n          marginTop: '10px',\n          marginInlineStart: '10px',\n          display: 'flex',\n          gap: 8,\n          zIndex: 10,\n        }}\n      >\n        <Button onClick={() => setDepth(1)}>{'Collapse All'}</Button>\n        <Button onClick={() => setDepth(12)}>{'Expand All'}</Button>\n        <Button\n          onClick={() =>\n            setOrientation((prev) =>\n              prev === 'horizontal' ? 'vertical' : 'horizontal',\n            )\n          }\n        >\n          {'Toggle Orientation'}\n        </Button>\n        <Select\n          options={nodeTypeOptions}\n          value={nodeTypeOptions.find((option) => option.value === nodeType)}\n          setValue={(selected) => setNodeType(selected.value)}\n          menuWidth={120}\n        />\n      </div>\n\n      <Container fluid className=\"p-0\" style={{ overflow: 'hidden' }}>\n        <Row className=\"map-column\" sm={12}>\n          <Col style={{ height: '85vh' }}>\n            {edges_data.isFetching ||\n            points_data.isFetching ||\n            !treeData ||\n            isLoading ? (\n              <Loader />\n            ) : (\n              <AutoFitTree\n                initialDepth={depth}\n                data={treeData}\n                nodeType={nodeType}\n                orientation={orientation}\n                onNodeClick={onNodeClick}\n              />\n            )}\n            <RightPanel\n              className={`right-panel ${showRightPanel ? 'open' : ''}`}\n              point={selectedPoint}\n              onClose={() => {\n                setSelectedPoint(null);\n                setShowRightPanel(false);\n              }}\n            />\n          </Col>\n        </Row>\n      </Container>\n    </div>\n  );\n};\nexport default HierarchyGraph;\n"],"mappings":"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"}
|
|
196
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_useQueryURL","_interopRequireDefault","_utils","_reactRedux","_AutoFitTree","_reactBootstrap","_Loader","_Button","_RightPanel","_urls","_useApiWithDashboardQuery","_Select","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","HierarchyGraph","searchQuery","useQueryURL","ReduxState","useSelector","state","_useState","useState","_useState2","_slicedToArray2","depth","setDepth","_useState3","_useState4","nodeType","setNodeType","_useState5","_useState6","selectedPoint","setSelectedPoint","_useState7","_useState8","showRightPanel","setShowRightPanel","isGraphTab","points_data","edges_data","waterAuthorityName","global_data","onNodeClick","nodeData","items","find","p","id","attributes","point_id","factoriesEndPoint","useMemo","urls","dashboard","Utility","factories","paramsAll","type","_useApiWithDashboardQ","useApiWithDashboardQuery","_useApiWithDashboardQ2","responseSites","isLoadingSites","errorSites","pollutionBySiteId","m","Map","data","_iterator","_createForOfIteratorHelper2","_step","s","n","done","_step$value","value","site_id","pollution","type_distribution","err","e","f","decoratedPointsById","base","mapById","copy","_i","_Object$keys","keys","length","numId","Number","_objectSpread2","edgesWithDevice","pointsWithDevice","filter","has_device","edge","source_point_id","descendants_has_device","treeData","buildTree","nodeTypeOptions","label","createElement","style","marginTop","marginInlineStart","display","gap","zIndex","onClick","Select","options","option","setValue","selected","menuWidth","Container","fluid","className","overflow","Row","sm","Col","height","isFetching","Loader","initialDepth","concat","point","onClose","_default","exports"],"sources":["../../../src/ui-kit/HierarchyGraph/HierarchyGraph.tsx"],"sourcesContent":["import React, { useMemo } from 'react';\n\nimport useQueryURL from '../../hooks/useQueryURL';\nimport { buildTree, mapById, NodeType } from './utils';\nimport { useSelector } from 'react-redux';\nimport { useState } from 'react';\nimport AutoFitTree from './AutoFitTree';\nimport { Container, Row, Col } from 'react-bootstrap';\nimport { Loader } from '../../pages/DashboardMap/Loader';\nimport Button from '../Button/Button';\nimport RightPanel from '../../pages/OperationsPage/RightPanel';\nimport { urls } from '../../utilities/urls';\nimport { useApiWithDashboardQuery } from '../../hooks/useApiWithDashboardQuery';\nimport { FactoriesResponse } from '../../Widgets/MostPolluting/Factories/factoriesResponse.interface';\nimport { Select } from '../../components/CustomInputs/Select/Select';\n\nconst HierarchyGraph = () => {\n  const searchQuery = useQueryURL();\n  const ReduxState = useSelector((state) => state);\n  // const [orientation, setOrientation] = useState<'horizontal' | 'vertical'>(\n  //   'vertical',\n  // );\n  const [depth, setDepth] = useState<number>(12);\n  const [nodeType, setNodeType] = useState<NodeType>('pie');\n  const [selectedPoint, setSelectedPoint] = useState(null);\n  const [showRightPanel, setShowRightPanel] = useState(false);\n  const isGraphTab = searchQuery.get('view') === 'graph';\n  const {\n    points_data,\n    edges_data,\n    global_data: { waterAuthorityName },\n  } = ReduxState;\n\n  const onNodeClick = (nodeData) => {\n    setSelectedPoint(\n      points_data.items.find((p) => p.id === nodeData.attributes.point_id),\n    );\n    setShowRightPanel(!showRightPanel);\n  };\n\n  // stable endpoints/params ✅\n  const factoriesEndPoint = useMemo(\n    () => urls().dashboard.Utility.factories,\n    [],\n  );\n\n  const paramsAll = useMemo(() => ({ type: 'All' }), []);\n\n  // fetches\n  const [responseSites, isLoadingSites, errorSites] =\n    useApiWithDashboardQuery<FactoriesResponse>(factoriesEndPoint, paramsAll);\n\n  // 1) Build a pollution map from both responses (no state; pure memo)\n  const pollutionBySiteId = useMemo(() => {\n    const m = new Map<number, any>();\n    if (responseSites?.data) {\n      for (const { site_id, pollution } of responseSites.data) {\n        if (pollution?.type_distribution)\n          m.set(site_id, pollution.type_distribution);\n      }\n    }\n    return m;\n  }, [responseSites?.data]);\n\n  // 2) Create a SAFE copy of point_map_data with pollution merged in (no mutations)\n  const decoratedPointsById = useMemo(() => {\n    // mapById(points_data.items) returns a plain object keyed by id; clone it\n    const base = mapById(points_data.items);\n    const copy: Record<number, any> = {};\n    for (const id of Object.keys(base)) {\n      const numId = Number(id);\n      const pollution = pollutionBySiteId.get(numId);\n      // shallow clone each point; add pollution if exists\n      copy[numId] = pollution\n        ? { ...base[numId], pollution }\n        : { ...base[numId] };\n    }\n    return copy;\n  }, [points_data.items, pollutionBySiteId]);\n\n  // 3) Compute edgesWithDevice safely/memoized (no extra renders)\n  const edgesWithDevice = useMemo(() => {\n    const pointsWithDevice = mapById(\n      points_data.items.filter((p) => p.has_device),\n    );\n    return edges_data.items.filter(\n      (edge) =>\n        pointsWithDevice[edge.source_point_id] || edge.descendants_has_device,\n    );\n  }, [points_data.items, edges_data.items]);\n\n  // 4) Build the tree ONLY when data is ready; keep referential stability\n  const treeData = useMemo(() => {\n    if (isLoadingSites || errorSites) return null;\n\n    return buildTree(edgesWithDevice, decoratedPointsById, waterAuthorityName);\n  }, [\n    edgesWithDevice,\n    decoratedPointsById,\n    waterAuthorityName,\n    isLoadingSites,\n    errorSites,\n  ]);\n\n  if (!isGraphTab) {\n    return null;\n  }\n\n  const nodeTypeOptions = [\n    { label: 'Pie Chart', value: 'pie' },\n    { label: 'Bar', value: 'bar' },\n  ];\n  return (\n    <div>\n      <div\n        style={{\n          marginTop: '10px',\n          marginInlineStart: '10px',\n          display: 'flex',\n          gap: 8,\n          zIndex: 10,\n        }}\n      >\n        <Button onClick={() => setDepth(1)}>{'Collapse All'}</Button>\n        <Button onClick={() => setDepth(12)}>{'Expand All'}</Button>\n        {/*<Button*/}\n        {/*  onClick={() =>*/}\n        {/*    setOrientation((prev) =>*/}\n        {/*      prev === 'horizontal' ? 'vertical' : 'horizontal',*/}\n        {/*    )*/}\n        {/*  }*/}\n        {/*>*/}\n        {/*  {'Toggle Orientation'}*/}\n        {/*</Button>*/}\n        <Select\n          options={nodeTypeOptions}\n          value={nodeTypeOptions.find((option) => option.value === nodeType)}\n          setValue={(selected) => setNodeType(selected.value)}\n          menuWidth={120}\n        />\n      </div>\n\n      <Container fluid className=\"p-0\" style={{ overflow: 'hidden' }}>\n        <Row className=\"map-column\" sm={12}>\n          <Col style={{ height: '85vh' }}>\n            {edges_data.isFetching ||\n            points_data.isFetching ||\n            !treeData ||\n            isLoadingSites ? (\n              <Loader />\n            ) : (\n              <AutoFitTree\n                initialDepth={depth}\n                data={treeData}\n                nodeType={nodeType}\n                onNodeClick={onNodeClick}\n              />\n            )}\n            <RightPanel\n              className={`right-panel ${showRightPanel ? 'open' : ''}`}\n              point={selectedPoint}\n              onClose={() => {\n                setSelectedPoint(null);\n                setShowRightPanel(false);\n              }}\n            />\n          </Col>\n        </Row>\n      </Container>\n    </div>\n  );\n};\nexport default HierarchyGraph;\n"],"mappings":";;;;;;;;;;;AAAA,IAAAA,MAAA,GAAAC,uBAAA,CAAAC,OAAA;AAEA,IAAAC,YAAA,GAAAC,sBAAA,CAAAF,OAAA;AACA,IAAAG,MAAA,GAAAH,OAAA;AACA,IAAAI,WAAA,GAAAJ,OAAA;AAEA,IAAAK,YAAA,GAAAH,sBAAA,CAAAF,OAAA;AACA,IAAAM,eAAA,GAAAN,OAAA;AACA,IAAAO,OAAA,GAAAP,OAAA;AACA,IAAAQ,OAAA,GAAAN,sBAAA,CAAAF,OAAA;AACA,IAAAS,WAAA,GAAAP,sBAAA,CAAAF,OAAA;AACA,IAAAU,KAAA,GAAAV,OAAA;AACA,IAAAW,yBAAA,GAAAX,OAAA;AAEA,IAAAY,OAAA,GAAAZ,OAAA;AAAqE,SAAAa,yBAAAC,WAAA,eAAAC,OAAA,kCAAAC,iBAAA,OAAAD,OAAA,QAAAE,gBAAA,OAAAF,OAAA,YAAAF,wBAAA,YAAAA,yBAAAC,WAAA,WAAAA,WAAA,GAAAG,gBAAA,GAAAD,iBAAA,KAAAF,WAAA;AAAA,SAAAf,wBAAAmB,GAAA,EAAAJ,WAAA,SAAAA,WAAA,IAAAI,GAAA,IAAAA,GAAA,CAAAC,UAAA,WAAAD,GAAA,QAAAA,GAAA,aAAAE,OAAA,CAAAF,GAAA,yBAAAA,GAAA,4BAAAG,OAAA,EAAAH,GAAA,UAAAI,KAAA,GAAAT,wBAAA,CAAAC,WAAA,OAAAQ,KAAA,IAAAA,KAAA,CAAAC,GAAA,CAAAL,GAAA,YAAAI,KAAA,CAAAE,GAAA,CAAAN,GAAA,SAAAO,MAAA,WAAAC,qBAAA,GAAAC,MAAA,CAAAC,cAAA,IAAAD,MAAA,CAAAE,wBAAA,WAAAC,GAAA,IAAAZ,GAAA,QAAAY,GAAA,kBAAAH,MAAA,CAAAI,SAAA,CAAAC,cAAA,CAAAC,IAAA,CAAAf,GAAA,EAAAY,GAAA,SAAAI,IAAA,GAAAR,qBAAA,GAAAC,MAAA,CAAAE,wBAAA,CAAAX,GAAA,EAAAY,GAAA,cAAAI,IAAA,KAAAA,IAAA,CAAAV,GAAA,IAAAU,IAAA,CAAAC,GAAA,KAAAR,MAAA,CAAAC,cAAA,CAAAH,MAAA,EAAAK,GAAA,EAAAI,IAAA,YAAAT,MAAA,CAAAK,GAAA,IAAAZ,GAAA,CAAAY,GAAA,SAAAL,MAAA,CAAAJ,OAAA,GAAAH,GAAA,MAAAI,KAAA,IAAAA,KAAA,CAAAa,GAAA,CAAAjB,GAAA,EAAAO,MAAA,YAAAA,MAAA;AAErE,IAAMW,cAAc,GAAG,SAAjBA,cAAcA,CAAA,EAAS;EAC3B,IAAMC,WAAW,GAAG,IAAAC,oBAAW,EAAC,CAAC;EACjC,IAAMC,UAAU,GAAG,IAAAC,uBAAW,EAAC,UAACC,KAAK;IAAA,OAAKA,KAAK;EAAA,EAAC;EAChD;EACA;EACA;EACA,IAAAC,SAAA,GAA0B,IAAAC,eAAQ,EAAS,EAAE,CAAC;IAAAC,UAAA,OAAAC,eAAA,CAAAxB,OAAA,EAAAqB,SAAA;IAAvCI,KAAK,GAAAF,UAAA;IAAEG,QAAQ,GAAAH,UAAA;EACtB,IAAAI,UAAA,GAAgC,IAAAL,eAAQ,EAAW,KAAK,CAAC;IAAAM,UAAA,OAAAJ,eAAA,CAAAxB,OAAA,EAAA2B,UAAA;IAAlDE,QAAQ,GAAAD,UAAA;IAAEE,WAAW,GAAAF,UAAA;EAC5B,IAAAG,UAAA,GAA0C,IAAAT,eAAQ,EAAC,IAAI,CAAC;IAAAU,UAAA,OAAAR,eAAA,CAAAxB,OAAA,EAAA+B,UAAA;IAAjDE,aAAa,GAAAD,UAAA;IAAEE,gBAAgB,GAAAF,UAAA;EACtC,IAAAG,UAAA,GAA4C,IAAAb,eAAQ,EAAC,KAAK,CAAC;IAAAc,UAAA,OAAAZ,eAAA,CAAAxB,OAAA,EAAAmC,UAAA;IAApDE,cAAc,GAAAD,UAAA;IAAEE,iBAAiB,GAAAF,UAAA;EACxC,IAAMG,UAAU,GAAGvB,WAAW,CAACb,GAAG,CAAC,MAAM,CAAC,KAAK,OAAO;EACtD,IACEqC,WAAW,GAGTtB,UAAU,CAHZsB,WAAW;IACXC,UAAU,GAERvB,UAAU,CAFZuB,UAAU;IACKC,kBAAkB,GAC/BxB,UAAU,CADZyB,WAAW,CAAID,kBAAkB;EAGnC,IAAME,WAAW,GAAG,SAAdA,WAAWA,CAAIC,QAAQ,EAAK;IAChCX,gBAAgB,CACdM,WAAW,CAACM,KAAK,CAACC,IAAI,CAAC,UAACC,CAAC;MAAA,OAAKA,CAAC,CAACC,EAAE,KAAKJ,QAAQ,CAACK,UAAU,CAACC,QAAQ;IAAA,EACrE,CAAC;IACDb,iBAAiB,CAAC,CAACD,cAAc,CAAC;EACpC,CAAC;;EAED;EACA,IAAMe,iBAAiB,GAAG,IAAAC,cAAO,EAC/B;IAAA,OAAM,IAAAC,UAAI,EAAC,CAAC,CAACC,SAAS,CAACC,OAAO,CAACC,SAAS;EAAA,GACxC,EACF,CAAC;EAED,IAAMC,SAAS,GAAG,IAAAL,cAAO,EAAC;IAAA,OAAO;MAAEM,IAAI,EAAE;IAAM,CAAC;EAAA,CAAC,EAAE,EAAE,CAAC;;EAEtD;EACA,IAAAC,qBAAA,GACE,IAAAC,kDAAwB,EAAoBT,iBAAiB,EAAEM,SAAS,CAAC;IAAAI,sBAAA,OAAAtC,eAAA,CAAAxB,OAAA,EAAA4D,qBAAA;IADpEG,aAAa,GAAAD,sBAAA;IAAEE,cAAc,GAAAF,sBAAA;IAAEG,UAAU,GAAAH,sBAAA;;EAGhD;EACA,IAAMI,iBAAiB,GAAG,IAAAb,cAAO,EAAC,YAAM;IACtC,IAAMc,CAAC,GAAG,IAAIC,GAAG,CAAc,CAAC;IAChC,IAAIL,aAAa,aAAbA,aAAa,uBAAbA,aAAa,CAAEM,IAAI,EAAE;MAAA,IAAAC,SAAA,OAAAC,2BAAA,CAAAvE,OAAA,EACc+D,aAAa,CAACM,IAAI;QAAAG,KAAA;MAAA;QAAvD,KAAAF,SAAA,CAAAG,CAAA,MAAAD,KAAA,GAAAF,SAAA,CAAAI,CAAA,IAAAC,IAAA,GAAyD;UAAA,IAAAC,WAAA,GAAAJ,KAAA,CAAAK,KAAA;YAA5CC,OAAO,GAAAF,WAAA,CAAPE,OAAO;YAAEC,SAAS,GAAAH,WAAA,CAATG,SAAS;UAC7B,IAAIA,SAAS,aAATA,SAAS,uBAATA,SAAS,CAAEC,iBAAiB,EAC9Bb,CAAC,CAACrD,GAAG,CAACgE,OAAO,EAAEC,SAAS,CAACC,iBAAiB,CAAC;QAC/C;MAAC,SAAAC,GAAA;QAAAX,SAAA,CAAAY,CAAA,CAAAD,GAAA;MAAA;QAAAX,SAAA,CAAAa,CAAA;MAAA;IACH;IACA,OAAOhB,CAAC;EACV,CAAC,EAAE,CAACJ,aAAa,aAAbA,aAAa,uBAAbA,aAAa,CAAEM,IAAI,CAAC,CAAC;;EAEzB;EACA,IAAMe,mBAAmB,GAAG,IAAA/B,cAAO,EAAC,YAAM;IACxC;IACA,IAAMgC,IAAI,GAAG,IAAAC,cAAO,EAAC9C,WAAW,CAACM,KAAK,CAAC;IACvC,IAAMyC,IAAyB,GAAG,CAAC,CAAC;IACpC,SAAAC,EAAA,MAAAC,YAAA,GAAiBnF,MAAM,CAACoF,IAAI,CAACL,IAAI,CAAC,EAAAG,EAAA,GAAAC,YAAA,CAAAE,MAAA,EAAAH,EAAA,IAAE;MAA/B,IAAMvC,EAAE,GAAAwC,YAAA,CAAAD,EAAA;MACX,IAAMI,KAAK,GAAGC,MAAM,CAAC5C,EAAE,CAAC;MACxB,IAAM8B,SAAS,GAAGb,iBAAiB,CAAC/D,GAAG,CAACyF,KAAK,CAAC;MAC9C;MACAL,IAAI,CAACK,KAAK,CAAC,GAAGb,SAAS,OAAAe,cAAA,CAAA9F,OAAA,MAAA8F,cAAA,CAAA9F,OAAA,MACdqF,IAAI,CAACO,KAAK,CAAC;QAAEb,SAAS,EAATA;MAAS,SAAAe,cAAA,CAAA9F,OAAA,MACtBqF,IAAI,CAACO,KAAK,CAAC,CAAE;IACxB;IACA,OAAOL,IAAI;EACb,CAAC,EAAE,CAAC/C,WAAW,CAACM,KAAK,EAAEoB,iBAAiB,CAAC,CAAC;;EAE1C;EACA,IAAM6B,eAAe,GAAG,IAAA1C,cAAO,EAAC,YAAM;IACpC,IAAM2C,gBAAgB,GAAG,IAAAV,cAAO,EAC9B9C,WAAW,CAACM,KAAK,CAACmD,MAAM,CAAC,UAACjD,CAAC;MAAA,OAAKA,CAAC,CAACkD,UAAU;IAAA,EAC9C,CAAC;IACD,OAAOzD,UAAU,CAACK,KAAK,CAACmD,MAAM,CAC5B,UAACE,IAAI;MAAA,OACHH,gBAAgB,CAACG,IAAI,CAACC,eAAe,CAAC,IAAID,IAAI,CAACE,sBAAsB;IAAA,CACzE,CAAC;EACH,CAAC,EAAE,CAAC7D,WAAW,CAACM,KAAK,EAAEL,UAAU,CAACK,KAAK,CAAC,CAAC;;EAEzC;EACA,IAAMwD,QAAQ,GAAG,IAAAjD,cAAO,EAAC,YAAM;IAC7B,IAAIW,cAAc,IAAIC,UAAU,EAAE,OAAO,IAAI;IAE7C,OAAO,IAAAsC,gBAAS,EAACR,eAAe,EAAEX,mBAAmB,EAAE1C,kBAAkB,CAAC;EAC5E,CAAC,EAAE,CACDqD,eAAe,EACfX,mBAAmB,EACnB1C,kBAAkB,EAClBsB,cAAc,EACdC,UAAU,CACX,CAAC;EAEF,IAAI,CAAC1B,UAAU,EAAE;IACf,OAAO,IAAI;EACb;EAEA,IAAMiE,eAAe,GAAG,CACtB;IAAEC,KAAK,EAAE,WAAW;IAAE5B,KAAK,EAAE;EAAM,CAAC,EACpC;IAAE4B,KAAK,EAAE,KAAK;IAAE5B,KAAK,EAAE;EAAM,CAAC,CAC/B;EACD,oBACEpG,MAAA,CAAAuB,OAAA,CAAA0G,aAAA,2BACEjI,MAAA,CAAAuB,OAAA,CAAA0G,aAAA;IACEC,KAAK,EAAE;MACLC,SAAS,EAAE,MAAM;MACjBC,iBAAiB,EAAE,MAAM;MACzBC,OAAO,EAAE,MAAM;MACfC,GAAG,EAAE,CAAC;MACNC,MAAM,EAAE;IACV;EAAE,gBAEFvI,MAAA,CAAAuB,OAAA,CAAA0G,aAAA,CAACvH,OAAA,CAAAa,OAAM;IAACiH,OAAO,EAAE,SAAAA,QAAA;MAAA,OAAMvF,QAAQ,CAAC,CAAC,CAAC;IAAA;EAAC,GAAE,cAAuB,CAAC,eAC7DjD,MAAA,CAAAuB,OAAA,CAAA0G,aAAA,CAACvH,OAAA,CAAAa,OAAM;IAACiH,OAAO,EAAE,SAAAA,QAAA;MAAA,OAAMvF,QAAQ,CAAC,EAAE,CAAC;IAAA;EAAC,GAAE,YAAqB,CAAC,eAU5DjD,MAAA,CAAAuB,OAAA,CAAA0G,aAAA,CAACnH,OAAA,CAAA2H,MAAM;IACLC,OAAO,EAAEX,eAAgB;IACzB3B,KAAK,EAAE2B,eAAe,CAACzD,IAAI,CAAC,UAACqE,MAAM;MAAA,OAAKA,MAAM,CAACvC,KAAK,KAAKhD,QAAQ;IAAA,EAAE;IACnEwF,QAAQ,EAAE,SAAAA,SAACC,QAAQ;MAAA,OAAKxF,WAAW,CAACwF,QAAQ,CAACzC,KAAK,CAAC;IAAA,CAAC;IACpD0C,SAAS,EAAE;EAAI,CAChB,CACE,CAAC,eAEN9I,MAAA,CAAAuB,OAAA,CAAA0G,aAAA,CAACzH,eAAA,CAAAuI,SAAS;IAACC,KAAK;IAACC,SAAS,EAAC,KAAK;IAACf,KAAK,EAAE;MAAEgB,QAAQ,EAAE;IAAS;EAAE,gBAC7DlJ,MAAA,CAAAuB,OAAA,CAAA0G,aAAA,CAACzH,eAAA,CAAA2I,GAAG;IAACF,SAAS,EAAC,YAAY;IAACG,EAAE,EAAE;EAAG,gBACjCpJ,MAAA,CAAAuB,OAAA,CAAA0G,aAAA,CAACzH,eAAA,CAAA6I,GAAG;IAACnB,KAAK,EAAE;MAAEoB,MAAM,EAAE;IAAO;EAAE,GAC5BtF,UAAU,CAACuF,UAAU,IACtBxF,WAAW,CAACwF,UAAU,IACtB,CAAC1B,QAAQ,IACTtC,cAAc,gBACZvF,MAAA,CAAAuB,OAAA,CAAA0G,aAAA,CAACxH,OAAA,CAAA+I,MAAM,MAAE,CAAC,gBAEVxJ,MAAA,CAAAuB,OAAA,CAAA0G,aAAA,CAAC1H,YAAA,CAAAgB,OAAW;IACVkI,YAAY,EAAEzG,KAAM;IACpB4C,IAAI,EAAEiC,QAAS;IACfzE,QAAQ,EAAEA,QAAS;IACnBe,WAAW,EAAEA;EAAY,CAC1B,CACF,eACDnE,MAAA,CAAAuB,OAAA,CAAA0G,aAAA,CAACtH,WAAA,CAAAY,OAAU;IACT0H,SAAS,iBAAAS,MAAA,CAAiB9F,cAAc,GAAG,MAAM,GAAG,EAAE,CAAG;IACzD+F,KAAK,EAAEnG,aAAc;IACrBoG,OAAO,EAAE,SAAAA,QAAA,EAAM;MACbnG,gBAAgB,CAAC,IAAI,CAAC;MACtBI,iBAAiB,CAAC,KAAK,CAAC;IAC1B;EAAE,CACH,CACE,CACF,CACI,CACR,CAAC;AAEV,CAAC;AAAC,IAAAgG,QAAA,GACavH,cAAc;AAAAwH,OAAA,CAAAvI,OAAA,GAAAsI,QAAA"}
|
|
@@ -6,23 +6,55 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
6
6
|
});
|
|
7
7
|
exports.default = void 0;
|
|
8
8
|
var _react = _interopRequireDefault(require("react"));
|
|
9
|
-
var
|
|
9
|
+
var _PointUtils = require("../../Widgets/Map/points/PointUtils");
|
|
10
|
+
var _StyledLink = require("components/Links/StyledLink/StyledLink");
|
|
11
|
+
var _TopNavbar = require("../../assets/icons/TopNavbar");
|
|
12
|
+
var LeafSign = function LeafSign(_ref) {
|
|
13
|
+
var siteType = _ref.siteType,
|
|
14
|
+
point_id = _ref.point_id,
|
|
15
|
+
_ref$color = _ref.color,
|
|
16
|
+
color = _ref$color === void 0 ? '#444' : _ref$color;
|
|
17
|
+
var isFactory = (0, _PointUtils.isFactoryType)(siteType);
|
|
10
18
|
return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("line", {
|
|
11
19
|
x1: "0",
|
|
12
|
-
y1: "
|
|
20
|
+
y1: "83",
|
|
13
21
|
x2: "0",
|
|
14
22
|
y2: "105",
|
|
15
|
-
stroke:
|
|
23
|
+
stroke: color,
|
|
16
24
|
strokeWidth: "4"
|
|
17
|
-
}), /*#__PURE__*/_react.default.createElement("line", {
|
|
25
|
+
}), isFactory ? /*#__PURE__*/_react.default.createElement("line", {
|
|
18
26
|
x1: "-40",
|
|
19
27
|
y1: "105",
|
|
20
28
|
x2: "40",
|
|
21
29
|
y2: "105",
|
|
22
|
-
stroke:
|
|
30
|
+
stroke: color,
|
|
23
31
|
strokeWidth: "4"
|
|
24
|
-
})
|
|
32
|
+
}) : /*#__PURE__*/_react.default.createElement(_StyledLink.StyledLink, {
|
|
33
|
+
target: "_blank",
|
|
34
|
+
updateParams: {
|
|
35
|
+
view: 'map'
|
|
36
|
+
},
|
|
37
|
+
to: "/dashboard_v2/site/".concat(point_id),
|
|
38
|
+
onClick: function onClick(e) {
|
|
39
|
+
return e.stopPropagation();
|
|
40
|
+
}
|
|
41
|
+
}, /*#__PURE__*/_react.default.createElement("g", {
|
|
42
|
+
transform: 'translate(0, 100)'
|
|
43
|
+
}, /*#__PURE__*/_react.default.createElement("circle", {
|
|
44
|
+
cx: "0",
|
|
45
|
+
cy: 16,
|
|
46
|
+
r: 18,
|
|
47
|
+
fill: "white",
|
|
48
|
+
stroke: color,
|
|
49
|
+
strokeWidth: "1",
|
|
50
|
+
vectorEffect: "non-scaling-stroke"
|
|
51
|
+
}), /*#__PURE__*/_react.default.createElement("g", {
|
|
52
|
+
transform: 'translate(-17, -1)',
|
|
53
|
+
style: {
|
|
54
|
+
stroke: 'none'
|
|
55
|
+
}
|
|
56
|
+
}, /*#__PURE__*/_react.default.createElement(_TopNavbar.MapSvg, null)))));
|
|
25
57
|
};
|
|
26
58
|
var _default = LeafSign;
|
|
27
59
|
exports.default = _default;
|
|
28
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
60
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIl9Qb2ludFV0aWxzIiwiX1N0eWxlZExpbmsiLCJfVG9wTmF2YmFyIiwiTGVhZlNpZ24iLCJfcmVmIiwic2l0ZVR5cGUiLCJwb2ludF9pZCIsIl9yZWYkY29sb3IiLCJjb2xvciIsImlzRmFjdG9yeSIsImlzRmFjdG9yeVR5cGUiLCJkZWZhdWx0IiwiY3JlYXRlRWxlbWVudCIsIkZyYWdtZW50IiwieDEiLCJ5MSIsIngyIiwieTIiLCJzdHJva2UiLCJzdHJva2VXaWR0aCIsIlN0eWxlZExpbmsiLCJ0YXJnZXQiLCJ1cGRhdGVQYXJhbXMiLCJ2aWV3IiwidG8iLCJjb25jYXQiLCJvbkNsaWNrIiwiZSIsInN0b3BQcm9wYWdhdGlvbiIsInRyYW5zZm9ybSIsImN4IiwiY3kiLCJyIiwiZmlsbCIsInZlY3RvckVmZmVjdCIsInN0eWxlIiwiTWFwU3ZnIiwiX2RlZmF1bHQiLCJleHBvcnRzIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3VpLWtpdC9IaWVyYXJjaHlHcmFwaC9MZWFmU2lnbi50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCB7IGlzRmFjdG9yeVR5cGUgfSBmcm9tICcuLi8uLi9XaWRnZXRzL01hcC9wb2ludHMvUG9pbnRVdGlscyc7XG5pbXBvcnQgeyBTdHlsZWRMaW5rIH0gZnJvbSAnc3JjL2NvbXBvbmVudHMvTGlua3MvU3R5bGVkTGluay9TdHlsZWRMaW5rJztcbmltcG9ydCB7IE1hcFN2ZyB9IGZyb20gJy4uLy4uL2Fzc2V0cy9pY29ucy9Ub3BOYXZiYXInO1xuXG5jb25zdCBMZWFmU2lnbiA9ICh7IHNpdGVUeXBlLCBwb2ludF9pZCwgY29sb3IgPSAnIzQ0NCcgfSkgPT4ge1xuICBjb25zdCBpc0ZhY3RvcnkgPSBpc0ZhY3RvcnlUeXBlKHNpdGVUeXBlKTtcbiAgcmV0dXJuIChcbiAgICA8PlxuICAgICAgPGxpbmUgeDE9XCIwXCIgeTE9XCI4M1wiIHgyPVwiMFwiIHkyPVwiMTA1XCIgc3Ryb2tlPXtjb2xvcn0gc3Ryb2tlV2lkdGg9XCI0XCIgLz5cbiAgICAgIHtpc0ZhY3RvcnkgPyAoXG4gICAgICAgIDxsaW5lXG4gICAgICAgICAgeDE9XCItNDBcIlxuICAgICAgICAgIHkxPVwiMTA1XCJcbiAgICAgICAgICB4Mj1cIjQwXCJcbiAgICAgICAgICB5Mj1cIjEwNVwiXG4gICAgICAgICAgc3Ryb2tlPXtjb2xvcn1cbiAgICAgICAgICBzdHJva2VXaWR0aD1cIjRcIlxuICAgICAgICAvPlxuICAgICAgKSA6IChcbiAgICAgICAgPFN0eWxlZExpbmtcbiAgICAgICAgICB0YXJnZXQ9XCJfYmxhbmtcIlxuICAgICAgICAgIHVwZGF0ZVBhcmFtcz17eyB2aWV3OiAnbWFwJyB9fVxuICAgICAgICAgIHRvPXtgL2Rhc2hib2FyZF92Mi9zaXRlLyR7cG9pbnRfaWR9YH1cbiAgICAgICAgICBvbkNsaWNrPXsoZSkgPT4gZS5zdG9wUHJvcGFnYXRpb24oKX1cbiAgICAgICAgPlxuICAgICAgICAgIDxnIHRyYW5zZm9ybT17J3RyYW5zbGF0ZSgwLCAxMDApJ30+XG4gICAgICAgICAgICA8Y2lyY2xlXG4gICAgICAgICAgICAgIGN4PVwiMFwiXG4gICAgICAgICAgICAgIGN5PXsxNn1cbiAgICAgICAgICAgICAgcj17MTh9XG4gICAgICAgICAgICAgIGZpbGw9XCJ3aGl0ZVwiXG4gICAgICAgICAgICAgIHN0cm9rZT17Y29sb3J9XG4gICAgICAgICAgICAgIHN0cm9rZVdpZHRoPVwiMVwiXG4gICAgICAgICAgICAgIHZlY3RvckVmZmVjdD1cIm5vbi1zY2FsaW5nLXN0cm9rZVwiXG4gICAgICAgICAgICAvPlxuXG4gICAgICAgICAgICA8ZyB0cmFuc2Zvcm09eyd0cmFuc2xhdGUoLTE3LCAtMSknfSBzdHlsZT17eyBzdHJva2U6ICdub25lJyB9fT5cbiAgICAgICAgICAgICAgPE1hcFN2ZyAvPlxuICAgICAgICAgICAgPC9nPlxuICAgICAgICAgIDwvZz5cbiAgICAgICAgPC9TdHlsZWRMaW5rPlxuICAgICAgKX1cbiAgICA8Lz5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IExlYWZTaWduO1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQUEsSUFBQUEsTUFBQSxHQUFBQyxzQkFBQSxDQUFBQyxPQUFBO0FBQ0EsSUFBQUMsV0FBQSxHQUFBRCxPQUFBO0FBQ0EsSUFBQUUsV0FBQSxHQUFBRixPQUFBO0FBQ0EsSUFBQUcsVUFBQSxHQUFBSCxPQUFBO0FBRUEsSUFBTUksUUFBUSxHQUFHLFNBQVhBLFFBQVFBLENBQUFDLElBQUEsRUFBK0M7RUFBQSxJQUF6Q0MsUUFBUSxHQUFBRCxJQUFBLENBQVJDLFFBQVE7SUFBRUMsUUFBUSxHQUFBRixJQUFBLENBQVJFLFFBQVE7SUFBQUMsVUFBQSxHQUFBSCxJQUFBLENBQUVJLEtBQUs7SUFBTEEsS0FBSyxHQUFBRCxVQUFBLGNBQUcsTUFBTSxHQUFBQSxVQUFBO0VBQ3BELElBQU1FLFNBQVMsR0FBRyxJQUFBQyx5QkFBYSxFQUFDTCxRQUFRLENBQUM7RUFDekMsb0JBQ0VSLE1BQUEsQ0FBQWMsT0FBQSxDQUFBQyxhQUFBLENBQUFmLE1BQUEsQ0FBQWMsT0FBQSxDQUFBRSxRQUFBLHFCQUNFaEIsTUFBQSxDQUFBYyxPQUFBLENBQUFDLGFBQUE7SUFBTUUsRUFBRSxFQUFDLEdBQUc7SUFBQ0MsRUFBRSxFQUFDLElBQUk7SUFBQ0MsRUFBRSxFQUFDLEdBQUc7SUFBQ0MsRUFBRSxFQUFDLEtBQUs7SUFBQ0MsTUFBTSxFQUFFVixLQUFNO0lBQUNXLFdBQVcsRUFBQztFQUFHLENBQUUsQ0FBQyxFQUNyRVYsU0FBUyxnQkFDUlosTUFBQSxDQUFBYyxPQUFBLENBQUFDLGFBQUE7SUFDRUUsRUFBRSxFQUFDLEtBQUs7SUFDUkMsRUFBRSxFQUFDLEtBQUs7SUFDUkMsRUFBRSxFQUFDLElBQUk7SUFDUEMsRUFBRSxFQUFDLEtBQUs7SUFDUkMsTUFBTSxFQUFFVixLQUFNO0lBQ2RXLFdBQVcsRUFBQztFQUFHLENBQ2hCLENBQUMsZ0JBRUZ0QixNQUFBLENBQUFjLE9BQUEsQ0FBQUMsYUFBQSxDQUFDWCxXQUFBLENBQUFtQixVQUFVO0lBQ1RDLE1BQU0sRUFBQyxRQUFRO0lBQ2ZDLFlBQVksRUFBRTtNQUFFQyxJQUFJLEVBQUU7SUFBTSxDQUFFO0lBQzlCQyxFQUFFLHdCQUFBQyxNQUFBLENBQXdCbkIsUUFBUSxDQUFHO0lBQ3JDb0IsT0FBTyxFQUFFLFNBQUFBLFFBQUNDLENBQUM7TUFBQSxPQUFLQSxDQUFDLENBQUNDLGVBQWUsQ0FBQyxDQUFDO0lBQUE7RUFBQyxnQkFFcEMvQixNQUFBLENBQUFjLE9BQUEsQ0FBQUMsYUFBQTtJQUFHaUIsU0FBUyxFQUFFO0VBQW9CLGdCQUNoQ2hDLE1BQUEsQ0FBQWMsT0FBQSxDQUFBQyxhQUFBO0lBQ0VrQixFQUFFLEVBQUMsR0FBRztJQUNOQyxFQUFFLEVBQUUsRUFBRztJQUNQQyxDQUFDLEVBQUUsRUFBRztJQUNOQyxJQUFJLEVBQUMsT0FBTztJQUNaZixNQUFNLEVBQUVWLEtBQU07SUFDZFcsV0FBVyxFQUFDLEdBQUc7SUFDZmUsWUFBWSxFQUFDO0VBQW9CLENBQ2xDLENBQUMsZUFFRnJDLE1BQUEsQ0FBQWMsT0FBQSxDQUFBQyxhQUFBO0lBQUdpQixTQUFTLEVBQUUsb0JBQXFCO0lBQUNNLEtBQUssRUFBRTtNQUFFakIsTUFBTSxFQUFFO0lBQU87RUFBRSxnQkFDNURyQixNQUFBLENBQUFjLE9BQUEsQ0FBQUMsYUFBQSxDQUFDVixVQUFBLENBQUFrQyxNQUFNLE1BQUUsQ0FDUixDQUNGLENBQ08sQ0FFZCxDQUFDO0FBRVAsQ0FBQztBQUFDLElBQUFDLFFBQUEsR0FFYWxDLFFBQVE7QUFBQW1DLE9BQUEsQ0FBQTNCLE9BQUEsR0FBQTBCLFFBQUEifQ==
|
|
@@ -18,22 +18,22 @@ var MicroStackedBarNode = function MicroStackedBarNode(_ref) {
|
|
|
18
18
|
var score = ((_nodeDatum$attributes2 = nodeDatum.attributes) === null || _nodeDatum$attributes2 === void 0 ? void 0 : _nodeDatum$attributes2.score) || -1;
|
|
19
19
|
var segments = [{
|
|
20
20
|
value: pollution.extreme || 0,
|
|
21
|
-
color: '#
|
|
21
|
+
color: '#f6004f',
|
|
22
22
|
title: 'Extreme'
|
|
23
23
|
}, {
|
|
24
24
|
value: pollution.high || 0,
|
|
25
|
-
color: '#
|
|
25
|
+
color: '#f67129',
|
|
26
26
|
title: 'High'
|
|
27
27
|
}, {
|
|
28
28
|
value: pollution.medium || 0,
|
|
29
|
-
color: '#
|
|
29
|
+
color: '#f6b22f',
|
|
30
30
|
title: 'Medium'
|
|
31
31
|
}, {
|
|
32
32
|
value: pollution.clear || 0,
|
|
33
33
|
color: '#23aa24',
|
|
34
34
|
title: 'Clear'
|
|
35
35
|
}];
|
|
36
|
-
if (score
|
|
36
|
+
if (score < 0) {
|
|
37
37
|
segments.push({
|
|
38
38
|
value: 100,
|
|
39
39
|
color: '#B9BABD',
|
|
@@ -56,4 +56,4 @@ var MicroStackedBarNode = function MicroStackedBarNode(_ref) {
|
|
|
56
56
|
};
|
|
57
57
|
var _default = MicroStackedBarNode;
|
|
58
58
|
exports.default = _default;
|
|
59
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIl9Ob2RlTGF5b3V0IiwiX01pY3JvU3RhY2tlZEJhciIsIl9leGNsdWRlZCIsIk1pY3JvU3RhY2tlZEJhck5vZGUiLCJfcmVmIiwiX25vZGVEYXR1bSRhdHRyaWJ1dGVzIiwiX25vZGVEYXR1bSRhdHRyaWJ1dGVzMiIsIm5vZGVEYXR1bSIsInByb3BzIiwiX29iamVjdFdpdGhvdXRQcm9wZXJ0aWVzMiIsImRlZmF1bHQiLCJwb2xsdXRpb24iLCJhdHRyaWJ1dGVzIiwic2NvcmUiLCJzZWdtZW50cyIsInZhbHVlIiwiZXh0cmVtZSIsImNvbG9yIiwidGl0bGUiLCJoaWdoIiwibWVkaXVtIiwiY2xlYXIiLCJwdXNoIiwiY3JlYXRlRWxlbWVudCIsIk9iamVjdCIsImFzc2lnbiIsImNvbnRlbnRTdHlsZSIsInBhZGRpbmdUb3AiLCJwYWRkaW5nSW5saW5lU3RhcnQiLCJ3aWR0aCIsImhlaWdodCIsInJhZGl1cyIsIl9kZWZhdWx0IiwiZXhwb3J0cyJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy91aS1raXQvSGllcmFyY2h5R3JhcGgvTWljcm9TdGFja2VkQmFyTm9kZS50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCBOb2RlTGF5b3V0IGZyb20gJy4vTm9kZUxheW91dCc7XG5pbXBvcnQgeyBOb2RlUHJvcHMgfSBmcm9tICcuL3V0aWxzJztcbmltcG9ydCBNaWNyb1N0YWNrZWRCYXIgZnJvbSAnLi9NaWNyb1N0YWNrZWRCYXInO1xuXG5jb25zdCBNaWNyb1N0YWNrZWRCYXJOb2RlID0gKHsgbm9kZURhdHVtLCAuLi5wcm9wcyB9OiBOb2RlUHJvcHMpID0+IHtcbiAgY29uc3QgcG9sbHV0aW9uID0gbm9kZURhdHVtLmF0dHJpYnV0ZXM/
|
|
59
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIl9Ob2RlTGF5b3V0IiwiX01pY3JvU3RhY2tlZEJhciIsIl9leGNsdWRlZCIsIk1pY3JvU3RhY2tlZEJhck5vZGUiLCJfcmVmIiwiX25vZGVEYXR1bSRhdHRyaWJ1dGVzIiwiX25vZGVEYXR1bSRhdHRyaWJ1dGVzMiIsIm5vZGVEYXR1bSIsInByb3BzIiwiX29iamVjdFdpdGhvdXRQcm9wZXJ0aWVzMiIsImRlZmF1bHQiLCJwb2xsdXRpb24iLCJhdHRyaWJ1dGVzIiwic2NvcmUiLCJzZWdtZW50cyIsInZhbHVlIiwiZXh0cmVtZSIsImNvbG9yIiwidGl0bGUiLCJoaWdoIiwibWVkaXVtIiwiY2xlYXIiLCJwdXNoIiwiY3JlYXRlRWxlbWVudCIsIk9iamVjdCIsImFzc2lnbiIsImNvbnRlbnRTdHlsZSIsInBhZGRpbmdUb3AiLCJwYWRkaW5nSW5saW5lU3RhcnQiLCJ3aWR0aCIsImhlaWdodCIsInJhZGl1cyIsIl9kZWZhdWx0IiwiZXhwb3J0cyJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy91aS1raXQvSGllcmFyY2h5R3JhcGgvTWljcm9TdGFja2VkQmFyTm9kZS50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCBOb2RlTGF5b3V0IGZyb20gJy4vTm9kZUxheW91dCc7XG5pbXBvcnQgeyBOb2RlUHJvcHMgfSBmcm9tICcuL3V0aWxzJztcbmltcG9ydCBNaWNyb1N0YWNrZWRCYXIgZnJvbSAnLi9NaWNyb1N0YWNrZWRCYXInO1xuXG5jb25zdCBNaWNyb1N0YWNrZWRCYXJOb2RlID0gKHsgbm9kZURhdHVtLCAuLi5wcm9wcyB9OiBOb2RlUHJvcHMpID0+IHtcbiAgY29uc3QgcG9sbHV0aW9uID0gbm9kZURhdHVtLmF0dHJpYnV0ZXM/LnBvbGx1dGlvbiB8fCB7fTtcbiAgY29uc3Qgc2NvcmUgPSBub2RlRGF0dW0uYXR0cmlidXRlcz8uc2NvcmUgfHwgLTE7XG4gIGNvbnN0IHNlZ21lbnRzID0gW1xuICAgIHsgdmFsdWU6IHBvbGx1dGlvbi5leHRyZW1lIHx8IDAsIGNvbG9yOiAnI2Y2MDA0ZicsIHRpdGxlOiAnRXh0cmVtZScgfSxcbiAgICB7IHZhbHVlOiBwb2xsdXRpb24uaGlnaCB8fCAwLCBjb2xvcjogJyNmNjcxMjknLCB0aXRsZTogJ0hpZ2gnIH0sXG4gICAgeyB2YWx1ZTogcG9sbHV0aW9uLm1lZGl1bSB8fCAwLCBjb2xvcjogJyNmNmIyMmYnLCB0aXRsZTogJ01lZGl1bScgfSxcbiAgICB7IHZhbHVlOiBwb2xsdXRpb24uY2xlYXIgfHwgMCwgY29sb3I6ICcjMjNhYTI0JywgdGl0bGU6ICdDbGVhcicgfSxcbiAgXTtcbiAgaWYgKHNjb3JlIDwgMCkge1xuICAgIHNlZ21lbnRzLnB1c2goeyB2YWx1ZTogMTAwLCBjb2xvcjogJyNCOUJBQkQnLCB0aXRsZTogJ1VuZGVmaW5lZCcgfSk7XG4gIH1cbiAgcmV0dXJuIChcbiAgICA8Tm9kZUxheW91dFxuICAgICAgbm9kZURhdHVtPXtub2RlRGF0dW19XG4gICAgICB7Li4ucHJvcHN9XG4gICAgICBjb250ZW50U3R5bGU9e3sgcGFkZGluZ1RvcDogJzUwcHgnLCBwYWRkaW5nSW5saW5lU3RhcnQ6ICcxNXB4JyB9fVxuICAgID5cbiAgICAgIDxNaWNyb1N0YWNrZWRCYXIgc2VnbWVudHM9e3NlZ21lbnRzfSB3aWR0aD17MTYwfSBoZWlnaHQ9ezIwfSByYWRpdXM9ezh9IC8+XG4gICAgPC9Ob2RlTGF5b3V0PlxuICApO1xufTtcbmV4cG9ydCBkZWZhdWx0IE1pY3JvU3RhY2tlZEJhck5vZGU7XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7O0FBQUEsSUFBQUEsTUFBQSxHQUFBQyxzQkFBQSxDQUFBQyxPQUFBO0FBQ0EsSUFBQUMsV0FBQSxHQUFBRixzQkFBQSxDQUFBQyxPQUFBO0FBRUEsSUFBQUUsZ0JBQUEsR0FBQUgsc0JBQUEsQ0FBQUMsT0FBQTtBQUFnRCxJQUFBRyxTQUFBO0FBRWhELElBQU1DLG1CQUFtQixHQUFHLFNBQXRCQSxtQkFBbUJBLENBQUFDLElBQUEsRUFBMkM7RUFBQSxJQUFBQyxxQkFBQSxFQUFBQyxzQkFBQTtFQUFBLElBQXJDQyxTQUFTLEdBQUFILElBQUEsQ0FBVEcsU0FBUztJQUFLQyxLQUFLLE9BQUFDLHlCQUFBLENBQUFDLE9BQUEsRUFBQU4sSUFBQSxFQUFBRixTQUFBO0VBQ2hELElBQU1TLFNBQVMsR0FBRyxFQUFBTixxQkFBQSxHQUFBRSxTQUFTLENBQUNLLFVBQVUsY0FBQVAscUJBQUEsdUJBQXBCQSxxQkFBQSxDQUFzQk0sU0FBUyxLQUFJLENBQUMsQ0FBQztFQUN2RCxJQUFNRSxLQUFLLEdBQUcsRUFBQVAsc0JBQUEsR0FBQUMsU0FBUyxDQUFDSyxVQUFVLGNBQUFOLHNCQUFBLHVCQUFwQkEsc0JBQUEsQ0FBc0JPLEtBQUssS0FBSSxDQUFDLENBQUM7RUFDL0MsSUFBTUMsUUFBUSxHQUFHLENBQ2Y7SUFBRUMsS0FBSyxFQUFFSixTQUFTLENBQUNLLE9BQU8sSUFBSSxDQUFDO0lBQUVDLEtBQUssRUFBRSxTQUFTO0lBQUVDLEtBQUssRUFBRTtFQUFVLENBQUMsRUFDckU7SUFBRUgsS0FBSyxFQUFFSixTQUFTLENBQUNRLElBQUksSUFBSSxDQUFDO0lBQUVGLEtBQUssRUFBRSxTQUFTO0lBQUVDLEtBQUssRUFBRTtFQUFPLENBQUMsRUFDL0Q7SUFBRUgsS0FBSyxFQUFFSixTQUFTLENBQUNTLE1BQU0sSUFBSSxDQUFDO0lBQUVILEtBQUssRUFBRSxTQUFTO0lBQUVDLEtBQUssRUFBRTtFQUFTLENBQUMsRUFDbkU7SUFBRUgsS0FBSyxFQUFFSixTQUFTLENBQUNVLEtBQUssSUFBSSxDQUFDO0lBQUVKLEtBQUssRUFBRSxTQUFTO0lBQUVDLEtBQUssRUFBRTtFQUFRLENBQUMsQ0FDbEU7RUFDRCxJQUFJTCxLQUFLLEdBQUcsQ0FBQyxFQUFFO0lBQ2JDLFFBQVEsQ0FBQ1EsSUFBSSxDQUFDO01BQUVQLEtBQUssRUFBRSxHQUFHO01BQUVFLEtBQUssRUFBRSxTQUFTO01BQUVDLEtBQUssRUFBRTtJQUFZLENBQUMsQ0FBQztFQUNyRTtFQUNBLG9CQUNFckIsTUFBQSxDQUFBYSxPQUFBLENBQUFhLGFBQUEsQ0FBQ3ZCLFdBQUEsQ0FBQVUsT0FBVSxFQUFBYyxNQUFBLENBQUFDLE1BQUE7SUFDVGxCLFNBQVMsRUFBRUE7RUFBVSxHQUNqQkMsS0FBSztJQUNUa0IsWUFBWSxFQUFFO01BQUVDLFVBQVUsRUFBRSxNQUFNO01BQUVDLGtCQUFrQixFQUFFO0lBQU87RUFBRSxpQkFFakUvQixNQUFBLENBQUFhLE9BQUEsQ0FBQWEsYUFBQSxDQUFDdEIsZ0JBQUEsQ0FBQVMsT0FBZTtJQUFDSSxRQUFRLEVBQUVBLFFBQVM7SUFBQ2UsS0FBSyxFQUFFLEdBQUk7SUFBQ0MsTUFBTSxFQUFFLEVBQUc7SUFBQ0MsTUFBTSxFQUFFO0VBQUUsQ0FBRSxDQUMvRCxDQUFDO0FBRWpCLENBQUM7QUFBQyxJQUFBQyxRQUFBLEdBQ2E3QixtQkFBbUI7QUFBQThCLE9BQUEsQ0FBQXZCLE9BQUEsR0FBQXNCLFFBQUEifQ==
|
|
@@ -55,28 +55,26 @@ var NodeLayout = function NodeLayout(_ref) {
|
|
|
55
55
|
x: "-100",
|
|
56
56
|
y: "-120",
|
|
57
57
|
width: "200",
|
|
58
|
-
height: "
|
|
58
|
+
height: "250"
|
|
59
59
|
}, /*#__PURE__*/_react.default.createElement(_utils.ActionsContainer, null, /*#__PURE__*/_react.default.createElement("span", {
|
|
60
60
|
style: {
|
|
61
61
|
marginInlineEnd: '8px'
|
|
62
62
|
}
|
|
63
63
|
}, /*#__PURE__*/_react.default.createElement(_zoomIn.ReactComponent, {
|
|
64
|
-
onClick: onShowDetails
|
|
65
|
-
width: 35,
|
|
66
|
-
height: 35
|
|
64
|
+
onClick: onShowDetails
|
|
67
65
|
})), /*#__PURE__*/_react.default.createElement(_StyledLink.StyledLink, {
|
|
68
66
|
style: {
|
|
69
67
|
marginStart: '8px'
|
|
70
68
|
},
|
|
71
69
|
target: "_blank",
|
|
70
|
+
updateParams: {
|
|
71
|
+
view: 'dashboard'
|
|
72
|
+
},
|
|
72
73
|
to: "/dashboard_v2/site/".concat((_nodeDatum$attributes5 = nodeDatum.attributes) === null || _nodeDatum$attributes5 === void 0 ? void 0 : _nodeDatum$attributes5.point_id),
|
|
73
74
|
onClick: function onClick(e) {
|
|
74
75
|
return e.stopPropagation();
|
|
75
76
|
}
|
|
76
|
-
}, /*#__PURE__*/_react.default.createElement(_TopNavbar.DashboardSvg, {
|
|
77
|
-
width: 35,
|
|
78
|
-
height: 35
|
|
79
|
-
}))), /*#__PURE__*/_react.default.createElement(_CardLayout.default, {
|
|
77
|
+
}, /*#__PURE__*/_react.default.createElement(_TopNavbar.DashboardSvg, null))), /*#__PURE__*/_react.default.createElement(_CardLayout.default, {
|
|
80
78
|
title: title,
|
|
81
79
|
style: cardStyle,
|
|
82
80
|
headerRight: /*#__PURE__*/_react.default.createElement(_NodeIcon.default, {
|
|
@@ -85,8 +83,12 @@ var NodeLayout = function NodeLayout(_ref) {
|
|
|
85
83
|
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
86
84
|
className: 'node-content',
|
|
87
85
|
style: contentStyle
|
|
88
|
-
}, children))), isLeafNode && /*#__PURE__*/_react.default.createElement(_LeafSign.default,
|
|
86
|
+
}, children))), isLeafNode && /*#__PURE__*/_react.default.createElement(_LeafSign.default, {
|
|
87
|
+
siteType: factoryType,
|
|
88
|
+
point_id: nodeDatum.attributes.point_id,
|
|
89
|
+
color: borderColor
|
|
90
|
+
}));
|
|
89
91
|
};
|
|
90
92
|
var _default = NodeLayout;
|
|
91
93
|
exports.default = _default;
|
|
92
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
94
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_zoomIn","_scoreToData","_CardLayout","_NodeIcon","_TopNavbar","_StyledLink","_utils","_LeafSign","NodeLayout","_ref","_nodeDatum$attributes","_nodeDatum$attributes2","_nodeDatum$attributes3","_nodeDatum$attributes4","_nodeDatum$attributes5","nodeDatum","toggleNode","onNodeClick","siteID","children","contentStyle","score","attributes","borderColor","scoreToColor","factoryType","type","isLeafNode","length","isMonitored","monitored","cardStyle","borderRadius","borderStyle","borderWidth","backgroundColor","stroke","height","title","area_name","name","onShowDetails","event","stopPropagation","default","createElement","onClick","style","cursor","x","y","width","ActionsContainer","marginInlineEnd","ReactComponent","StyledLink","marginStart","target","updateParams","view","to","concat","point_id","e","DashboardSvg","headerRight","className","siteType","color","_default","exports"],"sources":["../../../src/ui-kit/HierarchyGraph/NodeLayout.tsx"],"sourcesContent":["import React from 'react';\nimport { ReactComponent as DetailsSvg } from 'src/assets/icons/zoom-in.svg';\nimport { scoreToColor } from '../../utilities/scoreToData';\nimport CardLayout from '../../Widgets/MostPolluting/Factories/FactoryBox/CardLayout';\nimport NodeIcon from './NodeIcon';\nimport { DashboardSvg } from '../../assets/icons/TopNavbar';\nimport { StyledLink } from 'src/components/Links/StyledLink/StyledLink';\nimport { ActionsContainer, NodeProps } from './utils';\nimport LeafSign from './LeafSign';\n\nconst NodeLayout = ({\n  nodeDatum,\n  toggleNode,\n  onNodeClick,\n  siteID,\n  children,\n  contentStyle,\n}: NodeProps) => {\n  const score = nodeDatum.attributes?.score || -1;\n  const borderColor = scoreToColor(score);\n  const factoryType = nodeDatum.attributes?.type || '';\n  const isLeafNode = !nodeDatum.children || nodeDatum.children.length === 0;\n  const isMonitored = nodeDatum.attributes?.monitored;\n  // const isFocused = siteID === nodeDatum.attributes?.point_id?.toString();\n\n  const cardStyle: React.CSSProperties = {\n    borderRadius: '4px',\n    borderColor,\n    borderStyle: isMonitored ? 'solid' : 'dashed',\n    borderWidth: '5px',\n    backgroundColor: '#FFFFFF',\n    stroke: 'none',\n    height: '170px',\n  };\n  const title =\n    factoryType === 'area'\n      ? nodeDatum.attributes?.area_name || nodeDatum.name\n      : nodeDatum.name;\n  const onShowDetails = (event) => {\n    event.stopPropagation();\n    onNodeClick(nodeDatum);\n  };\n\n  if (!nodeDatum.name) {\n    return null;\n  }\n  return (\n    <g onClick={toggleNode} style={{ cursor: 'pointer' }}>\n      <foreignObject x=\"-100\" y=\"-120\" width=\"200\" height=\"250\">\n        <ActionsContainer>\n          <span style={{ marginInlineEnd: '8px' }}>\n            <DetailsSvg onClick={onShowDetails} />\n          </span>\n          <StyledLink\n            style={{ marginStart: '8px' }}\n            target=\"_blank\"\n            updateParams={{ view: 'dashboard' }}\n            to={`/dashboard_v2/site/${nodeDatum.attributes?.point_id}`}\n            onClick={(e) => e.stopPropagation()}\n          >\n            <DashboardSvg />\n          </StyledLink>\n        </ActionsContainer>\n        <CardLayout\n          title={title}\n          style={cardStyle}\n          headerRight={<NodeIcon type={factoryType} />}\n        >\n          <div className={'node-content'} style={contentStyle}>\n            {children}\n          </div>\n        </CardLayout>\n      </foreignObject>\n      {isLeafNode && (\n        <LeafSign\n          siteType={factoryType}\n          point_id={nodeDatum.attributes.point_id}\n          color={borderColor}\n        />\n      )}\n    </g>\n  );\n};\nexport default NodeLayout;\n"],"mappings":"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"}
|
|
@@ -98,4 +98,4 @@ var ActionsContainer = _styledComponents.default.div.withConfig({
|
|
|
98
98
|
componentId: "sc-21qmj9-0"
|
|
99
99
|
})(["{text-align:center;}"]);
|
|
100
100
|
exports.ActionsContainer = ActionsContainer;
|
|
101
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJidWlsZFRyZWUiLCJjb25uZWN0aW9ucyIsInBvaW50X2RhdGEiLCJ1dGlsaXR5X25hbWUiLCJub2RlcyIsImNoaWxkcmVuIiwiU2V0IiwiX2l0ZXJhdG9yIiwiX2NyZWF0ZUZvck9mSXRlcmF0b3JIZWxwZXIyIiwiZGVmYXVsdCIsIl9zdGVwIiwicyIsIm4iLCJkb25lIiwiX3N0ZXAkdmFsdWUiLCJ2YWx1ZSIsInNvdXJjZV9wb2ludF9pZCIsInRhcmdldF9wb2ludF9pZCIsImRpc3RhbmNlIiwiX3JlZiIsIm5hbWUiLCJzb3VyY2VEYXRhIiwiX29iamVjdFdpdGhvdXRQcm9wZXJ0aWVzMiIsIl9leGNsdWRlZCIsInRhcmdldF9kYXRhIiwiYXR0cmlidXRlcyIsIl9vYmplY3RTcHJlYWQyIiwicG9pbnRfaWQiLCJwdXNoIiwiYWRkIiwiZXJyIiwiZSIsImYiLCJyb290cyIsIk9iamVjdCIsImtleXMiLCJmaWx0ZXIiLCJpZCIsImhhcyIsIk51bWJlciIsIm1hcCIsImxlbmd0aCIsIm1hcEJ5SWQiLCJpdGVtcyIsInJlZHVjZSIsImFjYyIsIl9yZWYyIiwiaGFzX2RldmljZSIsImdyb3VwIiwiYXJlYV9uYW1lIiwicHJvcHMiLCJfZXhjbHVkZWQyIiwibW9uaXRvcmVkIiwidHlwZSIsIkFjdGlvbnNDb250YWluZXIiLCJzdHlsZWQiLCJkaXYiLCJ3aXRoQ29uZmlnIiwiZGlzcGxheU5hbWUiLCJjb21wb25lbnRJZCIsImV4cG9ydHMiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvdWkta2l0L0hpZXJhcmNoeUdyYXBoL3V0aWxzLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IElQb2ludCB9IGZyb20gJy4uLy4uL3N0b3JlL3BvaW50cy9tb2RlbHMvSVBvaW50JztcbmltcG9ydCBzdHlsZWQgZnJvbSAnc3R5bGVkLWNvbXBvbmVudHMvbWFjcm8nO1xuaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcblxuLyoqXG4gKiBDb252ZXJ0IGVkZ2VzIHRvIHJvd3Mgc3VpdGFibGUgZm9yIGQzLnN0cmF0aWZ5KClcbiAqIFJldHVybnMgYW4gYXJyYXkgb2YgeyBpZCwgcGFyZW50SWQsIGRpc3RhbmNlPywgc2hhcGVfZGF0YT8gfVxuICogSWYgbXVsdGlwbGUgcm9vdHMgZXhpc3QsIHlvdSBjYW4gb3B0aW9uYWxseSBhZGQgYSBzdXBlciByb290IHJvdy5cbiAqL1xudHlwZSBFZGdlID0ge1xuICBzb3VyY2VfcG9pbnRfaWQ6IG51bWJlciB8IHN0cmluZztcbiAgdGFyZ2V0X3BvaW50X2lkOiBudW1iZXIgfCBzdHJpbmc7XG4gIGRpc3RhbmNlPzogbnVtYmVyO1xufTtcbnR5cGUgVHJlZU5vZGUgPSB7XG4gIG5hbWU6IHN0cmluZztcbiAgY2hpbGRyZW4/OiBUcmVlTm9kZVtdO1xuICBhdHRyaWJ1dGVzPzogeyBkaXN0YW5jZTogbnVtYmVyOyB0eXBlOiBzdHJpbmc7IG1vbml0b3JlZDogYm9vbGVhbiB9O1xufTtcbnR5cGUgVHJlZURhdGEgPSBUcmVlTm9kZSB8IHsgbmFtZTogc3RyaW5nOyBjaGlsZHJlbjogVHJlZU5vZGVbXSB9O1xuXG5leHBvcnQgZnVuY3Rpb24gYnVpbGRUcmVlKFxuICBjb25uZWN0aW9uczogRWRnZVtdLFxuICBwb2ludF9kYXRhLFxuICB1dGlsaXR5X25hbWUsXG4pOiBUcmVlRGF0YSB7XG4gIGNvbnN0IG5vZGVzID0ge307XG4gIGNvbnN0IGNoaWxkcmVuID0gbmV3IFNldCgpO1xuXG4gIC8vIEJ1aWxkIG1hcCBvZiBub2RlcyBhbmQgdHJhY2sgY2hpbGRyZW5cbiAgZm9yIChjb25zdCB7IHNvdXJjZV9wb2ludF9pZCwgdGFyZ2V0X3BvaW50X2lkLCBkaXN0YW5jZSB9IG9mIGNvbm5lY3Rpb25zKSB7XG4gICAgY29uc3QgeyBuYW1lLCAuLi5zb3VyY2VEYXRhIH0gPSBwb2ludF9kYXRhW3NvdXJjZV9wb2ludF9pZF0gfHwge307XG4gICAgaWYgKCFub2Rlc1tzb3VyY2VfcG9pbnRfaWRdKVxuICAgICAgbm9kZXNbc291cmNlX3BvaW50X2lkXSA9IHtcbiAgICAgICAgbmFtZSxcbiAgICAgICAgY2hpbGRyZW46IFtdLFxuICAgICAgfTtcbiAgICBpZiAoIW5vZGVzW3RhcmdldF9wb2ludF9pZF0pIHtcbiAgICAgIGNvbnN0IHRhcmdldF9kYXRhID0gcG9pbnRfZGF0YVt0YXJnZXRfcG9pbnRfaWRdIHx8IHt9O1xuICAgICAgbm9kZXNbdGFyZ2V0X3BvaW50X2lkXSA9IHtcbiAgICAgICAgbmFtZTogdGFyZ2V0X2RhdGEubmFtZSxcbiAgICAgICAgYXR0cmlidXRlczoge1xuICAgICAgICAgIC4uLnRhcmdldF9kYXRhLFxuICAgICAgICAgIHBvaW50X2lkOiB0YXJnZXRfcG9pbnRfaWQsXG4gICAgICAgIH0sXG4gICAgICAgIGNoaWxkcmVuOiBbXSxcbiAgICAgIH07XG4gICAgfVxuICAgIG5vZGVzW3RhcmdldF9wb2ludF9pZF0uY2hpbGRyZW4ucHVzaChub2Rlc1tzb3VyY2VfcG9pbnRfaWRdKTtcbiAgICBjaGlsZHJlbi5hZGQoc291cmNlX3BvaW50X2lkKTtcbiAgICBub2Rlc1tzb3VyY2VfcG9pbnRfaWRdLmF0dHJpYnV0ZXMgPSB7XG4gICAgICBkaXN0YW5jZSxcbiAgICAgIC4uLnNvdXJjZURhdGEsXG4gICAgICBwb2ludF9pZDogc291cmNlX3BvaW50X2lkLFxuICAgIH07XG4gIH1cblxuICAvLyBGaW5kIHJvb3QocylcbiAgY29uc3Qgcm9vdHMgPSBPYmplY3Qua2V5cyhub2RlcylcbiAgICAuZmlsdGVyKChpZCkgPT4gIWNoaWxkcmVuLmhhcyhOdW1iZXIoaWQpKSlcbiAgICAubWFwKChpZCkgPT4gbm9kZXNbaWRdKTtcblxuICAvLyBJZiBtdWx0aXBsZSByb290cyBleGlzdCwgd3JhcCBpbiBhIHN1cGVyIHJvb3RcbiAgcmV0dXJuIHJvb3RzLmxlbmd0aCA9PT0gMVxuICAgID8gcm9vdHNbMF1cbiAgICA6IHsgbmFtZTogdXRpbGl0eV9uYW1lLCBjaGlsZHJlbjogcm9vdHMgfTtcbn1cbnR5cGUgUG9pbnREYXRhID0ge1xuICBuYW1lOiBzdHJpbmc7XG4gIG1vbml0b3JlZDogYm9vbGVhbjtcbiAgdHlwZTogc3RyaW5nO1xuICBhcmVhX25hbWU/OiBzdHJpbmc7XG4gIHNjb3JlPzogbnVtYmVyO1xuICBwb2xsdXRpb24/OiBhbnk7XG59O1xuZXhwb3J0IGZ1bmN0aW9uIG1hcEJ5SWQoaXRlbXM6IElQb2ludFtdKTogUmVjb3JkPHN0cmluZyB8IG51bWJlciwgUG9pbnREYXRhPiB7XG4gIHJldHVybiBpdGVtcy5yZWR1Y2UoXG4gICAgKGFjYywgeyBpZCwgbmFtZSwgaGFzX2RldmljZSwgZ3JvdXAsIGFyZWFfbmFtZSwgLi4ucHJvcHMgfSkgPT4ge1xuICAgICAgYWNjW2lkXSA9IHtcbiAgICAgICAgLi4ucHJvcHMsXG4gICAgICAgIG5hbWUsXG4gICAgICAgIG1vbml0b3JlZDogaGFzX2RldmljZSxcbiAgICAgICAgdHlwZTogYXJlYV9uYW1lID8gJ2FyZWEnIDogZ3JvdXAudHlwZSxcbiAgICAgICAgYXJlYV9uYW1lLFxuICAgICAgfTtcbiAgICAgIHJldHVybiBhY2M7XG4gICAgfSxcbiAgICB7fSBhcyBSZWNvcmQ8c3RyaW5nIHwgbnVtYmVyLCBQb2ludERhdGE+LFxuICApO1xufVxuXG5leHBvcnQgdHlwZSBOb2RlUHJvcHMgPSB7XG4gIG5vZGVEYXR1bToge1xuICAgIG5hbWU6IHN0cmluZztcbiAgICBhdHRyaWJ1dGVzPzoge1xuICAgICAgc2NvcmU/OiBudW1iZXI7XG4gICAgICB0eXBlPzogc3RyaW5nO1xuICAgICAgcG9pbnRfaWQ/OiBudW1iZXIgfCBzdHJpbmc7XG4gICAgICBhcmVhX25hbWU/OiBzdHJpbmc7XG4gICAgICBtb25pdG9yZWQ/OiBib29sZWFuO1xuICAgICAgcG9sbHV0aW9uPzogYW55O1xuICAgIH07XG4gICAgY2hpbGRyZW4/OiBhbnlbXTtcbiAgfTtcbiAgY2hpbGRyZW4/OiBSZWFjdC5SZWFjdE5vZGU7XG4gIHNpdGVJRD86IHN0cmluZyB8IG51bWJlcjtcbiAgdG9nZ2xlTm9kZTogKCkgPT4gdm9pZDtcbiAgb25Ob2RlQ2xpY2s6IChub2RlRGF0YTogYW55KSA9PiB2b2lkO1xuICBjb250ZW50U3R5bGU/
|
|
101
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["buildTree","connections","point_data","utility_name","nodes","children","Set","_iterator","_createForOfIteratorHelper2","default","_step","s","n","done","_step$value","value","source_point_id","target_point_id","distance","_ref","name","sourceData","_objectWithoutProperties2","_excluded","target_data","attributes","_objectSpread2","point_id","push","add","err","e","f","roots","Object","keys","filter","id","has","Number","map","length","mapById","items","reduce","acc","_ref2","has_device","group","area_name","props","_excluded2","monitored","type","ActionsContainer","styled","div","withConfig","displayName","componentId","exports"],"sources":["../../../src/ui-kit/HierarchyGraph/utils.ts"],"sourcesContent":["import { IPoint } from '../../store/points/models/IPoint';\nimport styled from 'styled-components/macro';\nimport React from 'react';\n\n/**\n * Convert edges to rows suitable for d3.stratify()\n * Returns an array of { id, parentId, distance?, shape_data? }\n * If multiple roots exist, you can optionally add a super root row.\n */\ntype Edge = {\n  source_point_id: number | string;\n  target_point_id: number | string;\n  distance?: number;\n};\ntype TreeNode = {\n  name: string;\n  children?: TreeNode[];\n  attributes?: { distance: number; type: string; monitored: boolean };\n};\ntype TreeData = TreeNode | { name: string; children: TreeNode[] };\n\nexport function buildTree(\n  connections: Edge[],\n  point_data,\n  utility_name,\n): TreeData {\n  const nodes = {};\n  const children = new Set();\n\n  // Build map of nodes and track children\n  for (const { source_point_id, target_point_id, distance } of connections) {\n    const { name, ...sourceData } = point_data[source_point_id] || {};\n    if (!nodes[source_point_id])\n      nodes[source_point_id] = {\n        name,\n        children: [],\n      };\n    if (!nodes[target_point_id]) {\n      const target_data = point_data[target_point_id] || {};\n      nodes[target_point_id] = {\n        name: target_data.name,\n        attributes: {\n          ...target_data,\n          point_id: target_point_id,\n        },\n        children: [],\n      };\n    }\n    nodes[target_point_id].children.push(nodes[source_point_id]);\n    children.add(source_point_id);\n    nodes[source_point_id].attributes = {\n      distance,\n      ...sourceData,\n      point_id: source_point_id,\n    };\n  }\n\n  // Find root(s)\n  const roots = Object.keys(nodes)\n    .filter((id) => !children.has(Number(id)))\n    .map((id) => nodes[id]);\n\n  // If multiple roots exist, wrap in a super root\n  return roots.length === 1\n    ? roots[0]\n    : { name: utility_name, children: roots };\n}\ntype PointData = {\n  name: string;\n  monitored: boolean;\n  type: string;\n  area_name?: string;\n  score?: number;\n  pollution?: any;\n};\nexport function mapById(items: IPoint[]): Record<string | number, PointData> {\n  return items.reduce(\n    (acc, { id, name, has_device, group, area_name, ...props }) => {\n      acc[id] = {\n        ...props,\n        name,\n        monitored: has_device,\n        type: area_name ? 'area' : group.type,\n        area_name,\n      };\n      return acc;\n    },\n    {} as Record<string | number, PointData>,\n  );\n}\n\nexport type NodeProps = {\n  nodeDatum: {\n    name: string;\n    attributes?: {\n      score?: number;\n      type?: string;\n      point_id?: number | string;\n      area_name?: string;\n      monitored?: boolean;\n      pollution?: any;\n    };\n    children?: any[];\n  };\n  children?: React.ReactNode;\n  siteID?: string | number;\n  toggleNode: () => void;\n  onNodeClick: (nodeData: any) => void;\n  contentStyle?: React.CSSProperties;\n};\nexport type NodeType = 'pie' | 'bar' | 'mixed' | 'multi_bar';\nexport const ActionsContainer = styled.div`\n   {\n    text-align: center;\n  }\n`;\n"],"mappings":"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"}
|
|
@@ -34,11 +34,12 @@ var Truncate = function Truncate(props) {
|
|
|
34
34
|
return;
|
|
35
35
|
};
|
|
36
36
|
(0, _react.useEffect)(function () {
|
|
37
|
-
if (textRef.current
|
|
37
|
+
if (textRef.current && textRef.current.innerText !== '') {
|
|
38
38
|
truncate();
|
|
39
39
|
setText(textRef.current.innerText);
|
|
40
40
|
}
|
|
41
|
-
|
|
41
|
+
// Run once after mount or when children change
|
|
42
|
+
}, [props.children]);
|
|
42
43
|
return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("p", {
|
|
43
44
|
ref: textRef,
|
|
44
45
|
style: {
|
|
@@ -65,4 +66,4 @@ var TruncatedText = _styledComponents.default.div.withConfig({
|
|
|
65
66
|
})([".truncated-text{padding:2px;border-radius:3px;text-align:", ";text-overflow:ellipsis;margin:0;font-size:1em;overflow:hidden !important;unicode-bidi:plaintext;font-weight:600;span{white-space:nowrap;text-overflow:ellipsis;}}"], function (p) {
|
|
66
67
|
return p.inheritTextAlign ? 'inherit' : 'center';
|
|
67
68
|
});
|
|
68
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVXaWxkY2FyZCIsInJlcXVpcmUiLCJfcmVhY3RCb290c3RyYXAiLCJfcmVhY3RSZWR1eCIsIl9nZXRSZXF1aXJlV2lsZGNhcmRDYWNoZSIsIm5vZGVJbnRlcm9wIiwiV2Vha01hcCIsImNhY2hlQmFiZWxJbnRlcm9wIiwiY2FjaGVOb2RlSW50ZXJvcCIsIm9iaiIsIl9fZXNNb2R1bGUiLCJfdHlwZW9mIiwiZGVmYXVsdCIsImNhY2hlIiwiaGFzIiwiZ2V0IiwibmV3T2JqIiwiaGFzUHJvcGVydHlEZXNjcmlwdG9yIiwiT2JqZWN0IiwiZGVmaW5lUHJvcGVydHkiLCJnZXRPd25Qcm9wZXJ0eURlc2NyaXB0b3IiLCJrZXkiLCJwcm90b3R5cGUiLCJoYXNPd25Qcm9wZXJ0eSIsImNhbGwiLCJkZXNjIiwic2V0IiwiVHJ1bmNhdGUiLCJwcm9wcyIsImNoaWxkcmVuIiwiaW5oZXJpdFRleHRBbGlnbiIsInRleHRSZWYiLCJ1c2VSZWYiLCJfdXNlU3RhdGUiLCJ1c2VTdGF0ZSIsIl91c2VTdGF0ZTIiLCJfc2xpY2VkVG9BcnJheTIiLCJ0ZXh0Iiwic2V0VGV4dCIsIl91c2VTdGF0ZTMiLCJfdXNlU3RhdGU0IiwidHJ1bmNhdGVkIiwic2V0VHJ1bmNhdGVkIiwidHJ1bmNhdGUiLCJjdXJyZW50IiwiaW5uZXJUZXh0IiwidXNlRWZmZWN0IiwiY3JlYXRlRWxlbWVudCIsIkZyYWdtZW50IiwicmVmIiwic3R5bGUiLCJkaXNwbGF5IiwiT3ZlcmxheVRyaWdnZXIiLCJwbGFjZW1lbnQiLCJvdmVybGF5IiwiVG9vbHRpcCIsImlkIiwiVHJ1bmNhdGVkVGV4dCIsImNsYXNzTmFtZSIsImNvbm5lY3RvciIsImNvbm5lY3QiLCJfZGVmYXVsdCIsImV4cG9ydHMiLCJzdHlsZWQiLCJkaXYiLCJ3aXRoQ29uZmlnIiwiZGlzcGxheU5hbWUiLCJjb21wb25lbnRJZCIsInAiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvdXRpbGl0aWVzL1RydW5jYXRlLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlRWZmZWN0LCB1c2VSZWYsIHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgT3ZlcmxheVRyaWdnZXIsIFRvb2x0aXAgfSBmcm9tICdyZWFjdC1ib290c3RyYXAnO1xuaW1wb3J0IHsgY29ubmVjdCwgQ29ubmVjdGVkUHJvcHMgfSBmcm9tICdyZWFjdC1yZWR1eCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ3N0eWxlZC1jb21wb25lbnRzL21hY3JvJztcblxudHlwZSBQcm9wcyA9IENvbm5lY3RlZFByb3BzPHR5cGVvZiBjb25uZWN0b3I+ICYge1xuICBjaGFyYWN0ZXJzOiBudW1iZXI7XG4gIGNoaWxkcmVuOiBhbnk7XG4gIGluaGVyaXRUZXh0QWxpZ246IGJvb2xlYW47XG59O1xuXG5jb25zdCBUcnVuY2F0ZTogUmVhY3QuRkM8UHJvcHM+ID0gKHByb3BzKSA9PiB7XG4gIGNvbnN0IGNoaWxkcmVuID0gKCkgPT4ge1xuICAgIHJldHVybiBwcm9wcy5jaGlsZHJlbjtcbiAgfTtcbiAgY29uc3QgeyBpbmhlcml0VGV4dEFsaWduIH0gPSBwcm9wcztcbiAgY29uc3QgdGV4dFJlZiA9IHVzZVJlZjxIVE1MRGl2RWxlbWVudD4obnVsbCk7XG4gIGNvbnN0IFt0ZXh0LCBzZXRUZXh0XSA9IHVzZVN0YXRlPHN0cmluZz4oJycpO1xuICBjb25zdCBbdHJ1bmNhdGVkLCBzZXRUcnVuY2F0ZWRdID0gdXNlU3RhdGU8YW55PigpO1xuICBjb25zdCB0cnVuY2F0ZSA9ICgpID0+
|
|
69
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVXaWxkY2FyZCIsInJlcXVpcmUiLCJfcmVhY3RCb290c3RyYXAiLCJfcmVhY3RSZWR1eCIsIl9nZXRSZXF1aXJlV2lsZGNhcmRDYWNoZSIsIm5vZGVJbnRlcm9wIiwiV2Vha01hcCIsImNhY2hlQmFiZWxJbnRlcm9wIiwiY2FjaGVOb2RlSW50ZXJvcCIsIm9iaiIsIl9fZXNNb2R1bGUiLCJfdHlwZW9mIiwiZGVmYXVsdCIsImNhY2hlIiwiaGFzIiwiZ2V0IiwibmV3T2JqIiwiaGFzUHJvcGVydHlEZXNjcmlwdG9yIiwiT2JqZWN0IiwiZGVmaW5lUHJvcGVydHkiLCJnZXRPd25Qcm9wZXJ0eURlc2NyaXB0b3IiLCJrZXkiLCJwcm90b3R5cGUiLCJoYXNPd25Qcm9wZXJ0eSIsImNhbGwiLCJkZXNjIiwic2V0IiwiVHJ1bmNhdGUiLCJwcm9wcyIsImNoaWxkcmVuIiwiaW5oZXJpdFRleHRBbGlnbiIsInRleHRSZWYiLCJ1c2VSZWYiLCJfdXNlU3RhdGUiLCJ1c2VTdGF0ZSIsIl91c2VTdGF0ZTIiLCJfc2xpY2VkVG9BcnJheTIiLCJ0ZXh0Iiwic2V0VGV4dCIsIl91c2VTdGF0ZTMiLCJfdXNlU3RhdGU0IiwidHJ1bmNhdGVkIiwic2V0VHJ1bmNhdGVkIiwidHJ1bmNhdGUiLCJjdXJyZW50IiwiaW5uZXJUZXh0IiwidXNlRWZmZWN0IiwiY3JlYXRlRWxlbWVudCIsIkZyYWdtZW50IiwicmVmIiwic3R5bGUiLCJkaXNwbGF5IiwiT3ZlcmxheVRyaWdnZXIiLCJwbGFjZW1lbnQiLCJvdmVybGF5IiwiVG9vbHRpcCIsImlkIiwiVHJ1bmNhdGVkVGV4dCIsImNsYXNzTmFtZSIsImNvbm5lY3RvciIsImNvbm5lY3QiLCJfZGVmYXVsdCIsImV4cG9ydHMiLCJzdHlsZWQiLCJkaXYiLCJ3aXRoQ29uZmlnIiwiZGlzcGxheU5hbWUiLCJjb21wb25lbnRJZCIsInAiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvdXRpbGl0aWVzL1RydW5jYXRlLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlRWZmZWN0LCB1c2VSZWYsIHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgT3ZlcmxheVRyaWdnZXIsIFRvb2x0aXAgfSBmcm9tICdyZWFjdC1ib290c3RyYXAnO1xuaW1wb3J0IHsgY29ubmVjdCwgQ29ubmVjdGVkUHJvcHMgfSBmcm9tICdyZWFjdC1yZWR1eCc7XG5pbXBvcnQgc3R5bGVkIGZyb20gJ3N0eWxlZC1jb21wb25lbnRzL21hY3JvJztcblxudHlwZSBQcm9wcyA9IENvbm5lY3RlZFByb3BzPHR5cGVvZiBjb25uZWN0b3I+ICYge1xuICBjaGFyYWN0ZXJzOiBudW1iZXI7XG4gIGNoaWxkcmVuOiBhbnk7XG4gIGluaGVyaXRUZXh0QWxpZ246IGJvb2xlYW47XG59O1xuXG5jb25zdCBUcnVuY2F0ZTogUmVhY3QuRkM8UHJvcHM+ID0gKHByb3BzKSA9PiB7XG4gIGNvbnN0IGNoaWxkcmVuID0gKCkgPT4ge1xuICAgIHJldHVybiBwcm9wcy5jaGlsZHJlbjtcbiAgfTtcbiAgY29uc3QgeyBpbmhlcml0VGV4dEFsaWduIH0gPSBwcm9wcztcbiAgY29uc3QgdGV4dFJlZiA9IHVzZVJlZjxIVE1MRGl2RWxlbWVudD4obnVsbCk7XG4gIGNvbnN0IFt0ZXh0LCBzZXRUZXh0XSA9IHVzZVN0YXRlPHN0cmluZz4oJycpO1xuICBjb25zdCBbdHJ1bmNhdGVkLCBzZXRUcnVuY2F0ZWRdID0gdXNlU3RhdGU8YW55PigpO1xuICBjb25zdCB0cnVuY2F0ZSA9ICgpID0+IHtcbiAgICBpZiAodGV4dFJlZi5jdXJyZW50ICE9PSBudWxsICYmIHRleHRSZWYuY3VycmVudC5pbm5lclRleHQgIT09ICcnKSB7XG4gICAgICByZXR1cm4gc2V0VHJ1bmNhdGVkKHRleHRSZWYuY3VycmVudC5pbm5lclRleHQpO1xuICAgIH1cblxuICAgIHJldHVybjtcbiAgfTtcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmICh0ZXh0UmVmLmN1cnJlbnQgJiYgdGV4dFJlZi5jdXJyZW50LmlubmVyVGV4dCAhPT0gJycpIHtcbiAgICAgIHRydW5jYXRlKCk7XG4gICAgICBzZXRUZXh0KHRleHRSZWYuY3VycmVudC5pbm5lclRleHQpO1xuICAgIH1cbiAgICAvLyBSdW4gb25jZSBhZnRlciBtb3VudCBvciB3aGVuIGNoaWxkcmVuIGNoYW5nZVxuICB9LCBbcHJvcHMuY2hpbGRyZW5dKTtcblxuICByZXR1cm4gKFxuICAgIDxSZWFjdC5GcmFnbWVudD5cbiAgICAgIDxwIHJlZj17dGV4dFJlZn0gc3R5bGU9e3sgZGlzcGxheTogJ25vbmUnIH19PlxuICAgICAgICB7Y2hpbGRyZW4oKX1cbiAgICAgIDwvcD5cblxuICAgICAgPE92ZXJsYXlUcmlnZ2VyXG4gICAgICAgIGtleT17J3RvcCd9XG4gICAgICAgIHBsYWNlbWVudD17J3RvcCd9XG4gICAgICAgIG92ZXJsYXk9ezxUb29sdGlwIGlkPXtgdG9vbHRpcC10b3BgfT57dGV4dH08L1Rvb2x0aXA+fVxuICAgICAgPlxuICAgICAgICA8VHJ1bmNhdGVkVGV4dCBpbmhlcml0VGV4dEFsaWduPXtpbmhlcml0VGV4dEFsaWdufT5cbiAgICAgICAgICA8cCBjbGFzc05hbWU9eyd0cnVuY2F0ZWQtdGV4dCd9PlxuICAgICAgICAgICAgPHNwYW4+e3RydW5jYXRlZH08L3NwYW4+XG4gICAgICAgICAgPC9wPlxuICAgICAgICA8L1RydW5jYXRlZFRleHQ+XG4gICAgICA8L092ZXJsYXlUcmlnZ2VyPlxuICAgIDwvUmVhY3QuRnJhZ21lbnQ+XG4gICk7XG59O1xuXG5jb25zdCBjb25uZWN0b3IgPSBjb25uZWN0KG51bGwpO1xuZXhwb3J0IGRlZmF1bHQgY29ubmVjdG9yKFRydW5jYXRlKTtcblxuY29uc3QgVHJ1bmNhdGVkVGV4dCA9IHN0eWxlZC5kaXY8eyBpbmhlcml0VGV4dEFsaWduOiBib29sZWFuIH0+YFxuICAudHJ1bmNhdGVkLXRleHQge1xuICAgIHBhZGRpbmc6IDJweDtcbiAgICBib3JkZXItcmFkaXVzOiAzcHg7XG4gICAgdGV4dC1hbGlnbjogJHsocCkgPT4gKHAuaW5oZXJpdFRleHRBbGlnbiA/ICdpbmhlcml0JyA6ICdjZW50ZXInKX07XG4gICAgdGV4dC1vdmVyZmxvdzogZWxsaXBzaXM7XG4gICAgbWFyZ2luOiAwO1xuICAgIGZvbnQtc2l6ZTogMWVtO1xuICAgIG92ZXJmbG93OiBoaWRkZW4gIWltcG9ydGFudDtcbiAgICB1bmljb2RlLWJpZGk6IHBsYWludGV4dDtcbiAgICBmb250LXdlaWdodDogNjAwO1xuXG4gICAgc3BhbiB7XG4gICAgICB3aGl0ZS1zcGFjZTogbm93cmFwO1xuICAgICAgdGV4dC1vdmVyZmxvdzogZWxsaXBzaXM7XG4gICAgfVxuICB9XG5gO1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7O0FBQUEsSUFBQUEsTUFBQSxHQUFBQyx1QkFBQSxDQUFBQyxPQUFBO0FBQ0EsSUFBQUMsZUFBQSxHQUFBRCxPQUFBO0FBQ0EsSUFBQUUsV0FBQSxHQUFBRixPQUFBO0FBQXNELFNBQUFHLHlCQUFBQyxXQUFBLGVBQUFDLE9BQUEsa0NBQUFDLGlCQUFBLE9BQUFELE9BQUEsUUFBQUUsZ0JBQUEsT0FBQUYsT0FBQSxZQUFBRix3QkFBQSxZQUFBQSx5QkFBQUMsV0FBQSxXQUFBQSxXQUFBLEdBQUFHLGdCQUFBLEdBQUFELGlCQUFBLEtBQUFGLFdBQUE7QUFBQSxTQUFBTCx3QkFBQVMsR0FBQSxFQUFBSixXQUFBLFNBQUFBLFdBQUEsSUFBQUksR0FBQSxJQUFBQSxHQUFBLENBQUFDLFVBQUEsV0FBQUQsR0FBQSxRQUFBQSxHQUFBLGFBQUFFLE9BQUEsQ0FBQUYsR0FBQSx5QkFBQUEsR0FBQSw0QkFBQUcsT0FBQSxFQUFBSCxHQUFBLFVBQUFJLEtBQUEsR0FBQVQsd0JBQUEsQ0FBQUMsV0FBQSxPQUFBUSxLQUFBLElBQUFBLEtBQUEsQ0FBQUMsR0FBQSxDQUFBTCxHQUFBLFlBQUFJLEtBQUEsQ0FBQUUsR0FBQSxDQUFBTixHQUFBLFNBQUFPLE1BQUEsV0FBQUMscUJB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
|