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

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.
Files changed (46) hide show
  1. package/lib/Router.js +12 -5
  2. package/lib/Widgets/Map/Map.js +3 -3
  3. package/lib/Widgets/Map/MapUtils.js +2 -1
  4. package/lib/Widgets/MostPolluting/Factories/factoriesResponse.interface.js +1 -1
  5. package/lib/assets/streami-logo.svg +26 -0
  6. package/lib/components/DischargeHeatmap/mocks/handlers.js +3 -3
  7. package/lib/components/Header/Toolbar/Toolbar.js +3 -6
  8. package/lib/components/KandoModal/KandoModal.js +27 -4
  9. package/lib/components/KandoModal/styles.scss +4 -0
  10. package/lib/components/SeasonalInsights/SeasonalInsights.js +230 -0
  11. package/lib/components/SevereEvent/SevereEvent.js +18 -2
  12. package/lib/components/SevereEvent/SevereEvent.scss +24 -0
  13. package/lib/components/SevereEvent/UpstreamBadge.js +60 -0
  14. package/lib/components/TopBanner/TopBanner.js +227 -0
  15. package/lib/components/TopBanner/insightsDismissalStorage.js +36 -0
  16. package/lib/i18n/en.json +28 -3
  17. package/lib/i18n/fr.json +13 -0
  18. package/lib/i18n/he.json +21 -1
  19. package/lib/i18n/it.json +13 -0
  20. package/lib/macros/getVersion.js +2 -2
  21. package/lib/pages/AreaPage/Dashboard/Dashboard.js +2 -2
  22. package/lib/pages/EventsPage/events/EventsStyle.scss +1 -1
  23. package/lib/pages/EventsPage/events/event_info/EventDetails.js +2 -2
  24. package/lib/pages/EventsPage/events/event_info/EventSection.test.js +21 -22
  25. package/lib/pages/EventsPage/events/event_info/Header/Header.js +1 -1
  26. package/lib/pages/EventsPage/events/event_info/Header/HeaderContainer.js +2 -2
  27. package/lib/pages/EventsPage/events/event_info/Header/index.js +1 -1
  28. package/lib/pages/EventsPage/events/event_info/SeverityScore/index.js +1 -1
  29. package/lib/pages/EventsPage/events/event_info/Timelines/index.js +1 -1
  30. package/lib/pages/EventsPage/events/events_list/EventsList.js +7 -1
  31. package/lib/pages/EventsPage/events/events_list/Filter/FilterContainer.js +3 -3
  32. package/lib/pages/EventsPage/events/events_list/Filter/FilterItem.js +5 -1
  33. package/lib/pages/EventsPage/events/events_list/Sort.js +21 -15
  34. package/lib/pages/NetworkPage/NetworkPage.js +48 -0
  35. package/lib/pages/SamplingsPage/SamplingProperties/SamplingProperties.js +10 -7
  36. package/lib/pages/SitePage/SitePage.js +2 -2
  37. package/lib/test/mocks/browser.js +1 -1
  38. package/lib/test/test-utils.js +1 -1
  39. package/lib/ui-kit/HierarchyGraph/AutoFitTree.js +27 -10
  40. package/lib/ui-kit/HierarchyGraph/HierarchyGraph.js +20 -10
  41. package/lib/ui-kit/HierarchyGraph/NetworkNode.js +37 -0
  42. package/lib/ui-kit/HierarchyGraph/style.scss +4 -0
  43. package/lib/ui-kit/KandoTable/KandoTable.test.js +1 -1
  44. package/lib/utilities/scoreToData.test.js +1 -1
  45. package/lib/utilities/urls.js +3 -3
  46. package/package.json +1 -1
