@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,230 @@
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 _i18next = _interopRequireDefault(require("i18next"));
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");
19
+ var _reactRedux = require("react-redux");
20
+ 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); }
21
+ 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; }
22
+ var SeasonalInsights = function SeasonalInsights(_ref) {
23
+ var apiEndpoint = _ref.apiEndpoint,
24
+ dataProp = _ref.data,
25
+ className = _ref.className,
26
+ onLoaded = _ref.onLoaded;
27
+ var _useState = (0, _react.useState)(dataProp !== null && dataProp !== void 0 ? dataProp : null),
28
+ _useState2 = (0, _slicedToArray2.default)(_useState, 2),
29
+ data = _useState2[0],
30
+ setData = _useState2[1];
31
+ var _useState3 = (0, _react.useState)(false),
32
+ _useState4 = (0, _slicedToArray2.default)(_useState3, 2),
33
+ showDetails = _useState4[0],
34
+ setShowDetails = _useState4[1];
35
+
36
+ // If parent provides data, render it and skip fetching.
37
+ (0, _react.useEffect)(function () {
38
+ if (typeof dataProp === 'undefined') return;
39
+ setData(dataProp !== null && dataProp !== void 0 ? dataProp : null);
40
+ }, [dataProp]);
41
+ var risk = (0, _react.useMemo)(function () {
42
+ var _data$insight_info;
43
+ var risks = data === null || data === void 0 ? void 0 : (_data$insight_info = data.insight_info) === null || _data$insight_info === void 0 ? void 0 : _data$insight_info.risks;
44
+ if (!risks) return null;
45
+ var lang = (data === null || data === void 0 ? void 0 : data.locale) || 'en';
46
+ return risks[lang] || null;
47
+ }, [data]);
48
+ var _useSelector = (0, _reactRedux.useSelector)(function (state) {
49
+ return [state.global_data.waterAuthorityId];
50
+ }),
51
+ _useSelector2 = (0, _slicedToArray2.default)(_useSelector, 1),
52
+ waterAuthorityId = _useSelector2[0];
53
+ var summary = (risk === null || risk === void 0 ? void 0 : risk.risk_summary) || '';
54
+ var detailed = (risk === null || risk === void 0 ? void 0 : risk.detailed_risks) || [];
55
+ var hasDetails = detailed.length > 0;
56
+ var _useNavContext = (0, _useNavContext2.useNavContext)(),
57
+ isRtl = _useNavContext.isRtl,
58
+ locale = _useNavContext.locale;
59
+ var streamiHref = "/assistant?locale=".concat(locale, "&water_authority_id=").concat(waterAuthorityId);
60
+ (0, _react.useEffect)(function () {
61
+ // If parent provides data, do not fetch.
62
+ if (typeof dataProp !== 'undefined') return;
63
+ if (!apiEndpoint) return;
64
+ var controller = new AbortController();
65
+ fetch(apiEndpoint, {
66
+ signal: controller.signal
67
+ }).then( /*#__PURE__*/function () {
68
+ var _ref2 = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee(res) {
69
+ return _regenerator.default.wrap(function _callee$(_context) {
70
+ while (1) {
71
+ switch (_context.prev = _context.next) {
72
+ case 0:
73
+ if (res.ok) {
74
+ _context.next = 2;
75
+ break;
76
+ }
77
+ throw new Error("Request failed (".concat(res.status, ")"));
78
+ case 2:
79
+ _context.next = 4;
80
+ return res.json();
81
+ case 4:
82
+ return _context.abrupt("return", _context.sent);
83
+ case 5:
84
+ case "end":
85
+ return _context.stop();
86
+ }
87
+ }
88
+ }, _callee);
89
+ }));
90
+ return function (_x) {
91
+ return _ref2.apply(this, arguments);
92
+ };
93
+ }()).then(function (payload) {
94
+ setData(payload);
95
+ if (onLoaded) onLoaded(payload);
96
+ }).catch(function (err) {
97
+ if ((err === null || err === void 0 ? void 0 : err.name) === 'AbortError') return;
98
+ setData(null);
99
+ });
100
+ return function () {
101
+ return controller.abort();
102
+ };
103
+ }, [apiEndpoint, dataProp, onLoaded]);
104
+ return /*#__PURE__*/_react.default.createElement(Container, {
105
+ isRtl: isRtl
106
+ }, /*#__PURE__*/_react.default.createElement(SummarySection, null, /*#__PURE__*/_react.default.createElement(SummaryHeader, {
107
+ isRtl: isRtl
108
+ }, /*#__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(AttributionLink, {
109
+ href: streamiHref
110
+ }, /*#__PURE__*/_react.default.createElement(BrandLogoSmall, {
111
+ src: _streamiLogo.default,
112
+ alt: "STREAMi"
113
+ }), /*#__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", {
114
+ href: "#",
115
+ className: "more-info-button",
116
+ onClick: function onClick(e) {
117
+ e.preventDefault();
118
+ setShowDetails(function (prev) {
119
+ return !prev;
120
+ });
121
+ },
122
+ "aria-expanded": showDetails
123
+ }, 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) {
124
+ var _r$expected_pollution;
125
+ return /*#__PURE__*/_react.default.createElement(Card, {
126
+ key: idx
127
+ }, /*#__PURE__*/_react.default.createElement(CardHeader, null, /*#__PURE__*/_react.default.createElement(TitleBlock, null, formatSectorIconName(r.sector) ? /*#__PURE__*/_react.default.createElement(_Sector.default, {
128
+ sectorIconName: formatSectorIconName(r.sector) || 'Missing',
129
+ sectorName: r.sector,
130
+ showLabel: false,
131
+ withTooltip: true
132
+ }) : 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) {
133
+ return /*#__PURE__*/_react.default.createElement(Chip, {
134
+ key: "".concat(p, "-").concat(chipIdx)
135
+ }, p);
136
+ }))) : 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);
137
+ })) : null) : null);
138
+ };
139
+ var Container = _styledComponents.default.div.withConfig({
140
+ displayName: "SeasonalInsights__Container",
141
+ componentId: "sc-jrd7ho-0"
142
+ })(["padding:16px;margin:16px;display:flex;flex-direction:column;gap:12px;text-align:", ";min-width:320px;border-radius:12px;"], function (_ref3) {
143
+ var isRtl = _ref3.isRtl;
144
+ return isRtl ? 'right' : 'left';
145
+ });
146
+ var SummarySection = _styledComponents.default.div.withConfig({
147
+ displayName: "SeasonalInsights__SummarySection",
148
+ componentId: "sc-jrd7ho-1"
149
+ })(["display:flex;flex-direction:column;gap:8px;padding:12px 14px;border-radius:10px;"]);
150
+ var SummaryHeader = _styledComponents.default.div.withConfig({
151
+ displayName: "SeasonalInsights__SummaryHeader",
152
+ componentId: "sc-jrd7ho-2"
153
+ })(["display:flex;align-items:center;justify-content:space-between;gap:12px;flex-direction:", ";"], function (_ref4) {
154
+ var isRtl = _ref4.isRtl;
155
+ return isRtl ? 'row-reverse' : 'row';
156
+ });
157
+ var SummaryTitle = _styledComponents.default.div.withConfig({
158
+ displayName: "SeasonalInsights__SummaryTitle",
159
+ componentId: "sc-jrd7ho-3"
160
+ })(["font-weight:600;font-size:16px;color:#1d1d1d;"]);
161
+ var SummaryText = _styledComponents.default.div.withConfig({
162
+ displayName: "SeasonalInsights__SummaryText",
163
+ componentId: "sc-jrd7ho-4"
164
+ })(["font-size:15px;color:#2b2b2b;line-height:1.5;"]);
165
+ var ToggleRow = _styledComponents.default.div.withConfig({
166
+ displayName: "SeasonalInsights__ToggleRow",
167
+ componentId: "sc-jrd7ho-5"
168
+ })(["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;}"]);
169
+ var PoweredBy = _styledComponents.default.span.withConfig({
170
+ displayName: "SeasonalInsights__PoweredBy",
171
+ componentId: "sc-jrd7ho-6"
172
+ })(["font-size:12px;color:#6b7280;white-space:nowrap;"]);
173
+ var BrandLogoSmall = _styledComponents.default.img.withConfig({
174
+ displayName: "SeasonalInsights__BrandLogoSmall",
175
+ componentId: "sc-jrd7ho-7"
176
+ })(["height:16px;width:auto;opacity:0.7;flex-shrink:0;"]);
177
+ var AttributionLink = _styledComponents.default.a.withConfig({
178
+ displayName: "SeasonalInsights__AttributionLink",
179
+ componentId: "sc-jrd7ho-8"
180
+ })(["display:inline-flex;align-items:center;gap:6px;order:1;text-decoration:none;color:inherit;&:hover ", "{opacity:1;}&:hover ", "{text-decoration:underline;}&:focus,&:focus-visible{outline:none;box-shadow:none;}"], BrandLogoSmall, PoweredBy);
181
+ var MoreInfoWrap = _styledComponents.default.div.withConfig({
182
+ displayName: "SeasonalInsights__MoreInfoWrap",
183
+ componentId: "sc-jrd7ho-9"
184
+ })(["order:2;"]);
185
+ var CardList = _styledComponents.default.div.withConfig({
186
+ displayName: "SeasonalInsights__CardList",
187
+ componentId: "sc-jrd7ho-10"
188
+ })(["display:flex;flex-direction:column;gap:12px;"]);
189
+ var Card = _styledComponents.default.div.withConfig({
190
+ displayName: "SeasonalInsights__Card",
191
+ componentId: "sc-jrd7ho-11"
192
+ })(["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;"]);
193
+ var CardHeader = _styledComponents.default.div.withConfig({
194
+ displayName: "SeasonalInsights__CardHeader",
195
+ componentId: "sc-jrd7ho-12"
196
+ })(["display:flex;align-items:center;gap:8px;justify-content:space-between;"]);
197
+ var TitleBlock = _styledComponents.default.div.withConfig({
198
+ displayName: "SeasonalInsights__TitleBlock",
199
+ componentId: "sc-jrd7ho-13"
200
+ })(["display:inline-flex;align-items:center;margin-inline-start:-14px;"]);
201
+ var CardTitle = _styledComponents.default.div.withConfig({
202
+ displayName: "SeasonalInsights__CardTitle",
203
+ componentId: "sc-jrd7ho-14"
204
+ })(["font-weight:600;font-size:15px;color:#1e1e1e;"]);
205
+ var CardSection = _styledComponents.default.div.withConfig({
206
+ displayName: "SeasonalInsights__CardSection",
207
+ componentId: "sc-jrd7ho-15"
208
+ })(["display:flex;flex-direction:column;gap:6px;"]);
209
+ var SectionLabel = _styledComponents.default.div.withConfig({
210
+ displayName: "SeasonalInsights__SectionLabel",
211
+ componentId: "sc-jrd7ho-16"
212
+ })(["font-size:14px;color:rgb(184,189,199);"]);
213
+ var SectionText = _styledComponents.default.div.withConfig({
214
+ displayName: "SeasonalInsights__SectionText",
215
+ componentId: "sc-jrd7ho-17"
216
+ })(["font-size:14px;color:#3d3d3d;line-height:1.45;"]);
217
+ var ChipRow = _styledComponents.default.div.withConfig({
218
+ displayName: "SeasonalInsights__ChipRow",
219
+ componentId: "sc-jrd7ho-18"
220
+ })(["display:flex;gap:8px;flex-wrap:wrap;"]);
221
+ var Chip = _styledComponents.default.span.withConfig({
222
+ displayName: "SeasonalInsights__Chip",
223
+ componentId: "sc-jrd7ho-19"
224
+ })(["background:#f1f3f5;color:#1f2933;border-radius:12px;padding:6px 10px;font-size:12px;font-weight:500;border:1px solid #e0e4ea;"]);
225
+ var formatSectorIconName = function formatSectorIconName(value) {
226
+ return (value || '').toString().trim().toLowerCase().replace(/[^a-z0-9]+/g, '_').replace(/^_+|_+$/g, '');
227
+ };
228
+ var _default = SeasonalInsights;
229
+ exports.default = _default;
230
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_i18next","_interopRequireDefault","require","_react","_interopRequireWildcard","_Sector","_MoreInfoButton","_streamiLogo","_useNavContext2","_reactRedux","_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","_useSelector","useSelector","state","global_data","waterAuthorityId","_useSelector2","summary","risk_summary","detailed","detailed_risks","hasDetails","length","_useNavContext","useNavContext","isRtl","streamiHref","concat","controller","AbortController","fetch","signal","then","_ref2","_asyncToGenerator2","_regenerator","mark","_callee","res","wrap","_callee$","_context","prev","next","ok","Error","status","json","abrupt","sent","stop","_x","apply","arguments","payload","catch","err","name","abort","createElement","Container","SummarySection","SummaryHeader","SummaryTitle","i18next","t","SummaryText","ToggleRow","AttributionLink","href","BrandLogoSmall","src","StreamiLogo","alt","PoweredBy","MoreInfoWrap","MoreInfoDiv","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","a","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';\nimport { appReducer } from 'src/store/rootReducer';\nimport { useSelector } from 'react-redux';\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 [waterAuthorityId] = useSelector(\n    (state: ReturnType<typeof appReducer>) => [\n      state.global_data.waterAuthorityId,\n    ],\n  );\n  const summary = risk?.risk_summary || '';\n  const detailed = risk?.detailed_risks || [];\n  const hasDetails = detailed.length > 0;\n  const { isRtl, locale } = useNavContext();\n  const streamiHref = `/assistant?locale=${locale}&water_authority_id=${waterAuthorityId}`;\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        <AttributionLink href={streamiHref}>\n          <BrandLogoSmall src={StreamiLogo} alt=\"STREAMi\" />\n          <PoweredBy>{'Powered by STREAMi'}</PoweredBy>\n        </AttributionLink>\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 BrandLogoSmall = styled.img`\n  height: 16px;\n  width: auto;\n  opacity: 0.7;\n  flex-shrink: 0;\n`;\n\nconst AttributionLink = styled.a`\n  display: inline-flex;\n  align-items: center;\n  gap: 6px;\n  order: 1;\n  text-decoration: none;\n  color: inherit;\n\n  &:hover ${BrandLogoSmall} {\n    opacity: 1;\n  }\n\n  &:hover ${PoweredBy} {\n    text-decoration: underline;\n  }\n\n  &:focus,\n  &:focus-visible {\n    outline: none;\n    box-shadow: none;\n  }\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-size: 14px;\n  color: rgb(184, 189, 199);\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":";;;;;;;;;;;;AAAA,IAAAA,QAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,MAAA,GAAAC,uBAAA,CAAAF,OAAA;AAEA,IAAAG,OAAA,GAAAJ,sBAAA,CAAAC,OAAA;AACA,IAAAI,eAAA,GAAAJ,OAAA;AAAkG,IAAAK,YAAA,GAAAN,sBAAA,CAAAC,OAAA;AAElG,IAAAM,eAAA,GAAAN,OAAA;AAEA,IAAAO,WAAA,GAAAP,OAAA;AAA0C,SAAAQ,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;AAyC1C,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;EAGpB,IAAAG,UAAA,GAAsC,IAAAJ,eAAQ,EAAU,KAAK,CAAC;IAAAK,UAAA,OAAAH,eAAA,CAAAzB,OAAA,EAAA2B,UAAA;IAAvDE,WAAW,GAAAD,UAAA;IAAEE,cAAc,GAAAF,UAAA;;EAElC;EACA,IAAAG,gBAAS,EAAC,YAAM;IACd,IAAI,OAAOb,QAAQ,KAAK,WAAW,EAAE;IACrCQ,OAAO,CAACR,QAAQ,aAARA,QAAQ,cAARA,QAAQ,GAAI,IAAI,CAAC;EAC3B,CAAC,EAAE,CAACA,QAAQ,CAAC,CAAC;EAEd,IAAMc,IAAI,GAAG,IAAAC,cAAO,EAAC,YAAM;IAAA,IAAAC,kBAAA;IACzB,IAAMC,KAAK,GAAGhB,IAAI,aAAJA,IAAI,wBAAAe,kBAAA,GAAJf,IAAI,CAAEiB,YAAY,cAAAF,kBAAA,uBAAlBA,kBAAA,CAAoBC,KAAK;IACvC,IAAI,CAACA,KAAK,EAAE,OAAO,IAAI;IACvB,IAAME,IAAI,GAAG,CAAAlB,IAAI,aAAJA,IAAI,uBAAJA,IAAI,CAAEmB,MAAM,KAAI,IAAI;IACjC,OAAOH,KAAK,CAACE,IAAI,CAAC,IAAI,IAAI;EAC5B,CAAC,EAAE,CAAClB,IAAI,CAAC,CAAC;EAEV,IAAAoB,YAAA,GAA2B,IAAAC,uBAAW,EACpC,UAACC,KAAoC;MAAA,OAAK,CACxCA,KAAK,CAACC,WAAW,CAACC,gBAAgB,CACnC;IAAA,CACH,CAAC;IAAAC,aAAA,OAAAnB,eAAA,CAAAzB,OAAA,EAAAuC,YAAA;IAJMI,gBAAgB,GAAAC,aAAA;EAKvB,IAAMC,OAAO,GAAG,CAAAb,IAAI,aAAJA,IAAI,uBAAJA,IAAI,CAAEc,YAAY,KAAI,EAAE;EACxC,IAAMC,QAAQ,GAAG,CAAAf,IAAI,aAAJA,IAAI,uBAAJA,IAAI,CAAEgB,cAAc,KAAI,EAAE;EAC3C,IAAMC,UAAU,GAAGF,QAAQ,CAACG,MAAM,GAAG,CAAC;EACtC,IAAAC,cAAA,GAA0B,IAAAC,6BAAa,EAAC,CAAC;IAAjCC,KAAK,GAAAF,cAAA,CAALE,KAAK;IAAEf,MAAM,GAAAa,cAAA,CAANb,MAAM;EACrB,IAAMgB,WAAW,wBAAAC,MAAA,CAAwBjB,MAAM,0BAAAiB,MAAA,CAAuBZ,gBAAgB,CAAE;EAExF,IAAAZ,gBAAS,EAAC,YAAM;IACd;IACA,IAAI,OAAOb,QAAQ,KAAK,WAAW,EAAE;IACrC,IAAI,CAACD,WAAW,EAAE;IAElB,IAAMuC,UAAU,GAAG,IAAIC,eAAe,CAAC,CAAC;IAExCC,KAAK,CAACzC,WAAW,EAAE;MAAE0C,MAAM,EAAEH,UAAU,CAACG;IAAO,CAAC,CAAC,CAC9CC,IAAI;MAAA,IAAAC,KAAA,OAAAC,kBAAA,CAAA9D,OAAA,gBAAA+D,YAAA,CAAA/D,OAAA,CAAAgE,IAAA,CAAC,SAAAC,QAAOC,GAAG;QAAA,OAAAH,YAAA,CAAA/D,OAAA,CAAAmE,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,oBAAAlB,MAAA,CAAoBW,GAAG,CAACQ,MAAM,MAAG,CAAC;cAAA;gBAAAL,QAAA,CAAAE,IAAA;gBAAA,OAErCL,GAAG,CAACS,IAAI,CAAC,CAAC;cAAA;gBAAA,OAAAN,QAAA,CAAAO,MAAA,WAAAP,QAAA,CAAAQ,IAAA;cAAA;cAAA;gBAAA,OAAAR,QAAA,CAAAS,IAAA;YAAA;UAAA;QAAA,GAAAb,OAAA;MAAA,CACzB;MAAA,iBAAAc,EAAA;QAAA,OAAAlB,KAAA,CAAAmB,KAAA,OAAAC,SAAA;MAAA;IAAA,IAAC,CACDrB,IAAI,CAAC,UAACsB,OAAO,EAAK;MACjBxD,OAAO,CAACwD,OAAO,CAAC;MAChB,IAAI7D,QAAQ,EAAEA,QAAQ,CAAC6D,OAAO,CAAC;IACjC,CAAC,CAAC,CACDC,KAAK,CAAC,UAACC,GAAG,EAAK;MACd,IAAI,CAAAA,GAAG,aAAHA,GAAG,uBAAHA,GAAG,CAAEC,IAAI,MAAK,YAAY,EAAE;MAChC3D,OAAO,CAAC,IAAI,CAAC;IACf,CAAC,CAAC;IAEJ,OAAO;MAAA,OAAM8B,UAAU,CAAC8B,KAAK,CAAC,CAAC;IAAA;EACjC,CAAC,EAAE,CAACrE,WAAW,EAAEC,QAAQ,EAAEG,QAAQ,CAAC,CAAC;EAErC,oBACEpC,MAAA,CAAAe,OAAA,CAAAuF,aAAA,CAACC,SAAS;IAACnC,KAAK,EAAEA;EAAM,gBACtBpE,MAAA,CAAAe,OAAA,CAAAuF,aAAA,CAACE,cAAc,qBACbxG,MAAA,CAAAe,OAAA,CAAAuF,aAAA,CAACG,aAAa;IAACrC,KAAK,EAAEA;EAAM,gBAC1BpE,MAAA,CAAAe,OAAA,CAAAuF,aAAA,CAACI,YAAY,QACVC,gBAAO,CAACC,CAAC,CAAC,mCAAmC,CAClC,CACD,CAAC,eAChB5G,MAAA,CAAAe,OAAA,CAAAuF,aAAA,CAACO,WAAW,QAAEjD,OAAqB,CACrB,CAAC,eACjB5D,MAAA,CAAAe,OAAA,CAAAuF,aAAA,CAACQ,SAAS,qBACR9G,MAAA,CAAAe,OAAA,CAAAuF,aAAA,CAACS,eAAe;IAACC,IAAI,EAAE3C;EAAY,gBACjCrE,MAAA,CAAAe,OAAA,CAAAuF,aAAA,CAACW,cAAc;IAACC,GAAG,EAAEC,oBAAY;IAACC,GAAG,EAAC;EAAS,CAAE,CAAC,eAClDpH,MAAA,CAAAe,OAAA,CAAAuF,aAAA,CAACe,SAAS,QAAE,oBAAgC,CAC7B,CAAC,EACjBrD,UAAU,gBACThE,MAAA,CAAAe,OAAA,CAAAuF,aAAA,CAACgB,YAAY,qBACXtH,MAAA,CAAAe,OAAA,CAAAuF,aAAA,CAACnG,eAAA,CAAAoH,WAAW,qBACVvH,MAAA,CAAAe,OAAA,CAAAuF,aAAA;IACEU,IAAI,EAAC,GAAG;IACR7E,SAAS,EAAC,kBAAkB;IAC5BqF,OAAO,EAAE,SAAAA,QAACC,CAAC,EAAK;MACdA,CAAC,CAACC,cAAc,CAAC,CAAC;MAClB7E,cAAc,CAAC,UAACwC,IAAI;QAAA,OAAK,CAACA,IAAI;MAAA,EAAC;IACjC,CAAE;IACF,iBAAezC;EAAY,GAE1BA,WAAW,GACR+D,gBAAO,CAACC,CAAC,CAAC,6BAA6B,CAAC,GACxCD,gBAAO,CAACC,CAAC,CAAC,6BAA6B,CAC1C,CACQ,CACD,CAAC,GACb,IACK,CAAC,EAEX5C,UAAU,gBACThE,MAAA,CAAAe,OAAA,CAAAuF,aAAA,CAAAtG,MAAA,CAAAe,OAAA,CAAA4G,QAAA,QACG/E,WAAW,gBACV5C,MAAA,CAAAe,OAAA,CAAAuF,aAAA,CAACsB,QAAQ,QACN9D,QAAQ,CAAC+D,GAAG,CAAC,UAACC,CAAC,EAAEC,GAAG;IAAA,IAAAC,qBAAA;IAAA,oBACnBhI,MAAA,CAAAe,OAAA,CAAAuF,aAAA,CAAC2B,IAAI;MAACzG,GAAG,EAAEuG;IAAI,gBACb/H,MAAA,CAAAe,OAAA,CAAAuF,aAAA,CAAC4B,UAAU,qBACTlI,MAAA,CAAAe,OAAA,CAAAuF,aAAA,CAAC6B,UAAU,QACRC,oBAAoB,CAACN,CAAC,CAACO,MAAM,CAAC,gBAC7BrI,MAAA,CAAAe,OAAA,CAAAuF,aAAA,CAACpG,OAAA,CAAAa,OAAM;MACLuH,cAAc,EACZF,oBAAoB,CAACN,CAAC,CAACO,MAAM,CAAC,IAAI,SACnC;MACDE,UAAU,EAAET,CAAC,CAACO,MAAO;MACrBG,SAAS,EAAE,KAAM;MACjBC,WAAW,EAAE;IAAK,CACnB,CAAC,GACA,IAAI,eACRzI,MAAA,CAAAe,OAAA,CAAAuF,aAAA,CAACoC,SAAS,QAAEZ,CAAC,CAACa,QAAoB,CACxB,CACF,CAAC,EAEZ,EAAAX,qBAAA,GAAAF,CAAC,CAACc,wBAAwB,cAAAZ,qBAAA,uBAA1BA,qBAAA,CAA4B/D,MAAM,iBACjCjE,MAAA,CAAAe,OAAA,CAAAuF,aAAA,CAACuC,WAAW,qBACV7I,MAAA,CAAAe,OAAA,CAAAuF,aAAA,CAACwC,YAAY,QACVnC,gBAAO,CAACC,CAAC,CAAC,6BAA6B,CAC5B,CAAC,eACf5G,MAAA,CAAAe,OAAA,CAAAuF,aAAA,CAACyC,OAAO,QACLjB,CAAC,CAACc,wBAAwB,CAACf,GAAG,CAAC,UAACmB,CAAC,EAAEC,OAAO;MAAA,oBACzCjJ,MAAA,CAAAe,OAAA,CAAAuF,aAAA,CAAC4C,IAAI;QAAC1H,GAAG,KAAA8C,MAAA,CAAK0E,CAAC,OAAA1E,MAAA,CAAI2E,OAAO;MAAG,GAAED,CAAQ,CAAC;IAAA,CACzC,CACM,CACE,CAAC,GACZ,IAAI,EAEPlB,CAAC,CAACqB,4BAA4B,gBAC7BnJ,MAAA,CAAAe,OAAA,CAAAuF,aAAA,CAACuC,WAAW,qBACV7I,MAAA,CAAAe,OAAA,CAAAuF,aAAA,CAACwC,YAAY,QACVnC,gBAAO,CAACC,CAAC,CAAC,oCAAoC,CACnC,CAAC,eACf5G,MAAA,CAAAe,OAAA,CAAAuF,aAAA,CAAC8C,WAAW,QACTtB,CAAC,CAACqB,4BACQ,CACF,CAAC,GACZ,IACA,CAAC;EAAA,CACR,CACO,CAAC,GACT,IACJ,CAAC,GACD,IACK,CAAC;AAEhB,CAAC;AAED,IAAM5C,SAAS,GAAG8C,yBAAM,CAACC,GAAG,CAAAC,UAAA;EAAAC,WAAA;EAAAC,WAAA;AAAA,iIAMZ,UAAAC,KAAA;EAAA,IAAGtF,KAAK,GAAAsF,KAAA,CAALtF,KAAK;EAAA,OAAQA,KAAK,GAAG,OAAO,GAAG,MAAM;AAAA,CAAC,CAIxD;AAED,IAAMoC,cAAc,GAAG6C,yBAAM,CAACC,GAAG,CAAAC,UAAA;EAAAC,WAAA;EAAAC,WAAA;AAAA,wFAQhC;AAED,IAAMhD,aAAa,GAAG4C,yBAAM,CAACC,GAAG,CAAAC,UAAA;EAAAC,WAAA;EAAAC,WAAA;AAAA,oGAKZ,UAAAE,KAAA;EAAA,IAAGvF,KAAK,GAAAuF,KAAA,CAALvF,KAAK;EAAA,OAAQA,KAAK,GAAG,aAAa,GAAG,KAAK;AAAA,CAAC,CACjE;AAED,IAAMsC,YAAY,GAAG2C,yBAAM,CAACC,GAAG,CAAAC,UAAA;EAAAC,WAAA;EAAAC,WAAA;AAAA,qDAI9B;AAED,IAAM5C,WAAW,GAAGwC,yBAAM,CAACC,GAAG,CAAAC,UAAA;EAAAC,WAAA;EAAAC,WAAA;AAAA,qDAI7B;AAED,IAAM3C,SAAS,GAAGuC,yBAAM,CAACC,GAAG,CAAAC,UAAA;EAAAC,WAAA;EAAAC,WAAA;AAAA,uMAa3B;AAED,IAAMpC,SAAS,GAAGgC,yBAAM,CAACO,IAAI,CAAAL,UAAA;EAAAC,WAAA;EAAAC,WAAA;AAAA,wDAI5B;AAED,IAAMxC,cAAc,GAAGoC,yBAAM,CAACQ,GAAG,CAAAN,UAAA;EAAAC,WAAA;EAAAC,WAAA;AAAA,yDAKhC;AAED,IAAM1C,eAAe,GAAGsC,yBAAM,CAACS,CAAC,CAAAP,UAAA;EAAAC,WAAA;EAAAC,WAAA;AAAA,yNAQpBxC,cAAc,EAIdI,SAAS,CASpB;AAED,IAAMC,YAAY,GAAG+B,yBAAM,CAACC,GAAG,CAAAC,UAAA;EAAAC,WAAA;EAAAC,WAAA;AAAA,gBAE9B;AAED,IAAM7B,QAAQ,GAAGyB,yBAAM,CAACC,GAAG,CAAAC,UAAA;EAAAC,WAAA;EAAAC,WAAA;AAAA,oDAI1B;AAED,IAAMxB,IAAI,GAAGoB,yBAAM,CAACC,GAAG,CAAAC,UAAA;EAAAC,WAAA;EAAAC,WAAA;AAAA,sKAStB;AAED,IAAMvB,UAAU,GAAGmB,yBAAM,CAACC,GAAG,CAAAC,UAAA;EAAAC,WAAA;EAAAC,WAAA;AAAA,8EAK5B;AAED,IAAMtB,UAAU,GAAGkB,yBAAM,CAACC,GAAG,CAAAC,UAAA;EAAAC,WAAA;EAAAC,WAAA;AAAA,yEAK5B;AAED,IAAMf,SAAS,GAAGW,yBAAM,CAACC,GAAG,CAAAC,UAAA;EAAAC,WAAA;EAAAC,WAAA;AAAA,qDAI3B;AAED,IAAMZ,WAAW,GAAGQ,yBAAM,CAACC,GAAG,CAAAC,UAAA;EAAAC,WAAA;EAAAC,WAAA;AAAA,mDAI7B;AAED,IAAMX,YAAY,GAAGO,yBAAM,CAACC,GAAG,CAAAC,UAAA;EAAAC,WAAA;EAAAC,WAAA;AAAA,8CAG9B;AAED,IAAML,WAAW,GAAGC,yBAAM,CAACC,GAAG,CAAAC,UAAA;EAAAC,WAAA;EAAAC,WAAA;AAAA,sDAI7B;AAED,IAAMV,OAAO,GAAGM,yBAAM,CAACC,GAAG,CAAAC,UAAA;EAAAC,WAAA;EAAAC,WAAA;AAAA,4CAIzB;AAED,IAAMP,IAAI,GAAGG,yBAAM,CAACO,IAAI,CAAAL,UAAA;EAAAC,WAAA;EAAAC,WAAA;AAAA,qIAQvB;AAED,IAAMrB,oBAAoB,GAAG,SAAvBA,oBAAoBA,CAAI2B,KAAc;EAAA,OAC1C,CAACA,KAAK,IAAI,EAAE,EACTC,QAAQ,CAAC,CAAC,CACVC,IAAI,CAAC,CAAC,CACNC,WAAW,CAAC,CAAC,CACbC,OAAO,CAAC,aAAa,EAAE,GAAG,CAAC,CAC3BA,OAAO,CAAC,UAAU,EAAE,EAAE,CAAC;AAAA;AAAC,IAAAC,QAAA,GAEdtI,gBAAgB;AAAAuI,OAAA,CAAAtJ,OAAA,GAAAqJ,QAAA"}
@@ -18,6 +18,7 @@ var _AlertIcon = require("@svgr/webpack?&svgo=false&ref!./AlertIcon.svg");
18
18
  var _EventUtils = require("pages/EventsPage/events/events_list/EventUtils");
