@kando-env/kando-ui 1.2.466-alpha.4 → 1.2.466-alpha.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/Router.js +6 -4
- package/lib/Widgets/MostPolluting/components/PotentialImpact.test.js +1 -2
- package/lib/Widgets/PotentialImpactSummary/Icon.js +1 -2
- package/lib/components/DamageType/DamageType.js +3 -3
- package/lib/components/Header/Toolbar/Toolbar.js +1 -3
- package/lib/components/KandoModal/KandoModal.js +24 -4
- package/lib/components/SeasonalInsights/SeasonalInsights.js +150 -0
- package/lib/components/TopBanner/TopBanner.js +208 -0
- package/lib/components/TrendGraphNVL/TrendGraphNVL.js +1 -2
- package/lib/i18n/en.json +3 -0
- package/lib/i18n/he.json +3 -0
- package/lib/macros/getVersion.js +1 -1
- package/lib/pages/CovidPage/components/TrendGraphNVL/TrendGraphNVL.js +1 -2
- package/lib/pages/EventsPage/EventsMapContainer/EventsMapContainerHelpers.js +1 -2
- package/lib/pages/EventsPage/events/events_list/Filter/FilterContainer.js +3 -3
- package/lib/utilities/Enum.js +4 -4
- package/package.json +1 -1
|
@@ -19,6 +19,7 @@ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj &&
|
|
|
19
19
|
docs: https://react-responsive-modal.leopradel.com/
|
|
20
20
|
*/
|
|
21
21
|
var KandoModal = function KandoModal(_ref) {
|
|
22
|
+
var _document$documentEle;
|
|
22
23
|
var _ref$isOpen = _ref.isOpen,
|
|
23
24
|
isOpen = _ref$isOpen === void 0 ? false : _ref$isOpen,
|
|
24
25
|
buttonLabel = _ref.buttonLabel,
|
|
@@ -27,18 +28,26 @@ var KandoModal = function KandoModal(_ref) {
|
|
|
27
28
|
children = _ref.children,
|
|
28
29
|
type = _ref.type,
|
|
29
30
|
openerClass = _ref.openerClass,
|
|
30
|
-
handleButtonClick = _ref.handleButtonClick
|
|
31
|
+
handleButtonClick = _ref.handleButtonClick,
|
|
32
|
+
onClose = _ref.onClose,
|
|
33
|
+
_ref$hideOpener = _ref.hideOpener,
|
|
34
|
+
hideOpener = _ref$hideOpener === void 0 ? false : _ref$hideOpener,
|
|
35
|
+
dir = _ref.dir;
|
|
31
36
|
var containerRef = _react.default.useRef(null);
|
|
32
37
|
var _useState = (0, _react.useState)(isOpen),
|
|
33
38
|
_useState2 = (0, _slicedToArray2.default)(_useState, 2),
|
|
34
39
|
open = _useState2[0],
|
|
35
40
|
setOpen = _useState2[1];
|
|
41
|
+
(0, _react.useEffect)(function () {
|
|
42
|
+
setOpen(isOpen);
|
|
43
|
+
}, [isOpen]);
|
|
36
44
|
var onOpenModal = function onOpenModal() {
|
|
37
45
|
return setOpen(true);
|
|
38
46
|
};
|
|
39
47
|
var onCloseModal = function onCloseModal() {
|
|
40
48
|
setOpen(false);
|
|
41
49
|
clearHistory();
|
|
50
|
+
if (onClose) onClose();
|
|
42
51
|
};
|
|
43
52
|
var queryURL = (0, _useQueryURL.default)();
|
|
44
53
|
var handleClick = function handleClick() {
|
|
@@ -77,7 +86,15 @@ var KandoModal = function KandoModal(_ref) {
|
|
|
77
86
|
updateHistory();
|
|
78
87
|
}
|
|
79
88
|
}, [open]);
|
|
80
|
-
|
|
89
|
+
var resolvedDir = dir || (typeof document !== 'undefined' && ((_document$documentEle = document.documentElement) === null || _document$documentEle === void 0 ? void 0 : _document$documentEle.dir) === 'rtl' ? 'rtl' : 'ltr');
|
|
90
|
+
var isRtl = resolvedDir === 'rtl';
|
|
91
|
+
var modalStyles = isRtl ? {
|
|
92
|
+
closeButton: {
|
|
93
|
+
left: '14px',
|
|
94
|
+
right: 'auto'
|
|
95
|
+
}
|
|
96
|
+
} : undefined;
|
|
97
|
+
return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, !hideOpener && /*#__PURE__*/_react.default.createElement("div", {
|
|
81
98
|
className: "kmodal__opener kmodal__opener--".concat(openerClass),
|
|
82
99
|
onClick: function onClick() {
|
|
83
100
|
return handleClick();
|
|
@@ -87,12 +104,15 @@ var KandoModal = function KandoModal(_ref) {
|
|
|
87
104
|
center: true,
|
|
88
105
|
open: open,
|
|
89
106
|
onClose: onCloseModal,
|
|
107
|
+
styles: modalStyles,
|
|
90
108
|
classNames: {
|
|
91
109
|
overlay: 'kmodal__overlay',
|
|
92
110
|
modal: "kmodal kmodal--type-".concat(type)
|
|
93
111
|
}
|
|
94
|
-
},
|
|
112
|
+
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
113
|
+
dir: resolvedDir
|
|
114
|
+
}, children)));
|
|
95
115
|
};
|
|
96
116
|
var _default = KandoModal;
|
|
97
117
|
exports.default = _default;
|
|
98
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_lodash","_reactResponsiveModal","_useQueryURL","_interopRequireDefault","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","KandoModal","_ref","_ref$isOpen","isOpen","buttonLabel","_ref$changeHistory","changeHistory","children","type","openerClass","handleButtonClick","containerRef","React","useRef","_useState","useState","_useState2","_slicedToArray2","open","setOpen","onOpenModal","onCloseModal","clearHistory","queryURL","useQueryURL","handleClick","undefined","updateHistory","isEmpty","_i","_Object$entries","entries","length","_Object$entries$_i","param","value","window","history","replaceState","concat","location","pathname","_i2","_Object$entries2","_Object$entries2$_i","delete","useEffect","createElement","Fragment","className","onClick","Modal","container","current","center","onClose","classNames","overlay","modal","_default","exports"],"sources":["../../../src/components/KandoModal/KandoModal.tsx"],"sourcesContent":["import React, { ReactElement, useEffect, useState } from 'react';\nimport { isEmpty } from 'lodash';\nimport { Modal } from 'react-responsive-modal';\nimport 'react-responsive-modal/styles.css';\n\nimport useQueryURL from 'src/hooks/useQueryURL';\n\nimport './styles.scss';\n\ntype IKandoModal = React.PropsWithChildren<{\n  isOpen?: boolean;\n  openerClass?: string;\n  buttonLabel?: string | ReactElement;\n  changeHistory?: Object;\n  type?: string;\n  handleButtonClick?: Function;\n}>;\n\n/* Wrapper around Modal,\n   docs: https://react-responsive-modal.leopradel.com/\n*/\nconst KandoModal: React.FC<IKandoModal> = ({\n  isOpen = false,\n  buttonLabel,\n  changeHistory = {},\n  children,\n  type,\n  openerClass,\n  handleButtonClick,\n}) => {\n  const containerRef = React.useRef(null);\n  const [open, setOpen] = useState(isOpen);\n  const onOpenModal = () => setOpen(true);\n  const onCloseModal = () => {\n    setOpen(false);\n    clearHistory();\n  };\n  const queryURL = useQueryURL();\n  const handleClick = () => {\n    if (handleButtonClick !== undefined) {\n      handleButtonClick!();\n    }\n    onOpenModal();\n  };\n\n  // add changeHistory's param=value to the URL\n  function updateHistory() {\n    if (!isEmpty(changeHistory)) {\n      for (const [param, value] of Object.entries(changeHistory)) {\n        queryURL.set(param, value);\n        window.history.replaceState(\n          {},\n          '',\n          `${window.location.pathname}?${queryURL}`,\n        );\n      }\n    }\n  }\n\n  // Remove\n  function clearHistory() {\n    if (!isEmpty(changeHistory)) {\n      for (const [param] of Object.entries(changeHistory)) {\n        queryURL.delete(param);\n        window.history.replaceState(\n          {},\n          '',\n          `${window.location.pathname}?${queryURL}`,\n        );\n      }\n    }\n  }\n\n  useEffect(() => {\n    if (open) {\n      updateHistory();\n    }\n  }, [open]);\n\n  return (\n    <>\n      <div\n        className={`kmodal__opener kmodal__opener--${openerClass}`}\n        onClick={() => handleClick()}\n      >\n        {buttonLabel}\n      </div>\n      <Modal\n        container={containerRef.current}\n        center\n        open={open}\n        onClose={onCloseModal}\n        classNames={{\n          overlay: 'kmodal__overlay',\n          modal: `kmodal kmodal--type-${type}`,\n        }}\n      >\n        {children}\n      </Modal>\n    </>\n  );\n};\n\nexport default KandoModal;\n"],"mappings":"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"}
|
|
118
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_lodash","_reactResponsiveModal","_useQueryURL","_interopRequireDefault","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","KandoModal","_ref","_document$documentEle","_ref$isOpen","isOpen","buttonLabel","_ref$changeHistory","changeHistory","children","type","openerClass","handleButtonClick","onClose","_ref$hideOpener","hideOpener","dir","containerRef","React","useRef","_useState","useState","_useState2","_slicedToArray2","open","setOpen","useEffect","onOpenModal","onCloseModal","clearHistory","queryURL","useQueryURL","handleClick","undefined","updateHistory","isEmpty","_i","_Object$entries","entries","length","_Object$entries$_i","param","value","window","history","replaceState","concat","location","pathname","_i2","_Object$entries2","_Object$entries2$_i","delete","resolvedDir","document","documentElement","isRtl","modalStyles","closeButton","left","right","createElement","Fragment","className","onClick","Modal","container","current","center","styles","classNames","overlay","modal","_default","exports"],"sources":["../../../src/components/KandoModal/KandoModal.tsx"],"sourcesContent":["import React, { ReactElement, useEffect, useState } from 'react';\nimport { isEmpty } from 'lodash';\nimport { Modal } from 'react-responsive-modal';\nimport 'react-responsive-modal/styles.css';\n\nimport useQueryURL from 'src/hooks/useQueryURL';\n\nimport './styles.scss';\n\ntype IKandoModal = React.PropsWithChildren<{\n  isOpen?: boolean;\n  openerClass?: string;\n  buttonLabel?: string | ReactElement;\n  changeHistory?: Object;\n  type?: string;\n  handleButtonClick?: Function;\n  /** Called when the modal is closed (e.g., X click, overlay click, ESC). */\n  onClose?: () => void;\n  /** When true, do not render the opener button/div. Useful for controlled usage. */\n  hideOpener?: boolean;\n  /** Force content direction for the modal (also used to position the close button). */\n  dir?: 'rtl' | 'ltr';\n}>;\n\n/* Wrapper around Modal,\n   docs: https://react-responsive-modal.leopradel.com/\n*/\nconst KandoModal: React.FC<IKandoModal> = ({\n  isOpen = false,\n  buttonLabel,\n  changeHistory = {},\n  children,\n  type,\n  openerClass,\n  handleButtonClick,\n  onClose,\n  hideOpener = false,\n  dir,\n}) => {\n  const containerRef = React.useRef(null);\n  const [open, setOpen] = useState(isOpen);\n  useEffect(() => {\n    setOpen(isOpen);\n  }, [isOpen]);\n  const onOpenModal = () => setOpen(true);\n  const onCloseModal = () => {\n    setOpen(false);\n    clearHistory();\n    if (onClose) onClose();\n  };\n  const queryURL = useQueryURL();\n  const handleClick = () => {\n    if (handleButtonClick !== undefined) {\n      handleButtonClick!();\n    }\n    onOpenModal();\n  };\n\n  // add changeHistory's param=value to the URL\n  function updateHistory() {\n    if (!isEmpty(changeHistory)) {\n      for (const [param, value] of Object.entries(changeHistory)) {\n        queryURL.set(param, value);\n        window.history.replaceState(\n          {},\n          '',\n          `${window.location.pathname}?${queryURL}`,\n        );\n      }\n    }\n  }\n\n  // Remove\n  function clearHistory() {\n    if (!isEmpty(changeHistory)) {\n      for (const [param] of Object.entries(changeHistory)) {\n        queryURL.delete(param);\n        window.history.replaceState(\n          {},\n          '',\n          `${window.location.pathname}?${queryURL}`,\n        );\n      }\n    }\n  }\n\n  useEffect(() => {\n    if (open) {\n      updateHistory();\n    }\n  }, [open]);\n\n  const resolvedDir: 'rtl' | 'ltr' =\n    dir ||\n    (typeof document !== 'undefined' && document.documentElement?.dir === 'rtl'\n      ? 'rtl'\n      : 'ltr');\n\n  const isRtl = resolvedDir === 'rtl';\n\n  const modalStyles = isRtl\n    ? {\n        closeButton: {\n          left: '14px',\n          right: 'auto',\n        },\n      }\n    : undefined;\n\n  return (\n    <>\n      {!hideOpener && (\n        <div\n          className={`kmodal__opener kmodal__opener--${openerClass}`}\n          onClick={() => handleClick()}\n        >\n          {buttonLabel}\n        </div>\n      )}\n      <Modal\n        container={containerRef.current}\n        center\n        open={open}\n        onClose={onCloseModal}\n        styles={modalStyles}\n        classNames={{\n          overlay: 'kmodal__overlay',\n          modal: `kmodal kmodal--type-${type}`,\n        }}\n      >\n        <div dir={resolvedDir}>{children}</div>\n      </Modal>\n    </>\n  );\n};\n\nexport default KandoModal;\n"],"mappings":"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"}
|
|
@@ -0,0 +1,150 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _typeof = require("@babel/runtime/helpers/typeof");
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports.default = void 0;
|
|
9
|
+
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
|
|
10
|
+
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/asyncToGenerator"));
|
|
11
|
+
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/slicedToArray"));
|
|
12
|
+
var _i18next = _interopRequireDefault(require("i18next"));
|
|
13
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
14
|
+
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); }
|
|
15
|
+
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
16
|
+
var SeasonalInsights = function SeasonalInsights(_ref) {
|
|
17
|
+
var _data$insight_info2, _data$insight_info3;
|
|
18
|
+
var apiEndpoint = _ref.apiEndpoint,
|
|
19
|
+
dataProp = _ref.data,
|
|
20
|
+
className = _ref.className,
|
|
21
|
+
onLoaded = _ref.onLoaded;
|
|
22
|
+
var _useState = (0, _react.useState)(dataProp !== null && dataProp !== void 0 ? dataProp : null),
|
|
23
|
+
_useState2 = (0, _slicedToArray2.default)(_useState, 2),
|
|
24
|
+
data = _useState2[0],
|
|
25
|
+
setData = _useState2[1];
|
|
26
|
+
|
|
27
|
+
// If parent provides data, render it and skip fetching.
|
|
28
|
+
(0, _react.useEffect)(function () {
|
|
29
|
+
if (typeof dataProp === 'undefined') return;
|
|
30
|
+
setData(dataProp !== null && dataProp !== void 0 ? dataProp : null);
|
|
31
|
+
}, [dataProp]);
|
|
32
|
+
var risk = (0, _react.useMemo)(function () {
|
|
33
|
+
var _data$insight_info;
|
|
34
|
+
var risks = data === null || data === void 0 ? void 0 : (_data$insight_info = data.insight_info) === null || _data$insight_info === void 0 ? void 0 : _data$insight_info.risks;
|
|
35
|
+
if (!risks) return null;
|
|
36
|
+
var lang = (data === null || data === void 0 ? void 0 : data.locale) || 'en';
|
|
37
|
+
return risks[lang] || null;
|
|
38
|
+
}, [data]);
|
|
39
|
+
var summary = (risk === null || risk === void 0 ? void 0 : risk.risk_summary) || '';
|
|
40
|
+
var detailed = (risk === null || risk === void 0 ? void 0 : risk.detailed_risks) || [];
|
|
41
|
+
var start = (data === null || data === void 0 ? void 0 : (_data$insight_info2 = data.insight_info) === null || _data$insight_info2 === void 0 ? void 0 : _data$insight_info2.start_time) || (data === null || data === void 0 ? void 0 : data.start_time);
|
|
42
|
+
var end = (data === null || data === void 0 ? void 0 : (_data$insight_info3 = data.insight_info) === null || _data$insight_info3 === void 0 ? void 0 : _data$insight_info3.end_time) || (data === null || data === void 0 ? void 0 : data.end_time);
|
|
43
|
+
var isHebrew = (0, _react.useMemo)(function () {
|
|
44
|
+
var lang = ((data === null || data === void 0 ? void 0 : data.locale) || _i18next.default.language || 'en').toLowerCase();
|
|
45
|
+
return lang.startsWith('he');
|
|
46
|
+
}, [data === null || data === void 0 ? void 0 : data.locale]);
|
|
47
|
+
(0, _react.useEffect)(function () {
|
|
48
|
+
// If parent provides data, do not fetch.
|
|
49
|
+
if (typeof dataProp !== 'undefined') return;
|
|
50
|
+
if (!apiEndpoint) return;
|
|
51
|
+
var controller = new AbortController();
|
|
52
|
+
fetch(apiEndpoint, {
|
|
53
|
+
signal: controller.signal
|
|
54
|
+
}).then( /*#__PURE__*/function () {
|
|
55
|
+
var _ref2 = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee(res) {
|
|
56
|
+
return _regenerator.default.wrap(function _callee$(_context) {
|
|
57
|
+
while (1) {
|
|
58
|
+
switch (_context.prev = _context.next) {
|
|
59
|
+
case 0:
|
|
60
|
+
if (res.ok) {
|
|
61
|
+
_context.next = 2;
|
|
62
|
+
break;
|
|
63
|
+
}
|
|
64
|
+
throw new Error("Request failed (".concat(res.status, ")"));
|
|
65
|
+
case 2:
|
|
66
|
+
_context.next = 4;
|
|
67
|
+
return res.json();
|
|
68
|
+
case 4:
|
|
69
|
+
return _context.abrupt("return", _context.sent);
|
|
70
|
+
case 5:
|
|
71
|
+
case "end":
|
|
72
|
+
return _context.stop();
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
}, _callee);
|
|
76
|
+
}));
|
|
77
|
+
return function (_x) {
|
|
78
|
+
return _ref2.apply(this, arguments);
|
|
79
|
+
};
|
|
80
|
+
}()).then(function (payload) {
|
|
81
|
+
setData(payload);
|
|
82
|
+
if (onLoaded) onLoaded(payload);
|
|
83
|
+
}).catch(function (err) {
|
|
84
|
+
if ((err === null || err === void 0 ? void 0 : err.name) === 'AbortError') return;
|
|
85
|
+
setData(null);
|
|
86
|
+
});
|
|
87
|
+
return function () {
|
|
88
|
+
return controller.abort();
|
|
89
|
+
};
|
|
90
|
+
}, [apiEndpoint, dataProp, onLoaded]);
|
|
91
|
+
return /*#__PURE__*/_react.default.createElement("div", {
|
|
92
|
+
className: className,
|
|
93
|
+
dir: isHebrew ? 'rtl' : 'ltr',
|
|
94
|
+
style: {
|
|
95
|
+
padding: 12,
|
|
96
|
+
display: 'flex',
|
|
97
|
+
flexDirection: 'column',
|
|
98
|
+
gap: 12,
|
|
99
|
+
textAlign: isHebrew ? 'right' : 'left'
|
|
100
|
+
}
|
|
101
|
+
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
102
|
+
style: {
|
|
103
|
+
display: 'flex',
|
|
104
|
+
flexDirection: 'column',
|
|
105
|
+
gap: 4
|
|
106
|
+
}
|
|
107
|
+
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
108
|
+
style: {
|
|
109
|
+
fontWeight: 600
|
|
110
|
+
}
|
|
111
|
+
}, summary), /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement("span", null, start), " - ", /*#__PURE__*/_react.default.createElement("span", null, end))), /*#__PURE__*/_react.default.createElement("div", {
|
|
112
|
+
style: {
|
|
113
|
+
display: 'flex',
|
|
114
|
+
flexDirection: 'column',
|
|
115
|
+
gap: 10
|
|
116
|
+
}
|
|
117
|
+
}, detailed.map(function (r, idx) {
|
|
118
|
+
var _r$expected_pollution;
|
|
119
|
+
return /*#__PURE__*/_react.default.createElement("div", {
|
|
120
|
+
key: idx,
|
|
121
|
+
style: {
|
|
122
|
+
padding: 12,
|
|
123
|
+
border: '1px solid rgba(0,0,0,0.1)',
|
|
124
|
+
borderRadius: 8,
|
|
125
|
+
background: 'rgba(0,0,0,0.02)'
|
|
126
|
+
}
|
|
127
|
+
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
128
|
+
style: {
|
|
129
|
+
fontWeight: 700
|
|
130
|
+
}
|
|
131
|
+
}, r.siu_name), r.sector_code ? /*#__PURE__*/_react.default.createElement("div", {
|
|
132
|
+
style: {
|
|
133
|
+
marginTop: 2,
|
|
134
|
+
opacity: 0.8,
|
|
135
|
+
fontSize: 12
|
|
136
|
+
}
|
|
137
|
+
}, r.sector) : null, ((_r$expected_pollution = r.expected_pollution_types) === null || _r$expected_pollution === void 0 ? void 0 : _r$expected_pollution.length) ? /*#__PURE__*/_react.default.createElement("div", {
|
|
138
|
+
style: {
|
|
139
|
+
marginTop: 8
|
|
140
|
+
}
|
|
141
|
+
}, r.expected_pollution_types.join(', ')) : null, r.seasonal_or_location_factors ? /*#__PURE__*/_react.default.createElement("div", {
|
|
142
|
+
style: {
|
|
143
|
+
marginTop: 8
|
|
144
|
+
}
|
|
145
|
+
}, r.seasonal_or_location_factors) : null);
|
|
146
|
+
})));
|
|
147
|
+
};
|
|
148
|
+
var _default = SeasonalInsights;
|
|
149
|
+
exports.default = _default;
|
|
150
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_i18next","_interopRequireDefault","require","_react","_interopRequireWildcard","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","SeasonalInsights","_ref","_data$insight_info2","_data$insight_info3","apiEndpoint","dataProp","data","className","onLoaded","_useState","useState","_useState2","_slicedToArray2","setData","useEffect","risk","useMemo","_data$insight_info","risks","insight_info","lang","locale","summary","risk_summary","detailed","detailed_risks","start","start_time","end","end_time","isHebrew","i18next","language","toLowerCase","startsWith","controller","AbortController","fetch","signal","then","_ref2","_asyncToGenerator2","_regenerator","mark","_callee","res","wrap","_callee$","_context","prev","next","ok","Error","concat","status","json","abrupt","sent","stop","_x","apply","arguments","payload","catch","err","name","abort","createElement","dir","style","padding","display","flexDirection","gap","textAlign","fontWeight","map","r","idx","_r$expected_pollution","border","borderRadius","background","siu_name","sector_code","marginTop","opacity","fontSize","sector","expected_pollution_types","length","join","seasonal_or_location_factors","_default","exports"],"sources":["../../../src/components/SeasonalInsights/SeasonalInsights.tsx"],"sourcesContent":["import i18next from 'i18next';\nimport React, { useEffect, useMemo, useState } from 'react';\n\ntype DetailedRisk = {\n  sector?: string;\n  siu_name?: string;\n  sector_code?: string;\n  expected_pollution_types?: string[];\n  seasonal_or_location_factors?: string;\n};\n\nexport type SeasonalInsightResponse = {\n  locale: string;\n  id?: number;\n  start_time?: string;\n  end_time?: string;\n  insight_info?: {\n    risks?: {\n      [lang: string]: {\n        risk_summary?: string;\n        detailed_risks?: DetailedRisk[];\n      };\n    };\n    start_time?: string;\n    end_time?: string;\n    overall_confidence?: string;\n    water_authority_id?: string | number;\n  };\n};\n\nexport interface SeasonalInsightsProps {\n  /** If provided, the component will fetch the insight payload from this endpoint. */\n  apiEndpoint?: string;\n  /** If provided, the component will render using this data and will NOT fetch. */\n  data?: SeasonalInsightResponse | null;\n  /** Optional override: 'he', 'en', etc. Defaults to auto-detect based on document direction / browser language. */\n  language?: string;\n  /** Optional className for outer wrapper */\n  className?: string;\n  /** Optional callback to receive raw payload (only when fetching). */\n  onLoaded?: (data: SeasonalInsightResponse) => void;\n}\n\nconst SeasonalInsights: React.FC<SeasonalInsightsProps> = ({\n  apiEndpoint,\n  data: dataProp,\n  className,\n  onLoaded,\n}) => {\n  const [data, setData] = useState<SeasonalInsightResponse | null>(\n    dataProp ?? null,\n  );\n\n  // If parent provides data, render it and skip fetching.\n  useEffect(() => {\n    if (typeof dataProp === 'undefined') return;\n    setData(dataProp ?? null);\n  }, [dataProp]);\n\n  const risk = useMemo(() => {\n    const risks = data?.insight_info?.risks;\n    if (!risks) return null;\n    const lang = data?.locale || 'en';\n    return risks[lang] || null;\n  }, [data]);\n\n  const summary = risk?.risk_summary || '';\n  const detailed = risk?.detailed_risks || [];\n\n  const start = data?.insight_info?.start_time || data?.start_time;\n  const end = data?.insight_info?.end_time || data?.end_time;\n\n  const isHebrew = useMemo(() => {\n    const lang = (data?.locale || i18next.language || 'en').toLowerCase();\n    return lang.startsWith('he');\n  }, [data?.locale]);\n\n  useEffect(() => {\n    // If parent provides data, do not fetch.\n    if (typeof dataProp !== 'undefined') return;\n    if (!apiEndpoint) return;\n\n    const controller = new AbortController();\n\n    fetch(apiEndpoint, { signal: controller.signal })\n      .then(async (res) => {\n        if (!res.ok) {\n          throw new Error(`Request failed (${res.status})`);\n        }\n        return (await res.json()) as SeasonalInsightResponse;\n      })\n      .then((payload) => {\n        setData(payload);\n        if (onLoaded) onLoaded(payload);\n      })\n      .catch((err) => {\n        if (err?.name === 'AbortError') return;\n        setData(null);\n      });\n\n    return () => controller.abort();\n  }, [apiEndpoint, dataProp, onLoaded]);\n\n  return (\n    <div\n      className={className}\n      dir={isHebrew ? 'rtl' : 'ltr'}\n      style={{\n        padding: 12,\n        display: 'flex',\n        flexDirection: 'column',\n        gap: 12,\n        textAlign: isHebrew ? 'right' : 'left',\n      }}\n    >\n      <div style={{ display: 'flex', flexDirection: 'column', gap: 4 }}>\n        <div style={{ fontWeight: 600 }}>{summary}</div>\n        <div>\n          <span>{start}</span> - <span>{end}</span>\n        </div>\n      </div>\n\n      <div style={{ display: 'flex', flexDirection: 'column', gap: 10 }}>\n        {detailed.map((r, idx) => (\n          <div\n            key={idx}\n            style={{\n              padding: 12,\n              border: '1px solid rgba(0,0,0,0.1)',\n              borderRadius: 8,\n              background: 'rgba(0,0,0,0.02)',\n            }}\n          >\n            <div style={{ fontWeight: 700 }}>{r.siu_name}</div>\n\n            {r.sector_code ? (\n              <div style={{ marginTop: 2, opacity: 0.8, fontSize: 12 }}>\n                {r.sector}\n              </div>\n            ) : null}\n\n            {r.expected_pollution_types?.length ? (\n              <div style={{ marginTop: 8 }}>\n                {r.expected_pollution_types.join(', ')}\n              </div>\n            ) : null}\n\n            {r.seasonal_or_location_factors ? (\n              <div style={{ marginTop: 8 }}>\n                {r.seasonal_or_location_factors}\n              </div>\n            ) : null}\n          </div>\n        ))}\n      </div>\n    </div>\n  );\n};\n\nexport default SeasonalInsights;\n"],"mappings":"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"}
|
|
@@ -0,0 +1,208 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _typeof = require("@babel/runtime/helpers/typeof");
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports.default = void 0;
|
|
9
|
+
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
|
|
10
|
+
var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/objectSpread2"));
|
|
11
|
+
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/asyncToGenerator"));
|
|
12
|
+
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/slicedToArray"));
|
|
13
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
14
|
+
var _KandoModal = _interopRequireDefault(require("../KandoModal"));
|
|
15
|
+
var _SeasonalInsights = _interopRequireDefault(require("../SeasonalInsights/SeasonalInsights"));
|
|
16
|
+
var _i18next = _interopRequireDefault(require("i18next"));
|
|
17
|
+
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); }
|
|
18
|
+
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
19
|
+
var LOCAL_STORAGE_KEY_BASE = 'TopBannerDismissed';
|
|
20
|
+
var buildDismissKey = function buildDismissKey(data) {
|
|
21
|
+
var _data$insight_info, _data$insight_info2;
|
|
22
|
+
var id = data === null || data === void 0 ? void 0 : data.id;
|
|
23
|
+
var start = data === null || data === void 0 ? void 0 : (_data$insight_info = data.insight_info) === null || _data$insight_info === void 0 ? void 0 : _data$insight_info.start_time;
|
|
24
|
+
var end = data === null || data === void 0 ? void 0 : (_data$insight_info2 = data.insight_info) === null || _data$insight_info2 === void 0 ? void 0 : _data$insight_info2.end_time;
|
|
25
|
+
if (id && start && end) return "".concat(LOCAL_STORAGE_KEY_BASE, ":").concat(id, ":").concat(start, ":").concat(end);
|
|
26
|
+
return LOCAL_STORAGE_KEY_BASE;
|
|
27
|
+
};
|
|
28
|
+
var TopBanner = function TopBanner(_ref) {
|
|
29
|
+
var _ref$backgroundColor = _ref.backgroundColor,
|
|
30
|
+
backgroundColor = _ref$backgroundColor === void 0 ? '#f5b7c5' : _ref$backgroundColor,
|
|
31
|
+
_ref$text = _ref.text,
|
|
32
|
+
text = _ref$text === void 0 ? '' : _ref$text,
|
|
33
|
+
onVisibilityChange = _ref.onVisibilityChange,
|
|
34
|
+
apiEndpoint = _ref.apiEndpoint;
|
|
35
|
+
var _useState = (0, _react.useState)(true),
|
|
36
|
+
_useState2 = (0, _slicedToArray2.default)(_useState, 2),
|
|
37
|
+
visible = _useState2[0],
|
|
38
|
+
setVisible = _useState2[1];
|
|
39
|
+
var _useState3 = (0, _react.useState)(null),
|
|
40
|
+
_useState4 = (0, _slicedToArray2.default)(_useState3, 2),
|
|
41
|
+
headerText = _useState4[0],
|
|
42
|
+
setHeaderText = _useState4[1];
|
|
43
|
+
var _useState5 = (0, _react.useState)(false),
|
|
44
|
+
_useState6 = (0, _slicedToArray2.default)(_useState5, 2),
|
|
45
|
+
showModal = _useState6[0],
|
|
46
|
+
setShowModal = _useState6[1];
|
|
47
|
+
var _useState7 = (0, _react.useState)(null),
|
|
48
|
+
_useState8 = (0, _slicedToArray2.default)(_useState7, 2),
|
|
49
|
+
insightData = _useState8[0],
|
|
50
|
+
setInsightData = _useState8[1];
|
|
51
|
+
var dismissKey = buildDismissKey(insightData);
|
|
52
|
+
var bannerHeight = 30; // px
|
|
53
|
+
var dir = _i18next.default.dir();
|
|
54
|
+
|
|
55
|
+
// const hasInsightDetails = useMemo(() => {
|
|
56
|
+
// const risks = insightData?.insight_info?.risks;
|
|
57
|
+
// if (!risks) return false;
|
|
58
|
+
// return Object.values(risks).some(r => (r?.risk_summary && r.risk_summary.length > 0) || (r?.detailed_risks && r.detailed_risks.length > 0));
|
|
59
|
+
// }, [insightData]);
|
|
60
|
+
|
|
61
|
+
// On mount or when dismissKey changes, check localStorage for dismissal
|
|
62
|
+
(0, _react.useEffect)(function () {
|
|
63
|
+
try {
|
|
64
|
+
var dismissed = localStorage.getItem(dismissKey) === 'true';
|
|
65
|
+
setVisible(!dismissed);
|
|
66
|
+
if (onVisibilityChange) onVisibilityChange(!dismissed);
|
|
67
|
+
} catch (_unused) {
|
|
68
|
+
setVisible(true);
|
|
69
|
+
if (onVisibilityChange) onVisibilityChange(true);
|
|
70
|
+
}
|
|
71
|
+
}, [dismissKey]);
|
|
72
|
+
|
|
73
|
+
// Fetch data from API if endpoint is provided, robustly
|
|
74
|
+
(0, _react.useEffect)(function () {
|
|
75
|
+
if (!apiEndpoint) return;
|
|
76
|
+
var controller = new AbortController();
|
|
77
|
+
fetch(apiEndpoint, {
|
|
78
|
+
signal: controller.signal
|
|
79
|
+
}).then( /*#__PURE__*/function () {
|
|
80
|
+
var _ref2 = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee(res) {
|
|
81
|
+
return _regenerator.default.wrap(function _callee$(_context) {
|
|
82
|
+
while (1) {
|
|
83
|
+
switch (_context.prev = _context.next) {
|
|
84
|
+
case 0:
|
|
85
|
+
if (!(res.status === 404)) {
|
|
86
|
+
_context.next = 2;
|
|
87
|
+
break;
|
|
88
|
+
}
|
|
89
|
+
return _context.abrupt("return", {
|
|
90
|
+
error: 'not_found'
|
|
91
|
+
});
|
|
92
|
+
case 2:
|
|
93
|
+
if (res.ok) {
|
|
94
|
+
_context.next = 4;
|
|
95
|
+
break;
|
|
96
|
+
}
|
|
97
|
+
throw new Error("Request failed (".concat(res.status, ")"));
|
|
98
|
+
case 4:
|
|
99
|
+
_context.next = 6;
|
|
100
|
+
return res.json();
|
|
101
|
+
case 6:
|
|
102
|
+
return _context.abrupt("return", _context.sent);
|
|
103
|
+
case 7:
|
|
104
|
+
case "end":
|
|
105
|
+
return _context.stop();
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
}, _callee);
|
|
109
|
+
}));
|
|
110
|
+
return function (_x) {
|
|
111
|
+
return _ref2.apply(this, arguments);
|
|
112
|
+
};
|
|
113
|
+
}()).then(function (data) {
|
|
114
|
+
// When the API says not_found, do not show the banner.
|
|
115
|
+
if ((data === null || data === void 0 ? void 0 : data.error) === 'not_found') {
|
|
116
|
+
setInsightData(null);
|
|
117
|
+
setHeaderText(null);
|
|
118
|
+
setVisible(false);
|
|
119
|
+
return;
|
|
120
|
+
}
|
|
121
|
+
setInsightData(data);
|
|
122
|
+
setHeaderText(_i18next.default.t('seasonal_insights.title'));
|
|
123
|
+
setVisible(!!data);
|
|
124
|
+
}).catch(function (err) {});
|
|
125
|
+
return function () {
|
|
126
|
+
return controller.abort();
|
|
127
|
+
};
|
|
128
|
+
}, [apiEndpoint, text]);
|
|
129
|
+
|
|
130
|
+
// Notify parent on visibility change
|
|
131
|
+
(0, _react.useEffect)(function () {
|
|
132
|
+
if (onVisibilityChange) onVisibilityChange(visible);
|
|
133
|
+
}, [visible]);
|
|
134
|
+
|
|
135
|
+
// When dismissed, persist in localStorage
|
|
136
|
+
var handleDismiss = function handleDismiss() {
|
|
137
|
+
setVisible(false);
|
|
138
|
+
try {
|
|
139
|
+
localStorage.setItem(dismissKey, 'true');
|
|
140
|
+
} catch (_unused2) {}
|
|
141
|
+
};
|
|
142
|
+
var openModal = function openModal() {
|
|
143
|
+
setShowModal(true);
|
|
144
|
+
};
|
|
145
|
+
var closeModal = function closeModal() {
|
|
146
|
+
setShowModal(false);
|
|
147
|
+
};
|
|
148
|
+
var modal = (0, _react.useMemo)(function () {
|
|
149
|
+
if (!showModal) return null;
|
|
150
|
+
var dir = _i18next.default.dir();
|
|
151
|
+
return /*#__PURE__*/_react.default.createElement(_KandoModal.default, {
|
|
152
|
+
isOpen: showModal,
|
|
153
|
+
onClose: closeModal,
|
|
154
|
+
dir: dir
|
|
155
|
+
}, /*#__PURE__*/_react.default.createElement(_SeasonalInsights.default, {
|
|
156
|
+
data: insightData
|
|
157
|
+
}));
|
|
158
|
+
}, [showModal]);
|
|
159
|
+
var bannerContent = headerText || text;
|
|
160
|
+
if (!visible || !bannerContent) {
|
|
161
|
+
return null;
|
|
162
|
+
}
|
|
163
|
+
return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("div", {
|
|
164
|
+
style: {
|
|
165
|
+
width: '100%',
|
|
166
|
+
background: backgroundColor,
|
|
167
|
+
padding: '8px',
|
|
168
|
+
textAlign: 'center',
|
|
169
|
+
position: 'relative',
|
|
170
|
+
// position: 'fixed',
|
|
171
|
+
// top: 0,
|
|
172
|
+
// left: 0,
|
|
173
|
+
boxSizing: 'border-box',
|
|
174
|
+
minHeight: "".concat(bannerHeight, "px"),
|
|
175
|
+
height: "".concat(bannerHeight, "px"),
|
|
176
|
+
display: 'flex',
|
|
177
|
+
alignItems: 'center',
|
|
178
|
+
justifyContent: 'center',
|
|
179
|
+
// zIndex: 9999,
|
|
180
|
+
fontSize: '14px'
|
|
181
|
+
}
|
|
182
|
+
}, /*#__PURE__*/_react.default.createElement("span", {
|
|
183
|
+
style: {
|
|
184
|
+
cursor: apiEndpoint ? 'pointer' : 'default'
|
|
185
|
+
},
|
|
186
|
+
onClick: apiEndpoint ? openModal : undefined
|
|
187
|
+
}, bannerContent), /*#__PURE__*/_react.default.createElement("button", {
|
|
188
|
+
onClick: handleDismiss,
|
|
189
|
+
style: (0, _objectSpread2.default)((0, _objectSpread2.default)({
|
|
190
|
+
position: 'absolute'
|
|
191
|
+
}, dir === 'rtl' ? {
|
|
192
|
+
left: 8,
|
|
193
|
+
right: 'auto'
|
|
194
|
+
} : {
|
|
195
|
+
right: 8
|
|
196
|
+
}), {}, {
|
|
197
|
+
// top: 8,
|
|
198
|
+
background: 'transparent',
|
|
199
|
+
border: 'none',
|
|
200
|
+
fontSize: '18px',
|
|
201
|
+
cursor: 'pointer'
|
|
202
|
+
}),
|
|
203
|
+
"aria-label": "Dismiss banner"
|
|
204
|
+
}, "\xD7")), modal);
|
|
205
|
+
};
|
|
206
|
+
var _default = TopBanner;
|
|
207
|
+
exports.default = _default;
|
|
208
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_KandoModal","_interopRequireDefault","_SeasonalInsights","_i18next","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","LOCAL_STORAGE_KEY_BASE","buildDismissKey","data","_data$insight_info","_data$insight_info2","id","start","insight_info","start_time","end","end_time","concat","TopBanner","_ref","_ref$backgroundColor","backgroundColor","_ref$text","text","onVisibilityChange","apiEndpoint","_useState","useState","_useState2","_slicedToArray2","visible","setVisible","_useState3","_useState4","headerText","setHeaderText","_useState5","_useState6","showModal","setShowModal","_useState7","_useState8","insightData","setInsightData","dismissKey","bannerHeight","dir","i18next","useEffect","dismissed","localStorage","getItem","_unused","controller","AbortController","fetch","signal","then","_ref2","_asyncToGenerator2","_regenerator","mark","_callee","res","wrap","_callee$","_context","prev","next","status","abrupt","error","ok","Error","json","sent","stop","_x","apply","arguments","t","catch","err","abort","handleDismiss","setItem","_unused2","openModal","closeModal","modal","useMemo","createElement","isOpen","onClose","bannerContent","Fragment","style","width","background","padding","textAlign","position","boxSizing","minHeight","height","display","alignItems","justifyContent","fontSize","cursor","onClick","undefined","_objectSpread2","left","right","border","_default","exports"],"sources":["../../../src/components/TopBanner/TopBanner.tsx"],"sourcesContent":["import React, { useState, useEffect, useMemo } from 'react';\nimport KandoModal from '../KandoModal';\nimport SeasonalInsights, {\n  SeasonalInsightResponse,\n} from '../SeasonalInsights/SeasonalInsights';\nimport i18next from 'i18next';\n\ninterface TopBannerProps {\n  backgroundColor?: string;\n  text?: React.ReactNode;\n  onVisibilityChange?: (visible: boolean) => void;\n  apiEndpoint?: string; // Add this prop for API endpoint\n}\n\nconst LOCAL_STORAGE_KEY_BASE = 'TopBannerDismissed';\n\nconst buildDismissKey = (data?: SeasonalInsightResponse | null) => {\n  const id = data?.id;\n  const start = data?.insight_info?.start_time;\n  const end = data?.insight_info?.end_time;\n  if (id && start && end)\n    return `${LOCAL_STORAGE_KEY_BASE}:${id}:${start}:${end}`;\n  return LOCAL_STORAGE_KEY_BASE;\n};\n\nconst TopBanner: React.FC<TopBannerProps> = ({\n  backgroundColor = '#f5b7c5',\n  text = '',\n  onVisibilityChange,\n  apiEndpoint,\n}) => {\n  const [visible, setVisible] = useState(true);\n  const [headerText, setHeaderText] = useState<React.ReactNode>(null);\n  const [showModal, setShowModal] = useState(false);\n  const [insightData, setInsightData] =\n    useState<SeasonalInsightResponse | null>(null);\n\n  const dismissKey = buildDismissKey(insightData);\n  const bannerHeight = 30; // px\n  const dir = i18next.dir();\n\n  // const hasInsightDetails = useMemo(() => {\n  //     const risks = insightData?.insight_info?.risks;\n  //     if (!risks) return false;\n  //     return Object.values(risks).some(r => (r?.risk_summary && r.risk_summary.length > 0) || (r?.detailed_risks && r.detailed_risks.length > 0));\n  // }, [insightData]);\n\n  // On mount or when dismissKey changes, check localStorage for dismissal\n  useEffect(() => {\n    try {\n      const dismissed = localStorage.getItem(dismissKey) === 'true';\n      setVisible(!dismissed);\n      if (onVisibilityChange) onVisibilityChange(!dismissed);\n    } catch {\n      setVisible(true);\n      if (onVisibilityChange) onVisibilityChange(true);\n    }\n  }, [dismissKey]);\n\n  // Fetch data from API if endpoint is provided, robustly\n  useEffect(() => {\n    if (!apiEndpoint) return;\n\n    const controller = new AbortController();\n\n    fetch(apiEndpoint, { signal: controller.signal })\n      .then(async (res) => {\n        if (res.status === 404) {\n          // API explicitly says there is no seasonal insight.\n          return { error: 'not_found' } as unknown as SeasonalInsightResponse;\n        }\n        if (!res.ok) {\n          throw new Error(`Request failed (${res.status})`);\n        }\n        return (await res.json()) as SeasonalInsightResponse;\n      })\n      .then((data) => {\n        // When the API says not_found, do not show the banner.\n        if ((data as any)?.error === 'not_found') {\n          setInsightData(null);\n          setHeaderText(null);\n          setVisible(false);\n          return;\n        }\n        setInsightData(data);\n\n        setHeaderText(i18next.t('seasonal_insights.title'));\n\n        setVisible(!!data);\n      })\n      .catch((err) => {});\n\n    return () => controller.abort();\n  }, [apiEndpoint, text]);\n\n  // Notify parent on visibility change\n  useEffect(() => {\n    if (onVisibilityChange) onVisibilityChange(visible);\n  }, [visible]);\n\n  // When dismissed, persist in localStorage\n  const handleDismiss = () => {\n    setVisible(false);\n    try {\n      localStorage.setItem(dismissKey, 'true');\n    } catch {}\n  };\n\n  const openModal = () => {\n    setShowModal(true);\n  };\n\n  const closeModal = () => {\n    setShowModal(false);\n  };\n\n  const modal = useMemo(() => {\n    if (!showModal) return null;\n    const dir = i18next.dir();\n    return (\n      <KandoModal isOpen={showModal} onClose={closeModal} dir={dir}>\n        <SeasonalInsights data={insightData} />\n      </KandoModal>\n    );\n  }, [showModal]);\n\n  const bannerContent = headerText || text;\n  if (!visible || !bannerContent) {\n    return null;\n  }\n\n  return (\n    <>\n      <div\n        style={{\n          width: '100%',\n          background: backgroundColor,\n          padding: '8px',\n          textAlign: 'center',\n          position: 'relative',\n          // position: 'fixed',\n          // top: 0,\n          // left: 0,\n          boxSizing: 'border-box',\n          minHeight: `${bannerHeight}px`,\n          height: `${bannerHeight}px`,\n          display: 'flex',\n          alignItems: 'center',\n          justifyContent: 'center',\n          // zIndex: 9999,\n          fontSize: '14px',\n        }}\n      >\n        <span\n          style={{ cursor: apiEndpoint ? 'pointer' : 'default' }}\n          onClick={apiEndpoint ? openModal : undefined}\n        >\n          {bannerContent}\n        </span>\n        <button\n          onClick={handleDismiss}\n          style={{\n            position: 'absolute',\n            ...(dir === 'rtl'\n              ? { left: 8, right: 'auto' as const }\n              : { right: 8 }),\n            // top: 8,\n            background: 'transparent',\n            border: 'none',\n            fontSize: '18px',\n            cursor: 'pointer',\n          }}\n          aria-label=\"Dismiss banner\"\n        >\n          ×\n        </button>\n      </div>\n      {modal}\n    </>\n  );\n};\n\nexport default TopBanner;\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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"}
|