@kando-env/kando-ui 1.2.418-alpha.7 → 1.2.418-alpha.9

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.
@@ -114,9 +114,9 @@ var buildChartOptions = function buildChartOptions(data) {
114
114
  categories.push(categoryTranslated);
115
115
  for (var _i2 = 0, _Object$entries = Object.entries(categoryValues); _i2 < _Object$entries.length; _i2++) {
116
116
  var _Object$entries$_i = (0, _slicedToArray2.default)(_Object$entries[_i2], 2),
117
- key = _Object$entries$_i[0],
117
+ _key = _Object$entries$_i[0],
118
118
  values = _Object$entries$_i[1];
119
- var severityIdx = parseInt(key);
119
+ var severityIdx = parseInt(_key);
120
120
  // @ts-ignore
121
121
  series[severityIdx].data.push(values['percents']);
122
122
  }
@@ -222,4 +222,4 @@ var DamageType = function DamageType(_ref) {
222
222
  };
223
223
  var _default = DamageType;
224
224
  exports.default = _default;
225
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_highcharts","_interopRequireDefault","_highchartsReactOfficial","_lodash","_reactFontawesome","_freeSolidSvgIcons","_i18n","_ContentLoader","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","CHART_BAR_WIDTH","CHART_BAR_MARGIN","chartDefaultOptions","chart","type","backgroundColor","credits","enabled","title","text","undefined","xAxis","categories","yAxis","gridLineColor","labels","min","stackLabels","formatter","Highcharts","numberFormat","total","legend","reversed","plotOptions","series","stacking","shadow","borderWidth","dataLabels","pointWidth","pointPadding","groupPadding","exporting","stripDamageType","string","toLowerCase","replace","buildChartOptions","data","damages","entries","isEmpty","color","showInLegend","name","i18n","t","_i","_damages","length","_damages$_i","_slicedToArray2","categoryKey","categoryValues","categoryTranslated","concat","push","_i2","_Object$entries","_Object$entries$_i","values","severityIdx","parseInt","opts","height","DamageType","_ref","_chartOptions$series","pointId","periodDays","_useState","useState","_useState2","chartOptions","setChartOptions","_useState3","_useState4","expansionStatus","setExpansionStatus","_useState5","_useState6","isFetching","setIsFetching","_useState7","_useState8","isDataPresent","setIsDataPresent","initFetching","useEffect","fetch","then","res","json","builtOptions","toggleExpansionStatus","nextStatus","createElement","className","Fragment","RowLoader","margin","bgColor","fgColor","highcharts","options","onClick","FontAwesomeIcon","icon","faChevronDown","faChevronUp","_default","exports"],"sources":["../../../src/components/DamageType/DamageType.tsx"],"sourcesContent":["import React, { useEffect, useState } from 'react';\nimport Highcharts from 'highcharts';\nimport HighchartsReact from 'highcharts-react-official';\nimport { isEmpty } from 'lodash';\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport { faChevronDown, faChevronUp } from '@fortawesome/free-solid-svg-icons';\n\nimport i18n from '../../utilities/i18n';\nimport { RowLoader } from '../ContentLoader';\n\nimport './styles.scss';\n\ntype IProps = {\n  pointId: number | null;\n  periodDays: number | null;\n};\n\ntype IChartOptions = {\n  damages: {\n    [key: string]: Array<{ severity: number; percents: number }>;\n  };\n};\n\nconst CHART_BAR_WIDTH = 23;\nconst CHART_BAR_MARGIN = 40;\n\nconst chartDefaultOptions = () => {\n  return {\n    chart: {\n      type: 'bar',\n      backgroundColor: '#f2f2f2',\n    },\n    credits: {\n      enabled: false,\n    },\n    title: {\n      text: undefined,\n    },\n    xAxis: {\n      categories: [],\n    },\n    yAxis: {\n      gridLineColor: '#f2f2f2',\n      labels: {\n        enabled: undefined,\n      },\n      min: 0,\n      title: {\n        text: undefined,\n      },\n      stackLabels: {\n        enabled: true,\n        // @ts-ignore\n        formatter: function () {\n          // @ts-ignore\n          return Highcharts.numberFormat(this.total, 0, ',', '.') + '%';\n        },\n      },\n    },\n    legend: {\n      reversed: false, // @TODO check\n    },\n    plotOptions: {\n      series: {\n        stacking: 'normal',\n        shadow: false,\n        borderWidth: 0,\n        dataLabels: {\n          enabled: false,\n        },\n        // @ts-ignore\n        pointWidth: 15,\n        pointPadding: 0,\n        groupPadding: 0.3,\n      },\n    },\n    exporting: {\n      enabled: false,\n    },\n    series: undefined,\n  };\n};\n\nconst stripDamageType = (string: string) => {\n  return string.toLowerCase().replace('/', '-');\n};\n\nconst buildChartOptions = (data: IChartOptions) => {\n  const damages = Object.entries(data.damages);\n  if (isEmpty(damages)) {\n    return {};\n  }\n\n  // Series will be shown as different colors inside the bars\n  const series = [\n    {\n      color: '#fce0bc',\n      showInLegend: false,\n      name: i18n.t('events_overview.severities.0'),\n      data: [],\n    },\n    {\n      color: '#f9c37d',\n      showInLegend: false,\n      name: i18n.t('events_overview.severities.1'),\n      data: [],\n    },\n    {\n      color: '#eb808c',\n      showInLegend: false,\n      name: i18n.t('events_overview.severities.2'),\n      data: [],\n    },\n  ];\n\n  // Add the categories (bars)\n  let categories: any[] = [];\n  for (const [categoryKey, categoryValues] of damages) {\n    const categoryTranslated = i18n.t(\n      `events_overview.damage_types.${stripDamageType(categoryKey)}`,\n    );\n    categories.push(categoryTranslated);\n    for (const [key, values] of Object.entries(categoryValues)) {\n      const severityIdx = parseInt(key);\n      // @ts-ignore\n      series[severityIdx].data.push(values['percents']);\n    }\n  }\n\n  let opts = chartDefaultOptions();\n  // @ts-ignore\n  opts.xAxis.categories = categories;\n  // @ts-ignore\n  opts.series = series;\n  // @ts-ignore\n  opts.chart.height = CHART_BAR_MARGIN + CHART_BAR_WIDTH * categories.length;\n\n  return opts;\n};\n\nconst DamageType = ({ pointId, periodDays }: IProps) => {\n  const [chartOptions, setChartOptions] = useState<Highcharts.Options>({});\n  const [expansionStatus, setExpansionStatus] = useState('');\n  const [isFetching, setIsFetching] = useState<boolean>(false);\n  const [isDataPresent, setIsDataPresent] = useState<boolean>(false);\n\n  const initFetching = () => {\n    setIsFetching(true);\n    setIsDataPresent(false);\n    setChartOptions({});\n  };\n\n  useEffect(() => {\n    initFetching();\n    if (pointId !== null) {\n      fetch(`/data/damage-type/${pointId}?period_days=${periodDays}`)\n        .then((res) => res.json())\n        .then((data) => {\n          setIsFetching(false);\n          const builtOptions = buildChartOptions(data.data);\n          // @ts-ignore\n          if (!isEmpty(builtOptions) && !isEmpty(builtOptions.xAxis)) {\n            setChartOptions(builtOptions);\n            // @ts-ignore\n            setIsDataPresent(!isEmpty(builtOptions.series));\n            // @ts-ignore\n            if (builtOptions.series.length > 5) {\n              setExpansionStatus('closed');\n            }\n          }\n        });\n    }\n\n    return () => {};\n  }, [pointId, periodDays]);\n\n  const toggleExpansionStatus = () => {\n    if (expansionStatus === '') {\n      return;\n    }\n\n    const nextStatus = expansionStatus === 'open' ? 'closed' : 'open';\n    setExpansionStatus(nextStatus);\n  };\n\n  if (!isFetching && !isDataPresent) {\n    return (\n      <div className=\"damage\">\n        <div className=\"damage__title\">\n          {i18n.t('events_overview.damage_type')}\n        </div>\n        <div className=\"damage__message\">\n          {i18n.t('components.damage_type.no_types')}\n        </div>\n      </div>\n    );\n  }\n\n  return (\n    <>\n      {isFetching ? (\n        <RowLoader margin=\"26px 0 0\" bgColor=\"#f2f2f2\" fgColor=\"#fff\" />\n      ) : (\n        <div\n          className={`damage ${expansionStatus === 'open' && 'damage--open'}`}\n        >\n          <div className=\"damage__title\">\n            {i18n.t('events_overview.damage_type')}\n          </div>\n\n          <div className=\"damage__content\">\n            {(chartOptions.series?.length || 0) > 0 && (\n              <HighchartsReact highcharts={Highcharts} options={chartOptions} />\n            )}\n\n            {expansionStatus === 'closed' && (\n              <div\n                className=\"damage__show-more damage__show-more--open\"\n                onClick={toggleExpansionStatus}\n              >\n                {i18n.t('components.damage_type.show_all')}\n                &nbsp;\n                <FontAwesomeIcon icon={faChevronDown} />\n              </div>\n            )}\n\n            {expansionStatus === 'open' && (\n              <div\n                className=\"damage__show-more damage__show-more--close\"\n                onClick={() => setExpansionStatus('closed')}\n              >\n                {i18n.t('components.damage_type.show_less')}\n                &nbsp;\n                <FontAwesomeIcon icon={faChevronUp} />\n              </div>\n            )}\n          </div>\n        </div>\n      )}\n    </>\n  );\n};\n\nexport default DamageType;\n"],"mappings":"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"}
225
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_highcharts","_interopRequireDefault","_highchartsReactOfficial","_lodash","_reactFontawesome","_freeSolidSvgIcons","_i18n","_ContentLoader","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","CHART_BAR_WIDTH","CHART_BAR_MARGIN","chartDefaultOptions","chart","type","backgroundColor","credits","enabled","title","text","undefined","xAxis","categories","yAxis","gridLineColor","labels","min","stackLabels","formatter","Highcharts","numberFormat","total","legend","reversed","plotOptions","series","stacking","shadow","borderWidth","dataLabels","pointWidth","pointPadding","groupPadding","exporting","stripDamageType","string","toLowerCase","replace","buildChartOptions","data","damages","entries","isEmpty","color","showInLegend","name","i18n","t","_i","_damages","length","_damages$_i","_slicedToArray2","categoryKey","categoryValues","categoryTranslated","concat","push","_i2","_Object$entries","_Object$entries$_i","values","severityIdx","parseInt","opts","height","DamageType","_ref","_chartOptions$series","pointId","periodDays","_useState","useState","_useState2","chartOptions","setChartOptions","_useState3","_useState4","expansionStatus","setExpansionStatus","_useState5","_useState6","isFetching","setIsFetching","_useState7","_useState8","isDataPresent","setIsDataPresent","initFetching","useEffect","fetch","then","res","json","builtOptions","toggleExpansionStatus","nextStatus","createElement","className","Fragment","RowLoader","margin","bgColor","fgColor","highcharts","options","onClick","FontAwesomeIcon","icon","faChevronDown","faChevronUp","_default","exports"],"sources":["../../../src/components/DamageType/DamageType.tsx"],"sourcesContent":["import React, { useEffect, useState } from 'react';\nimport Highcharts from 'highcharts';\nimport HighchartsReact from 'highcharts-react-official';\nimport { isEmpty } from 'lodash';\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport { faChevronDown, faChevronUp } from '@fortawesome/free-solid-svg-icons';\n\nimport i18n from '../../utilities/i18n';\nimport { RowLoader } from '../ContentLoader';\n\nimport './styles.scss';\n\ntype IProps = {\n  pointId: number | null;\n  periodDays: number | null;\n};\n\ntype IChartOptions = {\n  damages: {\n    [key: string]: Array<{ severity: number; percents: number }>;\n  };\n};\n\nconst CHART_BAR_WIDTH = 23;\nconst CHART_BAR_MARGIN = 40;\n\nconst chartDefaultOptions = () => {\n  return {\n    chart: {\n      type: 'bar',\n      backgroundColor: '#f2f2f2',\n    },\n    credits: {\n      enabled: false,\n    },\n    title: {\n      text: undefined,\n    },\n    xAxis: {\n      categories: [],\n    },\n    yAxis: {\n      gridLineColor: '#f2f2f2',\n      labels: {\n        enabled: undefined,\n      },\n      min: 0,\n      title: {\n        text: undefined,\n      },\n      stackLabels: {\n        enabled: true,\n        // @ts-ignore\n        formatter: function () {\n          // @ts-ignore\n          return Highcharts.numberFormat(this.total, 0, ',', '.') + '%';\n        },\n      },\n    },\n    legend: {\n      reversed: false, // @TODO check\n    },\n    plotOptions: {\n      series: {\n        stacking: 'normal',\n        shadow: false,\n        borderWidth: 0,\n        dataLabels: {\n          enabled: false,\n        },\n        // @ts-ignore\n        pointWidth: 15,\n        pointPadding: 0,\n        groupPadding: 0.3,\n      },\n    },\n    exporting: {\n      enabled: false,\n    },\n    series: undefined,\n  };\n};\n\nconst stripDamageType = (string: string) => {\n  return string.toLowerCase().replace('/', '-');\n};\n\nconst buildChartOptions = (data: IChartOptions) => {\n  const damages = Object.entries(data.damages);\n  if (isEmpty(damages)) {\n    return {};\n  }\n\n  // Series will be shown as different colors inside the bars\n  const series = [\n    {\n      color: '#fce0bc',\n      showInLegend: false,\n      name: i18n.t('events_overview.severities.0'),\n      data: [],\n    },\n    {\n      color: '#f9c37d',\n      showInLegend: false,\n      name: i18n.t('events_overview.severities.1'),\n      data: [],\n    },\n    {\n      color: '#eb808c',\n      showInLegend: false,\n      name: i18n.t('events_overview.severities.2'),\n      data: [],\n    },\n  ];\n\n  // Add the categories (bars)\n  let categories: any[] = [];\n  for (const [categoryKey, categoryValues] of damages) {\n    const categoryTranslated = i18n.t(\n      `events_overview.damage_types.${stripDamageType(categoryKey)}`,\n    );\n    categories.push(categoryTranslated);\n    for (const [key, values] of Object.entries(categoryValues)) {\n      const severityIdx = parseInt(key);\n      // @ts-ignore\n      series[severityIdx].data.push(values['percents']);\n    }\n  }\n\n  let opts = chartDefaultOptions();\n  // @ts-ignore\n  opts.xAxis.categories = categories;\n  // @ts-ignore\n  opts.series = series;\n  // @ts-ignore\n  opts.chart.height = CHART_BAR_MARGIN + CHART_BAR_WIDTH * categories.length;\n\n  return opts;\n};\n\nconst DamageType = ({ pointId, periodDays }: IProps) => {\n  const [chartOptions, setChartOptions] = useState<Highcharts.Options>({});\n  const [expansionStatus, setExpansionStatus] = useState('');\n  const [isFetching, setIsFetching] = useState<boolean>(false);\n  const [isDataPresent, setIsDataPresent] = useState<boolean>(false);\n\n  const initFetching = () => {\n    setIsFetching(true);\n    setIsDataPresent(false);\n    setChartOptions({});\n  };\n\n  useEffect(() => {\n    initFetching();\n    if (pointId !== null) {\n      fetch(`/data/damage-type/${pointId}?period_days=${periodDays}`)\n        .then((res) => res.json())\n        .then((data) => {\n          setIsFetching(false);\n          const builtOptions = buildChartOptions(data.data);\n          // @ts-ignore\n          if (!isEmpty(builtOptions) && !isEmpty(builtOptions.xAxis)) {\n            setChartOptions(builtOptions);\n            // @ts-ignore\n            setIsDataPresent(!isEmpty(builtOptions.series));\n            // @ts-ignore\n            if (builtOptions.series.length > 5) {\n              setExpansionStatus('closed');\n            }\n          }\n        });\n    }\n\n    return () => {};\n  }, [pointId, periodDays]);\n\n  const toggleExpansionStatus = () => {\n    if (expansionStatus === '') {\n      return;\n    }\n\n    const nextStatus = expansionStatus === 'open' ? 'closed' : 'open';\n    setExpansionStatus(nextStatus);\n  };\n\n  if (!isFetching && !isDataPresent) {\n    return (\n      <div className=\"damage\">\n        <div className=\"damage__title\">\n          {i18n.t('events_overview.damage_type')}\n        </div>\n        <div className=\"damage__message\">\n          {i18n.t('components.damage_type.no_types')}\n        </div>\n      </div>\n    );\n  }\n\n  return (\n    <>\n      {isFetching ? (\n        <RowLoader margin=\"26px 0 0\" bgColor=\"#f2f2f2\" fgColor=\"#fff\" />\n      ) : (\n        <div\n          className={`damage ${expansionStatus === 'open' && 'damage--open'}`}\n        >\n          <div className=\"damage__title\">\n            {i18n.t('events_overview.damage_type')}\n          </div>\n\n          <div className=\"damage__content\">\n            {(chartOptions.series?.length || 0) > 0 && (\n              <HighchartsReact highcharts={Highcharts} options={chartOptions} />\n            )}\n\n            {expansionStatus === 'closed' && (\n              <div\n                className=\"damage__show-more damage__show-more--open\"\n                onClick={toggleExpansionStatus}\n              >\n                {i18n.t('components.damage_type.show_all')}\n                &nbsp;\n                <FontAwesomeIcon icon={faChevronDown} />\n              </div>\n            )}\n\n            {expansionStatus === 'open' && (\n              <div\n                className=\"damage__show-more damage__show-more--close\"\n                onClick={() => setExpansionStatus('closed')}\n              >\n                {i18n.t('components.damage_type.show_less')}\n                &nbsp;\n                <FontAwesomeIcon icon={faChevronUp} />\n              </div>\n            )}\n          </div>\n        </div>\n      )}\n    </>\n  );\n};\n\nexport default DamageType;\n"],"mappings":"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"}
@@ -14,12 +14,29 @@ var _jquery = _interopRequireDefault(require("jquery"));
14
14
  var _react = _interopRequireWildcard(require("react"));
15
15
  var _highchartsReactOfficial = _interopRequireDefault(require("highcharts-react-official"));
16
16
  var _highstock = _interopRequireDefault(require("highcharts/highstock"));
17
+ var _noDataToDisplay = _interopRequireDefault(require("highcharts/modules/no-data-to-display"));
17
18
  var _ContentLoader = require("../ContentLoader");
18
19
  var _i18n = _interopRequireDefault(require("../../utilities/i18n"));
19
20
  var _styledComponents = _interopRequireDefault(require("styled-components"));
20
21
  var _reactRedux = require("react-redux");
21
22
  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); }
22
23
  function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof3(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; }
24
+ // Initialize no-data-to-display module with Highcharts
25
+ (0, _noDataToDisplay.default)(_highstock.default);
26
+
27
+ // Set global options for noData message and style
28
+ _highstock.default.setOptions({
29
+ lang: {
30
+ noData: _i18n.default.t('general.no_data_available')
31
+ },
32
+ noData: {
33
+ style: {
34
+ fontWeight: 'bold',
35
+ fontSize: '14px',
36
+ color: '#666'
37
+ }
38
+ }
39
+ });
23
40
  function addHours(hours) {
24
41
  var hoursAgo = new Date();
25
42
  hoursAgo.setHours(hoursAgo.getHours() + hours);
@@ -229,4 +246,4 @@ var Graph = function Graph(_ref5) {
229
246
  };
230
247
  var _default = Graph;
231
248
  exports.default = _default;
232
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_jquery","_interopRequireDefault","require","_react","_interopRequireWildcard","_highchartsReactOfficial","_highstock","_ContentLoader","_i18n","_styledComponents","_reactRedux","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof3","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","addHours","hours","hoursAgo","Date","setHours","getHours","getTime","ResetZoomButton","styled","button","withConfig","displayName","componentId","_ref","isRtl","_ref2","_ref3","theme","colorScheme","natural","n30","_ref4","n20","Graph","_ref5","pointId","title","startTime","endTime","plotFrom","plotTo","noObservation","_ref5$customHighChart","customHighChartOptions","_ref5$displayResetZoo","displayResetZoomButton","chartComponent","useRef","_useState","useState","text","_useState2","_slicedToArray2","graphOptions","setGraphOptions","_useState3","_useState4","isFetching","setIsFetching","objectClone","_objectSpread2","credits","enabled","series","chart","spacingBottom","spacingLeft","spacingRight","spacingTop","backgroundColor","height","zoomType","yAxis","xAxis","type","plotBands","time","timezoneOffset","createSeries","sData","datasets","xDatas","_iterator","_createForOfIteratorHelper2","_step","_loop","dataset","value","data","map","val","j","point_id","unit","tooltip","pointFormatter","bullet","concat","color","name","y","toFixed","s","n","done","err","e","f","iterateAndEval","colors","keys","i","length","_typeof2","toString","match","functionStr","substring","func","Function","createYAxis","result","Highcharts","getOptions","$","each","yAxises","index","push","showEmpty","getData","url","fetch","then","response","json","parseInt","timezone","tz_offset","from","to","useEffect","cleanup","resetZoom","_chartComponent$curre","current","_chartComponent$curre2","setExtremes","navContext","useSelector","state","nav_context_data","locale","createElement","RowLoader","width","fgColor","bgColor","Fragment","ref","highcharts","options","onClick","i18n","t","_default","exports"],"sources":["../../../src/components/Graph/Graph.tsx"],"sourcesContent":["import $ from 'jquery';\nimport React, { useEffect, useRef, useState } from 'react';\nimport HighchartsReact from 'highcharts-react-official';\nimport Highcharts from 'highcharts/highstock';\nimport { RowLoader } from '../ContentLoader';\nimport i18n from '../../utilities/i18n';\nimport styled from 'styled-components';\nimport { useSelector } from 'react-redux';\nimport { appReducer } from '../../store/rootReducer';\n\ntype IProps = {\n  pointId: number | null;\n  title?: string | null;\n  startTime?: number;\n  endTime?: number;\n  plotFrom?: number;\n  plotTo?: number;\n  noObservation?: boolean;\n  displayResetZoomButton?: boolean;\n  customHighChartOptions?: object;\n};\n\nfunction addHours(hours: number) {\n  let hoursAgo = new Date();\n  hoursAgo.setHours(hoursAgo.getHours() + hours);\n  return hoursAgo.getTime() / 1000;\n}\nconst ResetZoomButton = styled.button<{ isRtl: boolean }>`\n  @media (max-width: 500px) {\n    right: ${({ isRtl }) => (isRtl ? '15px' : 'unset')}!important;\n    left: ${({ isRtl }) => (isRtl ? 'unset' : '15px')} !important;\n    top: 6px !important;\n  }\n  position: absolute;\n  top: 65px;\n  right: 15px;\n  border: 1px solid ${({ theme }) => theme.colorScheme.natural.n30};\n  border-radius: 5px;\n  padding: 0 5px;\n\n  &:hover {\n    background-color: ${({ theme }) => theme.colorScheme.natural.n20};\n  }\n`;\nconst Graph = ({\n  pointId,\n  title,\n  startTime,\n  endTime,\n  plotFrom,\n  plotTo,\n  noObservation,\n  customHighChartOptions = {},\n  displayResetZoomButton = false,\n}: IProps) => {\n  const chartComponent = useRef<any>(null);\n  const [graphOptions, setGraphOptions] = useState({\n    title: { text: 'Please Wait ...' },\n  });\n  const [isFetching, setIsFetching] = useState<boolean>(true);\n  let objectClone = {\n    title: {\n      text: title,\n    },\n    credits: {\n      enabled: false,\n    },\n    series: [],\n    chart: {\n      spacingBottom: 20,\n      spacingLeft: 0,\n      spacingRight: 0,\n      spacingTop: 20,\n      backgroundColor: 'rgba(0,0,0,0)',\n      height: 250,\n      zoomType: 'x',\n    },\n    yAxis: [],\n    xAxis: {\n      type: 'datetime',\n      plotBands: [],\n    },\n    time: {\n      timezoneOffset: 0,\n    },\n    ...customHighChartOptions,\n  };\n  const createSeries = (sData: any) => {\n    let datasets = sData.datasets;\n    let xDatas = sData.xDatas;\n    for (const dataset of datasets) {\n      dataset.data = dataset.data.map((val: number, j: number) => [\n        xDatas[dataset.point_id][j],\n        val,\n      ]);\n\n      if (dataset?.unit) {\n        dataset.tooltip = {\n          pointFormatter: function () {\n            const bullet = `<tspan style=\"fill:${dataset.color}\" x=\"8\" dy=\"15\">●</tspan> `;\n            return `<tspan>${bullet}${\n              dataset.name\n            }:</tspan> <b>${this.y.toFixed(2)} °${dataset.unit}</b>`;\n          },\n        };\n      }\n    }\n    return datasets;\n  };\n\n  const iterateAndEval = (data: any, colors: any) => {\n    if (data) {\n      let keys = Object.keys(data);\n      for (let i = 0; i < keys.length; i++) {\n        let key = keys[i],\n          value = data[key];\n        if (typeof value == 'object') {\n          iterateAndEval(value, colors);\n        } else {\n          if (value && value.toString().match(/function::/)) {\n            let functionStr = value.substring(10),\n              func = new Function(functionStr);\n            data[key] = func();\n          } else if (value && value.toString().match(/colors\\[(.*?)\\]/)) {\n            data[key] = colors[value.toString().match(/colors\\[(.*?)\\]/)[1]];\n          }\n        }\n      }\n    }\n  };\n\n  const createYAxis = (sData: any) => {\n    var result: any[] = [],\n      colors = Highcharts.getOptions().colors;\n    if (sData) {\n      // eslint-disable-next-line\n      $.each(sData.yAxises, function (index, yAxis) {\n        iterateAndEval(yAxis, colors);\n        result.push(yAxis);\n      });\n    }\n    if (result.length === 0) {\n      result.push({\n        showEmpty: false,\n        title: {\n          text: '',\n        },\n      });\n    }\n\n    return result;\n  };\n\n  const getData = () => {\n    startTime = startTime || addHours(-3);\n    endTime = endTime || addHours(3);\n    let url = `/control_room/point_chart_data.json?point_id=${pointId}`;\n    url += startTime ? `&start=${startTime}` : '';\n    url += endTime ? `&stop=${endTime}` : '';\n    url += noObservation ? `&no_observation=${noObservation}` : '';\n    setIsFetching(true);\n    fetch(url)\n      .then((response) => response.json())\n      .then((json) => {\n        //@ts-ignore\n        objectClone.series = createSeries(json);\n        //@ts-ignore\n        objectClone.yAxis = createYAxis(json);\n        objectClone.time.timezoneOffset =\n          parseInt(json.timezone.tz_offset) * 60;\n        if (plotFrom && plotTo) {\n          objectClone.xAxis.plotBands = [\n            {\n              //@ts-ignore\n              color: 'rgba(230,23,148,0.1)',\n              //@ts-ignore\n              from: plotFrom * 1000,\n              //@ts-ignore\n              to: plotTo * 1000,\n            },\n          ];\n        }\n        // @ts-ignore\n        setGraphOptions(objectClone);\n        setIsFetching(false);\n      });\n  };\n\n  useEffect(() => {\n    getData();\n    return function cleanup() {};\n  }, [pointId]);\n  const resetZoom = () => {\n    if (chartComponent.current?.chart) {\n      const { xAxis, yAxis } = chartComponent.current.chart;\n      if (xAxis?.length && yAxis?.length) {\n        xAxis[0].setExtremes();\n        yAxis[0].setExtremes();\n      }\n    }\n  };\n  const navContext = useSelector(\n    (state: ReturnType<typeof appReducer>) => state.nav_context_data.navContext,\n  );\n  const isRtl: boolean = navContext.locale === 'he' ? true : false;\n  return isFetching ? (\n    <RowLoader width=\"100%\" height={190} fgColor=\"#eee\" bgColor=\"#fff\" />\n  ) : (\n    <>\n      <HighchartsReact\n        ref={chartComponent}\n        highcharts={Highcharts}\n        options={graphOptions}\n      />\n      {displayResetZoomButton && (\n        <ResetZoomButton onClick={resetZoom} isRtl={isRtl}>\n          {i18n.t('events_overview.floating_graph.reset_zoom')}\n        </ResetZoomButton>\n      )}\n    </>\n  );\n};\n\nexport default Graph;\n"],"mappings":";;;;;;;;;;;;AAAA,IAAAA,OAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,MAAA,GAAAC,uBAAA,CAAAF,OAAA;AACA,IAAAG,wBAAA,GAAAJ,sBAAA,CAAAC,OAAA;AACA,IAAAI,UAAA,GAAAL,sBAAA,CAAAC,OAAA;AACA,IAAAK,cAAA,GAAAL,OAAA;AACA,IAAAM,KAAA,GAAAP,sBAAA,CAAAC,OAAA;AACA,IAAAO,iBAAA,GAAAR,sBAAA,CAAAC,OAAA;AACA,IAAAQ,WAAA,GAAAR,OAAA;AAA0C,SAAAS,yBAAAC,WAAA,eAAAC,OAAA,kCAAAC,iBAAA,OAAAD,OAAA,QAAAE,gBAAA,OAAAF,OAAA,YAAAF,wBAAA,YAAAA,yBAAAC,WAAA,WAAAA,WAAA,GAAAG,gBAAA,GAAAD,iBAAA,KAAAF,WAAA;AAAA,SAAAR,wBAAAY,GAAA,EAAAJ,WAAA,SAAAA,WAAA,IAAAI,GAAA,IAAAA,GAAA,CAAAC,UAAA,WAAAD,GAAA,QAAAA,GAAA,aAAAE,QAAA,CAAAF,GAAA,yBAAAA,GAAA,4BAAAG,OAAA,EAAAH,GAAA,UAAAI,KAAA,GAAAT,wBAAA,CAAAC,WAAA,OAAAQ,KAAA,IAAAA,KAAA,CAAAC,GAAA,CAAAL,GAAA,YAAAI,KAAA,CAAAE,GAAA,CAAAN,GAAA,SAAAO,MAAA,WAAAC,qBAAA,GAAAC,MAAA,CAAAC,cAAA,IAAAD,MAAA,CAAAE,wBAAA,WAAAC,GAAA,IAAAZ,GAAA,QAAAY,GAAA,kBAAAH,MAAA,CAAAI,SAAA,CAAAC,cAAA,CAAAC,IAAA,CAAAf,GAAA,EAAAY,GAAA,SAAAI,IAAA,GAAAR,qBAAA,GAAAC,MAAA,CAAAE,wBAAA,CAAAX,GAAA,EAAAY,GAAA,cAAAI,IAAA,KAAAA,IAAA,CAAAV,GAAA,IAAAU,IAAA,CAAAC,GAAA,KAAAR,MAAA,CAAAC,cAAA,CAAAH,MAAA,EAAAK,GAAA,EAAAI,IAAA,YAAAT,MAAA,CAAAK,GAAA,IAAAZ,GAAA,CAAAY,GAAA,SAAAL,MAAA,CAAAJ,OAAA,GAAAH,GAAA,MAAAI,KAAA,IAAAA,KAAA,CAAAa,GAAA,CAAAjB,GAAA,EAAAO,MAAA,YAAAA,MAAA;AAe1C,SAASW,QAAQA,CAACC,KAAa,EAAE;EAC/B,IAAIC,QAAQ,GAAG,IAAIC,IAAI,CAAC,CAAC;EACzBD,QAAQ,CAACE,QAAQ,CAACF,QAAQ,CAACG,QAAQ,CAAC,CAAC,GAAGJ,KAAK,CAAC;EAC9C,OAAOC,QAAQ,CAACI,OAAO,CAAC,CAAC,GAAG,IAAI;AAClC;AACA,IAAMC,eAAe,GAAGC,yBAAM,CAACC,MAAM,CAAAC,UAAA;EAAAC,WAAA;EAAAC,WAAA;AAAA,2NAExB,UAAAC,IAAA;EAAA,IAAGC,KAAK,GAAAD,IAAA,CAALC,KAAK;EAAA,OAAQA,KAAK,GAAG,MAAM,GAAG,OAAO;AAAA,CAAC,EAC1C,UAAAC,KAAA;EAAA,IAAGD,KAAK,GAAAC,KAAA,CAALD,KAAK;EAAA,OAAQA,KAAK,GAAG,OAAO,GAAG,MAAM;AAAA,CAAC,EAM/B,UAAAE,KAAA;EAAA,IAAGC,KAAK,GAAAD,KAAA,CAALC,KAAK;EAAA,OAAOA,KAAK,CAACC,WAAW,CAACC,OAAO,CAACC,GAAG;AAAA,GAK1C,UAAAC,KAAA;EAAA,IAAGJ,KAAK,GAAAI,KAAA,CAALJ,KAAK;EAAA,OAAOA,KAAK,CAACC,WAAW,CAACC,OAAO,CAACG,GAAG;AAAA,EAEnE;AACD,IAAMC,KAAK,GAAG,SAARA,KAAKA,CAAAC,KAAA,EAUG;EAAA,IATZC,OAAO,GAAAD,KAAA,CAAPC,OAAO;IACPC,KAAK,GAAAF,KAAA,CAALE,KAAK;IACLC,SAAS,GAAAH,KAAA,CAATG,SAAS;IACTC,OAAO,GAAAJ,KAAA,CAAPI,OAAO;IACPC,QAAQ,GAAAL,KAAA,CAARK,QAAQ;IACRC,MAAM,GAAAN,KAAA,CAANM,MAAM;IACNC,aAAa,GAAAP,KAAA,CAAbO,aAAa;IAAAC,qBAAA,GAAAR,KAAA,CACbS,sBAAsB;IAAtBA,sBAAsB,GAAAD,qBAAA,cAAG,CAAC,CAAC,GAAAA,qBAAA;IAAAE,qBAAA,GAAAV,KAAA,CAC3BW,sBAAsB;IAAtBA,sBAAsB,GAAAD,qBAAA,cAAG,KAAK,GAAAA,qBAAA;EAE9B,IAAME,cAAc,GAAG,IAAAC,aAAM,EAAM,IAAI,CAAC;EACxC,IAAAC,SAAA,GAAwC,IAAAC,eAAQ,EAAC;MAC/Cb,KAAK,EAAE;QAAEc,IAAI,EAAE;MAAkB;IACnC,CAAC,CAAC;IAAAC,UAAA,OAAAC,eAAA,CAAAzD,OAAA,EAAAqD,SAAA;IAFKK,YAAY,GAAAF,UAAA;IAAEG,eAAe,GAAAH,UAAA;EAGpC,IAAAI,UAAA,GAAoC,IAAAN,eAAQ,EAAU,IAAI,CAAC;IAAAO,UAAA,OAAAJ,eAAA,CAAAzD,OAAA,EAAA4D,UAAA;IAApDE,UAAU,GAAAD,UAAA;IAAEE,aAAa,GAAAF,UAAA;EAChC,IAAIG,WAAW,OAAAC,cAAA,CAAAjE,OAAA;IACbyC,KAAK,EAAE;MACLc,IAAI,EAAEd;IACR,CAAC;IACDyB,OAAO,EAAE;MACPC,OAAO,EAAE;IACX,CAAC;IACDC,MAAM,EAAE,EAAE;IACVC,KAAK,EAAE;MACLC,aAAa,EAAE,EAAE;MACjBC,WAAW,EAAE,CAAC;MACdC,YAAY,EAAE,CAAC;MACfC,UAAU,EAAE,EAAE;MACdC,eAAe,EAAE,eAAe;MAChCC,MAAM,EAAE,GAAG;MACXC,QAAQ,EAAE;IACZ,CAAC;IACDC,KAAK,EAAE,EAAE;IACTC,KAAK,EAAE;MACLC,IAAI,EAAE,UAAU;MAChBC,SAAS,EAAE;IACb,CAAC;IACDC,IAAI,EAAE;MACJC,cAAc,EAAE;IAClB;EAAC,GACElC,sBAAsB,CAC1B;EACD,IAAMmC,YAAY,GAAG,SAAfA,YAAYA,CAAIC,KAAU,EAAK;IACnC,IAAIC,QAAQ,GAAGD,KAAK,CAACC,QAAQ;IAC7B,IAAIC,MAAM,GAAGF,KAAK,CAACE,MAAM;IAAC,IAAAC,SAAA,OAAAC,2BAAA,CAAAxF,OAAA,EACJqF,QAAQ;MAAAI,KAAA;IAAA;MAAA,IAAAC,KAAA,YAAAA,MAAA;QAAA,IAAnBC,OAAO,GAAAF,KAAA,CAAAG,KAAA;QAChBD,OAAO,CAACE,IAAI,GAAGF,OAAO,CAACE,IAAI,CAACC,GAAG,CAAC,UAACC,GAAW,EAAEC,CAAS;UAAA,OAAK,CAC1DV,MAAM,CAACK,OAAO,CAACM,QAAQ,CAAC,CAACD,CAAC,CAAC,EAC3BD,GAAG,CACJ;QAAA,EAAC;QAEF,IAAIJ,OAAO,aAAPA,OAAO,uBAAPA,OAAO,CAAEO,IAAI,EAAE;UACjBP,OAAO,CAACQ,OAAO,GAAG;YAChBC,cAAc,EAAE,SAAAA,eAAA,EAAY;cAC1B,IAAMC,MAAM,0BAAAC,MAAA,CAAyBX,OAAO,CAACY,KAAK,yCAA4B;cAC9E,iBAAAD,MAAA,CAAiBD,MAAM,EAAAC,MAAA,CACrBX,OAAO,CAACa,IAAI,mBAAAF,MAAA,CACE,IAAI,CAACG,CAAC,CAACC,OAAO,CAAC,CAAC,CAAC,WAAAJ,MAAA,CAAKX,OAAO,CAACO,IAAI;YACpD;UACF,CAAC;QACH;MAAC;MAfH,KAAAX,SAAA,CAAAoB,CAAA,MAAAlB,KAAA,GAAAF,SAAA,CAAAqB,CAAA,IAAAC,IAAA,GAAgC;QAAAnB,KAAA;MAgBhC;IAAC,SAAAoB,GAAA;MAAAvB,SAAA,CAAAwB,CAAA,CAAAD,GAAA;IAAA;MAAAvB,SAAA,CAAAyB,CAAA;IAAA;IACD,OAAO3B,QAAQ;EACjB,CAAC;EAED,IAAM4B,cAAc,GAAG,SAAjBA,cAAcA,CAAIpB,IAAS,EAAEqB,MAAW,EAAK;IACjD,IAAIrB,IAAI,EAAE;MACR,IAAIsB,IAAI,GAAG7G,MAAM,CAAC6G,IAAI,CAACtB,IAAI,CAAC;MAC5B,KAAK,IAAIuB,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGD,IAAI,CAACE,MAAM,EAAED,CAAC,EAAE,EAAE;QACpC,IAAI3G,GAAG,GAAG0G,IAAI,CAACC,CAAC,CAAC;UACfxB,KAAK,GAAGC,IAAI,CAACpF,GAAG,CAAC;QACnB,IAAI,IAAA6G,QAAA,CAAAtH,OAAA,EAAO4F,KAAK,KAAI,QAAQ,EAAE;UAC5BqB,cAAc,CAACrB,KAAK,EAAEsB,MAAM,CAAC;QAC/B,CAAC,MAAM;UACL,IAAItB,KAAK,IAAIA,KAAK,CAAC2B,QAAQ,CAAC,CAAC,CAACC,KAAK,CAAC,YAAY,CAAC,EAAE;YACjD,IAAIC,WAAW,GAAG7B,KAAK,CAAC8B,SAAS,CAAC,EAAE,CAAC;cACnCC,IAAI,GAAG,IAAIC,QAAQ,CAACH,WAAW,CAAC;YAClC5B,IAAI,CAACpF,GAAG,CAAC,GAAGkH,IAAI,CAAC,CAAC;UACpB,CAAC,MAAM,IAAI/B,KAAK,IAAIA,KAAK,CAAC2B,QAAQ,CAAC,CAAC,CAACC,KAAK,CAAC,iBAAiB,CAAC,EAAE;YAC7D3B,IAAI,CAACpF,GAAG,CAAC,GAAGyG,MAAM,CAACtB,KAAK,CAAC2B,QAAQ,CAAC,CAAC,CAACC,KAAK,CAAC,iBAAiB,CAAC,CAAC,CAAC,CAAC,CAAC;UAClE;QACF;MACF;IACF;EACF,CAAC;EAED,IAAMK,WAAW,GAAG,SAAdA,WAAWA,CAAIzC,KAAU,EAAK;IAClC,IAAI0C,MAAa,GAAG,EAAE;MACpBZ,MAAM,GAAGa,kBAAU,CAACC,UAAU,CAAC,CAAC,CAACd,MAAM;IACzC,IAAI9B,KAAK,EAAE;MACT;MACA6C,eAAC,CAACC,IAAI,CAAC9C,KAAK,CAAC+C,OAAO,EAAE,UAAUC,KAAK,EAAEvD,KAAK,EAAE;QAC5CoC,cAAc,CAACpC,KAAK,EAAEqC,MAAM,CAAC;QAC7BY,MAAM,CAACO,IAAI,CAACxD,KAAK,CAAC;MACpB,CAAC,CAAC;IACJ;IACA,IAAIiD,MAAM,CAACT,MAAM,KAAK,CAAC,EAAE;MACvBS,MAAM,CAACO,IAAI,CAAC;QACVC,SAAS,EAAE,KAAK;QAChB7F,KAAK,EAAE;UACLc,IAAI,EAAE;QACR;MACF,CAAC,CAAC;IACJ;IAEA,OAAOuE,MAAM;EACf,CAAC;EAED,IAAMS,OAAO,GAAG,SAAVA,OAAOA,CAAA,EAAS;IACpB7F,SAAS,GAAGA,SAAS,IAAI3B,QAAQ,CAAC,CAAC,CAAC,CAAC;IACrC4B,OAAO,GAAGA,OAAO,IAAI5B,QAAQ,CAAC,CAAC,CAAC;IAChC,IAAIyH,GAAG,mDAAAlC,MAAA,CAAmD9D,OAAO,CAAE;IACnEgG,GAAG,IAAI9F,SAAS,aAAA4D,MAAA,CAAa5D,SAAS,IAAK,EAAE;IAC7C8F,GAAG,IAAI7F,OAAO,YAAA2D,MAAA,CAAY3D,OAAO,IAAK,EAAE;IACxC6F,GAAG,IAAI1F,aAAa,sBAAAwD,MAAA,CAAsBxD,aAAa,IAAK,EAAE;IAC9DiB,aAAa,CAAC,IAAI,CAAC;IACnB0E,KAAK,CAACD,GAAG,CAAC,CACPE,IAAI,CAAC,UAACC,QAAQ;MAAA,OAAKA,QAAQ,CAACC,IAAI,CAAC,CAAC;IAAA,EAAC,CACnCF,IAAI,CAAC,UAACE,IAAI,EAAK;MACd;MACA5E,WAAW,CAACI,MAAM,GAAGe,YAAY,CAACyD,IAAI,CAAC;MACvC;MACA5E,WAAW,CAACa,KAAK,GAAGgD,WAAW,CAACe,IAAI,CAAC;MACrC5E,WAAW,CAACiB,IAAI,CAACC,cAAc,GAC7B2D,QAAQ,CAACD,IAAI,CAACE,QAAQ,CAACC,SAAS,CAAC,GAAG,EAAE;MACxC,IAAInG,QAAQ,IAAIC,MAAM,EAAE;QACtBmB,WAAW,CAACc,KAAK,CAACE,SAAS,GAAG,CAC5B;UACE;UACAuB,KAAK,EAAE,sBAAsB;UAC7B;UACAyC,IAAI,EAAEpG,QAAQ,GAAG,IAAI;UACrB;UACAqG,EAAE,EAAEpG,MAAM,GAAG;QACf,CAAC,CACF;MACH;MACA;MACAc,eAAe,CAACK,WAAW,CAAC;MAC5BD,aAAa,CAAC,KAAK,CAAC;IACtB,CAAC,CAAC;EACN,CAAC;EAED,IAAAmF,gBAAS,EAAC,YAAM;IACdX,OAAO,CAAC,CAAC;IACT,OAAO,SAASY,OAAOA,CAAA,EAAG,CAAC,CAAC;EAC9B,CAAC,EAAE,CAAC3G,OAAO,CAAC,CAAC;EACb,IAAM4G,SAAS,GAAG,SAAZA,SAASA,CAAA,EAAS;IAAA,IAAAC,qBAAA;IACtB,KAAAA,qBAAA,GAAIlG,cAAc,CAACmG,OAAO,cAAAD,qBAAA,uBAAtBA,qBAAA,CAAwBhF,KAAK,EAAE;MACjC,IAAAkF,sBAAA,GAAyBpG,cAAc,CAACmG,OAAO,CAACjF,KAAK;QAA7CS,KAAK,GAAAyE,sBAAA,CAALzE,KAAK;QAAED,KAAK,GAAA0E,sBAAA,CAAL1E,KAAK;MACpB,IAAI,CAAAC,KAAK,aAALA,KAAK,uBAALA,KAAK,CAAEuC,MAAM,MAAIxC,KAAK,aAALA,KAAK,uBAALA,KAAK,CAAEwC,MAAM,GAAE;QAClCvC,KAAK,CAAC,CAAC,CAAC,CAAC0E,WAAW,CAAC,CAAC;QACtB3E,KAAK,CAAC,CAAC,CAAC,CAAC2E,WAAW,CAAC,CAAC;MACxB;IACF;EACF,CAAC;EACD,IAAMC,UAAU,GAAG,IAAAC,uBAAW,EAC5B,UAACC,KAAoC;IAAA,OAAKA,KAAK,CAACC,gBAAgB,CAACH,UAAU;EAAA,CAC7E,CAAC;EACD,IAAM5H,KAAc,GAAG4H,UAAU,CAACI,MAAM,KAAK,IAAI,GAAG,IAAI,GAAG,KAAK;EAChE,OAAO/F,UAAU,gBACf9E,MAAA,CAAAgB,OAAA,CAAA8J,aAAA,CAAC1K,cAAA,CAAA2K,SAAS;IAACC,KAAK,EAAC,MAAM;IAACrF,MAAM,EAAE,GAAI;IAACsF,OAAO,EAAC,MAAM;IAACC,OAAO,EAAC;EAAM,CAAE,CAAC,gBAErElL,MAAA,CAAAgB,OAAA,CAAA8J,aAAA,CAAA9K,MAAA,CAAAgB,OAAA,CAAAmK,QAAA,qBACEnL,MAAA,CAAAgB,OAAA,CAAA8J,aAAA,CAAC5K,wBAAA,CAAAc,OAAe;IACdoK,GAAG,EAAEjH,cAAe;IACpBkH,UAAU,EAAEtC,kBAAW;IACvBuC,OAAO,EAAE5G;EAAa,CACvB,CAAC,EACDR,sBAAsB,iBACrBlE,MAAA,CAAAgB,OAAA,CAAA8J,aAAA,CAACxI,eAAe;IAACiJ,OAAO,EAAEnB,SAAU;IAACvH,KAAK,EAAEA;EAAM,GAC/C2I,aAAI,CAACC,CAAC,CAAC,2CAA2C,CACpC,CAEnB,CACH;AACH,CAAC;AAAC,IAAAC,QAAA,GAEapI,KAAK;AAAAqI,OAAA,CAAA3K,OAAA,GAAA0K,QAAA"}
249
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_jquery","_interopRequireDefault","require","_react","_interopRequireWildcard","_highchartsReactOfficial","_highstock","_noDataToDisplay","_ContentLoader","_i18n","_styledComponents","_reactRedux","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof3","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","NoDataToDisplay","Highcharts","setOptions","lang","noData","i18n","t","style","fontWeight","fontSize","color","addHours","hours","hoursAgo","Date","setHours","getHours","getTime","ResetZoomButton","styled","button","withConfig","displayName","componentId","_ref","isRtl","_ref2","_ref3","theme","colorScheme","natural","n30","_ref4","n20","Graph","_ref5","pointId","title","startTime","endTime","plotFrom","plotTo","noObservation","_ref5$customHighChart","customHighChartOptions","_ref5$displayResetZoo","displayResetZoomButton","chartComponent","useRef","_useState","useState","text","_useState2","_slicedToArray2","graphOptions","setGraphOptions","_useState3","_useState4","isFetching","setIsFetching","objectClone","_objectSpread2","credits","enabled","series","chart","spacingBottom","spacingLeft","spacingRight","spacingTop","backgroundColor","height","zoomType","yAxis","xAxis","type","plotBands","time","timezoneOffset","createSeries","sData","datasets","xDatas","_iterator","_createForOfIteratorHelper2","_step","_loop","dataset","value","data","map","val","j","point_id","unit","tooltip","pointFormatter","bullet","concat","name","y","toFixed","s","n","done","err","e","f","iterateAndEval","colors","keys","i","length","_typeof2","toString","match","functionStr","substring","func","Function","createYAxis","result","getOptions","$","each","yAxises","index","push","showEmpty","getData","url","fetch","then","response","json","parseInt","timezone","tz_offset","from","to","useEffect","cleanup","resetZoom","_chartComponent$curre","current","_chartComponent$curre2","setExtremes","navContext","useSelector","state","nav_context_data","locale","createElement","RowLoader","width","fgColor","bgColor","Fragment","ref","highcharts","options","onClick","_default","exports"],"sources":["../../../src/components/Graph/Graph.tsx"],"sourcesContent":["import $ from 'jquery';\nimport React, { useEffect, useRef, useState } from 'react';\nimport HighchartsReact from 'highcharts-react-official';\nimport Highcharts from 'highcharts/highstock';\nimport NoDataToDisplay from 'highcharts/modules/no-data-to-display';\nimport { RowLoader } from '../ContentLoader';\nimport i18n from '../../utilities/i18n';\nimport styled from 'styled-components';\nimport { useSelector } from 'react-redux';\nimport { appReducer } from '../../store/rootReducer';\n\n// Initialize no-data-to-display module with Highcharts\nNoDataToDisplay(Highcharts);\n\n// Set global options for noData message and style\nHighcharts.setOptions({\n  lang: {\n    noData: i18n.t('general.no_data_available'),\n  },\n  noData: {\n    style: {\n      fontWeight: 'bold',\n      fontSize: '14px',\n      color: '#666',\n    },\n  },\n});\n\ntype IProps = {\n  pointId: number | null;\n  title?: string | null;\n  startTime?: number;\n  endTime?: number;\n  plotFrom?: number;\n  plotTo?: number;\n  noObservation?: boolean;\n  displayResetZoomButton?: boolean;\n  customHighChartOptions?: object;\n};\n\nfunction addHours(hours: number) {\n  let hoursAgo = new Date();\n  hoursAgo.setHours(hoursAgo.getHours() + hours);\n  return hoursAgo.getTime() / 1000;\n}\nconst ResetZoomButton = styled.button<{ isRtl: boolean }>`\n  @media (max-width: 500px) {\n    right: ${({ isRtl }) => (isRtl ? '15px' : 'unset')}!important;\n    left: ${({ isRtl }) => (isRtl ? 'unset' : '15px')} !important;\n    top: 6px !important;\n  }\n  position: absolute;\n  top: 65px;\n  right: 15px;\n  border: 1px solid ${({ theme }) => theme.colorScheme.natural.n30};\n  border-radius: 5px;\n  padding: 0 5px;\n\n  &:hover {\n    background-color: ${({ theme }) => theme.colorScheme.natural.n20};\n  }\n`;\nconst Graph = ({\n  pointId,\n  title,\n  startTime,\n  endTime,\n  plotFrom,\n  plotTo,\n  noObservation,\n  customHighChartOptions = {},\n  displayResetZoomButton = false,\n}: IProps) => {\n  const chartComponent = useRef<any>(null);\n  const [graphOptions, setGraphOptions] = useState({\n    title: { text: 'Please Wait ...' },\n  });\n  const [isFetching, setIsFetching] = useState<boolean>(true);\n  let objectClone = {\n    title: {\n      text: title,\n    },\n    credits: {\n      enabled: false,\n    },\n    series: [],\n    chart: {\n      spacingBottom: 20,\n      spacingLeft: 0,\n      spacingRight: 0,\n      spacingTop: 20,\n      backgroundColor: 'rgba(0,0,0,0)',\n      height: 250,\n      zoomType: 'x',\n    },\n    yAxis: [],\n    xAxis: {\n      type: 'datetime',\n      plotBands: [],\n    },\n    time: {\n      timezoneOffset: 0,\n    },\n    ...customHighChartOptions,\n  };\n  const createSeries = (sData: any) => {\n    let datasets = sData.datasets;\n    let xDatas = sData.xDatas;\n    for (const dataset of datasets) {\n      dataset.data = dataset.data.map((val: number, j: number) => [\n        xDatas[dataset.point_id][j],\n        val,\n      ]);\n\n      if (dataset?.unit) {\n        dataset.tooltip = {\n          pointFormatter: function () {\n            const bullet = `<tspan style=\"fill:${dataset.color}\" x=\"8\" dy=\"15\">●</tspan> `;\n            return `<tspan>${bullet}${\n              dataset.name\n            }:</tspan> <b>${this.y.toFixed(2)} °${dataset.unit}</b>`;\n          },\n        };\n      }\n    }\n    return datasets;\n  };\n\n  const iterateAndEval = (data: any, colors: any) => {\n    if (data) {\n      let keys = Object.keys(data);\n      for (let i = 0; i < keys.length; i++) {\n        let key = keys[i],\n          value = data[key];\n        if (typeof value == 'object') {\n          iterateAndEval(value, colors);\n        } else {\n          if (value && value.toString().match(/function::/)) {\n            let functionStr = value.substring(10),\n              func = new Function(functionStr);\n            data[key] = func();\n          } else if (value && value.toString().match(/colors\\[(.*?)\\]/)) {\n            data[key] = colors[value.toString().match(/colors\\[(.*?)\\]/)[1]];\n          }\n        }\n      }\n    }\n  };\n\n  const createYAxis = (sData: any) => {\n    var result: any[] = [],\n      colors = Highcharts.getOptions().colors;\n    if (sData) {\n      // eslint-disable-next-line\n      $.each(sData.yAxises, function (index, yAxis) {\n        iterateAndEval(yAxis, colors);\n        result.push(yAxis);\n      });\n    }\n    if (result.length === 0) {\n      result.push({\n        showEmpty: false,\n        title: {\n          text: '',\n        },\n      });\n    }\n\n    return result;\n  };\n\n  const getData = () => {\n    startTime = startTime || addHours(-3);\n    endTime = endTime || addHours(3);\n    let url = `/control_room/point_chart_data.json?point_id=${pointId}`;\n    url += startTime ? `&start=${startTime}` : '';\n    url += endTime ? `&stop=${endTime}` : '';\n    url += noObservation ? `&no_observation=${noObservation}` : '';\n    setIsFetching(true);\n    fetch(url)\n      .then((response) => response.json())\n      .then((json) => {\n        //@ts-ignore\n        objectClone.series = createSeries(json);\n        //@ts-ignore\n        objectClone.yAxis = createYAxis(json);\n        objectClone.time.timezoneOffset =\n          parseInt(json.timezone.tz_offset) * 60;\n        if (plotFrom && plotTo) {\n          objectClone.xAxis.plotBands = [\n            {\n              //@ts-ignore\n              color: 'rgba(230,23,148,0.1)',\n              //@ts-ignore\n              from: plotFrom * 1000,\n              //@ts-ignore\n              to: plotTo * 1000,\n            },\n          ];\n        }\n        // @ts-ignore\n        setGraphOptions(objectClone);\n        setIsFetching(false);\n      });\n  };\n\n  useEffect(() => {\n    getData();\n    return function cleanup() {};\n  }, [pointId]);\n  const resetZoom = () => {\n    if (chartComponent.current?.chart) {\n      const { xAxis, yAxis } = chartComponent.current.chart;\n      if (xAxis?.length && yAxis?.length) {\n        xAxis[0].setExtremes();\n        yAxis[0].setExtremes();\n      }\n    }\n  };\n  const navContext = useSelector(\n    (state: ReturnType<typeof appReducer>) => state.nav_context_data.navContext,\n  );\n  const isRtl: boolean = navContext.locale === 'he' ? true : false;\n  return isFetching ? (\n    <RowLoader width=\"100%\" height={190} fgColor=\"#eee\" bgColor=\"#fff\" />\n  ) : (\n    <>\n      <HighchartsReact\n        ref={chartComponent}\n        highcharts={Highcharts}\n        options={graphOptions}\n      />\n      {displayResetZoomButton && (\n        <ResetZoomButton onClick={resetZoom} isRtl={isRtl}>\n          {i18n.t('events_overview.floating_graph.reset_zoom')}\n        </ResetZoomButton>\n      )}\n    </>\n  );\n};\n\nexport default Graph;\n"],"mappings":"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"}
@@ -31,7 +31,6 @@ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj &&
31
31
  //
32
32
  // return { values: values, x_axis: x_axis };
33
33
  // };
34
-
35
34
  var TrendGraphNVL = function TrendGraphNVL(_ref) {
36
35
  var areaID = _ref.areaID,
37
36
  pathogen = _ref.pathogen,
@@ -158,4 +157,4 @@ var TrendGraphNVL = function TrendGraphNVL(_ref) {
158
157
  };
159
158
  var _default = TrendGraphNVL;
160
159
  exports.default = _default;
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/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      &__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      &__subtitle {\n        font-size: 1.2rem;\n        text-align: center;\n        margin: 0 0 0.6rem;\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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"}
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/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      &__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      &__subtitle {\n        font-size: 1.2rem;\n        text-align: center;\n        margin: 0 0 0.6rem;\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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"}
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
 
3
- var packageJsonVersion = "1.2.418-alpha.7";
3
+ var packageJsonVersion = "1.2.418-alpha.9";
4
4
  if (typeof packageJsonVersion === 'string') {
5
5
  // eslint-disable-next-line no-console
6
6
  console.log("%c Kando UI %c v".concat(packageJsonVersion, " "), 'font-size: 15px; background-color: #fff; color: #e20f53;', 'font-weight: bold; font-size: 15px; background-color: #e20f53; color: #fff;', "with NODE_ENV=".concat(process.env.NODE_ENV));
@@ -31,7 +31,6 @@ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj &&
31
31
  //
32
32
  // return { values: values, x_axis: x_axis };
33
33
  // };
34
-
35
34
  var TrendGraphNVL = function TrendGraphNVL(_ref) {
36
35
  var areaID = _ref.areaID,
37
36
  pathogen = _ref.pathogen,
@@ -158,4 +157,4 @@ var TrendGraphNVL = function TrendGraphNVL(_ref) {
158
157
  };
159
158
  var _default = TrendGraphNVL;
160
159
  exports.default = _default;
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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"}
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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"}
@@ -5,7 +5,8 @@
5
5
  position: absolute;
6
6
  top: 14px;
7
7
  height: calc(100% - 75px);
8
- width: 1px; //calc(100% - 480px);
8
+ width: auto;
9
+ min-width: 50px;
9
10
  display: flex;
10
11
  text-align: center;
11
12
  flex-direction: column;
@@ -37,20 +37,28 @@ var FloatingGraph = function FloatingGraph(_ref) {
37
37
  var graphData = {};
38
38
  var observation = globalDataFloatingGraph === null || globalDataFloatingGraph === void 0 ? void 0 : globalDataFloatingGraph.observation;
39
39
  graphData.pointId = ((_observation = observation) === null || _observation === void 0 ? void 0 : _observation.point_id) || (globalDataFloatingGraph === null || globalDataFloatingGraph === void 0 ? void 0 : globalDataFloatingGraph.point.id);
40
+ var plotFrom = ((_observation2 = observation) === null || _observation2 === void 0 ? void 0 : _observation2.start_time) || 0;
41
+ var plotTo = ((_observation3 = observation) === null || _observation3 === void 0 ? void 0 : _observation3.last_seen_time) || 0;
42
+
43
+ // even if we find an observation, do not show its plot on the graph
40
44
  if (!observation && (event_data === null || event_data === void 0 ? void 0 : event_data.observations)) {
41
45
  observation = event_data.observations.find(function (o) {
42
46
  return o.id === (event_data === null || event_data === void 0 ? void 0 : event_data.first_seen_observation_id);
43
47
  });
44
48
  }
45
49
  graphData = (0, _objectSpread2.default)((0, _objectSpread2.default)({}, graphData), {}, {
46
- plotFrom: ((_observation2 = observation) === null || _observation2 === void 0 ? void 0 : _observation2.start_time) || 0,
47
- plotTo: ((_observation3 = observation) === null || _observation3 === void 0 ? void 0 : _observation3.last_seen_time) || 0,
48
50
  startTime: observation.start_time - timeGapFromEvent,
49
51
  endTime: observation.last_seen_time + timeGapFromEvent,
50
52
  noObservation: observation ? false : true,
51
53
  customHighChartOptions: customHighChartOptions,
52
54
  displayResetZoomButton: true
53
55
  });
56
+ if (plotFrom >= 0 && plotTo > 0) {
57
+ graphData = (0, _objectSpread2.default)((0, _objectSpread2.default)({}, graphData), {}, {
58
+ plotFrom: plotFrom,
59
+ plotTo: plotTo
60
+ });
61
+ }
54
62
  return /*#__PURE__*/_react.default.createElement(_Graph.default, graphData);
55
63
  };
56
64
  var minimizeGraphHandler = function minimizeGraphHandler() {
@@ -81,4 +89,4 @@ var FloatingGraph = function FloatingGraph(_ref) {
81
89
  };
82
90
  var _default = FloatingGraph;
83
91
  exports.default = _default;
84
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_Graph","_interopRequireDefault","_highstock","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","FloatingGraph","_ref","isOpen","_ref$customHighChartO","customHighChartOptions","globalDataFloatingGraph","event_data","closeGraphHandler","_useState","useState","_useState2","_slicedToArray2","minimized","setMinimized","Highcharts","setOptions","lang","rangeSelectorZoom","graphTitle","point","group","name","matchGraph","_observation","_observation2","_observation3","timeGapFromEvent","graphData","observation","pointId","point_id","id","observations","find","o","first_seen_observation_id","_objectSpread2","plotFrom","start_time","plotTo","last_seen_time","startTime","endTime","noObservation","displayResetZoomButton","createElement","minimizeGraphHandler","prevState","className","concat","onClick","_default","exports"],"sources":["../../../../src/pages/EventsPage/FloatingGraph/FloatingGraph.tsx"],"sourcesContent":["import React, { useState } from 'react';\nimport Graph from 'src/components/Graph';\nimport './floatingGraphStyle.scss';\nimport Highcharts from 'highcharts/highstock';\n\ntype IProps = {\n  customHighChartOptions?: Highcharts.Options;\n  globalDataFloatingGraph?: { [key: string]: any };\n  event_data?: any;\n  closeGraphHandler: Function;\n  graphId: string;\n  isOpen?: boolean;\n};\n\nconst FloatingGraph: React.FC<IProps> = ({\n  isOpen,\n  customHighChartOptions = {},\n  globalDataFloatingGraph,\n  event_data,\n  closeGraphHandler,\n}) => {\n  const [minimized, setMinimized] = useState<boolean>(false);\n  Highcharts.setOptions({\n    lang: {\n      rangeSelectorZoom: '',\n    },\n  });\n  const graphTitle = isOpen ? globalDataFloatingGraph?.point.group.name : '';\n\n  const matchGraph = () => {\n    const timeGapFromEvent = 86400 * 31 * 2; // 2 months\n    let graphData: any = {};\n    let observation = globalDataFloatingGraph?.observation;\n    graphData.pointId =\n      observation?.point_id || globalDataFloatingGraph?.point.id;\n    if (!observation && event_data?.observations) {\n      observation = event_data.observations.find(\n        (o) => o.id === event_data?.first_seen_observation_id,\n      );\n    }\n    graphData = {\n      ...graphData,\n      plotFrom: observation?.start_time || 0,\n      plotTo: observation?.last_seen_time || 0,\n      startTime: observation.start_time - timeGapFromEvent,\n      endTime: observation.last_seen_time + timeGapFromEvent,\n      noObservation: observation ? false : true,\n      customHighChartOptions: customHighChartOptions,\n      displayResetZoomButton: true,\n    };\n    return <Graph {...graphData} />;\n  };\n  const minimizeGraphHandler = () => {\n    setMinimized((prevState) => !prevState);\n  };\n\n  if (!isOpen) {\n    return null;\n  }\n  return (\n    <div className={`floating-graph ${minimized ? 'minimized' : ''}`}>\n      <div\n        className=\"floating-graph__close\"\n        onClick={() => closeGraphHandler()}\n      ></div>\n      <div\n        className=\"floating-graph__minimize\"\n        onClick={() => minimizeGraphHandler()}\n      ></div>\n      <div className=\"graph-ttl\">{graphTitle}</div>\n      <div className=\"high-chart-wrapper\">{matchGraph()}</div>\n    </div>\n  );\n};\n\nexport default FloatingGraph;\n"],"mappings":";;;;;;;;;;AAAA,IAAAA,MAAA,GAAAC,uBAAA,CAAAC,OAAA;AACA,IAAAC,MAAA,GAAAC,sBAAA,CAAAF,OAAA;AACAA,OAAA;AACA,IAAAG,UAAA,GAAAD,sBAAA,CAAAF,OAAA;AAA8C,SAAAI,yBAAAC,WAAA,eAAAC,OAAA,kCAAAC,iBAAA,OAAAD,OAAA,QAAAE,gBAAA,OAAAF,OAAA,YAAAF,wBAAA,YAAAA,yBAAAC,WAAA,WAAAA,WAAA,GAAAG,gBAAA,GAAAD,iBAAA,KAAAF,WAAA;AAAA,SAAAN,wBAAAU,GAAA,EAAAJ,WAAA,SAAAA,WAAA,IAAAI,GAAA,IAAAA,GAAA,CAAAC,UAAA,WAAAD,GAAA,QAAAA,GAAA,aAAAE,OAAA,CAAAF,GAAA,yBAAAA,GAAA,4BAAAG,OAAA,EAAAH,GAAA,UAAAI,KAAA,GAAAT,wBAAA,CAAAC,WAAA,OAAAQ,KAAA,IAAAA,KAAA,CAAAC,GAAA,CAAAL,GAAA,YAAAI,KAAA,CAAAE,GAAA,CAAAN,GAAA,SAAAO,MAAA,WAAAC,qBAAA,GAAAC,MAAA,CAAAC,cAAA,IAAAD,MAAA,CAAAE,wBAAA,WAAAC,GAAA,IAAAZ,GAAA,QAAAY,GAAA,kBAAAH,MAAA,CAAAI,SAAA,CAAAC,cAAA,CAAAC,IAAA,CAAAf,GAAA,EAAAY,GAAA,SAAAI,IAAA,GAAAR,qBAAA,GAAAC,MAAA,CAAAE,wBAAA,CAAAX,GAAA,EAAAY,GAAA,cAAAI,IAAA,KAAAA,IAAA,CAAAV,GAAA,IAAAU,IAAA,CAAAC,GAAA,KAAAR,MAAA,CAAAC,cAAA,CAAAH,MAAA,EAAAK,GAAA,EAAAI,IAAA,YAAAT,MAAA,CAAAK,GAAA,IAAAZ,GAAA,CAAAY,GAAA,SAAAL,MAAA,CAAAJ,OAAA,GAAAH,GAAA,MAAAI,KAAA,IAAAA,KAAA,CAAAa,GAAA,CAAAjB,GAAA,EAAAO,MAAA,YAAAA,MAAA;AAW9C,IAAMW,aAA+B,GAAG,SAAlCA,aAA+BA,CAAAC,IAAA,EAM/B;EAAA,IALJC,MAAM,GAAAD,IAAA,CAANC,MAAM;IAAAC,qBAAA,GAAAF,IAAA,CACNG,sBAAsB;IAAtBA,sBAAsB,GAAAD,qBAAA,cAAG,CAAC,CAAC,GAAAA,qBAAA;IAC3BE,uBAAuB,GAAAJ,IAAA,CAAvBI,uBAAuB;IACvBC,UAAU,GAAAL,IAAA,CAAVK,UAAU;IACVC,iBAAiB,GAAAN,IAAA,CAAjBM,iBAAiB;EAEjB,IAAAC,SAAA,GAAkC,IAAAC,eAAQ,EAAU,KAAK,CAAC;IAAAC,UAAA,OAAAC,eAAA,CAAA1B,OAAA,EAAAuB,SAAA;IAAnDI,SAAS,GAAAF,UAAA;IAAEG,YAAY,GAAAH,UAAA;EAC9BI,kBAAU,CAACC,UAAU,CAAC;IACpBC,IAAI,EAAE;MACJC,iBAAiB,EAAE;IACrB;EACF,CAAC,CAAC;EACF,IAAMC,UAAU,GAAGhB,MAAM,GAAGG,uBAAuB,aAAvBA,uBAAuB,uBAAvBA,uBAAuB,CAAEc,KAAK,CAACC,KAAK,CAACC,IAAI,GAAG,EAAE;EAE1E,IAAMC,UAAU,GAAG,SAAbA,UAAUA,CAAA,EAAS;IAAA,IAAAC,YAAA,EAAAC,aAAA,EAAAC,aAAA;IACvB,IAAMC,gBAAgB,GAAG,KAAK,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;IACzC,IAAIC,SAAc,GAAG,CAAC,CAAC;IACvB,IAAIC,WAAW,GAAGvB,uBAAuB,aAAvBA,uBAAuB,uBAAvBA,uBAAuB,CAAEuB,WAAW;IACtDD,SAAS,CAACE,OAAO,GACf,EAAAN,YAAA,GAAAK,WAAW,cAAAL,YAAA,uBAAXA,YAAA,CAAaO,QAAQ,MAAIzB,uBAAuB,aAAvBA,uBAAuB,uBAAvBA,uBAAuB,CAAEc,KAAK,CAACY,EAAE;IAC5D,IAAI,CAACH,WAAW,KAAItB,UAAU,aAAVA,UAAU,uBAAVA,UAAU,CAAE0B,YAAY,GAAE;MAC5CJ,WAAW,GAAGtB,UAAU,CAAC0B,YAAY,CAACC,IAAI,CACxC,UAACC,CAAC;QAAA,OAAKA,CAAC,CAACH,EAAE,MAAKzB,UAAU,aAAVA,UAAU,uBAAVA,UAAU,CAAE6B,yBAAyB;MAAA,CACvD,CAAC;IACH;IACAR,SAAS,OAAAS,cAAA,CAAAnD,OAAA,MAAAmD,cAAA,CAAAnD,OAAA,MACJ0C,SAAS;MACZU,QAAQ,EAAE,EAAAb,aAAA,GAAAI,WAAW,cAAAJ,aAAA,uBAAXA,aAAA,CAAac,UAAU,KAAI,CAAC;MACtCC,MAAM,EAAE,EAAAd,aAAA,GAAAG,WAAW,cAAAH,aAAA,uBAAXA,aAAA,CAAae,cAAc,KAAI,CAAC;MACxCC,SAAS,EAAEb,WAAW,CAACU,UAAU,GAAGZ,gBAAgB;MACpDgB,OAAO,EAAEd,WAAW,CAACY,cAAc,GAAGd,gBAAgB;MACtDiB,aAAa,EAAEf,WAAW,GAAG,KAAK,GAAG,IAAI;MACzCxB,sBAAsB,EAAEA,sBAAsB;MAC9CwC,sBAAsB,EAAE;IAAI,EAC7B;IACD,oBAAOzE,MAAA,CAAAc,OAAA,CAAA4D,aAAA,CAACvE,MAAA,CAAAW,OAAK,EAAK0C,SAAY,CAAC;EACjC,CAAC;EACD,IAAMmB,oBAAoB,GAAG,SAAvBA,oBAAoBA,CAAA,EAAS;IACjCjC,YAAY,CAAC,UAACkC,SAAS;MAAA,OAAK,CAACA,SAAS;IAAA,EAAC;EACzC,CAAC;EAED,IAAI,CAAC7C,MAAM,EAAE;IACX,OAAO,IAAI;EACb;EACA,oBACE/B,MAAA,CAAAc,OAAA,CAAA4D,aAAA;IAAKG,SAAS,oBAAAC,MAAA,CAAoBrC,SAAS,GAAG,WAAW,GAAG,EAAE;EAAG,gBAC/DzC,MAAA,CAAAc,OAAA,CAAA4D,aAAA;IACEG,SAAS,EAAC,uBAAuB;IACjCE,OAAO,EAAE,SAAAA,QAAA;MAAA,OAAM3C,iBAAiB,CAAC,CAAC;IAAA;EAAC,CAC/B,CAAC,eACPpC,MAAA,CAAAc,OAAA,CAAA4D,aAAA;IACEG,SAAS,EAAC,0BAA0B;IACpCE,OAAO,EAAE,SAAAA,QAAA;MAAA,OAAMJ,oBAAoB,CAAC,CAAC;IAAA;EAAC,CAClC,CAAC,eACP3E,MAAA,CAAAc,OAAA,CAAA4D,aAAA;IAAKG,SAAS,EAAC;EAAW,GAAE9B,UAAgB,CAAC,eAC7C/C,MAAA,CAAAc,OAAA,CAAA4D,aAAA;IAAKG,SAAS,EAAC;EAAoB,GAAE1B,UAAU,CAAC,CAAO,CACpD,CAAC;AAEV,CAAC;AAAC,IAAA6B,QAAA,GAEanD,aAAa;AAAAoD,OAAA,CAAAnE,OAAA,GAAAkE,QAAA"}
92
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_Graph","_interopRequireDefault","_highstock","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","FloatingGraph","_ref","isOpen","_ref$customHighChartO","customHighChartOptions","globalDataFloatingGraph","event_data","closeGraphHandler","_useState","useState","_useState2","_slicedToArray2","minimized","setMinimized","Highcharts","setOptions","lang","rangeSelectorZoom","graphTitle","point","group","name","matchGraph","_observation","_observation2","_observation3","timeGapFromEvent","graphData","observation","pointId","point_id","id","plotFrom","start_time","plotTo","last_seen_time","observations","find","o","first_seen_observation_id","_objectSpread2","startTime","endTime","noObservation","displayResetZoomButton","createElement","minimizeGraphHandler","prevState","className","concat","onClick","_default","exports"],"sources":["../../../../src/pages/EventsPage/FloatingGraph/FloatingGraph.tsx"],"sourcesContent":["import React, { useState } from 'react';\nimport Graph from 'src/components/Graph';\nimport './floatingGraphStyle.scss';\nimport Highcharts from 'highcharts/highstock';\n\ntype IProps = {\n  customHighChartOptions?: Highcharts.Options;\n  globalDataFloatingGraph?: { [key: string]: any };\n  event_data?: any;\n  closeGraphHandler: Function;\n  graphId: string;\n  isOpen?: boolean;\n};\n\nconst FloatingGraph: React.FC<IProps> = ({\n  isOpen,\n  customHighChartOptions = {},\n  globalDataFloatingGraph,\n  event_data,\n  closeGraphHandler,\n}) => {\n  const [minimized, setMinimized] = useState<boolean>(false);\n  Highcharts.setOptions({\n    lang: {\n      rangeSelectorZoom: '',\n    },\n  });\n  const graphTitle = isOpen ? globalDataFloatingGraph?.point.group.name : '';\n\n  const matchGraph = () => {\n    const timeGapFromEvent = 86400 * 31 * 2; // 2 months\n    let graphData: any = {};\n    let observation = globalDataFloatingGraph?.observation;\n    graphData.pointId =\n      observation?.point_id || globalDataFloatingGraph?.point.id;\n\n    let plotFrom = observation?.start_time || 0;\n    let plotTo = observation?.last_seen_time || 0;\n\n    // even if we find an observation, do not show its plot on the graph\n    if (!observation && event_data?.observations) {\n      observation = event_data.observations.find(\n        (o) => o.id === event_data?.first_seen_observation_id,\n      );\n    }\n\n    graphData = {\n      ...graphData,\n      startTime: observation.start_time - timeGapFromEvent,\n      endTime: observation.last_seen_time + timeGapFromEvent,\n      noObservation: observation ? false : true,\n      customHighChartOptions: customHighChartOptions,\n      displayResetZoomButton: true,\n    };\n\n    if (plotFrom >= 0 && plotTo > 0) {\n      graphData = {\n        ...graphData,\n        plotFrom: plotFrom,\n        plotTo: plotTo,\n      };\n    }\n    return <Graph {...graphData} />;\n  };\n  const minimizeGraphHandler = () => {\n    setMinimized((prevState) => !prevState);\n  };\n\n  if (!isOpen) {\n    return null;\n  }\n  return (\n    <div className={`floating-graph ${minimized ? 'minimized' : ''}`}>\n      <div\n        className=\"floating-graph__close\"\n        onClick={() => closeGraphHandler()}\n      ></div>\n      <div\n        className=\"floating-graph__minimize\"\n        onClick={() => minimizeGraphHandler()}\n      ></div>\n      <div className=\"graph-ttl\">{graphTitle}</div>\n      <div className=\"high-chart-wrapper\">{matchGraph()}</div>\n    </div>\n  );\n};\n\nexport default FloatingGraph;\n"],"mappings":";;;;;;;;;;AAAA,IAAAA,MAAA,GAAAC,uBAAA,CAAAC,OAAA;AACA,IAAAC,MAAA,GAAAC,sBAAA,CAAAF,OAAA;AACAA,OAAA;AACA,IAAAG,UAAA,GAAAD,sBAAA,CAAAF,OAAA;AAA8C,SAAAI,yBAAAC,WAAA,eAAAC,OAAA,kCAAAC,iBAAA,OAAAD,OAAA,QAAAE,gBAAA,OAAAF,OAAA,YAAAF,wBAAA,YAAAA,yBAAAC,WAAA,WAAAA,WAAA,GAAAG,gBAAA,GAAAD,iBAAA,KAAAF,WAAA;AAAA,SAAAN,wBAAAU,GAAA,EAAAJ,WAAA,SAAAA,WAAA,IAAAI,GAAA,IAAAA,GAAA,CAAAC,UAAA,WAAAD,GAAA,QAAAA,GAAA,aAAAE,OAAA,CAAAF,GAAA,yBAAAA,GAAA,4BAAAG,OAAA,EAAAH,GAAA,UAAAI,KAAA,GAAAT,wBAAA,CAAAC,WAAA,OAAAQ,KAAA,IAAAA,KAAA,CAAAC,GAAA,CAAAL,GAAA,YAAAI,KAAA,CAAAE,GAAA,CAAAN,GAAA,SAAAO,MAAA,WAAAC,qBAAA,GAAAC,MAAA,CAAAC,cAAA,IAAAD,MAAA,CAAAE,wBAAA,WAAAC,GAAA,IAAAZ,GAAA,QAAAY,GAAA,kBAAAH,MAAA,CAAAI,SAAA,CAAAC,cAAA,CAAAC,IAAA,CAAAf,GAAA,EAAAY,GAAA,SAAAI,IAAA,GAAAR,qBAAA,GAAAC,MAAA,CAAAE,wBAAA,CAAAX,GAAA,EAAAY,GAAA,cAAAI,IAAA,KAAAA,IAAA,CAAAV,GAAA,IAAAU,IAAA,CAAAC,GAAA,KAAAR,MAAA,CAAAC,cAAA,CAAAH,MAAA,EAAAK,GAAA,EAAAI,IAAA,YAAAT,MAAA,CAAAK,GAAA,IAAAZ,GAAA,CAAAY,GAAA,SAAAL,MAAA,CAAAJ,OAAA,GAAAH,GAAA,MAAAI,KAAA,IAAAA,KAAA,CAAAa,GAAA,CAAAjB,GAAA,EAAAO,MAAA,YAAAA,MAAA;AAW9C,IAAMW,aAA+B,GAAG,SAAlCA,aAA+BA,CAAAC,IAAA,EAM/B;EAAA,IALJC,MAAM,GAAAD,IAAA,CAANC,MAAM;IAAAC,qBAAA,GAAAF,IAAA,CACNG,sBAAsB;IAAtBA,sBAAsB,GAAAD,qBAAA,cAAG,CAAC,CAAC,GAAAA,qBAAA;IAC3BE,uBAAuB,GAAAJ,IAAA,CAAvBI,uBAAuB;IACvBC,UAAU,GAAAL,IAAA,CAAVK,UAAU;IACVC,iBAAiB,GAAAN,IAAA,CAAjBM,iBAAiB;EAEjB,IAAAC,SAAA,GAAkC,IAAAC,eAAQ,EAAU,KAAK,CAAC;IAAAC,UAAA,OAAAC,eAAA,CAAA1B,OAAA,EAAAuB,SAAA;IAAnDI,SAAS,GAAAF,UAAA;IAAEG,YAAY,GAAAH,UAAA;EAC9BI,kBAAU,CAACC,UAAU,CAAC;IACpBC,IAAI,EAAE;MACJC,iBAAiB,EAAE;IACrB;EACF,CAAC,CAAC;EACF,IAAMC,UAAU,GAAGhB,MAAM,GAAGG,uBAAuB,aAAvBA,uBAAuB,uBAAvBA,uBAAuB,CAAEc,KAAK,CAACC,KAAK,CAACC,IAAI,GAAG,EAAE;EAE1E,IAAMC,UAAU,GAAG,SAAbA,UAAUA,CAAA,EAAS;IAAA,IAAAC,YAAA,EAAAC,aAAA,EAAAC,aAAA;IACvB,IAAMC,gBAAgB,GAAG,KAAK,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;IACzC,IAAIC,SAAc,GAAG,CAAC,CAAC;IACvB,IAAIC,WAAW,GAAGvB,uBAAuB,aAAvBA,uBAAuB,uBAAvBA,uBAAuB,CAAEuB,WAAW;IACtDD,SAAS,CAACE,OAAO,GACf,EAAAN,YAAA,GAAAK,WAAW,cAAAL,YAAA,uBAAXA,YAAA,CAAaO,QAAQ,MAAIzB,uBAAuB,aAAvBA,uBAAuB,uBAAvBA,uBAAuB,CAAEc,KAAK,CAACY,EAAE;IAE5D,IAAIC,QAAQ,GAAG,EAAAR,aAAA,GAAAI,WAAW,cAAAJ,aAAA,uBAAXA,aAAA,CAAaS,UAAU,KAAI,CAAC;IAC3C,IAAIC,MAAM,GAAG,EAAAT,aAAA,GAAAG,WAAW,cAAAH,aAAA,uBAAXA,aAAA,CAAaU,cAAc,KAAI,CAAC;;IAE7C;IACA,IAAI,CAACP,WAAW,KAAItB,UAAU,aAAVA,UAAU,uBAAVA,UAAU,CAAE8B,YAAY,GAAE;MAC5CR,WAAW,GAAGtB,UAAU,CAAC8B,YAAY,CAACC,IAAI,CACxC,UAACC,CAAC;QAAA,OAAKA,CAAC,CAACP,EAAE,MAAKzB,UAAU,aAAVA,UAAU,uBAAVA,UAAU,CAAEiC,yBAAyB;MAAA,CACvD,CAAC;IACH;IAEAZ,SAAS,OAAAa,cAAA,CAAAvD,OAAA,MAAAuD,cAAA,CAAAvD,OAAA,MACJ0C,SAAS;MACZc,SAAS,EAAEb,WAAW,CAACK,UAAU,GAAGP,gBAAgB;MACpDgB,OAAO,EAAEd,WAAW,CAACO,cAAc,GAAGT,gBAAgB;MACtDiB,aAAa,EAAEf,WAAW,GAAG,KAAK,GAAG,IAAI;MACzCxB,sBAAsB,EAAEA,sBAAsB;MAC9CwC,sBAAsB,EAAE;IAAI,EAC7B;IAED,IAAIZ,QAAQ,IAAI,CAAC,IAAIE,MAAM,GAAG,CAAC,EAAE;MAC/BP,SAAS,OAAAa,cAAA,CAAAvD,OAAA,MAAAuD,cAAA,CAAAvD,OAAA,MACJ0C,SAAS;QACZK,QAAQ,EAAEA,QAAQ;QAClBE,MAAM,EAAEA;MAAM,EACf;IACH;IACA,oBAAO/D,MAAA,CAAAc,OAAA,CAAA4D,aAAA,CAACvE,MAAA,CAAAW,OAAK,EAAK0C,SAAY,CAAC;EACjC,CAAC;EACD,IAAMmB,oBAAoB,GAAG,SAAvBA,oBAAoBA,CAAA,EAAS;IACjCjC,YAAY,CAAC,UAACkC,SAAS;MAAA,OAAK,CAACA,SAAS;IAAA,EAAC;EACzC,CAAC;EAED,IAAI,CAAC7C,MAAM,EAAE;IACX,OAAO,IAAI;EACb;EACA,oBACE/B,MAAA,CAAAc,OAAA,CAAA4D,aAAA;IAAKG,SAAS,oBAAAC,MAAA,CAAoBrC,SAAS,GAAG,WAAW,GAAG,EAAE;EAAG,gBAC/DzC,MAAA,CAAAc,OAAA,CAAA4D,aAAA;IACEG,SAAS,EAAC,uBAAuB;IACjCE,OAAO,EAAE,SAAAA,QAAA;MAAA,OAAM3C,iBAAiB,CAAC,CAAC;IAAA;EAAC,CAC/B,CAAC,eACPpC,MAAA,CAAAc,OAAA,CAAA4D,aAAA;IACEG,SAAS,EAAC,0BAA0B;IACpCE,OAAO,EAAE,SAAAA,QAAA;MAAA,OAAMJ,oBAAoB,CAAC,CAAC;IAAA;EAAC,CAClC,CAAC,eACP3E,MAAA,CAAAc,OAAA,CAAA4D,aAAA;IAAKG,SAAS,EAAC;EAAW,GAAE9B,UAAgB,CAAC,eAC7C/C,MAAA,CAAAc,OAAA,CAAA4D,aAAA;IAAKG,SAAS,EAAC;EAAoB,GAAE1B,UAAU,CAAC,CAAO,CACpD,CAAC;AAEV,CAAC;AAAC,IAAA6B,QAAA,GAEanD,aAAa;AAAAoD,OAAA,CAAAnE,OAAA,GAAAkE,QAAA"}
@@ -39,7 +39,7 @@ var ImportSiteProcess = function ImportSiteProcess() {
39
39
  submitURL: submitURL
40
40
  }, /*#__PURE__*/_react.default.createElement(_reactBootstrap.Alert, {
41
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: '), 'Kando_tree', /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("u", null, 'For location:(One of the following options)'), /*#__PURE__*/_react.default.createElement("br", null), '1. Lat_loc - latitude, Lng_loc - longitude', /*#__PURE__*/_react.default.createElement("br", null), '2. address - location name', /*#__PURE__*/_react.default.createElement("br", null), '3. split address: street, street_number, city, zipcode, country(At least city)'), /*#__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, 'For site type: (default Factory)'), /*#__PURE__*/_react.default.createElement("br", null), 'site_type(WWTP, Factory, Pipe, Collectors, PumpStation, WaterLevel)', /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("u", null, 'Extra data:'), /*#__PURE__*/_react.default.createElement("br", null), 'd_water_c, water_discharge, Diameter, Slop, Depth, Width, pop_size')), /*#__PURE__*/_react.default.createElement(_uiKit.MobileInput, {
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: '), 'Kando_tree', /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("u", null, 'For location:(One of the following options)'), /*#__PURE__*/_react.default.createElement("br", null), '1. Lat_loc - latitude, Lng_loc - longitude', /*#__PURE__*/_react.default.createElement("br", null), '2. address - location name', /*#__PURE__*/_react.default.createElement("br", null), '3. split address: street, street_number, city, zipcode, country(At least city)'), /*#__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, 'For site type: (default Factory)'), /*#__PURE__*/_react.default.createElement("br", null), 'site_type(WWTP, Factory, Pipe, Collectors, PumpStation, WaterLevel)', /*#__PURE__*/_react.default.createElement("br", null), /*#__PURE__*/_react.default.createElement("u", null, 'Extra data:'), /*#__PURE__*/_react.default.createElement("br", null), 'd_water_c, water_discharge, Diameter, Slop, Depth, Width, pop_size, Installation')), /*#__PURE__*/_react.default.createElement(_uiKit.MobileInput, {
43
43
  isInvalid: false,
44
44
  handleChange: fileTitleChangedHandler,
45
45
  inputTitle: _i18n.default.t('import_gis_process.title_input_label'),
@@ -52,4 +52,4 @@ var ImportSiteProcess = function ImportSiteProcess() {
52
52
  };
53
53
  var _default = ImportSiteProcess;
54
54
  exports.default = _default;
55
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_ImportFileWizard","_interopRequireDefault","require","_urls","_reactRedux","_react","_uiKit","_i18n","_actionsCreator","_reactBootstrap","ImportSiteProcess","dispatch","useDispatch","waterAuthorityId","useSelector","state","global_data","_useSelector","importGis","uploadingFile","submitURL","urls","importSiteFile","newFile","url","validationURL","validateFile","fileTitleChangedHandler","event","setFileTitle","target","value","default","createElement","acceptType","title","navContext","Alert","variant","MobileInput","isInvalid","handleChange","inputTitle","i18n","t","placeholder","fileTitle","type","name","mandatory","_default","exports"],"sources":["../../../src/pages/ImportSiteProcess/index.tsx"],"sourcesContent":["import ImportFile from 'src/pages/ImportFileWizard';\nimport { urls } from 'src/utilities/urls';\nimport { useDispatch, useSelector } from 'react-redux';\nimport React from 'react';\nimport { MobileInput } from 'src/ui-kit';\nimport i18n from 'src/utilities/i18n';\nimport { setFileTitle } from 'src/store/ImportGis/actionsCreator';\nimport { appReducer } from 'src/store/rootReducer';\nimport { Alert } from 'react-bootstrap';\n\nconst ImportSiteProcess = () => {\n  const dispatch = useDispatch();\n  const waterAuthorityId = useSelector(\n    (state) => state.global_data.waterAuthorityId,\n  );\n  const { uploadingFile } = useSelector(\n    (state: ReturnType<typeof appReducer>) => state.importGis,\n  );\n  const submitURL = urls({ waterAuthorityId }).importSiteFile.newFile.url;\n  const validationURL = urls({ waterAuthorityId }).importSiteFile.validateFile\n    .url;\n  const fileTitleChangedHandler = (event) => {\n    dispatch(setFileTitle(event.target.value));\n  };\n  return (\n    <ImportFile\n      acceptType={'csv'}\n      title={'import_site_process.title'}\n      navContext={'import_site_process'}\n      validationURL={validationURL}\n      submitURL={submitURL}\n    >\n      <Alert variant=\"info\">\n        <h4>{'Upload a csv file with the following columns'}</h4>\n        <div>\n          <b>{'Mandatory fields: '}</b>\n          {'Kando_tree'}\n          <br />\n          <u>{'For location:(One of the following options)'}</u>\n          <br />\n          {'1. Lat_loc - latitude, Lng_loc - longitude'}\n          <br />\n          {'2. address - location name'}\n          <br />\n          {\n            '3. split address: street, street_number, city, zipcode, country(At least city)'\n          }\n        </div>\n        <div>\n          <b>{'Optional fields: '}</b>\n          <br />\n          <u>{'For sector:'}</u>\n          <br />\n          {'1. activity - factory activity'}\n          <br />\n          {'2. nace - nace code'}\n          <br />\n          {'3. naics - naics code'}\n          <br />\n          {'4. sic - SIC code'}\n          <br />\n          {'5. Sector - for the exact kando sector name'}\n          <br />\n          <u>{'For site type: (default Factory)'}</u>\n          <br />\n          {\n            'site_type(WWTP, Factory, Pipe, Collectors, PumpStation, WaterLevel)'\n          }\n          <br />\n          <u>{'Extra data:'}</u>\n          <br />\n          {'d_water_c, water_discharge, Diameter, Slop, Depth, Width, pop_size'}\n        </div>\n      </Alert>\n      <MobileInput\n        isInvalid={false}\n        handleChange={fileTitleChangedHandler}\n        inputTitle={i18n.t('import_gis_process.title_input_label')}\n        placeholder={i18n.t('import_gis_process.title_input_placeholder')}\n        value={uploadingFile.fileTitle}\n        type=\"text\"\n        name=\"fileTitle\"\n        mandatory={true}\n      />\n    </ImportFile>\n  );\n};\n\nexport default ImportSiteProcess;\n"],"mappings":"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"}
55
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_ImportFileWizard","_interopRequireDefault","require","_urls","_reactRedux","_react","_uiKit","_i18n","_actionsCreator","_reactBootstrap","ImportSiteProcess","dispatch","useDispatch","waterAuthorityId","useSelector","state","global_data","_useSelector","importGis","uploadingFile","submitURL","urls","importSiteFile","newFile","url","validationURL","validateFile","fileTitleChangedHandler","event","setFileTitle","target","value","default","createElement","acceptType","title","navContext","Alert","variant","MobileInput","isInvalid","handleChange","inputTitle","i18n","t","placeholder","fileTitle","type","name","mandatory","_default","exports"],"sources":["../../../src/pages/ImportSiteProcess/index.tsx"],"sourcesContent":["import ImportFile from 'src/pages/ImportFileWizard';\nimport { urls } from 'src/utilities/urls';\nimport { useDispatch, useSelector } from 'react-redux';\nimport React from 'react';\nimport { MobileInput } from 'src/ui-kit';\nimport i18n from 'src/utilities/i18n';\nimport { setFileTitle } from 'src/store/ImportGis/actionsCreator';\nimport { appReducer } from 'src/store/rootReducer';\nimport { Alert } from 'react-bootstrap';\n\nconst ImportSiteProcess = () => {\n  const dispatch = useDispatch();\n  const waterAuthorityId = useSelector(\n    (state) => state.global_data.waterAuthorityId,\n  );\n  const { uploadingFile } = useSelector(\n    (state: ReturnType<typeof appReducer>) => state.importGis,\n  );\n  const submitURL = urls({ waterAuthorityId }).importSiteFile.newFile.url;\n  const validationURL = urls({ waterAuthorityId }).importSiteFile.validateFile\n    .url;\n  const fileTitleChangedHandler = (event) => {\n    dispatch(setFileTitle(event.target.value));\n  };\n  return (\n    <ImportFile\n      acceptType={'csv'}\n      title={'import_site_process.title'}\n      navContext={'import_site_process'}\n      validationURL={validationURL}\n      submitURL={submitURL}\n    >\n      <Alert variant=\"info\">\n        <h4>{'Upload a csv file with the following columns'}</h4>\n        <div>\n          <b>{'Mandatory fields: '}</b>\n          {'Kando_tree'}\n          <br />\n          <u>{'For location:(One of the following options)'}</u>\n          <br />\n          {'1. Lat_loc - latitude, Lng_loc - longitude'}\n          <br />\n          {'2. address - location name'}\n          <br />\n          {\n            '3. split address: street, street_number, city, zipcode, country(At least city)'\n          }\n        </div>\n        <div>\n          <b>{'Optional fields: '}</b>\n          <br />\n          <u>{'For sector:'}</u>\n          <br />\n          {'1. activity - factory activity'}\n          <br />\n          {'2. nace - nace code'}\n          <br />\n          {'3. naics - naics code'}\n          <br />\n          {'4. sic - SIC code'}\n          <br />\n          {'5. Sector - for the exact kando sector name'}\n          <br />\n          <u>{'For site type: (default Factory)'}</u>\n          <br />\n          {\n            'site_type(WWTP, Factory, Pipe, Collectors, PumpStation, WaterLevel)'\n          }\n          <br />\n          <u>{'Extra data:'}</u>\n          <br />\n          {\n            'd_water_c, water_discharge, Diameter, Slop, Depth, Width, pop_size, Installation'\n          }\n        </div>\n      </Alert>\n      <MobileInput\n        isInvalid={false}\n        handleChange={fileTitleChangedHandler}\n        inputTitle={i18n.t('import_gis_process.title_input_label')}\n        placeholder={i18n.t('import_gis_process.title_input_placeholder')}\n        value={uploadingFile.fileTitle}\n        type=\"text\"\n        name=\"fileTitle\"\n        mandatory={true}\n      />\n    </ImportFile>\n  );\n};\n\nexport default ImportSiteProcess;\n"],"mappings":";;;;;;;AAAA,IAAAA,iBAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,KAAA,GAAAD,OAAA;AACA,IAAAE,WAAA,GAAAF,OAAA;AACA,IAAAG,MAAA,GAAAJ,sBAAA,CAAAC,OAAA;AACA,IAAAI,MAAA,GAAAJ,OAAA;AACA,IAAAK,KAAA,GAAAN,sBAAA,CAAAC,OAAA;AACA,IAAAM,eAAA,GAAAN,OAAA;AAEA,IAAAO,eAAA,GAAAP,OAAA;AAEA,IAAMQ,iBAAiB,GAAG,SAApBA,iBAAiBA,CAAA,EAAS;EAC9B,IAAMC,QAAQ,GAAG,IAAAC,uBAAW,EAAC,CAAC;EAC9B,IAAMC,gBAAgB,GAAG,IAAAC,uBAAW,EAClC,UAACC,KAAK;IAAA,OAAKA,KAAK,CAACC,WAAW,CAACH,gBAAgB;EAAA,CAC/C,CAAC;EACD,IAAAI,YAAA,GAA0B,IAAAH,uBAAW,EACnC,UAACC,KAAoC;MAAA,OAAKA,KAAK,CAACG,SAAS;IAAA,CAC3D,CAAC;IAFOC,aAAa,GAAAF,YAAA,CAAbE,aAAa;EAGrB,IAAMC,SAAS,GAAG,IAAAC,UAAI,EAAC;IAAER,gBAAgB,EAAhBA;EAAiB,CAAC,CAAC,CAACS,cAAc,CAACC,OAAO,CAACC,GAAG;EACvE,IAAMC,aAAa,GAAG,IAAAJ,UAAI,EAAC;IAAER,gBAAgB,EAAhBA;EAAiB,CAAC,CAAC,CAACS,cAAc,CAACI,YAAY,CACzEF,GAAG;EACN,IAAMG,uBAAuB,GAAG,SAA1BA,uBAAuBA,CAAIC,KAAK,EAAK;IACzCjB,QAAQ,CAAC,IAAAkB,4BAAY,EAACD,KAAK,CAACE,MAAM,CAACC,KAAK,CAAC,CAAC;EAC5C,CAAC;EACD,oBACE1B,MAAA,CAAA2B,OAAA,CAAAC,aAAA,CAACjC,iBAAA,CAAAgC,OAAU;IACTE,UAAU,EAAE,KAAM;IAClBC,KAAK,EAAE,2BAA4B;IACnCC,UAAU,EAAE,qBAAsB;IAClCX,aAAa,EAAEA,aAAc;IAC7BL,SAAS,EAAEA;EAAU,gBAErBf,MAAA,CAAA2B,OAAA,CAAAC,aAAA,CAACxB,eAAA,CAAA4B,KAAK;IAACC,OAAO,EAAC;EAAM,gBACnBjC,MAAA,CAAA2B,OAAA,CAAAC,aAAA,aAAK,8CAAmD,CAAC,eACzD5B,MAAA,CAAA2B,OAAA,CAAAC,aAAA,2BACE5B,MAAA,CAAA2B,OAAA,CAAAC,aAAA,YAAI,oBAAwB,CAAC,EAC5B,YAAY,eACb5B,MAAA,CAAA2B,OAAA,CAAAC,aAAA,WAAK,CAAC,eACN5B,MAAA,CAAA2B,OAAA,CAAAC,aAAA,YAAI,6CAAiD,CAAC,eACtD5B,MAAA,CAAA2B,OAAA,CAAAC,aAAA,WAAK,CAAC,EACL,4CAA4C,eAC7C5B,MAAA,CAAA2B,OAAA,CAAAC,aAAA,WAAK,CAAC,EACL,4BAA4B,eAC7B5B,MAAA,CAAA2B,OAAA,CAAAC,aAAA,WAAK,CAAC,EAEJ,gFAEC,CAAC,eACN5B,MAAA,CAAA2B,OAAA,CAAAC,aAAA,2BACE5B,MAAA,CAAA2B,OAAA,CAAAC,aAAA,YAAI,mBAAuB,CAAC,eAC5B5B,MAAA,CAAA2B,OAAA,CAAAC,aAAA,WAAK,CAAC,eACN5B,MAAA,CAAA2B,OAAA,CAAAC,aAAA,YAAI,aAAiB,CAAC,eACtB5B,MAAA,CAAA2B,OAAA,CAAAC,aAAA,WAAK,CAAC,EACL,gCAAgC,eACjC5B,MAAA,CAAA2B,OAAA,CAAAC,aAAA,WAAK,CAAC,EACL,qBAAqB,eACtB5B,MAAA,CAAA2B,OAAA,CAAAC,aAAA,WAAK,CAAC,EACL,uBAAuB,eACxB5B,MAAA,CAAA2B,OAAA,CAAAC,aAAA,WAAK,CAAC,EACL,mBAAmB,eACpB5B,MAAA,CAAA2B,OAAA,CAAAC,aAAA,WAAK,CAAC,EACL,6CAA6C,eAC9C5B,MAAA,CAAA2B,OAAA,CAAAC,aAAA,WAAK,CAAC,eACN5B,MAAA,CAAA2B,OAAA,CAAAC,aAAA,YAAI,kCAAsC,CAAC,eAC3C5B,MAAA,CAAA2B,OAAA,CAAAC,aAAA,WAAK,CAAC,EAEJ,qEAAqE,eAEvE5B,MAAA,CAAA2B,OAAA,CAAAC,aAAA,WAAK,CAAC,eACN5B,MAAA,CAAA2B,OAAA,CAAAC,aAAA,YAAI,aAAiB,CAAC,eACtB5B,MAAA,CAAA2B,OAAA,CAAAC,aAAA,WAAK,CAAC,EAEJ,kFAEC,CACA,CAAC,eACR5B,MAAA,CAAA2B,OAAA,CAAAC,aAAA,CAAC3B,MAAA,CAAAiC,WAAW;IACVC,SAAS,EAAE,KAAM;IACjBC,YAAY,EAAEd,uBAAwB;IACtCe,UAAU,EAAEC,aAAI,CAACC,CAAC,CAAC,sCAAsC,CAAE;IAC3DC,WAAW,EAAEF,aAAI,CAACC,CAAC,CAAC,4CAA4C,CAAE;IAClEb,KAAK,EAAEZ,aAAa,CAAC2B,SAAU;IAC/BC,IAAI,EAAC,MAAM;IACXC,IAAI,EAAC,WAAW;IAChBC,SAAS,EAAE;EAAK,CACjB,CACS,CAAC;AAEjB,CAAC;AAAC,IAAAC,QAAA,GAEaxC,iBAAiB;AAAAyC,OAAA,CAAAnB,OAAA,GAAAkB,QAAA"}