@kando-env/kando-ui 1.2.466-alpha.10 → 1.2.466-alpha.11
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/components/KandoModal/KandoModal.js +16 -13
- package/lib/components/KandoModal/styles.scss +4 -0
- package/lib/components/SeasonalInsights/SeasonalInsights.js +103 -54
- package/lib/components/TopBanner/TopBanner.js +47 -55
- package/lib/i18n/en.json +11 -2
- package/lib/i18n/fr.json +11 -2
- package/lib/i18n/he.json +11 -2
- package/lib/i18n/it.json +11 -2
- package/lib/macros/getVersion.js +1 -1
- package/package.json +1 -1
|
@@ -13,13 +13,13 @@ var _reactResponsiveModal = require("react-responsive-modal");
|
|
|
13
13
|
require("react-responsive-modal/styles.css");
|
|
14
14
|
var _useQueryURL = _interopRequireDefault(require("hooks/useQueryURL"));
|
|
15
15
|
require("./styles.scss");
|
|
16
|
+
var _useNavContext2 = require("hooks/useNavContext");
|
|
16
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); }
|
|
17
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; }
|
|
18
19
|
/* Wrapper around Modal,
|
|
19
20
|
docs: https://react-responsive-modal.leopradel.com/
|
|
20
21
|
*/
|
|
21
22
|
var KandoModal = function KandoModal(_ref) {
|
|
22
|
-
var _document$documentEle;
|
|
23
23
|
var _ref$isOpen = _ref.isOpen,
|
|
24
24
|
isOpen = _ref$isOpen === void 0 ? false : _ref$isOpen,
|
|
25
25
|
buttonLabel = _ref.buttonLabel,
|
|
@@ -31,16 +31,12 @@ var KandoModal = function KandoModal(_ref) {
|
|
|
31
31
|
handleButtonClick = _ref.handleButtonClick,
|
|
32
32
|
onClose = _ref.onClose,
|
|
33
33
|
_ref$hideOpener = _ref.hideOpener,
|
|
34
|
-
hideOpener = _ref$hideOpener === void 0 ? false : _ref$hideOpener
|
|
35
|
-
dir = _ref.dir;
|
|
34
|
+
hideOpener = _ref$hideOpener === void 0 ? false : _ref$hideOpener;
|
|
36
35
|
var containerRef = _react.default.useRef(null);
|
|
37
36
|
var _useState = (0, _react.useState)(isOpen),
|
|
38
37
|
_useState2 = (0, _slicedToArray2.default)(_useState, 2),
|
|
39
38
|
open = _useState2[0],
|
|
40
39
|
setOpen = _useState2[1];
|
|
41
|
-
(0, _react.useEffect)(function () {
|
|
42
|
-
setOpen(isOpen);
|
|
43
|
-
}, [isOpen]);
|
|
44
40
|
var onOpenModal = function onOpenModal() {
|
|
45
41
|
return setOpen(true);
|
|
46
42
|
};
|
|
@@ -56,6 +52,9 @@ var KandoModal = function KandoModal(_ref) {
|
|
|
56
52
|
}
|
|
57
53
|
onOpenModal();
|
|
58
54
|
};
|
|
55
|
+
var _useNavContext = (0, _useNavContext2.useNavContext)(),
|
|
56
|
+
isRtl = _useNavContext.isRtl,
|
|
57
|
+
dir = _useNavContext.dir;
|
|
59
58
|
|
|
60
59
|
// add changeHistory's param=value to the URL
|
|
61
60
|
function updateHistory() {
|
|
@@ -86,14 +85,18 @@ var KandoModal = function KandoModal(_ref) {
|
|
|
86
85
|
updateHistory();
|
|
87
86
|
}
|
|
88
87
|
}, [open]);
|
|
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
88
|
var modalStyles = isRtl ? {
|
|
92
89
|
closeButton: {
|
|
93
|
-
left: '
|
|
94
|
-
right: 'auto'
|
|
90
|
+
left: '8px',
|
|
91
|
+
right: 'auto',
|
|
92
|
+
top: '8px'
|
|
93
|
+
}
|
|
94
|
+
} : {
|
|
95
|
+
closeButton: {
|
|
96
|
+
right: '8px',
|
|
97
|
+
top: '8px'
|
|
95
98
|
}
|
|
96
|
-
}
|
|
99
|
+
};
|
|
97
100
|
return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, !hideOpener && /*#__PURE__*/_react.default.createElement("div", {
|
|
98
101
|
className: "kmodal__opener kmodal__opener--".concat(openerClass),
|
|
99
102
|
onClick: function onClick() {
|
|
@@ -110,9 +113,9 @@ var KandoModal = function KandoModal(_ref) {
|
|
|
110
113
|
modal: "kmodal kmodal--type-".concat(type)
|
|
111
114
|
}
|
|
112
115
|
}, /*#__PURE__*/_react.default.createElement("div", {
|
|
113
|
-
dir:
|
|
116
|
+
dir: dir
|
|
114
117
|
}, children)));
|
|
115
118
|
};
|
|
116
119
|
var _default = KandoModal;
|
|
117
120
|
exports.default = _default;
|
|
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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"}
|
|
121
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_lodash","_reactResponsiveModal","_useQueryURL","_interopRequireDefault","_useNavContext2","_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","onClose","_ref$hideOpener","hideOpener","containerRef","React","useRef","_useState","useState","_useState2","_slicedToArray2","open","setOpen","onOpenModal","onCloseModal","clearHistory","queryURL","useQueryURL","handleClick","undefined","_useNavContext","useNavContext","isRtl","dir","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","modalStyles","closeButton","left","right","top","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';\nimport { useNavContext } from 'src/hooks/useNavContext';\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}>;\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}) => {\n  const containerRef = React.useRef(null);\n  const [open, setOpen] = useState(isOpen);\n\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  const { isRtl, dir } = useNavContext();\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 modalStyles = isRtl\n    ? {\n        closeButton: {\n          left: '8px',\n          right: 'auto',\n          top: '8px',\n        },\n      }\n    : {\n        closeButton: {\n          right: '8px',\n          top: '8px',\n        },\n      };\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={dir}>{children}</div>\n      </Modal>\n    </>\n  );\n};\n\nexport default KandoModal;\n"],"mappings":"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"}
|
|
@@ -9,8 +9,11 @@ exports.default = void 0;
|
|
|
9
9
|
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
|
|
10
10
|
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/asyncToGenerator"));
|
|
11
11
|
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/slicedToArray"));
|
|
12
|
+
var _styledComponents = _interopRequireDefault(require("styled-components"));
|
|
12
13
|
var _i18next = _interopRequireDefault(require("i18next"));
|
|
13
14
|
var _react = _interopRequireWildcard(require("react"));
|
|
15
|
+
var _Sector = _interopRequireDefault(require("../Sector"));
|
|
16
|
+
var _MoreInfoButton = require("pages/EventsPage/events/event_info/SourceDetails/MoreInfoButton");
|
|
14
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); }
|
|
15
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; }
|
|
16
19
|
var SeasonalInsights = function SeasonalInsights(_ref) {
|
|
@@ -22,6 +25,10 @@ var SeasonalInsights = function SeasonalInsights(_ref) {
|
|
|
22
25
|
_useState2 = (0, _slicedToArray2.default)(_useState, 2),
|
|
23
26
|
data = _useState2[0],
|
|
24
27
|
setData = _useState2[1];
|
|
28
|
+
var _useState3 = (0, _react.useState)(false),
|
|
29
|
+
_useState4 = (0, _slicedToArray2.default)(_useState3, 2),
|
|
30
|
+
showDetails = _useState4[0],
|
|
31
|
+
setShowDetails = _useState4[1];
|
|
25
32
|
|
|
26
33
|
// If parent provides data, render it and skip fetching.
|
|
27
34
|
(0, _react.useEffect)(function () {
|
|
@@ -37,6 +44,7 @@ var SeasonalInsights = function SeasonalInsights(_ref) {
|
|
|
37
44
|
}, [data]);
|
|
38
45
|
var summary = (risk === null || risk === void 0 ? void 0 : risk.risk_summary) || '';
|
|
39
46
|
var detailed = (risk === null || risk === void 0 ? void 0 : risk.detailed_risks) || [];
|
|
47
|
+
var hasDetails = detailed.length > 0;
|
|
40
48
|
var isHebrew = (0, _react.useMemo)(function () {
|
|
41
49
|
var lang = ((data === null || data === void 0 ? void 0 : data.locale) || _i18next.default.language || 'en').toLowerCase();
|
|
42
50
|
return lang.startsWith('he');
|
|
@@ -85,63 +93,104 @@ var SeasonalInsights = function SeasonalInsights(_ref) {
|
|
|
85
93
|
return controller.abort();
|
|
86
94
|
};
|
|
87
95
|
}, [apiEndpoint, dataProp, onLoaded]);
|
|
88
|
-
return /*#__PURE__*/_react.default.createElement(
|
|
96
|
+
return /*#__PURE__*/_react.default.createElement(Container, {
|
|
89
97
|
className: className,
|
|
90
98
|
dir: isHebrew ? 'rtl' : 'ltr',
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
}, /*#__PURE__*/_react.default.createElement(
|
|
105
|
-
style: {
|
|
106
|
-
fontWeight: 600
|
|
107
|
-
}
|
|
108
|
-
}, summary)), /*#__PURE__*/_react.default.createElement("div", {
|
|
109
|
-
style: {
|
|
110
|
-
display: 'flex',
|
|
111
|
-
flexDirection: 'column',
|
|
112
|
-
gap: 10
|
|
113
|
-
}
|
|
114
|
-
}, detailed.map(function (r, idx) {
|
|
99
|
+
isRtl: isHebrew
|
|
100
|
+
}, /*#__PURE__*/_react.default.createElement(SummarySection, null, /*#__PURE__*/_react.default.createElement(SummaryTitle, null, _i18next.default.t('seasonal_insights.summary_heading')), /*#__PURE__*/_react.default.createElement(SummaryText, null, summary)), hasDetails ? /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(ToggleRow, {
|
|
101
|
+
isRtl: isHebrew
|
|
102
|
+
}, /*#__PURE__*/_react.default.createElement(_MoreInfoButton.MoreInfoDiv, null, /*#__PURE__*/_react.default.createElement("a", {
|
|
103
|
+
href: "#",
|
|
104
|
+
className: "more-info-button",
|
|
105
|
+
onClick: function onClick(e) {
|
|
106
|
+
e.preventDefault();
|
|
107
|
+
setShowDetails(function (prev) {
|
|
108
|
+
return !prev;
|
|
109
|
+
});
|
|
110
|
+
},
|
|
111
|
+
"aria-expanded": showDetails
|
|
112
|
+
}, showDetails ? _i18next.default.t('seasonal_insights.show_less') : _i18next.default.t('seasonal_insights.show_more')))), showDetails ? /*#__PURE__*/_react.default.createElement(CardList, null, detailed.map(function (r, idx) {
|
|
115
113
|
var _r$expected_pollution;
|
|
116
|
-
return /*#__PURE__*/_react.default.createElement(
|
|
117
|
-
key: idx
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
114
|
+
return /*#__PURE__*/_react.default.createElement(Card, {
|
|
115
|
+
key: idx
|
|
116
|
+
}, /*#__PURE__*/_react.default.createElement(CardHeader, null, /*#__PURE__*/_react.default.createElement(TitleBlock, null, formatSectorIconName(r.sector) ? /*#__PURE__*/_react.default.createElement(_Sector.default, {
|
|
117
|
+
sectorIconName: formatSectorIconName(r.sector) || 'Missing',
|
|
118
|
+
sectorName: r.sector,
|
|
119
|
+
showLabel: false,
|
|
120
|
+
withTooltip: true
|
|
121
|
+
}) : null, /*#__PURE__*/_react.default.createElement(CardTitle, null, r.siu_name))), ((_r$expected_pollution = r.expected_pollution_types) === null || _r$expected_pollution === void 0 ? void 0 : _r$expected_pollution.length) ? /*#__PURE__*/_react.default.createElement(CardSection, null, /*#__PURE__*/_react.default.createElement(SectionLabel, null, _i18next.default.t('seasonal_insights.key_risks')), /*#__PURE__*/_react.default.createElement(ChipRow, null, r.expected_pollution_types.map(function (p, chipIdx) {
|
|
122
|
+
return /*#__PURE__*/_react.default.createElement(Chip, {
|
|
123
|
+
key: "".concat(p, "-").concat(chipIdx)
|
|
124
|
+
}, p);
|
|
125
|
+
}))) : null, r.seasonal_or_location_factors ? /*#__PURE__*/_react.default.createElement(CardSection, null, /*#__PURE__*/_react.default.createElement(SectionLabel, null, _i18next.default.t('seasonal_insights.seasonal_factors')), /*#__PURE__*/_react.default.createElement(SectionText, null, r.seasonal_or_location_factors)) : null);
|
|
126
|
+
})) : null) : null);
|
|
127
|
+
};
|
|
128
|
+
var Container = _styledComponents.default.div.withConfig({
|
|
129
|
+
displayName: "SeasonalInsights__Container",
|
|
130
|
+
componentId: "sc-jrd7ho-0"
|
|
131
|
+
})(["padding:16px;margin:16px;display:flex;flex-direction:column;gap:12px;text-align:", ";background:#f7f8fa;min-width:320px;border-radius:12px;"], function (_ref3) {
|
|
132
|
+
var isRtl = _ref3.isRtl;
|
|
133
|
+
return isRtl ? 'right' : 'left';
|
|
134
|
+
});
|
|
135
|
+
var SummarySection = _styledComponents.default.div.withConfig({
|
|
136
|
+
displayName: "SeasonalInsights__SummarySection",
|
|
137
|
+
componentId: "sc-jrd7ho-1"
|
|
138
|
+
})(["display:flex;flex-direction:column;gap:8px;padding:12px 14px;border-radius:10px;background:#ffffff;box-shadow:0 1px 3px rgba(0,0,0,0.06);"]);
|
|
139
|
+
var SummaryTitle = _styledComponents.default.div.withConfig({
|
|
140
|
+
displayName: "SeasonalInsights__SummaryTitle",
|
|
141
|
+
componentId: "sc-jrd7ho-2"
|
|
142
|
+
})(["font-weight:600;font-size:16px;color:#1d1d1d;"]);
|
|
143
|
+
var SummaryText = _styledComponents.default.div.withConfig({
|
|
144
|
+
displayName: "SeasonalInsights__SummaryText",
|
|
145
|
+
componentId: "sc-jrd7ho-3"
|
|
146
|
+
})(["font-size:15px;color:#2b2b2b;line-height:1.5;"]);
|
|
147
|
+
var ToggleRow = _styledComponents.default.div.withConfig({
|
|
148
|
+
displayName: "SeasonalInsights__ToggleRow",
|
|
149
|
+
componentId: "sc-jrd7ho-4"
|
|
150
|
+
})(["display:flex;justify-content:flex-end;margin-top:6px;"]);
|
|
151
|
+
var CardList = _styledComponents.default.div.withConfig({
|
|
152
|
+
displayName: "SeasonalInsights__CardList",
|
|
153
|
+
componentId: "sc-jrd7ho-5"
|
|
154
|
+
})(["display:flex;flex-direction:column;gap:12px;"]);
|
|
155
|
+
var Card = _styledComponents.default.div.withConfig({
|
|
156
|
+
displayName: "SeasonalInsights__Card",
|
|
157
|
+
componentId: "sc-jrd7ho-6"
|
|
158
|
+
})(["padding:14px;border-radius:10px;background:#ffffff;border:1px solid #e4e6ea;box-shadow:0 1px 4px rgba(0,0,0,0.05);display:flex;flex-direction:column;gap:10px;"]);
|
|
159
|
+
var CardHeader = _styledComponents.default.div.withConfig({
|
|
160
|
+
displayName: "SeasonalInsights__CardHeader",
|
|
161
|
+
componentId: "sc-jrd7ho-7"
|
|
162
|
+
})(["display:flex;align-items:center;gap:8px;justify-content:space-between;"]);
|
|
163
|
+
var TitleBlock = _styledComponents.default.div.withConfig({
|
|
164
|
+
displayName: "SeasonalInsights__TitleBlock",
|
|
165
|
+
componentId: "sc-jrd7ho-8"
|
|
166
|
+
})(["display:inline-flex;align-items:center;margin-inline-start:-14px;"]);
|
|
167
|
+
var CardTitle = _styledComponents.default.div.withConfig({
|
|
168
|
+
displayName: "SeasonalInsights__CardTitle",
|
|
169
|
+
componentId: "sc-jrd7ho-9"
|
|
170
|
+
})(["font-weight:600;font-size:15px;color:#1e1e1e;"]);
|
|
171
|
+
var CardSection = _styledComponents.default.div.withConfig({
|
|
172
|
+
displayName: "SeasonalInsights__CardSection",
|
|
173
|
+
componentId: "sc-jrd7ho-10"
|
|
174
|
+
})(["display:flex;flex-direction:column;gap:6px;"]);
|
|
175
|
+
var SectionLabel = _styledComponents.default.div.withConfig({
|
|
176
|
+
displayName: "SeasonalInsights__SectionLabel",
|
|
177
|
+
componentId: "sc-jrd7ho-11"
|
|
178
|
+
})(["font-weight:600;font-size:13px;color:#2f333a;"]);
|
|
179
|
+
var SectionText = _styledComponents.default.div.withConfig({
|
|
180
|
+
displayName: "SeasonalInsights__SectionText",
|
|
181
|
+
componentId: "sc-jrd7ho-12"
|
|
182
|
+
})(["font-size:14px;color:#3d3d3d;line-height:1.45;"]);
|
|
183
|
+
var ChipRow = _styledComponents.default.div.withConfig({
|
|
184
|
+
displayName: "SeasonalInsights__ChipRow",
|
|
185
|
+
componentId: "sc-jrd7ho-13"
|
|
186
|
+
})(["display:flex;gap:8px;flex-wrap:wrap;"]);
|
|
187
|
+
var Chip = _styledComponents.default.span.withConfig({
|
|
188
|
+
displayName: "SeasonalInsights__Chip",
|
|
189
|
+
componentId: "sc-jrd7ho-14"
|
|
190
|
+
})(["background:#f1f3f5;color:#1f2933;border-radius:12px;padding:6px 10px;font-size:12px;font-weight:500;border:1px solid #e0e4ea;"]);
|
|
191
|
+
var formatSectorIconName = function formatSectorIconName(value) {
|
|
192
|
+
return (value || '').toString().trim().toLowerCase().replace(/[^a-z0-9]+/g, '_').replace(/^_+|_+$/g, '');
|
|
144
193
|
};
|
|
145
194
|
var _default = SeasonalInsights;
|
|
146
195
|
exports.default = _default;
|
|
147
|
-
//# 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","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","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 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\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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"}
|
|
196
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_i18next","_interopRequireDefault","require","_react","_interopRequireWildcard","_Sector","_MoreInfoButton","_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","apiEndpoint","dataProp","data","className","onLoaded","_useState","useState","_useState2","_slicedToArray2","setData","_useState3","_useState4","showDetails","setShowDetails","useEffect","risk","useMemo","_data$insight_info","risks","insight_info","lang","locale","summary","risk_summary","detailed","detailed_risks","hasDetails","length","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","Container","dir","isRtl","SummarySection","SummaryTitle","t","SummaryText","Fragment","ToggleRow","MoreInfoDiv","href","onClick","e","preventDefault","CardList","map","r","idx","_r$expected_pollution","Card","CardHeader","TitleBlock","formatSectorIconName","sector","sectorIconName","sectorName","showLabel","withTooltip","CardTitle","siu_name","expected_pollution_types","CardSection","SectionLabel","ChipRow","p","chipIdx","Chip","seasonal_or_location_factors","SectionText","styled","div","withConfig","displayName","componentId","_ref3","span","value","toString","trim","replace","_default","exports"],"sources":["../../../src/components/SeasonalInsights/SeasonalInsights.tsx"],"sourcesContent":["import i18next from 'i18next';\nimport React, { useEffect, useMemo, useState } from 'react';\nimport styled from 'styled-components/macro';\nimport Sector from '../Sector';\nimport { MoreInfoDiv } from 'src/pages/EventsPage/events/event_info/SourceDetails/MoreInfoButton';\n\ntype DetailedRisk = {\n  sector?: string;\n  siu_name?: 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  const [showDetails, setShowDetails] = useState<boolean>(false);\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  const hasDetails = detailed.length > 0;\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    <Container\n      className={className}\n      dir={isHebrew ? 'rtl' : 'ltr'}\n      isRtl={isHebrew}\n    >\n      <SummarySection>\n        <SummaryTitle>\n          {i18next.t('seasonal_insights.summary_heading')}\n        </SummaryTitle>\n        <SummaryText>{summary}</SummaryText>\n      </SummarySection>\n\n      {hasDetails ? (\n        <>\n          <ToggleRow isRtl={isHebrew}>\n            <MoreInfoDiv>\n              <a\n                href=\"#\"\n                className=\"more-info-button\"\n                onClick={(e) => {\n                  e.preventDefault();\n                  setShowDetails((prev) => !prev);\n                }}\n                aria-expanded={showDetails}\n              >\n                {showDetails\n                  ? i18next.t('seasonal_insights.show_less')\n                  : i18next.t('seasonal_insights.show_more')}\n              </a>\n            </MoreInfoDiv>\n          </ToggleRow>\n\n          {showDetails ? (\n            <CardList>\n              {detailed.map((r, idx) => (\n                <Card key={idx}>\n                  <CardHeader>\n                    <TitleBlock>\n                      {formatSectorIconName(r.sector) ? (\n                        <Sector\n                          sectorIconName={\n                            formatSectorIconName(r.sector) || 'Missing'\n                          }\n                          sectorName={r.sector}\n                          showLabel={false}\n                          withTooltip={true}\n                        />\n                      ) : null}\n                      <CardTitle>{r.siu_name}</CardTitle>\n                    </TitleBlock>\n                  </CardHeader>\n\n                  {r.expected_pollution_types?.length ? (\n                    <CardSection>\n                      <SectionLabel>\n                        {i18next.t('seasonal_insights.key_risks')}\n                      </SectionLabel>\n                      <ChipRow>\n                        {r.expected_pollution_types.map((p, chipIdx) => (\n                          <Chip key={`${p}-${chipIdx}`}>{p}</Chip>\n                        ))}\n                      </ChipRow>\n                    </CardSection>\n                  ) : null}\n\n                  {r.seasonal_or_location_factors ? (\n                    <CardSection>\n                      <SectionLabel>\n                        {i18next.t('seasonal_insights.seasonal_factors')}\n                      </SectionLabel>\n                      <SectionText>\n                        {r.seasonal_or_location_factors}\n                      </SectionText>\n                    </CardSection>\n                  ) : null}\n                </Card>\n              ))}\n            </CardList>\n          ) : null}\n        </>\n      ) : null}\n    </Container>\n  );\n};\n\nconst Container = styled.div<{ isRtl: boolean }>`\n  padding: 16px;\n  margin: 16px;\n  display: flex;\n  flex-direction: column;\n  gap: 12px;\n  text-align: ${({ isRtl }) => (isRtl ? 'right' : 'left')};\n  background: #f7f8fa;\n  min-width: 320px;\n  border-radius: 12px;\n`;\n\nconst SummarySection = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: 8px;\n  padding: 12px 14px;\n  border-radius: 10px;\n  background: #ffffff;\n  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.06);\n`;\n\nconst SummaryTitle = styled.div`\n  font-weight: 600;\n  font-size: 16px;\n  color: #1d1d1d;\n`;\n\nconst SummaryText = styled.div`\n  font-size: 15px;\n  color: #2b2b2b;\n  line-height: 1.5;\n`;\n\nconst ToggleRow = styled.div`\n  display: flex;\n  justify-content: flex-end;\n  margin-top: 6px;\n`;\n\nconst CardList = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: 12px;\n`;\n\nconst Card = styled.div`\n  padding: 14px;\n  border-radius: 10px;\n  background: #ffffff;\n  border: 1px solid #e4e6ea;\n  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.05);\n  display: flex;\n  flex-direction: column;\n  gap: 10px;\n`;\n\nconst CardHeader = styled.div`\n  display: flex;\n  align-items: center;\n  gap: 8px;\n  justify-content: space-between;\n`;\n\nconst TitleBlock = styled.div`\n  display: inline-flex;\n  align-items: center;\n  //   gap: 8px;\n  margin-inline-start: -14px;\n`;\n\nconst CardTitle = styled.div`\n  font-weight: 600;\n  font-size: 15px;\n  color: #1e1e1e;\n`;\n\nconst CardSection = styled.div`\n  display: flex;\n  flex-direction: column;\n  gap: 6px;\n`;\n\nconst SectionLabel = styled.div`\n  font-weight: 600;\n  font-size: 13px;\n  color: #2f333a;\n`;\n\nconst SectionText = styled.div`\n  font-size: 14px;\n  color: #3d3d3d;\n  line-height: 1.45;\n`;\n\nconst ChipRow = styled.div`\n  display: flex;\n  gap: 8px;\n  flex-wrap: wrap;\n`;\n\nconst Chip = styled.span`\n  background: #f1f3f5;\n  color: #1f2933;\n  border-radius: 12px;\n  padding: 6px 10px;\n  font-size: 12px;\n  font-weight: 500;\n  border: 1px solid #e0e4ea;\n`;\n\nconst formatSectorIconName = (value?: string) =>\n  (value || '')\n    .toString()\n    .trim()\n    .toLowerCase()\n    .replace(/[^a-z0-9]+/g, '_')\n    .replace(/^_+|_+$/g, '');\n\nexport default SeasonalInsights;\n"],"mappings":"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"}
|
|
@@ -7,14 +7,17 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
7
7
|
});
|
|
8
8
|
exports.default = void 0;
|
|
9
9
|
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
|
|
10
|
-
var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/objectSpread2"));
|
|
11
10
|
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/asyncToGenerator"));
|
|
12
11
|
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/slicedToArray"));
|
|
12
|
+
var _styledComponents = _interopRequireDefault(require("styled-components"));
|
|
13
13
|
var _react = _interopRequireWildcard(require("react"));
|
|
14
14
|
var _KandoModal = _interopRequireDefault(require("../KandoModal"));
|
|
15
15
|
var _SeasonalInsights = _interopRequireDefault(require("../SeasonalInsights/SeasonalInsights"));
|
|
16
16
|
var _i18next = _interopRequireDefault(require("i18next"));
|
|
17
17
|
var _insightsDismissalStorage = require("./insightsDismissalStorage");
|
|
18
|
+
var _Analytics = require("utilities/Analytics");
|
|
19
|
+
var _reactRedux = require("react-redux");
|
|
20
|
+
var _useNavContext2 = require("hooks/useNavContext");
|
|
18
21
|
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); }
|
|
19
22
|
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; }
|
|
20
23
|
var INSIGHT_TYPE = 'seasonal_insight';
|
|
@@ -29,28 +32,24 @@ var TopBanner = function TopBanner(_ref) {
|
|
|
29
32
|
_useState2 = (0, _slicedToArray2.default)(_useState, 2),
|
|
30
33
|
visible = _useState2[0],
|
|
31
34
|
setVisible = _useState2[1];
|
|
32
|
-
var _useState3 = (0, _react.useState)(
|
|
35
|
+
var _useState3 = (0, _react.useState)(false),
|
|
33
36
|
_useState4 = (0, _slicedToArray2.default)(_useState3, 2),
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
var _useState5 = (0, _react.useState)(
|
|
37
|
+
showModal = _useState4[0],
|
|
38
|
+
setShowModal = _useState4[1];
|
|
39
|
+
var _useState5 = (0, _react.useState)(null),
|
|
37
40
|
_useState6 = (0, _slicedToArray2.default)(_useState5, 2),
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
var _useState7 = (0, _react.useState)(''),
|
|
41
|
-
_useState8 = (0, _slicedToArray2.default)(_useState7, 2),
|
|
42
|
-
learnMoreText = _useState8[0],
|
|
43
|
-
setLearnMoreText = _useState8[1];
|
|
44
|
-
var _useState9 = (0, _react.useState)(false),
|
|
45
|
-
_useState10 = (0, _slicedToArray2.default)(_useState9, 2),
|
|
46
|
-
showModal = _useState10[0],
|
|
47
|
-
setShowModal = _useState10[1];
|
|
48
|
-
var _useState11 = (0, _react.useState)(null),
|
|
49
|
-
_useState12 = (0, _slicedToArray2.default)(_useState11, 2),
|
|
50
|
-
insightData = _useState12[0],
|
|
51
|
-
setInsightData = _useState12[1];
|
|
41
|
+
insightData = _useState6[0],
|
|
42
|
+
setInsightData = _useState6[1];
|
|
52
43
|
var bannerHeight = 30; // px
|
|
53
|
-
var
|
|
44
|
+
var _useNavContext = (0, _useNavContext2.useNavContext)(),
|
|
45
|
+
dir = _useNavContext.dir;
|
|
46
|
+
var _useSelector = (0, _reactRedux.useSelector)(function (state) {
|
|
47
|
+
return state.global_data;
|
|
48
|
+
}),
|
|
49
|
+
waterAuthorityName = _useSelector.waterAuthorityName;
|
|
50
|
+
var titleText = String(_i18next.default.t('seasonal_insights.title'));
|
|
51
|
+
var learnMoreText = String(_i18next.default.t('seasonal_insights.learn_more'));
|
|
52
|
+
var dismissTooltipText = String(_i18next.default.t('seasonal_insights.dismiss_tooltip'));
|
|
54
53
|
|
|
55
54
|
// On mount or when insight id changes, check localStorage for dismissal
|
|
56
55
|
(0, _react.useEffect)(function () {
|
|
@@ -60,24 +59,20 @@ var TopBanner = function TopBanner(_ref) {
|
|
|
60
59
|
var record = (0, _insightsDismissalStorage.getDismissal)(INSIGHT_TYPE);
|
|
61
60
|
var dismissed = (record === null || record === void 0 ? void 0 : record.lastDismissedId) === String(insightData.id);
|
|
62
61
|
setVisible(!dismissed);
|
|
63
|
-
if (onVisibilityChange) onVisibilityChange(!dismissed);
|
|
64
62
|
} catch (_unused) {
|
|
65
63
|
setVisible(true);
|
|
66
|
-
if (onVisibilityChange) onVisibilityChange(true);
|
|
67
64
|
}
|
|
68
65
|
} else if (insightData === null) {
|
|
69
66
|
// No insight data - hide banner if using API, show if using static text prop
|
|
70
67
|
if (apiEndpoint) {
|
|
71
68
|
// API endpoint exists but no data returned - hide banner
|
|
72
69
|
setVisible(false);
|
|
73
|
-
if (onVisibilityChange) onVisibilityChange(false);
|
|
74
70
|
} else {
|
|
75
71
|
// No API endpoint - show banner if text is provided
|
|
76
72
|
setVisible(!!text);
|
|
77
|
-
if (onVisibilityChange) onVisibilityChange(!!text);
|
|
78
73
|
}
|
|
79
74
|
}
|
|
80
|
-
}, [insightData === null || insightData === void 0 ? void 0 : insightData.id, insightData, apiEndpoint, text
|
|
75
|
+
}, [insightData === null || insightData === void 0 ? void 0 : insightData.id, insightData, apiEndpoint, text]);
|
|
81
76
|
|
|
82
77
|
// Fetch data from API if endpoint is provided, robustly
|
|
83
78
|
(0, _react.useEffect)(function () {
|
|
@@ -123,22 +118,14 @@ var TopBanner = function TopBanner(_ref) {
|
|
|
123
118
|
// When the API says not_found, do not show the banner.
|
|
124
119
|
if ((data === null || data === void 0 ? void 0 : data.error) === 'not_found') {
|
|
125
120
|
setInsightData(null);
|
|
126
|
-
setHeaderText(null);
|
|
127
|
-
setTitleText('');
|
|
128
|
-
setLearnMoreText('');
|
|
129
121
|
setVisible(false);
|
|
130
122
|
return;
|
|
131
123
|
}
|
|
132
124
|
setInsightData(data);
|
|
133
|
-
setTitleText(String(_i18next.default.t('seasonal_insights.title')));
|
|
134
|
-
setLearnMoreText(String(_i18next.default.t('seasonal_insights.learn_more')));
|
|
135
125
|
}).catch(function (err) {
|
|
136
126
|
// On fetch error, hide the banner (no data to show)
|
|
137
127
|
if ((err === null || err === void 0 ? void 0 : err.name) !== 'AbortError') {
|
|
138
128
|
setInsightData(null);
|
|
139
|
-
setHeaderText(null);
|
|
140
|
-
setTitleText('');
|
|
141
|
-
setLearnMoreText('');
|
|
142
129
|
setVisible(false);
|
|
143
130
|
}
|
|
144
131
|
});
|
|
@@ -154,6 +141,10 @@ var TopBanner = function TopBanner(_ref) {
|
|
|
154
141
|
|
|
155
142
|
// When dismissed, persist in localStorage
|
|
156
143
|
var handleDismiss = function handleDismiss() {
|
|
144
|
+
(0, _Analytics.analyticsTrack)('seasonal_insight_dismissed', {
|
|
145
|
+
id: insightData === null || insightData === void 0 ? void 0 : insightData.id,
|
|
146
|
+
utility_name: waterAuthorityName
|
|
147
|
+
});
|
|
157
148
|
setVisible(false);
|
|
158
149
|
if ((insightData === null || insightData === void 0 ? void 0 : insightData.id) === undefined) return;
|
|
159
150
|
try {
|
|
@@ -164,23 +155,24 @@ var TopBanner = function TopBanner(_ref) {
|
|
|
164
155
|
};
|
|
165
156
|
var openModal = function openModal() {
|
|
166
157
|
setShowModal(true);
|
|
158
|
+
(0, _Analytics.analyticsTrack)('Clicked seasonal_insight', {
|
|
159
|
+
id: insightData === null || insightData === void 0 ? void 0 : insightData.id,
|
|
160
|
+
utility_name: waterAuthorityName
|
|
161
|
+
});
|
|
167
162
|
};
|
|
168
163
|
var closeModal = function closeModal() {
|
|
169
164
|
setShowModal(false);
|
|
170
165
|
};
|
|
171
166
|
var modal = (0, _react.useMemo)(function () {
|
|
172
167
|
if (!showModal) return null;
|
|
173
|
-
var dir = _i18next.default.dir();
|
|
174
168
|
return /*#__PURE__*/_react.default.createElement(_KandoModal.default, {
|
|
175
169
|
isOpen: showModal,
|
|
176
|
-
onClose: closeModal
|
|
177
|
-
dir: dir
|
|
170
|
+
onClose: closeModal
|
|
178
171
|
}, /*#__PURE__*/_react.default.createElement(_SeasonalInsights.default, {
|
|
179
172
|
data: insightData
|
|
180
173
|
}));
|
|
181
174
|
}, [showModal]);
|
|
182
|
-
|
|
183
|
-
if (!visible || !hasContent) {
|
|
175
|
+
if (!visible || !apiEndpoint) {
|
|
184
176
|
return null;
|
|
185
177
|
}
|
|
186
178
|
return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("div", {
|
|
@@ -199,7 +191,7 @@ var TopBanner = function TopBanner(_ref) {
|
|
|
199
191
|
fontSize: '14px',
|
|
200
192
|
cursor: 'default'
|
|
201
193
|
}
|
|
202
|
-
}, /*#__PURE__*/_react.default.createElement("span", null, apiEndpoint
|
|
194
|
+
}, /*#__PURE__*/_react.default.createElement("span", null, apiEndpoint && /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("span", {
|
|
203
195
|
style: {
|
|
204
196
|
filter: 'drop-shadow(0 0 2px rgba(0, 0, 0, 0.3))',
|
|
205
197
|
fontSize: '16px',
|
|
@@ -212,24 +204,24 @@ var TopBanner = function TopBanner(_ref) {
|
|
|
212
204
|
textDecoration: 'underline',
|
|
213
205
|
cursor: 'pointer'
|
|
214
206
|
}
|
|
215
|
-
}, learnMoreText))
|
|
207
|
+
}, learnMoreText))), /*#__PURE__*/_react.default.createElement(DismissButton, {
|
|
216
208
|
onClick: handleDismiss,
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
right: 'auto'
|
|
222
|
-
} : {
|
|
223
|
-
right: 10
|
|
224
|
-
}), {}, {
|
|
225
|
-
background: 'transparent',
|
|
226
|
-
border: 'none',
|
|
227
|
-
fontSize: '24px',
|
|
228
|
-
cursor: 'pointer'
|
|
229
|
-
}),
|
|
230
|
-
"aria-label": "Dismiss banner"
|
|
209
|
+
"aria-label": 'dismissTooltip',
|
|
210
|
+
className: "kd-tooltip",
|
|
211
|
+
"data-text": dismissTooltipText,
|
|
212
|
+
isRtl: dir === 'rtl'
|
|
231
213
|
}, "\xD7")), modal);
|
|
232
214
|
};
|
|
215
|
+
var DismissButton = _styledComponents.default.button.withConfig({
|
|
216
|
+
displayName: "TopBanner__DismissButton",
|
|
217
|
+
componentId: "sc-1towuq0-0"
|
|
218
|
+
})(["position:absolute;", " background:transparent;border:none;font-size:24px;cursor:pointer;&.kd-tooltip{&[data-text]::after{content:attr(data-text);position:absolute;color:white;background-color:rgba(0,0,0,0.9);border-radius:5px;top:16px;", " padding:4px 6px;z-index:-1;white-space:nowrap;font-size:12px;}&:hover{&[data-text]::after{z-index:10000;}}}"], function (_ref3) {
|
|
219
|
+
var isRtl = _ref3.isRtl;
|
|
220
|
+
return isRtl ? 'left: 10px; right: auto;' : 'right: 10px; left: auto;';
|
|
221
|
+
}, function (_ref4) {
|
|
222
|
+
var isRtl = _ref4.isRtl;
|
|
223
|
+
return isRtl ? 'left: 22px;' : 'right: 22px;';
|
|
224
|
+
});
|
|
233
225
|
var _default = TopBanner;
|
|
234
226
|
exports.default = _default;
|
|
235
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_KandoModal","_interopRequireDefault","_SeasonalInsights","_i18next","_insightsDismissalStorage","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","INSIGHT_TYPE","TopBanner","_ref","_ref$backgroundColor","backgroundColor","_ref$text","text","onVisibilityChange","apiEndpoint","_useState","useState","_useState2","_slicedToArray2","visible","setVisible","_useState3","_useState4","headerText","setHeaderText","_useState5","_useState6","titleText","setTitleText","_useState7","_useState8","learnMoreText","setLearnMoreText","_useState9","_useState10","showModal","setShowModal","_useState11","_useState12","insightData","setInsightData","bannerHeight","dir","i18next","useEffect","id","undefined","record","getDismissal","dismissed","lastDismissedId","String","_unused","controller","AbortController","fetch","signal","then","_ref2","_asyncToGenerator2","_regenerator","mark","_callee","res","wrap","_callee$","_context","prev","next","status","abrupt","error","ok","Error","concat","json","sent","stop","_x","apply","arguments","data","t","catch","err","name","abort","handleDismiss","setDismissal","_unused2","openModal","closeModal","modal","useMemo","createElement","isOpen","onClose","hasContent","Fragment","style","width","background","padding","textAlign","position","boxSizing","minHeight","height","display","alignItems","justifyContent","fontSize","cursor","filter","marginRight","onClick","textDecoration","_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';\nimport {\n  getDismissal,\n  setDismissal,\n  InsightType,\n} from './insightsDismissalStorage';\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 INSIGHT_TYPE: InsightType = 'seasonal_insight';\n\nconst TopBanner: React.FC<TopBannerProps> = ({\n  backgroundColor = 'rgb(217, 234, 255)', // #f5b7c5',\n  text = '',\n  onVisibilityChange,\n  apiEndpoint,\n}) => {\n  const [visible, setVisible] = useState(true);\n  const [headerText, setHeaderText] = useState<React.ReactNode>(null);\n  const [titleText, setTitleText] = useState<string>('');\n  const [learnMoreText, setLearnMoreText] = useState<string>('');\n  const [showModal, setShowModal] = useState(false);\n  const [insightData, setInsightData] =\n    useState<SeasonalInsightResponse | null>(null);\n\n  const bannerHeight = 30; // px\n  const dir = i18next.dir();\n\n  // On mount or when insight id changes, check localStorage for dismissal\n  useEffect(() => {\n    // If we have insight data with an id, check if it was dismissed\n    if (insightData?.id !== undefined) {\n      try {\n        const record = getDismissal(INSIGHT_TYPE);\n        const dismissed = record?.lastDismissedId === String(insightData.id);\n        setVisible(!dismissed);\n        if (onVisibilityChange) onVisibilityChange(!dismissed);\n      } catch {\n        setVisible(true);\n        if (onVisibilityChange) onVisibilityChange(true);\n      }\n    } else if (insightData === null) {\n      // No insight data - hide banner if using API, show if using static text prop\n      if (apiEndpoint) {\n        // API endpoint exists but no data returned - hide banner\n        setVisible(false);\n        if (onVisibilityChange) onVisibilityChange(false);\n      } else {\n        // No API endpoint - show banner if text is provided\n        setVisible(!!text);\n        if (onVisibilityChange) onVisibilityChange(!!text);\n      }\n    }\n  }, [insightData?.id, insightData, apiEndpoint, text, onVisibilityChange]);\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          setTitleText('');\n          setLearnMoreText('');\n          setVisible(false);\n          return;\n        }\n        setInsightData(data);\n\n        setTitleText(String(i18next.t('seasonal_insights.title')));\n        setLearnMoreText(String(i18next.t('seasonal_insights.learn_more')));\n      })\n      .catch((err) => {\n        // On fetch error, hide the banner (no data to show)\n        if (err?.name !== 'AbortError') {\n          setInsightData(null);\n          setHeaderText(null);\n          setTitleText('');\n          setLearnMoreText('');\n          setVisible(false);\n        }\n      });\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    if (insightData?.id === undefined) return;\n\n    try {\n      setDismissal(INSIGHT_TYPE, String(insightData.id));\n    } catch {\n      // ignore storage errors\n    }\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 hasContent = apiEndpoint\n    ? titleText && learnMoreText\n    : text || headerText;\n  if (!visible || !hasContent) {\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          boxSizing: 'border-box',\n          minHeight: `${bannerHeight}px`,\n          height: `${bannerHeight}px`,\n          display: 'flex',\n          alignItems: 'center',\n          justifyContent: 'center',\n          fontSize: '14px',\n          cursor: 'default',\n        }}\n      >\n        <span>\n          {apiEndpoint ? (\n            <>\n              <span\n                style={{\n                  filter: 'drop-shadow(0 0 2px rgba(0, 0, 0, 0.3))',\n                  fontSize: '16px',\n                  display: 'inline-block',\n                  marginRight: '4px',\n                }}\n              >\n                ✨\n              </span>\n              {titleText}{' '}\n              <span\n                onClick={openModal}\n                style={{\n                  textDecoration: 'underline',\n                  cursor: 'pointer',\n                }}\n              >\n                {learnMoreText}\n              </span>\n            </>\n          ) : (\n            headerText || text\n          )}\n        </span>\n        <button\n          onClick={handleDismiss}\n          style={{\n            position: 'absolute',\n            ...(dir === 'rtl'\n              ? { left: 10, right: 'auto' as const }\n              : { right: 10 }),\n            background: 'transparent',\n            border: 'none',\n            fontSize: '24px',\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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"}
|
|
227
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_KandoModal","_interopRequireDefault","_SeasonalInsights","_i18next","_insightsDismissalStorage","_Analytics","_reactRedux","_useNavContext2","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","INSIGHT_TYPE","TopBanner","_ref","_ref$backgroundColor","backgroundColor","_ref$text","text","onVisibilityChange","apiEndpoint","_useState","useState","_useState2","_slicedToArray2","visible","setVisible","_useState3","_useState4","showModal","setShowModal","_useState5","_useState6","insightData","setInsightData","bannerHeight","_useNavContext","useNavContext","dir","_useSelector","useSelector","state","global_data","waterAuthorityName","titleText","String","i18next","t","learnMoreText","dismissTooltipText","useEffect","id","undefined","record","getDismissal","dismissed","lastDismissedId","_unused","controller","AbortController","fetch","signal","then","_ref2","_asyncToGenerator2","_regenerator","mark","_callee","res","wrap","_callee$","_context","prev","next","status","abrupt","error","ok","Error","concat","json","sent","stop","_x","apply","arguments","data","catch","err","name","abort","handleDismiss","analyticsTrack","utility_name","setDismissal","_unused2","openModal","closeModal","modal","useMemo","createElement","isOpen","onClose","Fragment","style","width","background","padding","textAlign","position","boxSizing","minHeight","height","display","alignItems","justifyContent","fontSize","cursor","filter","marginRight","onClick","textDecoration","DismissButton","className","isRtl","styled","button","withConfig","displayName","componentId","_ref3","_ref4","_default","exports"],"sources":["../../../src/components/TopBanner/TopBanner.tsx"],"sourcesContent":["import React, { useState, useEffect, useMemo } from 'react';\nimport styled from 'styled-components/macro';\nimport KandoModal from '../KandoModal';\nimport SeasonalInsights, {\n  SeasonalInsightResponse,\n} from '../SeasonalInsights/SeasonalInsights';\nimport i18next from 'i18next';\nimport {\n  getDismissal,\n  setDismissal,\n  InsightType,\n} from './insightsDismissalStorage';\nimport { analyticsTrack } from 'src/utilities/Analytics';\nimport { useSelector } from 'react-redux';\nimport { useNavContext } from 'src/hooks/useNavContext';\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 INSIGHT_TYPE: InsightType = 'seasonal_insight';\n\nconst TopBanner: React.FC<TopBannerProps> = ({\n  backgroundColor = 'rgb(217, 234, 255)', // #f5b7c5',\n  text = '',\n  onVisibilityChange,\n  apiEndpoint,\n}) => {\n  const [visible, setVisible] = useState(true);\n  const [showModal, setShowModal] = useState(false);\n  const [insightData, setInsightData] =\n    useState<SeasonalInsightResponse | null>(null);\n\n  const bannerHeight = 30; // px\n  const { dir } = useNavContext();\n  const { waterAuthorityName } = useSelector((state) => state.global_data);\n\n  const titleText = String(i18next.t('seasonal_insights.title'));\n  const learnMoreText = String(i18next.t('seasonal_insights.learn_more'));\n  const dismissTooltipText = String(\n    i18next.t('seasonal_insights.dismiss_tooltip'),\n  );\n\n  // On mount or when insight id changes, check localStorage for dismissal\n  useEffect(() => {\n    // If we have insight data with an id, check if it was dismissed\n    if (insightData?.id !== undefined) {\n      try {\n        const record = getDismissal(INSIGHT_TYPE);\n        const dismissed = record?.lastDismissedId === String(insightData.id);\n        setVisible(!dismissed);\n      } catch {\n        setVisible(true);\n      }\n    } else if (insightData === null) {\n      // No insight data - hide banner if using API, show if using static text prop\n      if (apiEndpoint) {\n        // API endpoint exists but no data returned - hide banner\n        setVisible(false);\n      } else {\n        // No API endpoint - show banner if text is provided\n        setVisible(!!text);\n      }\n    }\n  }, [insightData?.id, insightData, apiEndpoint, text]);\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          setVisible(false);\n          return;\n        }\n        setInsightData(data);\n      })\n      .catch((err) => {\n        // On fetch error, hide the banner (no data to show)\n        if (err?.name !== 'AbortError') {\n          setInsightData(null);\n          setVisible(false);\n        }\n      });\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    analyticsTrack('seasonal_insight_dismissed', {\n      id: insightData?.id,\n      utility_name: waterAuthorityName,\n    });\n    setVisible(false);\n    if (insightData?.id === undefined) return;\n\n    try {\n      setDismissal(INSIGHT_TYPE, String(insightData.id));\n    } catch {\n      // ignore storage errors\n    }\n  };\n\n  const openModal = () => {\n    setShowModal(true);\n    analyticsTrack('Clicked seasonal_insight', {\n      id: insightData?.id,\n      utility_name: waterAuthorityName,\n    });\n  };\n\n  const closeModal = () => {\n    setShowModal(false);\n  };\n\n  const modal = useMemo(() => {\n    if (!showModal) return null;\n    return (\n      <KandoModal isOpen={showModal} onClose={closeModal}>\n        <SeasonalInsights data={insightData} />\n      </KandoModal>\n    );\n  }, [showModal]);\n\n  if (!visible || !apiEndpoint) {\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          boxSizing: 'border-box',\n          minHeight: `${bannerHeight}px`,\n          height: `${bannerHeight}px`,\n          display: 'flex',\n          alignItems: 'center',\n          justifyContent: 'center',\n          fontSize: '14px',\n          cursor: 'default',\n        }}\n      >\n        <span>\n          {apiEndpoint && (\n            <>\n              <span\n                style={{\n                  filter: 'drop-shadow(0 0 2px rgba(0, 0, 0, 0.3))',\n                  fontSize: '16px',\n                  display: 'inline-block',\n                  marginRight: '4px',\n                }}\n              >\n                ✨\n              </span>\n              {titleText}{' '}\n              <span\n                onClick={openModal}\n                style={{\n                  textDecoration: 'underline',\n                  cursor: 'pointer',\n                }}\n              >\n                {learnMoreText}\n              </span>\n            </>\n          )}\n        </span>\n        <DismissButton\n          onClick={handleDismiss}\n          aria-label={'dismissTooltip'}\n          className=\"kd-tooltip\"\n          data-text={dismissTooltipText}\n          isRtl={dir === 'rtl'}\n        >\n          ×\n        </DismissButton>\n      </div>\n      {modal}\n    </>\n  );\n};\n\nconst DismissButton = styled.button<{ isRtl: boolean }>`\n  position: absolute;\n  ${({ isRtl }) =>\n    isRtl ? 'left: 10px; right: auto;' : 'right: 10px; left: auto;'}\n  background: transparent;\n  border: none;\n  font-size: 24px;\n  cursor: pointer;\n\n  &.kd-tooltip {\n    &[data-text]::after {\n      content: attr(data-text);\n      position: absolute;\n      color: white;\n      background-color: rgba(0, 0, 0, 0.9);\n      border-radius: 5px;\n      top: 16px;\n      ${({ isRtl }) => (isRtl ? 'left: 22px;' : 'right: 22px;')}\n      padding: 4px 6px;\n      z-index: -1;\n      //   transition: all 0.2s ease-in-out;\n      white-space: nowrap;\n      font-size: 12px;\n    }\n    &:hover {\n      &[data-text]::after {\n        z-index: 10000;\n      }\n    }\n  }\n`;\n\nexport default TopBanner;\n"],"mappings":"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"}
|
package/lib/i18n/en.json
CHANGED
|
@@ -4142,8 +4142,17 @@
|
|
|
4142
4142
|
}
|
|
4143
4143
|
},
|
|
4144
4144
|
"seasonal_insights": {
|
|
4145
|
-
"title": "Seasonal Insights Available",
|
|
4146
|
-
"learn_more": "Learn more"
|
|
4145
|
+
"title": "Seasonal Insights Available.",
|
|
4146
|
+
"learn_more": "Learn more.",
|
|
4147
|
+
"dismiss_tooltip": "Dismiss until a new insight is available.",
|
|
4148
|
+
"tooltip": "Seasonal insights highlight the key changes for this time of year. Click Learn more to see the full details.",
|
|
4149
|
+
"show_more": "More info",
|
|
4150
|
+
"show_less": "Show less",
|
|
4151
|
+
"summary_heading": "What to expect next",
|
|
4152
|
+
"timeframe": "Time window",
|
|
4153
|
+
"confidence": "Confidence",
|
|
4154
|
+
"key_risks": "Key risks",
|
|
4155
|
+
"seasonal_factors": "Seasonal factors"
|
|
4147
4156
|
}
|
|
4148
4157
|
}
|
|
4149
4158
|
}
|
package/lib/i18n/fr.json
CHANGED
|
@@ -3795,8 +3795,17 @@
|
|
|
3795
3795
|
}
|
|
3796
3796
|
},
|
|
3797
3797
|
"seasonal_insights": {
|
|
3798
|
-
"title": "Informations saisonnières disponibles",
|
|
3799
|
-
"learn_more": "En savoir plus"
|
|
3798
|
+
"title": "Informations saisonnières disponibles.",
|
|
3799
|
+
"learn_more": "En savoir plus.",
|
|
3800
|
+
"dismiss_tooltip": "Ignorer jusqu’à ce qu’un nouvel aperçu soit disponible.",
|
|
3801
|
+
"tooltip": "Les informations saisonnières mettent en avant les principaux changements de la période. Cliquez sur En savoir plus pour voir tous les détails.",
|
|
3802
|
+
"show_more": "Plus d’infos",
|
|
3803
|
+
"show_less": "Afficher moins",
|
|
3804
|
+
"summary_heading": "À quoi s’attendre ensuite",
|
|
3805
|
+
"timeframe": "Période",
|
|
3806
|
+
"confidence": "Confiance",
|
|
3807
|
+
"key_risks": "Principaux risques",
|
|
3808
|
+
"seasonal_factors": "Facteurs saisonniers"
|
|
3800
3809
|
}
|
|
3801
3810
|
}
|
|
3802
3811
|
}
|
package/lib/i18n/he.json
CHANGED
|
@@ -3921,8 +3921,17 @@
|
|
|
3921
3921
|
}
|
|
3922
3922
|
},
|
|
3923
3923
|
"seasonal_insights": {
|
|
3924
|
-
"title": "תובנות עונתיות
|
|
3925
|
-
"learn_more": "למד
|
|
3924
|
+
"title": "תובנות עונתיות זמינות.",
|
|
3925
|
+
"learn_more": "למד עוד.",
|
|
3926
|
+
"dismiss_tooltip": "התעלם עד שתהיה תובנה חדשה זמינה.",
|
|
3927
|
+
"tooltip": "תובנות עונתיות מדגישות את השינויים המרכזיים בתקופה זו. לחץ על למד עוד כדי לראות את כל הפרטים.",
|
|
3928
|
+
"show_more": "מידע נוסף",
|
|
3929
|
+
"show_less": "הסתר מידע",
|
|
3930
|
+
"summary_heading": "מה צפוי בהמשך",
|
|
3931
|
+
"timeframe": "מסגרת זמן",
|
|
3932
|
+
"confidence": "רמת ודאות",
|
|
3933
|
+
"key_risks": "סיכונים מרכזיים",
|
|
3934
|
+
"seasonal_factors": "גורמים עונתיים"
|
|
3926
3935
|
}
|
|
3927
3936
|
}
|
|
3928
3937
|
}
|
package/lib/i18n/it.json
CHANGED
|
@@ -3808,8 +3808,17 @@
|
|
|
3808
3808
|
}
|
|
3809
3809
|
},
|
|
3810
3810
|
"seasonal_insights": {
|
|
3811
|
-
"title": "Approfondimenti stagionali disponibili",
|
|
3812
|
-
"learn_more": "Scopri di
|
|
3811
|
+
"title": "Approfondimenti stagionali disponibili.",
|
|
3812
|
+
"learn_more": "Scopri di più.",
|
|
3813
|
+
"dismiss_tooltip": "Ignora finché non sarà disponibile una nuova informazione.",
|
|
3814
|
+
"tooltip": "Gli approfondimenti stagionali evidenziano i principali cambiamenti di questo periodo. Fai clic su Scopri di più per vedere tutti i dettagli.",
|
|
3815
|
+
"show_more": "Più informazioni",
|
|
3816
|
+
"show_less": "Mostra meno",
|
|
3817
|
+
"summary_heading": "Cosa aspettarsi dopo",
|
|
3818
|
+
"timeframe": "Finestra temporale",
|
|
3819
|
+
"confidence": "Attendibilità",
|
|
3820
|
+
"key_risks": "Rischi principali",
|
|
3821
|
+
"seasonal_factors": "Fattori stagionali"
|
|
3813
3822
|
}
|
|
3814
3823
|
}
|
|
3815
3824
|
}
|
package/lib/macros/getVersion.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
var packageJsonVersion = "1.2.466-alpha.
|
|
3
|
+
var packageJsonVersion = "1.2.466-alpha.11";
|
|
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));
|