19
19
  var _useUserTimeZone = require("hooks/useUserTimeZone");
20
20
  var _SiteName = _interopRequireDefault(require("../../ui-kit/siteName/SiteName"));
21
+ var _UpstreamBadge = _interopRequireDefault(require("./UpstreamBadge"));
21
22
  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
23
  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
24
  var SevereEvent = function SevereEvent(_ref) {
@@ -71,7 +72,22 @@ var SevereEvent = function SevereEvent(_ref) {
71
72
  className: "top"
72
73
  }, eventSource(event), event.discharging && /*#__PURE__*/_react.default.createElement("div", {
73
74
  className: "discharging"
74
- }, _i18n.default.t('events_overview.discharging'))), /*#__PURE__*/_react.default.createElement("div", {
75
+ }, _i18n.default.t('events_overview.discharging')), event.observations.length > 1 && /*#__PURE__*/_react.default.createElement("div", {
76
+ className: "upstream-badge"
77
+ }, /*#__PURE__*/_react.default.createElement(_InfoTooltip.InfoTooltip, {
78
+ key: "upstream-".concat(event.id),
79
+ data: _i18n.default.t('event_info.upstream_observations', {
80
+ count: event.observations.length
81
+ }),
82
+ title: '',
83
+ alignToBottom: false,
84
+ alternateIcon: /*#__PURE__*/_react.default.createElement(_UpstreamBadge.default, {
85
+ count: event.observations.length,
86
+ className: "upstream-badge"
87
+ }),
88
+ padding: false,
89
+ reversed: true
90
+ }, /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null)))), /*#__PURE__*/_react.default.createElement("div", {
75
91
  className: "content"
76
92
  }, /*#__PURE__*/_react.default.createElement("div", {
77
93
  className: "seen"
@@ -155,4 +171,4 @@ var SevereEvent = function SevereEvent(_ref) {
155
171
  };
156
172
  exports.SevereEvent = SevereEvent;
157
173
  var severities = ['low', 'high', 'extreme'];
158
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_lodash","_i18n","_interopRequireDefault","_TimeFormat","_info","_Eta","_InfoTooltip","_AlertIcon","_EventUtils","_useUserTimeZone","_SiteName","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","SevereEvent","_ref","etaWWTP","_ref$msg","msg","event","handleClick","onMouseEnterEvent","onMouseLeaveEvent","exceptionAlert","validateEvent","_useMemo","useMemo","parseEventData","firstseen","lastseen","dischargeTime","calculateTimeDuration","start_time","end_time","last_seen_time","itemContainer","useRef","eventSource","source_type","sources","polluter","_first","createElement","className","i18n","t","first","point_name","useEffect","undefined","ref","onClick","onMouseEnter","onMouseLeave","concat","severities","Number","severity","id","discharging","site","timestamp","toString","time_zone","date","time","href","interestPoints","event_ids","includes","messages","map","event_id","InfoTooltip","data","message","title","alignToBottom","alternateIcon","ReactComponent","reversed","padding","Fragment","width","height","exports"],"sources":["../../../src/components/SevereEvent/SevereEvent.tsx"],"sourcesContent":["import React, { useEffect, useMemo, useRef } from 'react';\nimport { first } from 'lodash';\nimport i18n from '../../utilities/i18n';\nimport TimeFormat from 'src/utilities/TimeFormat';\nimport { ReactComponent as Info } from './assets/info.svg';\nimport Eta from './Eta/Eta';\nimport './SevereEvent.scss';\nimport { etaWWTP } from 'src/pages/UtilityDashboardPage/MostSevereEvents/models';\nimport { IEvent } from 'src/store/events/models/IEvent';\nimport { InfoTooltip } from 'src/ui-kit/InfoTooltip/InfoTooltip';\nimport { ReactComponent as AlertIcon } from './AlertIcon.svg';\nimport { parseEventData } from 'src/pages/EventsPage/events/events_list/EventUtils';\nimport { calculateTimeDuration } from 'src/hooks/useUserTimeZone';\nimport SiteName from '../../ui-kit/siteName/SiteName';\n\nexport interface SevereEventProps {\n  etaWWTP?: etaWWTP;\n  msg?: string;\n  event: IEvent;\n  onMouseEnterEvent?: (event: any) => void;\n  onMouseLeaveEvent?: () => void;\n  handleClick?: (arg2: any, arg1: any) => void;\n  valuesFromKQL?: string;\n  exceptionAlert?: {\n    messages: { message: any; event_id: number }[];\n    event_ids: number[];\n  };\n  validateEvent?: (event: IEvent) => void;\n}\n\nexport const SevereEvent: React.FC<SevereEventProps> = ({\n  etaWWTP,\n  msg = '',\n  event,\n  handleClick,\n  onMouseEnterEvent,\n  onMouseLeaveEvent,\n  exceptionAlert,\n  validateEvent,\n}) => {\n  const { firstseen, lastseen } = useMemo(() => parseEventData(event), [event]);\n  const dischargeTime = calculateTimeDuration({\n    start_time: firstseen.start_time,\n    end_time: firstseen.last_seen_time,\n  });\n  const itemContainer = useRef<any>(null);\n\n  /* Show name in the title for factories only */\n  const eventSource = (event: IEvent) => {\n    if (event.source_type === 'factory' && event.sources[0].polluter) {\n      return (\n        <div className=\"source\">\n          {i18n.t('dashboard_v2.utility_dashboard.most-severe-events.source')}\n          :&nbsp;\n          {first(event.sources)?.point_name || 'No Name'}\n        </div>\n      );\n    }\n\n    return null;\n  };\n\n  useEffect(() => {\n    validateEvent !== undefined && validateEvent(event);\n  }, []);\n\n  return (\n    <div\n      ref={itemContainer}\n      onClick={() => handleClick && handleClick(event, itemContainer)}\n      onMouseEnter={() => onMouseEnterEvent && onMouseEnterEvent(event)}\n      onMouseLeave={() => onMouseLeaveEvent && onMouseLeaveEvent()}\n      className={`severe-event ${severities[Number(event.severity)]}`}\n      data-event-id={event.id}\n    >\n      <div className=\"top\">\n        {eventSource(event)}\n\n        {event.discharging && (\n          <div className=\"discharging\">\n            {i18n.t('events_overview.discharging')}\n          </div>\n        )}\n      </div>\n      <div className=\"content\">\n        <div className=\"seen\">\n          <div className=\"details\">\n            <div className=\"first\">\n              <div className=\"type-title\">\n                {i18n.t(\n                  'dashboard_v2.utility_dashboard.most-severe-events.first-seen',\n                )}\n                :\n              </div>\n              <span className=\"mobile\">\n                <div className=\"addr\">\n                  <SiteName site={firstseen.point_name} />\n                </div>\n                <div className=\"date\">\n                  <TimeFormat\n                    timestamp={firstseen.start_time.toString()}\n                    time_zone={firstseen.time_zone.toString()}\n                  />\n                </div>\n              </span>\n            </div>\n            <div className=\"last\">\n              <div className=\"type-title\">\n                {' '}\n                {i18n.t(\n                  'dashboard_v2.utility_dashboard.most-severe-events.last-seen',\n                )}\n                :\n              </div>\n              <span className=\"mobile\">\n                <div className=\"addr\">\n                  <SiteName site={lastseen.point_name} />\n                </div>\n                <div className=\"date\">\n                  <TimeFormat\n                    timestamp={lastseen.last_seen_time.toString()}\n                    time_zone={lastseen.time_zone.toString()}\n                  />\n                </div>\n              </span>\n            </div>\n          </div>\n          <div className={'lower_details'}>\n            <div className=\"total-time\">\n              <div className=\"type-title\">\n                {i18n.t('events_overview.discharge_time')}\n                {/*Total time*/}:\n              </div>\n              <div className=\"time\">{dischargeTime}</div>\n            </div>\n          </div>\n        </div>\n        {etaWWTP && (\n          <div className=\"eta-wwtp\">\n            <div className=\"type-title\">\n              {i18n.t(\n                'dashboard_v2.utility_dashboard.most-severe-events.eta-wwtp',\n              )}\n              :\n            </div>\n            <div className=\"info\">\n              <div className=\"date \">\n                {etaWWTP.date}\n                <span className=\"time\"> ({etaWWTP.time})</span>\n              </div>\n              <a href=\"#\" className=\"more \">\n                {etaWWTP.interestPoints\n                  ? `${etaWWTP.interestPoints} ${i18n.t(\n                      'dashboard_v2.utility_dashboard.most-severe-events.more-interset',\n                    )}`\n                  : ''}\n              </a>\n            </div>\n          </div>\n        )}\n        <div className=\"alert-icon\">\n          {exceptionAlert !== undefined &&\n            exceptionAlert.event_ids.includes(event.id) &&\n            exceptionAlert.messages.map((msg) => {\n              if (msg.event_id === event.id) {\n                return (\n                  <InfoTooltip\n                    key={`alert-${msg.event_id}`}\n                    data={msg.message}\n                    title={''}\n                    alignToBottom={false}\n                    alternateIcon={<AlertIcon />}\n                    reversed={true}\n                    padding={false}\n                  >\n                    <></>\n                  </InfoTooltip>\n                );\n              } else {\n                return null;\n              }\n            })}\n        </div>\n        <Eta event={event} />\n\n        <div className={`msg${msg ? ' on' : ''}`}>\n          <Info width=\"13px\" height=\"12px\" />\n          {msg}\n        </div>\n      </div>\n    </div>\n  );\n};\n\nconst severities = ['low', 'high', 'extreme'];\n"],"mappings":"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"}
174
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_lodash","_i18n","_interopRequireDefault","_TimeFormat","_info","_Eta","_InfoTooltip","_AlertIcon","_EventUtils","_useUserTimeZone","_SiteName","_UpstreamBadge","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","SevereEvent","_ref","etaWWTP","_ref$msg","msg","event","handleClick","onMouseEnterEvent","onMouseLeaveEvent","exceptionAlert","validateEvent","_useMemo","useMemo","parseEventData","firstseen","lastseen","dischargeTime","calculateTimeDuration","start_time","end_time","last_seen_time","itemContainer","useRef","eventSource","source_type","sources","polluter","_first","createElement","className","i18n","t","first","point_name","useEffect","undefined","ref","onClick","onMouseEnter","onMouseLeave","concat","severities","Number","severity","id","discharging","observations","length","InfoTooltip","data","I18n","count","title","alignToBottom","alternateIcon","padding","reversed","Fragment","site","timestamp","toString","time_zone","date","time","href","interestPoints","event_ids","includes","messages","map","event_id","message","ReactComponent","width","height","exports"],"sources":["../../../src/components/SevereEvent/SevereEvent.tsx"],"sourcesContent":["import React, { useEffect, useMemo, useRef } from 'react';\nimport { first } from 'lodash';\nimport i18n from '../../utilities/i18n';\nimport TimeFormat from 'src/utilities/TimeFormat';\nimport { ReactComponent as Info } from './assets/info.svg';\nimport Eta from './Eta/Eta';\nimport './SevereEvent.scss';\nimport { etaWWTP } from 'src/pages/UtilityDashboardPage/MostSevereEvents/models';\nimport { IEvent } from 'src/store/events/models/IEvent';\nimport { InfoTooltip } from 'src/ui-kit/InfoTooltip/InfoTooltip';\nimport { ReactComponent as AlertIcon } from './AlertIcon.svg';\nimport { parseEventData } from 'src/pages/EventsPage/events/events_list/EventUtils';\nimport { calculateTimeDuration } from 'src/hooks/useUserTimeZone';\nimport SiteName from '../../ui-kit/siteName/SiteName';\nimport UpstreamBadge from './UpstreamBadge';\nimport I18n from '../../utilities/i18n';\n\nexport interface SevereEventProps {\n  etaWWTP?: etaWWTP;\n  msg?: string;\n  event: IEvent;\n  onMouseEnterEvent?: (event: any) => void;\n  onMouseLeaveEvent?: () => void;\n  handleClick?: (arg2: any, arg1: any) => void;\n  valuesFromKQL?: string;\n  exceptionAlert?: {\n    messages: { message: any; event_id: number }[];\n    event_ids: number[];\n  };\n  validateEvent?: (event: IEvent) => void;\n}\n\nexport const SevereEvent: React.FC<SevereEventProps> = ({\n  etaWWTP,\n  msg = '',\n  event,\n  handleClick,\n  onMouseEnterEvent,\n  onMouseLeaveEvent,\n  exceptionAlert,\n  validateEvent,\n}) => {\n  const { firstseen, lastseen } = useMemo(() => parseEventData(event), [event]);\n  const dischargeTime = calculateTimeDuration({\n    start_time: firstseen.start_time,\n    end_time: firstseen.last_seen_time,\n  });\n  const itemContainer = useRef<any>(null);\n\n  /* Show name in the title for factories only */\n  const eventSource = (event: IEvent) => {\n    if (event.source_type === 'factory' && event.sources[0].polluter) {\n      return (\n        <div className=\"source\">\n          {i18n.t('dashboard_v2.utility_dashboard.most-severe-events.source')}\n          :&nbsp;\n          {first(event.sources)?.point_name || 'No Name'}\n        </div>\n      );\n    }\n\n    return null;\n  };\n\n  useEffect(() => {\n    validateEvent !== undefined && validateEvent(event);\n  }, []);\n\n  return (\n    <div\n      ref={itemContainer}\n      onClick={() => handleClick && handleClick(event, itemContainer)}\n      onMouseEnter={() => onMouseEnterEvent && onMouseEnterEvent(event)}\n      onMouseLeave={() => onMouseLeaveEvent && onMouseLeaveEvent()}\n      className={`severe-event ${severities[Number(event.severity)]}`}\n      data-event-id={event.id}\n    >\n      <div className=\"top\">\n        {eventSource(event)}\n\n        {event.discharging && (\n          <div className=\"discharging\">\n            {i18n.t('events_overview.discharging')}\n          </div>\n        )}\n        {event.observations.length > 1 && (\n          <div className=\"upstream-badge\">\n            <InfoTooltip\n              key={`upstream-${event.id}`}\n              data={I18n.t('event_info.upstream_observations', {\n                count: event.observations.length,\n              })}\n              title={''}\n              alignToBottom={false}\n              alternateIcon={\n                <UpstreamBadge\n                  count={event.observations.length}\n                  className=\"upstream-badge\"\n                />\n              }\n              padding={false}\n              reversed={true}\n            >\n              <></>\n            </InfoTooltip>\n          </div>\n        )}\n      </div>\n      <div className=\"content\">\n        <div className=\"seen\">\n          <div className=\"details\">\n            <div className=\"first\">\n              <div className=\"type-title\">\n                {i18n.t(\n                  'dashboard_v2.utility_dashboard.most-severe-events.first-seen',\n                )}\n                :\n              </div>\n              <span className=\"mobile\">\n                <div className=\"addr\">\n                  <SiteName site={firstseen.point_name} />\n                </div>\n                <div className=\"date\">\n                  <TimeFormat\n                    timestamp={firstseen.start_time.toString()}\n                    time_zone={firstseen.time_zone.toString()}\n                  />\n                </div>\n              </span>\n            </div>\n            <div className=\"last\">\n              <div className=\"type-title\">\n                {' '}\n                {i18n.t(\n                  'dashboard_v2.utility_dashboard.most-severe-events.last-seen',\n                )}\n                :\n              </div>\n              <span className=\"mobile\">\n                <div className=\"addr\">\n                  <SiteName site={lastseen.point_name} />\n                </div>\n                <div className=\"date\">\n                  <TimeFormat\n                    timestamp={lastseen.last_seen_time.toString()}\n                    time_zone={lastseen.time_zone.toString()}\n                  />\n                </div>\n              </span>\n            </div>\n          </div>\n          <div className={'lower_details'}>\n            <div className=\"total-time\">\n              <div className=\"type-title\">\n                {i18n.t('events_overview.discharge_time')}\n                {/*Total time*/}:\n              </div>\n              <div className=\"time\">{dischargeTime}</div>\n            </div>\n          </div>\n        </div>\n        {etaWWTP && (\n          <div className=\"eta-wwtp\">\n            <div className=\"type-title\">\n              {i18n.t(\n                'dashboard_v2.utility_dashboard.most-severe-events.eta-wwtp',\n              )}\n              :\n            </div>\n            <div className=\"info\">\n              <div className=\"date \">\n                {etaWWTP.date}\n                <span className=\"time\"> ({etaWWTP.time})</span>\n              </div>\n              <a href=\"#\" className=\"more \">\n                {etaWWTP.interestPoints\n                  ? `${etaWWTP.interestPoints} ${i18n.t(\n                      'dashboard_v2.utility_dashboard.most-severe-events.more-interset',\n                    )}`\n                  : ''}\n              </a>\n            </div>\n          </div>\n        )}\n        <div className=\"alert-icon\">\n          {exceptionAlert !== undefined &&\n            exceptionAlert.event_ids.includes(event.id) &&\n            exceptionAlert.messages.map((msg) => {\n              if (msg.event_id === event.id) {\n                return (\n                  <InfoTooltip\n                    key={`alert-${msg.event_id}`}\n                    data={msg.message}\n                    title={''}\n                    alignToBottom={false}\n                    alternateIcon={<AlertIcon />}\n                    reversed={true}\n                    padding={false}\n                  >\n                    <></>\n                  </InfoTooltip>\n                );\n              } else {\n                return null;\n              }\n            })}\n        </div>\n        <Eta event={event} />\n\n        <div className={`msg${msg ? ' on' : ''}`}>\n          <Info width=\"13px\" height=\"12px\" />\n          {msg}\n        </div>\n      </div>\n    </div>\n  );\n};\n\nconst severities = ['low', 'high', 'extreme'];\n"],"mappings":"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"}
@@ -62,6 +62,30 @@
62
62
  align-items: center;
63
63
  justify-content: space-between;
64
64
 
65
+ > :first-child {
66
+ &.upstream-badge {
67
+ width: 100%;
68
+ display: flex;
69
+ justify-content: flex-end;
70
+ }
71
+ }
72
+ .upstream-badge {
73
+ color: var(--theme-color);
74
+
75
+ svg {
76
+ opacity: 1;
77
+ fill: var(--theme-color);
78
+ }
79
+ .info-tooltip::after {
80
+ inset-inline-end: 10px;
81
+ margin-top: 5px;
82
+ }
83
+ .tooltip-content {
84
+ inset-inline-end: 50px;
85
+ margin-block-start: -15px;
86
+ }
87
+ }
88
+
65
89
  > .source {
66
90
  font-size: 14px;
67
91
  color: #fff;
@@ -0,0 +1,60 @@
1
+ "use strict";
2
+
3
+ var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
4
+ Object.defineProperty(exports, "__esModule", {
5
+ value: true
6
+ });
7
+ exports.default = exports.UpstreamBadge = void 0;
8
+ var _react = _interopRequireDefault(require("react"));
9
+ var UpstreamBadge = function UpstreamBadge(_ref) {
10
+ var count = _ref.count,
11
+ _ref$color = _ref.color,
12
+ color = _ref$color === void 0 ? '#E11D48' : _ref$color,
13
+ _ref$size = _ref.size,
14
+ size = _ref$size === void 0 ? 35 : _ref$size,
15
+ _ref$className = _ref.className,
16
+ className = _ref$className === void 0 ? 'UpstreamBadge' : _ref$className;
17
+ var innerSize = size * 0.82;
18
+ return /*#__PURE__*/_react.default.createElement("div", {
19
+ className: className,
20
+ style: {
21
+ width: size,
22
+ height: size,
23
+ borderRadius: '50%',
24
+ backgroundColor: '#FFFFFF',
25
+ boxShadow: '0 4px 10px rgba(0,0,0,0.15)',
26
+ display: 'flex',
27
+ alignItems: 'center',
28
+ justifyContent: 'center'
29
+ }
30
+ }, /*#__PURE__*/_react.default.createElement("div", {
31
+ style: {
32
+ width: innerSize,
33
+ height: innerSize,
34
+ borderRadius: '50%',
35
+ backgroundColor: '#F8F8F8',
36
+ display: 'flex',
37
+ flexDirection: 'column',
38
+ alignItems: 'center',
39
+ justifyContent: 'center',
40
+ fontWeight: 700,
41
+ lineHeight: 1
42
+ }
43
+ }, /*#__PURE__*/_react.default.createElement("svg", {
44
+ width: innerSize * 0.45,
45
+ height: innerSize * 0.5,
46
+ viewBox: "0 0 24 24",
47
+ fill: color
48
+ }, /*#__PURE__*/_react.default.createElement("path", {
49
+ d: "M12 2l7 8h-4v12h-6V10H5l7-8z"
50
+ })), /*#__PURE__*/_react.default.createElement("div", {
51
+ style: {
52
+ marginTop: 2,
53
+ fontSize: innerSize * 0.45
54
+ }
55
+ }, count)));
56
+ };
57
+ exports.UpstreamBadge = UpstreamBadge;
58
+ var _default = UpstreamBadge;
59
+ exports.default = _default;
60
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVEZWZhdWx0IiwicmVxdWlyZSIsIlVwc3RyZWFtQmFkZ2UiLCJfcmVmIiwiY291bnQiLCJfcmVmJGNvbG9yIiwiY29sb3IiLCJfcmVmJHNpemUiLCJzaXplIiwiX3JlZiRjbGFzc05hbWUiLCJjbGFzc05hbWUiLCJpbm5lclNpemUiLCJkZWZhdWx0IiwiY3JlYXRlRWxlbWVudCIsInN0eWxlIiwid2lkdGgiLCJoZWlnaHQiLCJib3JkZXJSYWRpdXMiLCJiYWNrZ3JvdW5kQ29sb3IiLCJib3hTaGFkb3ciLCJkaXNwbGF5IiwiYWxpZ25JdGVtcyIsImp1c3RpZnlDb250ZW50IiwiZmxleERpcmVjdGlvbiIsImZvbnRXZWlnaHQiLCJsaW5lSGVpZ2h0Iiwidmlld0JveCIsImZpbGwiLCJkIiwibWFyZ2luVG9wIiwiZm9udFNpemUiLCJleHBvcnRzIiwiX2RlZmF1bHQiXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvY29tcG9uZW50cy9TZXZlcmVFdmVudC9VcHN0cmVhbUJhZGdlLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xuXG50eXBlIFVwc3RyZWFtQmFkZ2VQcm9wcyA9IHtcbiAgY291bnQ6IG51bWJlcjtcbiAgY2xhc3NOYW1lPzogc3RyaW5nO1xuICBjb2xvcj86IHN0cmluZzsgLy8gbWFpbiBjb2xvciAoYXJyb3cgKyBudW1iZXIpXG4gIHNpemU/OiBudW1iZXI7IC8vIGRpYW1ldGVyIGluIHB4XG59O1xuXG5leHBvcnQgY29uc3QgVXBzdHJlYW1CYWRnZTogUmVhY3QuRkM8VXBzdHJlYW1CYWRnZVByb3BzPiA9ICh7XG4gIGNvdW50LFxuICBjb2xvciA9ICcjRTExRDQ4JywgLy8gZGVmYXVsdCByZWRcbiAgc2l6ZSA9IDM1LFxuICBjbGFzc05hbWUgPSAnVXBzdHJlYW1CYWRnZScsXG59KSA9PiB7XG4gIGNvbnN0IGlubmVyU2l6ZSA9IHNpemUgKiAwLjgyO1xuXG4gIHJldHVybiAoXG4gICAgPGRpdlxuICAgICAgY2xhc3NOYW1lPXtjbGFzc05hbWV9XG4gICAgICBzdHlsZT17e1xuICAgICAgICB3aWR0aDogc2l6ZSxcbiAgICAgICAgaGVpZ2h0OiBzaXplLFxuICAgICAgICBib3JkZXJSYWRpdXM6ICc1MCUnLFxuICAgICAgICBiYWNrZ3JvdW5kQ29sb3I6ICcjRkZGRkZGJyxcbiAgICAgICAgYm94U2hhZG93OiAnMCA0cHggMTBweCByZ2JhKDAsMCwwLDAuMTUpJyxcbiAgICAgICAgZGlzcGxheTogJ2ZsZXgnLFxuICAgICAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICAgICAganVzdGlmeUNvbnRlbnQ6ICdjZW50ZXInLFxuICAgICAgfX1cbiAgICA+XG4gICAgICA8ZGl2XG4gICAgICAgIHN0eWxlPXt7XG4gICAgICAgICAgd2lkdGg6IGlubmVyU2l6ZSxcbiAgICAgICAgICBoZWlnaHQ6IGlubmVyU2l6ZSxcbiAgICAgICAgICBib3JkZXJSYWRpdXM6ICc1MCUnLFxuICAgICAgICAgIGJhY2tncm91bmRDb2xvcjogJyNGOEY4RjgnLFxuICAgICAgICAgIGRpc3BsYXk6ICdmbGV4JyxcbiAgICAgICAgICBmbGV4RGlyZWN0aW9uOiAnY29sdW1uJyxcbiAgICAgICAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICAgICAgICBqdXN0aWZ5Q29udGVudDogJ2NlbnRlcicsXG4gICAgICAgICAgZm9udFdlaWdodDogNzAwLFxuICAgICAgICAgIGxpbmVIZWlnaHQ6IDEsXG4gICAgICAgIH19XG4gICAgICA+XG4gICAgICAgIHsvKiBBcnJvdyAqL31cbiAgICAgICAgPHN2Z1xuICAgICAgICAgIHdpZHRoPXtpbm5lclNpemUgKiAwLjQ1fVxuICAgICAgICAgIGhlaWdodD17aW5uZXJTaXplICogMC41fVxuICAgICAgICAgIHZpZXdCb3g9XCIwIDAgMjQgMjRcIlxuICAgICAgICAgIGZpbGw9e2NvbG9yfVxuICAgICAgICA+XG4gICAgICAgICAgPHBhdGggZD1cIk0xMiAybDcgOGgtNHYxMmgtNlYxMEg1bDctOHpcIiAvPlxuICAgICAgICA8L3N2Zz5cblxuICAgICAgICB7LyogQ291bnQgKi99XG4gICAgICAgIDxkaXZcbiAgICAgICAgICBzdHlsZT17e1xuICAgICAgICAgICAgbWFyZ2luVG9wOiAyLFxuICAgICAgICAgICAgZm9udFNpemU6IGlubmVyU2l6ZSAqIDAuNDUsXG4gICAgICAgICAgfX1cbiAgICAgICAgPlxuICAgICAgICAgIHtjb3VudH1cbiAgICAgICAgPC9kaXY+XG4gICAgICA8L2Rpdj5cbiAgICA8L2Rpdj5cbiAgKTtcbn07XG5leHBvcnQgZGVmYXVsdCBVcHN0cmVhbUJhZGdlO1xuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQUEsSUFBQUEsTUFBQSxHQUFBQyxzQkFBQSxDQUFBQyxPQUFBO0FBU08sSUFBTUMsYUFBMkMsR0FBRyxTQUE5Q0EsYUFBMkNBLENBQUFDLElBQUEsRUFLbEQ7RUFBQSxJQUpKQyxLQUFLLEdBQUFELElBQUEsQ0FBTEMsS0FBSztJQUFBQyxVQUFBLEdBQUFGLElBQUEsQ0FDTEcsS0FBSztJQUFMQSxLQUFLLEdBQUFELFVBQUEsY0FBRyxTQUFTLEdBQUFBLFVBQUE7SUFBQUUsU0FBQSxHQUFBSixJQUFBLENBQ2pCSyxJQUFJO0lBQUpBLElBQUksR0FBQUQsU0FBQSxjQUFHLEVBQUUsR0FBQUEsU0FBQTtJQUFBRSxjQUFBLEdBQUFOLElBQUEsQ0FDVE8sU0FBUztJQUFUQSxTQUFTLEdBQUFELGNBQUEsY0FBRyxlQUFlLEdBQUFBLGNBQUE7RUFFM0IsSUFBTUUsU0FBUyxHQUFHSCxJQUFJLEdBQUcsSUFBSTtFQUU3QixvQkFDRVQsTUFBQSxDQUFBYSxPQUFBLENBQUFDLGFBQUE7SUFDRUgsU0FBUyxFQUFFQSxTQUFVO0lBQ3JCSSxLQUFLLEVBQUU7TUFDTEMsS0FBSyxFQUFFUCxJQUFJO01BQ1hRLE1BQU0sRUFBRVIsSUFBSTtNQUNaUyxZQUFZLEVBQUUsS0FBSztNQUNuQkMsZUFBZSxFQUFFLFNBQVM7TUFDMUJDLFNBQVMsRUFBRSw2QkFBNkI7TUFDeENDLE9BQU8sRUFBRSxNQUFNO01BQ2ZDLFVBQVUsRUFBRSxRQUFRO01BQ3BCQyxjQUFjLEVBQUU7SUFDbEI7RUFBRSxnQkFFRnZCLE1BQUEsQ0FBQWEsT0FBQSxDQUFBQyxhQUFBO0lBQ0VDLEtBQUssRUFBRTtNQUNMQyxLQUFLLEVBQUVKLFNBQVM7TUFDaEJLLE1BQU0sRUFBRUwsU0FBUztNQUNqQk0sWUFBWSxFQUFFLEtBQUs7TUFDbkJDLGVBQWUsRUFBRSxTQUFTO01BQzFCRSxPQUFPLEVBQUUsTUFBTTtNQUNmRyxhQUFhLEVBQUUsUUFBUTtNQUN2QkYsVUFBVSxFQUFFLFFBQVE7TUFDcEJDLGNBQWMsRUFBRSxRQUFRO01BQ3hCRSxVQUFVLEVBQUUsR0FBRztNQUNmQyxVQUFVLEVBQUU7SUFDZDtFQUFFLGdCQUdGMUIsTUFBQSxDQUFBYSxPQUFBLENBQUFDLGFBQUE7SUFDRUUsS0FBSyxFQUFFSixTQUFTLEdBQUcsSUFBSztJQUN4QkssTUFBTSxFQUFFTCxTQUFTLEdBQUcsR0FBSTtJQUN4QmUsT0FBTyxFQUFDLFdBQVc7SUFDbkJDLElBQUksRUFBRXJCO0VBQU0sZ0JBRVpQLE1BQUEsQ0FBQWEsT0FBQSxDQUFBQyxhQUFBO0lBQU1lLENBQUMsRUFBQztFQUE4QixDQUFFLENBQ3JDLENBQUMsZUFHTjdCLE1BQUEsQ0FBQWEsT0FBQSxDQUFBQyxhQUFBO0lBQ0VDLEtBQUssRUFBRTtNQUNMZSxTQUFTLEVBQUUsQ0FBQztNQUNaQyxRQUFRLEVBQUVuQixTQUFTLEdBQUc7SUFDeEI7RUFBRSxHQUVEUCxLQUNFLENBQ0YsQ0FDRixDQUFDO0FBRVYsQ0FBQztBQUFDMkIsT0FBQSxDQUFBN0IsYUFBQSxHQUFBQSxhQUFBO0FBQUEsSUFBQThCLFFBQUEsR0FDYTlCLGFBQWE7QUFBQTZCLE9BQUEsQ0FBQW5CLE9BQUEsR0FBQW9CLFFBQUEifQ==