@kando-env/kando-ui 1.2.466-alpha.9 → 1.2.467-alpha.1

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":";;;;;;;;;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;AAAuB,SAAAK,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,SAAAP,wBAAAW,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;AAiBvB;AACA;AACA;AACA,IAAMW,UAAiC,GAAG,SAApCA,UAAiCA,CAAAC,IAAA,EAWjC;EAAA,IAAAC,qBAAA;EAAA,IAAAC,WAAA,GAAAF,IAAA,CAVJG,MAAM;IAANA,MAAM,GAAAD,WAAA,cAAG,KAAK,GAAAA,WAAA;IACdE,WAAW,GAAAJ,IAAA,CAAXI,WAAW;IAAAC,kBAAA,GAAAL,IAAA,CACXM,aAAa;IAAbA,aAAa,GAAAD,kBAAA,cAAG,CAAC,CAAC,GAAAA,kBAAA;IAClBE,QAAQ,GAAAP,IAAA,CAARO,QAAQ;IACRC,IAAI,GAAAR,IAAA,CAAJQ,IAAI;IACJC,WAAW,GAAAT,IAAA,CAAXS,WAAW;IACXC,iBAAiB,GAAAV,IAAA,CAAjBU,iBAAiB;IACjBC,OAAO,GAAAX,IAAA,CAAPW,OAAO;IAAAC,eAAA,GAAAZ,IAAA,CACPa,UAAU;IAAVA,UAAU,GAAAD,eAAA,cAAG,KAAK,GAAAA,eAAA;IAClBE,GAAG,GAAAd,IAAA,CAAHc,GAAG;EAEH,IAAMC,YAAY,GAAGC,cAAK,CAACC,MAAM,CAAC,IAAI,CAAC;EACvC,IAAAC,SAAA,GAAwB,IAAAC,eAAQ,EAAChB,MAAM,CAAC;IAAAiB,UAAA,OAAAC,eAAA,CAAArC,OAAA,EAAAkC,SAAA;IAAjCI,IAAI,GAAAF,UAAA;IAAEG,OAAO,GAAAH,UAAA;EACpB,IAAAI,gBAAS,EAAC,YAAM;IACdD,OAAO,CAACpB,MAAM,CAAC;EACjB,CAAC,EAAE,CAACA,MAAM,CAAC,CAAC;EACZ,IAAMsB,WAAW,GAAG,SAAdA,WAAWA,CAAA;IAAA,OAASF,OAAO,CAAC,IAAI,CAAC;EAAA;EACvC,IAAMG,YAAY,GAAG,SAAfA,YAAYA,CAAA,EAAS;IACzBH,OAAO,CAAC,KAAK,CAAC;IACdI,YAAY,CAAC,CAAC;IACd,IAAIhB,OAAO,EAAEA,OAAO,CAAC,CAAC;EACxB,CAAC;EACD,IAAMiB,QAAQ,GAAG,IAAAC,oBAAW,EAAC,CAAC;EAC9B,IAAMC,WAAW,GAAG,SAAdA,WAAWA,CAAA,EAAS;IACxB,IAAIpB,iBAAiB,KAAKqB,SAAS,EAAE;MACnCrB,iBAAiB,CAAE,CAAC;IACtB;IACAe,WAAW,CAAC,CAAC;EACf,CAAC;;EAED;EACA,SAASO,aAAaA,CAAA,EAAG;IACvB,IAAI,CAAC,IAAAC,eAAO,EAAC3B,aAAa,CAAC,EAAE;MAC3B,SAAA4B,EAAA,MAAAC,eAAA,GAA6B7C,MAAM,CAAC8C,OAAO,CAAC9B,aAAa,CAAC,EAAA4B,EAAA,GAAAC,eAAA,CAAAE,MAAA,EAAAH,EAAA,IAAE;QAAvD,IAAAI,kBAAA,OAAAjB,eAAA,CAAArC,OAAA,EAAAmD,eAAA,CAAAD,EAAA;UAAOK,KAAK,GAAAD,kBAAA;UAAEE,KAAK,GAAAF,kBAAA;QACtBV,QAAQ,CAAC9B,GAAG,CAACyC,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,CAAIhB,QAAQ,CACzC,CAAC;MACH;IACF;EACF;;EAEA;EACA,SAASD,YAAYA,CAAA,EAAG;IACtB,IAAI,CAAC,IAAAM,eAAO,EAAC3B,aAAa,CAAC,EAAE;MAC3B,SAAAyC,GAAA,MAAAC,gBAAA,GAAsB1D,MAAM,CAAC8C,OAAO,CAAC9B,aAAa,CAAC,EAAAyC,GAAA,GAAAC,gBAAA,CAAAX,MAAA,EAAAU,GAAA,IAAE;QAAhD,IAAAE,mBAAA,OAAA5B,eAAA,CAAArC,OAAA,EAAAgE,gBAAA,CAAAD,GAAA;UAAOR,KAAK,GAAAU,mBAAA;QACfrB,QAAQ,CAACsB,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,CAAIhB,QAAQ,CACzC,CAAC;MACH;IACF;EACF;EAEA,IAAAJ,gBAAS,EAAC,YAAM;IACd,IAAIF,IAAI,EAAE;MACRU,aAAa,CAAC,CAAC;IACjB;EACF,CAAC,EAAE,CAACV,IAAI,CAAC,CAAC;EAEV,IAAM6B,WAA0B,GAC9BrC,GAAG,KACF,OAAOsC,QAAQ,KAAK,WAAW,IAAI,EAAAnD,qBAAA,GAAAmD,QAAQ,CAACC,eAAe,cAAApD,qBAAA,uBAAxBA,qBAAA,CAA0Ba,GAAG,MAAK,KAAK,GACvE,KAAK,GACL,KAAK,CAAC;EAEZ,IAAMwC,KAAK,GAAGH,WAAW,KAAK,KAAK;EAEnC,IAAMI,WAAW,GAAGD,KAAK,GACrB;IACEE,WAAW,EAAE;MACXC,IAAI,EAAE,MAAM;MACZC,KAAK,EAAE;IACT;EACF,CAAC,GACD3B,SAAS;EAEb,oBACE9D,MAAA,CAAAe,OAAA,CAAA2E,aAAA,CAAA1F,MAAA,CAAAe,OAAA,CAAA4E,QAAA,QACG,CAAC/C,UAAU,iBACV5C,MAAA,CAAAe,OAAA,CAAA2E,aAAA;IACEE,SAAS,oCAAAjB,MAAA,CAAoCnC,WAAW,CAAG;IAC3DqD,OAAO,EAAE,SAAAA,QAAA;MAAA,OAAMhC,WAAW,CAAC,CAAC;IAAA;EAAC,GAE5B1B,WACE,CACN,eACDnC,MAAA,CAAAe,OAAA,CAAA2E,aAAA,CAACtF,qBAAA,CAAA0F,KAAK;IACJC,SAAS,EAAEjD,YAAY,CAACkD,OAAQ;IAChCC,MAAM;IACN5C,IAAI,EAAEA,IAAK;IACXX,OAAO,EAAEe,YAAa;IACtByC,MAAM,EAAEZ,WAAY;IACpBa,UAAU,EAAE;MACVC,OAAO,EAAE,iBAAiB;MAC1BC,KAAK,yBAAA1B,MAAA,CAAyBpC,IAAI;IACpC;EAAE,gBAEFvC,MAAA,CAAAe,OAAA,CAAA2E,aAAA;IAAK7C,GAAG,EAAEqC;EAAY,GAAE5C,QAAc,CACjC,CACP,CAAC;AAEP,CAAC;AAAC,IAAAgE,QAAA,GAEaxE,UAAU;AAAAyE,OAAA,CAAAxF,OAAA,GAAAuF,QAAA"}
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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"}
@@ -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,13 @@ 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");
17
+ var _streamiLogo = _interopRequireDefault(require("assets/streami-logo.svg"));
18
+ var _useNavContext2 = require("hooks/useNavContext");
14
19
  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