@@ -0,0 +1,227 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ var _typeof = require("@babel/runtime/helpers/typeof");
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ exports.default = void 0;
9
+ var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
10
+ var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/asyncToGenerator"));
11
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/slicedToArray"));
12
+ var _styledComponents = _interopRequireDefault(require("styled-components"));
13
+ var _react = _interopRequireWildcard(require("react"));
14
+ var _KandoModal = _interopRequireDefault(require("../KandoModal"));
15
+ var _SeasonalInsights = _interopRequireDefault(require("../SeasonalInsights/SeasonalInsights"));
16
+ var _i18next = _interopRequireDefault(require("i18next"));
17
+ var _insightsDismissalStorage = require("./insightsDismissalStorage");
18
+ var _Analytics = require("utilities/Analytics");
19
+ var _reactRedux = require("react-redux");
20
+ var _useNavContext2 = require("hooks/useNavContext");
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); }
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; }
23
+ var INSIGHT_TYPE = 'seasonal_insight';
24
+ var TopBanner = function TopBanner(_ref) {
25
+ var _ref$backgroundColor = _ref.backgroundColor,
26
+ backgroundColor = _ref$backgroundColor === void 0 ? 'rgb(217, 234, 255)' : _ref$backgroundColor,
27
+ _ref$text = _ref.text,
28
+ text = _ref$text === void 0 ? '' : _ref$text,
29
+ onVisibilityChange = _ref.onVisibilityChange,
30
+ apiEndpoint = _ref.apiEndpoint;
31
+ var _useState = (0, _react.useState)(true),
32
+ _useState2 = (0, _slicedToArray2.default)(_useState, 2),
33
+ visible = _useState2[0],
34
+ setVisible = _useState2[1];
35
+ var _useState3 = (0, _react.useState)(false),
36
+ _useState4 = (0, _slicedToArray2.default)(_useState3, 2),
37
+ showModal = _useState4[0],
38
+ setShowModal = _useState4[1];
39
+ var _useState5 = (0, _react.useState)(null),
40
+ _useState6 = (0, _slicedToArray2.default)(_useState5, 2),
41
+ insightData = _useState6[0],
42
+ setInsightData = _useState6[1];
43
+ var bannerHeight = 30; // px
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'));
53
+
54
+ // On mount or when insight id changes, check localStorage for dismissal
55
+ (0, _react.useEffect)(function () {
56
+ // If we have insight data with an id, check if it was dismissed
57
+ if ((insightData === null || insightData === void 0 ? void 0 : insightData.id) !== undefined) {
58
+ try {
59
+ var record = (0, _insightsDismissalStorage.getDismissal)(INSIGHT_TYPE);
60
+ var dismissed = (record === null || record === void 0 ? void 0 : record.lastDismissedId) === String(insightData.id);
61
+ setVisible(!dismissed);
62
+ } catch (_unused) {
63
+ setVisible(true);
64
+ }
65
+ } else if (insightData === null) {
66
+ // No insight data - hide banner if using API, show if using static text prop
67
+ if (apiEndpoint) {
68
+ // API endpoint exists but no data returned - hide banner
69
+ setVisible(false);
70
+ } else {
71
+ // No API endpoint - show banner if text is provided
72
+ setVisible(!!text);
73
+ }
74
+ }
75
+ }, [insightData === null || insightData === void 0 ? void 0 : insightData.id, insightData, apiEndpoint, text]);
76
+
77
+ // Fetch data from API if endpoint is provided, robustly
78
+ (0, _react.useEffect)(function () {
79
+ if (!apiEndpoint) return;
80
+ var controller = new AbortController();
81
+ fetch(apiEndpoint, {
82
+ signal: controller.signal
83
+ }).then( /*#__PURE__*/function () {
84
+ var _ref2 = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee(res) {
85
+ return _regenerator.default.wrap(function _callee$(_context) {
86
+ while (1) {
87
+ switch (_context.prev = _context.next) {
88
+ case 0:
89
+ if (!(res.status === 404)) {
90
+ _context.next = 2;
91
+ break;
92
+ }
93
+ return _context.abrupt("return", {
94
+ error: 'not_found'
95
+ });
96
+ case 2:
97
+ if (res.ok) {
98
+ _context.next = 4;
99
+ break;
100
+ }
101
+ throw new Error("Request failed (".concat(res.status, ")"));
102
+ case 4:
103
+ _context.next = 6;
104
+ return res.json();
105
+ case 6:
106
+ return _context.abrupt("return", _context.sent);
107
+ case 7:
108
+ case "end":
109
+ return _context.stop();
110
+ }
111
+ }
112
+ }, _callee);
113
+ }));
114
+ return function (_x) {
115
+ return _ref2.apply(this, arguments);
116
+ };
117
+ }()).then(function (data) {
118
+ // When the API says not_found, do not show the banner.
119
+ if ((data === null || data === void 0 ? void 0 : data.error) === 'not_found') {
120
+ setInsightData(null);
121
+ setVisible(false);
122
+ return;
123
+ }
124
+ setInsightData(data);
125
+ }).catch(function (err) {
126
+ // On fetch error, hide the banner (no data to show)
127
+ if ((err === null || err === void 0 ? void 0 : err.name) !== 'AbortError') {
128
+ setInsightData(null);
129
+ setVisible(false);
130
+ }
131
+ });
132
+ return function () {
133
+ return controller.abort();
134
+ };
135
+ }, [apiEndpoint, text]);
136
+
137
+ // Notify parent on visibility change
138
+ (0, _react.useEffect)(function () {
139
+ if (onVisibilityChange) onVisibilityChange(visible);
140
+ }, [visible]);
141
+
142
+ // When dismissed, persist in localStorage
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
+ });
148
+ setVisible(false);
149
+ if ((insightData === null || insightData === void 0 ? void 0 : insightData.id) === undefined) return;
150
+ try {
151
+ (0, _insightsDismissalStorage.setDismissal)(INSIGHT_TYPE, String(insightData.id));
152
+ } catch (_unused2) {
153
+ // ignore storage errors
154
+ }
155
+ };
156
+ var openModal = function openModal() {
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
+ });
162
+ };
163
+ var closeModal = function closeModal() {
164
+ setShowModal(false);
165
+ };
166
+ var modal = (0, _react.useMemo)(function () {
167
+ if (!showModal) return null;
168
+ return /*#__PURE__*/_react.default.createElement(_KandoModal.default, {
169
+ isOpen: showModal,
170
+ onClose: closeModal
171
+ }, /*#__PURE__*/_react.default.createElement(_SeasonalInsights.default, {
172
+ data: insightData
173
+ }));
174
+ }, [showModal]);
175
+ if (!visible || !apiEndpoint) {
176
+ return null;
177
+ }
178
+ return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(BannerContainer, {
179
+ backgroundColor: backgroundColor,
180
+ bannerHeight: bannerHeight
181
+ }, /*#__PURE__*/_react.default.createElement("span", null, apiEndpoint && /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("span", {
182
+ style: {
183
+ filter: 'drop-shadow(0 0 2px rgba(0, 0, 0, 0.3))',
184
+ fontSize: '16px',
185
+ display: 'inline-block',
186
+ marginRight: '4px'
187
+ }
188
+ }, "\u2728"), titleText, ' ', /*#__PURE__*/_react.default.createElement("span", {
189
+ onClick: openModal,
190
+ style: {
191
+ textDecoration: 'underline',
192
+ cursor: 'pointer'
193
+ }
194
+ }, learnMoreText))), /*#__PURE__*/_react.default.createElement(DismissButton, {
195
+ onClick: handleDismiss,
196
+ "aria-label": 'dismissTooltip',
197
+ className: "kd-tooltip",
198
+ "data-text": dismissTooltipText,
199
+ isRtl: dir === 'rtl'
200
+ }, "\xD7")), modal);
201
+ };
202
+ var DismissButton = _styledComponents.default.button.withConfig({
203
+ displayName: "TopBanner__DismissButton",
204
+ componentId: "sc-1towuq0-0"
205
+ })(["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;opacity:0;visibility:hidden;pointer-events:none;transition:opacity 0.15s ease-in-out,visibility 0.15s ease-in-out;white-space:nowrap;font-size:12px;}&:hover{&[data-text]::after{z-index:-1;opacity:1;visibility:visible;}}}"], function (_ref3) {
206
+ var isRtl = _ref3.isRtl;
207
+ return isRtl ? 'left: 10px; right: auto;' : 'right: 10px; left: auto;';
208
+ }, function (_ref4) {
209
+ var isRtl = _ref4.isRtl;
210
+ return isRtl ? 'left: 22px;' : 'right: 22px;';
211
+ });
212
+ var BannerContainer = _styledComponents.default.div.withConfig({
213
+ displayName: "TopBanner__BannerContainer",
214
+ componentId: "sc-1towuq0-1"
215
+ })(["width:100%;background:", ";padding:8px;text-align:center;position:sticky;top:0;z-index:1200;box-sizing:border-box;min-height:", ";height:", ";display:flex;align-items:center;justify-content:center;font-size:14px;cursor:default;"], function (_ref5) {
216
+ var backgroundColor = _ref5.backgroundColor;
217
+ return backgroundColor;
218
+ }, function (_ref6) {
219
+ var bannerHeight = _ref6.bannerHeight;
220
+ return "".concat(bannerHeight, "px");
221
+ }, function (_ref7) {
222
+ var bannerHeight = _ref7.bannerHeight;
223
+ return "".concat(bannerHeight, "px");
224
+ });
225
+ var _default = TopBanner;
226
+ exports.default = _default;
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","BannerContainer","style","filter","fontSize","display","marginRight","onClick","textDecoration","cursor","DismissButton","className","isRtl","styled","button","withConfig","displayName","componentId","_ref3","_ref4","div","_ref5","_ref6","_ref7","_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      <BannerContainer\n        backgroundColor={backgroundColor}\n        bannerHeight={bannerHeight}\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      </BannerContainer>\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      opacity: 0;\n      visibility: hidden;\n      pointer-events: none;\n      transition: opacity 0.15s ease-in-out, visibility 0.15s ease-in-out;\n      white-space: nowrap;\n      font-size: 12px;\n    }\n    &:hover {\n      &[data-text]::after {\n        z-index: -1;\n        opacity: 1;\n        visibility: visible;\n      }\n    }\n  }\n`;\n\nconst BannerContainer = styled.div<{\n  backgroundColor: string;\n  bannerHeight: number;\n}>`\n  width: 100%;\n  background: ${({ backgroundColor }) => backgroundColor};\n  padding: 8px;\n  text-align: center;\n  position: sticky;\n  top: 0;\n  z-index: 1200;\n  box-sizing: border-box;\n  min-height: ${({ bannerHeight }) => `${bannerHeight}px`};\n  height: ${({ bannerHeight }) => `${bannerHeight}px`};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  font-size: 14px;\n  cursor: default;\n`;\n\nexport default TopBanner;\n"],"mappings":"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"}
@@ -0,0 +1,36 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.getDismissal = getDismissal;
7
+ exports.setDismissal = setDismissal;
8
+ var STORAGE_PREFIX = 'TopBannerDismissed';
9
+ var buildKey = function buildKey(type) {
10
+ return "".concat(STORAGE_PREFIX, ":").concat(type);
11
+ };
12
+ function getDismissal(type) {
13
+ try {
14
+ var raw = localStorage.getItem(buildKey(type));
15
+ if (!raw) return null;
16
+ var parsed = JSON.parse(raw);
17
+ if (!parsed || typeof parsed.lastDismissedId !== 'string') {
18
+ return null;
19
+ }
20
+ return parsed;
21
+ } catch (_unused) {
22
+ return null;
23
+ }
24
+ }
25
+ function setDismissal(type, id) {
26
+ var record = {
27
+ lastDismissedId: id,
28
+ dismissedAt: new Date().toISOString()
29
+ };
30
+ try {
31
+ localStorage.setItem(buildKey(type), JSON.stringify(record));
32
+ } catch (_unused2) {
33
+ // ignore storage errors
34
+ }
35
+ }
36
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJTVE9SQUdFX1BSRUZJWCIsImJ1aWxkS2V5IiwidHlwZSIsImNvbmNhdCIsImdldERpc21pc3NhbCIsInJhdyIsImxvY2FsU3RvcmFnZSIsImdldEl0ZW0iLCJwYXJzZWQiLCJKU09OIiwicGFyc2UiLCJsYXN0RGlzbWlzc2VkSWQiLCJfdW51c2VkIiwic2V0RGlzbWlzc2FsIiwiaWQiLCJyZWNvcmQiLCJkaXNtaXNzZWRBdCIsIkRhdGUiLCJ0b0lTT1N0cmluZyIsInNldEl0ZW0iLCJzdHJpbmdpZnkiLCJfdW51c2VkMiJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL1RvcEJhbm5lci9pbnNpZ2h0c0Rpc21pc3NhbFN0b3JhZ2UudHMiXSwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHR5cGUgSW5zaWdodFR5cGUgPSAnc2Vhc29uYWxfaW5zaWdodCc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgSW5zaWdodERpc21pc3NhbFJlY29yZCB7XG4gIGxhc3REaXNtaXNzZWRJZDogc3RyaW5nO1xuICBkaXNtaXNzZWRBdD86IHN0cmluZztcbn1cblxuY29uc3QgU1RPUkFHRV9QUkVGSVggPSAnVG9wQmFubmVyRGlzbWlzc2VkJztcblxuY29uc3QgYnVpbGRLZXkgPSAodHlwZTogSW5zaWdodFR5cGUpID0+IGAke1NUT1JBR0VfUFJFRklYfToke3R5cGV9YDtcblxuZXhwb3J0IGZ1bmN0aW9uIGdldERpc21pc3NhbCh0eXBlOiBJbnNpZ2h0VHlwZSk6IEluc2lnaHREaXNtaXNzYWxSZWNvcmQgfCBudWxsIHtcbiAgdHJ5IHtcbiAgICBjb25zdCByYXcgPSBsb2NhbFN0b3JhZ2UuZ2V0SXRlbShidWlsZEtleSh0eXBlKSk7XG4gICAgaWYgKCFyYXcpIHJldHVybiBudWxsO1xuXG4gICAgY29uc3QgcGFyc2VkID0gSlNPTi5wYXJzZShyYXcpIGFzIFBhcnRpYWw8SW5zaWdodERpc21pc3NhbFJlY29yZD47XG4gICAgaWYgKCFwYXJzZWQgfHwgdHlwZW9mIHBhcnNlZC5sYXN0RGlzbWlzc2VkSWQgIT09ICdzdHJpbmcnKSB7XG4gICAgICByZXR1cm4gbnVsbDtcbiAgICB9XG5cbiAgICByZXR1cm4gcGFyc2VkIGFzIEluc2lnaHREaXNtaXNzYWxSZWNvcmQ7XG4gIH0gY2F0Y2gge1xuICAgIHJldHVybiBudWxsO1xuICB9XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBzZXREaXNtaXNzYWwodHlwZTogSW5zaWdodFR5cGUsIGlkOiBzdHJpbmcpIHtcbiAgY29uc3QgcmVjb3JkOiBJbnNpZ2h0RGlzbWlzc2FsUmVjb3JkID0ge1xuICAgIGxhc3REaXNtaXNzZWRJZDogaWQsXG4gICAgZGlzbWlzc2VkQXQ6IG5ldyBEYXRlKCkudG9JU09TdHJpbmcoKSxcbiAgfTtcblxuICB0cnkge1xuICAgIGxvY2FsU3RvcmFnZS5zZXRJdGVtKGJ1aWxkS2V5KHR5cGUpLCBKU09OLnN0cmluZ2lmeShyZWNvcmQpKTtcbiAgfSBjYXRjaCB7XG4gICAgLy8gaWdub3JlIHN0b3JhZ2UgZXJyb3JzXG4gIH1cbn1cbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQU9BLElBQU1BLGNBQWMsR0FBRyxvQkFBb0I7QUFFM0MsSUFBTUMsUUFBUSxHQUFHLFNBQVhBLFFBQVFBLENBQUlDLElBQWlCO0VBQUEsVUFBQUMsTUFBQSxDQUFRSCxjQUFjLE9BQUFHLE1BQUEsQ0FBSUQsSUFBSTtBQUFBLENBQUU7QUFFNUQsU0FBU0UsWUFBWUEsQ0FBQ0YsSUFBaUIsRUFBaUM7RUFDN0UsSUFBSTtJQUNGLElBQU1HLEdBQUcsR0FBR0MsWUFBWSxDQUFDQyxPQUFPLENBQUNOLFFBQVEsQ0FBQ0MsSUFBSSxDQUFDLENBQUM7SUFDaEQsSUFBSSxDQUFDRyxHQUFHLEVBQUUsT0FBTyxJQUFJO0lBRXJCLElBQU1HLE1BQU0sR0FBR0MsSUFBSSxDQUFDQyxLQUFLLENBQUNMLEdBQUcsQ0FBb0M7SUFDakUsSUFBSSxDQUFDRyxNQUFNLElBQUksT0FBT0EsTUFBTSxDQUFDRyxlQUFlLEtBQUssUUFBUSxFQUFFO01BQ3pELE9BQU8sSUFBSTtJQUNiO0lBRUEsT0FBT0gsTUFBTTtFQUNmLENBQUMsQ0FBQyxPQUFBSSxPQUFBLEVBQU07SUFDTixPQUFPLElBQUk7RUFDYjtBQUNGO0FBRU8sU0FBU0MsWUFBWUEsQ0FBQ1gsSUFBaUIsRUFBRVksRUFBVSxFQUFFO0VBQzFELElBQU1DLE1BQThCLEdBQUc7SUFDckNKLGVBQWUsRUFBRUcsRUFBRTtJQUNuQkUsV0FBVyxFQUFFLElBQUlDLElBQUksQ0FBQyxDQUFDLENBQUNDLFdBQVcsQ0FBQztFQUN0QyxDQUFDO0VBRUQsSUFBSTtJQUNGWixZQUFZLENBQUNhLE9BQU8sQ0FBQ2xCLFFBQVEsQ0FBQ0MsSUFBSSxDQUFDLEVBQUVPLElBQUksQ0FBQ1csU0FBUyxDQUFDTCxNQUFNLENBQUMsQ0FBQztFQUM5RCxDQUFDLENBQUMsT0FBQU0sUUFBQSxFQUFNO0lBQ047RUFBQTtBQUVKIn0=
package/lib/i18n/en.json CHANGED
@@ -128,7 +128,7 @@
128
128
  "monitors": "Dataloggers",
129
129
  "systems": "Systems Management",
130
130
  "project_management": "Deployment Management",
131
- "streami": "STREAMi Data",
131
+ "streami_data": "STREAMi Data",
132
132
  "view_map": "View Map",
133
133
  "logic_parameters_sets": "Pollution weights",
134
134
  "admin_info": "Developers",
@@ -151,6 +151,7 @@
151
151
  "assistant_demo": "Chat Assistance (STREAMi) - demo",
152
152
  "assistant": "STREAMi (Chat Assistance)",
153
153
  "pollution_risk_assessment": "View Assessment Map",
154
+ "assistant_regulation": "STREAMi Regulation",
154
155
  "operations_map": "Operations Map",
155
156
  "operations_assistant": "STREAMi Operations"
156
157
  },
@@ -2967,7 +2968,8 @@
2967
2968
  "arrange_by": "Arrange by",
2968
2969
  "newest": "Newest first",
2969
2970
  "oldest": "Oldest first",
2970
- "severity": "Severity"
2971
+ "severity": "Severity",
2972
+ "observed_upstream": "Observed Upstream"
2971
2973
  },
2972
2974
  "damage_types": {
2973
2975
  "agriculture": "Agriculture",
@@ -3072,7 +3074,10 @@
3072
3074
  "points_mode_filter_item": "Site Mode",
3073
3075
  "sampler_filter_item": "Sampler Mode",
3074
3076
  "insight_data_filter_item": "Insight Data",
3077
+ "network_insight_data_filter_item": "Insight Data",
3075
3078
  "sampling_parameter_filter_item": "Exceeding Parameter",
3079
+ "discharge_time_filter_item": "Discharge Time",
3080
+ "observed_upstream_filter_item": "Observed Upstream",
3076
3081
  "duration_filter_item": "Duration"
3077
3082
  },
3078
3083
  "filter": "Filter",
@@ -3121,9 +3126,15 @@
3121
3126
  "with": "With",
3122
3127
  "without": "Without"
3123
3128
  },
3129
+ "observed_upstream": {
3130
+ "with": "With",
3131
+ "without": "Without"
3132
+ },
3124
3133
  "insight_data": {
3125
3134
  "score": "Score",
3126
- "pollution_contributor": "Pollution Contributor"
3135
+ "pollution_contributor": "Pollution Contributor",
3136
+ "risk": "Risk",
3137
+ "cost": "Cost"
3127
3138
  }
3128
3139
  }
3129
3140
  },
@@ -3133,6 +3144,7 @@
3133
3144
  "contaminants": "Contaminants",
3134
3145
  "sampling": "Sampling",
3135
3146
  "sampling_plural": "Samplings ({{count}})",
3147
+ "upstream_observations": "Seen on {{count}} sites",
3136
3148
  "static_thresholds_crossed_explanation": "Exceeding expected pollution for this sector",
3137
3149
  "dynamic_thresholds_crossed_explanation": "Worse than usual for this site ({{score}})",
3138
3150
  "worse_than_usual_explanation": "Worse than usual for this site",
@@ -4132,6 +4144,19 @@
4132
4144
  "should_install": "Should install"
4133
4145
  }
4134
4146
  }
4147
+ },
4148
+ "seasonal_insights": {
4149
+ "title": "Seasonal Insights Available.",
4150
+ "learn_more": "Learn more.",
4151
+ "dismiss_tooltip": "Dismiss until a new insight is available.",
4152
+ "tooltip": "Seasonal insights highlight the key changes for this time of year. Click Learn more to see the full details.",
4153
+ "show_more": "More info",
4154
+ "show_less": "Show less",
4155
+ "summary_heading": "What to expect next",
4156
+ "timeframe": "Time window",
4157
+ "confidence": "Confidence",
4158
+ "key_risks": "Key risks",
4159
+ "seasonal_factors": "Seasonal factors"
4135
4160
  }
4136
4161
  }
4137
4162
  }
package/lib/i18n/fr.json CHANGED
@@ -3793,6 +3793,19 @@
3793
3793
  "sub_areas": "Sous-zones",
3794
3794
  "factories": "Usines"
3795
3795
  }
3796
+ },
3797
+ "seasonal_insights": {
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"
3796
3809
  }
3797
3810
  }
3798
3811
  }
package/lib/i18n/he.json CHANGED
@@ -2989,7 +2989,10 @@
2989
2989
  "sampling_mode_filter_item": "צורת דיגום",
2990
2990
  "sampling_id_filter_item": "ID",
2991
2991
  "site_filter_item": "שם אתר",
2992
- "lab_filter_item": "מעבדה"
2992
+ "lab_filter_item": "מעבדה",
2993
+ "sampling_parameter_filter_item": "פרמטרים חורגים",
2994
+ "discharge_time_filter_item": "זמן הזרמה",
2995
+ "observed_upstream_filter_item": "נצפה במעלה הזרם"
2993
2996
  },
2994
2997
  "filter": "סינון",
2995
2998
  "apply": "סנן",
@@ -3023,6 +3026,10 @@
3023
3026
  "with": "עם",
3024
3027
  "without": "בלי"
3025
3028
  },
3029
+ "observed_upstream": {
3030
+ "with": "עם",
3031
+ "without": "בלי"
3032
+ },
3026
3033
  "sampling_mode": {
3027
3034
  "manual": "הזנה ידנית",
3028
3035
  "automatic": "אוטומטי"
@@ -3912,6 +3919,19 @@
3912
3919
  "sub_areas": "אזורי משנה",
3913
3920
  "factories": "מפעלים"
3914
3921
  }
3922
+ },
3923
+ "seasonal_insights": {
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": "גורמים עונתיים"
3915
3935
  }
3916
3936
  }
3917
3937
  }
package/lib/i18n/it.json CHANGED
@@ -3806,6 +3806,19 @@
3806
3806
  "sub_areas": "Sottoaree",
3807
3807
  "factories": "Fabbriche"
3808
3808
  }
3809
+ },
3810
+ "seasonal_insights": {
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"
3809
3822
  }
3810
3823
  }
3811
3824
  }
@@ -1,10 +1,10 @@
1
1
  "use strict";
2
2
 
3
- var packageJsonVersion = "1.2.466";
3
+ var packageJsonVersion = "1.2.467-alpha.10";
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));
7
7
  } else {
8
8
  console.error('getVersion.js got bad version from package.json, expected string.');
9
9
  }
10
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJwYWNrYWdlSnNvblZlcnNpb24iLCJjb25zb2xlIiwibG9nIiwiY29uY2F0IiwicHJvY2VzcyIsImVudiIsIk5PREVfRU5WIiwiZXJyb3IiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvbWFjcm9zL2dldFZlcnNpb24uanMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHByZXZhbCBmcm9tICdwcmV2YWwubWFjcm8nO1xuXG5jb25zdCBwYWNrYWdlSnNvblZlcnNpb24gPSBwcmV2YWxgbW9kdWxlLmV4cG9ydHMgPSByZXF1aXJlKCcuLi8uLi9iaW4vZ2V0VmVyc2lvbkZyb21QYWNrYWdlSnNvbi5qcycpYDtcbmlmICh0eXBlb2YgcGFja2FnZUpzb25WZXJzaW9uID09PSAnc3RyaW5nJykge1xuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tY29uc29sZVxuICBjb25zb2xlLmxvZyhcbiAgICBgJWMgS2FuZG8gVUkgJWMgdiR7cGFja2FnZUpzb25WZXJzaW9ufSBgLFxuICAgICdmb250LXNpemU6IDE1cHg7IGJhY2tncm91bmQtY29sb3I6ICNmZmY7IGNvbG9yOiAjZTIwZjUzOycsXG4gICAgJ2ZvbnQtd2VpZ2h0OiBib2xkOyBmb250LXNpemU6IDE1cHg7IGJhY2tncm91bmQtY29sb3I6ICNlMjBmNTM7IGNvbG9yOiAjZmZmOycsXG4gICAgYHdpdGggTk9ERV9FTlY9JHtwcm9jZXNzLmVudi5OT0RFX0VOVn1gLFxuICApO1xufSBlbHNlIHtcbiAgY29uc29sZS5lcnJvcihcbiAgICAnZ2V0VmVyc2lvbi5qcyBnb3QgYmFkIHZlcnNpb24gZnJvbSBwYWNrYWdlLmpzb24sIGV4cGVjdGVkIHN0cmluZy4nLFxuICApO1xufVxuIl0sIm1hcHBpbmdzIjoiOztBQUVBLElBQU1BLGtCQUFrQixZQUE2RTtBQUNyRyxJQUFJLE9BQU9BLGtCQUFrQixLQUFLLFFBQVEsRUFBRTtFQUMxQztFQUNBQyxPQUFPLENBQUNDLEdBQUcsb0JBQUFDLE1BQUEsQ0FDVUgsa0JBQWtCLFFBQ3JDLDBEQUEwRCxFQUMxRCw2RUFBNkUsbUJBQUFHLE1BQUEsQ0FDNURDLE9BQU8sQ0FBQ0MsR0FBRyxDQUFDQyxRQUFRLENBQ3ZDLENBQUM7QUFDSCxDQUFDLE1BQU07RUFDTEwsT0FBTyxDQUFDTSxLQUFLLENBQ1gsbUVBQ0YsQ0FBQztBQUNIIn0=
10
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJwYWNrYWdlSnNvblZlcnNpb24iLCJjb25zb2xlIiwibG9nIiwiY29uY2F0IiwicHJvY2VzcyIsImVudiIsIk5PREVfRU5WIiwiZXJyb3IiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvbWFjcm9zL2dldFZlcnNpb24uanMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHByZXZhbCBmcm9tICdwcmV2YWwubWFjcm8nO1xuXG5jb25zdCBwYWNrYWdlSnNvblZlcnNpb24gPSBwcmV2YWxgbW9kdWxlLmV4cG9ydHMgPSByZXF1aXJlKCcuLi8uLi9iaW4vZ2V0VmVyc2lvbkZyb21QYWNrYWdlSnNvbi5qcycpYDtcbmlmICh0eXBlb2YgcGFja2FnZUpzb25WZXJzaW9uID09PSAnc3RyaW5nJykge1xuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tY29uc29sZVxuICBjb25zb2xlLmxvZyhcbiAgICBgJWMgS2FuZG8gVUkgJWMgdiR7cGFja2FnZUpzb25WZXJzaW9ufSBgLFxuICAgICdmb250LXNpemU6IDE1cHg7IGJhY2tncm91bmQtY29sb3I6ICNmZmY7IGNvbG9yOiAjZTIwZjUzOycsXG4gICAgJ2ZvbnQtd2VpZ2h0OiBib2xkOyBmb250LXNpemU6IDE1cHg7IGJhY2tncm91bmQtY29sb3I6ICNlMjBmNTM7IGNvbG9yOiAjZmZmOycsXG4gICAgYHdpdGggTk9ERV9FTlY9JHtwcm9jZXNzLmVudi5OT0RFX0VOVn1gLFxuICApO1xufSBlbHNlIHtcbiAgY29uc29sZS5lcnJvcihcbiAgICAnZ2V0VmVyc2lvbi5qcyBnb3QgYmFkIHZlcnNpb24gZnJvbSBwYWNrYWdlLmpzb24sIGV4cGVjdGVkIHN0cmluZy4nLFxuICApO1xufVxuIl0sIm1hcHBpbmdzIjoiOztBQUVBLElBQU1BLGtCQUFrQixxQkFBNkU7QUFDckcsSUFBSSxPQUFPQSxrQkFBa0IsS0FBSyxRQUFRLEVBQUU7RUFDMUM7RUFDQUMsT0FBTyxDQUFDQyxHQUFHLG9CQUFBQyxNQUFBLENBQ1VILGtCQUFrQixRQUNyQywwREFBMEQsRUFDMUQsNkVBQTZFLG1CQUFBRyxNQUFBLENBQzVEQyxPQUFPLENBQUNDLEdBQUcsQ0FBQ0MsUUFBUSxDQUN2QyxDQUFDO0FBQ0gsQ0FBQyxNQUFNO0VBQ0xMLE9BQU8sQ0FBQ00sS0FBSyxDQUNYLG1FQUNGLENBQUM7QUFDSCJ9
@@ -40,7 +40,7 @@ var Dashboard = function Dashboard() {
40
40
  var events_endpoint = "/events.json";
41
41
  var eventParams = (0, _react.useMemo)(function () {
42
42
  return {
43
- valuesFromKQL: "AreaFilterItem IN ( ".concat(areaID, " ) SeverityFilterItem IN ( 1 2 ) TimeFilterItem IN ( ").concat(period, " ) ORDER_BY severity")
43
+ valuesFromKQL: "AreaFilterItem IN ( ".concat(areaID, " ) SeverityFilterItem IN ( 1 2 ) TimeFilterItem IN ( ").concat(period, " ) ORDER_BY observed_upstream")
44
44
  };
45
45
  }, [areaID, period]);
46
46
  var utilityInfoTitles = [_i18n.default.t('dashboard_v2.utility_dashboard.topbar.utility-information.Factories'), _i18n.default.t('collectors'), _i18n.default.t('dashboard_v2.utility_dashboard.topbar.utility-information.wwtps')];
@@ -98,4 +98,4 @@ var LineChartComponent = (0, _styledComponents.default)(_LineChart.LineChart).wi
98
98
  displayName: "Dashboard__LineChartComponent",
99
99
  componentId: "sc-14zdtnx-4"
100
100
  })(["grid-area:graph;@media (max-width:600px){width:92vw;}"]);
101
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reactRedux","_reactRouterDom","_i18n","_interopRequireDefault","_QualitySummary","_UtilityInformation","_PotentialImpactSummary","_LineChart","_EventsRow","_InfoTooltip","_MostPolluting","_useKandoFetch2","_urls","_reactI18next","_useQueryURL","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","Dashboard","querySelector","useQueryURL","isDashboardTab","_useParams","useParams","areaID","period","useSelector","state","dashboard","_useKandoFetch","useKandoFetch","urls","Area","tabsData","data","isFetching","events_endpoint","eventParams","useMemo","valuesFromKQL","concat","utilityInfoTitles","i18n","t","createElement","Container","InfoComponent","endpoint","titles","showMap","valuesKeys","title","refreshMap","SummaryComponent","CommonComponent","LineChartComponent","className","InfoTooltip","Trans","i18nKey","EventsRow","MostPolluting","dashboardItem","displayTabs","tab_list","defaultTab","default_tab","exports","styled","div","withConfig","displayName","componentId","UtilityInformation","QualitySummary","PotentialImpactSummary","LineChart"],"sources":["../../../../src/pages/AreaPage/Dashboard/Dashboard.tsx"],"sourcesContent":["import React, { useMemo } from 'react';\nimport { useSelector } from 'react-redux';\nimport { useParams } from 'react-router-dom';\nimport { appReducer } from 'src/store/rootReducer';\nimport i18n from 'src/utilities/i18n';\nimport { QualitySummary } from 'src/Widgets/QualitySummary/QualitySummary';\nimport { UtilityInformation } from 'src/Widgets/UtilityInformation/UtilityInformation';\nimport styled from 'styled-components/macro';\nimport { PotentialImpactSummary } from '../../../Widgets/PotentialImpactSummary';\nimport { LineChart } from './LineChart/LineChart';\nimport { EventsRow } from 'src/Widgets/EventsRow/EventsRow';\nimport { InfoTooltip } from 'src/ui-kit/InfoTooltip/InfoTooltip';\nimport { MostPolluting } from 'src/Widgets/MostPolluting/MostPolluting';\nimport useKandoFetch from 'src/hooks/useKandoFetch';\nimport { urls } from 'src/utilities/urls';\nimport { Trans } from 'react-i18next';\nimport useQueryURL from 'src/hooks/useQueryURL';\n\nexport const Dashboard = () => {\n  const querySelector = useQueryURL();\n  const isDashboardTab = querySelector.get('view') !== 'map';\n  const { areaID } = useParams();\n  const period = useSelector(\n    (state: ReturnType<typeof appReducer>) =>\n      state.dashboard.period['range'] || state.dashboard.period,\n  );\n  const {\n    data,\n    isFetching,\n  }: {\n    data: { default_tab: string; tab_list: number[] };\n    isFetching: boolean;\n  } = useKandoFetch(urls({ areaID }).dashboard.Area.tabsData);\n\n  const events_endpoint = `/events.json`;\n\n  const eventParams = useMemo(() => {\n    return {\n      valuesFromKQL: `AreaFilterItem IN ( ${areaID} ) SeverityFilterItem IN ( 1 2 ) TimeFilterItem IN ( ${period} ) ORDER_BY severity`,\n    };\n  }, [areaID, period]);\n\n  const utilityInfoTitles = [\n    i18n.t(\n      'dashboard_v2.utility_dashboard.topbar.utility-information.Factories',\n    ),\n    i18n.t('collectors'),\n    i18n.t('dashboard_v2.utility_dashboard.topbar.utility-information.wwtps'),\n  ];\n\n  return (\n    <Container>\n      <InfoComponent\n        endpoint={`/areas/${areaID}/information.json`}\n        titles={utilityInfoTitles}\n        showMap={true}\n        valuesKeys={['total_factories', 'total_collectors', 'total_wwtps']}\n        title={i18n.t('area_dashboard.area-info')}\n        refreshMap={isDashboardTab}\n      />\n      <SummaryComponent endpoint={`/areas/${areaID}/quality-summary.json`} />\n      <CommonComponent endpoint={`/areas/${areaID}/information.json`} />\n      <LineChartComponent endpoint={`/areas/${areaID}/trend-graph.json`} />\n      <div className=\"significant-events\">\n        <div className=\"title\">\n          <InfoTooltip\n            title={i18n.t('area_dashboard.most-significant-events')}\n            data={i18n.t('helpers.info_tooltip.most_significant_events')}\n          >\n            <Trans i18nKey={'area_dashboard.most-significant-events'} />\n          </InfoTooltip>\n        </div>\n        <EventsRow endpoint={events_endpoint} eventParams={eventParams} />\n      </div>\n      <div className=\"sites\">\n        {!isFetching && (\n          <MostPolluting\n            dashboardItem={'Area'}\n            displayTabs={data.tab_list}\n            defaultTab={data.default_tab}\n          />\n        )}\n      </div>\n    </Container>\n  );\n};\n\nconst Container = styled.div`\n  display: grid;\n  grid-template-columns: 1fr 1fr 1fr 1fr;\n  grid-template-rows: 250px 340px 300px auto;\n  grid-auto-rows: auto;\n  grid-gap: 15px;\n  color: #1d1d1d;\n  width: 100%;\n  grid-template-areas:\n    'info   summary summary common'\n    'info   graph   graph   graph'\n    'events events  events  events'\n    'sites  sites   sites   sites';\n\n  @media (max-width: 1500px) {\n    grid-template-rows: 250px 300px 300px auto;\n  }\n  @media (max-width: 1250px) {\n    grid-gap: 10px;\n    grid-template-areas:\n      'info   info   summary  summary'\n      'info   info   common   common'\n      'events events events   events'\n      'graph  graph  graph    graph'\n      'sites  sites  sites    sites';\n  }\n\n  @media (max-width: 996px) {\n    grid-gap: 10px;\n    grid-template-columns: 1fr 1fr;\n    grid-template-rows: auto 300px;\n\n    grid-template-areas:\n      'info summary'\n      'events common'\n      'graph graph'\n      'sites sites';\n  }\n\n  @media (max-width: 600px) {\n    display: flex;\n    flex-direction: column;\n  }\n  .graph {\n    grid-area: graph;\n  }\n  .sites {\n    padding-top: 14px;\n  }\n  .significant-events {\n    > .title {\n      font-size: 24px;\n\n      margin-bottom: 14px;\n      @media (min-width: 1200px) {\n        @media (max-width: 1450px) {\n          font-size: 20px;\n          @media (max-width: 1250px) {\n            font-size: 16px;\n          }\n        }\n      }\n\n      @media (max-width: 400px) {\n        font-size: 16px;\n      }\n    }\n  }\n  .significant-events {\n    grid-area: events;\n  }\n  .sites {\n    grid-area: sites;\n    min-height: 100%;\n    position: relative;\n  }\n  .map-box {\n    flex: 1;\n    padding: 20px;\n    width: 100%;\n  }\n`;\n\nconst InfoComponent = styled(UtilityInformation)`\n  grid-area: info;\n`;\n\nconst SummaryComponent = styled(QualitySummary)`\n  grid-area: summary;\n`;\n\nconst CommonComponent = styled(PotentialImpactSummary)`\n  grid-area: common;\n`;\n\nconst LineChartComponent = styled(LineChart)`\n  grid-area: graph;\n\n  @media (max-width: 600px) {\n    width: 92vw;\n  }\n`;\n"],"mappings":"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"}
101
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reactRedux","_reactRouterDom","_i18n","_interopRequireDefault","_QualitySummary","_UtilityInformation","_PotentialImpactSummary","_LineChart","_EventsRow","_InfoTooltip","_MostPolluting","_useKandoFetch2","_urls","_reactI18next","_useQueryURL","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","Dashboard","querySelector","useQueryURL","isDashboardTab","_useParams","useParams","areaID","period","useSelector","state","dashboard","_useKandoFetch","useKandoFetch","urls","Area","tabsData","data","isFetching","events_endpoint","eventParams","useMemo","valuesFromKQL","concat","utilityInfoTitles","i18n","t","createElement","Container","InfoComponent","endpoint","titles","showMap","valuesKeys","title","refreshMap","SummaryComponent","CommonComponent","LineChartComponent","className","InfoTooltip","Trans","i18nKey","EventsRow","MostPolluting","dashboardItem","displayTabs","tab_list","defaultTab","default_tab","exports","styled","div","withConfig","displayName","componentId","UtilityInformation","QualitySummary","PotentialImpactSummary","LineChart"],"sources":["../../../../src/pages/AreaPage/Dashboard/Dashboard.tsx"],"sourcesContent":["import React, { useMemo } from 'react';\nimport { useSelector } from 'react-redux';\nimport { useParams } from 'react-router-dom';\nimport { appReducer } from 'src/store/rootReducer';\nimport i18n from 'src/utilities/i18n';\nimport { QualitySummary } from 'src/Widgets/QualitySummary/QualitySummary';\nimport { UtilityInformation } from 'src/Widgets/UtilityInformation/UtilityInformation';\nimport styled from 'styled-components/macro';\nimport { PotentialImpactSummary } from '../../../Widgets/PotentialImpactSummary';\nimport { LineChart } from './LineChart/LineChart';\nimport { EventsRow } from 'src/Widgets/EventsRow/EventsRow';\nimport { InfoTooltip } from 'src/ui-kit/InfoTooltip/InfoTooltip';\nimport { MostPolluting } from 'src/Widgets/MostPolluting/MostPolluting';\nimport useKandoFetch from 'src/hooks/useKandoFetch';\nimport { urls } from 'src/utilities/urls';\nimport { Trans } from 'react-i18next';\nimport useQueryURL from 'src/hooks/useQueryURL';\n\nexport const Dashboard = () => {\n  const querySelector = useQueryURL();\n  const isDashboardTab = querySelector.get('view') !== 'map';\n  const { areaID } = useParams();\n  const period = useSelector(\n    (state: ReturnType<typeof appReducer>) =>\n      state.dashboard.period['range'] || state.dashboard.period,\n  );\n  const {\n    data,\n    isFetching,\n  }: {\n    data: { default_tab: string; tab_list: number[] };\n    isFetching: boolean;\n  } = useKandoFetch(urls({ areaID }).dashboard.Area.tabsData);\n\n  const events_endpoint = `/events.json`;\n\n  const eventParams = useMemo(() => {\n    return {\n      valuesFromKQL: `AreaFilterItem IN ( ${areaID} ) SeverityFilterItem IN ( 1 2 ) TimeFilterItem IN ( ${period} ) ORDER_BY observed_upstream`,\n    };\n  }, [areaID, period]);\n\n  const utilityInfoTitles = [\n    i18n.t(\n      'dashboard_v2.utility_dashboard.topbar.utility-information.Factories',\n    ),\n    i18n.t('collectors'),\n    i18n.t('dashboard_v2.utility_dashboard.topbar.utility-information.wwtps'),\n  ];\n\n  return (\n    <Container>\n      <InfoComponent\n        endpoint={`/areas/${areaID}/information.json`}\n        titles={utilityInfoTitles}\n        showMap={true}\n        valuesKeys={['total_factories', 'total_collectors', 'total_wwtps']}\n        title={i18n.t('area_dashboard.area-info')}\n        refreshMap={isDashboardTab}\n      />\n      <SummaryComponent endpoint={`/areas/${areaID}/quality-summary.json`} />\n      <CommonComponent endpoint={`/areas/${areaID}/information.json`} />\n      <LineChartComponent endpoint={`/areas/${areaID}/trend-graph.json`} />\n      <div className=\"significant-events\">\n        <div className=\"title\">\n          <InfoTooltip\n            title={i18n.t('area_dashboard.most-significant-events')}\n            data={i18n.t('helpers.info_tooltip.most_significant_events')}\n          >\n            <Trans i18nKey={'area_dashboard.most-significant-events'} />\n          </InfoTooltip>\n        </div>\n        <EventsRow endpoint={events_endpoint} eventParams={eventParams} />\n      </div>\n      <div className=\"sites\">\n        {!isFetching && (\n          <MostPolluting\n            dashboardItem={'Area'}\n            displayTabs={data.tab_list}\n            defaultTab={data.default_tab}\n          />\n        )}\n      </div>\n    </Container>\n  );\n};\n\nconst Container = styled.div`\n  display: grid;\n  grid-template-columns: 1fr 1fr 1fr 1fr;\n  grid-template-rows: 250px 340px 300px auto;\n  grid-auto-rows: auto;\n  grid-gap: 15px;\n  color: #1d1d1d;\n  width: 100%;\n  grid-template-areas:\n    'info   summary summary common'\n    'info   graph   graph   graph'\n    'events events  events  events'\n    'sites  sites   sites   sites';\n\n  @media (max-width: 1500px) {\n    grid-template-rows: 250px 300px 300px auto;\n  }\n  @media (max-width: 1250px) {\n    grid-gap: 10px;\n    grid-template-areas:\n      'info   info   summary  summary'\n      'info   info   common   common'\n      'events events events   events'\n      'graph  graph  graph    graph'\n      'sites  sites  sites    sites';\n  }\n\n  @media (max-width: 996px) {\n    grid-gap: 10px;\n    grid-template-columns: 1fr 1fr;\n    grid-template-rows: auto 300px;\n\n    grid-template-areas:\n      'info summary'\n      'events common'\n      'graph graph'\n      'sites sites';\n  }\n\n  @media (max-width: 600px) {\n    display: flex;\n    flex-direction: column;\n  }\n  .graph {\n    grid-area: graph;\n  }\n  .sites {\n    padding-top: 14px;\n  }\n  .significant-events {\n    > .title {\n      font-size: 24px;\n\n      margin-bottom: 14px;\n      @media (min-width: 1200px) {\n        @media (max-width: 1450px) {\n          font-size: 20px;\n          @media (max-width: 1250px) {\n            font-size: 16px;\n          }\n        }\n      }\n\n      @media (max-width: 400px) {\n        font-size: 16px;\n      }\n    }\n  }\n  .significant-events {\n    grid-area: events;\n  }\n  .sites {\n    grid-area: sites;\n    min-height: 100%;\n    position: relative;\n  }\n  .map-box {\n    flex: 1;\n    padding: 20px;\n    width: 100%;\n  }\n`;\n\nconst InfoComponent = styled(UtilityInformation)`\n  grid-area: info;\n`;\n\nconst SummaryComponent = styled(QualitySummary)`\n  grid-area: summary;\n`;\n\nconst CommonComponent = styled(PotentialImpactSummary)`\n  grid-area: common;\n`;\n\nconst LineChartComponent = styled(LineChart)`\n  grid-area: graph;\n\n  @media (max-width: 600px) {\n    width: 92vw;\n  }\n`;\n"],"mappings":"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"}
@@ -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);