@kando-env/kando-ui 1.2.414 → 1.2.415

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.
@@ -31,6 +31,7 @@ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj &&
31
31
  //
32
32
  // return { values: values, x_axis: x_axis };
33
33
  // };
34
+
34
35
  var TrendGraphNVL = function TrendGraphNVL(_ref) {
35
36
  var areaID = _ref.areaID,
36
37
  pathogen = _ref.pathogen,
@@ -157,4 +158,4 @@ var TrendGraphNVL = function TrendGraphNVL(_ref) {
157
158
  };
158
159
  var _default = TrendGraphNVL;
159
160
  exports.default = _default;
160
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_highchartsReactOfficial","_interopRequireDefault","_highstock","_trendline","_indicators","_useKandoFetch2","_ContentLoader","_i18n","_reactRedux","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","indicators","Highcharts","trendline","TrendGraphNVL","_ref","areaID","pathogen","_ref$forWbeDashboard","forWbeDashboard","_ref$isVirtualArea","isVirtualArea","TrendStyles","styled","div","withConfig","displayName","componentId","waterAuthorityId","useSelector","state","global_data","matchUrl","concat","_useKandoFetch","useKandoFetch","data","isFetching","_useState","useState","_useState2","_slicedToArray2","options","setOptions","createOptions","parsedData","chart","height","credits","enabled","title","text","rangeSelector","selected","legend","plotOptions","series","marker","radius","xAxis","labels","rotation","categories","x_axis","crosshair","yAxis","softMax","formatter","value","style","color","getOptions","colors","type","id","name","i18n","t","values","lineWidth","time","timezoneOffset","tooltip","y","useHTML","useEffect","length","opts","createElement","className","RowLoader","margin","bgColor","fgColor","area_name","highcharts","_default","exports"],"sources":["../../../../../src/pages/CovidPage/components/TrendGraphNVL/TrendGraphNVL.tsx"],"sourcesContent":["import React, { useEffect, useState } from 'react';\nimport HighchartsReact from 'highcharts-react-official';\nimport Highcharts from 'highcharts/highstock';\nimport trendline from 'highcharts/indicators/trendline';\nimport indicators from 'highcharts/indicators/indicators';\n\nimport useKandoFetch from 'src/hooks/useKandoFetch';\nimport { RowLoader } from 'src/components/ContentLoader';\nimport i18n from 'src/utilities/i18n';\n\nimport { useSelector } from 'react-redux';\nimport { appReducer } from 'src/store/rootReducer';\nimport styled from 'styled-components/macro';\n\nindicators(Highcharts);\ntrendline(Highcharts);\n\ntype IProps = {\n  areaID: number | null;\n  pathogen: string;\n  forWbeDashboard: boolean;\n  isVirtualArea: boolean;\n};\n\ntype IFetchResponse = {} | { x_axis: any[]; values: number[] };\n\n// const parseData = (jsonData: Array<any>) => {\n//   const values = jsonData.map((data: any) => data.nvl);\n//   const x_axis = jsonData.map((data: any) => data.date);\n//\n//   if (!values.length || !x_axis.length) {\n//     return [];\n//   }\n//\n//   return { values: values, x_axis: x_axis };\n// };\n\nconst TrendGraphNVL = ({\n  areaID,\n  pathogen,\n  forWbeDashboard = false,\n  isVirtualArea = false,\n}: IProps) => {\n  const TrendStyles = styled.div`\n    .trend-graph-nvl {\n      height: 320px;\n      overflow: hidden;\n\n      &__title {\n        ${forWbeDashboard ? 'text-align: unset;' : 'text-align: center;'}\n        ${forWbeDashboard ? 'font-size: .9rem;' : 'font-size: 1.6rem;'}\n      ${forWbeDashboard ? 'margin: 0.9rem 0.3rem;' : 'margin: 0 0 2rem;'}\n      }\n\n      &__subtitle {\n        font-size: 1.2rem;\n        text-align: center;\n        margin: 0 0 0.6rem;\n      }\n\n      &__no-chart-data {\n      }\n    }\n  `;\n  const waterAuthorityId = useSelector(\n    (state: ReturnType<typeof appReducer>) =>\n      state.global_data.waterAuthorityId,\n  );\n  const matchUrl = () => {\n    if (isVirtualArea) {\n      return `/api_ui/wbe_dashboard/${pathogen}/trend_graph/virtual/${areaID}?water_authority_id=${waterAuthorityId}`;\n    } else {\n      return `/api_ui/wbe_dashboard/${pathogen}/trend_graph/area/${areaID}?water_authority_id=${waterAuthorityId}`;\n    }\n  };\n  const { data, isFetching } = useKandoFetch(matchUrl());\n  const [options, setOptions] = useState<IFetchResponse>({});\n\n  const createOptions = (parsedData: IFetchResponse) => {\n    return {\n      chart: {\n        height: 254,\n      },\n      // @ts-ignore\n      credits: {\n        enabled: false,\n      },\n      title: {\n        text: null,\n      },\n      rangeSelector: {\n        selected: 5,\n      },\n      legend: {\n        enabled: false,\n      },\n      plotOptions: {\n        series: {\n          marker: {\n            radius: 6,\n          },\n        },\n      },\n      xAxis: [\n        {\n          labels: {\n            rotation: -45,\n          },\n          // @ts-ignore\n          categories: parsedData.x_axis,\n          crosshair: true,\n        },\n      ],\n      yAxis: {\n        // Primary yAxis\n        softMax: 0,\n        title: {\n          text: '',\n        },\n        labels: {\n          // @ts-ignore\n          formatter: function () {\n            // @ts-ignore\n            return this.value;\n          },\n          style: {\n            // @ts-ignore\n            color: Highcharts.getOptions().colors[1],\n          },\n        },\n      },\n      series: [\n        {\n          type: 'line',\n          id: 'PIs',\n          name: i18n.t('components.nvl_trend.value'),\n          // @ts-ignore\n          data: parsedData.values,\n          lineWidth: forWbeDashboard ? 2 : 3,\n          color: forWbeDashboard ? '#3d85ff' : '#fec107',\n        },\n      ],\n      time: {\n        timezoneOffset: data['timezone_offset'],\n      },\n      tooltip: {\n        // @ts-ignore\n        formatter: function () {\n          // @ts-ignore\n          return `${this.series.name}<br/><b>${this.y}</b>`;\n        },\n        useHTML: true,\n      },\n    };\n  };\n\n  useEffect(() => {\n    if (!isFetching && data?.values.length > 0) {\n      const opts = createOptions(data);\n      setOptions(opts);\n    }\n  }, [isFetching]);\n\n  return (\n    <TrendStyles>\n      <div className=\"trend-graph-nvl\">\n        {isFetching ? (\n          <RowLoader margin=\"26px 0 0\" bgColor=\"#f2f2f2\" fgColor=\"#fff\" />\n        ) : (\n          <div className=\"trend-graph-nvl__content\">\n            {!forWbeDashboard && (\n              <div className=\"trend-graph-nvl__title\">\n                {data?.area_name}\n                &nbsp;\n                {i18n.t('components.nvl_trend.over_time')}\n              </div>\n            )}\n            {data.values.length > 0 ? (\n              <HighchartsReact highcharts={Highcharts} options={options} />\n            ) : (\n              <div className=\"trend-graph-nvl__no-chart-data\"></div>\n            )}\n          </div>\n        )}\n      </div>\n    </TrendStyles>\n  );\n};\n\nexport default TrendGraphNVL;\n"],"mappings":"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"}
161
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_highchartsReactOfficial","_interopRequireDefault","_highstock","_trendline","_indicators","_useKandoFetch2","_ContentLoader","_i18n","_reactRedux","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","indicators","Highcharts","trendline","TrendGraphNVL","_ref","areaID","pathogen","_ref$forWbeDashboard","forWbeDashboard","_ref$isVirtualArea","isVirtualArea","TrendStyles","styled","div","withConfig","displayName","componentId","waterAuthorityId","useSelector","state","global_data","matchUrl","concat","_useKandoFetch","useKandoFetch","data","isFetching","_useState","useState","_useState2","_slicedToArray2","options","setOptions","createOptions","parsedData","chart","height","credits","enabled","title","text","rangeSelector","selected","legend","plotOptions","series","marker","radius","xAxis","labels","rotation","categories","x_axis","crosshair","yAxis","softMax","formatter","value","style","color","getOptions","colors","type","id","name","i18n","t","values","lineWidth","time","timezoneOffset","tooltip","y","useHTML","useEffect","length","opts","createElement","className","RowLoader","margin","bgColor","fgColor","area_name","highcharts","_default","exports"],"sources":["../../../../../src/pages/CovidPage/components/TrendGraphNVL/TrendGraphNVL.tsx"],"sourcesContent":["import React, { useEffect, useState } from 'react';\nimport HighchartsReact from 'highcharts-react-official';\nimport Highcharts from 'highcharts/highstock';\nimport trendline from 'highcharts/indicators/trendline';\nimport indicators from 'highcharts/indicators/indicators';\n\nimport useKandoFetch from 'src/hooks/useKandoFetch';\nimport { RowLoader } from 'src/components/ContentLoader';\nimport i18n from 'src/utilities/i18n';\n\nimport { useSelector } from 'react-redux';\nimport { appReducer } from 'src/store/rootReducer';\nimport styled from 'styled-components/macro';\n\nindicators(Highcharts);\ntrendline(Highcharts);\n\ntype IProps = {\n  areaID: number | null;\n  pathogen: string;\n  forWbeDashboard: boolean;\n  isVirtualArea: boolean;\n};\n\ntype IFetchResponse = {} | { x_axis: any[]; values: number[] };\n\n// const parseData = (jsonData: Array<any>) => {\n//   const values = jsonData.map((data: any) => data.nvl);\n//   const x_axis = jsonData.map((data: any) => data.date);\n//\n//   if (!values.length || !x_axis.length) {\n//     return [];\n//   }\n//\n//   return { values: values, x_axis: x_axis };\n// };\n\nconst TrendGraphNVL = ({\n  areaID,\n  pathogen,\n  forWbeDashboard = false,\n  isVirtualArea = false,\n}: IProps) => {\n  const TrendStyles = styled.div`\n    .trend-graph-nvl {\n      height: 320px;\n      overflow: hidden;\n\n      &__title {\n        ${forWbeDashboard ? 'text-align: unset;' : 'text-align: center;'}\n        ${forWbeDashboard ? 'font-size: .9rem;' : 'font-size: 1.6rem;'}\n      ${forWbeDashboard ? 'margin: 0.9rem 0.3rem;' : 'margin: 0 0 2rem;'}\n      }\n\n      &__subtitle {\n        font-size: 1.2rem;\n        text-align: center;\n        margin: 0 0 0.6rem;\n      }\n\n      &__no-chart-data {\n      }\n    }\n  `;\n  const waterAuthorityId = useSelector(\n    (state: ReturnType<typeof appReducer>) =>\n      state.global_data.waterAuthorityId,\n  );\n  const matchUrl = () => {\n    if (isVirtualArea) {\n      return `/api_ui/wbe_dashboard/${pathogen}/trend_graph/virtual/${areaID}?water_authority_id=${waterAuthorityId}`;\n    } else {\n      return `/api_ui/wbe_dashboard/${pathogen}/trend_graph/area/${areaID}?water_authority_id=${waterAuthorityId}`;\n    }\n  };\n  const { data, isFetching } = useKandoFetch(matchUrl());\n  const [options, setOptions] = useState<IFetchResponse>({});\n\n  const createOptions = (parsedData: IFetchResponse) => {\n    return {\n      chart: {\n        height: 254,\n      },\n      // @ts-ignore\n      credits: {\n        enabled: false,\n      },\n      title: {\n        text: null,\n      },\n      rangeSelector: {\n        selected: 5,\n      },\n      legend: {\n        enabled: false,\n      },\n      plotOptions: {\n        series: {\n          marker: {\n            radius: 6,\n          },\n        },\n      },\n      xAxis: [\n        {\n          labels: {\n            rotation: -45,\n          },\n          // @ts-ignore\n          categories: parsedData.x_axis,\n          crosshair: true,\n        },\n      ],\n      yAxis: {\n        // Primary yAxis\n        softMax: 0,\n        title: {\n          text: '',\n        },\n        labels: {\n          // @ts-ignore\n          formatter: function () {\n            // @ts-ignore\n            return this.value;\n          },\n          style: {\n            // @ts-ignore\n            color: Highcharts.getOptions().colors[1],\n          },\n        },\n      },\n      series: [\n        {\n          type: 'line',\n          id: 'PIs',\n          name: i18n.t('components.nvl_trend.value'),\n          // @ts-ignore\n          data: parsedData.values,\n          lineWidth: forWbeDashboard ? 2 : 3,\n          color: forWbeDashboard ? '#3d85ff' : '#fec107',\n        },\n      ],\n      time: {\n        timezoneOffset: data['timezone_offset'],\n      },\n      tooltip: {\n        // @ts-ignore\n        formatter: function () {\n          // @ts-ignore\n          return `${this.series.name}<br/><b>${this.y}</b>`;\n        },\n        useHTML: true,\n      },\n    };\n  };\n\n  useEffect(() => {\n    if (!isFetching && data?.values.length > 0) {\n      const opts = createOptions(data);\n      setOptions(opts);\n    }\n  }, [isFetching]);\n\n  return (\n    <TrendStyles>\n      <div className=\"trend-graph-nvl\">\n        {isFetching ? (\n          <RowLoader margin=\"26px 0 0\" bgColor=\"#f2f2f2\" fgColor=\"#fff\" />\n        ) : (\n          <div className=\"trend-graph-nvl__content\">\n            {!forWbeDashboard && (\n              <div className=\"trend-graph-nvl__title\">\n                {data?.area_name}\n                &nbsp;\n                {i18n.t('components.nvl_trend.over_time')}\n              </div>\n            )}\n            {data.values.length > 0 ? (\n              <HighchartsReact highcharts={Highcharts} options={options} />\n            ) : (\n              <div className=\"trend-graph-nvl__no-chart-data\"></div>\n            )}\n          </div>\n        )}\n      </div>\n    </TrendStyles>\n  );\n};\n\nexport default TrendGraphNVL;\n"],"mappings":"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"}
@@ -38,9 +38,21 @@ var ImportedGisFilesPage = function ImportedGisFilesPage(_ref) {
38
38
  }).importGisFile.importGisProcessPage.url;