20
  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
21
  var SeasonalInsights = function SeasonalInsights(_ref) {
@@ -22,6 +27,10 @@ var SeasonalInsights = function SeasonalInsights(_ref) {
22
27
  _useState2 = (0, _slicedToArray2.default)(_useState, 2),
23
28
  data = _useState2[0],
24
29
  setData = _useState2[1];
30
+ var _useState3 = (0, _react.useState)(false),
31
+ _useState4 = (0, _slicedToArray2.default)(_useState3, 2),
32
+ showDetails = _useState4[0],
33
+ setShowDetails = _useState4[1];
25
34
 
26
35
  // If parent provides data, render it and skip fetching.
27
36
  (0, _react.useEffect)(function () {
@@ -37,10 +46,9 @@ var SeasonalInsights = function SeasonalInsights(_ref) {
37
46
  }, [data]);
38
47
  var summary = (risk === null || risk === void 0 ? void 0 : risk.risk_summary) || '';
39
48
  var detailed = (risk === null || risk === void 0 ? void 0 : risk.detailed_risks) || [];
40
- var isHebrew = (0, _react.useMemo)(function () {
41
- var lang = ((data === null || data === void 0 ? void 0 : data.locale) || _i18next.default.language || 'en').toLowerCase();
42
- return lang.startsWith('he');
43
- }, [data === null || data === void 0 ? void 0 : data.locale]);
49
+ var hasDetails = detailed.length > 0;
50
+ var _useNavContext = (0, _useNavContext2.useNavContext)(),
51
+ isRtl = _useNavContext.isRtl;
44
52
  (0, _react.useEffect)(function () {
45
53
  // If parent provides data, do not fetch.
46
54
  if (typeof dataProp !== 'undefined') return;
@@ -85,63 +93,128 @@ var SeasonalInsights = function SeasonalInsights(_ref) {
85
93
  return controller.abort();
86
94
  };
87
95
  }, [apiEndpoint, dataProp, onLoaded]);
88
- return /*#__PURE__*/_react.default.createElement("div", {
89
- className: className,
90
- 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) {
96
+ return /*#__PURE__*/_react.default.createElement(Container, {
97
+ isRtl: isRtl
98
+ }, /*#__PURE__*/_react.default.createElement(SummarySection, null, /*#__PURE__*/_react.default.createElement(SummaryHeader, {
99
+ isRtl: isRtl
100
+ }, /*#__PURE__*/_react.default.createElement(SummaryTitle, null, _i18next.default.t('seasonal_insights.summary_heading'))), /*#__PURE__*/_react.default.createElement(SummaryText, null, summary)), /*#__PURE__*/_react.default.createElement(ToggleRow, null, /*#__PURE__*/_react.default.createElement(Attribution, null, /*#__PURE__*/_react.default.createElement(BrandLogoSmall, {
101
+ src: _streamiLogo.default,
102
+ alt: "Streami"
103
+ }), /*#__PURE__*/_react.default.createElement(PoweredBy, null, 'Powered by STREAMi')), hasDetails ? /*#__PURE__*/_react.default.createElement(MoreInfoWrap, null, /*#__PURE__*/_react.default.createElement(_MoreInfoButton.MoreInfoDiv, null, /*#__PURE__*/_react.default.createElement("a", {
104
+ href: "#",
105
+ className: "more-info-button",
106
+ onClick: function onClick(e) {
107
+ e.preventDefault();
108
+ setShowDetails(function (prev) {
109
+ return !prev;
110
+ });
111
+ },
112
+ "aria-expanded": showDetails
113
+ }, showDetails ? _i18next.default.t('seasonal_insights.show_less') : _i18next.default.t('seasonal_insights.show_more')))) : null), hasDetails ? /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, showDetails ? /*#__PURE__*/_react.default.createElement(CardList, null, detailed.map(function (r, idx) {
115
114
  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
- })));
115
+ return /*#__PURE__*/_react.default.createElement(Card, {
116
+ key: idx
117
+ }, /*#__PURE__*/_react.default.createElement(CardHeader, null, /*#__PURE__*/_react.default.createElement(TitleBlock, null, formatSectorIconName(r.sector) ? /*#__PURE__*/_react.default.createElement(_Sector.default, {
118
+ sectorIconName: formatSectorIconName(r.sector) || 'Missing',
119
+ sectorName: r.sector,
120
+ showLabel: false,
121
+ withTooltip: true
122
+ }) : 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) {
123
+ return /*#__PURE__*/_react.default.createElement(Chip, {
124
+ key: "".concat(p, "-").concat(chipIdx)
125
+ }, p);
126
+ }))) : 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);
127
+ })) : null) : null);
128
+ };
129
+ var Container = _styledComponents.default.div.withConfig({
130
+ displayName: "SeasonalInsights__Container",
131
+ componentId: "sc-jrd7ho-0"
132
+ })(["padding:16px;margin:16px;display:flex;flex-direction:column;gap:12px;text-align:", ";min-width:320px;border-radius:12px;"], function (_ref3) {
133
+ var isRtl = _ref3.isRtl;
134
+ return isRtl ? 'right' : 'left';
135
+ });
136
+ var SummarySection = _styledComponents.default.div.withConfig({
137
+ displayName: "SeasonalInsights__SummarySection",
138
+ componentId: "sc-jrd7ho-1"
139
+ })(["display:flex;flex-direction:column;gap:8px;padding:12px 14px;border-radius:10px;"]);
140
+ var SummaryHeader = _styledComponents.default.div.withConfig({
141
+ displayName: "SeasonalInsights__SummaryHeader",
142
+ componentId: "sc-jrd7ho-2"
143
+ })(["display:flex;align-items:center;justify-content:space-between;gap:12px;flex-direction:", ";"], function (_ref4) {
144
+ var isRtl = _ref4.isRtl;
145
+ return isRtl ? 'row-reverse' : 'row';
146
+ });
147
+ var SummaryTitle = _styledComponents.default.div.withConfig({
148
+ displayName: "SeasonalInsights__SummaryTitle",
149
+ componentId: "sc-jrd7ho-3"
150
+ })(["font-weight:600;font-size:16px;color:#1d1d1d;"]);
151
+ var SummaryText = _styledComponents.default.div.withConfig({
152
+ displayName: "SeasonalInsights__SummaryText",
153
+ componentId: "sc-jrd7ho-4"
154
+ })(["font-size:15px;color:#2b2b2b;line-height:1.5;"]);
155
+ var ToggleRow = _styledComponents.default.div.withConfig({
156
+ displayName: "SeasonalInsights__ToggleRow",
157
+ componentId: "sc-jrd7ho-5"
158
+ })(["display:flex;justify-content:space-between;align-items:center;margin-top:6px;gap:10px;flex-direction:row;.more-info-button:focus,.more-info-button:focus-visible{outline:none;box-shadow:none;}"]);
159
+ var PoweredBy = _styledComponents.default.span.withConfig({
160
+ displayName: "SeasonalInsights__PoweredBy",
161
+ componentId: "sc-jrd7ho-6"
162
+ })(["font-size:12px;color:#6b7280;white-space:nowrap;"]);
163
+ var Attribution = _styledComponents.default.div.withConfig({
164
+ displayName: "SeasonalInsights__Attribution",
165
+ componentId: "sc-jrd7ho-7"
166
+ })(["display:inline-flex;align-items:center;gap:6px;order:1;"]);
167
+ var BrandLogoSmall = _styledComponents.default.img.withConfig({
168
+ displayName: "SeasonalInsights__BrandLogoSmall",
169
+ componentId: "sc-jrd7ho-8"
170
+ })(["height:16px;width:auto;opacity:0.7;flex-shrink:0;"]);
171
+ var MoreInfoWrap = _styledComponents.default.div.withConfig({
172
+ displayName: "SeasonalInsights__MoreInfoWrap",
173
+ componentId: "sc-jrd7ho-9"
174
+ })(["order:2;"]);
175
+ var CardList = _styledComponents.default.div.withConfig({
176
+ displayName: "SeasonalInsights__CardList",
177
+ componentId: "sc-jrd7ho-10"
178
+ })(["display:flex;flex-direction:column;gap:12px;"]);
179
+ var Card = _styledComponents.default.div.withConfig({
180
+ displayName: "SeasonalInsights__Card",
181
+ componentId: "sc-jrd7ho-11"
182
+ })(["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;"]);
183
+ var CardHeader = _styledComponents.default.div.withConfig({
184
+ displayName: "SeasonalInsights__CardHeader",
185
+ componentId: "sc-jrd7ho-12"
186
+ })(["display:flex;align-items:center;gap:8px;justify-content:space-between;"]);
187
+ var TitleBlock = _styledComponents.default.div.withConfig({
188
+ displayName: "SeasonalInsights__TitleBlock",
189
+ componentId: "sc-jrd7ho-13"
190
+ })(["display:inline-flex;align-items:center;margin-inline-start:-14px;"]);
191
+ var CardTitle = _styledComponents.default.div.withConfig({
192
+ displayName: "SeasonalInsights__CardTitle",
193
+ componentId: "sc-jrd7ho-14"
194
+ })(["font-weight:600;font-size:15px;color:#1e1e1e;"]);
195
+ var CardSection = _styledComponents.default.div.withConfig({
196
+ displayName: "SeasonalInsights__CardSection",
197
+ componentId: "sc-jrd7ho-15"
198
+ })(["display:flex;flex-direction:column;gap:6px;"]);
199
+ var SectionLabel = _styledComponents.default.div.withConfig({
200
+ displayName: "SeasonalInsights__SectionLabel",
201
+ componentId: "sc-jrd7ho-16"
202
+ })(["font-weight:600;font-size:13px;color:#2f333a;"]);
203
+ var SectionText = _styledComponents.default.div.withConfig({
204
+ displayName: "SeasonalInsights__SectionText",
205
+ componentId: "sc-jrd7ho-17"
206
+ })(["font-size:14px;color:#3d3d3d;line-height:1.45;"]);
207
+ var ChipRow = _styledComponents.default.div.withConfig({
208
+ displayName: "SeasonalInsights__ChipRow",
209
+ componentId: "sc-jrd7ho-18"
210
+ })(["display:flex;gap:8px;flex-wrap:wrap;"]);
211
+ var Chip = _styledComponents.default.span.withConfig({
212
+ displayName: "SeasonalInsights__Chip",
213
+ componentId: "sc-jrd7ho-19"
214
+ })(["background:#f1f3f5;color:#1f2933;border-radius:12px;padding:6px 10px;font-size:12px;font-weight:500;border:1px solid #e0e4ea;"]);
215
+ var formatSectorIconName = function formatSectorIconName(value) {
216
+ return (value || '').toString().trim().toLowerCase().replace(/[^a-z0-9]+/g, '_').replace(/^_+|_+$/g, '');
144
217
  };
