@kando-env/kando-ui 1.2.458-alpha.1 → 1.2.458-alpha.11

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.
@@ -6,7 +6,6 @@ Object.defineProperty(exports, "__esModule", {
6
6
  value: true
7
7
  });
8
8
  exports.default = void 0;
9
- exports.getAllNodeNames = getAllNodeNames;
10
9
  var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/objectSpread2"));
11
10
  var _createForOfIteratorHelper2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/createForOfIteratorHelper"));
12
11
  var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/slicedToArray"));
@@ -20,32 +19,14 @@ var _Loader = require("../../pages/DashboardMap/Loader");
20
19
  var _RightPanel = _interopRequireDefault(require("../../pages/OperationsPage/RightPanel"));
21
20
  var _urls = require("../../utilities/urls");
22
21
  var _useApiWithDashboardQuery = require("../../hooks/useApiWithDashboardQuery");
23
- var _reactSelect = _interopRequireDefault(require("react-select"));
24
- var _d3Hierarchy = require("d3-hierarchy");
25
- var _i18n = _interopRequireDefault(require("../../utilities/i18n"));
26
- var _reactRouterDom = require("react-router-dom");
22
+ var _FilterContainer = _interopRequireDefault(require("../../pages/EventsPage/events/events_list/Filter/FilterContainer"));
27
23
  function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
28
24
  function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
29
- function getAllNodeNames(tree) {
30
- var root = (0, _d3Hierarchy.hierarchy)(tree);
31
- return root.descendants().map(function (n) {
32
- var _n$data$attributes;
33
- return {
34
- value: (_n$data$attributes = n.data.attributes) === null || _n$data$attributes === void 0 ? void 0 : _n$data$attributes.point_id,
35
- label: n.data.name
36
- };
37
- });
38
- }
39
25
  var HierarchyGraph = function HierarchyGraph() {
40
26
  var searchQuery = (0, _useQueryURL.default)();
41
- var _useParams = (0, _reactRouterDom.useParams)(),
42
- siteID = _useParams.siteID;
43
27
  var ReduxState = (0, _reactRedux.useSelector)(function (state) {
44
28
  return state;
45
29
  });
46
- // const [depth, setDepth] = useState<number>(12);
47
- // const [treeKey, setTreeKey] = useState<number>(0);
48
- // const [nodeType, setNodeType] = useState<NodeType>('pie');
49
30
  var _useState = (0, _react.useState)(null),
50
31
  _useState2 = (0, _slicedToArray2.default)(_useState, 2),
51
32
  selectedPoint = _useState2[0],
@@ -54,14 +35,10 @@ var HierarchyGraph = function HierarchyGraph() {
54
35
  _useState4 = (0, _slicedToArray2.default)(_useState3, 2),
55
36
  showRightPanel = _useState4[0],
56
37
  setShowRightPanel = _useState4[1];
57
- var _useState5 = (0, _react.useState)(false),
38
+ var _useState5 = (0, _react.useState)({}),
58
39
  _useState6 = (0, _slicedToArray2.default)(_useState5, 2),
59
- showOnlyMonitored = _useState6[0],
60
- setShowOnlyMonitored = _useState6[1];
61
- // const updateTreeView = (depth) => {
62
- // setDepth(depth);
63
- // setTreeKey((prev) => prev + 1); // force re-mount to reset tree state
64
- // };
40
+ filterOptions = _useState6[0],
41
+ setFilterOptions = _useState6[1];
65
42
  var isHierarchyTab = searchQuery.get('view') === 'hierarchy';
66
43
  var points_data = ReduxState.points_data,
67
44
  edges_data = ReduxState.edges_data,
@@ -100,8 +77,17 @@ var HierarchyGraph = function HierarchyGraph() {
100
77
  for (_iterator.s(); !(_step = _iterator.n()).done;) {
101
78
  var _step$value = _step.value,
102
79
  site_id = _step$value.site_id,
103
- pollution = _step$value.pollution;
104
- if (pollution === null || pollution === void 0 ? void 0 : pollution.type_distribution) m.set(site_id, pollution.type_distribution);
80
+ pollution = _step$value.pollution,
81
+ sector_name = _step$value.sector_name,
82
+ sector_id = _step$value.sector_id,
83
+ contributor_percents = _step$value.contributor_percents;
84
+ var extraData = {
85
+ sector_name: sector_name,
86
+ contributor_percents: contributor_percents,
87
+ sector_id: sector_id
88
+ };
89
+ if (pollution === null || pollution === void 0 ? void 0 : pollution.type_distribution) extraData['pollution'] = pollution.type_distribution;
90
+ m.set(site_id, extraData);
105
91
  }
106
92
  } catch (err) {
107
93
  _iterator.e(err);
@@ -122,9 +108,7 @@ var HierarchyGraph = function HierarchyGraph() {
122
108
  var numId = Number(id);
123
109
  var pollution = pollutionBySiteId.get(numId);
124
110
  // shallow clone each point; add pollution if exists
125
- copy[numId] = pollution ? (0, _objectSpread2.default)((0, _objectSpread2.default)({}, base[numId]), {}, {
126
- pollution: pollution
127
- }) : (0, _objectSpread2.default)({}, base[numId]);
111
+ copy[numId] = pollution ? (0, _objectSpread2.default)((0, _objectSpread2.default)({}, base[numId]), pollution) : (0, _objectSpread2.default)({}, base[numId]);
128
112
  }
129
113
  return copy;
130
114
  }, [points_data.items, pollutionBySiteId]);
@@ -138,96 +122,52 @@ var HierarchyGraph = function HierarchyGraph() {
138
122
  return pointsWithDevice[edge.source_point_id] || edge.descendants_has_device;
139
123
  });
140
124
  }, [points_data.items, edges_data.items]);
125
+ var filterPoints = (0, _react.useMemo)(function () {
126
+ var pointsOption = {};
127
+ var pointList = points_data.items;
128
+ edgesWithDevice.forEach(function (edge) {
129
+ var sourcePoint = pointList.find(function (p) {
130
+ return p.id === edge.source_point_id;
131
+ });
132
+ var targetPoint = pointList.find(function (p) {
133
+ return p.id === edge.target_point_id;
134
+ });
135
+ if (sourcePoint) pointsOption[sourcePoint.id] = {
136
+ id: sourcePoint.id,
137
+ name: sourcePoint.group.name
138
+ };
139
+ if (targetPoint) pointsOption[targetPoint.id] = {
140
+ id: targetPoint.id,
141
+ name: targetPoint.group.name
142
+ };
143
+ });
144
+ return Object.values(pointsOption);
145
+ }, [points_data.items, edgesWithDevice]);
141
146
 
142
147
  // 4) Build the tree ONLY when data is ready; keep referential stability
143
148
  var treeData = (0, _react.useMemo)(function () {
144
149
  if (isLoadingSites || errorSites) return null;
145
150
  return (0, _utils.buildTree)(edgesWithDevice, decoratedPointsById, waterAuthorityName);
146
151
  }, [edgesWithDevice, decoratedPointsById, waterAuthorityName, isLoadingSites, errorSites]);
152
+ var updateFilter = function updateFilter(appliedFilter) {
153
+ // Process the applied filter as needed
154
+ var selectedFilters = {};
155
+ appliedFilter.filter_items.forEach(function (item) {
156
+ selectedFilters[item.type] = item.selected_options;
157
+ });
158
+ setFilterOptions(selectedFilters);
159
+ // You can update state or make API calls based on the applied filter
160
+ };
147
161
 
148
- // const nodeTypeOptions = [
149
- // { label: 'Pie Chart', value: 'pie' },
150
- // { label: 'Bar', value: 'bar' },
151
- // ];
152
-
153
- var _useState7 = (0, _react.useState)(''),
154
- _useState8 = (0, _slicedToArray2.default)(_useState7, 2),
155
- searchTerm = _useState8[0],
156
- setSearchTerm = _useState8[1];
157
- var searchOptions = (0, _react.useMemo)(function () {
158
- return treeData ? getAllNodeNames(treeData) : [];
159
- }, [treeData]);
160
- var _useState9 = (0, _react.useState)(false),
161
- _useState10 = (0, _slicedToArray2.default)(_useState9, 2),
162
- showSamplers = _useState10[0],
163
- setShowSamplers = _useState10[1];
164
- (0, _react.useEffect)(function () {
165
- if (siteID) {
166
- var matchedOption = searchOptions.find(function (option) {
167
- var _option$value;
168
- return (option === null || option === void 0 ? void 0 : (_option$value = option.value) === null || _option$value === void 0 ? void 0 : _option$value.toString()) === siteID;
169
- });
170
- if (matchedOption) {
171
- setSearchTerm(matchedOption.label);
172
- }
173
- }
174
- }, [searchOptions]);
175
162
  if (!isHierarchyTab) {
176
163
  return null;
177
164
  }