39
39
  history.push(url);
40
40
  };
41
+ var uploadNewSitesHandler = function uploadNewSitesHandler() {
42
+ var url = (0, _urls.urls)({
43
+ waterAuthorityId: waterAuthorityId,
44
+ local: navContext.locale
45
+ }).importSiteFile.importSiteProcessPage.url;
46
+ history.push(url);
47
+ };
41
48
  var defaultImportedGisFilesTable = [{
42
49
  date: _i18n.default.t('datatable.no_data')
43
50
  }];
51
+ var _useSelector3 = (0, _reactRedux.useSelector)(function (_ref2) {
52
+ var permissions = _ref2.permissions;
53
+ return permissions;
54
+ }),
55
+ enable_upload_sites = _useSelector3.enable_upload_sites;
44
56
  return /*#__PURE__*/_react.default.createElement("div", {
45
57
  className: _styleModule.default.pageLayout
46
58
  }, /*#__PURE__*/_react.default.createElement("div", {
@@ -54,6 +66,13 @@ var ImportedGisFilesPage = function ImportedGisFilesPage(_ref) {
54
66
  className: _styleModule.default.uploadButtonIcon,
55
67
  width: "14px",
56
68
  height: "16px"
69
+ })), enable_upload_sites && /*#__PURE__*/_react.default.createElement("div", {
70
+ className: _styleModule.default.uploadButtonWrapper,
71
+ onClick: uploadNewSitesHandler
72
+ }, /*#__PURE__*/_react.default.createElement("span", null, _i18n.default.t('importGisPage.upload_sites')), /*#__PURE__*/_react.default.createElement(_kandoStepper.UploadSvg, {
73
+ className: _styleModule.default.uploadButtonIcon,
74
+ width: "14px",
75
+ height: "16px"
57
76
  })), /*#__PURE__*/_react.default.createElement(_uiKit.KandoTable, {
58
77
  data: importedGisFilesTable.length ? importedGisFilesTable : defaultImportedGisFilesTable,
59
78
  columns: columns,
@@ -68,4 +87,4 @@ var ImportedGisFilesPage = function ImportedGisFilesPage(_ref) {
68
87
  };
69
88
  var _default = ImportedGisFilesPage;
70
89
  exports.default = _default;
71
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIl9yZWFjdFJlZHV4IiwiX3JlYWN0RGF0YVRhYmxlQ29tcG9uZW50IiwiX3N0eWxlTW9kdWxlIiwiX3VpS2l0IiwiX3JlYWN0Um91dGVyRG9tIiwiX2kxOG4iLCJfdXJscyIsIl9rYW5kb1N0ZXBwZXIiLCJJbXBvcnRlZEdpc0ZpbGVzUGFnZSIsIl9yZWYiLCJjb2x1bW5zIiwiaGFuZGxlU29ydCIsImhpc3RvcnkiLCJ1c2VIaXN0b3J5IiwiX3VzZVNlbGVjdG9yIiwidXNlU2VsZWN0b3IiLCJzdGF0ZSIsImdsb2JhbF9kYXRhIiwid2F0ZXJBdXRob3JpdHlJZCIsIndhdGVyQXV0aG9yaXR5TmFtZSIsIm5hdkNvbnRleHQiLCJuYXZfY29udGV4dF9kYXRhIiwiX3VzZVNlbGVjdG9yMiIsImltcG9ydEdpcyIsImltcG9ydGVkR2lzRmlsZXNUYWJsZSIsImlzRmV0Y2hpbmciLCJ1cGxvYWROZXdGaWxlSGFuZGxlciIsInVybCIsInVybHMiLCJsb2NhbCIsImxvY2FsZSIsImltcG9ydEdpc0ZpbGUiLCJpbXBvcnRHaXNQcm9jZXNzUGFnZSIsInB1c2giLCJkZWZhdWx0SW1wb3J0ZWRHaXNGaWxlc1RhYmxlIiwiZGF0ZSIsImkxOG4iLCJ0IiwiZGVmYXVsdCIsImNyZWF0ZUVsZW1lbnQiLCJjbGFzc05hbWUiLCJzdHlsZXMiLCJwYWdlTGF5b3V0IiwiUGFnZVRpdGxlIiwidXBsb2FkQnV0dG9uV3JhcHBlciIsIm9uQ2xpY2siLCJVcGxvYWRTdmciLCJ1cGxvYWRCdXR0b25JY29uIiwid2lkdGgiLCJoZWlnaHQiLCJLYW5kb1RhYmxlIiwiZGF0YSIsImxlbmd0aCIsImV4cGFuZGFibGVSb3dzIiwidG90YWxSb3dzIiwiaXNTb3J0U2VydmVyIiwicHJvZ3Jlc3NQZW5kaW5nIiwicGFnaW5hdGlvbiIsImRpcmVjdGlvbiIsIkRpcmVjdGlvbiIsIkxUUiIsIl9kZWZhdWx0IiwiZXhwb3J0cyJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9wYWdlcy9JbXBvcnRHaXNQYWdlL0ltcG9ydGVkR2lzRmlsZXNQYWdlLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgRkMgfSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyB1c2VTZWxlY3RvciB9IGZyb20gJ3JlYWN0LXJlZHV4JztcbmltcG9ydCB7IERpcmVjdGlvbiwgVGFibGVDb2x1bW4gfSBmcm9tICdyZWFjdC1kYXRhLXRhYmxlLWNvbXBvbmVudCc7XG5pbXBvcnQgeyBhcHBSZWR1Y2VyIH0gZnJvbSAnc3JjL3N0b3JlL3Jvb3RSZWR1Y2VyJztcbmltcG9ydCBzdHlsZXMgZnJvbSAnLi9zdHlsZS5tb2R1bGUuc2Nzcyc7XG5pbXBvcnQgeyBLYW5kb1RhYmxlIH0gZnJvbSAnc3JjL3VpLWtpdCc7XG5pbXBvcnQgeyBJbXBvcnRlZEdpc0ZpbGVzRGF0YSB9IGZyb20gJy4vaW1wb3J0R2lzVXRpbHMnO1xuaW1wb3J0IHsgdXNlSGlzdG9yeSB9IGZyb20gJ3JlYWN0LXJvdXRlci1kb20nO1xuaW1wb3J0IGkxOG4gZnJvbSAnc3JjL3V0aWxpdGllcy9pMThuJztcbmltcG9ydCB7IHVybHMgfSBmcm9tICdzcmMvdXRpbGl0aWVzL3VybHMnO1xuaW1wb3J0IHsgVXBsb2FkU3ZnIH0gZnJvbSAnc3JjL2Fzc2V0cy9pY29ucy9rYW5kb1N0ZXBwZXInO1xuXG5pbnRlcmZhY2UgaW1wb3J0R2lzUHJvcHMge1xuICBjb2x1bW5zOiBUYWJsZUNvbHVtbjxJbXBvcnRlZEdpc0ZpbGVzRGF0YT5bXTtcbiAgaGFuZGxlU29ydDogKFxuICAgIGNvbHVtbjogVGFibGVDb2x1bW48SW1wb3J0ZWRHaXNGaWxlc0RhdGE+LFxuICAgIHNvcnREaXJlY3Rpb246IHN0cmluZyxcbiAgKSA9PiB2b2lkO1xufVxuXG5jb25zdCBJbXBvcnRlZEdpc0ZpbGVzUGFnZTogRkM8aW1wb3J0R2lzUHJvcHM+ID0gKHsgY29sdW1ucywgaGFuZGxlU29ydCB9KSA9PiB7XG4gIGNvbnN0IGhpc3RvcnkgPSB1c2VIaXN0b3J5KCk7XG5cbiAgY29uc3QgeyB3YXRlckF1dGhvcml0eUlkLCB3YXRlckF1dGhvcml0eU5hbWUgfSA9IHVzZVNlbGVjdG9yKFxuICAgIChzdGF0ZTogUmV0dXJuVHlwZTx0eXBlb2YgYXBwUmVkdWNlcj4pID0+IHN0YXRlLmdsb2JhbF9kYXRhLFxuICApO1xuXG4gIGNvbnN0IG5hdkNvbnRleHQgPSB1c2VTZWxlY3RvcihcbiAgICAoc3RhdGU6IFJldHVyblR5cGU8dHlwZW9mIGFwcFJlZHVjZXI+KSA9PiBzdGF0ZS5uYXZfY29udGV4dF9kYXRhLm5hdkNvbnRleHQsXG4gICk7XG5cbiAgY29uc3QgeyBpbXBvcnRlZEdpc0ZpbGVzVGFibGUsIGlzRmV0Y2hpbmcgfSA9IHVzZVNlbGVjdG9yKFxuICAgIChzdGF0ZTogUmV0dXJuVHlwZTx0eXBlb2YgYXBwUmVkdWNlcj4pID0+IHN0YXRlLmltcG9ydEdpcyxcbiAgKTtcblxuICBjb25zdCB1cGxvYWROZXdGaWxlSGFuZGxlciA9ICgpID0+IHtcbiAgICBjb25zdCB1cmwgPSB1cmxzKHsgd2F0ZXJBdXRob3JpdHlJZCwgbG9jYWw6IG5hdkNvbnRleHQubG9jYWxlIH0pXG4gICAgICAuaW1wb3J0R2lzRmlsZS5pbXBvcnRHaXNQcm9jZXNzUGFnZS51cmw7XG4gICAgaGlzdG9yeS5wdXNoKHVybCk7XG4gIH07XG4gIGNvbnN0IGRlZmF1bHRJbXBvcnRlZEdpc0ZpbGVzVGFibGUgPSBbXG4gICAge1xuICAgICAgZGF0ZTogaTE4bi50KCdkYXRhdGFibGUubm9fZGF0YScpLFxuICAgIH0sXG4gIF07XG5cbiAgcmV0dXJuIChcbiAgICA8ZGl2IGNsYXNzTmFtZT17c3R5bGVzLnBhZ2VMYXlvdXR9PlxuICAgICAgPGRpdiBjbGFzc05hbWU9e3N0eWxlcy5QYWdlVGl0bGV9PlxuICAgICAgICB7aTE4bi50KCdpbXBvcnRHaXNQYWdlLnBhZ2VfdGl0bGUnLCB7IHdhdGVyQXV0aG9yaXR5TmFtZSB9KX1cbiAgICAgIDwvZGl2PlxuICAgICAgPGRpdlxuICAgICAgICBjbGFzc05hbWU9e3N0eWxlcy51cGxvYWRCdXR0b25XcmFwcGVyfVxuICAgICAgICBvbkNsaWNrPXt1cGxvYWROZXdGaWxlSGFuZGxlcn1cbiAgICAgID5cbiAgICAgICAgPHNwYW4+e2kxOG4udCgnaW1wb3J0R2lzUGFnZS51cGxvYWRfbmV3Jyl9PC9zcGFuPlxuICAgICAgICA8VXBsb2FkU3ZnXG4gICAgICAgICAgY2xhc3NOYW1lPXtzdHlsZXMudXBsb2FkQnV0dG9uSWNvbn1cbiAgICAgICAgICB3aWR0aD1cIjE0cHhcIlxuICAgICAgICAgIGhlaWdodD1cIjE2cHhcIlxuICAgICAgICAvPlxuICAgICAgPC9kaXY+XG4gICAgICA8S2FuZG9UYWJsZVxuICAgICAgICBkYXRhPXtcbiAgICAgICAgICBpbXBvcnRlZEdpc0ZpbGVzVGFibGUubGVuZ3RoXG4gICAgICAgICAgICA/IGltcG9ydGVkR2lzRmlsZXNUYWJsZVxuICAgICAgICAgICAgOiBkZWZhdWx0SW1wb3J0ZWRHaXNGaWxlc1RhYmxlXG4gICAgICAgIH1cbiAgICAgICAgY29sdW1ucz17Y29sdW1uc31cbiAgICAgICAgZXhwYW5kYWJsZVJvd3M9e2ZhbHNlfVxuICAgICAgICBoYW5kbGVTb3J0PXtoYW5kbGVTb3J0fVxuICAgICAgICB0b3RhbFJvd3M9e2ltcG9ydGVkR2lzRmlsZXNUYWJsZS5sZW5ndGh9XG4gICAgICAgIGlzU29ydFNlcnZlcj17ZmFsc2V9XG4gICAgICAgIHByb2dyZXNzUGVuZGluZz17aXNGZXRjaGluZ31cbiAgICAgICAgcGFnaW5hdGlvbj17ZmFsc2V9XG4gICAgICAgIGRpcmVjdGlvbj17RGlyZWN0aW9uLkxUUn1cbiAgICAgIC8+XG4gICAgPC9kaXY+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBJbXBvcnRlZEdpc0ZpbGVzUGFnZTtcbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUFBLElBQUFBLE1BQUEsR0FBQUMsc0JBQUEsQ0FBQUMsT0FBQTtBQUNB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
90
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_reactRedux","_reactDataTableComponent","_styleModule","_uiKit","_reactRouterDom","_i18n","_urls","_kandoStepper","ImportedGisFilesPage","_ref","columns","handleSort","history","useHistory","_useSelector","useSelector","state","global_data","waterAuthorityId","waterAuthorityName","navContext","nav_context_data","_useSelector2","importGis","importedGisFilesTable","isFetching","uploadNewFileHandler","url","urls","local","locale","importGisFile","importGisProcessPage","push","uploadNewSitesHandler","importSiteFile","importSiteProcessPage","defaultImportedGisFilesTable","date","i18n","t","_useSelector3","_ref2","permissions","enable_upload_sites","default","createElement","className","styles","pageLayout","PageTitle","uploadButtonWrapper","onClick","UploadSvg","uploadButtonIcon","width","height","KandoTable","data","length","expandableRows","totalRows","isSortServer","progressPending","pagination","direction","Direction","LTR","_default","exports"],"sources":["../../../src/pages/ImportGisPage/ImportedGisFilesPage.tsx"],"sourcesContent":["import React, { FC } from 'react';\nimport { useSelector } from 'react-redux';\nimport { Direction, TableColumn } from 'react-data-table-component';\nimport { appReducer } from 'src/store/rootReducer';\nimport styles from './style.module.scss';\nimport { KandoTable } from 'src/ui-kit';\nimport { ImportedGisFilesData } from './importGisUtils';\nimport { useHistory } from 'react-router-dom';\nimport i18n from 'src/utilities/i18n';\nimport { urls } from 'src/utilities/urls';\nimport { UploadSvg } from 'src/assets/icons/kandoStepper';\n\ninterface importGisProps {\n  columns: TableColumn<ImportedGisFilesData>[];\n  handleSort: (\n    column: TableColumn<ImportedGisFilesData>,\n    sortDirection: string,\n  ) => void;\n}\n\nconst ImportedGisFilesPage: FC<importGisProps> = ({ columns, handleSort }) => {\n  const history = useHistory();\n\n  const { waterAuthorityId, waterAuthorityName } = useSelector(\n    (state: ReturnType<typeof appReducer>) => state.global_data,\n  );\n\n  const navContext = useSelector(\n    (state: ReturnType<typeof appReducer>) => state.nav_context_data.navContext,\n  );\n\n  const { importedGisFilesTable, isFetching } = useSelector(\n    (state: ReturnType<typeof appReducer>) => state.importGis,\n  );\n\n  const uploadNewFileHandler = () => {\n    const url = urls({ waterAuthorityId, local: navContext.locale })\n      .importGisFile.importGisProcessPage.url;\n    history.push(url);\n  };\n\n  const uploadNewSitesHandler = () => {\n    const url = urls({ waterAuthorityId, local: navContext.locale })\n      .importSiteFile.importSiteProcessPage.url;\n    history.push(url);\n  };\n  const defaultImportedGisFilesTable = [\n    {\n      date: i18n.t('datatable.no_data'),\n    },\n  ];\n  const { enable_upload_sites } = useSelector(({ permissions }) => permissions);\n  return (\n    <div className={styles.pageLayout}>\n      <div className={styles.PageTitle}>\n        {i18n.t('importGisPage.page_title', { waterAuthorityName })}\n      </div>\n      <div\n        className={styles.uploadButtonWrapper}\n        onClick={uploadNewFileHandler}\n      >\n        <span>{i18n.t('importGisPage.upload_new')}</span>\n        <UploadSvg\n          className={styles.uploadButtonIcon}\n          width=\"14px\"\n          height=\"16px\"\n        />\n      </div>\n      {enable_upload_sites && (\n        <div\n          className={styles.uploadButtonWrapper}\n          onClick={uploadNewSitesHandler}\n        >\n          <span>{i18n.t('importGisPage.upload_sites')}</span>\n          <UploadSvg\n            className={styles.uploadButtonIcon}\n            width=\"14px\"\n            height=\"16px\"\n          />\n        </div>\n      )}\n      <KandoTable\n        data={\n          importedGisFilesTable.length\n            ? importedGisFilesTable\n            : defaultImportedGisFilesTable\n        }\n        columns={columns}\n        expandableRows={false}\n        handleSort={handleSort}\n        totalRows={importedGisFilesTable.length}\n        isSortServer={false}\n        progressPending={isFetching}\n        pagination={false}\n        direction={Direction.LTR}\n      />\n    </div>\n  );\n};\n\nexport default ImportedGisFilesPage;\n"],"mappings":"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"}
@@ -9,6 +9,8 @@ var _react = _interopRequireDefault(require("react"));
9
9
  var _i18n = _interopRequireDefault(require("utilities/i18n"));
10
10
  var _styleModule = _interopRequireDefault(require("./style.module.scss"));
11
11
  var _File = require("utilities/File");
12
+ var _reactI18next = require("react-i18next");
13
+ var _StyledLink = require("components/Links/StyledLink/StyledLink");
12
14
  var fileStatus;
13
15
  exports.fileStatus = fileStatus;
14
16
  (function (fileStatus) {
@@ -76,8 +78,25 @@ var getColumns = function getColumns() {
76
78
  }
77
79
  }, (_row$file2 = row.file) === null || _row$file2 === void 0 ? void 0 : _row$file2.filename);
78
80
  }
81
+ }, {
82
+ name: _i18n.default.t('importGisPage.table_cols.details'),
83
+ selector: function selector(row) {
84
+ return row.has_groups ? 'map' : '';
85
+ },
86
+ sortable: false,
87
+ width: '80px',
88
+ cell: function cell(_ref) {
89
+ var has_groups = _ref.has_groups,
90
+ id = _ref.id;
91
+ return has_groups && /*#__PURE__*/_react.default.createElement(_StyledLink.Link, {
92
+ to: "/import_sites/".concat(id),
93
+ className: _styleModule.default.link
94
+ }, /*#__PURE__*/_react.default.createElement(_reactI18next.Trans, {
95
+ i18nKey: "importGisPage.details"
96
+ }));
97
+ }
79
98
  }];