145
218
  var _default = SeasonalInsights;
146
219
  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":";;;;;;;;;;;AAAA,IAAAA,QAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,MAAA,GAAAC,uBAAA,CAAAF,OAAA;AAA4D,SAAAG,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,SAAAF,wBAAAM,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;AA0C5D,IAAMW,gBAAiD,GAAG,SAApDA,gBAAiDA,CAAAC,IAAA,EAKjD;EAAA,IAJJC,WAAW,GAAAD,IAAA,CAAXC,WAAW;IACLC,QAAQ,GAAAF,IAAA,CAAdG,IAAI;IACJC,SAAS,GAAAJ,IAAA,CAATI,SAAS;IACTC,QAAQ,GAAAL,IAAA,CAARK,QAAQ;EAER,IAAAC,SAAA,GAAwB,IAAAC,eAAQ,EAC9BL,QAAQ,aAARA,QAAQ,cAARA,QAAQ,GAAI,IACd,CAAC;IAAAM,UAAA,OAAAC,eAAA,CAAAzB,OAAA,EAAAsB,SAAA;IAFMH,IAAI,GAAAK,UAAA;IAAEE,OAAO,GAAAF,UAAA;;EAIpB;EACA,IAAAG,gBAAS,EAAC,YAAM;IACd,IAAI,OAAOT,QAAQ,KAAK,WAAW,EAAE;IACrCQ,OAAO,CAACR,QAAQ,aAARA,QAAQ,cAARA,QAAQ,GAAI,IAAI,CAAC;EAC3B,CAAC,EAAE,CAACA,QAAQ,CAAC,CAAC;EAEd,IAAMU,IAAI,GAAG,IAAAC,cAAO,EAAC,YAAM;IAAA,IAAAC,kBAAA;IACzB,IAAMC,KAAK,GAAGZ,IAAI,aAAJA,IAAI,wBAAAW,kBAAA,GAAJX,IAAI,CAAEa,YAAY,cAAAF,kBAAA,uBAAlBA,kBAAA,CAAoBC,KAAK;IACvC,IAAI,CAACA,KAAK,EAAE,OAAO,IAAI;IACvB,IAAME,IAAI,GAAG,CAAAd,IAAI,aAAJA,IAAI,uBAAJA,IAAI,CAAEe,MAAM,KAAI,IAAI;IACjC,OAAOH,KAAK,CAACE,IAAI,CAAC,IAAI,IAAI;EAC5B,CAAC,EAAE,CAACd,IAAI,CAAC,CAAC;EAEV,IAAMgB,OAAO,GAAG,CAAAP,IAAI,aAAJA,IAAI,uBAAJA,IAAI,CAAEQ,YAAY,KAAI,EAAE;EACxC,IAAMC,QAAQ,GAAG,CAAAT,IAAI,aAAJA,IAAI,uBAAJA,IAAI,CAAEU,cAAc,KAAI,EAAE;EAE3C,IAAMC,QAAQ,GAAG,IAAAV,cAAO,EAAC,YAAM;IAC7B,IAAMI,IAAI,GAAG,CAAC,CAAAd,IAAI,aAAJA,IAAI,uBAAJA,IAAI,CAAEe,MAAM,KAAIM,gBAAO,CAACC,QAAQ,IAAI,IAAI,EAAEC,WAAW,CAAC,CAAC;IACrE,OAAOT,IAAI,CAACU,UAAU,CAAC,IAAI,CAAC;EAC9B,CAAC,EAAE,CAACxB,IAAI,aAAJA,IAAI,uBAAJA,IAAI,CAAEe,MAAM,CAAC,CAAC;EAElB,IAAAP,gBAAS,EAAC,YAAM;IACd;IACA,IAAI,OAAOT,QAAQ,KAAK,WAAW,EAAE;IACrC,IAAI,CAACD,WAAW,EAAE;IAElB,IAAM2B,UAAU,GAAG,IAAIC,eAAe,CAAC,CAAC;IAExCC,KAAK,CAAC7B,WAAW,EAAE;MAAE8B,MAAM,EAAEH,UAAU,CAACG;IAAO,CAAC,CAAC,CAC9CC,IAAI;MAAA,IAAAC,KAAA,OAAAC,kBAAA,CAAAlD,OAAA,gBAAAmD,YAAA,CAAAnD,OAAA,CAAAoD,IAAA,CAAC,SAAAC,QAAOC,GAAG;QAAA,OAAAH,YAAA,CAAAnD,OAAA,CAAAuD,IAAA,UAAAC,SAAAC,QAAA;UAAA;YAAA,QAAAA,QAAA,CAAAC,IAAA,GAAAD,QAAA,CAAAE,IAAA;cAAA;gBAAA,IACTL,GAAG,CAACM,EAAE;kBAAAH,QAAA,CAAAE,IAAA;kBAAA;gBAAA;gBAAA,MACH,IAAIE,KAAK,oBAAAC,MAAA,CAAoBR,GAAG,CAACS,MAAM,MAAG,CAAC;cAAA;gBAAAN,QAAA,CAAAE,IAAA;gBAAA,OAErCL,GAAG,CAACU,IAAI,CAAC,CAAC;cAAA;gBAAA,OAAAP,QAAA,CAAAQ,MAAA,WAAAR,QAAA,CAAAS,IAAA;cAAA;cAAA;gBAAA,OAAAT,QAAA,CAAAU,IAAA;YAAA;UAAA;QAAA,GAAAd,OAAA;MAAA,CACzB;MAAA,iBAAAe,EAAA;QAAA,OAAAnB,KAAA,CAAAoB,KAAA,OAAAC,SAAA;MAAA;IAAA,IAAC,CACDtB,IAAI,CAAC,UAACuB,OAAO,EAAK;MACjB7C,OAAO,CAAC6C,OAAO,CAAC;MAChB,IAAIlD,QAAQ,EAAEA,QAAQ,CAACkD,OAAO,CAAC;IACjC,CAAC,CAAC,CACDC,KAAK,CAAC,UAACC,GAAG,EAAK;MACd,IAAI,CAAAA,GAAG,aAAHA,GAAG,uBAAHA,GAAG,CAAEC,IAAI,MAAK,YAAY,EAAE;MAChChD,OAAO,CAAC,IAAI,CAAC;IACf,CAAC,CAAC;IAEJ,OAAO;MAAA,OAAMkB,UAAU,CAAC+B,KAAK,CAAC,CAAC;IAAA;EACjC,CAAC,EAAE,CAAC1D,WAAW,EAAEC,QAAQ,EAAEG,QAAQ,CAAC,CAAC;EAErC,oBACE/B,MAAA,CAAAU,OAAA,CAAA4E,aAAA;IACExD,SAAS,EAAEA,SAAU;IACrByD,GAAG,EAAEtC,QAAQ,GAAG,KAAK,GAAG,KAAM;IAC9BuC,KAAK,EAAE;MACLC,OAAO,EAAE,EAAE;MACXC,OAAO,EAAE,MAAM;MACfC,aAAa,EAAE,QAAQ;MACvBC,GAAG,EAAE,EAAE;MACPC,SAAS,EAAE5C,QAAQ,GAAG,OAAO,GAAG;IAClC;EAAE,gBAEFjD,MAAA,CAAAU,OAAA,CAAA4E,aAAA;IAAKE,KAAK,EAAE;MAAEE,OAAO,EAAE,MAAM;MAAEC,aAAa,EAAE,QAAQ;MAAEC,GAAG,EAAE;IAAE;EAAE,gBAC/D5F,MAAA,CAAAU,OAAA,CAAA4E,aAAA;IAAKE,KAAK,EAAE;MAAEM,UAAU,EAAE;IAAI;EAAE,GAAEjD,OAAa,CAC5C,CAAC,eAEN7C,MAAA,CAAAU,OAAA,CAAA4E,aAAA;IAAKE,KAAK,EAAE;MAAEE,OAAO,EAAE,MAAM;MAAEC,aAAa,EAAE,QAAQ;MAAEC,GAAG,EAAE;IAAG;EAAE,GAC/D7C,QAAQ,CAACgD,GAAG,CAAC,UAACC,CAAC,EAAEC,GAAG;IAAA,IAAAC,qBAAA;IAAA,oBACnBlG,MAAA,CAAAU,OAAA,CAAA4E,aAAA;MACEnE,GAAG,EAAE8E,GAAI;MACTT,KAAK,EAAE;QACLC,OAAO,EAAE,EAAE;QACXU,MAAM,EAAE,2BAA2B;QACnCC,YAAY,EAAE,CAAC;QACfC,UAAU,EAAE;MACd;IAAE,gBAEFrG,MAAA,CAAAU,OAAA,CAAA4E,aAAA;MAAKE,KAAK,EAAE;QAAEM,UAAU,EAAE;MAAI;IAAE,GAAEE,CAAC,CAACM,QAAc,CAAC,EAElDN,CAAC,CAACO,WAAW,gBACZvG,MAAA,CAAAU,OAAA,CAAA4E,aAAA;MAAKE,KAAK,EAAE;QAAEgB,SAAS,EAAE,CAAC;QAAEC,OAAO,EAAE,GAAG;QAAEC,QAAQ,EAAE;MAAG;IAAE,GACtDV,CAAC,CAACW,MACA,CAAC,GACJ,IAAI,EAEP,EAAAT,qBAAA,GAAAF,CAAC,CAACY,wBAAwB,cAAAV,qBAAA,uBAA1BA,qBAAA,CAA4BW,MAAM,iBACjC7G,MAAA,CAAAU,OAAA,CAAA4E,aAAA;MAAKE,KAAK,EAAE;QAAEgB,SAAS,EAAE;MAAE;IAAE,GAC1BR,CAAC,CAACY,wBAAwB,CAACE,IAAI,CAAC,IAAI,CAClC,CAAC,GACJ,IAAI,EAEPd,CAAC,CAACe,4BAA4B,gBAC7B/G,MAAA,CAAAU,OAAA,CAAA4E,aAAA;MAAKE,KAAK,EAAE;QAAEgB,SAAS,EAAE;MAAE;IAAE,GAC1BR,CAAC,CAACe,4BACA,CAAC,GACJ,IACD,CAAC;EAAA,CACP,CACE,CACF,CAAC;AAEV,CAAC;AAAC,IAAAC,QAAA,GAEavF,gBAAgB;AAAAwF,OAAA,CAAAvG,OAAA,GAAAsG,QAAA"}
