@kando-env/kando-ui 1.2.466-alpha.10 → 1.2.466-alpha.12

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.
@@ -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: '14px',
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
- } : undefined;
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: resolvedDir
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":";;;;;;;;;AAAA,IAAAA,MAAA,GAAAC,uBAAA,CAAAC,OAAA;AACA,IAAAC,OAAA,GAAAD,OAAA;AACA,IAAAE,qBAAA,GAAAF,OAAA;AACAA,OAAA;AAEA,IAAAG,YAAA,GAAAC,sBAAA,CAAAJ,OAAA;AAEAA,OAAA;AACA,IAAAK,eAAA,GAAAL,OAAA;AAAwD,SAAAM,yBAAAC,WAAA,eAAAC,OAAA,kCAAAC,iBAAA,OAAAD,OAAA,QAAAE,gBAAA,OAAAF,OAAA,YAAAF,wBAAA,YAAAA,yBAAAC,WAAA,WAAAA,WAAA,GAAAG,gBAAA,GAAAD,iBAAA,KAAAF,WAAA;AAAA,SAAAR,wBAAAY,GAAA,EAAAJ,WAAA,SAAAA,WAAA,IAAAI,GAAA,IAAAA,GAAA,CAAAC,UAAA,WAAAD,GAAA,QAAAA,GAAA,aAAAE,OAAA,CAAAF,GAAA,yBAAAA,GAAA,4BAAAG,OAAA,EAAAH,GAAA,UAAAI,KAAA,GAAAT,wBAAA,CAAAC,WAAA,OAAAQ,KAAA,IAAAA,KAAA,CAAAC,GAAA,CAAAL,GAAA,YAAAI,KAAA,CAAAE,GAAA,CAAAN,GAAA,SAAAO,MAAA,WAAAC,qBAAA,GAAAC,MAAA,CAAAC,cAAA,IAAAD,MAAA,CAAAE,wBAAA,WAAAC,GAAA,IAAAZ,GAAA,QAAAY,GAAA,kBAAAH,MAAA,CAAAI,SAAA,CAAAC,cAAA,CAAAC,IAAA,CAAAf,GAAA,EAAAY,GAAA,SAAAI,IAAA,GAAAR,qBAAA,GAAAC,MAAA,CAAAE,wBAAA,CAAAX,GAAA,EAAAY,GAAA,cAAAI,IAAA,KAAAA,IAAA,CAAAV,GAAA,IAAAU,IAAA,CAAAC,GAAA,KAAAR,MAAA,CAAAC,cAAA,CAAAH,MAAA,EAAAK,GAAA,EAAAI,IAAA,YAAAT,MAAA,CAAAK,GAAA,IAAAZ,GAAA,CAAAY,GAAA,SAAAL,MAAA,CAAAJ,OAAA,GAAAH,GAAA,MAAAI,KAAA,IAAAA,KAAA,CAAAa,GAAA,CAAAjB,GAAA,EAAAO,MAAA,YAAAA,MAAA;AAexD;AACA;AACA;AACA,IAAMW,UAAiC,GAAG,SAApCA,UAAiCA,CAAAC,IAAA,EAUjC;EAAA,IAAAC,WAAA,GAAAD,IAAA,CATJE,MAAM;IAANA,MAAM,GAAAD,WAAA,cAAG,KAAK,GAAAA,WAAA;IACdE,WAAW,GAAAH,IAAA,CAAXG,WAAW;IAAAC,kBAAA,GAAAJ,IAAA,CACXK,aAAa;IAAbA,aAAa,GAAAD,kBAAA,cAAG,CAAC,CAAC,GAAAA,kBAAA;IAClBE,QAAQ,GAAAN,IAAA,CAARM,QAAQ;IACRC,IAAI,GAAAP,IAAA,CAAJO,IAAI;IACJC,WAAW,GAAAR,IAAA,CAAXQ,WAAW;IACXC,iBAAiB,GAAAT,IAAA,CAAjBS,iBAAiB;IACjBC,OAAO,GAAAV,IAAA,CAAPU,OAAO;IAAAC,eAAA,GAAAX,IAAA,CACPY,UAAU;IAAVA,UAAU,GAAAD,eAAA,cAAG,KAAK,GAAAA,eAAA;EAElB,IAAME,YAAY,GAAGC,cAAK,CAACC,MAAM,CAAC,IAAI,CAAC;EACvC,IAAAC,SAAA,GAAwB,IAAAC,eAAQ,EAACf,MAAM,CAAC;IAAAgB,UAAA,OAAAC,eAAA,CAAAnC,OAAA,EAAAgC,SAAA;IAAjCI,IAAI,GAAAF,UAAA;IAAEG,OAAO,GAAAH,UAAA;EAEpB,IAAMI,WAAW,GAAG,SAAdA,WAAWA,CAAA;IAAA,OAASD,OAAO,CAAC,IAAI,CAAC;EAAA;EACvC,IAAME,YAAY,GAAG,SAAfA,YAAYA,CAAA,EAAS;IACzBF,OAAO,CAAC,KAAK,CAAC;IACdG,YAAY,CAAC,CAAC;IACd,IAAId,OAAO,EAAEA,OAAO,CAAC,CAAC;EACxB,CAAC;EACD,IAAMe,QAAQ,GAAG,IAAAC,oBAAW,EAAC,CAAC;EAC9B,IAAMC,WAAW,GAAG,SAAdA,WAAWA,CAAA,EAAS;IACxB,IAAIlB,iBAAiB,KAAKmB,SAAS,EAAE;MACnCnB,iBAAiB,CAAE,CAAC;IACtB;IACAa,WAAW,CAAC,CAAC;EACf,CAAC;EACD,IAAAO,cAAA,GAAuB,IAAAC,6BAAa,EAAC,CAAC;IAA9BC,KAAK,GAAAF,cAAA,CAALE,KAAK;IAAEC,GAAG,GAAAH,cAAA,CAAHG,GAAG;;EAElB;EACA,SAASC,aAAaA,CAAA,EAAG;IACvB,IAAI,CAAC,IAAAC,eAAO,EAAC7B,aAAa,CAAC,EAAE;MAC3B,SAAA8B,EAAA,MAAAC,eAAA,GAA6B9C,MAAM,CAAC+C,OAAO,CAAChC,aAAa,CAAC,EAAA8B,EAAA,GAAAC,eAAA,CAAAE,MAAA,EAAAH,EAAA,IAAE;QAAvD,IAAAI,kBAAA,OAAApB,eAAA,CAAAnC,OAAA,EAAAoD,eAAA,CAAAD,EAAA;UAAOK,KAAK,GAAAD,kBAAA;UAAEE,KAAK,GAAAF,kBAAA;QACtBd,QAAQ,CAAC3B,GAAG,CAAC0C,KAAK,EAAEC,KAAK,CAAC;QAC1BC,MAAM,CAACC,OAAO,CAACC,YAAY,CACzB,CAAC,CAAC,EACF,EAAE,KAAAC,MAAA,CACCH,MAAM,CAACI,QAAQ,CAACC,QAAQ,OAAAF,MAAA,CAAIpB,QAAQ,CACzC,CAAC;MACH;IACF;EACF;;EAEA;EACA,SAASD,YAAYA,CAAA,EAAG;IACtB,IAAI,CAAC,IAAAU,eAAO,EAAC7B,aAAa,CAAC,EAAE;MAC3B,SAAA2C,GAAA,MAAAC,gBAAA,GAAsB3D,MAAM,CAAC+C,OAAO,CAAChC,aAAa,CAAC,EAAA2C,GAAA,GAAAC,gBAAA,CAAAX,MAAA,EAAAU,GAAA,IAAE;QAAhD,IAAAE,mBAAA,OAAA/B,eAAA,CAAAnC,OAAA,EAAAiE,gBAAA,CAAAD,GAAA;UAAOR,KAAK,GAAAU,mBAAA;QACfzB,QAAQ,CAAC0B,MAAM,CAACX,KAAK,CAAC;QACtBE,MAAM,CAACC,OAAO,CAACC,YAAY,CACzB,CAAC,CAAC,EACF,EAAE,KAAAC,MAAA,CACCH,MAAM,CAACI,QAAQ,CAACC,QAAQ,OAAAF,MAAA,CAAIpB,QAAQ,CACzC,CAAC;MACH;IACF;EACF;EAEA,IAAA2B,gBAAS,EAAC,YAAM;IACd,IAAIhC,IAAI,EAAE;MACRa,aAAa,CAAC,CAAC;IACjB;EACF,CAAC,EAAE,CAACb,IAAI,CAAC,CAAC;EAEV,IAAMiC,WAAW,GAAGtB,KAAK,GACrB;IACEuB,WAAW,EAAE;MACXC,IAAI,EAAE,KAAK;MACXC,KAAK,EAAE,MAAM;MACbC,GAAG,EAAE;IACP;EACF,CAAC,GACD;IACEH,WAAW,EAAE;MACXE,KAAK,EAAE,KAAK;MACZC,GAAG,EAAE;IACP;EACF,CAAC;EAEL,oBACEzF,MAAA,CAAAgB,OAAA,CAAA0E,aAAA,CAAA1F,MAAA,CAAAgB,OAAA,CAAA2E,QAAA,QACG,CAAC/C,UAAU,iBACV5C,MAAA,CAAAgB,OAAA,CAAA0E,aAAA;IACEE,SAAS,oCAAAf,MAAA,CAAoCrC,WAAW,CAAG;IAC3DqD,OAAO,EAAE,SAAAA,QAAA;MAAA,OAAMlC,WAAW,CAAC,CAAC;IAAA;EAAC,GAE5BxB,WACE,CACN,eACDnC,MAAA,CAAAgB,OAAA,CAAA0E,aAAA,CAACtF,qBAAA,CAAA0F,KAAK;IACJC,SAAS,EAAElD,YAAY,CAACmD,OAAQ;IAChCC,MAAM;IACN7C,IAAI,EAAEA,IAAK;IACXV,OAAO,EAAEa,YAAa;IACtB2C,MAAM,EAAEb,WAAY;IACpBc,UAAU,EAAE;MACVC,OAAO,EAAE,iBAAiB;MAC1BC,KAAK,yBAAAxB,MAAA,CAAyBtC,IAAI;IACpC;EAAE,gBAEFvC,MAAA,CAAAgB,OAAA,CAAA0E,aAAA;IAAK1B,GAAG,EAAEA;EAAI,GAAE1B,QAAc,CACzB,CACP,CAAC;AAEP,CAAC;AAAC,IAAAgE,QAAA,GAEavE,UAAU;AAAAwE,OAAA,CAAAvF,OAAA,GAAAsF,QAAA"}
@@ -3,6 +3,10 @@
3
3
  }