80
99
  return tableColumns;
81
100
  };
82
101
  exports.getColumns = getColumns;
83
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIl9pMThuIiwiX3N0eWxlTW9kdWxlIiwiX0ZpbGUiLCJmaWxlU3RhdHVzIiwiZXhwb3J0cyIsImdldENvbHVtbnMiLCJ0YWJsZUNvbHVtbnMiLCJuYW1lIiwiaTE4biIsInQiLCJzZWxlY3RvciIsInJvdyIsImRhdGUiLCJzb3J0YWJsZSIsInNvcnRGaWVsZCIsInVzZXIiLCJ0aXRsZSIsInN0YXR1cyIsIndpZHRoIiwiY2VsbCIsImRlZmF1bHQiLCJjcmVhdGVFbGVtZW50IiwiY2xhc3NOYW1lIiwic3R5bGVzIiwiY29uY2F0IiwiX3JvdyRmaWxlIiwiZmlsZSIsImZpbGVuYW1lIiwiX3JvdyRmaWxlMiIsImxpbmsiLCJvbkNsaWNrIiwiZ2V0R2VvSnNvbkRhdGFGcm9tVXJsIiwidXJsIiwiZmlsZU5hbWUiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvcGFnZXMvSW1wb3J0R2lzUGFnZS9pbXBvcnRHaXNVdGlscy50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcbmltcG9ydCBpMThuIGZyb20gJ3NyYy91dGlsaXRpZXMvaTE4bic7XG5pbXBvcnQgeyBUYWJsZUNvbHVtbiB9IGZyb20gJ3JlYWN0LWRhdGEtdGFibGUtY29tcG9uZW50JztcbmltcG9ydCBzdHlsZXMgZnJvbSAnLi9zdHlsZS5tb2R1bGUuc2Nzcyc7XG5pbXBvcnQgeyBnZXRHZW9Kc29uRGF0YUZyb21VcmwgfSBmcm9tICdzcmMvdXRpbGl0aWVzL0ZpbGUnO1xuXG5leHBvcnQgZW51bSBmaWxlU3RhdHVzIHtcbiAgaW5fcHJvZ3Jlc3MgPSAwLFxuICBzdWNjZXNzID0gMSxcbiAgZmFpbGVkID0gMixcbn1cbmV4cG9ydCBpbnRlcmZhY2UgSW1wb3J0ZWRGaWxlIHtcbiAgZmlsZW5hbWU6IHN0cmluZztcbiAgdXJsOiBzdHJpbmc7XG59XG5leHBvcnQgaW50ZXJmYWNlIEltcG9ydGVkR2lzRmlsZXNEYXRhIHtcbiAgdGl0bGU/OiBzdHJpbmc7XG4gIGRhdGU6IHN0cmluZztcbiAgdXNlcj86IHN0cmluZztcbiAgc3RhdHVzPzogc3RyaW5nO1xuICBmaWxlPzogSW1wb3J0ZWRGaWxlO1xufVxuZXhwb3J0IGNvbnN0IGdldENvbHVtbnMgPSAoKSA9PiB7XG4gIGNvbnN0IHRhYmxlQ29sdW1uczogVGFibGVDb2x1bW48SW1wb3J0ZWRHaXNGaWxlc0RhdGE+W10gPSBbXG4gICAge1xuICAgICAgbmFtZTogaTE4bi50KCdpbXBvcnRHaXNQYWdlLnRhYmxlX2NvbHMuZGF0ZScpLFxuICAgICAgc2VsZWN0b3I6IChyb3cpID0+IHJvdy5kYXRlLFxuICAgICAgc29ydGFibGU6IHRydWUsXG4gICAgICBzb3J0RmllbGQ6ICdkYXRlJyxcbiAgICB9LFxuICAgIHtcbiAgICAgIG5hbWU6IGkxOG4udCgnaW1wb3J0R2lzUGFnZS50YWJsZV9jb2xzLnVzZXInKSxcbiAgICAgIHNlbGVjdG9yOiAocm93KSA9PiByb3cudXNlciB8fCAnJyxcbiAgICAgIHNvcnRhYmxlOiB0cnVlLFxuICAgICAgc29ydEZpZWxkOiAndXNlcicsXG4gICAgfSxcbiAgICB7XG4gICAgICBuYW1lOiBpMThuLnQoJ2ltcG9ydEdpc1BhZ2UudGFibGVfY29scy50aXRsZScpLFxuICAgICAgc2VsZWN0b3I6IChyb3cpID0+IHJvdy50aXRsZSB8fCAnJyxcbiAgICAgIHNvcnRhYmxlOiB0cnVlLFxuICAgICAgc29ydEZpZWxkOiAndGl0bGUnLFxuICAgIH0sXG4gICAge1xuICAgICAgbmFtZTogaTE4bi50KCdpbXBvcnRHaXNQYWdlLnRhYmxlX2NvbHMuc3RhdHVzJyksXG4gICAgICBzZWxlY3RvcjogKHJvdykgPT4gcm93LnN0YXR1cyB8fCAnJyxcbiAgICAgIHNvcnRhYmxlOiB0cnVlLFxuICAgICAgc29ydEZpZWxkOiAnc3RhdHVzJyxcbiAgICAgIHdpZHRoOiAnMTIwcHgnLFxuICAgICAgY2VsbDogKHJvdzogeyBzdGF0dXM/OiBzdHJpbmcgfSkgPT4ge1xuICAgICAgICByZXR1cm4gKFxuICAgICAgICAgIDxkaXYgY2xhc3NOYW1lPXtyb3cuc3RhdHVzID8gc3R5bGVzW3Jvdy5zdGF0dXNdIDogJyd9PlxuICAgICAgICAgICAge3Jvdy5zdGF0dXNcbiAgICAgICAgICAgICAgPyBpMThuLnQoYGltcG9ydEdpc1BhZ2UuZmlsZV9zdGF0dXMuJHtmaWxlU3RhdHVzW3Jvdy5zdGF0dXNdfWApXG4gICAgICAgICAgICAgIDogJyd9XG4gICAgICAgICAgPC9kaXY+XG4gICAgICAgICk7XG4gICAgICB9LFxuICAgIH0sXG4gICAge1xuICAgICAgbmFtZTogaTE4bi50KCdpbXBvcnRHaXNQYWdlLnRhYmxlX2NvbHMuZmlsZScpLFxuICAgICAgc2VsZWN0b3I6IChyb3cpID0+IHJvdy5maWxlPy5maWxlbmFtZSB8fCAnJyxcbiAgICAgIHNvcnRhYmxlOiB0cnVlLFxuICAgICAgc29ydEZpZWxkOiAnZmlsZW5hbWUnLFxuICAgICAgd2lkdGg6ICcyNTBweCcsXG4gICAgICBjZWxsOiAocm93OiB7IGZpbGU/OiBJbXBvcnRlZEZpbGUgfSkgPT4ge1xuICAgICAgICByZXR1cm4gKFxuICAgICAgICAgIDxhXG4gICAgICAgICAgICBjbGFzc05hbWU9e3N0eWxlcy5saW5rfVxuICAgICAgICAgICAgdGl0bGU9e2kxOG4udCgnaW1wb3J0R2lzUGFnZS5kb3dubG9hZCcpfVxuICAgICAgICAgICAgb25DbGljaz17KCkgPT4ge1xuICAgICAgICAgICAgICBpZiAocm93LmZpbGUpIHtcbiAgICAgICAgICAgICAgICByZXR1cm4gZ2V0R2VvSnNvbkRhdGFGcm9tVXJsKHtcbiAgICAgICAgICAgICAgICAgIHVybDogcm93LmZpbGUudXJsLFxuICAgICAgICAgICAgICAgICAgZmlsZU5hbWU6IHJvdy5maWxlLmZpbGVuYW1lLFxuICAgICAgICAgICAgICAgIH0pO1xuICAgICAgICAgICAgICB9XG4gICAgICAgICAgICAgIHJldHVybjtcbiAgICAgICAgICAgIH19XG4gICAgICAgICAgPlxuICAgICAgICAgICAge3Jvdy5maWxlPy5maWxlbmFtZX1cbiAgICAgICAgICA8L2E+XG4gICAgICAgICk7XG4gICAgICB9LFxuICAgIH0sXG4gIF07XG5cbiAgcmV0dXJuIHRhYmxlQ29sdW1ucztcbn07XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFBQSxJQUFBQSxNQUFBLEdBQUFDLHNCQUFBLENBQUFDLE9BQUE7QUFDQSxJQUFBQyxLQUFBLEdBQUFGLHNCQUFBLENBQUFDLE9BQUE7QUFFQSxJQUFBRSxZQUFBLEdBQUFILHNCQUFBLENBQUFDLE9BQUE7QUFDQSxJQUFBRyxLQUFBLEdBQUFILE9BQUE7QUFBMkQsSUFFL0NJLFVBQVU7QUFBQUMsT0FBQSxDQUFBRCxVQUFBLEdBQUFBLFVBQUE7QUFBQSxXQUFWQSxVQUFVO0VBQVZBLFVBQVUsQ0FBVkEsVUFBVTtFQUFWQSxVQUFVLENBQVZBLFVBQVU7RUFBVkEsVUFBVSxDQUFWQSxVQUFVO0FBQUEsR0FBVkEsVUFBVSxLQUFBQyxPQUFBLENBQUFELFVBQUEsR0FBVkEsVUFBVTtBQWdCZixJQUFNRSxVQUFVLEdBQUcsU0FBYkEsVUFBVUEsQ0FBQSxFQUFTO0VBQzlCLElBQU1DLFlBQWlELEdBQUcsQ0FDeEQ7SUFDRUMsSUFBSSxFQUFFQyxhQUFJLENBQUNDLENBQUMsQ0FBQywrQkFBK0IsQ0FBQztJQUM3Q0MsUUFBUSxFQUFFLFNBQUFBLFNBQUNDLEdBQUc7TUFBQSxPQUFLQSxHQUFHLENBQUNDLElBQUk7SUFBQTtJQUMzQkMsUUFBUSxFQUFFLElBQUk7SUFDZEMsU0FBUyxFQUFFO0VBQ2IsQ0FBQyxFQUNEO0lBQ0VQLElBQUksRUFBRUMsYUFBSSxDQUFDQyxDQUFDLENBQUMsK0JBQStCLENBQUM7SUFDN0NDLFFBQVEsRUFBRSxTQUFBQSxTQUFDQyxHQUFHO01BQUEsT0FBS0EsR0FBRyxDQUFDSSxJQUFJLElBQUksRUFBRTtJQUFBO0lBQ2pDRixRQUFRLEVBQUUsSUFBSTtJQUNkQyxTQUFTLEVBQUU7RUFD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
102
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_i18n","_styleModule","_File","_reactI18next","_StyledLink","fileStatus","exports","getColumns","tableColumns","name","i18n","t","selector","row","date","sortable","sortField","user","title","status","width","cell","default","createElement","className","styles","concat","_row$file","file","filename","_row$file2","link","onClick","getGeoJsonDataFromUrl","url","fileName","has_groups","_ref","id","Link","to","Trans","i18nKey"],"sources":["../../../src/pages/ImportGisPage/importGisUtils.tsx"],"sourcesContent":["import React from 'react';\nimport i18n from 'src/utilities/i18n';\nimport { TableColumn } from 'react-data-table-component';\nimport styles from './style.module.scss';\nimport { getGeoJsonDataFromUrl } from 'src/utilities/File';\nimport { Trans } from 'react-i18next';\nimport { Link } from 'src/components/Links/StyledLink/StyledLink';\n\nexport enum fileStatus {\n  in_progress = 0,\n  success = 1,\n  failed = 2,\n}\nexport interface ImportedFile {\n  filename: string;\n  url: string;\n}\nexport interface ImportedGisFilesData {\n  id: string;\n  title?: string;\n  date: string;\n  has_groups: boolean;\n  user?: string;\n  status?: string;\n  file?: ImportedFile;\n}\nexport const getColumns = () => {\n  const tableColumns: TableColumn<ImportedGisFilesData>[] = [\n    {\n      name: i18n.t('importGisPage.table_cols.date'),\n      selector: (row) => row.date,\n      sortable: true,\n      sortField: 'date',\n    },\n    {\n      name: i18n.t('importGisPage.table_cols.user'),\n      selector: (row) => row.user || '',\n      sortable: true,\n      sortField: 'user',\n    },\n    {\n      name: i18n.t('importGisPage.table_cols.title'),\n      selector: (row) => row.title || '',\n      sortable: true,\n      sortField: 'title',\n    },\n    {\n      name: i18n.t('importGisPage.table_cols.status'),\n      selector: (row) => row.status || '',\n      sortable: true,\n      sortField: 'status',\n      width: '120px',\n      cell: (row: { status?: string }) => {\n        return (\n          <div className={row.status ? styles[row.status] : ''}>\n            {row.status\n              ? i18n.t(`importGisPage.file_status.${fileStatus[row.status]}`)\n              : ''}\n          </div>\n        );\n      },\n    },\n    {\n      name: i18n.t('importGisPage.table_cols.file'),\n      selector: (row) => row.file?.filename || '',\n      sortable: true,\n      sortField: 'filename',\n      width: '250px',\n      cell: (row: { file?: ImportedFile }) => {\n        return (\n          <a\n            className={styles.link}\n            title={i18n.t('importGisPage.download')}\n            onClick={() => {\n              if (row.file) {\n                return getGeoJsonDataFromUrl({\n                  url: row.file.url,\n                  fileName: row.file.filename,\n                });\n              }\n              return;\n            }}\n          >\n            {row.file?.filename}\n          </a>\n        );\n      },\n    },\n    {\n      name: i18n.t('importGisPage.table_cols.details'),\n      selector: (row) => (row.has_groups ? 'map' : ''),\n      sortable: false,\n      width: '80px',\n      cell: ({ has_groups, id }) => {\n        return (\n          has_groups && (\n            <Link to={`/import_sites/${id}`} className={styles.link}>\n              <Trans i18nKey=\"importGisPage.details\" />\n            </Link>\n          )\n        );\n      },\n    },\n  ];\n\n  return tableColumns;\n};\n"],"mappings":"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"}
@@ -0,0 +1,55 @@
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 _ImportFileWizard = _interopRequireDefault(require("pages/ImportFileWizard"));
9
+ var _urls = require("utilities/urls");
10
+ var _reactRedux = require("react-redux");
11
+ var _react = _interopRequireDefault(require("react"));
12
+ var _uiKit = require("ui-kit");
13
+ var _i18n = _interopRequireDefault(require("utilities/i18n"));
14
+ var _actionsCreator = require("store/ImportGis/actionsCreator");
15
+ var _reactBootstrap = require("react-bootstrap");
16
+ var ImportSiteProcess = function ImportSiteProcess() {
17
+ var dispatch = (0, _reactRedux.useDispatch)();
18
+ var waterAuthorityId = (0, _reactRedux.useSelector)(function (state) {
19
+ return state.global_data.waterAuthorityId;
20
+ });
21
+ var _useSelector = (0, _reactRedux.useSelector)(function (state) {
22
+ return state.importGis;
23
+ }),
24
+ uploadingFile = _useSelector.uploadingFile;
25
+ var submitURL = (0, _urls.urls)({
26
+ waterAuthorityId: waterAuthorityId
27
+ }).importSiteFile.newFile.url;
28
+ var validationURL = (0, _urls.urls)({
29
+ waterAuthorityId: waterAuthorityId
30
+ }).importSiteFile.validateFile.url;
31
+ var fileTitleChangedHandler = function fileTitleChangedHandler(event) {
32
+ dispatch((0, _actionsCreator.setFileTitle)(event.target.value));
33
+ };
34
+ return /*#__PURE__*/_react.default.createElement(_ImportFileWizard.default, {
35
+ acceptType: 'csv',
36
+ title: 'import_site_process.title',
37
+ navContext: 'import_site_process',
38
+ validationURL: validationURL,
39
+ submitURL: submitURL
40
+ }, /*#__PURE__*/_react.default.createElement(_reactBootstrap.Alert, {
41
+ variant: "info"
42
+ }, /*#__PURE__*/_react.default.createElement("h4", null, 'Upload a csv file with the following columns'), /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement("b", null, 'Mandatory fields: '), 'site_name, address(location)'), /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement("b", null, 'Optional fields: '), /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("u", null, 'For sector:'), /*#__PURE__*/_react.default.createElement("br", null), '1. activity - factory activity', /*#__PURE__*/_react.default.createElement("br", null), '2. nace - nace code', /*#__PURE__*/_react.default.createElement("br", null), '3. naics - naics code', /*#__PURE__*/_react.default.createElement("br", null), '4. sic - SIC code', /*#__PURE__*/_react.default.createElement("br", null), '5. Sector - for the exact kando sector name', /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("u", null, 'Extra data:'), /*#__PURE__*/_react.default.createElement("br", null), 'water_consumption, water_discharge, type(WWTP, Factory, Pipe, Collectors, PumpStation, WaterLevel)')), /*#__PURE__*/_react.default.createElement(_uiKit.MobileInput, {
43
+ isInvalid: false,
44
+ handleChange: fileTitleChangedHandler,
45
+ inputTitle: _i18n.default.t('import_gis_process.title_input_label'),
46
+ placeholder: _i18n.default.t('import_gis_process.title_input_placeholder'),
47
+ value: uploadingFile.fileTitle,
48
+ type: "text",
49
+ name: "fileTitle",
50
+ mandatory: true
51
+ }));
52
+ };
53
+ var _default = ImportSiteProcess;
54
+ exports.default = _default;
55
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfSW1wb3J0RmlsZVdpemFyZCIsIl9pbnRlcm9wUmVxdWlyZURlZmF1bHQiLCJyZXF1aXJlIiwiX3VybHMiLCJfcmVhY3RSZWR1eCIsIl9yZWFjdCIsIl91aUtpdCIsIl9pMThuIiwiX2FjdGlvbnNDcmVhdG9yIiwiX3JlYWN0Qm9vdHN0cmFwIiwiSW1wb3J0U2l0ZVByb2Nlc3MiLCJkaXNwYXRjaCIsInVzZURpc3BhdGNoIiwid2F0ZXJBdXRob3JpdHlJZCIsInVzZVNlbGVjdG9yIiwic3RhdGUiLCJnbG9iYWxfZGF0YSIsIl91c2VTZWxlY3RvciIsImltcG9ydEdpcyIsInVwbG9hZGluZ0ZpbGUiLCJzdWJtaXRVUkwiLCJ1cmxzIiwiaW1wb3J0U2l0ZUZpbGUiLCJuZXdGaWxlIiwidXJsIiwidmFsaWRhdGlvblVSTCIsInZhbGlkYXRlRmlsZSIsImZpbGVUaXRsZUNoYW5nZWRIYW5kbGVyIiwiZXZlbnQiLCJzZXRGaWxlVGl0bGUiLCJ0YXJnZXQiLCJ2YWx1ZSIsImRlZmF1bHQiLCJjcmVhdGVFbGVtZW50IiwiYWNjZXB0VHlwZSIsInRpdGxlIiwibmF2Q29udGV4dCIsIkFsZXJ0IiwidmFyaWFudCIsIk1vYmlsZUlucHV0IiwiaXNJbnZhbGlkIiwiaGFuZGxlQ2hhbmdlIiwiaW5wdXRUaXRsZSIsImkxOG4iLCJ0IiwicGxhY2Vob2xkZXIiLCJmaWxlVGl0bGUiLCJ0eXBlIiwibmFtZSIsIm1hbmRhdG9yeSIsIl9kZWZhdWx0IiwiZXhwb3J0cyJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9wYWdlcy9JbXBvcnRTaXRlUHJvY2Vzcy9pbmRleC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IEltcG9ydEZpbGUgZnJvbSAnc3JjL3BhZ2VzL0ltcG9ydEZpbGVXaXphcmQnO1xuaW1wb3J0IHsgdXJscyB9IGZyb20gJ3NyYy91dGlsaXRpZXMvdXJscyc7XG5pbXBvcnQgeyB1c2VEaXNwYXRjaCwgdXNlU2VsZWN0b3IgfSBmcm9tICdyZWFjdC1yZWR1eCc7XG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuaW1wb3J0IHsgTW9iaWxlSW5wdXQgfSBmcm9tICdzcmMvdWkta2l0JztcbmltcG9ydCBpMThuIGZyb20gJ3NyYy91dGlsaXRpZXMvaTE4bic7XG5pbXBvcnQgeyBzZXRGaWxlVGl0bGUgfSBmcm9tICdzcmMvc3RvcmUvSW1wb3J0R2lzL2FjdGlvbnNDcmVhdG9yJztcbmltcG9ydCB7IGFwcFJlZHVjZXIgfSBmcm9tICdzcmMvc3RvcmUvcm9vdFJlZHVjZXInO1xuaW1wb3J0IHsgQWxlcnQgfSBmcm9tICdyZWFjdC1ib290c3RyYXAnO1xuXG5jb25zdCBJbXBvcnRTaXRlUHJvY2VzcyA9ICgpID0+IHtcbiAgY29uc3QgZGlzcGF0Y2ggPSB1c2VEaXNwYXRjaCgpO1xuICBjb25zdCB3YXRlckF1dGhvcml0eUlkID0gdXNlU2VsZWN0b3IoXG4gICAgKHN0YXRlKSA9PiBzdGF0ZS5nbG9iYWxfZGF0YS53YXRlckF1dGhvcml0eUlkLFxuICApO1xuICBjb25zdCB7IHVwbG9hZGluZ0ZpbGUgfSA9IHVzZVNlbGVjdG9yKFxuICAgIChzdGF0ZTogUmV0dXJuVHlwZTx0eXBlb2YgYXBwUmVkdWNlcj4pID0+IHN0YXRlLmltcG9ydEdpcyxcbiAgKTtcbiAgY29uc3Qgc3VibWl0VVJMID0gdXJscyh7IHdhdGVyQXV0aG9yaXR5SWQgfSkuaW1wb3J0U2l0ZUZpbGUubmV3RmlsZS51cmw7XG4gIGNvbnN0IHZhbGlkYXRpb25VUkwgPSB1cmxzKHsgd2F0ZXJBdXRob3JpdHlJZCB9KS5pbXBvcnRTaXRlRmlsZS52YWxpZGF0ZUZpbGVcbiAgICAudXJsO1xuICBjb25zdCBmaWxlVGl0bGVDaGFuZ2VkSGFuZGxlciA9IChldmVudCkgPT4ge1xuICAgIGRpc3BhdGNoKHNldEZpbGVUaXRsZShldmVudC50YXJnZXQudmFsdWUpKTtcbiAgfTtcbiAgcmV0dXJuIChcbiAgICA8SW1wb3J0RmlsZVxuICAgICAgYWNjZXB0VHlwZT17J2Nzdid9XG4gICAgICB0aXRsZT17J2ltcG9ydF9zaXRlX3Byb2Nlc3MudGl0bGUnfVxuICAgICAgbmF2Q29udGV4dD17J2ltcG9ydF9zaXRlX3Byb2Nlc3MnfVxuICAgICAgdmFsaWRhdGlvblVSTD17dmFsaWRhdGlvblVSTH1cbiAgICAgIHN1Ym1pdFVSTD17c3VibWl0VVJMfVxuICAgID5cbiAgICAgIDxBbGVydCB2YXJpYW50PVwiaW5mb1wiPlxuICAgICAgICA8aDQ+eydVcGxvYWQgYSBjc3YgZmlsZSB3aXRoIHRoZSBmb2xsb3dpbmcgY29sdW1ucyd9PC9oND5cbiAgICAgICAgPGRpdj5cbiAgICAgICAgICA8Yj57J01hbmRhdG9yeSBmaWVsZHM6ICd9PC9iPlxuICAgICAgICAgIHsnc2l0ZV9uYW1lLCBhZGRyZXNzKGxvY2F0aW9uKSd9XG4gICAgICAgIDwvZGl2PlxuICAgICAgICA8ZGl2PlxuICAgICAgICAgIDxiPnsnT3B0aW9uYWwgZmllbGRzOiAnfTwvYj5cbiAgICAgICAgICA8YnIgLz5cbiAgICAgICAgICA8dT57J0ZvciBzZWN0b3I6J308L3U+XG4gICAgICAgICAgPGJyIC8+XG4gICAgICAgICAgeycxLiBhY3Rpdml0eSAtIGZhY3RvcnkgYWN0aXZpdHknfVxuICAgICAgICAgIDxiciAvPlxuICAgICAgICAgIHsnMi4gbmFjZSAtIG5hY2UgY29kZSd9XG4gICAgICAgICAgPGJyIC8+XG4gICAgICAgICAgeyczLiBuYWljcyAtIG5haWNzIGNvZGUnfVxuICAgICAgICAgIDxiciAvPlxuICAgICAgICAgIHsnNC4gc2ljIC0gU0lDIGNvZGUnfVxuICAgICAgICAgIDxiciAvPlxuICAgICAgICAgIHsnNS4gU2VjdG9yIC0gZm9yIHRoZSBleGFjdCBrYW5kbyBzZWN0b3IgbmFtZSd9XG4gICAgICAgICAgPGJyIC8+XG4gICAgICAgICAgPHU+eydFeHRyYSBkYXRhOid9PC91PlxuICAgICAgICAgIDxiciAvPlxuICAgICAgICAgIHtcbiAgICAgICAgICAgICd3YXRlcl9jb25zdW1wdGlvbiwgd2F0ZXJfZGlzY2hhcmdlLCB0eXBlKFdXVFAsIEZhY3RvcnksIFBpcGUsIENvbGxlY3RvcnMsIFB1bXBTdGF0aW9uLCBXYXRlckxldmVsKSdcbiAgICAgICAgICB9XG4gICAgICAgIDwvZGl2PlxuICAgICAgPC9BbGVydD5cbiAgICAgIDxNb2JpbGVJbnB1dFxuICAgICAgICBpc0ludmFsaWQ9e2ZhbHNlfVxuICAgICAgICBoYW5kbGVDaGFuZ2U9e2ZpbGVUaXRsZUNoYW5nZWRIYW5kbGVyfVxuICAgICAgICBpbnB1dFRpdGxlPXtpMThuLnQoJ2ltcG9ydF9naXNfcHJvY2Vzcy50aXRsZV9pbnB1dF9sYWJlbCcpfVxuICAgICAgICBwbGFjZWhvbGRlcj17aTE4bi50KCdpbXBvcnRfZ2lzX3Byb2Nlc3MudGl0bGVfaW5wdXRfcGxhY2Vob2xkZXInKX1cbiAgICAgICAgdmFsdWU9e3VwbG9hZGluZ0ZpbGUuZmlsZVRpdGxlfVxuICAgICAgICB0eXBlPVwidGV4dFwiXG4gICAgICAgIG5hbWU9XCJmaWxlVGl0bGVcIlxuICAgICAgICBtYW5kYXRvcnk9e3RydWV9XG4gICAgICAvPlxuICAgIDwvSW1wb3J0RmlsZT5cbiAgKTtcbn07XG5cbmV4cG9ydCBkZWZhdWx0IEltcG9ydFNpdGVQcm9jZXNzO1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQUEsSUFBQUEsaUJBQUEsR0FBQUMsc0JBQUEsQ0FBQUMsT0FBQTtBQUNBLElBQUFDLEtBQUEsR0FBQUQsT0FBQTtBQUNBLElBQUFFLFdBQUEsR0FBQUYsT0FBQTtBQUNBLElBQUFHLE1BQUEsR0FBQUosc0JBQUEsQ0FBQUMsT0FBQTtBQUNBLElBQUFJLE1BQUEsR0FBQUosT0FBQTtBQUNBLElBQUFLLEtBQUEsR0FBQU4sc0JBQUEsQ0FBQUMsT0FBQTtBQUNBLElBQUFNLGVBQUEsR0FBQU4sT0FBQTtBQUVBLElBQUFPLGVBQUEsR0FBQVAsT0FBQTtBQUVBLElBQU1RLGlCQUFpQixHQUFHLFNBQXBCQSxpQkFBaUJBLENBQUEsRUFBUztFQUM5QixJQUFNQyxRQUFRLEdBQUcsSUFBQUMsdUJBQVcs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
@@ -18,7 +18,10 @@ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj &&
18
18
  var LeftPanel = function LeftPanel(_ref) {
19
19
  var points = _ref.points,
20
20
  selectedPoint = _ref.selectedPoint,
21
- setSelectedPoint = _ref.setSelectedPoint;
21
+ setSelectedPoint = _ref.setSelectedPoint,
22
+ _ref$onlyMonitored = _ref.onlyMonitored,
23
+ onlyMonitored = _ref$onlyMonitored === void 0 ? true : _ref$onlyMonitored,
24
+ filterOptions = _ref.filterOptions;
22
25
  var _useState = (0, _react.useState)([]),
23
26
  _useState2 = (0, _slicedToArray2.default)(_useState, 2),
24
27
  selectedFilters = _useState2[0],
@@ -50,22 +53,6 @@ var LeftPanel = function LeftPanel(_ref) {
50
53
  var sortedPoints = points.sort(function (a, b) {
51
54
  return b.issues.length - a.issues.length;
52
55
  });
53
- var filterOptions = [{
54
- value: 'installation_height',
55
- label: 'Installation Height'
56
- }, {
57
- value: 'distance',
58
- label: 'Distance'
59
- }, {
60
- value: 'no_parent',
61
- label: 'No Parent'
62
- }, {
63
- value: 'diameter',
64
- label: 'Diameter'
65
- }, {
66
- value: 'water_consumption',
67
- label: 'Water Consumption'
68
- }];
69
56
  (0, _react.useEffect)(function () {
70
57
  setFilteredPoints(sortedPoints);
71
58
  }, [sortedPoints]);
@@ -85,7 +72,7 @@ var LeftPanel = function LeftPanel(_ref) {
85
72
  }, [selectedFilters]);
86
73
  return /*#__PURE__*/_react.default.createElement(_reactBootstrap.Container, {
87
74
  className: "mt-4 pl-3 pr-2"
88
- }, /*#__PURE__*/_react.default.createElement(_reactBootstrap.Row, null, /*#__PURE__*/_react.default.createElement(_reactBootstrap.Col, null, /*#__PURE__*/_react.default.createElement("h4", null, "Monitored Manholes(".concat(filteredPoints.length, ")")))), /*#__PURE__*/_react.default.createElement(_reactBootstrap.Row, {
75
+ }, /*#__PURE__*/_react.default.createElement(_reactBootstrap.Row, null, /*#__PURE__*/_react.default.createElement(_reactBootstrap.Col, null, /*#__PURE__*/_react.default.createElement("h4", null, "".concat(onlyMonitored ? 'Monitored ' : '', "Manholes(").concat(filteredPoints.length, ")")))), /*#__PURE__*/_react.default.createElement(_reactBootstrap.Row, {
89
76
  className: "mt-3 mb-3"
90
77
  }, /*#__PURE__*/_react.default.createElement(_reactBootstrap.Col, null, /*#__PURE__*/_react.default.createElement(_KandoFilter.default, {
91
78
  filterOptions: filterOptions,
@@ -112,4 +99,4 @@ var LeftPanel = function LeftPanel(_ref) {
112
99
  };
113
100
  var _default = LeftPanel;
114
101
  exports.default = _default;
115
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reactBootstrap","_reactFontawesome","_freeSolidSvgIcons","_Sector","_interopRequireDefault","_KandoFilter","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","LeftPanel","_ref","points","selectedPoint","setSelectedPoint","_useState","useState","_useState2","_slicedToArray2","selectedFilters","setSelectedFilters","_useState3","_useState4","filteredPoints","setFilteredPoints","maxIssues","issuesIconColor","length","showIssues","point","issuesLength","issues","createElement","FontAwesomeIcon","icon","faExclamationTriangle","className","sortedPoints","sort","a","b","filterOptions","value","label","useEffect","filter","some","issue","type","Container","Row","Col","concat","ListGroup","map","Item","id","onClick","sectorIconName","group","sector_icon_name","sectorName","sector_name","showLabel","withTooltip","name","_default","exports"],"sources":["../../../src/pages/OperationsPage/LeftPanel.tsx"],"sourcesContent":["import React, { useEffect, useState } from 'react';\nimport { Container, Row, Col, ListGroup } from 'react-bootstrap';\nimport { IPoint } from 'src/store/points/models/IPoint';\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport { faExclamationTriangle } from '@fortawesome/free-solid-svg-icons';\nimport Sector from 'src/components/Sector';\nimport KandoFilter from 'src/ui-kit/KandoFilter/KandoFilter';\n\nexport interface LeftPanelProps {\n  points: IPoint[];\n  selectedPoint: IPoint | null;\n  setSelectedPoint: (point: IPoint) => void;\n}\n\nconst LeftPanel: React.FC<LeftPanelProps> = ({\n  points,\n  selectedPoint,\n  setSelectedPoint,\n}) => {\n  const [selectedFilters, setSelectedFilters] = useState([]);\n  const [filteredPoints, setFilteredPoints] = useState<IPoint[]>([]);\n  const maxIssues = 3;\n  const issuesIconColor = (length) => {\n    if (length % maxIssues === 0) {\n      return 'icon-red';\n    } else if (length % maxIssues === 2) {\n      return 'icon-orange';\n    } else {\n      return 'icon-yellow';\n    }\n  };\n\n  const showIssues = (point) => {\n    const issuesLength = point?.issues.length;\n    if (issuesLength > 0) {\n      return (\n        <FontAwesomeIcon\n          icon={faExclamationTriangle}\n          className={issuesIconColor(issuesLength)}\n        />\n      );\n    }\n    return '';\n  };\n\n  const sortedPoints = points.sort((a, b) => b.issues.length - a.issues.length);\n\n  const filterOptions = [\n    { value: 'installation_height', label: 'Installation Height' },\n    { value: 'distance', label: 'Distance' },\n    { value: 'no_parent', label: 'No Parent' },\n    { value: 'diameter', label: 'Diameter' },\n    { value: 'water_consumption', label: 'Water Consumption' },\n  ];\n\n  useEffect(() => {\n    setFilteredPoints(sortedPoints);\n  }, [sortedPoints]);\n\n  useEffect(() => {\n    const filteredPoints = sortedPoints.filter((point) => {\n      if (selectedFilters.length === 0) {\n        return true; // Show all points if no filters are selected\n      }\n\n      return selectedFilters.some((filter) =>\n        point.issues.some((issue) => issue.type === filter.value),\n      );\n    });\n    setFilteredPoints(filteredPoints);\n  }, [selectedFilters]);\n\n  return (\n    <Container className=\"mt-4 pl-3 pr-2\">\n      <Row>\n        <Col>\n          <h4>{`Monitored Manholes(${filteredPoints.length})`}</h4>\n        </Col>\n      </Row>\n      <Row className=\"mt-3 mb-3\">\n        <Col>\n          <KandoFilter\n            filterOptions={filterOptions}\n            selectedFilters={selectedFilters}\n            setSelectedFilters={setSelectedFilters}\n          ></KandoFilter>\n        </Col>\n      </Row>\n      <Row>\n        <Col>\n          <div className=\"scrollable-list\">\n            <ListGroup>\n              {points.length > 0 &&\n                filteredPoints.map((point) => (\n                  <ListGroup.Item\n                    className={\n                      selectedPoint?.id === point.id\n                        ? 'list-item list-item-selected'\n                        : 'list-item'\n                    }\n                    key={point.id}\n                    onClick={() => setSelectedPoint(point)}\n                  >\n                    <div className=\"item-content\">\n                      <Sector\n                        sectorIconName={point.group.sector_icon_name}\n                        sectorName={point.group.sector_name}\n                        showLabel={false}\n                        withTooltip={true}\n                      ></Sector>\n                      <span>{point.name}</span>\n                    </div>\n                    {showIssues(point)}\n                  </ListGroup.Item>\n                ))}\n            </ListGroup>\n          </div>\n        </Col>\n      </Row>\n    </Container>\n  );\n};\n\nexport default LeftPanel;\n"],"mappings":"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"}
102
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reactBootstrap","_reactFontawesome","_freeSolidSvgIcons","_Sector","_interopRequireDefault","_KandoFilter","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","LeftPanel","_ref","points","selectedPoint","setSelectedPoint","_ref$onlyMonitored","onlyMonitored","filterOptions","_useState","useState","_useState2","_slicedToArray2","selectedFilters","setSelectedFilters","_useState3","_useState4","filteredPoints","setFilteredPoints","maxIssues","issuesIconColor","length","showIssues","point","issuesLength","issues","createElement","FontAwesomeIcon","icon","faExclamationTriangle","className","sortedPoints","sort","a","b","useEffect","filter","some","issue","type","value","Container","Row","Col","concat","ListGroup","map","Item","id","onClick","sectorIconName","group","sector_icon_name","sectorName","sector_name","showLabel","withTooltip","name","_default","exports"],"sources":["../../../src/pages/OperationsPage/LeftPanel.tsx"],"sourcesContent":["import React, { useEffect, useState } from 'react';\nimport { Container, Row, Col, ListGroup } from 'react-bootstrap';\nimport { IPoint } from 'src/store/points/models/IPoint';\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport { faExclamationTriangle } from '@fortawesome/free-solid-svg-icons';\nimport Sector from 'src/components/Sector';\nimport KandoFilter from 'src/ui-kit/KandoFilter/KandoFilter';\n\nexport interface LeftPanelProps {\n  points: IPoint[];\n  selectedPoint: IPoint | null;\n  setSelectedPoint: (point: IPoint) => void;\n  filterOptions: { value: string; label: string }[];\n  onlyMonitored: boolean;\n}\n\nconst LeftPanel: React.FC<LeftPanelProps> = ({\n  points,\n  selectedPoint,\n  setSelectedPoint,\n  onlyMonitored = true,\n  filterOptions,\n}) => {\n  const [selectedFilters, setSelectedFilters] = useState([]);\n  const [filteredPoints, setFilteredPoints] = useState<IPoint[]>([]);\n  const maxIssues = 3;\n  const issuesIconColor = (length) => {\n    if (length % maxIssues === 0) {\n      return 'icon-red';\n    } else if (length % maxIssues === 2) {\n      return 'icon-orange';\n    } else {\n      return 'icon-yellow';\n    }\n  };\n\n  const showIssues = (point) => {\n    const issuesLength = point?.issues.length;\n    if (issuesLength > 0) {\n      return (\n        <FontAwesomeIcon\n          icon={faExclamationTriangle}\n          className={issuesIconColor(issuesLength)}\n        />\n      );\n    }\n    return '';\n  };\n\n  const sortedPoints = points.sort((a, b) => b.issues.length - a.issues.length);\n\n  useEffect(() => {\n    setFilteredPoints(sortedPoints);\n  }, [sortedPoints]);\n\n  useEffect(() => {\n    const filteredPoints = sortedPoints.filter((point) => {\n      if (selectedFilters.length === 0) {\n        return true; // Show all points if no filters are selected\n      }\n\n      return selectedFilters.some((filter) =>\n        point.issues.some((issue) => issue.type === filter.value),\n      );\n    });\n    setFilteredPoints(filteredPoints);\n  }, [selectedFilters]);\n\n  return (\n    <Container className=\"mt-4 pl-3 pr-2\">\n      <Row>\n        <Col>\n          <h4>{`${onlyMonitored ? 'Monitored ' : ''}Manholes(${\n            filteredPoints.length\n          })`}</h4>\n        </Col>\n      </Row>\n      <Row className=\"mt-3 mb-3\">\n        <Col>\n          <KandoFilter\n            filterOptions={filterOptions}\n            selectedFilters={selectedFilters}\n            setSelectedFilters={setSelectedFilters}\n          ></KandoFilter>\n        </Col>\n      </Row>\n      <Row>\n        <Col>\n          <div className=\"scrollable-list\">\n            <ListGroup>\n              {points.length > 0 &&\n                filteredPoints.map((point) => (\n                  <ListGroup.Item\n                    className={\n                      selectedPoint?.id === point.id\n                        ? 'list-item list-item-selected'\n                        : 'list-item'\n                    }\n                    key={point.id}\n                    onClick={() => setSelectedPoint(point)}\n                  >\n                    <div className=\"item-content\">\n                      <Sector\n                        sectorIconName={point.group.sector_icon_name}\n                        sectorName={point.group.sector_name}\n                        showLabel={false}\n                        withTooltip={true}\n                      ></Sector>\n                      <span>{point.name}</span>\n                    </div>\n                    {showIssues(point)}\n                  </ListGroup.Item>\n                ))}\n            </ListGroup>\n          </div>\n        </Col>\n      </Row>\n    </Container>\n  );\n};\n\nexport default LeftPanel;\n"],"mappings":"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"}
@@ -95,8 +95,9 @@ var useMap = function useMap(mapRef, points, edges, areas, selectedPoint, update
95
95
  if (!pointsLayerRef.current.getLayers().length) {
96
96
  points.forEach(function (point) {
97
97
  var type = point.has_device === true || point.group.type === 'Groups::WastewaterTreatmentPlant' ? point.group.type : 'Groups::default';
98
- var icon = (0, _PointIcon.getPointIconByType)(type, point.name, '', false, true);
99
- var focusedIcon = (0, _PointIcon.getPointIconByType)(type, point.name, '', true, false);
98
+ var hasIssues = 'issues' in point && !point.has_device;
99
+ var icon = (0, _PointIcon.getPointIconByType)(type, point.name, '', false, true, hasIssues);
100
+ var focusedIcon = (0, _PointIcon.getPointIconByType)(type, point.name, '', true, false, hasIssues);
100
101
  if (point.latitude && point.longitude) {
101
102
  var _pointsLayerRef$curre3;
102
103
  var marker = getMarker(point);
@@ -253,4 +254,4 @@ var useMap = function useMap(mapRef, points, edges, areas, selectedPoint, update
253
254
  return map;
254
255
  };
255
256
  exports.useMap = useMap;
256
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_leaflet","_interopRequireDefault","require","_react","_PointIcon","_theme","_MapUtils","useMap","mapRef","points","edges","areas","selectedPoint","updateSelectedPoint","_useState","useState","_useState2","_slicedToArray2","default","map","setMap","_useState3","_useState4","focusedMarker","setFocusedMarker","focusedMarkerRef","useRef","pointsLayerRef","edgesLayerRef","areasLayerRef","useEffect","current","resetAllOthers","mapTypes","baseMaps","leafletMap","mapDefault","satellite","mapTemp","L","renderer","canvas","Object","values","addTo","control","layers","position","off","remove","_pointsLayerRef$curre","eachLayer","marker","options","kando_object_id","id","_isInside","fire","_pointsLayerRef$curre2","getBounds","contains","getLatLng","flyTo","getZoom","duration","animate","handleMarkerClick","point","addMarkers","hasLayer","removeLayer","featureGroup","getLayers","length","forEach","type","has_device","group","icon","getPointIconByType","name","focusedIcon","latitude","longitude","_pointsLayerRef$curre3","getMarker","setIcon","on","_focusedMarkerRef$cur","_leaflet_id","_focusedMarkerRef$cur2","addLayer","addEdges","pointLookup","Map","p","set","edge","_edgesLayerRef$curren","_edgesLayerRef$curren2","sourcePoint","get","source_point_id","targetPoint","target_point_id","latlngs","polyline","color","weight","opacity","smoothFactor","decorator","polylineDecorator","patterns","offset","repeat","symbol","Symbol","arrowHead","pixelSize","polygon","pathOptions","stroke","addAreas","flattenAreas","arguments","undefined","allAreas","area","shape_data","push","Array","isArray","sub_areas","concat","_toConsumableArray2","area_id","_areasLayerRef$curren","interactive","bindTooltip","area_name","permanent","direction","className","focusMap","fitBounds","setView","exports"],"sources":["../../../../src/pages/OperationsPage/Map/useMap.tsx"],"sourcesContent":["import L, { Marker } from 'leaflet';\nimport React, { useEffect, useRef, useState } from 'react';\nimport { getPointIconByType } from 'src/Widgets/Map/points/PointIcon';\nimport { leafletMap } from 'src/styles/theme/theme';\nimport { baseMaps } from 'src/Widgets/Map/MapUtils';\nimport { IPoint } from 'src/store/points/models/IPoint';\nimport { IEdge } from 'src/store/edges/models/IEdge';\nimport { IArea } from 'src/store/areas/models/IArea';\n\nexport const useMap = (\n  mapRef: React.RefObject<HTMLDivElement>,\n  points: IPoint[],\n  edges: IEdge[],\n  areas: IArea[],\n  selectedPoint: IPoint | null,\n  updateSelectedPoint: (point: IPoint) => void,\n): L.Map | undefined => {\n  const [map, setMap] = useState<L.Map>();\n  const [focusedMarker, setFocusedMarker] = useState<Marker | null>(null);\n  const focusedMarkerRef = useRef<Marker | null>(null);\n  const pointsLayerRef = useRef<L.FeatureGroup>();\n  const edgesLayerRef = useRef<L.FeatureGroup>();\n  const areasLayerRef = useRef<L.FeatureGroup>();\n\n  useEffect(() => {\n    focusedMarkerRef.current = focusedMarker;\n    resetAllOthers();\n  }, [focusedMarker]);\n\n  useEffect(() => {\n    if (!mapRef.current) {\n      return;\n    }\n\n    const mapTypes = baseMaps(leafletMap.mapDefault, leafletMap.satellite);\n    const mapTemp = L.map(mapRef.current, { renderer: L.canvas() });\n\n    Object.values(mapTypes)[0].addTo(mapTemp);\n\n    L.control.layers(mapTypes, {}, { position: 'bottomright' }).addTo(mapTemp);\n\n    setMap(mapTemp);\n\n    return () => {\n      if (!mapTemp) {\n        return;\n      }\n      mapTemp.off();\n      mapTemp.remove();\n    };\n  }, []);\n\n  const resetAllOthers = () => {\n    pointsLayerRef.current?.eachLayer((marker) => {\n      if (\n        marker.options.kando_object_id !== selectedPoint?.id &&\n        marker._isInside\n      ) {\n        marker.fire('mouseout');\n      }\n    });\n  };\n\n  useEffect(() => {\n    if (selectedPoint === null) {\n      setFocusedMarker(null);\n    } else {\n      pointsLayerRef.current?.eachLayer((marker) => {\n        if (\n          selectedPoint &&\n          marker.options.kando_object_id === selectedPoint?.id\n        ) {\n          if (!map?.getBounds().contains(marker.getLatLng())) {\n            map?.flyTo(marker.getLatLng(), map.getZoom(), {\n              duration: 0.5,\n              animate: false,\n            });\n          }\n          marker.fire('mouseover');\n          setFocusedMarker(marker);\n          return;\n        }\n      });\n    }\n  }, [selectedPoint]);\n\n  const handleMarkerClick = (point) => {\n    updateSelectedPoint(point);\n  };\n\n  const addMarkers = () => {\n    if (!map || !points) {\n      return;\n    }\n\n    if (pointsLayerRef.current) {\n      if (map.hasLayer(pointsLayerRef.current)) {\n        map.removeLayer(pointsLayerRef.current);\n      }\n    }\n\n    pointsLayerRef.current = L.featureGroup();\n    pointsLayerRef.current.addTo(map);\n\n    if (!pointsLayerRef.current.getLayers().length) {\n      points.forEach((point) => {\n        const type =\n          point.has_device === true ||\n          point.group.type === 'Groups::WastewaterTreatmentPlant'\n            ? point.group.type\n            : 'Groups::default';\n        const icon = getPointIconByType(type, point.name, '', false, true);\n\n        const focusedIcon = getPointIconByType(\n          type,\n          point.name,\n          '',\n          true,\n          false,\n        );\n\n        if (point.latitude && point.longitude) {\n          let marker = getMarker(point);\n\n          marker.setIcon(icon);\n          // The use of marker._isInside is to overcome the issue that mouseover is endlessly triggered\n          // and we need it only once\n          marker.on('mouseover', () => {\n            if (!marker._isInside) {\n              marker._isInside = true;\n              marker.setIcon(focusedIcon);\n            }\n          });\n\n          marker.on('mouseout', () => {\n            if (\n              focusedMarkerRef?.current?._leaflet_id !== marker?._leaflet_id\n            ) {\n              marker._isInside = false;\n              marker.setIcon(icon);\n            }\n          });\n\n          marker.on('click', () => {\n            if (\n              focusedMarkerRef?.current?._leaflet_id === marker?._leaflet_id\n            ) {\n              setFocusedMarker(null);\n              handleMarkerClick(null);\n            } else {\n              handleMarkerClick(point);\n            }\n          });\n\n          pointsLayerRef.current?.addLayer(marker);\n        }\n      });\n    }\n  };\n\n  const getMarker = (point: IPoint) => {\n    return L.marker([point.latitude, point.longitude], {\n      kando_object_id: point.id,\n    });\n  };\n\n  const addEdges = () => {\n    if (!map || !edges) {\n      return;\n    }\n\n    const pointLookup = new Map();\n    points.forEach((p) => pointLookup.set(p.id, p));\n\n    if (edgesLayerRef.current) {\n      if (map.hasLayer(edgesLayerRef.current)) {\n        map.removeLayer(edgesLayerRef.current);\n      }\n    }\n\n    edgesLayerRef.current = L.featureGroup();\n    edgesLayerRef.current.addTo(map);\n\n    edges.forEach((edge) => {\n      const sourcePoint = pointLookup.get(edge.source_point_id);\n      const targetPoint = pointLookup.get(edge.target_point_id);\n\n      if (!sourcePoint || !targetPoint) {\n        return;\n      }\n\n      const latlngs = [\n        [sourcePoint?.latitude, sourcePoint?.longitude],\n        [targetPoint?.latitude, targetPoint?.longitude],\n      ];\n\n      const polyline = L.polyline(latlngs, {\n        color: 'black',\n        weight: 1,\n        opacity: 0.5,\n        smoothFactor: 1,\n      });\n\n      edgesLayerRef.current?.addLayer(polyline);\n\n      const decorator = L.polylineDecorator(polyline, {\n        patterns: [\n          {\n            offset: 20,\n            repeat: 60,\n            symbol: L.Symbol.arrowHead({\n              pixelSize: 4,\n              polygon: false,\n              pathOptions: {\n                stroke: true,\n                color: '#555',\n                weight: 1,\n                opacity: 0.8,\n              },\n            }),\n          },\n        ],\n      });\n\n      edgesLayerRef.current?.addLayer(decorator);\n    });\n  };\n\n  const addAreas = () => {\n    if (!map || !areas) {\n      return;\n    }\n\n    if (areasLayerRef.current) {\n      if (map.hasLayer(areasLayerRef.current)) {\n        map.removeLayer(areasLayerRef.current);\n      }\n    }\n\n    areasLayerRef.current = L.featureGroup();\n    areasLayerRef.current.addTo(map);\n\n    const flattenAreas = (areas: IArea[] = []): IArea[] => {\n      let allAreas: IArea[] = [];\n\n      areas.forEach((area: IArea) => {\n        if (area.shape_data.length > 0) {\n          allAreas.push(area);\n        }\n\n        // If there are sub_areas, recurse and concatenate\n        if (Array.isArray(area.sub_areas) && area.sub_areas.length > 0) {\n          allAreas = allAreas.concat(flattenAreas(area.sub_areas));\n        }\n      });\n\n      // Remove duplicates\n      return [\n        ...new Map(allAreas.map((area) => [area.area_id, area])).values(),\n      ];\n    };\n\n    const allAreas = flattenAreas(areas);\n\n    allAreas.forEach((area) => {\n      const polygon = L.polygon(area.shape_data, {\n        color: 'black',\n        weight: 1,\n        opacity: 0.8,\n        smoothFactor: 1,\n        interactive: false,\n        kando_object_id: area.area_id,\n      });\n\n      polygon.bindTooltip(area.area_name, {\n        permanent: true,\n        direction: 'center',\n        className: 'area-tooltip',\n      });\n\n      areasLayerRef.current?.addLayer(polygon);\n    });\n  };\n\n  const focusMap = () => {\n    if (map) {\n      if (\n        pointsLayerRef?.current &&\n        Array.isArray(pointsLayerRef.current.getLayers()) &&\n        pointsLayerRef.current.getLayers().length > 0\n      ) {\n        map.fitBounds(pointsLayerRef.current.getBounds());\n      } else {\n        map.setView([32.219157, 34.982481], 12);\n      }\n    }\n  };\n\n  useEffect(() => {\n    if (map) {\n      addAreas();\n      addEdges();\n      addMarkers();\n      focusMap();\n    }\n  }, [points, areas, edges, map]);\n\n  return map;\n};\n"],"mappings":"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"}
257
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_leaflet","_interopRequireDefault","require","_react","_PointIcon","_theme","_MapUtils","useMap","mapRef","points","edges","areas","selectedPoint","updateSelectedPoint","_useState","useState","_useState2","_slicedToArray2","default","map","setMap","_useState3","_useState4","focusedMarker","setFocusedMarker","focusedMarkerRef","useRef","pointsLayerRef","edgesLayerRef","areasLayerRef","useEffect","current","resetAllOthers","mapTypes","baseMaps","leafletMap","mapDefault","satellite","mapTemp","L","renderer","canvas","Object","values","addTo","control","layers","position","off","remove","_pointsLayerRef$curre","eachLayer","marker","options","kando_object_id","id","_isInside","fire","_pointsLayerRef$curre2","getBounds","contains","getLatLng","flyTo","getZoom","duration","animate","handleMarkerClick","point","addMarkers","hasLayer","removeLayer","featureGroup","getLayers","length","forEach","type","has_device","group","hasIssues","icon","getPointIconByType","name","focusedIcon","latitude","longitude","_pointsLayerRef$curre3","getMarker","setIcon","on","_focusedMarkerRef$cur","_leaflet_id","_focusedMarkerRef$cur2","addLayer","addEdges","pointLookup","Map","p","set","edge","_edgesLayerRef$curren","_edgesLayerRef$curren2","sourcePoint","get","source_point_id","targetPoint","target_point_id","latlngs","polyline","color","weight","opacity","smoothFactor","decorator","polylineDecorator","patterns","offset","repeat","symbol","Symbol","arrowHead","pixelSize","polygon","pathOptions","stroke","addAreas","flattenAreas","arguments","undefined","allAreas","area","shape_data","push","Array","isArray","sub_areas","concat","_toConsumableArray2","area_id","_areasLayerRef$curren","interactive","bindTooltip","area_name","permanent","direction","className","focusMap","fitBounds","setView","exports"],"sources":["../../../../src/pages/OperationsPage/Map/useMap.tsx"],"sourcesContent":["import L, { Marker } from 'leaflet';\nimport React, { useEffect, useRef, useState } from 'react';\nimport { getPointIconByType } from 'src/Widgets/Map/points/PointIcon';\nimport { leafletMap } from 'src/styles/theme/theme';\nimport { baseMaps } from 'src/Widgets/Map/MapUtils';\nimport { IPoint } from 'src/store/points/models/IPoint';\nimport { IEdge } from 'src/store/edges/models/IEdge';\nimport { IArea } from 'src/store/areas/models/IArea';\n\nexport const useMap = (\n  mapRef: React.RefObject<HTMLDivElement>,\n  points: IPoint[],\n  edges: IEdge[],\n  areas: IArea[],\n  selectedPoint: IPoint | null,\n  updateSelectedPoint: (point: IPoint) => void,\n): L.Map | undefined => {\n  const [map, setMap] = useState<L.Map>();\n  const [focusedMarker, setFocusedMarker] = useState<Marker | null>(null);\n  const focusedMarkerRef = useRef<Marker | null>(null);\n  const pointsLayerRef = useRef<L.FeatureGroup>();\n  const edgesLayerRef = useRef<L.FeatureGroup>();\n  const areasLayerRef = useRef<L.FeatureGroup>();\n\n  useEffect(() => {\n    focusedMarkerRef.current = focusedMarker;\n    resetAllOthers();\n  }, [focusedMarker]);\n\n  useEffect(() => {\n    if (!mapRef.current) {\n      return;\n    }\n\n    const mapTypes = baseMaps(leafletMap.mapDefault, leafletMap.satellite);\n    const mapTemp = L.map(mapRef.current, { renderer: L.canvas() });\n\n    Object.values(mapTypes)[0].addTo(mapTemp);\n\n    L.control.layers(mapTypes, {}, { position: 'bottomright' }).addTo(mapTemp);\n\n    setMap(mapTemp);\n\n    return () => {\n      if (!mapTemp) {\n        return;\n      }\n      mapTemp.off();\n      mapTemp.remove();\n    };\n  }, []);\n\n  const resetAllOthers = () => {\n    pointsLayerRef.current?.eachLayer((marker) => {\n      if (\n        marker.options.kando_object_id !== selectedPoint?.id &&\n        marker._isInside\n      ) {\n        marker.fire('mouseout');\n      }\n    });\n  };\n\n  useEffect(() => {\n    if (selectedPoint === null) {\n      setFocusedMarker(null);\n    } else {\n      pointsLayerRef.current?.eachLayer((marker) => {\n        if (\n          selectedPoint &&\n          marker.options.kando_object_id === selectedPoint?.id\n        ) {\n          if (!map?.getBounds().contains(marker.getLatLng())) {\n            map?.flyTo(marker.getLatLng(), map.getZoom(), {\n              duration: 0.5,\n              animate: false,\n            });\n          }\n          marker.fire('mouseover');\n          setFocusedMarker(marker);\n          return;\n        }\n      });\n    }\n  }, [selectedPoint]);\n\n  const handleMarkerClick = (point) => {\n    updateSelectedPoint(point);\n  };\n\n  const addMarkers = () => {\n    if (!map || !points) {\n      return;\n    }\n\n    if (pointsLayerRef.current) {\n      if (map.hasLayer(pointsLayerRef.current)) {\n        map.removeLayer(pointsLayerRef.current);\n      }\n    }\n\n    pointsLayerRef.current = L.featureGroup();\n    pointsLayerRef.current.addTo(map);\n\n    if (!pointsLayerRef.current.getLayers().length) {\n      points.forEach((point) => {\n        const type =\n          point.has_device === true ||\n          point.group.type === 'Groups::WastewaterTreatmentPlant'\n            ? point.group.type\n            : 'Groups::default';\n        const hasIssues = 'issues' in point && !point.has_device;\n        const icon = getPointIconByType(\n          type,\n          point.name,\n          '',\n          false,\n          true,\n          hasIssues,\n        );\n\n        const focusedIcon = getPointIconByType(\n          type,\n          point.name,\n          '',\n          true,\n          false,\n          hasIssues,\n        );\n\n        if (point.latitude && point.longitude) {\n          let marker = getMarker(point);\n\n          marker.setIcon(icon);\n          // The use of marker._isInside is to overcome the issue that mouseover is endlessly triggered\n          // and we need it only once\n          marker.on('mouseover', () => {\n            if (!marker._isInside) {\n              marker._isInside = true;\n              marker.setIcon(focusedIcon);\n            }\n          });\n\n          marker.on('mouseout', () => {\n            if (\n              focusedMarkerRef?.current?._leaflet_id !== marker?._leaflet_id\n            ) {\n              marker._isInside = false;\n              marker.setIcon(icon);\n            }\n          });\n\n          marker.on('click', () => {\n            if (\n              focusedMarkerRef?.current?._leaflet_id === marker?._leaflet_id\n            ) {\n              setFocusedMarker(null);\n              handleMarkerClick(null);\n            } else {\n              handleMarkerClick(point);\n            }\n          });\n\n          pointsLayerRef.current?.addLayer(marker);\n        }\n      });\n    }\n  };\n\n  const getMarker = (point: IPoint) => {\n    return L.marker([point.latitude, point.longitude], {\n      kando_object_id: point.id,\n    });\n  };\n\n  const addEdges = () => {\n    if (!map || !edges) {\n      return;\n    }\n\n    const pointLookup = new Map();\n    points.forEach((p) => pointLookup.set(p.id, p));\n\n    if (edgesLayerRef.current) {\n      if (map.hasLayer(edgesLayerRef.current)) {\n        map.removeLayer(edgesLayerRef.current);\n      }\n    }\n\n    edgesLayerRef.current = L.featureGroup();\n    edgesLayerRef.current.addTo(map);\n\n    edges.forEach((edge) => {\n      const sourcePoint = pointLookup.get(edge.source_point_id);\n      const targetPoint = pointLookup.get(edge.target_point_id);\n\n      if (!sourcePoint || !targetPoint) {\n        return;\n      }\n\n      const latlngs = [\n        [sourcePoint?.latitude, sourcePoint?.longitude],\n        [targetPoint?.latitude, targetPoint?.longitude],\n      ];\n\n      const polyline = L.polyline(latlngs, {\n        color: 'black',\n        weight: 1,\n        opacity: 0.5,\n        smoothFactor: 1,\n      });\n\n      edgesLayerRef.current?.addLayer(polyline);\n\n      const decorator = L.polylineDecorator(polyline, {\n        patterns: [\n          {\n            offset: 20,\n            repeat: 60,\n            symbol: L.Symbol.arrowHead({\n              pixelSize: 4,\n              polygon: false,\n              pathOptions: {\n                stroke: true,\n                color: '#555',\n                weight: 1,\n                opacity: 0.8,\n              },\n            }),\n          },\n        ],\n      });\n\n      edgesLayerRef.current?.addLayer(decorator);\n    });\n  };\n\n  const addAreas = () => {\n    if (!map || !areas) {\n      return;\n    }\n\n    if (areasLayerRef.current) {\n      if (map.hasLayer(areasLayerRef.current)) {\n        map.removeLayer(areasLayerRef.current);\n      }\n    }\n\n    areasLayerRef.current = L.featureGroup();\n    areasLayerRef.current.addTo(map);\n\n    const flattenAreas = (areas: IArea[] = []): IArea[] => {\n      let allAreas: IArea[] = [];\n\n      areas.forEach((area: IArea) => {\n        if (area.shape_data.length > 0) {\n          allAreas.push(area);\n        }\n\n        // If there are sub_areas, recurse and concatenate\n        if (Array.isArray(area.sub_areas) && area.sub_areas.length > 0) {\n          allAreas = allAreas.concat(flattenAreas(area.sub_areas));\n        }\n      });\n\n      // Remove duplicates\n      return [\n        ...new Map(allAreas.map((area) => [area.area_id, area])).values(),\n      ];\n    };\n\n    const allAreas = flattenAreas(areas);\n\n    allAreas.forEach((area) => {\n      const polygon = L.polygon(area.shape_data, {\n        color: 'black',\n        weight: 1,\n        opacity: 0.8,\n        smoothFactor: 1,\n        interactive: false,\n        kando_object_id: area.area_id,\n      });\n\n      polygon.bindTooltip(area.area_name, {\n        permanent: true,\n        direction: 'center',\n        className: 'area-tooltip',\n      });\n\n      areasLayerRef.current?.addLayer(polygon);\n    });\n  };\n\n  const focusMap = () => {\n    if (map) {\n      if (\n        pointsLayerRef?.current &&\n        Array.isArray(pointsLayerRef.current.getLayers()) &&\n        pointsLayerRef.current.getLayers().length > 0\n      ) {\n        map.fitBounds(pointsLayerRef.current.getBounds());\n      } else {\n        map.setView([32.219157, 34.982481], 12);\n      }\n    }\n  };\n\n  useEffect(() => {\n    if (map) {\n      addAreas();\n      addEdges();\n      addMarkers();\n      focusMap();\n    }\n  }, [points, areas, edges, map]);\n\n  return map;\n};\n"],"mappings":"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"}