@kando-env/kando-ui 1.2.466-alpha.8 → 1.2.466-alpha.9
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/Router.js +6 -4
- package/lib/Widgets/Map/Map.js +3 -3
- package/lib/Widgets/Map/MapUtils.js +2 -1
- package/lib/Widgets/Map/edges/Edge.js +31 -46
- package/lib/components/DischargeHeatmap/mocks/handlers.js +3 -3
- package/lib/components/Header/Toolbar/Toolbar.js +1 -3
- package/lib/components/KandoModal/KandoModal.js +24 -4
- package/lib/components/SeasonalInsights/SeasonalInsights.js +147 -0
- package/lib/components/SevereEvent/SevereEvent.js +18 -2
- package/lib/components/SevereEvent/SevereEvent.scss +24 -0
- package/lib/components/SevereEvent/UpstreamBadge.js +60 -0
- package/lib/components/TopBanner/TopBanner.js +235 -0
- package/lib/components/TopBanner/insightsDismissalStorage.js +36 -0
- package/lib/i18n/en.json +15 -3
- package/lib/i18n/fr.json +4 -0
- package/lib/i18n/he.json +12 -1
- package/lib/i18n/it.json +4 -0
- package/lib/macros/getVersion.js +1 -1
- package/lib/pages/AreaPage/Dashboard/Dashboard.js +2 -2
- package/lib/pages/EventsPage/events/event_info/EventDetails.js +2 -2
- package/lib/pages/EventsPage/events/event_info/EventSection.test.js +21 -22
- package/lib/pages/EventsPage/events/event_info/Header/Header.js +1 -1
- package/lib/pages/EventsPage/events/event_info/Header/HeaderContainer.js +2 -2
- package/lib/pages/EventsPage/events/event_info/Header/index.js +1 -1
- package/lib/pages/EventsPage/events/event_info/SeverityScore/index.js +1 -1
- package/lib/pages/EventsPage/events/event_info/Timelines/index.js +1 -1
- package/lib/pages/EventsPage/events/events_list/EventsList.js +7 -1
- package/lib/pages/EventsPage/events/events_list/Filter/FilterContainer.js +2 -2
- package/lib/pages/EventsPage/events/events_list/Filter/FilterItem.js +4 -1
- package/lib/pages/EventsPage/events/events_list/Sort.js +21 -15
- package/lib/pages/SitePage/SitePage.js +2 -2
- package/lib/test/mocks/browser.js +1 -1
- package/lib/test/test-utils.js +1 -1
- package/lib/ui-kit/KandoTable/KandoTable.test.js +1 -1
- package/lib/utilities/scoreToData.test.js +1 -1
- package/lib/utilities/urls.js +3 -3
- package/package.json +9 -12
|
@@ -0,0 +1,235 @@
|
|
|
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 _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/objectSpread2"));
|
|
11
|
+
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/asyncToGenerator"));
|
|
12
|
+
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/slicedToArray"));
|
|
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
|
+
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
19
|
+
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
20
|
+
var INSIGHT_TYPE = 'seasonal_insight';
|
|
21
|
+
var TopBanner = function TopBanner(_ref) {
|
|
22
|
+
var _ref$backgroundColor = _ref.backgroundColor,
|
|
23
|
+
backgroundColor = _ref$backgroundColor === void 0 ? 'rgb(217, 234, 255)' : _ref$backgroundColor,
|
|
24
|
+
_ref$text = _ref.text,
|
|
25
|
+
text = _ref$text === void 0 ? '' : _ref$text,
|
|
26
|
+
onVisibilityChange = _ref.onVisibilityChange,
|
|
27
|
+
apiEndpoint = _ref.apiEndpoint;
|
|
28
|
+
var _useState = (0, _react.useState)(true),
|
|
29
|
+
_useState2 = (0, _slicedToArray2.default)(_useState, 2),
|
|
30
|
+
visible = _useState2[0],
|
|
31
|
+
setVisible = _useState2[1];
|
|
32
|
+
var _useState3 = (0, _react.useState)(null),
|
|
33
|
+
_useState4 = (0, _slicedToArray2.default)(_useState3, 2),
|
|
34
|
+
headerText = _useState4[0],
|
|
35
|
+
setHeaderText = _useState4[1];
|
|
36
|
+
var _useState5 = (0, _react.useState)(''),
|
|
37
|
+
_useState6 = (0, _slicedToArray2.default)(_useState5, 2),
|
|
38
|
+
titleText = _useState6[0],
|
|
39
|
+
setTitleText = _useState6[1];
|
|
40
|
+
var _useState7 = (0, _react.useState)(''),
|
|
41
|
+
_useState8 = (0, _slicedToArray2.default)(_useState7, 2),
|
|
42
|
+
learnMoreText = _useState8[0],
|
|
43
|
+
setLearnMoreText = _useState8[1];
|
|
44
|
+
var _useState9 = (0, _react.useState)(false),
|
|
45
|
+
_useState10 = (0, _slicedToArray2.default)(_useState9, 2),
|
|
46
|
+
showModal = _useState10[0],
|
|
47
|
+
setShowModal = _useState10[1];
|
|
48
|
+
var _useState11 = (0, _react.useState)(null),
|
|
49
|
+
_useState12 = (0, _slicedToArray2.default)(_useState11, 2),
|
|
50
|
+
insightData = _useState12[0],
|
|
51
|
+
setInsightData = _useState12[1];
|
|
52
|
+
var bannerHeight = 30; // px
|
|
53
|
+
var dir = _i18next.default.dir();
|
|
54
|
+
|
|
55
|
+
// On mount or when insight id changes, check localStorage for dismissal
|
|
56
|
+
(0, _react.useEffect)(function () {
|
|
57
|
+
// If we have insight data with an id, check if it was dismissed
|
|
58
|
+
if ((insightData === null || insightData === void 0 ? void 0 : insightData.id) !== undefined) {
|
|
59
|
+
try {
|
|
60
|
+
var record = (0, _insightsDismissalStorage.getDismissal)(INSIGHT_TYPE);
|
|
61
|
+
var dismissed = (record === null || record === void 0 ? void 0 : record.lastDismissedId) === String(insightData.id);
|
|
62
|
+
setVisible(!dismissed);
|
|
63
|
+
if (onVisibilityChange) onVisibilityChange(!dismissed);
|
|
64
|
+
} catch (_unused) {
|
|
65
|
+
setVisible(true);
|
|
66
|
+
if (onVisibilityChange) onVisibilityChange(true);
|
|
67
|
+
}
|
|
68
|
+
} else if (insightData === null) {
|
|
69
|
+
// No insight data - hide banner if using API, show if using static text prop
|
|
70
|
+
if (apiEndpoint) {
|
|
71
|
+
// API endpoint exists but no data returned - hide banner
|
|
72
|
+
setVisible(false);
|
|
73
|
+
if (onVisibilityChange) onVisibilityChange(false);
|
|
74
|
+
} else {
|
|
75
|
+
// No API endpoint - show banner if text is provided
|
|
76
|
+
setVisible(!!text);
|
|
77
|
+
if (onVisibilityChange) onVisibilityChange(!!text);
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
}, [insightData === null || insightData === void 0 ? void 0 : insightData.id, insightData, apiEndpoint, text, onVisibilityChange]);
|
|
81
|
+
|
|
82
|
+
// Fetch data from API if endpoint is provided, robustly
|
|
83
|
+
(0, _react.useEffect)(function () {
|
|
84
|
+
if (!apiEndpoint) return;
|
|
85
|
+
var controller = new AbortController();
|
|
86
|
+
fetch(apiEndpoint, {
|
|
87
|
+
signal: controller.signal
|
|
88
|
+
}).then( /*#__PURE__*/function () {
|
|
89
|
+
var _ref2 = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee(res) {
|
|
90
|
+
return _regenerator.default.wrap(function _callee$(_context) {
|
|
91
|
+
while (1) {
|
|
92
|
+
switch (_context.prev = _context.next) {
|
|
93
|
+
case 0:
|
|
94
|
+
if (!(res.status === 404)) {
|
|
95
|
+
_context.next = 2;
|
|
96
|
+
break;
|
|
97
|
+
}
|
|
98
|
+
return _context.abrupt("return", {
|
|
99
|
+
error: 'not_found'
|
|
100
|
+
});
|
|
101
|
+
case 2:
|
|
102
|
+
if (res.ok) {
|
|
103
|
+
_context.next = 4;
|
|
104
|
+
break;
|
|
105
|
+
}
|
|
106
|
+
throw new Error("Request failed (".concat(res.status, ")"));
|
|
107
|
+
case 4:
|
|
108
|
+
_context.next = 6;
|
|
109
|
+
return res.json();
|
|
110
|
+
case 6:
|
|
111
|
+
return _context.abrupt("return", _context.sent);
|
|
112
|
+
case 7:
|
|
113
|
+
case "end":
|
|
114
|
+
return _context.stop();
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
}, _callee);
|
|
118
|
+
}));
|
|
119
|
+
return function (_x) {
|
|
120
|
+
return _ref2.apply(this, arguments);
|
|
121
|
+
};
|
|
122
|
+
}()).then(function (data) {
|
|
123
|
+
// When the API says not_found, do not show the banner.
|
|
124
|
+
if ((data === null || data === void 0 ? void 0 : data.error) === 'not_found') {
|
|
125
|
+
setInsightData(null);
|
|
126
|
+
setHeaderText(null);
|
|
127
|
+
setTitleText('');
|
|
128
|
+
setLearnMoreText('');
|
|
129
|
+
setVisible(false);
|
|
130
|
+
return;
|
|
131
|
+
}
|
|
132
|
+
setInsightData(data);
|
|
133
|
+
setTitleText(String(_i18next.default.t('seasonal_insights.title')));
|
|
134
|
+
setLearnMoreText(String(_i18next.default.t('seasonal_insights.learn_more')));
|
|
135
|
+
}).catch(function (err) {
|
|
136
|
+
// On fetch error, hide the banner (no data to show)
|
|
137
|
+
if ((err === null || err === void 0 ? void 0 : err.name) !== 'AbortError') {
|
|
138
|
+
setInsightData(null);
|
|
139
|
+
setHeaderText(null);
|
|
140
|
+
setTitleText('');
|
|
141
|
+
setLearnMoreText('');
|
|
142
|
+
setVisible(false);
|
|
143
|
+
}
|
|
144
|
+
});
|
|
145
|
+
return function () {
|
|
146
|
+
return controller.abort();
|
|
147
|
+
};
|
|
148
|
+
}, [apiEndpoint, text]);
|
|
149
|
+
|
|
150
|
+
// Notify parent on visibility change
|
|
151
|
+
(0, _react.useEffect)(function () {
|
|
152
|
+
if (onVisibilityChange) onVisibilityChange(visible);
|
|
153
|
+
}, [visible]);
|
|
154
|
+
|
|
155
|
+
// When dismissed, persist in localStorage
|
|
156
|
+
var handleDismiss = function handleDismiss() {
|
|
157
|
+
setVisible(false);
|
|
158
|
+
if ((insightData === null || insightData === void 0 ? void 0 : insightData.id) === undefined) return;
|
|
159
|
+
try {
|
|
160
|
+
(0, _insightsDismissalStorage.setDismissal)(INSIGHT_TYPE, String(insightData.id));
|
|
161
|
+
} catch (_unused2) {
|
|
162
|
+
// ignore storage errors
|
|
163
|
+
}
|
|
164
|
+
};
|
|
165
|
+
var openModal = function openModal() {
|
|
166
|
+
setShowModal(true);
|
|
167
|
+
};
|
|
168
|
+
var closeModal = function closeModal() {
|
|
169
|
+
setShowModal(false);
|
|
170
|
+
};
|
|
171
|
+
var modal = (0, _react.useMemo)(function () {
|
|
172
|
+
if (!showModal) return null;
|
|
173
|
+
var dir = _i18next.default.dir();
|
|
174
|
+
return /*#__PURE__*/_react.default.createElement(_KandoModal.default, {
|
|
175
|
+
isOpen: showModal,
|
|
176
|
+
onClose: closeModal,
|
|
177
|
+
dir: dir
|
|
178
|
+
}, /*#__PURE__*/_react.default.createElement(_SeasonalInsights.default, {
|
|
179
|
+
data: insightData
|
|
180
|
+
}));
|
|
181
|
+
}, [showModal]);
|
|
182
|
+
var hasContent = apiEndpoint ? titleText && learnMoreText : text || headerText;
|
|
183
|
+
if (!visible || !hasContent) {
|
|
184
|
+
return null;
|
|
185
|
+
}
|
|
186
|
+
return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("div", {
|
|
187
|
+
style: {
|
|
188
|
+
width: '100%',
|
|
189
|
+
background: backgroundColor,
|
|
190
|
+
padding: '8px',
|
|
191
|
+
textAlign: 'center',
|
|
192
|
+
position: 'relative',
|
|
193
|
+
boxSizing: 'border-box',
|
|
194
|
+
minHeight: "".concat(bannerHeight, "px"),
|
|
195
|
+
height: "".concat(bannerHeight, "px"),
|
|
196
|
+
display: 'flex',
|
|
197
|
+
alignItems: 'center',
|
|
198
|
+
justifyContent: 'center',
|
|
199
|
+
fontSize: '14px',
|
|
200
|
+
cursor: 'default'
|
|
201
|
+
}
|
|
202
|
+
}, /*#__PURE__*/_react.default.createElement("span", null, apiEndpoint ? /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("span", {
|
|
203
|
+
style: {
|
|
204
|
+
filter: 'drop-shadow(0 0 2px rgba(0, 0, 0, 0.3))',
|
|
205
|
+
fontSize: '16px',
|
|
206
|
+
display: 'inline-block',
|
|
207
|
+
marginRight: '4px'
|
|
208
|
+
}
|
|
209
|
+
}, "\u2728"), titleText, ' ', /*#__PURE__*/_react.default.createElement("span", {
|
|
210
|
+
onClick: openModal,
|
|
211
|
+
style: {
|
|
212
|
+
textDecoration: 'underline',
|
|
213
|
+
cursor: 'pointer'
|
|
214
|
+
}
|
|
215
|
+
}, learnMoreText)) : headerText || text), /*#__PURE__*/_react.default.createElement("button", {
|
|
216
|
+
onClick: handleDismiss,
|
|
217
|
+
style: (0, _objectSpread2.default)((0, _objectSpread2.default)({
|
|
218
|
+
position: 'absolute'
|
|
219
|
+
}, dir === 'rtl' ? {
|
|
220
|
+
left: 10,
|
|
221
|
+
right: 'auto'
|
|
222
|
+
} : {
|
|
223
|
+
right: 10
|
|
224
|
+
}), {}, {
|
|
225
|
+
background: 'transparent',
|
|
226
|
+
border: 'none',
|
|
227
|
+
fontSize: '24px',
|
|
228
|
+
cursor: 'pointer'
|
|
229
|
+
}),
|
|
230
|
+
"aria-label": "Dismiss banner"
|
|
231
|
+
}, "\xD7")), modal);
|
|
232
|
+
};
|
|
233
|
+
var _default = TopBanner;
|
|
234
|
+
exports.default = _default;
|
|
235
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_KandoModal","_interopRequireDefault","_SeasonalInsights","_i18next","_insightsDismissalStorage","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","INSIGHT_TYPE","TopBanner","_ref","_ref$backgroundColor","backgroundColor","_ref$text","text","onVisibilityChange","apiEndpoint","_useState","useState","_useState2","_slicedToArray2","visible","setVisible","_useState3","_useState4","headerText","setHeaderText","_useState5","_useState6","titleText","setTitleText","_useState7","_useState8","learnMoreText","setLearnMoreText","_useState9","_useState10","showModal","setShowModal","_useState11","_useState12","insightData","setInsightData","bannerHeight","dir","i18next","useEffect","id","undefined","record","getDismissal","dismissed","lastDismissedId","String","_unused","controller","AbortController","fetch","signal","then","_ref2","_asyncToGenerator2","_regenerator","mark","_callee","res","wrap","_callee$","_context","prev","next","status","abrupt","error","ok","Error","concat","json","sent","stop","_x","apply","arguments","data","t","catch","err","name","abort","handleDismiss","setDismissal","_unused2","openModal","closeModal","modal","useMemo","createElement","isOpen","onClose","hasContent","Fragment","style","width","background","padding","textAlign","position","boxSizing","minHeight","height","display","alignItems","justifyContent","fontSize","cursor","filter","marginRight","onClick","textDecoration","_objectSpread2","left","right","border","_default","exports"],"sources":["../../../src/components/TopBanner/TopBanner.tsx"],"sourcesContent":["import React, { useState, useEffect, useMemo } from 'react';\nimport KandoModal from '../KandoModal';\nimport SeasonalInsights, {\n  SeasonalInsightResponse,\n} from '../SeasonalInsights/SeasonalInsights';\nimport i18next from 'i18next';\nimport {\n  getDismissal,\n  setDismissal,\n  InsightType,\n} from './insightsDismissalStorage';\n\ninterface TopBannerProps {\n  backgroundColor?: string;\n  text?: React.ReactNode;\n  onVisibilityChange?: (visible: boolean) => void;\n  apiEndpoint?: string; // Add this prop for API endpoint\n}\n\nconst INSIGHT_TYPE: InsightType = 'seasonal_insight';\n\nconst TopBanner: React.FC<TopBannerProps> = ({\n  backgroundColor = 'rgb(217, 234, 255)', // #f5b7c5',\n  text = '',\n  onVisibilityChange,\n  apiEndpoint,\n}) => {\n  const [visible, setVisible] = useState(true);\n  const [headerText, setHeaderText] = useState<React.ReactNode>(null);\n  const [titleText, setTitleText] = useState<string>('');\n  const [learnMoreText, setLearnMoreText] = useState<string>('');\n  const [showModal, setShowModal] = useState(false);\n  const [insightData, setInsightData] =\n    useState<SeasonalInsightResponse | null>(null);\n\n  const bannerHeight = 30; // px\n  const dir = i18next.dir();\n\n  // On mount or when insight id changes, check localStorage for dismissal\n  useEffect(() => {\n    // If we have insight data with an id, check if it was dismissed\n    if (insightData?.id !== undefined) {\n      try {\n        const record = getDismissal(INSIGHT_TYPE);\n        const dismissed = record?.lastDismissedId === String(insightData.id);\n        setVisible(!dismissed);\n        if (onVisibilityChange) onVisibilityChange(!dismissed);\n      } catch {\n        setVisible(true);\n        if (onVisibilityChange) onVisibilityChange(true);\n      }\n    } else if (insightData === null) {\n      // No insight data - hide banner if using API, show if using static text prop\n      if (apiEndpoint) {\n        // API endpoint exists but no data returned - hide banner\n        setVisible(false);\n        if (onVisibilityChange) onVisibilityChange(false);\n      } else {\n        // No API endpoint - show banner if text is provided\n        setVisible(!!text);\n        if (onVisibilityChange) onVisibilityChange(!!text);\n      }\n    }\n  }, [insightData?.id, insightData, apiEndpoint, text, onVisibilityChange]);\n\n  // Fetch data from API if endpoint is provided, robustly\n  useEffect(() => {\n    if (!apiEndpoint) return;\n\n    const controller = new AbortController();\n\n    fetch(apiEndpoint, { signal: controller.signal })\n      .then(async (res) => {\n        if (res.status === 404) {\n          // API explicitly says there is no seasonal insight.\n          return { error: 'not_found' } as unknown as SeasonalInsightResponse;\n        }\n        if (!res.ok) {\n          throw new Error(`Request failed (${res.status})`);\n        }\n        return (await res.json()) as SeasonalInsightResponse;\n      })\n      .then((data) => {\n        // When the API says not_found, do not show the banner.\n        if ((data as any)?.error === 'not_found') {\n          setInsightData(null);\n          setHeaderText(null);\n          setTitleText('');\n          setLearnMoreText('');\n          setVisible(false);\n          return;\n        }\n        setInsightData(data);\n\n        setTitleText(String(i18next.t('seasonal_insights.title')));\n        setLearnMoreText(String(i18next.t('seasonal_insights.learn_more')));\n      })\n      .catch((err) => {\n        // On fetch error, hide the banner (no data to show)\n        if (err?.name !== 'AbortError') {\n          setInsightData(null);\n          setHeaderText(null);\n          setTitleText('');\n          setLearnMoreText('');\n          setVisible(false);\n        }\n      });\n\n    return () => controller.abort();\n  }, [apiEndpoint, text]);\n\n  // Notify parent on visibility change\n  useEffect(() => {\n    if (onVisibilityChange) onVisibilityChange(visible);\n  }, [visible]);\n\n  // When dismissed, persist in localStorage\n  const handleDismiss = () => {\n    setVisible(false);\n    if (insightData?.id === undefined) return;\n\n    try {\n      setDismissal(INSIGHT_TYPE, String(insightData.id));\n    } catch {\n      // ignore storage errors\n    }\n  };\n\n  const openModal = () => {\n    setShowModal(true);\n  };\n\n  const closeModal = () => {\n    setShowModal(false);\n  };\n\n  const modal = useMemo(() => {\n    if (!showModal) return null;\n    const dir = i18next.dir();\n    return (\n      <KandoModal isOpen={showModal} onClose={closeModal} dir={dir}>\n        <SeasonalInsights data={insightData} />\n      </KandoModal>\n    );\n  }, [showModal]);\n\n  const hasContent = apiEndpoint\n    ? titleText && learnMoreText\n    : text || headerText;\n  if (!visible || !hasContent) {\n    return null;\n  }\n\n  return (\n    <>\n      <div\n        style={{\n          width: '100%',\n          background: backgroundColor,\n          padding: '8px',\n          textAlign: 'center',\n          position: 'relative',\n          boxSizing: 'border-box',\n          minHeight: `${bannerHeight}px`,\n          height: `${bannerHeight}px`,\n          display: 'flex',\n          alignItems: 'center',\n          justifyContent: 'center',\n          fontSize: '14px',\n          cursor: 'default',\n        }}\n      >\n        <span>\n          {apiEndpoint ? (\n            <>\n              <span\n                style={{\n                  filter: 'drop-shadow(0 0 2px rgba(0, 0, 0, 0.3))',\n                  fontSize: '16px',\n                  display: 'inline-block',\n                  marginRight: '4px',\n                }}\n              >\n                ✨\n              </span>\n              {titleText}{' '}\n              <span\n                onClick={openModal}\n                style={{\n                  textDecoration: 'underline',\n                  cursor: 'pointer',\n                }}\n              >\n                {learnMoreText}\n              </span>\n            </>\n          ) : (\n            headerText || text\n          )}\n        </span>\n        <button\n          onClick={handleDismiss}\n          style={{\n            position: 'absolute',\n            ...(dir === 'rtl'\n              ? { left: 10, right: 'auto' as const }\n              : { right: 10 }),\n            background: 'transparent',\n            border: 'none',\n            fontSize: '24px',\n            cursor: 'pointer',\n          }}\n          aria-label=\"Dismiss banner\"\n        >\n          ×\n        </button>\n      </div>\n      {modal}\n    </>\n  );\n};\n\nexport default TopBanner;\n"],"mappings":"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"}
|
|
@@ -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
|
-
"
|
|
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",
|
|
@@ -3073,7 +3075,8 @@
|
|
|
3073
3075
|
"sampler_filter_item": "Sampler Mode",
|
|
3074
3076
|
"insight_data_filter_item": "Insight Data",
|
|
3075
3077
|
"sampling_parameter_filter_item": "Exceeding Parameter",
|
|
3076
|
-
"
|
|
3078
|
+
"discharge_time_filter_item": "Discharge Time",
|
|
3079
|
+
"observed_upstream_filter_item": "Observed Upstream"
|
|
3077
3080
|
},
|
|
3078
3081
|
"filter": "Filter",
|
|
3079
3082
|
"apply": "Apply",
|
|
@@ -3121,6 +3124,10 @@
|
|
|
3121
3124
|
"with": "With",
|
|
3122
3125
|
"without": "Without"
|
|
3123
3126
|
},
|
|
3127
|
+
"observed_upstream": {
|
|
3128
|
+
"with": "With",
|
|
3129
|
+
"without": "Without"
|
|
3130
|
+
},
|
|
3124
3131
|
"insight_data": {
|
|
3125
3132
|
"score": "Score",
|
|
3126
3133
|
"pollution_contributor": "Pollution Contributor"
|
|
@@ -3133,6 +3140,7 @@
|
|
|
3133
3140
|
"contaminants": "Contaminants",
|
|
3134
3141
|
"sampling": "Sampling",
|
|
3135
3142
|
"sampling_plural": "Samplings ({{count}})",
|
|
3143
|
+
"upstream_observations": "Seen on {{count}} sites",
|
|
3136
3144
|
"static_thresholds_crossed_explanation": "Exceeding expected pollution for this sector",
|
|
3137
3145
|
"dynamic_thresholds_crossed_explanation": "Worse than usual for this site ({{score}})",
|
|
3138
3146
|
"worse_than_usual_explanation": "Worse than usual for this site",
|
|
@@ -4132,6 +4140,10 @@
|
|
|
4132
4140
|
"should_install": "Should install"
|
|
4133
4141
|
}
|
|
4134
4142
|
}
|
|
4143
|
+
},
|
|
4144
|
+
"seasonal_insights": {
|
|
4145
|
+
"title": "Seasonal Insights Available",
|
|
4146
|
+
"learn_more": "Learn more"
|
|
4135
4147
|
}
|
|
4136
4148
|
}
|
|
4137
4149
|
}
|
package/lib/i18n/fr.json
CHANGED
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,10 @@
|
|
|
3912
3919
|
"sub_areas": "אזורי משנה",
|
|
3913
3920
|
"factories": "מפעלים"
|
|
3914
3921
|
}
|
|
3922
|
+
},
|
|
3923
|
+
"seasonal_insights": {
|
|
3924
|
+
"title": "תובנות עונתיות זמינות",
|
|
3925
|
+
"learn_more": "למד עוד"
|
|
3915
3926
|
}
|
|
3916
3927
|
}
|
|
3917
3928
|
}
|
package/lib/i18n/it.json
CHANGED
package/lib/macros/getVersion.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
var packageJsonVersion = "1.2.466-alpha.
|
|
3
|
+
var packageJsonVersion = "1.2.466-alpha.9";
|
|
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));
|
|
@@ -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
|
|
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":";;;;;;;;;AAAA,IAAAA,MAAA,GAAAC,uBAAA,CAAAC,OAAA;AACA,IAAAC,WAAA,GAAAD,OAAA;AACA,IAAAE,eAAA,GAAAF,OAAA;AAEA,IAAAG,KAAA,GAAAC,sBAAA,CAAAJ,OAAA;AACA,IAAAK,eAAA,GAAAL,OAAA;AACA,IAAAM,mBAAA,GAAAN,OAAA;AAEA,IAAAO,uBAAA,GAAAP,OAAA;AACA,IAAAQ,UAAA,GAAAR,OAAA;AACA,IAAAS,UAAA,GAAAT,OAAA;AACA,IAAAU,YAAA,GAAAV,OAAA;AACA,IAAAW,cAAA,GAAAX,OAAA;AACA,IAAAY,eAAA,GAAAR,sBAAA,CAAAJ,OAAA;AACA,IAAAa,KAAA,GAAAb,OAAA;AACA,IAAAc,aAAA,GAAAd,OAAA;AACA,IAAAe,YAAA,GAAAX,sBAAA,CAAAJ,OAAA;AAAgD,SAAAgB,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,SAAAlB,wBAAAsB,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;AAEzC,IAAMW,SAAS,GAAG,SAAZA,SAASA,CAAA,EAAS;EAC7B,IAAMC,aAAa,GAAG,IAAAC,oBAAW,EAAC,CAAC;EACnC,IAAMC,cAAc,GAAGF,aAAa,CAACb,GAAG,CAAC,MAAM,CAAC,KAAK,KAAK;EAC1D,IAAAgB,UAAA,GAAmB,IAAAC,yBAAS,EAAC,CAAC;IAAtBC,MAAM,GAAAF,UAAA,CAANE,MAAM;EACd,IAAMC,MAAM,GAAG,IAAAC,uBAAW,EACxB,UAACC,KAAoC;IAAA,OACnCA,KAAK,CAACC,SAAS,CAACH,MAAM,CAAC,OAAO,CAAC,IAAIE,KAAK,CAACC,SAAS,CAACH,MAAM;EAAA,CAC7D,CAAC;EACD,IAAAI,cAAA,GAMI,IAAAC,uBAAa,EAAC,IAAAC,UAAI,EAAC;MAAEP,MAAM,EAANA;IAAO,CAAC,CAAC,CAACI,SAAS,CAACI,IAAI,CAACC,QAAQ,CAAC;IALzDC,IAAI,GAAAL,cAAA,CAAJK,IAAI;IACJC,UAAU,GAAAN,cAAA,CAAVM,UAAU;EAMZ,IAAMC,eAAe,iBAAiB;EAEtC,IAAMC,WAAW,GAAG,IAAAC,cAAO,EAAC,YAAM;IAChC,OAAO;MACLC,aAAa,yBAAAC,MAAA,CAAyBhB,MAAM,2DAAAgB,MAAA,CAAwDf,MAAM;IAC5G,CAAC;EACH,CAAC,EAAE,CAACD,MAAM,EAAEC,MAAM,CAAC,CAAC;EAEpB,IAAMgB,iBAAiB,GAAG,CACxBC,aAAI,CAACC,CAAC,CACJ,qEACF,CAAC,EACDD,aAAI,CAACC,CAAC,CAAC,YAAY,CAAC,EACpBD,aAAI,CAACC,CAAC,CAAC,iEAAiE,CAAC,CAC1E;EAED,oBACElE,MAAA,CAAA0B,OAAA,CAAAyC,aAAA,CAACC,SAAS,qBACRpE,MAAA,CAAA0B,OAAA,CAAAyC,aAAA,CAACE,aAAa;IACZC,QAAQ,YAAAP,MAAA,CAAYhB,MAAM,sBAAoB;IAC9CwB,MAAM,EAAEP,iBAAkB;IAC1BQ,OAAO,EAAE,IAAK;IACdC,UAAU,EAAE,CAAC,iBAAiB,EAAE,kBAAkB,EAAE,aAAa,CAAE;IACnEC,KAAK,EAAET,aAAI,CAACC,CAAC,CAAC,0BAA0B,CAAE;IAC1CS,UAAU,EAAE/B;EAAe,CAC5B,CAAC,eACF5C,MAAA,CAAA0B,OAAA,CAAAyC,aAAA,CAACS,gBAAgB;IAACN,QAAQ,YAAAP,MAAA,CAAYhB,MAAM;EAAwB,CAAE,CAAC,eACvE/C,MAAA,CAAA0B,OAAA,CAAAyC,aAAA,CAACU,eAAe;IAACP,QAAQ,YAAAP,MAAA,CAAYhB,MAAM;EAAoB,CAAE,CAAC,eAClE/C,MAAA,CAAA0B,OAAA,CAAAyC,aAAA,CAACW,kBAAkB;IAACR,QAAQ,YAAAP,MAAA,CAAYhB,MAAM;EAAoB,CAAE,CAAC,eACrE/C,MAAA,CAAA0B,OAAA,CAAAyC,aAAA;IAAKY,SAAS,EAAC;EAAoB,gBACjC/E,MAAA,CAAA0B,OAAA,CAAAyC,aAAA;IAAKY,SAAS,EAAC;EAAO,gBACpB/E,MAAA,CAAA0B,OAAA,CAAAyC,aAAA,CAACvD,YAAA,CAAAoE,WAAW;IACVN,KAAK,EAAET,aAAI,CAACC,CAAC,CAAC,wCAAwC,CAAE;IACxDT,IAAI,EAAEQ,aAAI,CAACC,CAAC,CAAC,8CAA8C;EAAE,gBAE7DlE,MAAA,CAAA0B,OAAA,CAAAyC,aAAA,CAACnD,aAAA,CAAAiE,KAAK;IAACC,OAAO,EAAE;EAAyC,CAAE,CAChD,CACV,CAAC,eACNlF,MAAA,CAAA0B,OAAA,CAAAyC,aAAA,CAACxD,UAAA,CAAAwE,SAAS;IAACb,QAAQ,EAAEX,eAAgB;IAACC,WAAW,EAAEA;EAAY,CAAE,CAC9D,CAAC,eACN5D,MAAA,CAAA0B,OAAA,CAAAyC,aAAA;IAAKY,SAAS,EAAC;EAAO,GACnB,CAACrB,UAAU,iBACV1D,MAAA,CAAA0B,OAAA,CAAAyC,aAAA,CAACtD,cAAA,CAAAuE,aAAa;IACZC,aAAa,EAAE,MAAO;IACtBC,WAAW,EAAE7B,IAAI,CAAC8B,QAAS;IAC3BC,UAAU,EAAE/B,IAAI,CAACgC;EAAY,CAC9B,CAEA,CACI,CAAC;AAEhB,CAAC;AAACC,OAAA,CAAAjD,SAAA,GAAAA,SAAA;AAEF,IAAM2B,SAAS,GAAGuB,yBAAM,CAACC,GAAG,CAAAC,UAAA;EAAAC,WAAA;EAAAC,WAAA;AAAA,stCAiF3B;AAED,IAAM1B,aAAa,GAAG,IAAAsB,yBAAM,EAACK,sCAAkB,CAAC,CAAAH,UAAA;EAAAC,WAAA;EAAAC,WAAA;AAAA,uBAE/C;AAED,IAAMnB,gBAAgB,GAAG,IAAAe,yBAAM,EAACM,8BAAc,CAAC,CAAAJ,UAAA;EAAAC,WAAA;EAAAC,WAAA;AAAA,0BAE9C;AAED,IAAMlB,eAAe,GAAG,IAAAc,yBAAM,EAACO,8CAAsB,CAAC,CAAAL,UAAA;EAAAC,WAAA;EAAAC,WAAA;AAAA,yBAErD;AAED,IAAMjB,kBAAkB,GAAG,IAAAa,yBAAM,EAACQ,oBAAS,CAAC,CAAAN,UAAA;EAAAC,WAAA;EAAAC,WAAA;AAAA,6DAM3C"}
|
|
@@ -38,7 +38,7 @@ var EventDetails = function EventDetails(props) {
|
|
|
38
38
|
return KQL;
|
|
39
39
|
};
|
|
40
40
|
var cutKQL = function cutKQL(KQL) {
|
|
41
|
-
KQL = "TimeFilterItem IN ( ".concat(buildDateRange(event.last_seen_time).earlyDate, ":").concat(buildDateRange(event.last_seen_time).lateDate, " ) ORDER_BY
|
|
41
|
+
KQL = "TimeFilterItem IN ( ".concat(buildDateRange(event.last_seen_time).earlyDate, ":").concat(buildDateRange(event.last_seen_time).lateDate, " ) ORDER_BY observed_upstream");
|
|
42
42
|
return KQL;
|
|
43
43
|
};
|
|
44
44
|
var buildKQLWithTimeRange = function buildKQLWithTimeRange() {
|
|
@@ -141,4 +141,4 @@ var EventDetails = function EventDetails(props) {
|
|
|
141
141
|
};
|
|
142
142
|
var _default = EventDetails;
|
|
143
143
|
exports.default = _default;
|
|
144
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_i18n","_TimeFormat","_EarlyWarnings","_Samplings","_EventUtils","_useQueryURL","_reactToastify","_reactFontawesome","_freeSolidSvgIcons","EventDetails","props","_event$samplings","event","points","buildDateRange","timestamp","date","Date","getTime","dayMs","dateMinusOne","datePlusOne","dateEarly","concat","getFullYear","getMonth","getDate","dateLate","earlyDate","lateDate","joinKQL","KQL","last_seen_time","cutKQL","buildKQLWithTimeRange","href","window","location","query","get","url","URL","includesALL","includes","timeFilterPresent","match","findTimeFilter","replace","searchParams","set","useQueryURL","copyUrl","navigator","clipboard","writeText","then","toast","success","i18n","t","position","autoClose","hideProgressBar","_parseEventData","parseEventData","firstseen","lastseen","total","default","createElement","className","onClick","FontAwesomeIcon","icon","faCopy","severity","point_name","start_time","time_zone","samplings","length","_default","exports"],"sources":["../../../../../src/pages/EventsPage/events/event_info/EventDetails.tsx"],"sourcesContent":["/* eslint-disable local-rules/no-hard-coded-jsx-literals */\nimport React from 'react';\nimport { IEvent } from 'src/store/events/models/IEvent';\nimport { IPointsState } from 'src/store/points/models/IPointsState';\nimport i18n from 'src/utilities/i18n';\nimport TimeFormat from 'src/utilities/TimeFormat';\nimport EarlyWarnings from './EarlyWarnings';\nimport Samplings from './samplingsOld/Samplings';\nimport { parseEventData } from '../events_list/EventUtils';\nimport useQueryURL from 'src/hooks/useQueryURL';\nimport { toast } from 'react-toastify';\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport { faCopy } from '@fortawesome/free-solid-svg-icons';\n\ntype IProps = {\n  event: IEvent;\n  points: IPointsState;\n};\n\nconst EventDetails: React.FC<IProps> = (props) => {\n  const { event, points } = props;\n\n  const buildDateRange = (timestamp) => {\n    let date = new Date(timestamp).getTime();\n    let dayMs = 86400000;\n    let dateMinusOne = new Date(date - dayMs);\n    let datePlusOne = new Date(date + dayMs);\n    let dateEarly = `${dateMinusOne.getFullYear()}-${\n      dateMinusOne.getMonth() + 1\n    }-${dateMinusOne.getDate()}`;\n    let dateLate = `${datePlusOne.getFullYear()}-${\n      datePlusOne.getMonth() + 1\n    }-${datePlusOne.getDate()}`;\n\n    return {\n      earlyDate: dateEarly,\n      lateDate: dateLate,\n    };\n  };\n\n  const joinKQL = (KQL: string) => {\n    KQL += ` TimeFilterItem IN ( ${\n      buildDateRange(event.last_seen_time).earlyDate\n    }:${buildDateRange(event.last_seen_time).lateDate} )`;\n\n    return KQL;\n  };\n\n  const cutKQL = (KQL: string) => {\n    KQL = `TimeFilterItem IN ( ${\n      buildDateRange(event.last_seen_time).earlyDate\n    }:${buildDateRange(event.last_seen_time).lateDate} ) ORDER_BY severity`;\n\n    return KQL;\n  };\n\n  const buildKQLWithTimeRange = () => {\n    const href = window.location.href;\n    let KQL = query.get('valuesFromKQL');\n    let url = new URL(href);\n\n    if (KQL === null) return url.href;\n\n    let includesALL = KQL.includes('ALL');\n    let timeFilterPresent = KQL.match('(?=TimeFilterItem)(.*?)(?:(\\\\)))');\n\n    if (timeFilterPresent) {\n      let findTimeFilter = timeFilterPresent;\n      if (findTimeFilter !== null) {\n        KQL = KQL.replace(findTimeFilter[0], ' ');\n      }\n\n      KQL = joinKQL(KQL);\n    } else {\n      KQL = includesALL ? cutKQL(KQL) : joinKQL(KQL);\n    }\n\n    url.searchParams.set('valuesFromKQL', KQL!);\n    return url.href;\n  };\n\n  const query = useQueryURL();\n  //eslint-disable-next-line\n  const copyUrl = () => {\n    navigator.clipboard.writeText(buildKQLWithTimeRange()).then(\n      () => {\n        toast.success(i18n.t('copy.success'), {\n          position: 'top-center',\n          autoClose: 1500,\n          hideProgressBar: true,\n        });\n      },\n      () => {\n        toast.success(i18n.t('copy.failed'), {\n          position: 'top-center',\n          autoClose: 1500,\n          hideProgressBar: true,\n        });\n      },\n    );\n  };\n\n  const { firstseen, lastseen, total } = parseEventData(event);\n\n  return (\n    <div className={'event-details event-info__card'}>\n      <div className=\"top\">\n        <div className=\"title\"> {i18n.t('events_overview.event_details')}</div>\n        <p\n          className=\"copy-button\"\n          onClick={() => {\n            copyUrl();\n          }}\n        >\n          <FontAwesomeIcon icon={faCopy} />\n        </p>\n      </div>\n      <div className=\"content\">\n        <div className={'event-info__detail event-info__event_severity'}>\n          <div className=\"box-title\">{i18n.t('events_overview.severity')}:</div>\n          <div className={'severities'}>\n            <p\n              className={`severities__severity severities__severity--0 severities__severity--0${\n                event.severity === '0' ? '--active' : ''\n              }`}\n            >\n              {i18n.t(`events_overview.severities.0`)}\n            </p>\n            <p\n              className={`severities__severity severities__severity--1 severities__severity--1${\n                event.severity === '1' ? '--active' : ''\n              }`}\n            >\n              {i18n.t(`events_overview.severities.1`)}\n            </p>\n            <p\n              className={`severities__severity severities__severity--2 severities__severity--2${\n                event.severity === '2' ? '--active' : ''\n              }`}\n            >\n              {i18n.t(`events_overview.severities.2`)}\n            </p>\n          </div>\n        </div>\n        <div\n          className={'event-info__detail event-info__detail__early-warnings'}\n        >\n          <EarlyWarnings event={event} />\n        </div>\n        <div className={'event-info__detail event-info__detail__seen'}>\n          <div className=\"box-title\">\n            {i18n.t('events_overview.first_seen')}:{' '}\n          </div>\n\n          <div>\n            <p>{firstseen.point_name}</p>\n            <span>\n              <TimeFormat\n                timestamp={firstseen.start_time}\n                time_zone={firstseen.time_zone}\n              />\n            </span>\n          </div>\n        </div>\n        <div className={'event-info__detail event-info__detail__seen'}>\n          <div className=\"box-title\">\n            {i18n.t('events_overview.last_seen')}:\n          </div>\n\n          <div>\n            <p>{lastseen.point_name}</p>\n            <span>\n              <TimeFormat\n                timestamp={lastseen.last_seen_time}\n                time_zone={lastseen.time_zone}\n              />\n            </span>\n          </div>\n        </div>\n        <div className={'event-info__detail event-info__detail__seen'}>\n          <div className=\"box-title\">\n            {i18n.t('events_overview.total_time')}:\n          </div>\n\n          <div className=\"total-time\">{total}</div>\n        </div>\n        {event?.samplings?.length > 0 && (\n          <div className={'event-info__detail'}>\n            <Samplings event={event} points={points} />\n          </div>\n        )}\n      </div>\n    </div>\n  );\n};\n\nexport default EventDetails;\n"],"mappings":"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"}
|
|
144
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_i18n","_TimeFormat","_EarlyWarnings","_Samplings","_EventUtils","_useQueryURL","_reactToastify","_reactFontawesome","_freeSolidSvgIcons","EventDetails","props","_event$samplings","event","points","buildDateRange","timestamp","date","Date","getTime","dayMs","dateMinusOne","datePlusOne","dateEarly","concat","getFullYear","getMonth","getDate","dateLate","earlyDate","lateDate","joinKQL","KQL","last_seen_time","cutKQL","buildKQLWithTimeRange","href","window","location","query","get","url","URL","includesALL","includes","timeFilterPresent","match","findTimeFilter","replace","searchParams","set","useQueryURL","copyUrl","navigator","clipboard","writeText","then","toast","success","i18n","t","position","autoClose","hideProgressBar","_parseEventData","parseEventData","firstseen","lastseen","total","default","createElement","className","onClick","FontAwesomeIcon","icon","faCopy","severity","point_name","start_time","time_zone","samplings","length","_default","exports"],"sources":["../../../../../src/pages/EventsPage/events/event_info/EventDetails.tsx"],"sourcesContent":["/* eslint-disable local-rules/no-hard-coded-jsx-literals */\nimport React from 'react';\nimport { IEvent } from 'src/store/events/models/IEvent';\nimport { IPointsState } from 'src/store/points/models/IPointsState';\nimport i18n from 'src/utilities/i18n';\nimport TimeFormat from 'src/utilities/TimeFormat';\nimport EarlyWarnings from './EarlyWarnings';\nimport Samplings from './samplingsOld/Samplings';\nimport { parseEventData } from '../events_list/EventUtils';\nimport useQueryURL from 'src/hooks/useQueryURL';\nimport { toast } from 'react-toastify';\nimport { FontAwesomeIcon } from '@fortawesome/react-fontawesome';\nimport { faCopy } from '@fortawesome/free-solid-svg-icons';\n\ntype IProps = {\n  event: IEvent;\n  points: IPointsState;\n};\n\nconst EventDetails: React.FC<IProps> = (props) => {\n  const { event, points } = props;\n\n  const buildDateRange = (timestamp) => {\n    let date = new Date(timestamp).getTime();\n    let dayMs = 86400000;\n    let dateMinusOne = new Date(date - dayMs);\n    let datePlusOne = new Date(date + dayMs);\n    let dateEarly = `${dateMinusOne.getFullYear()}-${\n      dateMinusOne.getMonth() + 1\n    }-${dateMinusOne.getDate()}`;\n    let dateLate = `${datePlusOne.getFullYear()}-${\n      datePlusOne.getMonth() + 1\n    }-${datePlusOne.getDate()}`;\n\n    return {\n      earlyDate: dateEarly,\n      lateDate: dateLate,\n    };\n  };\n\n  const joinKQL = (KQL: string) => {\n    KQL += ` TimeFilterItem IN ( ${\n      buildDateRange(event.last_seen_time).earlyDate\n    }:${buildDateRange(event.last_seen_time).lateDate} )`;\n\n    return KQL;\n  };\n\n  const cutKQL = (KQL: string) => {\n    KQL = `TimeFilterItem IN ( ${\n      buildDateRange(event.last_seen_time).earlyDate\n    }:${\n      buildDateRange(event.last_seen_time).lateDate\n    } ) ORDER_BY observed_upstream`;\n\n    return KQL;\n  };\n\n  const buildKQLWithTimeRange = () => {\n    const href = window.location.href;\n    let KQL = query.get('valuesFromKQL');\n    let url = new URL(href);\n\n    if (KQL === null) return url.href;\n\n    let includesALL = KQL.includes('ALL');\n    let timeFilterPresent = KQL.match('(?=TimeFilterItem)(.*?)(?:(\\\\)))');\n\n    if (timeFilterPresent) {\n      let findTimeFilter = timeFilterPresent;\n      if (findTimeFilter !== null) {\n        KQL = KQL.replace(findTimeFilter[0], ' ');\n      }\n\n      KQL = joinKQL(KQL);\n    } else {\n      KQL = includesALL ? cutKQL(KQL) : joinKQL(KQL);\n    }\n\n    url.searchParams.set('valuesFromKQL', KQL!);\n    return url.href;\n  };\n\n  const query = useQueryURL();\n  //eslint-disable-next-line\n  const copyUrl = () => {\n    navigator.clipboard.writeText(buildKQLWithTimeRange()).then(\n      () => {\n        toast.success(i18n.t('copy.success'), {\n          position: 'top-center',\n          autoClose: 1500,\n          hideProgressBar: true,\n        });\n      },\n      () => {\n        toast.success(i18n.t('copy.failed'), {\n          position: 'top-center',\n          autoClose: 1500,\n          hideProgressBar: true,\n        });\n      },\n    );\n  };\n\n  const { firstseen, lastseen, total } = parseEventData(event);\n\n  return (\n    <div className={'event-details event-info__card'}>\n      <div className=\"top\">\n        <div className=\"title\"> {i18n.t('events_overview.event_details')}</div>\n        <p\n          className=\"copy-button\"\n          onClick={() => {\n            copyUrl();\n          }}\n        >\n          <FontAwesomeIcon icon={faCopy} />\n        </p>\n      </div>\n      <div className=\"content\">\n        <div className={'event-info__detail event-info__event_severity'}>\n          <div className=\"box-title\">{i18n.t('events_overview.severity')}:</div>\n          <div className={'severities'}>\n            <p\n              className={`severities__severity severities__severity--0 severities__severity--0${\n                event.severity === '0' ? '--active' : ''\n              }`}\n            >\n              {i18n.t(`events_overview.severities.0`)}\n            </p>\n            <p\n              className={`severities__severity severities__severity--1 severities__severity--1${\n                event.severity === '1' ? '--active' : ''\n              }`}\n            >\n              {i18n.t(`events_overview.severities.1`)}\n            </p>\n            <p\n              className={`severities__severity severities__severity--2 severities__severity--2${\n                event.severity === '2' ? '--active' : ''\n              }`}\n            >\n              {i18n.t(`events_overview.severities.2`)}\n            </p>\n          </div>\n        </div>\n        <div\n          className={'event-info__detail event-info__detail__early-warnings'}\n        >\n          <EarlyWarnings event={event} />\n        </div>\n        <div className={'event-info__detail event-info__detail__seen'}>\n          <div className=\"box-title\">\n            {i18n.t('events_overview.first_seen')}:{' '}\n          </div>\n\n          <div>\n            <p>{firstseen.point_name}</p>\n            <span>\n              <TimeFormat\n                timestamp={firstseen.start_time}\n                time_zone={firstseen.time_zone}\n              />\n            </span>\n          </div>\n        </div>\n        <div className={'event-info__detail event-info__detail__seen'}>\n          <div className=\"box-title\">\n            {i18n.t('events_overview.last_seen')}:\n          </div>\n\n          <div>\n            <p>{lastseen.point_name}</p>\n            <span>\n              <TimeFormat\n                timestamp={lastseen.last_seen_time}\n                time_zone={lastseen.time_zone}\n              />\n            </span>\n          </div>\n        </div>\n        <div className={'event-info__detail event-info__detail__seen'}>\n          <div className=\"box-title\">\n            {i18n.t('events_overview.total_time')}:\n          </div>\n\n          <div className=\"total-time\">{total}</div>\n        </div>\n        {event?.samplings?.length > 0 && (\n          <div className={'event-info__detail'}>\n            <Samplings event={event} points={points} />\n          </div>\n        )}\n      </div>\n    </div>\n  );\n};\n\nexport default EventDetails;\n"],"mappings":";;;;;;;AACA,IAAAA,MAAA,GAAAC,sBAAA,CAAAC,OAAA;AAGA,IAAAC,KAAA,GAAAF,sBAAA,CAAAC,OAAA;AACA,IAAAE,WAAA,GAAAH,sBAAA,CAAAC,OAAA;AACA,IAAAG,cAAA,GAAAJ,sBAAA,CAAAC,OAAA;AACA,IAAAI,UAAA,GAAAL,sBAAA,CAAAC,OAAA;AACA,IAAAK,WAAA,GAAAL,OAAA;AACA,IAAAM,YAAA,GAAAP,sBAAA,CAAAC,OAAA;AACA,IAAAO,cAAA,GAAAP,OAAA;AACA,IAAAQ,iBAAA,GAAAR,OAAA;AACA,IAAAS,kBAAA,GAAAT,OAAA;AAZA;;AAmBA,IAAMU,YAA8B,GAAG,SAAjCA,YAA8BA,CAAIC,KAAK,EAAK;EAAA,IAAAC,gBAAA;EAChD,IAAQC,KAAK,GAAaF,KAAK,CAAvBE,KAAK;IAAEC,MAAM,GAAKH,KAAK,CAAhBG,MAAM;EAErB,IAAMC,cAAc,GAAG,SAAjBA,cAAcA,CAAIC,SAAS,EAAK;IACpC,IAAIC,IAAI,GAAG,IAAIC,IAAI,CAACF,SAAS,CAAC,CAACG,OAAO,CAAC,CAAC;IACxC,IAAIC,KAAK,GAAG,QAAQ;IACpB,IAAIC,YAAY,GAAG,IAAIH,IAAI,CAACD,IAAI,GAAGG,KAAK,CAAC;IACzC,IAAIE,WAAW,GAAG,IAAIJ,IAAI,CAACD,IAAI,GAAGG,KAAK,CAAC;IACxC,IAAIG,SAAS,MAAAC,MAAA,CAAMH,YAAY,CAACI,WAAW,CAAC,CAAC,OAAAD,MAAA,CAC3CH,YAAY,CAACK,QAAQ,CAAC,CAAC,GAAG,CAAC,OAAAF,MAAA,CACzBH,YAAY,CAACM,OAAO,CAAC,CAAC,CAAE;IAC5B,IAAIC,QAAQ,MAAAJ,MAAA,CAAMF,WAAW,CAACG,WAAW,CAAC,CAAC,OAAAD,MAAA,CACzCF,WAAW,CAACI,QAAQ,CAAC,CAAC,GAAG,CAAC,OAAAF,MAAA,CACxBF,WAAW,CAACK,OAAO,CAAC,CAAC,CAAE;IAE3B,OAAO;MACLE,SAAS,EAAEN,SAAS;MACpBO,QAAQ,EAAEF;IACZ,CAAC;EACH,CAAC;EAED,IAAMG,OAAO,GAAG,SAAVA,OAAOA,CAAIC,GAAW,EAAK;IAC/BA,GAAG,4BAAAR,MAAA,CACDT,cAAc,CAACF,KAAK,CAACoB,cAAc,CAAC,CAACJ,SAAS,OAAAL,MAAA,CAC5CT,cAAc,CAACF,KAAK,CAACoB,cAAc,CAAC,CAACH,QAAQ,OAAI;IAErD,OAAOE,GAAG;EACZ,CAAC;EAED,IAAME,MAAM,GAAG,SAATA,MAAMA,CAAIF,GAAW,EAAK;IAC9BA,GAAG,0BAAAR,MAAA,CACDT,cAAc,CAACF,KAAK,CAACoB,cAAc,CAAC,CAACJ,SAAS,OAAAL,MAAA,CAE9CT,cAAc,CAACF,KAAK,CAACoB,cAAc,CAAC,CAACH,QAAQ,kCAChB;IAE/B,OAAOE,GAAG;EACZ,CAAC;EAED,IAAMG,qBAAqB,GAAG,SAAxBA,qBAAqBA,CAAA,EAAS;IAClC,IAAMC,IAAI,GAAGC,MAAM,CAACC,QAAQ,CAACF,IAAI;IACjC,IAAIJ,GAAG,GAAGO,KAAK,CAACC,GAAG,CAAC,eAAe,CAAC;IACpC,IAAIC,GAAG,GAAG,IAAIC,GAAG,CAACN,IAAI,CAAC;IAEvB,IAAIJ,GAAG,KAAK,IAAI,EAAE,OAAOS,GAAG,CAACL,IAAI;IAEjC,IAAIO,WAAW,GAAGX,GAAG,CAACY,QAAQ,CAAC,KAAK,CAAC;IACrC,IAAIC,iBAAiB,GAAGb,GAAG,CAACc,KAAK,CAAC,kCAAkC,CAAC;IAErE,IAAID,iBAAiB,EAAE;MACrB,IAAIE,cAAc,GAAGF,iBAAiB;MACtC,IAAIE,cAAc,KAAK,IAAI,EAAE;QAC3Bf,GAAG,GAAGA,GAAG,CAACgB,OAAO,CAACD,cAAc,CAAC,CAAC,CAAC,EAAE,GAAG,CAAC;MAC3C;MAEAf,GAAG,GAAGD,OAAO,CAACC,GAAG,CAAC;IACpB,CAAC,MAAM;MACLA,GAAG,GAAGW,WAAW,GAAGT,MAAM,CAACF,GAAG,CAAC,GAAGD,OAAO,CAACC,GAAG,CAAC;IAChD;IAEAS,GAAG,CAACQ,YAAY,CAACC,GAAG,CAAC,eAAe,EAAElB,GAAI,CAAC;IAC3C,OAAOS,GAAG,CAACL,IAAI;EACjB,CAAC;EAED,IAAMG,KAAK,GAAG,IAAAY,oBAAW,EAAC,CAAC;EAC3B;EACA,IAAMC,OAAO,GAAG,SAAVA,OAAOA,CAAA,EAAS;IACpBC,SAAS,CAACC,SAAS,CAACC,SAAS,CAACpB,qBAAqB,CAAC,CAAC,CAAC,CAACqB,IAAI,CACzD,YAAM;MACJC,oBAAK,CAACC,OAAO,CAACC,aAAI,CAACC,CAAC,CAAC,cAAc,CAAC,EAAE;QACpCC,QAAQ,EAAE,YAAY;QACtBC,SAAS,EAAE,IAAI;QACfC,eAAe,EAAE;MACnB,CAAC,CAAC;IACJ,CAAC,EACD,YAAM;MACJN,oBAAK,CAACC,OAAO,CAACC,aAAI,CAACC,CAAC,CAAC,aAAa,CAAC,EAAE;QACnCC,QAAQ,EAAE,YAAY;QACtBC,SAAS,EAAE,IAAI;QACfC,eAAe,EAAE;MACnB,CAAC,CAAC;IACJ,CACF,CAAC;EACH,CAAC;EAED,IAAAC,eAAA,GAAuC,IAAAC,0BAAc,EAACpD,KAAK,CAAC;IAApDqD,SAAS,GAAAF,eAAA,CAATE,SAAS;IAAEC,QAAQ,GAAAH,eAAA,CAARG,QAAQ;IAAEC,KAAK,GAAAJ,eAAA,CAALI,KAAK;EAElC,oBACEtE,MAAA,CAAAuE,OAAA,CAAAC,aAAA;IAAKC,SAAS,EAAE;EAAiC,gBAC/CzE,MAAA,CAAAuE,OAAA,CAAAC,aAAA;IAAKC,SAAS,EAAC;EAAK,gBAClBzE,MAAA,CAAAuE,OAAA,CAAAC,aAAA;IAAKC,SAAS,EAAC;EAAO,GAAC,GAAC,EAACZ,aAAI,CAACC,CAAC,CAAC,+BAA+B,CAAO,CAAC,eACvE9D,MAAA,CAAAuE,OAAA,CAAAC,aAAA;IACEC,SAAS,EAAC,aAAa;IACvBC,OAAO,EAAE,SAAAA,QAAA,EAAM;MACbpB,OAAO,CAAC,CAAC;IACX;EAAE,gBAEFtD,MAAA,CAAAuE,OAAA,CAAAC,aAAA,CAAC9D,iBAAA,CAAAiE,eAAe;IAACC,IAAI,EAAEC;EAAO,CAAE,CAC/B,CACA,CAAC,eACN7E,MAAA,CAAAuE,OAAA,CAAAC,aAAA;IAAKC,SAAS,EAAC;EAAS,gBACtBzE,MAAA,CAAAuE,OAAA,CAAAC,aAAA;IAAKC,SAAS,EAAE;EAAgD,gBAC9DzE,MAAA,CAAAuE,OAAA,CAAAC,aAAA;IAAKC,SAAS,EAAC;EAAW,GAAEZ,aAAI,CAACC,CAAC,CAAC,0BAA0B,CAAC,EAAC,GAAM,CAAC,eACtE9D,MAAA,CAAAuE,OAAA,CAAAC,aAAA;IAAKC,SAAS,EAAE;EAAa,gBAC3BzE,MAAA,CAAAuE,OAAA,CAAAC,aAAA;IACEC,SAAS,yEAAA/C,MAAA,CACPX,KAAK,CAAC+D,QAAQ,KAAK,GAAG,GAAG,UAAU,GAAG,EAAE;EACvC,GAEFjB,aAAI,CAACC,CAAC,+BAA+B,CACrC,CAAC,eACJ9D,MAAA,CAAAuE,OAAA,CAAAC,aAAA;IACEC,SAAS,yEAAA/C,MAAA,CACPX,KAAK,CAAC+D,QAAQ,KAAK,GAAG,GAAG,UAAU,GAAG,EAAE;EACvC,GAEFjB,aAAI,CAACC,CAAC,+BAA+B,CACrC,CAAC,eACJ9D,MAAA,CAAAuE,OAAA,CAAAC,aAAA;IACEC,SAAS,yEAAA/C,MAAA,CACPX,KAAK,CAAC+D,QAAQ,KAAK,GAAG,GAAG,UAAU,GAAG,EAAE;EACvC,GAEFjB,aAAI,CAACC,CAAC,+BAA+B,CACrC,CACA,CACF,CAAC,eACN9D,MAAA,CAAAuE,OAAA,CAAAC,aAAA;IACEC,SAAS,EAAE;EAAwD,gBAEnEzE,MAAA,CAAAuE,OAAA,CAAAC,aAAA,CAACnE,cAAA,CAAAkE,OAAa;IAACxD,KAAK,EAAEA;EAAM,CAAE,CAC3B,CAAC,eACNf,MAAA,CAAAuE,OAAA,CAAAC,aAAA;IAAKC,SAAS,EAAE;EAA8C,gBAC5DzE,MAAA,CAAAuE,OAAA,CAAAC,aAAA;IAAKC,SAAS,EAAC;EAAW,GACvBZ,aAAI,CAACC,CAAC,CAAC,4BAA4B,CAAC,EAAC,GAAC,EAAC,GACrC,CAAC,eAEN9D,MAAA,CAAAuE,OAAA,CAAAC,aAAA,2BACExE,MAAA,CAAAuE,OAAA,CAAAC,aAAA,YAAIJ,SAAS,CAACW,UAAc,CAAC,eAC7B/E,MAAA,CAAAuE,OAAA,CAAAC,aAAA,4BACExE,MAAA,CAAAuE,OAAA,CAAAC,aAAA,CAACpE,WAAA,CAAAmE,OAAU;IACTrD,SAAS,EAAEkD,SAAS,CAACY,UAAW;IAChCC,SAAS,EAAEb,SAAS,CAACa;EAAU,CAChC,CACG,CACH,CACF,CAAC,eACNjF,MAAA,CAAAuE,OAAA,CAAAC,aAAA;IAAKC,SAAS,EAAE;EAA8C,gBAC5DzE,MAAA,CAAAuE,OAAA,CAAAC,aAAA;IAAKC,SAAS,EAAC;EAAW,GACvBZ,aAAI,CAACC,CAAC,CAAC,2BAA2B,CAAC,EAAC,GAClC,CAAC,eAEN9D,MAAA,CAAAuE,OAAA,CAAAC,aAAA,2BACExE,MAAA,CAAAuE,OAAA,CAAAC,aAAA,YAAIH,QAAQ,CAACU,UAAc,CAAC,eAC5B/E,MAAA,CAAAuE,OAAA,CAAAC,aAAA,4BACExE,MAAA,CAAAuE,OAAA,CAAAC,aAAA,CAACpE,WAAA,CAAAmE,OAAU;IACTrD,SAAS,EAAEmD,QAAQ,CAAClC,cAAe;IACnC8C,SAAS,EAAEZ,QAAQ,CAACY;EAAU,CAC/B,CACG,CACH,CACF,CAAC,eACNjF,MAAA,CAAAuE,OAAA,CAAAC,aAAA;IAAKC,SAAS,EAAE;EAA8C,gBAC5DzE,MAAA,CAAAuE,OAAA,CAAAC,aAAA;IAAKC,SAAS,EAAC;EAAW,GACvBZ,aAAI,CAACC,CAAC,CAAC,4BAA4B,CAAC,EAAC,GACnC,CAAC,eAEN9D,MAAA,CAAAuE,OAAA,CAAAC,aAAA;IAAKC,SAAS,EAAC;EAAY,GAAEH,KAAW,CACrC,CAAC,EACL,CAAAvD,KAAK,aAALA,KAAK,wBAAAD,gBAAA,GAALC,KAAK,CAAEmE,SAAS,cAAApE,gBAAA,uBAAhBA,gBAAA,CAAkBqE,MAAM,IAAG,CAAC,iBAC3BnF,MAAA,CAAAuE,OAAA,CAAAC,aAAA;IAAKC,SAAS,EAAE;EAAqB,gBACnCzE,MAAA,CAAAuE,OAAA,CAAAC,aAAA,CAAClE,UAAA,CAAAiE,OAAS;IAACxD,KAAK,EAAEA,KAAM;IAACC,MAAM,EAAEA;EAAO,CAAE,CACvC,CAEJ,CACF,CAAC;AAEV,CAAC;AAAC,IAAAoE,QAAA,GAEaxE,YAAY;AAAAyE,OAAA,CAAAd,OAAA,GAAAa,QAAA"}
|