220
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_i18next","_interopRequireDefault","require","_react","_interopRequireWildcard","_Sector","_MoreInfoButton","_streamiLogo","_useNavContext2","_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","_useNavContext","useNavContext","isRtl","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","SummarySection","SummaryHeader","SummaryTitle","i18next","t","SummaryText","ToggleRow","Attribution","BrandLogoSmall","src","StreamiLogo","alt","PoweredBy","MoreInfoWrap","MoreInfoDiv","href","onClick","e","preventDefault","Fragment","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","_ref4","span","img","value","toString","trim","toLowerCase","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';\nimport StreamiLogo from 'src/assets/streami-logo.svg';\nimport { useNavContext } from 'src/hooks/useNavContext';\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  const { isRtl } = useNavContext();\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 isRtl={isRtl}>\n      <SummarySection>\n        <SummaryHeader isRtl={isRtl}>\n          <SummaryTitle>\n            {i18next.t('seasonal_insights.summary_heading')}\n          </SummaryTitle>\n        </SummaryHeader>\n        <SummaryText>{summary}</SummaryText>\n      </SummarySection>\n      <ToggleRow>\n        <Attribution>\n          <BrandLogoSmall src={StreamiLogo} alt=\"Streami\" />\n          <PoweredBy>{'Powered by STREAMi'}</PoweredBy>\n        </Attribution>\n        {hasDetails ? (\n          <MoreInfoWrap>\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          </MoreInfoWrap>\n        ) : null}\n      </ToggleRow>\n\n      {hasDetails ? (\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 SummaryHeader = styled.div<{ isRtl: boolean }>`\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n  gap: 12px;\n  flex-direction: ${({ isRtl }) => (isRtl ? 'row-reverse' : 'row')};\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: space-between;\n  align-items: center;\n  margin-top: 6px;\n  gap: 10px;\n  flex-direction: row;\n\n  .more-info-button:focus,\n  .more-info-button:focus-visible {\n    outline: none;\n    box-shadow: none;\n  }\n`;\n\nconst PoweredBy = styled.span`\n  font-size: 12px;\n  color: #6b7280;\n  white-space: nowrap;\n`;\n\nconst Attribution = styled.div`\n  display: inline-flex;\n  align-items: center;\n  gap: 6px;\n  order: 1;\n`;\n\nconst BrandLogoSmall = styled.img`\n  height: 16px;\n  width: auto;\n  opacity: 0.7;\n  flex-shrink: 0;\n`;\n\nconst MoreInfoWrap = styled.div`\n  order: 2;\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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"}