4
4
 
5
5
  .kmodal {
6
+ position: relative;
7
+ border-radius: 12px;
8
+ overflow: hidden;
9
+ padding: 16px;
6
10
  &__overlay {
7
11
  background: #222222aa;
8
12
  }
@@ -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("div", {
96
+ return /*#__PURE__*/_react.default.createElement(Container, {
89
97
  className: className,
90
98
  dir: isHebrew ? 'rtl' : 'ltr',
91
- style: {
92
- padding: 12,
93
- display: 'flex',
94
- flexDirection: 'column',
95
- gap: 12,
96
- textAlign: isHebrew ? 'right' : 'left'
97
- }
98
- }, /*#__PURE__*/_react.default.createElement("div", {
99
- style: {
100
- display: 'flex',
101
- flexDirection: 'column',
102
- gap: 4
103
- }
104
- }, /*#__PURE__*/_react.default.createElement("div", {
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("div", {
117
- key: idx,
118
- style: {
119
- padding: 12,
120
- border: '1px solid rgba(0,0,0,0.1)',
121
- borderRadius: 8,
122
- background: 'rgba(0,0,0,0.02)'
123
- }
124
- }, /*#__PURE__*/_react.default.createElement("div", {
125
- style: {
126
- fontWeight: 700
127
- }
128
- }, r.siu_name), r.sector_code ? /*#__PURE__*/_react.default.createElement("div", {
129
- style: {
130
- marginTop: 2,
131
- opacity: 0.8,
132
- fontSize: 12
133
- }
134
- }, 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", {
135
- style: {
136
- marginTop: 8
137
- }
138
- }, r.expected_pollution_types.join(', ')) : null, r.seasonal_or_location_factors ? /*#__PURE__*/_react.default.createElement("div", {
139
- style: {
140
- marginTop: 8
141
- }
142
- }, r.seasonal_or_location_factors) : null);
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)(null),
35
+ var _useState3 = (0, _react.useState)(false),
33
36
  _useState4 = (0, _slicedToArray2.default)(_useState3, 2),
34
- headerText = _useState4[0],
35
- setHeaderText = _useState4[1];
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
- titleText = _useState6[0],
39
- setTitleText = _useState6[1];
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 dir = _i18next.default.dir();
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, onVisibilityChange]);
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
- var hasContent = apiEndpoint ? titleText && learnMoreText : text || headerText;
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 ? /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("span", {
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)) : headerText || text), /*#__PURE__*/_react.default.createElement("button", {
207
+ }, learnMoreText))), /*#__PURE__*/_react.default.createElement(DismissButton, {
216
208
  onClick: handleDismiss,
217
- style: (0, _objectSpread2.default)((0, _objectSpread2.default)({
218
- position: 'absolute'
219
- }, dir === 'rtl' ? {
220
- left: 10,
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":";;;;;;;;;;;;AAAA,IAAAA,MAAA,GAAAC,uBAAA,CAAAC,OAAA;AACA,IAAAC,WAAA,GAAAC,sBAAA,CAAAF,OAAA;AACA,IAAAG,iBAAA,GAAAD,sBAAA,CAAAF,OAAA;AAGA,IAAAI,QAAA,GAAAF,sBAAA,CAAAF,OAAA;AACA,IAAAK,yBAAA,GAAAL,OAAA;AAIoC,SAAAM,yBAAAC,WAAA,eAAAC,OAAA,kCAAAC,iBAAA,OAAAD,OAAA,QAAAE,gBAAA,OAAAF,OAAA,YAAAF,wBAAA,YAAAA,yBAAAC,WAAA,WAAAA,WAAA,GAAAG,gBAAA,GAAAD,iBAAA,KAAAF,WAAA;AAAA,SAAAR,wBAAAY,GAAA,EAAAJ,WAAA,SAAAA,WAAA,IAAAI,GAAA,IAAAA,GAAA,CAAAC,UAAA,WAAAD,GAAA,QAAAA,GAAA,aAAAE,OAAA,CAAAF,GAAA,yBAAAA,GAAA,4BAAAG,OAAA,EAAAH,GAAA,UAAAI,KAAA,GAAAT,wBAAA,CAAAC,WAAA,OAAAQ,KAAA,IAAAA,KAAA,CAAAC,GAAA,CAAAL,GAAA,YAAAI,KAAA,CAAAE,GAAA,CAAAN,GAAA,SAAAO,MAAA,WAAAC,qBAAA,GAAAC,MAAA,CAAAC,cAAA,IAAAD,MAAA,CAAAE,wBAAA,WAAAC,GAAA,IAAAZ,GAAA,QAAAY,GAAA,kBAAAH,MAAA,CAAAI,SAAA,CAAAC,cAAA,CAAAC,IAAA,CAAAf,GAAA,EAAAY,GAAA,SAAAI,IAAA,GAAAR,qBAAA,GAAAC,MAAA,CAAAE,wBAAA,CAAAX,GAAA,EAAAY,GAAA,cAAAI,IAAA,KAAAA,IAAA,CAAAV,GAAA,IAAAU,IAAA,CAAAC,GAAA,KAAAR,MAAA,CAAAC,cAAA,CAAAH,MAAA,EAAAK,GAAA,EAAAI,IAAA,YAAAT,MAAA,CAAAK,GAAA,IAAAZ,GAAA,CAAAY,GAAA,SAAAL,MAAA,CAAAJ,OAAA,GAAAH,GAAA,MAAAI,KAAA,IAAAA,KAAA,CAAAa,GAAA,CAAAjB,GAAA,EAAAO,MAAA,YAAAA,MAAA;AASpC,IAAMW,YAAyB,GAAG,kBAAkB;AAEpD,IAAMC,SAAmC,GAAG,SAAtCA,SAAmCA,CAAAC,IAAA,EAKnC;EAAA,IAAAC,oBAAA,GAAAD,IAAA,CAJJE,eAAe;IAAfA,eAAe,GAAAD,oBAAA,cAAG,oBAAoB,GAAAA,oBAAA;IAAAE,SAAA,GAAAH,IAAA,CACtCI,IAAI;IAAJA,IAAI,GAAAD,SAAA,cAAG,EAAE,GAAAA,SAAA;IACTE,kBAAkB,GAAAL,IAAA,CAAlBK,kBAAkB;IAClBC,WAAW,GAAAN,IAAA,CAAXM,WAAW;EAEX,IAAAC,SAAA,GAA8B,IAAAC,eAAQ,EAAC,IAAI,CAAC;IAAAC,UAAA,OAAAC,eAAA,CAAA3B,OAAA,EAAAwB,SAAA;IAArCI,OAAO,GAAAF,UAAA;IAAEG,UAAU,GAAAH,UAAA;EAC1B,IAAAI,UAAA,GAAoC,IAAAL,eAAQ,EAAkB,IAAI,CAAC;IAAAM,UAAA,OAAAJ,eAAA,CAAA3B,OAAA,EAAA8B,UAAA;IAA5DE,UAAU,GAAAD,UAAA;IAAEE,aAAa,GAAAF,UAAA;EAChC,IAAAG,UAAA,GAAkC,IAAAT,eAAQ,EAAS,EAAE,CAAC;IAAAU,UAAA,OAAAR,eAAA,CAAA3B,OAAA,EAAAkC,UAAA;IAA/CE,SAAS,GAAAD,UAAA;IAAEE,YAAY,GAAAF,UAAA;EAC9B,IAAAG,UAAA,GAA0C,IAAAb,eAAQ,EAAS,EAAE,CAAC;IAAAc,UAAA,OAAAZ,eAAA,CAAA3B,OAAA,EAAAsC,UAAA;IAAvDE,aAAa,GAAAD,UAAA;IAAEE,gBAAgB,GAAAF,UAAA;EACtC,IAAAG,UAAA,GAAkC,IAAAjB,eAAQ,EAAC,KAAK,CAAC;IAAAkB,WAAA,OAAAhB,eAAA,CAAA3B,OAAA,EAAA0C,UAAA;IAA1CE,SAAS,GAAAD,WAAA;IAAEE,YAAY,GAAAF,WAAA;EAC9B,IAAAG,WAAA,GACE,IAAArB,eAAQ,EAAiC,IAAI,CAAC;IAAAsB,WAAA,OAAApB,eAAA,CAAA3B,OAAA,EAAA8C,WAAA;IADzCE,WAAW,GAAAD,WAAA;IAAEE,cAAc,GAAAF,WAAA;EAGlC,IAAMG,YAAY,GAAG,EAAE,CAAC,CAAC;EACzB,IAAMC,GAAG,GAAGC,gBAAO,CAACD,GAAG,CAAC,CAAC;;EAEzB;EACA,IAAAE,gBAAS,EAAC,YAAM;IACd;IACA,IAAI,CAAAL,WAAW,aAAXA,WAAW,uBAAXA,WAAW,CAAEM,EAAE,MAAKC,SAAS,EAAE;MACjC,IAAI;QACF,IAAMC,MAAM,GAAG,IAAAC,sCAAY,EAAC1C,YAAY,CAAC;QACzC,IAAM2C,SAAS,GAAG,CAAAF,MAAM,aAANA,MAAM,uBAANA,MAAM,CAAEG,eAAe,MAAKC,MAAM,CAACZ,WAAW,CAACM,EAAE,CAAC;QACpEzB,UAAU,CAAC,CAAC6B,SAAS,CAAC;QACtB,IAAIpC,kBAAkB,EAAEA,kBAAkB,CAAC,CAACoC,SAAS,CAAC;MACxD,CAAC,CAAC,OAAAG,OAAA,EAAM;QACNhC,UAAU,CAAC,IAAI,CAAC;QAChB,IAAIP,kBAAkB,EAAEA,kBAAkB,CAAC,IAAI,CAAC;MAClD;IACF,CAAC,MAAM,IAAI0B,WAAW,KAAK,IAAI,EAAE;MAC/B;MACA,IAAIzB,WAAW,EAAE;QACf;QACAM,UAAU,CAAC,KAAK,CAAC;QACjB,IAAIP,kBAAkB,EAAEA,kBAAkB,CAAC,KAAK,CAAC;MACnD,CAAC,MAAM;QACL;QACAO,UAAU,CAAC,CAAC,CAACR,IAAI,CAAC;QAClB,IAAIC,kBAAkB,EAAEA,kBAAkB,CAAC,CAAC,CAACD,IAAI,CAAC;MACpD;IACF;EACF,CAAC,EAAE,CAAC2B,WAAW,aAAXA,WAAW,uBAAXA,WAAW,CAAEM,EAAE,EAAEN,WAAW,EAAEzB,WAAW,EAAEF,IAAI,EAAEC,kBAAkB,CAAC,CAAC;;EAEzE;EACA,IAAA+B,gBAAS,EAAC,YAAM;IACd,IAAI,CAAC9B,WAAW,EAAE;IAElB,IAAMuC,UAAU,GAAG,IAAIC,eAAe,CAAC,CAAC;IAExCC,KAAK,CAACzC,WAAW,EAAE;MAAE0C,MAAM,EAAEH,UAAU,CAACG;IAAO,CAAC,CAAC,CAC9CC,IAAI;MAAA,IAAAC,KAAA,OAAAC,kBAAA,CAAApE,OAAA,gBAAAqE,YAAA,CAAArE,OAAA,CAAAsE,IAAA,CAAC,SAAAC,QAAOC,GAAG;QAAA,OAAAH,YAAA,CAAArE,OAAA,CAAAyE,IAAA,UAAAC,SAAAC,QAAA;UAAA;YAAA,QAAAA,QAAA,CAAAC,IAAA,GAAAD,QAAA,CAAAE,IAAA;cAAA;gBAAA,MACVL,GAAG,CAACM,MAAM,KAAK,GAAG;kBAAAH,QAAA,CAAAE,IAAA;kBAAA;gBAAA;gBAAA,OAAAF,QAAA,CAAAI,MAAA,WAEb;kBAAEC,KAAK,EAAE;gBAAY,CAAC;cAAA;gBAAA,IAE1BR,GAAG,CAACS,EAAE;kBAAAN,QAAA,CAAAE,IAAA;kBAAA;gBAAA;gBAAA,MACH,IAAIK,KAAK,oBAAAC,MAAA,CAAoBX,GAAG,CAACM,MAAM,MAAG,CAAC;cAAA;gBAAAH,QAAA,CAAAE,IAAA;gBAAA,OAErCL,GAAG,CAACY,IAAI,CAAC,CAAC;cAAA;gBAAA,OAAAT,QAAA,CAAAI,MAAA,WAAAJ,QAAA,CAAAU,IAAA;cAAA;cAAA;gBAAA,OAAAV,QAAA,CAAAW,IAAA;YAAA;UAAA;QAAA,GAAAf,OAAA;MAAA,CACzB;MAAA,iBAAAgB,EAAA;QAAA,OAAApB,KAAA,CAAAqB,KAAA,OAAAC,SAAA;MAAA;IAAA,IAAC,CACDvB,IAAI,CAAC,UAACwB,IAAI,EAAK;MACd;MACA,IAAI,CAACA,IAAI,aAAJA,IAAI,uBAAJA,IAAI,CAAUV,KAAK,MAAK,WAAW,EAAE;QACxC/B,cAAc,CAAC,IAAI,CAAC;QACpBhB,aAAa,CAAC,IAAI,CAAC;QACnBI,YAAY,CAAC,EAAE,CAAC;QAChBI,gBAAgB,CAAC,EAAE,CAAC;QACpBZ,UAAU,CAAC,KAAK,CAAC;QACjB;MACF;MACAoB,cAAc,CAACyC,IAAI,CAAC;MAEpBrD,YAAY,CAACuB,MAAM,CAACR,gBAAO,CAACuC,CAAC,CAAC,yBAAyB,CAAC,CAAC,CAAC;MAC1DlD,gBAAgB,CAACmB,MAAM,CAACR,gBAAO,CAACuC,CAAC,CAAC,8BAA8B,CAAC,CAAC,CAAC;IACrE,CAAC,CAAC,CACDC,KAAK,CAAC,UAACC,GAAG,EAAK;MACd;MACA,IAAI,CAAAA,GAAG,aAAHA,GAAG,uBAAHA,GAAG,CAAEC,IAAI,MAAK,YAAY,EAAE;QAC9B7C,cAAc,CAAC,IAAI,CAAC;QACpBhB,aAAa,CAAC,IAAI,CAAC;QACnBI,YAAY,CAAC,EAAE,CAAC;QAChBI,gBAAgB,CAAC,EAAE,CAAC;QACpBZ,UAAU,CAAC,KAAK,CAAC;MACnB;IACF,CAAC,CAAC;IAEJ,OAAO;MAAA,OAAMiC,UAAU,CAACiC,KAAK,CAAC,CAAC;IAAA;EACjC,CAAC,EAAE,CAACxE,WAAW,EAAEF,IAAI,CAAC,CAAC;;EAEvB;EACA,IAAAgC,gBAAS,EAAC,YAAM;IACd,IAAI/B,kBAAkB,EAAEA,kBAAkB,CAACM,OAAO,CAAC;EACrD,CAAC,EAAE,CAACA,OAAO,CAAC,CAAC;;EAEb;EACA,IAAMoE,aAAa,GAAG,SAAhBA,aAAaA,CAAA,EAAS;IAC1BnE,UAAU,CAAC,KAAK,CAAC;IACjB,IAAI,CAAAmB,WAAW,aAAXA,WAAW,uBAAXA,WAAW,CAAEM,EAAE,MAAKC,SAAS,EAAE;IAEnC,IAAI;MACF,IAAA0C,sCAAY,EAAClF,YAAY,EAAE6C,MAAM,CAACZ,WAAW,CAACM,EAAE,CAAC,CAAC;IACpD,CAAC,CAAC,OAAA4C,QAAA,EAAM;MACN;IAAA;EAEJ,CAAC;EAED,IAAMC,SAAS,GAAG,SAAZA,SAASA,CAAA,EAAS;IACtBtD,YAAY,CAAC,IAAI,CAAC;EACpB,CAAC;EAED,IAAMuD,UAAU,GAAG,SAAbA,UAAUA,CAAA,EAAS;IACvBvD,YAAY,CAAC,KAAK,CAAC;EACrB,CAAC;EAED,IAAMwD,KAAK,GAAG,IAAAC,cAAO,EAAC,YAAM;IAC1B,IAAI,CAAC1D,SAAS,EAAE,OAAO,IAAI;IAC3B,IAAMO,GAAG,GAAGC,gBAAO,CAACD,GAAG,CAAC,CAAC;IACzB,oBACEnE,MAAA,CAAAgB,OAAA,CAAAuG,aAAA,CAACpH,WAAA,CAAAa,OAAU;MAACwG,MAAM,EAAE5D,SAAU;MAAC6D,OAAO,EAAEL,UAAW;MAACjD,GAAG,EAAEA;IAAI,gBAC3DnE,MAAA,CAAAgB,OAAA,CAAAuG,aAAA,CAAClH,iBAAA,CAAAW,OAAgB;MAAC0F,IAAI,EAAE1C;IAAY,CAAE,CAC5B,CAAC;EAEjB,CAAC,EAAE,CAACJ,SAAS,CAAC,CAAC;EAEf,IAAM8D,UAAU,GAAGnF,WAAW,GAC1Ba,SAAS,IAAII,aAAa,GAC1BnB,IAAI,IAAIW,UAAU;EACtB,IAAI,CAACJ,OAAO,IAAI,CAAC8E,UAAU,EAAE;IAC3B,OAAO,IAAI;EACb;EAEA,oBACE1H,MAAA,CAAAgB,OAAA,CAAAuG,aAAA,CAAAvH,MAAA,CAAAgB,OAAA,CAAA2G,QAAA,qBACE3H,MAAA,CAAAgB,OAAA,CAAAuG,aAAA;IACEK,KAAK,EAAE;MACLC,KAAK,EAAE,MAAM;MACbC,UAAU,EAAE3F,eAAe;MAC3B4F,OAAO,EAAE,KAAK;MACdC,SAAS,EAAE,QAAQ;MACnBC,QAAQ,EAAE,UAAU;MACpBC,SAAS,EAAE,YAAY;MACvBC,SAAS,KAAAhC,MAAA,CAAKjC,YAAY,OAAI;MAC9BkE,MAAM,KAAAjC,MAAA,CAAKjC,YAAY,OAAI;MAC3BmE,OAAO,EAAE,MAAM;MACfC,UAAU,EAAE,QAAQ;MACpBC,cAAc,EAAE,QAAQ;MACxBC,QAAQ,EAAE,MAAM;MAChBC,MAAM,EAAE;IACV;EAAE,gBAEFzI,MAAA,CAAAgB,OAAA,CAAAuG,aAAA,eACGhF,WAAW,gBACVvC,MAAA,CAAAgB,OAAA,CAAAuG,aAAA,CAAAvH,MAAA,CAAAgB,OAAA,CAAA2G,QAAA,qBACE3H,MAAA,CAAAgB,OAAA,CAAAuG,aAAA;IACEK,KAAK,EAAE;MACLc,MAAM,EAAE,yCAAyC;MACjDF,QAAQ,EAAE,MAAM;MAChBH,OAAO,EAAE,cAAc;MACvBM,WAAW,EAAE;IACf;EAAE,GACH,QAEK,CAAC,EACNvF,SAAS,EAAE,GAAG,eACfpD,MAAA,CAAAgB,OAAA,CAAAuG,aAAA;IACEqB,OAAO,EAAEzB,SAAU;IACnBS,KAAK,EAAE;MACLiB,cAAc,EAAE,WAAW;MAC3BJ,MAAM,EAAE;IACV;EAAE,GAEDjF,aACG,CACN,CAAC,GAEHR,UAAU,IAAIX,IAEZ,CAAC,eACPrC,MAAA,CAAAgB,OAAA,CAAAuG,aAAA;IACEqB,OAAO,EAAE5B,aAAc;IACvBY,KAAK,MAAAkB,cAAA,CAAA9H,OAAA,MAAA8H,cAAA,CAAA9H,OAAA;MACHiH,QAAQ,EAAE;IAAU,GAChB9D,GAAG,KAAK,KAAK,GACb;MAAE4E,IAAI,EAAE,EAAE;MAAEC,KAAK,EAAE;IAAgB,CAAC,GACpC;MAAEA,KAAK,EAAE;IAAG,CAAC;MACjBlB,UAAU,EAAE,aAAa;MACzBmB,MAAM,EAAE,MAAM;MACdT,QAAQ,EAAE,MAAM;MAChBC,MAAM,EAAE;IAAS,EACjB;IACF,cAAW;EAAgB,GAC5B,MAEO,CACL,CAAC,EACLpB,KACD,CAAC;AAEP,CAAC;AAAC,IAAA6B,QAAA,GAEalH,SAAS;AAAAmH,OAAA,CAAAnI,OAAA,GAAAkI,QAAA"}
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 più"
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
  }
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
 
3
- var packageJsonVersion = "1.2.466-alpha.10";
3
+ var packageJsonVersion = "1.2.466-alpha.12";
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));
@@ -34,7 +34,7 @@
34
34
  .sidenav {
35
35
  z-index: 999;
36
36
  position: fixed;
37
- top: 4em;
37
+ // top: 4em;
38
38
  width: 480px;
39
39
  height: 100%;
40
40
  box-shadow: 0px 10px 10px rgba(0, 0, 0, 0.1);
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@kando-env/kando-ui",
3
- "version": "1.2.466-alpha.10",
3
+ "version": "1.2.466-alpha.12",
4
4
  "main": "lib/index.js",
5
5
  "author": "Nadav(Private) <nadavk72@gmail.com>",
6
6
  "scripts": {