178
- return /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement("div", {
179
- style: {
180
- marginTop: '10px',
181
- marginInlineStart: '10px',
182
- display: 'flex',
183
- gap: 8,
184
- zIndex: 10
185
- }
186
- }, /*#__PURE__*/_react.default.createElement(_reactBootstrap.Form.Group, {
187
- className: 'mt-2'
188
- }, /*#__PURE__*/_react.default.createElement(_reactBootstrap.Form.Check, {
189
- inline: true,
190
- label: 'Show only monitored',
191
- name: "show_only_monitored",
192
- type: "checkbox",
193
- id: "show_only_monitored",
194
- onChange: function onChange(e) {
195
- setShowOnlyMonitored(!showOnlyMonitored);
196
- },
197
- checked: showOnlyMonitored
198
- })), /*#__PURE__*/_react.default.createElement(_reactBootstrap.Form.Group, {
199
- className: 'mt-2'
200
- }, /*#__PURE__*/_react.default.createElement(_reactBootstrap.Form.Check, {
201
- inline: true,
202
- label: 'Show samplers',
203
- name: "show_samplers",
204
- type: "checkbox",
205
- id: "show_samplers",
206
- onChange: function onChange(e) {
207
- setShowSamplers(!showSamplers);
208
- },
209
- checked: showSamplers
210
- })), /*#__PURE__*/_react.default.createElement("div", {
211
- style: {
212
- width: '240px'
213
- }
214
- }, /*#__PURE__*/_react.default.createElement(_reactSelect.default, {
215
- placeholder: _i18n.default.t('dashboard_v2.utility_dashboard.hierarchy.search'),
216
- value: searchOptions.find(function (option) {
217
- return option.label === searchTerm;
218
- }) || null,
219
- isLoading: !searchOptions.length,
220
- isClearable: true,
221
- isSearchable: true,
222
- name: "color",
223
- onChange: function onChange(value) {
224
- return setSearchTerm((value === null || value === void 0 ? void 0 : value.label) || '');
225
- },
226
- options: searchOptions,
227
- onInputChangeCallback: function onInputChangeCallback(input) {
228
- return setSearchTerm(input);
229
- }
230
- }))), /*#__PURE__*/_react.default.createElement(_reactBootstrap.Container, {
165
+ return /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement(_FilterContainer.default, {
166
+ filterPopupOpen: true,
167
+ fetchType: 'HierarchyFilter',
168
+ applyLogic: updateFilter,
169
+ custom_points: filterPoints
170
+ }), /*#__PURE__*/_react.default.createElement(_reactBootstrap.Container, {
231
171
  fluid: true,
232
172
  className: "p-0",
233
173
  style: {
@@ -244,10 +184,7 @@ var HierarchyGraph = function HierarchyGraph() {
244
184
  treeKey: 0,
245
185
  initialDepth: 12,
246
186
  data: treeData,
247
- nodeType: 'nodeType',
248
- searchTerm: searchTerm,
249
- showOnlyMonitored: showOnlyMonitored,
250
- showSamplers: showSamplers,
187
+ selectedFilters: filterOptions,
251
188
  onNodeClick: onNodeClick
252
189
  }), /*#__PURE__*/_react.default.createElement(_RightPanel.default, {
253
190
  className: "right-panel ".concat(showRightPanel ? 'open' : ''),
@@ -260,4 +197,4 @@ var HierarchyGraph = function HierarchyGraph() {
260
197
  };
261
198
  var _default = HierarchyGraph;
262
199
  exports.default = _default;
263
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_useQueryURL","_interopRequireDefault","_utils","_reactRedux","_AutoFitTree","_reactBootstrap","_Loader","_RightPanel","_urls","_useApiWithDashboardQuery","_reactSelect","_d3Hierarchy","_i18n","_reactRouterDom","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","getAllNodeNames","tree","root","hierarchy","descendants","map","n","_n$data$attributes","value","data","attributes","point_id","label","name","HierarchyGraph","searchQuery","useQueryURL","_useParams","useParams","siteID","ReduxState","useSelector","state","_useState","useState","_useState2","_slicedToArray2","selectedPoint","setSelectedPoint","_useState3","_useState4","showRightPanel","setShowRightPanel","_useState5","_useState6","showOnlyMonitored","setShowOnlyMonitored","isHierarchyTab","points_data","edges_data","waterAuthorityName","global_data","onNodeClick","nodeData","items","find","p","id","factoriesEndPoint","useMemo","urls","dashboard","Utility","factories","paramsAll","type","_useApiWithDashboardQ","useApiWithDashboardQuery","_useApiWithDashboardQ2","responseSites","isLoadingSites","errorSites","pollutionBySiteId","m","Map","_iterator","_createForOfIteratorHelper2","_step","s","done","_step$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","_useState7","_useState8","searchTerm","setSearchTerm","searchOptions","_useState9","_useState10","showSamplers","setShowSamplers","useEffect","matchedOption","option","_option$value","toString","createElement","style","marginTop","marginInlineStart","display","gap","zIndex","Form","Group","className","Check","inline","onChange","checked","width","placeholder","I18n","t","isLoading","isClearable","isSearchable","options","onInputChangeCallback","input","Container","fluid","overflow","Row","sm","Col","height","isFetching","Loader","treeKey","initialDepth","nodeType","concat","point","onClose","_default","exports"],"sources":["../../../src/ui-kit/HierarchyGraph/HierarchyGraph.tsx"],"sourcesContent":["import React, { useEffect, useMemo } from 'react';\n\nimport useQueryURL from '../../hooks/useQueryURL';\nimport { buildTree, mapById, TreeData } from './utils';\nimport { useSelector } from 'react-redux';\nimport { useState } from 'react';\nimport AutoFitTree from './AutoFitTree';\nimport { Container, Row, Col, Form } from 'react-bootstrap';\nimport { Loader } from '../../pages/DashboardMap/Loader';\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 ReactSelect from 'react-select';\nimport { hierarchy } from 'd3-hierarchy';\nimport I18n from '../../utilities/i18n';\nimport { useParams } from 'react-router-dom';\n\nexport function getAllNodeNames(tree: TreeData): string[] {\n  const root = hierarchy(tree as any);\n  return root.descendants().map((n) => {\n    return { value: n.data.attributes?.point_id, label: n.data.name };\n  });\n}\n\nconst HierarchyGraph = () => {\n  const searchQuery = useQueryURL();\n  const { siteID } = useParams();\n  const ReduxState = useSelector((state) => state);\n  // const [depth, setDepth] = useState<number>(12);\n  // const [treeKey, setTreeKey] = useState<number>(0);\n  // const [nodeType, setNodeType] = useState<NodeType>('pie');\n  const [selectedPoint, setSelectedPoint] = useState(null);\n  const [showRightPanel, setShowRightPanel] = useState(false);\n  const [showOnlyMonitored, setShowOnlyMonitored] = useState(false);\n  // const updateTreeView = (depth) => {\n  //   setDepth(depth);\n  //   setTreeKey((prev) => prev + 1); // force re-mount to reset tree state\n  // };\n  const isHierarchyTab = searchQuery.get('view') === 'hierarchy';\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  // const nodeTypeOptions = [\n  //   { label: 'Pie Chart', value: 'pie' },\n  //   { label: 'Bar', value: 'bar' },\n  // ];\n\n  const [searchTerm, setSearchTerm] = useState('');\n  const searchOptions = useMemo(\n    () => (treeData ? getAllNodeNames(treeData) : []),\n    [treeData],\n  );\n  const [showSamplers, setShowSamplers] = useState(false);\n\n  useEffect(() => {\n    if (siteID) {\n      const matchedOption = searchOptions.find(\n        (option) => option?.value?.toString() === siteID,\n      );\n      if (matchedOption) {\n        setSearchTerm(matchedOption.label);\n      }\n    }\n  }, [searchOptions]);\n\n  if (!isHierarchyTab) {\n    return null;\n  }\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={() => updateTreeView(1)}>{'Collapse All'}</Button>*/}\n        {/*<Button onClick={() => updateTreeView(12)}>{'Expand All'}</Button>*/}\n\n        {/*<Select*/}\n        {/*  options={nodeTypeOptions}*/}\n        {/*  value={nodeTypeOptions.find((option) => option.value === nodeType)}*/}\n        {/*  setValue={(selected) => setNodeType(selected.value)}*/}\n        {/*  menuWidth={120}*/}\n        {/*/>*/}\n        <Form.Group className={'mt-2'}>\n          <Form.Check\n            inline\n            label={'Show only monitored'}\n            name=\"show_only_monitored\"\n            type=\"checkbox\"\n            id=\"show_only_monitored\"\n            onChange={(e) => {\n              setShowOnlyMonitored(!showOnlyMonitored);\n            }}\n            checked={showOnlyMonitored}\n          />\n        </Form.Group>\n        <Form.Group className={'mt-2'}>\n          <Form.Check\n            inline\n            label={'Show samplers'}\n            name=\"show_samplers\"\n            type=\"checkbox\"\n            id=\"show_samplers\"\n            onChange={(e) => {\n              setShowSamplers(!showSamplers);\n            }}\n            checked={showSamplers}\n          />\n        </Form.Group>\n        <div style={{ width: '240px' }}>\n          <ReactSelect\n            placeholder={I18n.t(\n              'dashboard_v2.utility_dashboard.hierarchy.search',\n            )}\n            value={\n              searchOptions.find((option) => option.label === searchTerm) ||\n              null\n            }\n            isLoading={!searchOptions.length}\n            isClearable={true}\n            isSearchable={true}\n            name=\"color\"\n            onChange={(value) => setSearchTerm(value?.label || '')}\n            options={searchOptions}\n            onInputChangeCallback={(input) => setSearchTerm(input)}\n          />\n        </div>\n        {/*<input*/}\n        {/*  type=\"text\"*/}\n        {/*  style={{ height: '30px', marginTop: 6, paddingInlineStart: 5 }}*/}\n        {/*  value={searchTerm}*/}\n        {/*  onChange={(e) => setSearchTerm(e.target.value)}*/}\n        {/*  placeholder=\"Search by name...\"*/}\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                treeKey={0}\n                initialDepth={12}\n                data={treeData}\n                nodeType={'nodeType'}\n                searchTerm={searchTerm}\n                showOnlyMonitored={showOnlyMonitored}\n                showSamplers={showSamplers}\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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"}
200
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_useQueryURL","_interopRequireDefault","_utils","_reactRedux","_AutoFitTree","_reactBootstrap","_Loader","_RightPanel","_urls","_useApiWithDashboardQuery","_FilterContainer","_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","selectedPoint","setSelectedPoint","_useState3","_useState4","showRightPanel","setShowRightPanel","_useState5","_useState6","filterOptions","setFilterOptions","isHierarchyTab","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","sector_name","sector_id","contributor_percents","extraData","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","filterPoints","pointsOption","pointList","forEach","sourcePoint","targetPoint","target_point_id","name","group","values","treeData","buildTree","updateFilter","appliedFilter","selectedFilters","filter_items","item","selected_options","createElement","filterPopupOpen","fetchType","applyLogic","custom_points","Container","fluid","className","style","overflow","Row","sm","Col","height","isFetching","Loader","treeKey","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 } 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 RightPanel from '../../pages/OperationsPage/RightPanel';\nimport { urls } from '../../utilities/urls';\nimport { useApiWithDashboardQuery } from '../../hooks/useApiWithDashboardQuery';\nimport { FactoriesResponse } from '../../Widgets/MostPolluting/Factories/factoriesResponse.interface';\nimport FilterContainer from '../../pages/EventsPage/events/events_list/Filter/FilterContainer';\n\nconst HierarchyGraph = () => {\n  const searchQuery = useQueryURL();\n  const ReduxState = useSelector((state) => state);\n  const [selectedPoint, setSelectedPoint] = useState(null);\n  const [showRightPanel, setShowRightPanel] = useState(false);\n  const [filterOptions, setFilterOptions] = useState({});\n  const isHierarchyTab = searchQuery.get('view') === 'hierarchy';\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 {\n        site_id,\n        pollution,\n        sector_name,\n        sector_id,\n        contributor_percents,\n      } of responseSites.data) {\n        const extraData = { sector_name, contributor_percents, sector_id };\n        if (pollution?.type_distribution)\n          extraData['pollution'] = pollution.type_distribution;\n        m.set(site_id, extraData);\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  const filterPoints = useMemo(() => {\n    const pointsOption = {};\n    const pointList = points_data.items;\n    edgesWithDevice.forEach((edge) => {\n      const sourcePoint = pointList.find((p) => p.id === edge.source_point_id);\n      const targetPoint = pointList.find((p) => p.id === edge.target_point_id);\n      if (sourcePoint)\n        pointsOption[sourcePoint.id] = {\n          id: sourcePoint.id,\n          name: sourcePoint.group.name,\n        };\n      if (targetPoint)\n        pointsOption[targetPoint.id] = {\n          id: targetPoint.id,\n          name: targetPoint.group.name,\n        };\n    });\n    return Object.values(pointsOption);\n  }, [points_data.items, edgesWithDevice]);\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  const updateFilter = (appliedFilter) => {\n    // Process the applied filter as needed\n    const selectedFilters = {};\n\n    appliedFilter.filter_items.forEach((item) => {\n      selectedFilters[item.type] = item.selected_options;\n    });\n    setFilterOptions(selectedFilters);\n    // You can update state or make API calls based on the applied filter\n  };\n\n  if (!isHierarchyTab) {\n    return null;\n  }\n\n  return (\n    <div>\n      <FilterContainer\n        filterPopupOpen={true}\n        fetchType={'HierarchyFilter'}\n        applyLogic={updateFilter}\n        custom_points={filterPoints}\n      />\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                treeKey={0}\n                initialDepth={12}\n                data={treeData}\n                selectedFilters={filterOptions}\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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"}
@@ -16,9 +16,7 @@ var MicroStackedBar = function MicroStackedBar(_ref) {
16
16
  height = _ref$height === void 0 ? 8 : _ref$height,
17
17
  _ref$radius = _ref.radius,
18
18
  radius = _ref$radius === void 0 ? 4 : _ref$radius;
19
- var total = segments.reduce(function (s, x) {
20
- return s + x.value;
21
- }, 0) || 1;
19
+ var total = 100;
22
20
  var x = 0;
23
21
  return /*#__PURE__*/_react.default.createElement("svg", {
24
22
  width: width,
@@ -62,4 +60,4 @@ var MicroStackedBar = function MicroStackedBar(_ref) {
62
60
  };
63
61
  var _default = MicroStackedBar;
64
62
  exports.default = _default;
65
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIk1pY3JvU3RhY2tlZEJhciIsIl9yZWYiLCJzZWdtZW50cyIsIl9yZWYkd2lkdGgiLCJ3aWR0aCIsIl9yZWYkaGVpZ2h0IiwiaGVpZ2h0IiwiX3JlZiRyYWRpdXMiLCJyYWRpdXMiLCJ0b3RhbCIsInJlZHVjZSIsInMiLCJ4IiwidmFsdWUiLCJkZWZhdWx0IiwiY3JlYXRlRWxlbWVudCIsInN0eWxlIiwiZGlzcGxheSIsImlkIiwieSIsInJ4IiwicnkiLCJjbGlwUGF0aCIsIm1hcCIsImkiLCJ3IiwicmVjdCIsImtleSIsImZpbGwiLCJjb2xvciIsInN0cm9rZSIsIl9kZWZhdWx0IiwiZXhwb3J0cyJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy91aS1raXQvSGllcmFyY2h5R3JhcGgvTWljcm9TdGFja2VkQmFyLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuXG4vLyBNaWNyb1N0YWNrZWRCYXIudHN4XG50eXBlIFNlZyA9IHsgdmFsdWU6IG51bWJlcjsgY29sb3I6IHN0cmluZzsgdGl0bGU/OiBzdHJpbmcgfTsgLy8gdmFsdWUgY2FuIGJlIDAuLjEgb3IgMC4uMTAwXG5jb25zdCBNaWNyb1N0YWNrZWRCYXIgPSAoe1xuICBzZWdtZW50cyxcbiAgd2lkdGggPSA4MCxcbiAgaGVpZ2h0ID0gOCxcbiAgcmFkaXVzID0gNCxcbn06IHtcbiAgc2VnbWVudHM6IFNlZ1tdO1xuICB3aWR0aD86IG51bWJlcjtcbiAgaGVpZ2h0PzogbnVtYmVyO1xuICByYWRpdXM/OiBudW1iZXI7XG59KSA9PiB7XG4gIGNvbnN0IHRvdGFsID0gc2VnbWVudHMucmVkdWNlKChzLCB4KSA9PiBzICsgeC52YWx1ZSwgMCkgfHwgMTtcbiAgbGV0IHggPSAwO1xuICByZXR1cm4gKFxuICAgIDxzdmcgd2lkdGg9e3dpZHRofSBoZWlnaHQ9e2hlaWdodH0gc3R5bGU9e3sgZGlzcGxheTogJ2Jsb2NrJyB9fT5cbiAgICAgIDxkZWZzPlxuICAgICAgICA8Y2xpcFBhdGggaWQ9XCJyXCI+XG4gICAgICAgICAgPHJlY3RcbiAgICAgICAgICAgIHg9XCIwXCJcbiAgICAgICAgICAgIHk9XCIwXCJcbiAgICAgICAgICAgIHdpZHRoPXt3aWR0aH1cbiAgICAgICAgICAgIGhlaWdodD17aGVpZ2h0fVxuICAgICAgICAgICAgcng9e3JhZGl1c31cbiAgICAgICAgICAgIHJ5PXtyYWRpdXN9XG4gICAgICAgICAgLz5cbiAgICAgICAgPC9jbGlwUGF0aD5cbiAgICAgIDwvZGVmcz5cbiAgICAgIDxnIGNsaXBQYXRoPVwidXJsKCNyKVwiPlxuICAgICAgICB7c2VnbWVudHMubWFwKChzLCBpKSA9PiB7XG4gICAgICAgICAgY29uc3QgdyA9IChzLnZhbHVlIC8gdG90YWwpICogd2lkdGg7XG4gICAgICAgICAgY29uc3QgcmVjdCA9IChcbiAgICAgICAgICAgIDxyZWN0XG4gICAgICAgICAgICAgIGtleT17aX1cbiAgICAgICAgICAgICAgeD17eH1cbiAgICAgICAgICAgICAgeT17MH1cbiAgICAgICAgICAgICAgd2lkdGg9e3d9XG4gICAgICAgICAgICAgIGhlaWdodD17aGVpZ2h0fVxuICAgICAgICAgICAgICBmaWxsPXtzLmNvbG9yfVxuICAgICAgICAgICAgLz5cbiAgICAgICAgICApO1xuICAgICAgICAgIHggKz0gdztcbiAgICAgICAgICByZXR1cm4gcmVjdDtcbiAgICAgICAgfSl9XG4gICAgICA8L2c+XG4gICAgICA8cmVjdFxuICAgICAgICB4PVwiMFwiXG4gICAgICAgIHk9XCIwXCJcbiAgICAgICAgd2lkdGg9e3dpZHRofVxuICAgICAgICBoZWlnaHQ9e2hlaWdodH1cbiAgICAgICAgcng9e3JhZGl1c31cbiAgICAgICAgcnk9e3JhZGl1c31cbiAgICAgICAgZmlsbD1cIm5vbmVcIlxuICAgICAgICBzdHJva2U9XCIjQkRCREJEXCJcbiAgICAgIC8+XG4gICAgPC9zdmc+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
63
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIk1pY3JvU3RhY2tlZEJhciIsIl9yZWYiLCJzZWdtZW50cyIsIl9yZWYkd2lkdGgiLCJ3aWR0aCIsIl9yZWYkaGVpZ2h0IiwiaGVpZ2h0IiwiX3JlZiRyYWRpdXMiLCJyYWRpdXMiLCJ0b3RhbCIsIngiLCJkZWZhdWx0IiwiY3JlYXRlRWxlbWVudCIsInN0eWxlIiwiZGlzcGxheSIsImlkIiwieSIsInJ4IiwicnkiLCJjbGlwUGF0aCIsIm1hcCIsInMiLCJpIiwidyIsInZhbHVlIiwicmVjdCIsImtleSIsImZpbGwiLCJjb2xvciIsInN0cm9rZSIsIl9kZWZhdWx0IiwiZXhwb3J0cyJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy91aS1raXQvSGllcmFyY2h5R3JhcGgvTWljcm9TdGFja2VkQmFyLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuXG4vLyBNaWNyb1N0YWNrZWRCYXIudHN4XG50eXBlIFNlZyA9IHsgdmFsdWU6IG51bWJlcjsgY29sb3I6IHN0cmluZzsgdGl0bGU/OiBzdHJpbmcgfTsgLy8gdmFsdWUgY2FuIGJlIDAuLjEgb3IgMC4uMTAwXG5jb25zdCBNaWNyb1N0YWNrZWRCYXIgPSAoe1xuICBzZWdtZW50cyxcbiAgd2lkdGggPSA4MCxcbiAgaGVpZ2h0ID0gOCxcbiAgcmFkaXVzID0gNCxcbn06IHtcbiAgc2VnbWVudHM6IFNlZ1tdO1xuICB3aWR0aD86IG51bWJlcjtcbiAgaGVpZ2h0PzogbnVtYmVyO1xuICByYWRpdXM/OiBudW1iZXI7XG59KSA9PiB7XG4gIGNvbnN0IHRvdGFsID0gMTAwO1xuICBsZXQgeCA9IDA7XG4gIHJldHVybiAoXG4gICAgPHN2ZyB3aWR0aD17d2lkdGh9IGhlaWdodD17aGVpZ2h0fSBzdHlsZT17eyBkaXNwbGF5OiAnYmxvY2snIH19PlxuICAgICAgPGRlZnM+XG4gICAgICAgIDxjbGlwUGF0aCBpZD1cInJcIj5cbiAgICAgICAgICA8cmVjdFxuICAgICAgICAgICAgeD1cIjBcIlxuICAgICAgICAgICAgeT1cIjBcIlxuICAgICAgICAgICAgd2lkdGg9e3dpZHRofVxuICAgICAgICAgICAgaGVpZ2h0PXtoZWlnaHR9XG4gICAgICAgICAgICByeD17cmFkaXVzfVxuICAgICAgICAgICAgcnk9e3JhZGl1c31cbiAgICAgICAgICAvPlxuICAgICAgICA8L2NsaXBQYXRoPlxuICAgICAgPC9kZWZzPlxuICAgICAgPGcgY2xpcFBhdGg9XCJ1cmwoI3IpXCI+XG4gICAgICAgIHtzZWdtZW50cy5tYXAoKHMsIGkpID0+IHtcbiAgICAgICAgICBjb25zdCB3ID0gKHMudmFsdWUgLyB0b3RhbCkgKiB3aWR0aDtcbiAgICAgICAgICBjb25zdCByZWN0ID0gKFxuICAgICAgICAgICAgPHJlY3RcbiAgICAgICAgICAgICAga2V5PXtpfVxuICAgICAgICAgICAgICB4PXt4fVxuICAgICAgICAgICAgICB5PXswfVxuICAgICAgICAgICAgICB3aWR0aD17d31cbiAgICAgICAgICAgICAgaGVpZ2h0PXtoZWlnaHR9XG4gICAgICAgICAgICAgIGZpbGw9e3MuY29sb3J9XG4gICAgICAgICAgICAvPlxuICAgICAgICAgICk7XG4gICAgICAgICAgeCArPSB3O1xuICAgICAgICAgIHJldHVybiByZWN0O1xuICAgICAgICB9KX1cbiAgICAgIDwvZz5cbiAgICAgIDxyZWN0XG4gICAgICAgIHg9XCIwXCJcbiAgICAgICAgeT1cIjBcIlxuICAgICAgICB3aWR0aD17d2lkdGh9XG4gICAgICAgIGhlaWdodD17aGVpZ2h0fVxuICAgICAgICByeD17cmFkaXVzfVxuICAgICAgICByeT17cmFkaXVzfVxuICAgICAgICBmaWxsPVwibm9uZVwiXG4gICAgICAgIHN0cm9rZT1cIiNCREJEQkRcIlxuICAgICAgLz5cbiAgICA8L3N2Zz5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IE1pY3JvU3RhY2tlZEJhcjtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUFBLElBQUFBLE1BQUEsR0FBQUMsc0JBQUEsQ0FBQUMsT0FBQTtBQUVBO0FBQzZEO0FBQzdELElBQU1DLGVBQWUsR0FBRyxTQUFsQkEsZUFBZUEsQ0FBQUMsSUFBQSxFQVVmO0VBQUEsSUFUSkMsUUFBUSxHQUFBRCxJQUFBLENBQVJDLFFBQVE7SUFBQUMsVUFBQSxHQUFBRixJQUFBLENBQ1JHLEtBQUs7SUFBTEEsS0FBSyxHQUFBRCxVQUFBLGNBQUcsRUFBRSxHQUFBQSxVQUFBO0lBQUFFLFdBQUEsR0FBQUosSUFBQSxDQUNWSyxNQUFNO0lBQU5BLE1BQU0sR0FBQUQsV0FBQSxjQUFHLENBQUMsR0FBQUEsV0FBQTtJQUFBRSxXQUFBLEdBQUFOLElBQUEsQ0FDVk8sTUFBTTtJQUFOQSxNQUFNLEdBQUFELFdBQUEsY0FBRyxDQUFDLEdBQUFBLFdBQUE7RUFPVixJQUFNRSxLQUFLLEdBQUcsR0FBRztFQUNqQixJQUFJQyxDQUFDLEdBQUcsQ0FBQztFQUNULG9CQUNFYixNQUFBLENBQUFjLE9BQUEsQ0FBQUMsYUFBQTtJQUFLUixLQUFLLEVBQUVBLEtBQU07SUFBQ0UsTUFBTSxFQUFFQSxNQUFPO0lBQUNPLEtBQUssRUFBRTtNQUFFQyxPQUFPLEVBQUU7SUFBUTtFQUFFLGdCQUM3RGpCLE1BQUEsQ0FBQWMsT0FBQSxDQUFBQyxhQUFBLDRCQUNFZixNQUFBLENBQUFjLE9BQUEsQ0FBQUMsYUFBQTtJQUFVRyxFQUFFLEVBQUM7RUFBRyxnQkFDZGxCLE1BQUEsQ0FBQWMsT0FBQSxDQUFBQyxhQUFBO0lBQ0VGLENBQUMsRUFBQyxHQUFHO0lBQ0xNLENBQUMsRUFBQyxHQUFHO0lBQ0xaLEtBQUssRUFBRUEsS0FBTTtJQUNiRSxNQUFNLEVBQUVBLE1BQU87SUFDZlcsRUFBRSxFQUFFVCxNQUFPO0lBQ1hVLEVBQUUsRUFBRVY7RUFBTyxDQUNaLENBQ08sQ0FDTixDQUFDLGVBQ1BYLE1BQUEsQ0FBQWMsT0FBQSxDQUFBQyxhQUFBO0lBQUdPLFFBQVEsRUFBQztFQUFTLEdBQ2xCakIsUUFBUSxDQUFDa0IsR0FBRyxDQUFDLFVBQUNDLENBQUMsRUFBRUMsQ0FBQyxFQUFLO0lBQ3RCLElBQU1DLENBQUMsR0FBSUYsQ0FBQyxDQUFDRyxLQUFLLEdBQUdmLEtBQUssR0FBSUwsS0FBSztJQUNuQyxJQUFNcUIsSUFBSSxnQkFDUjVCLE1BQUEsQ0FBQWMsT0FBQSxDQUFBQyxhQUFBO01BQ0VjLEdBQUcsRUFBRUosQ0FBRTtNQUNQWixDQUFDLEVBQUVBLENBQUU7TUFDTE0sQ0FBQyxFQUFFLENBQUU7TUFDTFosS0FBSyxFQUFFbUIsQ0FBRTtNQUNUakIsTUFBTSxFQUFFQSxNQUFPO01BQ2ZxQixJQUFJLEVBQUVOLENBQUMsQ0FBQ087SUFBTSxDQUNmLENBQ0Y7SUFDRGxCLENBQUMsSUFBSWEsQ0FBQztJQUNOLE9BQU9FLElBQUk7RUFDYixDQUFDLENBQ0EsQ0FBQyxlQUNKNUIsTUFBQSxDQUFBYyxPQUFBLENBQUFDLGFBQUE7SUFDRUYsQ0FBQyxFQUFDLEdBQUc7SUFDTE0sQ0FBQyxFQUFDLEdBQUc7SUFDTFosS0FBSyxFQUFFQSxLQUFNO0lBQ2JFLE1BQU0sRUFBRUEsTUFBTztJQUNmVyxFQUFFLEVBQUVULE1BQU87SUFDWFUsRUFBRSxFQUFFVixNQUFPO0lBQ1htQixJQUFJLEVBQUMsTUFBTTtJQUNYRSxNQUFNLEVBQUM7RUFBUyxDQUNqQixDQUNFLENBQUM7QUFFVixDQUFDO0FBQUMsSUFBQUMsUUFBQSxHQUVhOUIsZUFBZTtBQUFBK0IsT0FBQSxDQUFBcEIsT0FBQSxHQUFBbUIsUUFBQSJ9
@@ -17,10 +17,8 @@ var _reactBootstrap = require("react-bootstrap");
17
17
  var _theme = require("../../styles/theme/theme");
18
18
  var _icons = require("utilities/map/icons");
19
19
  require("./style.scss");
20
- var _PollutionScorePercent = require("../../Widgets/MostPolluting/components/PollutionScorePercent");
21
- var _scoreToData = require("../../utilities/scoreToData");
22
20
  var NodeLayout = function NodeLayout(_ref) {
23
- var _nodeDatum$attributes, _nodeDatum$attributes2, _nodeDatum$attributes3, _nodeDatum$attributes4, _nodeDatum$name, _nodeDatum$name$toLow, _nodeDatum$attributes5, _nodeDatum$attributes6, _nodeDatum$attributes7, _nodeDatum$attributes8, _nodeDatum$attributes9, _nodeDatum$attributes10;
21
+ var _nodeDatum$attributes, _nodeDatum$attributes2, _nodeDatum$name, _nodeDatum$name$toLow, _nodeDatum$attributes3, _nodeDatum$attributes4, _nodeDatum$attributes5, _nodeDatum$attributes6, _nodeDatum$attributes7, _nodeDatum$attributes8;
24
22
  var nodeDatum = _ref.nodeDatum,
25
23
  toggleNode = _ref.toggleNode,
26
24
  searchTerm = _ref.searchTerm,
@@ -30,26 +28,25 @@ var NodeLayout = function NodeLayout(_ref) {
30
28
  var factoryType = ((_nodeDatum$attributes = nodeDatum.attributes) === null || _nodeDatum$attributes === void 0 ? void 0 : _nodeDatum$attributes.type) || '';
31
29
  var isLeafNode = !nodeDatum.children || nodeDatum.children.length === 0;
32
30
  var isMonitored = (_nodeDatum$attributes2 = nodeDatum.attributes) === null || _nodeDatum$attributes2 === void 0 ? void 0 : _nodeDatum$attributes2.monitored;
33
- var score = (_nodeDatum$attributes3 = (_nodeDatum$attributes4 = nodeDatum.attributes) === null || _nodeDatum$attributes4 === void 0 ? void 0 : _nodeDatum$attributes4.score) !== null && _nodeDatum$attributes3 !== void 0 ? _nodeDatum$attributes3 : -1;
34
31
  var borderColor = _theme.theme.natural.n30;
35
- var isHighlighted = !!searchTerm && (((_nodeDatum$name = nodeDatum.name) === null || _nodeDatum$name === void 0 ? void 0 : (_nodeDatum$name$toLow = _nodeDatum$name.toLowerCase()) === null || _nodeDatum$name$toLow === void 0 ? void 0 : _nodeDatum$name$toLow.includes(searchTerm.toLowerCase())) || (nodeDatum === null || nodeDatum === void 0 ? void 0 : (_nodeDatum$attributes5 = nodeDatum.attributes) === null || _nodeDatum$attributes5 === void 0 ? void 0 : (_nodeDatum$attributes6 = _nodeDatum$attributes5.area_name) === null || _nodeDatum$attributes6 === void 0 ? void 0 : (_nodeDatum$attributes7 = _nodeDatum$attributes6.toLowerCase()) === null || _nodeDatum$attributes7 === void 0 ? void 0 : _nodeDatum$attributes7.includes(searchTerm.toLowerCase())));
32
+ var isHighlighted = !!searchTerm && (((_nodeDatum$name = nodeDatum.name) === null || _nodeDatum$name === void 0 ? void 0 : (_nodeDatum$name$toLow = _nodeDatum$name.toLowerCase()) === null || _nodeDatum$name$toLow === void 0 ? void 0 : _nodeDatum$name$toLow.includes(searchTerm.toLowerCase())) || (nodeDatum === null || nodeDatum === void 0 ? void 0 : (_nodeDatum$attributes3 = nodeDatum.attributes) === null || _nodeDatum$attributes3 === void 0 ? void 0 : (_nodeDatum$attributes4 = _nodeDatum$attributes3.area_name) === null || _nodeDatum$attributes4 === void 0 ? void 0 : (_nodeDatum$attributes5 = _nodeDatum$attributes4.toLowerCase()) === null || _nodeDatum$attributes5 === void 0 ? void 0 : _nodeDatum$attributes5.includes(searchTerm.toLowerCase())));
36
33
  // const isFocused = siteID === nodeDatum.attributes?.point_id?.toString();
37
34
 
38
35
  var cardStyle = {
39
36
  borderRadius: '4px',
40
- borderColor: isHighlighted ? _theme.theme.colorScheme.secondary.s1 : borderColor,
37
+ borderColor: isHighlighted ? _theme.theme.brand.surface.muted : borderColor,
41
38
  borderStyle: isMonitored ? 'solid' : 'dashed',
42
39
  borderWidth: '3px',
43
40
  backgroundColor: '#FFFFFF',
44
41
  stroke: 'none',
45
42
  height: '170px'
46
43
  };
47
- var title = factoryType === 'area' ? ((_nodeDatum$attributes8 = nodeDatum.attributes) === null || _nodeDatum$attributes8 === void 0 ? void 0 : _nodeDatum$attributes8.area_name) || nodeDatum.name : nodeDatum.name;
44
+ var title = factoryType === 'area' ? ((_nodeDatum$attributes6 = nodeDatum.attributes) === null || _nodeDatum$attributes6 === void 0 ? void 0 : _nodeDatum$attributes6.area_name) || nodeDatum.name : nodeDatum.name;
48
45
  // const onShowDetails = (event) => {
49
46
  // event.stopPropagation();
50
47
  // onNodeClick(nodeDatum);
51
48
  // };
52
- var isShowSampler = showSamplers && ((_nodeDatum$attributes9 = nodeDatum.attributes) === null || _nodeDatum$attributes9 === void 0 ? void 0 : _nodeDatum$attributes9.has_sampler);
49
+ var isShowSampler = showSamplers && ((_nodeDatum$attributes7 = nodeDatum.attributes) === null || _nodeDatum$attributes7 === void 0 ? void 0 : _nodeDatum$attributes7.has_sampler);
53
50
  if (!nodeDatum.name) {
54
51
  return null;
55
52
  }
@@ -63,9 +60,9 @@ var NodeLayout = function NodeLayout(_ref) {
63
60
  y: "-137",
64
61
  width: "200",
65
62
  height: "250"
66
- }, ((_nodeDatum$attributes10 = nodeDatum.attributes) === null || _nodeDatum$attributes10 === void 0 ? void 0 : _nodeDatum$attributes10.point_id) && /*#__PURE__*/_react.default.createElement(_utils.ActionsContainer, null, /*#__PURE__*/_react.default.createElement(_StyledLink.StyledLink, {
63
+ }, ((_nodeDatum$attributes8 = nodeDatum.attributes) === null || _nodeDatum$attributes8 === void 0 ? void 0 : _nodeDatum$attributes8.point_id) && /*#__PURE__*/_react.default.createElement(_utils.ActionsContainer, null, /*#__PURE__*/_react.default.createElement(_StyledLink.StyledLink, {
67
64
  style: {
68
- stroke: borderColor,
65
+ stroke: _theme.theme.brand.surface.default,
69
66
  strokeWidth: 1,
70
67
  background: 'white',
71
68
  marginInlineStart: 64
@@ -112,19 +109,10 @@ var NodeLayout = function NodeLayout(_ref) {
112
109
  }, /*#__PURE__*/_react.default.createElement("div", {
113
110
  className: 'node-content',
114
111
  style: contentStyle
115
- }, nodeDatum.attributes && isMonitored &&
116
- /*#__PURE__*/
117
- // <SeverityBadge
118
- // className={'score'}
119
- // props={{ score, has_device: isMonitored }}
120
- // /> &&
121
- _react.default.createElement(_PollutionScorePercent.Wrapper, {
122
- scoreColor: (0, _scoreToData.scoreToColor)(score),
123
- up: true
124
- }, score < 0 ? (0, _PollutionScorePercent.render_score_undefined)((0, _scoreToData.scoreToLabel)(score)) : (0, _PollutionScorePercent.scoreLevel)((0, _scoreToData.scoreToLabel)(score), score))))), isLeafNode && /*#__PURE__*/_react.default.createElement(_LeafSign.default, {
112
+ }, nodeDatum.attributes && isMonitored && children))), isLeafNode && /*#__PURE__*/_react.default.createElement(_LeafSign.default, {
125
113
  color: borderColor
126
114
  }));
127
115
  };
128
116
  var _default = NodeLayout;
129
117
  exports.default = _default;
130
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_CardLayout","_NodeIcon","_TopNavbar","_StyledLink","_utils","_LeafSign","_reactI18next","_reactBootstrap","_theme","_icons","_PollutionScorePercent","_scoreToData","NodeLayout","_ref","_nodeDatum$attributes","_nodeDatum$attributes2","_nodeDatum$attributes3","_nodeDatum$attributes4","_nodeDatum$name","_nodeDatum$name$toLow","_nodeDatum$attributes5","_nodeDatum$attributes6","_nodeDatum$attributes7","_nodeDatum$attributes8","_nodeDatum$attributes9","_nodeDatum$attributes10","nodeDatum","toggleNode","searchTerm","showSamplers","children","contentStyle","factoryType","attributes","type","isLeafNode","length","isMonitored","monitored","score","borderColor","theme","natural","n30","isHighlighted","name","toLowerCase","includes","area_name","cardStyle","borderRadius","colorScheme","secondary","s1","borderStyle","borderWidth","backgroundColor","stroke","height","title","isShowSampler","has_sampler","default","createElement","onClick","style","cursor","x","y","width","point_id","ActionsContainer","StyledLink","strokeWidth","background","marginInlineStart","target","updateParams","view","to","concat","e","stopPropagation","OverlayTrigger","overlay","Tooltip","id","placement","Trans","i18nKey","MapSvg","className","src","samplerIcon","alt","headerRight","Wrapper","scoreColor","scoreToColor","up","render_score_undefined","scoreToLabel","scoreLevel","color","_default","exports"],"sources":["../../../src/ui-kit/HierarchyGraph/NodeLayout.tsx"],"sourcesContent":["import React from 'react';\nimport CardLayout from '../../Widgets/MostPolluting/Factories/FactoryBox/CardLayout';\nimport NodeIcon from './NodeIcon';\nimport { MapSvg } from '../../assets/icons/TopNavbar';\nimport { StyledLink } from 'src/components/Links/StyledLink/StyledLink';\nimport { ActionsContainer, NodeProps } from './utils';\nimport LeafSign from './LeafSign';\nimport { Trans } from 'react-i18next';\nimport { OverlayTrigger, Tooltip } from 'react-bootstrap';\nimport { theme } from '../../styles/theme/theme';\nimport { samplerIcon } from 'src/utilities/map/icons';\nimport './style.scss';\nimport {\n  render_score_undefined,\n  scoreLevel,\n  Wrapper,\n} from '../../Widgets/MostPolluting/components/PollutionScorePercent';\nimport { scoreToColor, scoreToLabel } from '../../utilities/scoreToData';\n\nconst NodeLayout = ({\n  nodeDatum,\n  toggleNode,\n  searchTerm,\n  showSamplers,\n  children,\n  contentStyle,\n}: NodeProps) => {\n  const factoryType = nodeDatum.attributes?.type || '';\n  const isLeafNode = !nodeDatum.children || nodeDatum.children.length === 0;\n  const isMonitored = nodeDatum.attributes?.monitored;\n  const score = nodeDatum.attributes?.score ?? -1;\n  const borderColor = theme.natural.n30;\n  const isHighlighted =\n    !!searchTerm &&\n    (nodeDatum.name?.toLowerCase()?.includes(searchTerm.toLowerCase()) ||\n      nodeDatum?.attributes?.area_name\n        ?.toLowerCase()\n        ?.includes(searchTerm.toLowerCase()));\n  // const isFocused = siteID === nodeDatum.attributes?.point_id?.toString();\n\n  const cardStyle: React.CSSProperties = {\n    borderRadius: '4px',\n    borderColor: isHighlighted ? theme.colorScheme.secondary.s1 : borderColor,\n    borderStyle: isMonitored ? 'solid' : 'dashed',\n    borderWidth: '3px',\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  const isShowSampler = showSamplers && nodeDatum.attributes?.has_sampler;\n\n  if (!nodeDatum.name) {\n    return null;\n  }\n  return (\n    <g onClick={toggleNode} style={{ cursor: 'pointer' }}>\n      <foreignObject x=\"-100\" y=\"-137\" width=\"200\" height=\"250\">\n        {nodeDatum.attributes?.point_id && (\n          <ActionsContainer>\n            {/*{earlyAdopter && (*/}\n            {/*  <span style={{ marginInlineEnd: '8px' }}>*/}\n            {/*    <OverlayTrigger*/}\n            {/*      overlay={*/}\n            {/*        <Tooltip id={'details'} placement=\"auto\">*/}\n            {/*          <Trans*/}\n            {/*            i18nKey={'group_screen.general_tab.group_details'}*/}\n            {/*          />*/}\n            {/*        </Tooltip>*/}\n            {/*      }*/}\n            {/*    >*/}\n            {/*      <DetailsSvg onClick={onShowDetails} />*/}\n            {/*    </OverlayTrigger>*/}\n            {/*  </span>*/}\n            {/*)}*/}\n            <StyledLink\n              style={{\n                stroke: borderColor,\n                strokeWidth: 1,\n                background: 'white',\n                marginInlineStart: 64,\n              }}\n              target=\"_blank\"\n              updateParams={{ view: 'map' }}\n              to={`/dashboard_v2/site/${nodeDatum.attributes.point_id}`}\n              onClick={(e) => e.stopPropagation()}\n            >\n              <OverlayTrigger\n                overlay={\n                  <Tooltip id=\"map\" placement=\"auto\">\n                    <Trans i18nKey={'header.map'} />\n                  </Tooltip>\n                }\n              >\n                <MapSvg style={{ width: 55, height: 55 }} />\n              </OverlayTrigger>\n            </StyledLink>\n            {isShowSampler && (\n              <OverlayTrigger\n                overlay={\n                  <Tooltip id=\"sampler\" placement=\"auto\">\n                    <Trans\n                      i18nKey={\n                        'dashboard_v2.utility_dashboard.hierarchy.sampler'\n                      }\n                    />\n                  </Tooltip>\n                }\n              >\n                <span className={'sampler-icon-holder'}>\n                  <img\n                    src={samplerIcon()}\n                    className=\"sampler-icon\"\n                    alt={'sampler'}\n                  />\n                </span>\n              </OverlayTrigger>\n            )}\n          </ActionsContainer>\n        )}\n        <CardLayout\n          title={title}\n          style={cardStyle}\n          headerRight={<NodeIcon type={factoryType} />}\n        >\n          <div className={'node-content'} style={contentStyle}>\n            {nodeDatum.attributes && isMonitored && (\n              // <SeverityBadge\n              //   className={'score'}\n              //   props={{ score, has_device: isMonitored }}\n              // /> &&\n              <Wrapper scoreColor={scoreToColor(score)} up={true}>\n                {score < 0\n                  ? render_score_undefined(scoreToLabel(score))\n                  : scoreLevel(scoreToLabel(score), score)}\n              </Wrapper>\n            )}\n          </div>\n        </CardLayout>\n      </foreignObject>\n      {isLeafNode && <LeafSign color={borderColor} />}\n    </g>\n  );\n};\nexport default NodeLayout;\n"],"mappings":"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"}
118
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_CardLayout","_NodeIcon","_TopNavbar","_StyledLink","_utils","_LeafSign","_reactI18next","_reactBootstrap","_theme","_icons","NodeLayout","_ref","_nodeDatum$attributes","_nodeDatum$attributes2","_nodeDatum$name","_nodeDatum$name$toLow","_nodeDatum$attributes3","_nodeDatum$attributes4","_nodeDatum$attributes5","_nodeDatum$attributes6","_nodeDatum$attributes7","_nodeDatum$attributes8","nodeDatum","toggleNode","searchTerm","showSamplers","children","contentStyle","factoryType","attributes","type","isLeafNode","length","isMonitored","monitored","borderColor","theme","natural","n30","isHighlighted","name","toLowerCase","includes","area_name","cardStyle","borderRadius","brand","surface","muted","borderStyle","borderWidth","backgroundColor","stroke","height","title","isShowSampler","has_sampler","default","createElement","onClick","style","cursor","x","y","width","point_id","ActionsContainer","StyledLink","strokeWidth","background","marginInlineStart","target","updateParams","view","to","concat","e","stopPropagation","OverlayTrigger","overlay","Tooltip","id","placement","Trans","i18nKey","MapSvg","className","src","samplerIcon","alt","headerRight","color","_default","exports"],"sources":["../../../src/ui-kit/HierarchyGraph/NodeLayout.tsx"],"sourcesContent":["import React from 'react';\nimport CardLayout from '../../Widgets/MostPolluting/Factories/FactoryBox/CardLayout';\nimport NodeIcon from './NodeIcon';\nimport { MapSvg } from '../../assets/icons/TopNavbar';\nimport { StyledLink } from 'src/components/Links/StyledLink/StyledLink';\nimport { ActionsContainer, NodeProps } from './utils';\nimport LeafSign from './LeafSign';\nimport { Trans } from 'react-i18next';\nimport { OverlayTrigger, Tooltip } from 'react-bootstrap';\nimport { theme } from '../../styles/theme/theme';\nimport { samplerIcon } from 'src/utilities/map/icons';\nimport './style.scss';\n\nconst NodeLayout = ({\n  nodeDatum,\n  toggleNode,\n  searchTerm,\n  showSamplers,\n  children,\n  contentStyle,\n}: NodeProps) => {\n  const factoryType = nodeDatum.attributes?.type || '';\n  const isLeafNode = !nodeDatum.children || nodeDatum.children.length === 0;\n  const isMonitored = nodeDatum.attributes?.monitored;\n  const borderColor = theme.natural.n30;\n  const isHighlighted =\n    !!searchTerm &&\n    (nodeDatum.name?.toLowerCase()?.includes(searchTerm.toLowerCase()) ||\n      nodeDatum?.attributes?.area_name\n        ?.toLowerCase()\n        ?.includes(searchTerm.toLowerCase()));\n  // const isFocused = siteID === nodeDatum.attributes?.point_id?.toString();\n\n  const cardStyle: React.CSSProperties = {\n    borderRadius: '4px',\n    borderColor: isHighlighted ? theme.brand.surface.muted : borderColor,\n    borderStyle: isMonitored ? 'solid' : 'dashed',\n    borderWidth: '3px',\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  const isShowSampler = showSamplers && nodeDatum.attributes?.has_sampler;\n\n  if (!nodeDatum.name) {\n    return null;\n  }\n  return (\n    <g onClick={toggleNode} style={{ cursor: 'pointer' }}>\n      <foreignObject x=\"-100\" y=\"-137\" width=\"200\" height=\"250\">\n        {nodeDatum.attributes?.point_id && (\n          <ActionsContainer>\n            {/*{earlyAdopter && (*/}\n            {/*  <span style={{ marginInlineEnd: '8px' }}>*/}\n            {/*    <OverlayTrigger*/}\n            {/*      overlay={*/}\n            {/*        <Tooltip id={'details'} placement=\"auto\">*/}\n            {/*          <Trans*/}\n            {/*            i18nKey={'group_screen.general_tab.group_details'}*/}\n            {/*          />*/}\n            {/*        </Tooltip>*/}\n            {/*      }*/}\n            {/*    >*/}\n            {/*      <DetailsSvg onClick={onShowDetails} />*/}\n            {/*    </OverlayTrigger>*/}\n            {/*  </span>*/}\n            {/*)}*/}\n            <StyledLink\n              style={{\n                stroke: theme.brand.surface.default,\n                strokeWidth: 1,\n                background: 'white',\n                marginInlineStart: 64,\n              }}\n              target=\"_blank\"\n              updateParams={{ view: 'map' }}\n              to={`/dashboard_v2/site/${nodeDatum.attributes.point_id}`}\n              onClick={(e) => e.stopPropagation()}\n            >\n              <OverlayTrigger\n                overlay={\n                  <Tooltip id=\"map\" placement=\"auto\">\n                    <Trans i18nKey={'header.map'} />\n                  </Tooltip>\n                }\n              >\n                <MapSvg style={{ width: 55, height: 55 }} />\n              </OverlayTrigger>\n            </StyledLink>\n            {isShowSampler && (\n              <OverlayTrigger\n                overlay={\n                  <Tooltip id=\"sampler\" placement=\"auto\">\n                    <Trans\n                      i18nKey={\n                        'dashboard_v2.utility_dashboard.hierarchy.sampler'\n                      }\n                    />\n                  </Tooltip>\n                }\n              >\n                <span className={'sampler-icon-holder'}>\n                  <img\n                    src={samplerIcon()}\n                    className=\"sampler-icon\"\n                    alt={'sampler'}\n                  />\n                </span>\n              </OverlayTrigger>\n            )}\n          </ActionsContainer>\n        )}\n        <CardLayout\n          title={title}\n          style={cardStyle}\n          headerRight={<NodeIcon type={factoryType} />}\n        >\n          <div className={'node-content'} style={contentStyle}>\n            {nodeDatum.attributes && isMonitored && children}\n          </div>\n        </CardLayout>\n      </foreignObject>\n      {isLeafNode && <LeafSign color={borderColor} />}\n    </g>\n  );\n};\nexport default NodeLayout;\n"],"mappings":"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"}
@@ -0,0 +1,48 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.default = void 0;
8
+ var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/objectWithoutProperties"));
9
+ var _react = _interopRequireDefault(require("react"));
10
+ var _NodeLayout = _interopRequireDefault(require("./NodeLayout"));
11
+ var _MicroStackedBar = _interopRequireDefault(require("./MicroStackedBar"));
12
+ var _reactBootstrap = require("react-bootstrap");
13
+ var _reactI18next = require("react-i18next");
14
+ var _scoreToData = require("../../utilities/scoreToData");
15
+ var _excluded = ["nodeDatum"];
16
+ var PollutionContributorNode = function PollutionContributorNode(_ref) {
17
+ var _nodeDatum$attributes;
18
+ var nodeDatum = _ref.nodeDatum,
19
+ props = (0, _objectWithoutProperties2.default)(_ref, _excluded);
20
+ var contribution_percent = ((_nodeDatum$attributes = nodeDatum.attributes) === null || _nodeDatum$attributes === void 0 ? void 0 : _nodeDatum$attributes.contributor_percents) || 0;
21
+ var segments = [{
22
+ value: contribution_percent,
23
+ color: (0, _scoreToData.scoreToColor)(contribution_percent),
24
+ title: 'Extreme'
25
+ }];
26
+ var pollutionPercent = "".concat(contribution_percent, "%");
27
+ return /*#__PURE__*/_react.default.createElement(_NodeLayout.default, Object.assign({
28
+ nodeDatum: nodeDatum
29
+ }, props), contribution_percent > 0 && /*#__PURE__*/_react.default.createElement(_reactBootstrap.OverlayTrigger, {
30
+ overlay: /*#__PURE__*/_react.default.createElement(_reactBootstrap.Tooltip, {
31
+ id: "polluted-".concat(nodeDatum.name),
32
+ placement: "auto"
33
+ }, /*#__PURE__*/_react.default.createElement(_reactI18next.Trans, {
34
+ i18nKey: 'dashboard_v2.utility_dashboard.hierarchy.polluted',
35
+ values: {
36
+ pollutionPercent: pollutionPercent
37
+ }
38
+ }))
39
+ }, /*#__PURE__*/_react.default.createElement("g", null, /*#__PURE__*/_react.default.createElement(_MicroStackedBar.default, {
40
+ segments: segments,
41
+ width: 160,
42
+ height: 20,
43
+ radius: 8
44
+ }))));
45
+ };
46
+ var _default = PollutionContributorNode;
47
+ exports.default = _default;
48
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIl9Ob2RlTGF5b3V0IiwiX01pY3JvU3RhY2tlZEJhciIsIl9yZWFjdEJvb3RzdHJhcCIsIl9yZWFjdEkxOG5leHQiLCJfc2NvcmVUb0RhdGEiLCJfZXhjbHVkZWQiLCJQb2xsdXRpb25Db250cmlidXRvck5vZGUiLCJfcmVmIiwiX25vZGVEYXR1bSRhdHRyaWJ1dGVzIiwibm9kZURhdHVtIiwicHJvcHMiLCJfb2JqZWN0V2l0aG91dFByb3BlcnRpZXMyIiwiZGVmYXVsdCIsImNvbnRyaWJ1dGlvbl9wZXJjZW50IiwiYXR0cmlidXRlcyIsImNvbnRyaWJ1dG9yX3BlcmNlbnRzIiwic2VnbWVudHMiLCJ2YWx1ZSIsImNvbG9yIiwic2NvcmVUb0NvbG9yIiwidGl0bGUiLCJwb2xsdXRpb25QZXJjZW50IiwiY29uY2F0IiwiY3JlYXRlRWxlbWVudCIsIk9iamVjdCIsImFzc2lnbiIsIk92ZXJsYXlUcmlnZ2VyIiwib3ZlcmxheSIsIlRvb2x0aXAiLCJpZCIsIm5hbWUiLCJwbGFjZW1lbnQiLCJUcmFucyIsImkxOG5LZXkiLCJ2YWx1ZXMiLCJ3aWR0aCIsImhlaWdodCIsInJhZGl1cyIsIl9kZWZhdWx0IiwiZXhwb3J0cyJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy91aS1raXQvSGllcmFyY2h5R3JhcGgvUG9sbHV0aW9uQ29udHJpYnV0b3JOb2RlLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IE5vZGVMYXlvdXQgZnJvbSAnLi9Ob2RlTGF5b3V0JztcbmltcG9ydCB7IE5vZGVQcm9wcyB9IGZyb20gJy4vdXRpbHMnO1xuaW1wb3J0IE1pY3JvU3RhY2tlZEJhciBmcm9tICcuL01pY3JvU3RhY2tlZEJhcic7XG5pbXBvcnQgeyBPdmVybGF5VHJpZ2dlciwgVG9vbHRpcCB9IGZyb20gJ3JlYWN0LWJvb3RzdHJhcCc7XG5pbXBvcnQgeyBUcmFucyB9IGZyb20gJ3JlYWN0LWkxOG5leHQnO1xuaW1wb3J0IHsgc2NvcmVUb0NvbG9yIH0gZnJvbSAnLi4vLi4vdXRpbGl0aWVzL3Njb3JlVG9EYXRhJztcblxuY29uc3QgUG9sbHV0aW9uQ29udHJpYnV0b3JOb2RlID0gKHsgbm9kZURhdHVtLCAuLi5wcm9wcyB9OiBOb2RlUHJvcHMpID0+IHtcbiAgY29uc3QgY29udHJpYnV0aW9uX3BlcmNlbnQgPSBub2RlRGF0dW0uYXR0cmlidXRlcz8uY29udHJpYnV0b3JfcGVyY2VudHMgfHwgMDtcbiAgY29uc3Qgc2VnbWVudHMgPSBbXG4gICAge1xuICAgICAgdmFsdWU6IGNvbnRyaWJ1dGlvbl9wZXJjZW50LFxuICAgICAgY29sb3I6IHNjb3JlVG9Db2xvcihjb250cmlidXRpb25fcGVyY2VudCksXG4gICAgICB0aXRsZTogJ0V4dHJlbWUnLFxuICAgIH0sXG4gIF07XG5cbiAgY29uc3QgcG9sbHV0aW9uUGVyY2VudCA9IGAke2NvbnRyaWJ1dGlvbl9wZXJjZW50fSVgO1xuICByZXR1cm4gKFxuICAgIDxOb2RlTGF5b3V0IG5vZGVEYXR1bT17bm9kZURhdHVtfSB7Li4ucHJvcHN9PlxuICAgICAge2NvbnRyaWJ1dGlvbl9wZXJjZW50ID4gMCAmJiAoXG4gICAgICAgIDxPdmVybGF5VHJpZ2dlclxuICAgICAgICAgIG92ZXJsYXk9e1xuICAgICAgICAgICAgPFRvb2x0aXAgaWQ9e2Bwb2xsdXRlZC0ke25vZGVEYXR1bS5uYW1lfWB9IHBsYWNlbWVudD1cImF1dG9cIj5cbiAgICAgICAgICAgICAgPFRyYW5zXG4gICAgICAgICAgICAgICAgaTE4bktleT17J2Rhc2hib2FyZF92Mi51dGlsaXR5X2Rhc2hib2FyZC5oaWVyYXJjaHkucG9sbHV0ZWQnfVxuICAgICAgICAgICAgICAgIHZhbHVlcz17eyBwb2xsdXRpb25QZXJjZW50IH19XG4gICAgICAgICAgICAgIC8+XG4gICAgICAgICAgICA8L1Rvb2x0aXA+XG4gICAgICAgICAgfVxuICAgICAgICA+XG4gICAgICAgICAgPGc+XG4gICAgICAgICAgICA8TWljcm9TdGFja2VkQmFyXG4gICAgICAgICAgICAgIHNlZ21lbnRzPXtzZWdtZW50c31cbiAgICAgICAgICAgICAgd2lkdGg9ezE2MH1cbiAgICAgICAgICAgICAgaGVpZ2h0PXsyMH1cbiAgICAgICAgICAgICAgcmFkaXVzPXs4fVxuICAgICAgICAgICAgLz5cbiAgICAgICAgICA8L2c+XG4gICAgICAgIDwvT3ZlcmxheVRyaWdnZXI+XG4gICAgICApfVxuICAgIDwvTm9kZUxheW91dD5cbiAgKTtcbn07XG5leHBvcnQgZGVmYXVsdCBQb2xsdXRpb25Db250cmlidXRvck5vZGU7XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7O0FBQUEsSUFBQUEsTUFBQSxHQUFBQyxzQkFBQSxDQUFBQyxPQUFBO0FBQ0EsSUFBQUMsV0FBQSxHQUFBRixzQkFBQSxDQUFBQyxPQUFBO0FBRUEsSUFBQUUsZ0JBQUEsR0FBQUgsc0JBQUEsQ0FBQUMsT0FBQTtBQUNBLElBQUFHLGVBQUEsR0FBQUgsT0FBQTtBQUNBLElBQUFJLGFBQUEsR0FBQUosT0FBQTtBQUNBLElBQUFLLFlBQUEsR0FBQUwsT0FBQTtBQUEyRCxJQUFBTSxTQUFBO0FBRTNELElBQU1DLHdCQUF3QixHQUFHLFNBQTNCQSx3QkFBd0JBLENBQUFDLElBQUEsRUFBMkM7RUFBQSxJQUFBQyxxQkFBQTtFQUFBLElBQXJDQyxTQUFTLEdBQUFGLElBQUEsQ0FBVEUsU0FBUztJQUFLQyxLQUFLLE9BQUFDLHlCQUFBLENBQUFDLE9BQUEsRUFBQUwsSUFBQSxFQUFBRixTQUFBO0VBQ3JELElBQU1RLG9CQUFvQixHQUFHLEVBQUFMLHFCQUFBLEdBQUFDLFNBQVMsQ0FBQ0ssVUFBVSxjQUFBTixxQkFBQSx1QkFBcEJBLHFCQUFBLENBQXNCTyxvQkFBb0IsS0FBSSxDQUFDO0VBQzVFLElBQU1DLFFBQVEsR0FBRyxDQUNmO0lBQ0VDLEtBQUssRUFBRUosb0JBQW9CO0lBQzNCSyxLQUFLLEVBQUUsSUFBQUMseUJBQVksRUFBQ04sb0JBQW9CLENBQUM7SUFDekNPLEtBQUssRUFBRTtFQUNULENBQUMsQ0FDRjtFQUVELElBQU1DLGdCQUFnQixNQUFBQyxNQUFBLENBQU1ULG9CQUFvQixNQUFHO0VBQ25ELG9CQUNFaEIsTUFBQSxDQUFBZSxPQUFBLENBQUFXLGFBQUEsQ0FBQ3ZCLFdBQUEsQ0FBQVksT0FBVSxFQUFBWSxNQUFBLENBQUFDLE1BQUE7SUFBQ2hCLFNBQVMsRUFBRUE7RUFBVSxHQUFLQyxLQUFLLEdBQ3hDRyxvQkFBb0IsR0FBRyxDQUFDLGlCQUN2QmhCLE1BQUEsQ0FBQWUsT0FBQSxDQUFBVyxhQUFBLENBQUNyQixlQUFBLENBQUF3QixjQUFjO0lBQ2JDLE9BQU8sZUFDTDlCLE1BQUEsQ0FBQWUsT0FBQSxDQUFBVyxhQUFBLENBQUNyQixlQUFBLENBQUEwQixPQUFPO01BQUNDLEVBQUUsY0FBQVAsTUFBQSxDQUFjYixTQUFTLENBQUNxQixJQUFJLENBQUc7TUFBQ0MsU0FBUyxFQUFDO0lBQU0sZ0JBQ3pEbEMsTUFBQSxDQUFBZSxPQUFBLENBQUFXLGFBQUEsQ0FBQ3BCLGFBQUEsQ0FBQTZCLEtBQUs7TUFDSkMsT0FBTyxFQUFFLG1EQUFvRDtNQUM3REMsTUFBTSxFQUFFO1FBQUViLGdCQUFnQixFQUFoQkE7TUFBaUI7SUFBRSxDQUM5QixDQUNNO0VBQ1YsZ0JBRUR4QixNQUFBLENBQUFlLE9BQUEsQ0FBQVcsYUFBQSx5QkFDRTFCLE1BQUEsQ0FBQWUsT0FBQSxDQUFBVyxhQUFBLENBQUN0QixnQkFBQSxDQUFBVyxPQUFlO0lBQ2RJLFFBQVEsRUFBRUEsUUFBUztJQUNuQm1CLEtBQUssRUFBRSxHQUFJO0lBQ1hDLE1BQU0sRUFBRSxFQUFHO0lBQ1hDLE1BQU0sRUFBRTtFQUFFLENBQ1gsQ0FDQSxDQUNXLENBRVIsQ0FBQztBQUVqQixDQUFDO0FBQUMsSUFBQUMsUUFBQSxHQUNhaEMsd0JBQXdCO0FBQUFpQyxPQUFBLENBQUEzQixPQUFBLEdBQUEwQixRQUFBIn0=