@kando-env/kando-ui 1.2.466 → 1.2.467-alpha.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/Router.js +7 -5
- package/lib/Widgets/Map/Map.js +3 -3
- package/lib/Widgets/Map/MapUtils.js +2 -1
- package/lib/assets/streami-logo.svg +26 -0
- package/lib/components/DischargeHeatmap/mocks/handlers.js +3 -3
- package/lib/components/Header/Toolbar/Toolbar.js +3 -6
- package/lib/components/KandoModal/KandoModal.js +27 -4
- package/lib/components/KandoModal/styles.scss +4 -0
- package/lib/components/SeasonalInsights/SeasonalInsights.js +220 -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 +227 -0
- package/lib/components/TopBanner/insightsDismissalStorage.js +36 -0
- package/lib/i18n/en.json +24 -3
- package/lib/i18n/fr.json +13 -0
- package/lib/i18n/he.json +21 -1
- package/lib/i18n/it.json +13 -0
- package/lib/macros/getVersion.js +2 -2
- package/lib/pages/AreaPage/Dashboard/Dashboard.js +2 -2
- package/lib/pages/EventsPage/events/EventsStyle.scss +1 -1
- 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/SamplingsPage/SamplingProperties/SamplingProperties.js +9 -4
- 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 +1 -1
|
@@ -0,0 +1,227 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
var _typeof = require("@babel/runtime/helpers/typeof");
|
|
5
|
+
Object.defineProperty(exports, "__esModule", {
|
|
6
|
+
value: true
|
|
7
|
+
});
|
|
8
|
+
exports.default = void 0;
|
|
9
|
+
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
|
|
10
|
+
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/asyncToGenerator"));
|
|
11
|
+
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/esm/slicedToArray"));
|
|
12
|
+
var _styledComponents = _interopRequireDefault(require("styled-components"));
|
|
13
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
14
|
+
var _KandoModal = _interopRequireDefault(require("../KandoModal"));
|
|
15
|
+
var _SeasonalInsights = _interopRequireDefault(require("../SeasonalInsights/SeasonalInsights"));
|
|
16
|
+
var _i18next = _interopRequireDefault(require("i18next"));
|
|
17
|
+
var _insightsDismissalStorage = require("./insightsDismissalStorage");
|
|
18
|
+
var _Analytics = require("utilities/Analytics");
|
|
19
|
+
var _reactRedux = require("react-redux");
|
|
20
|
+
var _useNavContext2 = require("hooks/useNavContext");
|
|
21
|
+
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
22
|
+
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
23
|
+
var INSIGHT_TYPE = 'seasonal_insight';
|
|
24
|
+
var TopBanner = function TopBanner(_ref) {
|
|
25
|
+
var _ref$backgroundColor = _ref.backgroundColor,
|
|
26
|
+
backgroundColor = _ref$backgroundColor === void 0 ? 'rgb(217, 234, 255)' : _ref$backgroundColor,
|
|
27
|
+
_ref$text = _ref.text,
|
|
28
|
+
text = _ref$text === void 0 ? '' : _ref$text,
|
|
29
|
+
onVisibilityChange = _ref.onVisibilityChange,
|
|
30
|
+
apiEndpoint = _ref.apiEndpoint;
|
|
31
|
+
var _useState = (0, _react.useState)(true),
|
|
32
|
+
_useState2 = (0, _slicedToArray2.default)(_useState, 2),
|
|
33
|
+
visible = _useState2[0],
|
|
34
|
+
setVisible = _useState2[1];
|
|
35
|
+
var _useState3 = (0, _react.useState)(false),
|
|
36
|
+
_useState4 = (0, _slicedToArray2.default)(_useState3, 2),
|
|
37
|
+
showModal = _useState4[0],
|
|
38
|
+
setShowModal = _useState4[1];
|
|
39
|
+
var _useState5 = (0, _react.useState)(null),
|
|
40
|
+
_useState6 = (0, _slicedToArray2.default)(_useState5, 2),
|
|
41
|
+
insightData = _useState6[0],
|
|
42
|
+
setInsightData = _useState6[1];
|
|
43
|
+
var bannerHeight = 30; // px
|
|
44
|
+
var _useNavContext = (0, _useNavContext2.useNavContext)(),
|
|
45
|
+
dir = _useNavContext.dir;
|
|
46
|
+
var _useSelector = (0, _reactRedux.useSelector)(function (state) {
|
|
47
|
+
return state.global_data;
|
|
48
|
+
}),
|
|
49
|
+
waterAuthorityName = _useSelector.waterAuthorityName;
|
|
50
|
+
var titleText = String(_i18next.default.t('seasonal_insights.title'));
|
|
51
|
+
var learnMoreText = String(_i18next.default.t('seasonal_insights.learn_more'));
|
|
52
|
+
var dismissTooltipText = String(_i18next.default.t('seasonal_insights.dismiss_tooltip'));
|
|
53
|
+
|
|
54
|
+
// On mount or when insight id changes, check localStorage for dismissal
|
|
55
|
+
(0, _react.useEffect)(function () {
|
|
56
|
+
// If we have insight data with an id, check if it was dismissed
|
|
57
|
+
if ((insightData === null || insightData === void 0 ? void 0 : insightData.id) !== undefined) {
|
|
58
|
+
try {
|
|
59
|
+
var record = (0, _insightsDismissalStorage.getDismissal)(INSIGHT_TYPE);
|
|
60
|
+
var dismissed = (record === null || record === void 0 ? void 0 : record.lastDismissedId) === String(insightData.id);
|
|
61
|
+
setVisible(!dismissed);
|
|
62
|
+
} catch (_unused) {
|
|
63
|
+
setVisible(true);
|
|
64
|
+
}
|
|
65
|
+
} else if (insightData === null) {
|
|
66
|
+
// No insight data - hide banner if using API, show if using static text prop
|
|
67
|
+
if (apiEndpoint) {
|
|
68
|
+
// API endpoint exists but no data returned - hide banner
|
|
69
|
+
setVisible(false);
|
|
70
|
+
} else {
|
|
71
|
+
// No API endpoint - show banner if text is provided
|
|
72
|
+
setVisible(!!text);
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
}, [insightData === null || insightData === void 0 ? void 0 : insightData.id, insightData, apiEndpoint, text]);
|
|
76
|
+
|
|
77
|
+
// Fetch data from API if endpoint is provided, robustly
|
|
78
|
+
(0, _react.useEffect)(function () {
|
|
79
|
+
if (!apiEndpoint) return;
|
|
80
|
+
var controller = new AbortController();
|
|
81
|
+
fetch(apiEndpoint, {
|
|
82
|
+
signal: controller.signal
|
|
83
|
+
}).then( /*#__PURE__*/function () {
|
|
84
|
+
var _ref2 = (0, _asyncToGenerator2.default)( /*#__PURE__*/_regenerator.default.mark(function _callee(res) {
|
|
85
|
+
return _regenerator.default.wrap(function _callee$(_context) {
|
|
86
|
+
while (1) {
|
|
87
|
+
switch (_context.prev = _context.next) {
|
|
88
|
+
case 0:
|
|
89
|
+
if (!(res.status === 404)) {
|
|
90
|
+
_context.next = 2;
|
|
91
|
+
break;
|
|
92
|
+
}
|
|
93
|
+
return _context.abrupt("return", {
|
|
94
|
+
error: 'not_found'
|
|
95
|
+
});
|
|
96
|
+
case 2:
|
|
97
|
+
if (res.ok) {
|
|
98
|
+
_context.next = 4;
|
|
99
|
+
break;
|
|
100
|
+
}
|
|
101
|
+
throw new Error("Request failed (".concat(res.status, ")"));
|
|
102
|
+
case 4:
|
|
103
|
+
_context.next = 6;
|
|
104
|
+
return res.json();
|
|
105
|
+
case 6:
|
|
106
|
+
return _context.abrupt("return", _context.sent);
|
|
107
|
+
case 7:
|
|
108
|
+
case "end":
|
|
109
|
+
return _context.stop();
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
}, _callee);
|
|
113
|
+
}));
|
|
114
|
+
return function (_x) {
|
|
115
|
+
return _ref2.apply(this, arguments);
|
|
116
|
+
};
|
|
117
|
+
}()).then(function (data) {
|
|
118
|
+
// When the API says not_found, do not show the banner.
|
|
119
|
+
if ((data === null || data === void 0 ? void 0 : data.error) === 'not_found') {
|
|
120
|
+
setInsightData(null);
|
|
121
|
+
setVisible(false);
|
|
122
|
+
return;
|
|
123
|
+
}
|
|
124
|
+
setInsightData(data);
|
|
125
|
+
}).catch(function (err) {
|
|
126
|
+
// On fetch error, hide the banner (no data to show)
|
|
127
|
+
if ((err === null || err === void 0 ? void 0 : err.name) !== 'AbortError') {
|
|
128
|
+
setInsightData(null);
|
|
129
|
+
setVisible(false);
|
|
130
|
+
}
|
|
131
|
+
});
|
|
132
|
+
return function () {
|
|
133
|
+
return controller.abort();
|
|
134
|
+
};
|
|
135
|
+
}, [apiEndpoint, text]);
|
|
136
|
+
|
|
137
|
+
// Notify parent on visibility change
|
|
138
|
+
(0, _react.useEffect)(function () {
|
|
139
|
+
if (onVisibilityChange) onVisibilityChange(visible);
|
|
140
|
+
}, [visible]);
|
|
141
|
+
|
|
142
|
+
// When dismissed, persist in localStorage
|
|
143
|
+
var handleDismiss = function handleDismiss() {
|
|
144
|
+
(0, _Analytics.analyticsTrack)('seasonal_insight_dismissed', {
|
|
145
|
+
id: insightData === null || insightData === void 0 ? void 0 : insightData.id,
|
|
146
|
+
utility_name: waterAuthorityName
|
|
147
|
+
});
|
|
148
|
+
setVisible(false);
|
|
149
|
+
if ((insightData === null || insightData === void 0 ? void 0 : insightData.id) === undefined) return;
|
|
150
|
+
try {
|
|
151
|
+
(0, _insightsDismissalStorage.setDismissal)(INSIGHT_TYPE, String(insightData.id));
|
|
152
|
+
} catch (_unused2) {
|
|
153
|
+
// ignore storage errors
|
|
154
|
+
}
|
|
155
|
+
};
|
|
156
|
+
var openModal = function openModal() {
|
|
157
|
+
setShowModal(true);
|
|
158
|
+
(0, _Analytics.analyticsTrack)('Clicked seasonal_insight', {
|
|
159
|
+
id: insightData === null || insightData === void 0 ? void 0 : insightData.id,
|
|
160
|
+
utility_name: waterAuthorityName
|
|
161
|
+
});
|
|
162
|
+
};
|
|
163
|
+
var closeModal = function closeModal() {
|
|
164
|
+
setShowModal(false);
|
|
165
|
+
};
|
|
166
|
+
var modal = (0, _react.useMemo)(function () {
|
|
167
|
+
if (!showModal) return null;
|
|
168
|
+
return /*#__PURE__*/_react.default.createElement(_KandoModal.default, {
|
|
169
|
+
isOpen: showModal,
|
|
170
|
+
onClose: closeModal
|
|
171
|
+
}, /*#__PURE__*/_react.default.createElement(_SeasonalInsights.default, {
|
|
172
|
+
data: insightData
|
|
173
|
+
}));
|
|
174
|
+
}, [showModal]);
|
|
175
|
+
if (!visible || !apiEndpoint) {
|
|
176
|
+
return null;
|
|
177
|
+
}
|
|
178
|
+
return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement(BannerContainer, {
|
|
179
|
+
backgroundColor: backgroundColor,
|
|
180
|
+
bannerHeight: bannerHeight
|
|
181
|
+
}, /*#__PURE__*/_react.default.createElement("span", null, apiEndpoint && /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, /*#__PURE__*/_react.default.createElement("span", {
|
|
182
|
+
style: {
|
|
183
|
+
filter: 'drop-shadow(0 0 2px rgba(0, 0, 0, 0.3))',
|
|
184
|
+
fontSize: '16px',
|
|
185
|
+
display: 'inline-block',
|
|
186
|
+
marginRight: '4px'
|
|
187
|
+
}
|
|
188
|
+
}, "\u2728"), titleText, ' ', /*#__PURE__*/_react.default.createElement("span", {
|
|
189
|
+
onClick: openModal,
|
|
190
|
+
style: {
|
|
191
|
+
textDecoration: 'underline',
|
|
192
|
+
cursor: 'pointer'
|
|
193
|
+
}
|
|
194
|
+
}, learnMoreText))), /*#__PURE__*/_react.default.createElement(DismissButton, {
|
|
195
|
+
onClick: handleDismiss,
|
|
196
|
+
"aria-label": 'dismissTooltip',
|
|
197
|
+
className: "kd-tooltip",
|
|
198
|
+
"data-text": dismissTooltipText,
|
|
199
|
+
isRtl: dir === 'rtl'
|
|
200
|
+
}, "\xD7")), modal);
|
|
201
|
+
};
|
|
202
|
+
var DismissButton = _styledComponents.default.button.withConfig({
|
|
203
|
+
displayName: "TopBanner__DismissButton",
|
|
204
|
+
componentId: "sc-1towuq0-0"
|
|
205
|
+
})(["position:absolute;", " background:transparent;border:none;font-size:24px;cursor:pointer;&.kd-tooltip{&[data-text]::after{content:attr(data-text);position:absolute;color:white;background-color:rgba(0,0,0,0.9);border-radius:5px;top:16px;", " padding:4px 6px;opacity:0;visibility:hidden;pointer-events:none;transition:opacity 0.15s ease-in-out,visibility 0.15s ease-in-out;white-space:nowrap;font-size:12px;}&:hover{&[data-text]::after{z-index:-1;opacity:1;visibility:visible;}}}"], function (_ref3) {
|
|
206
|
+
var isRtl = _ref3.isRtl;
|
|
207
|
+
return isRtl ? 'left: 10px; right: auto;' : 'right: 10px; left: auto;';
|
|
208
|
+
}, function (_ref4) {
|
|
209
|
+
var isRtl = _ref4.isRtl;
|
|
210
|
+
return isRtl ? 'left: 22px;' : 'right: 22px;';
|
|
211
|
+
});
|
|
212
|
+
var BannerContainer = _styledComponents.default.div.withConfig({
|
|
213
|
+
displayName: "TopBanner__BannerContainer",
|
|
214
|
+
componentId: "sc-1towuq0-1"
|
|
215
|
+
})(["width:100%;background:", ";padding:8px;text-align:center;position:sticky;top:0;z-index:1200;box-sizing:border-box;min-height:", ";height:", ";display:flex;align-items:center;justify-content:center;font-size:14px;cursor:default;"], function (_ref5) {
|
|
216
|
+
var backgroundColor = _ref5.backgroundColor;
|
|
217
|
+
return backgroundColor;
|
|
218
|
+
}, function (_ref6) {
|
|
219
|
+
var bannerHeight = _ref6.bannerHeight;
|
|
220
|
+
return "".concat(bannerHeight, "px");
|
|
221
|
+
}, function (_ref7) {
|
|
222
|
+
var bannerHeight = _ref7.bannerHeight;
|
|
223
|
+
return "".concat(bannerHeight, "px");
|
|
224
|
+
});
|
|
225
|
+
var _default = TopBanner;
|
|
226
|
+
exports.default = _default;
|
|
227
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_KandoModal","_interopRequireDefault","_SeasonalInsights","_i18next","_insightsDismissalStorage","_Analytics","_reactRedux","_useNavContext2","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","_typeof","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","INSIGHT_TYPE","TopBanner","_ref","_ref$backgroundColor","backgroundColor","_ref$text","text","onVisibilityChange","apiEndpoint","_useState","useState","_useState2","_slicedToArray2","visible","setVisible","_useState3","_useState4","showModal","setShowModal","_useState5","_useState6","insightData","setInsightData","bannerHeight","_useNavContext","useNavContext","dir","_useSelector","useSelector","state","global_data","waterAuthorityName","titleText","String","i18next","t","learnMoreText","dismissTooltipText","useEffect","id","undefined","record","getDismissal","dismissed","lastDismissedId","_unused","controller","AbortController","fetch","signal","then","_ref2","_asyncToGenerator2","_regenerator","mark","_callee","res","wrap","_callee$","_context","prev","next","status","abrupt","error","ok","Error","concat","json","sent","stop","_x","apply","arguments","data","catch","err","name","abort","handleDismiss","analyticsTrack","utility_name","setDismissal","_unused2","openModal","closeModal","modal","useMemo","createElement","isOpen","onClose","Fragment","BannerContainer","style","filter","fontSize","display","marginRight","onClick","textDecoration","cursor","DismissButton","className","isRtl","styled","button","withConfig","displayName","componentId","_ref3","_ref4","div","_ref5","_ref6","_ref7","_default","exports"],"sources":["../../../src/components/TopBanner/TopBanner.tsx"],"sourcesContent":["import React, { useState, useEffect, useMemo } from 'react';\nimport styled from 'styled-components/macro';\nimport KandoModal from '../KandoModal';\nimport SeasonalInsights, {\n  SeasonalInsightResponse,\n} from '../SeasonalInsights/SeasonalInsights';\nimport i18next from 'i18next';\nimport {\n  getDismissal,\n  setDismissal,\n  InsightType,\n} from './insightsDismissalStorage';\nimport { analyticsTrack } from 'src/utilities/Analytics';\nimport { useSelector } from 'react-redux';\nimport { useNavContext } from 'src/hooks/useNavContext';\n\ninterface TopBannerProps {\n  backgroundColor?: string;\n  text?: React.ReactNode;\n  onVisibilityChange?: (visible: boolean) => void;\n  apiEndpoint?: string; // Add this prop for API endpoint\n}\n\nconst INSIGHT_TYPE: InsightType = 'seasonal_insight';\n\nconst TopBanner: React.FC<TopBannerProps> = ({\n  backgroundColor = 'rgb(217, 234, 255)', // #f5b7c5',\n  text = '',\n  onVisibilityChange,\n  apiEndpoint,\n}) => {\n  const [visible, setVisible] = useState(true);\n  const [showModal, setShowModal] = useState(false);\n  const [insightData, setInsightData] =\n    useState<SeasonalInsightResponse | null>(null);\n\n  const bannerHeight = 30; // px\n  const { dir } = useNavContext();\n  const { waterAuthorityName } = useSelector((state) => state.global_data);\n\n  const titleText = String(i18next.t('seasonal_insights.title'));\n  const learnMoreText = String(i18next.t('seasonal_insights.learn_more'));\n  const dismissTooltipText = String(\n    i18next.t('seasonal_insights.dismiss_tooltip'),\n  );\n\n  // On mount or when insight id changes, check localStorage for dismissal\n  useEffect(() => {\n    // If we have insight data with an id, check if it was dismissed\n    if (insightData?.id !== undefined) {\n      try {\n        const record = getDismissal(INSIGHT_TYPE);\n        const dismissed = record?.lastDismissedId === String(insightData.id);\n        setVisible(!dismissed);\n      } catch {\n        setVisible(true);\n      }\n    } else if (insightData === null) {\n      // No insight data - hide banner if using API, show if using static text prop\n      if (apiEndpoint) {\n        // API endpoint exists but no data returned - hide banner\n        setVisible(false);\n      } else {\n        // No API endpoint - show banner if text is provided\n        setVisible(!!text);\n      }\n    }\n  }, [insightData?.id, insightData, apiEndpoint, text]);\n\n  // Fetch data from API if endpoint is provided, robustly\n  useEffect(() => {\n    if (!apiEndpoint) return;\n\n    const controller = new AbortController();\n\n    fetch(apiEndpoint, { signal: controller.signal })\n      .then(async (res) => {\n        if (res.status === 404) {\n          // API explicitly says there is no seasonal insight.\n          return { error: 'not_found' } as unknown as SeasonalInsightResponse;\n        }\n        if (!res.ok) {\n          throw new Error(`Request failed (${res.status})`);\n        }\n        return (await res.json()) as SeasonalInsightResponse;\n      })\n      .then((data) => {\n        // When the API says not_found, do not show the banner.\n        if ((data as any)?.error === 'not_found') {\n          setInsightData(null);\n          setVisible(false);\n          return;\n        }\n        setInsightData(data);\n      })\n      .catch((err) => {\n        // On fetch error, hide the banner (no data to show)\n        if (err?.name !== 'AbortError') {\n          setInsightData(null);\n          setVisible(false);\n        }\n      });\n\n    return () => controller.abort();\n  }, [apiEndpoint, text]);\n\n  // Notify parent on visibility change\n  useEffect(() => {\n    if (onVisibilityChange) onVisibilityChange(visible);\n  }, [visible]);\n\n  // When dismissed, persist in localStorage\n  const handleDismiss = () => {\n    analyticsTrack('seasonal_insight_dismissed', {\n      id: insightData?.id,\n      utility_name: waterAuthorityName,\n    });\n    setVisible(false);\n    if (insightData?.id === undefined) return;\n\n    try {\n      setDismissal(INSIGHT_TYPE, String(insightData.id));\n    } catch {\n      // ignore storage errors\n    }\n  };\n\n  const openModal = () => {\n    setShowModal(true);\n    analyticsTrack('Clicked seasonal_insight', {\n      id: insightData?.id,\n      utility_name: waterAuthorityName,\n    });\n  };\n\n  const closeModal = () => {\n    setShowModal(false);\n  };\n\n  const modal = useMemo(() => {\n    if (!showModal) return null;\n    return (\n      <KandoModal isOpen={showModal} onClose={closeModal}>\n        <SeasonalInsights data={insightData} />\n      </KandoModal>\n    );\n  }, [showModal]);\n\n  if (!visible || !apiEndpoint) {\n    return null;\n  }\n\n  return (\n    <>\n      <BannerContainer\n        backgroundColor={backgroundColor}\n        bannerHeight={bannerHeight}\n      >\n        <span>\n          {apiEndpoint && (\n            <>\n              <span\n                style={{\n                  filter: 'drop-shadow(0 0 2px rgba(0, 0, 0, 0.3))',\n                  fontSize: '16px',\n                  display: 'inline-block',\n                  marginRight: '4px',\n                }}\n              >\n                ✨\n              </span>\n              {titleText}{' '}\n              <span\n                onClick={openModal}\n                style={{\n                  textDecoration: 'underline',\n                  cursor: 'pointer',\n                }}\n              >\n                {learnMoreText}\n              </span>\n            </>\n          )}\n        </span>\n        <DismissButton\n          onClick={handleDismiss}\n          aria-label={'dismissTooltip'}\n          className=\"kd-tooltip\"\n          data-text={dismissTooltipText}\n          isRtl={dir === 'rtl'}\n        >\n          ×\n        </DismissButton>\n      </BannerContainer>\n      {modal}\n    </>\n  );\n};\n\nconst DismissButton = styled.button<{ isRtl: boolean }>`\n  position: absolute;\n  ${({ isRtl }) =>\n    isRtl ? 'left: 10px; right: auto;' : 'right: 10px; left: auto;'}\n  background: transparent;\n  border: none;\n  font-size: 24px;\n  cursor: pointer;\n\n  &.kd-tooltip {\n    &[data-text]::after {\n      content: attr(data-text);\n      position: absolute;\n      color: white;\n      background-color: rgba(0, 0, 0, 0.9);\n      border-radius: 5px;\n      top: 16px;\n      ${({ isRtl }) => (isRtl ? 'left: 22px;' : 'right: 22px;')}\n      padding: 4px 6px;\n      opacity: 0;\n      visibility: hidden;\n      pointer-events: none;\n      transition: opacity 0.15s ease-in-out, visibility 0.15s ease-in-out;\n      white-space: nowrap;\n      font-size: 12px;\n    }\n    &:hover {\n      &[data-text]::after {\n        z-index: -1;\n        opacity: 1;\n        visibility: visible;\n      }\n    }\n  }\n`;\n\nconst BannerContainer = styled.div<{\n  backgroundColor: string;\n  bannerHeight: number;\n}>`\n  width: 100%;\n  background: ${({ backgroundColor }) => backgroundColor};\n  padding: 8px;\n  text-align: center;\n  position: sticky;\n  top: 0;\n  z-index: 1200;\n  box-sizing: border-box;\n  min-height: ${({ bannerHeight }) => `${bannerHeight}px`};\n  height: ${({ bannerHeight }) => `${bannerHeight}px`};\n  display: flex;\n  align-items: center;\n  justify-content: center;\n  font-size: 14px;\n  cursor: default;\n`;\n\nexport default TopBanner;\n"],"mappings":"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"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.getDismissal = getDismissal;
|
|
7
|
+
exports.setDismissal = setDismissal;
|
|
8
|
+
var STORAGE_PREFIX = 'TopBannerDismissed';
|
|
9
|
+
var buildKey = function buildKey(type) {
|
|
10
|
+
return "".concat(STORAGE_PREFIX, ":").concat(type);
|
|
11
|
+
};
|
|
12
|
+
function getDismissal(type) {
|
|
13
|
+
try {
|
|
14
|
+
var raw = localStorage.getItem(buildKey(type));
|
|
15
|
+
if (!raw) return null;
|
|
16
|
+
var parsed = JSON.parse(raw);
|
|
17
|
+
if (!parsed || typeof parsed.lastDismissedId !== 'string') {
|
|
18
|
+
return null;
|
|
19
|
+
}
|
|
20
|
+
return parsed;
|
|
21
|
+
} catch (_unused) {
|
|
22
|
+
return null;
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
function setDismissal(type, id) {
|
|
26
|
+
var record = {
|
|
27
|
+
lastDismissedId: id,
|
|
28
|
+
dismissedAt: new Date().toISOString()
|
|
29
|
+
};
|
|
30
|
+
try {
|
|
31
|
+
localStorage.setItem(buildKey(type), JSON.stringify(record));
|
|
32
|
+
} catch (_unused2) {
|
|
33
|
+
// ignore storage errors
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJTVE9SQUdFX1BSRUZJWCIsImJ1aWxkS2V5IiwidHlwZSIsImNvbmNhdCIsImdldERpc21pc3NhbCIsInJhdyIsImxvY2FsU3RvcmFnZSIsImdldEl0ZW0iLCJwYXJzZWQiLCJKU09OIiwicGFyc2UiLCJsYXN0RGlzbWlzc2VkSWQiLCJfdW51c2VkIiwic2V0RGlzbWlzc2FsIiwiaWQiLCJyZWNvcmQiLCJkaXNtaXNzZWRBdCIsIkRhdGUiLCJ0b0lTT1N0cmluZyIsInNldEl0ZW0iLCJzdHJpbmdpZnkiLCJfdW51c2VkMiJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jb21wb25lbnRzL1RvcEJhbm5lci9pbnNpZ2h0c0Rpc21pc3NhbFN0b3JhZ2UudHMiXSwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHR5cGUgSW5zaWdodFR5cGUgPSAnc2Vhc29uYWxfaW5zaWdodCc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgSW5zaWdodERpc21pc3NhbFJlY29yZCB7XG4gIGxhc3REaXNtaXNzZWRJZDogc3RyaW5nO1xuICBkaXNtaXNzZWRBdD86IHN0cmluZztcbn1cblxuY29uc3QgU1RPUkFHRV9QUkVGSVggPSAnVG9wQmFubmVyRGlzbWlzc2VkJztcblxuY29uc3QgYnVpbGRLZXkgPSAodHlwZTogSW5zaWdodFR5cGUpID0+IGAke1NUT1JBR0VfUFJFRklYfToke3R5cGV9YDtcblxuZXhwb3J0IGZ1bmN0aW9uIGdldERpc21pc3NhbCh0eXBlOiBJbnNpZ2h0VHlwZSk6IEluc2lnaHREaXNtaXNzYWxSZWNvcmQgfCBudWxsIHtcbiAgdHJ5IHtcbiAgICBjb25zdCByYXcgPSBsb2NhbFN0b3JhZ2UuZ2V0SXRlbShidWlsZEtleSh0eXBlKSk7XG4gICAgaWYgKCFyYXcpIHJldHVybiBudWxsO1xuXG4gICAgY29uc3QgcGFyc2VkID0gSlNPTi5wYXJzZShyYXcpIGFzIFBhcnRpYWw8SW5zaWdodERpc21pc3NhbFJlY29yZD47XG4gICAgaWYgKCFwYXJzZWQgfHwgdHlwZW9mIHBhcnNlZC5sYXN0RGlzbWlzc2VkSWQgIT09ICdzdHJpbmcnKSB7XG4gICAgICByZXR1cm4gbnVsbDtcbiAgICB9XG5cbiAgICByZXR1cm4gcGFyc2VkIGFzIEluc2lnaHREaXNtaXNzYWxSZWNvcmQ7XG4gIH0gY2F0Y2gge1xuICAgIHJldHVybiBudWxsO1xuICB9XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBzZXREaXNtaXNzYWwodHlwZTogSW5zaWdodFR5cGUsIGlkOiBzdHJpbmcpIHtcbiAgY29uc3QgcmVjb3JkOiBJbnNpZ2h0RGlzbWlzc2FsUmVjb3JkID0ge1xuICAgIGxhc3REaXNtaXNzZWRJZDogaWQsXG4gICAgZGlzbWlzc2VkQXQ6IG5ldyBEYXRlKCkudG9JU09TdHJpbmcoKSxcbiAgfTtcblxuICB0cnkge1xuICAgIGxvY2FsU3RvcmFnZS5zZXRJdGVtKGJ1aWxkS2V5KHR5cGUpLCBKU09OLnN0cmluZ2lmeShyZWNvcmQpKTtcbiAgfSBjYXRjaCB7XG4gICAgLy8gaWdub3JlIHN0b3JhZ2UgZXJyb3JzXG4gIH1cbn1cbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQU9BLElBQU1BLGNBQWMsR0FBRyxvQkFBb0I7QUFFM0MsSUFBTUMsUUFBUSxHQUFHLFNBQVhBLFFBQVFBLENBQUlDLElBQWlCO0VBQUEsVUFBQUMsTUFBQSxDQUFRSCxjQUFjLE9BQUFHLE1BQUEsQ0FBSUQsSUFBSTtBQUFBLENBQUU7QUFFNUQsU0FBU0UsWUFBWUEsQ0FBQ0YsSUFBaUIsRUFBaUM7RUFDN0UsSUFBSTtJQUNGLElBQU1HLEdBQUcsR0FBR0MsWUFBWSxDQUFDQyxPQUFPLENBQUNOLFFBQVEsQ0FBQ0MsSUFBSSxDQUFDLENBQUM7SUFDaEQsSUFBSSxDQUFDRyxHQUFHLEVBQUUsT0FBTyxJQUFJO0lBRXJCLElBQU1HLE1BQU0sR0FBR0MsSUFBSSxDQUFDQyxLQUFLLENBQUNMLEdBQUcsQ0FBb0M7SUFDakUsSUFBSSxDQUFDRyxNQUFNLElBQUksT0FBT0EsTUFBTSxDQUFDRyxlQUFlLEtBQUssUUFBUSxFQUFFO01BQ3pELE9BQU8sSUFBSTtJQUNiO0lBRUEsT0FBT0gsTUFBTTtFQUNmLENBQUMsQ0FBQyxPQUFBSSxPQUFBLEVBQU07SUFDTixPQUFPLElBQUk7RUFDYjtBQUNGO0FBRU8sU0FBU0MsWUFBWUEsQ0FBQ1gsSUFBaUIsRUFBRVksRUFBVSxFQUFFO0VBQzFELElBQU1DLE1BQThCLEdBQUc7SUFDckNKLGVBQWUsRUFBRUcsRUFBRTtJQUNuQkUsV0FBVyxFQUFFLElBQUlDLElBQUksQ0FBQyxDQUFDLENBQUNDLFdBQVcsQ0FBQztFQUN0QyxDQUFDO0VBRUQsSUFBSTtJQUNGWixZQUFZLENBQUNhLE9BQU8sQ0FBQ2xCLFFBQVEsQ0FBQ0MsSUFBSSxDQUFDLEVBQUVPLElBQUksQ0FBQ1csU0FBUyxDQUFDTCxNQUFNLENBQUMsQ0FBQztFQUM5RCxDQUFDLENBQUMsT0FBQU0sUUFBQSxFQUFNO0lBQ047RUFBQTtBQUVKIn0=
|
package/lib/i18n/en.json
CHANGED
|
@@ -128,7 +128,7 @@
|
|
|
128
128
|
"monitors": "Dataloggers",
|
|
129
129
|
"systems": "Systems Management",
|
|
130
130
|
"project_management": "Deployment Management",
|
|
131
|
-
"
|
|
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,19 @@
|
|
|
4132
4140
|
"should_install": "Should install"
|
|
4133
4141
|
}
|
|
4134
4142
|
}
|
|
4143
|
+
},
|
|
4144
|
+
"seasonal_insights": {
|
|
4145
|
+
"title": "Seasonal Insights Available.",
|
|
4146
|
+
"learn_more": "Learn more.",
|
|
4147
|
+
"dismiss_tooltip": "Dismiss until a new insight is available.",
|
|
4148
|
+
"tooltip": "Seasonal insights highlight the key changes for this time of year. Click Learn more to see the full details.",
|
|
4149
|
+
"show_more": "More info",
|
|
4150
|
+
"show_less": "Show less",
|
|
4151
|
+
"summary_heading": "What to expect next",
|
|
4152
|
+
"timeframe": "Time window",
|
|
4153
|
+
"confidence": "Confidence",
|
|
4154
|
+
"key_risks": "Key risks",
|
|
4155
|
+
"seasonal_factors": "Seasonal factors"
|
|
4135
4156
|
}
|
|
4136
4157
|
}
|
|
4137
4158
|
}
|
package/lib/i18n/fr.json
CHANGED
|
@@ -3793,6 +3793,19 @@
|
|
|
3793
3793
|
"sub_areas": "Sous-zones",
|
|
3794
3794
|
"factories": "Usines"
|
|
3795
3795
|
}
|
|
3796
|
+
},
|
|
3797
|
+
"seasonal_insights": {
|
|
3798
|
+
"title": "Informations saisonnières disponibles.",
|
|
3799
|
+
"learn_more": "En savoir plus.",
|
|
3800
|
+
"dismiss_tooltip": "Ignorer jusqu’à ce qu’un nouvel aperçu soit disponible.",
|
|
3801
|
+
"tooltip": "Les informations saisonnières mettent en avant les principaux changements de la période. Cliquez sur En savoir plus pour voir tous les détails.",
|
|
3802
|
+
"show_more": "Plus d’infos",
|
|
3803
|
+
"show_less": "Afficher moins",
|
|
3804
|
+
"summary_heading": "À quoi s’attendre ensuite",
|
|
3805
|
+
"timeframe": "Période",
|
|
3806
|
+
"confidence": "Confiance",
|
|
3807
|
+
"key_risks": "Principaux risques",
|
|
3808
|
+
"seasonal_factors": "Facteurs saisonniers"
|
|
3796
3809
|
}
|
|
3797
3810
|
}
|
|
3798
3811
|
}
|
package/lib/i18n/he.json
CHANGED
|
@@ -2989,7 +2989,10 @@
|
|
|
2989
2989
|
"sampling_mode_filter_item": "צורת דיגום",
|
|
2990
2990
|
"sampling_id_filter_item": "ID",
|
|
2991
2991
|
"site_filter_item": "שם אתר",
|
|
2992
|
-
"lab_filter_item": "מעבדה"
|
|
2992
|
+
"lab_filter_item": "מעבדה",
|
|
2993
|
+
"sampling_parameter_filter_item": "פרמטרים חורגים",
|
|
2994
|
+
"discharge_time_filter_item": "זמן הזרמה",
|
|
2995
|
+
"observed_upstream_filter_item": "נצפה במעלה הזרם"
|
|
2993
2996
|
},
|
|
2994
2997
|
"filter": "סינון",
|
|
2995
2998
|
"apply": "סנן",
|
|
@@ -3023,6 +3026,10 @@
|
|
|
3023
3026
|
"with": "עם",
|
|
3024
3027
|
"without": "בלי"
|
|
3025
3028
|
},
|
|
3029
|
+
"observed_upstream": {
|
|
3030
|
+
"with": "עם",
|
|
3031
|
+
"without": "בלי"
|
|
3032
|
+
},
|
|
3026
3033
|
"sampling_mode": {
|
|
3027
3034
|
"manual": "הזנה ידנית",
|
|
3028
3035
|
"automatic": "אוטומטי"
|
|
@@ -3912,6 +3919,19 @@
|
|
|
3912
3919
|
"sub_areas": "אזורי משנה",
|
|
3913
3920
|
"factories": "מפעלים"
|
|
3914
3921
|
}
|
|
3922
|
+
},
|
|
3923
|
+
"seasonal_insights": {
|
|
3924
|
+
"title": "תובנות עונתיות זמינות.",
|
|
3925
|
+
"learn_more": "למד עוד.",
|
|
3926
|
+
"dismiss_tooltip": "התעלם עד שתהיה תובנה חדשה זמינה.",
|
|
3927
|
+
"tooltip": "תובנות עונתיות מדגישות את השינויים המרכזיים בתקופה זו. לחץ על למד עוד כדי לראות את כל הפרטים.",
|
|
3928
|
+
"show_more": "מידע נוסף",
|
|
3929
|
+
"show_less": "הסתר מידע",
|
|
3930
|
+
"summary_heading": "מה צפוי בהמשך",
|
|
3931
|
+
"timeframe": "מסגרת זמן",
|
|
3932
|
+
"confidence": "רמת ודאות",
|
|
3933
|
+
"key_risks": "סיכונים מרכזיים",
|
|
3934
|
+
"seasonal_factors": "גורמים עונתיים"
|
|
3915
3935
|
}
|
|
3916
3936
|
}
|
|
3917
3937
|
}
|
package/lib/i18n/it.json
CHANGED
|
@@ -3806,6 +3806,19 @@
|
|
|
3806
3806
|
"sub_areas": "Sottoaree",
|
|
3807
3807
|
"factories": "Fabbriche"
|
|
3808
3808
|
}
|
|
3809
|
+
},
|
|
3810
|
+
"seasonal_insights": {
|
|
3811
|
+
"title": "Approfondimenti stagionali disponibili.",
|
|
3812
|
+
"learn_more": "Scopri di più.",
|
|
3813
|
+
"dismiss_tooltip": "Ignora finché non sarà disponibile una nuova informazione.",
|
|
3814
|
+
"tooltip": "Gli approfondimenti stagionali evidenziano i principali cambiamenti di questo periodo. Fai clic su Scopri di più per vedere tutti i dettagli.",
|
|
3815
|
+
"show_more": "Più informazioni",
|
|
3816
|
+
"show_less": "Mostra meno",
|
|
3817
|
+
"summary_heading": "Cosa aspettarsi dopo",
|
|
3818
|
+
"timeframe": "Finestra temporale",
|
|
3819
|
+
"confidence": "Attendibilità",
|
|
3820
|
+
"key_risks": "Rischi principali",
|
|
3821
|
+
"seasonal_factors": "Fattori stagionali"
|
|
3809
3822
|
}
|
|
3810
3823
|
}
|
|
3811
3824
|
}
|
package/lib/macros/getVersion.js
CHANGED
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
var packageJsonVersion = "1.2.
|
|
3
|
+
var packageJsonVersion = "1.2.467-alpha.1";
|
|
4
4
|
if (typeof packageJsonVersion === 'string') {
|
|
5
5
|
// eslint-disable-next-line no-console
|
|
6
6
|
console.log("%c Kando UI %c v".concat(packageJsonVersion, " "), 'font-size: 15px; background-color: #fff; color: #e20f53;', 'font-weight: bold; font-size: 15px; background-color: #e20f53; color: #fff;', "with NODE_ENV=".concat(process.env.NODE_ENV));
|
|
7
7
|
} else {
|
|
8
8
|
console.error('getVersion.js got bad version from package.json, expected string.');
|
|
9
9
|
}
|
|
10
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
10
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJwYWNrYWdlSnNvblZlcnNpb24iLCJjb25zb2xlIiwibG9nIiwiY29uY2F0IiwicHJvY2VzcyIsImVudiIsIk5PREVfRU5WIiwiZXJyb3IiXSwic291cmNlcyI6WyIuLi8uLi9zcmMvbWFjcm9zL2dldFZlcnNpb24uanMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHByZXZhbCBmcm9tICdwcmV2YWwubWFjcm8nO1xuXG5jb25zdCBwYWNrYWdlSnNvblZlcnNpb24gPSBwcmV2YWxgbW9kdWxlLmV4cG9ydHMgPSByZXF1aXJlKCcuLi8uLi9iaW4vZ2V0VmVyc2lvbkZyb21QYWNrYWdlSnNvbi5qcycpYDtcbmlmICh0eXBlb2YgcGFja2FnZUpzb25WZXJzaW9uID09PSAnc3RyaW5nJykge1xuICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgbm8tY29uc29sZVxuICBjb25zb2xlLmxvZyhcbiAgICBgJWMgS2FuZG8gVUkgJWMgdiR7cGFja2FnZUpzb25WZXJzaW9ufSBgLFxuICAgICdmb250LXNpemU6IDE1cHg7IGJhY2tncm91bmQtY29sb3I6ICNmZmY7IGNvbG9yOiAjZTIwZjUzOycsXG4gICAgJ2ZvbnQtd2VpZ2h0OiBib2xkOyBmb250LXNpemU6IDE1cHg7IGJhY2tncm91bmQtY29sb3I6ICNlMjBmNTM7IGNvbG9yOiAjZmZmOycsXG4gICAgYHdpdGggTk9ERV9FTlY9JHtwcm9jZXNzLmVudi5OT0RFX0VOVn1gLFxuICApO1xufSBlbHNlIHtcbiAgY29uc29sZS5lcnJvcihcbiAgICAnZ2V0VmVyc2lvbi5qcyBnb3QgYmFkIHZlcnNpb24gZnJvbSBwYWNrYWdlLmpzb24sIGV4cGVjdGVkIHN0cmluZy4nLFxuICApO1xufVxuIl0sIm1hcHBpbmdzIjoiOztBQUVBLElBQU1BLGtCQUFrQixvQkFBNkU7QUFDckcsSUFBSSxPQUFPQSxrQkFBa0IsS0FBSyxRQUFRLEVBQUU7RUFDMUM7RUFDQUMsT0FBTyxDQUFDQyxHQUFHLG9CQUFBQyxNQUFBLENBQ1VILGtCQUFrQixRQUNyQywwREFBMEQsRUFDMUQsNkVBQTZFLG1CQUFBRyxNQUFBLENBQzVEQyxPQUFPLENBQUNDLEdBQUcsQ0FBQ0MsUUFBUSxDQUN2QyxDQUFDO0FBQ0gsQ0FBQyxNQUFNO0VBQ0xMLE9BQU8sQ0FBQ00sS0FBSyxDQUNYLG1FQUNGLENBQUM7QUFDSCJ9
|
|
@@ -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":"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"}
|