@kando-env/kando-ui 1.2.363-alpha.21 → 1.2.363-alpha.23
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/components/Header/InfoBar/Search/Search.js +2 -2
- package/lib/i18n/en.json +1 -2
- package/lib/i18n/he.json +1 -2
- package/lib/macros/getVersion.js +1 -1
- package/lib/pages/DashboardMap/List.js +3 -2
- package/lib/pages/DashboardMap/utils.js +3 -5
- package/lib/pages/NotificationsPageV2/components/NotificationsForm/NotificationsFormContent.js +11 -11
- package/package.json +1 -1
|
@@ -26,7 +26,7 @@ const Search = _ref => {
|
|
|
26
26
|
viewMode
|
|
27
27
|
} = _ref;
|
|
28
28
|
const [showClearIcon, setShowClearIcon] = (0, _react.useState)(false);
|
|
29
|
-
const placeholderStr = `header.search.
|
|
29
|
+
const placeholderStr = `header.search.placeholder`;
|
|
30
30
|
const placeholder = `${_i18n.default.t(placeholderStr)}`;
|
|
31
31
|
const noOptionsMessage = `${_i18n.default.t('header.search.empty')}`;
|
|
32
32
|
const onInputChange = newInput => {
|
|
@@ -55,4 +55,4 @@ const Search = _ref => {
|
|
|
55
55
|
};
|
|
56
56
|
var _default = /*#__PURE__*/_react.default.memo(Search);
|
|
57
57
|
exports.default = _default;
|
|
58
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
58
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfcmVhY3QiLCJfaW50ZXJvcFJlcXVpcmVXaWxkY2FyZCIsInJlcXVpcmUiLCJfaTE4biIsIl9pbnRlcm9wUmVxdWlyZURlZmF1bHQiLCJfR3JvdXBMYWJlbCIsIl9zZWFyY2hTdHlsZSIsIl9yZWFjdFNlbGVjdCIsIl9Db250cm9sIiwiX2dldFJlcXVpcmVXaWxkY2FyZENhY2hlIiwibm9kZUludGVyb3AiLCJXZWFrTWFwIiwiY2FjaGVCYWJlbEludGVyb3AiLCJjYWNoZU5vZGVJbnRlcm9wIiwib2JqIiwiX19lc01vZHVsZSIsImRlZmF1bHQiLCJjYWNoZSIsImhhcyIsImdldCIsIm5ld09iaiIsImhhc1Byb3BlcnR5RGVzY3JpcHRvciIsIk9iamVjdCIsImRlZmluZVByb3BlcnR5IiwiZ2V0T3duUHJvcGVydHlEZXNjcmlwdG9yIiwia2V5IiwicHJvdG90eXBlIiwiaGFzT3duUHJvcGVydHkiLCJjYWxsIiwiZGVzYyIsInNldCIsImZvcm1hdEdyb3VwTGFiZWwiLCJkYXRhIiwiY3JlYXRlRWxlbWVudCIsIm5hbWUiLCJsYWJlbCIsIlNlYXJjaCIsIl9yZWYiLCJvbkNoYW5nZSIsIm9wdGlvbnMiLCJ2aWV3TW9kZSIsInNob3dDbGVhckljb24iLCJzZXRTaG93Q2xlYXJJY29uIiwidXNlU3RhdGUiLCJwbGFjZWhvbGRlclN0ciIsInBsYWNlaG9sZGVyIiwiaTE4biIsInQiLCJub09wdGlvbnNNZXNzYWdlIiwib25JbnB1dENoYW5nZSIsIm5ld0lucHV0IiwibGVuZ3RoIiwidmFsdWUiLCJjb21wb25lbnRzIiwiQ29udHJvbCIsInN0eWxlcyIsInNlYXJjaFN0eWxlIiwiaXNTZWFyY2hhYmxlIiwiY2xhc3NOYW1lUHJlZml4IiwiX2RlZmF1bHQiLCJSZWFjdCIsIm1lbW8iLCJleHBvcnRzIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2NvbXBvbmVudHMvSGVhZGVyL0luZm9CYXIvU2VhcmNoL1NlYXJjaC50c3giXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0LCB7IHVzZVN0YXRlIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IGkxOG4gZnJvbSAnc3JjL3V0aWxpdGllcy9pMThuJztcbmltcG9ydCBHcm91cExhYmVsIGZyb20gJy4vR3JvdXBMYWJlbCc7XG5pbXBvcnQgc2VhcmNoU3R5bGUgZnJvbSAnLi9zZWFyY2hTdHlsZSc7XG5pbXBvcnQgJy4vc3R5bGVzLnNjc3MnO1xuaW1wb3J0IFNlbGVjdCBmcm9tICdyZWFjdC1zZWxlY3QnO1xuaW1wb3J0IENvbnRyb2wgZnJvbSAnLi9Db250cm9sJztcblxuY29uc3QgZm9ybWF0R3JvdXBMYWJlbCA9IChkYXRhKSA9PiB7XG4gIHJldHVybiA8R3JvdXBMYWJlbCBuYW1lPXtkYXRhLmxhYmVsfSAvPjtcbn07XG5cbmNvbnN0IFNlYXJjaCA9ICh7IG9uQ2hhbmdlLCBvcHRpb25zLCB2aWV3TW9kZSB9KSA9PiB7XG4gIGNvbnN0IFtzaG93Q2xlYXJJY29uLCBzZXRTaG93Q2xlYXJJY29uXSA9IHVzZVN0YXRlKGZhbHNlKTtcbiAgY29uc3QgcGxhY2Vob2xkZXJTdHIgPSBgaGVhZGVyLnNlYXJjaC5wbGFjZWhvbGRlcmA7XG4gIGNvbnN0IHBsYWNlaG9sZGVyID0gYCR7aTE4bi50KHBsYWNlaG9sZGVyU3RyKX1gO1xuICBjb25zdCBub09wdGlvbnNNZXNzYWdlID0gYCR7aTE4bi50KCdoZWFkZXIuc2VhcmNoLmVtcHR5Jyl9YDtcblxuICBjb25zdCBvbklucHV0Q2hhbmdlID0gKG5ld0lucHV0KSA9PiB7XG4gICAgaWYgKCFuZXdJbnB1dCkge1xuICAgICAgc2V0U2hvd0NsZWFySWNvbihmYWxzZSk7XG4gICAgfSBlbHNlIGlmIChuZXdJbnB1dC5sZW5ndGggPT09IDEpIHtcbiAgICAgIHNldFNob3dDbGVhckljb24odHJ1ZSk7XG4gICAgfVxuICB9O1xuXG4gIHJldHVybiAoXG4gICAgPFNlbGVjdFxuICAgICAgcGxhY2Vob2xkZXI9e3BsYWNlaG9sZGVyfVxuICAgICAgdmFsdWU9e251bGx9XG4gICAgICBjb21wb25lbnRzPXt7IENvbnRyb2wgfX1cbiAgICAgIHNob3dDbGVhckljb249e3Nob3dDbGVhckljb259XG4gICAgICBmb3JtYXRHcm91cExhYmVsPXtmb3JtYXRHcm91cExhYmVsfVxuICAgICAgb25JbnB1dENoYW5nZT17b25JbnB1dENoYW5nZX1cbiAgICAgIHN0eWxlcz17c2VhcmNoU3R5bGV9XG4gICAgICBpc1NlYXJjaGFibGU9e3RydWV9XG4gICAgICBjbGFzc05hbWVQcmVmaXg9eydkYXNoYm9hcmQtc2VsZWN0J31cbiAgICAgIG5vT3B0aW9uc01lc3NhZ2U9eygpID0+IG5vT3B0aW9uc01lc3NhZ2V9XG4gICAgICBvbkNoYW5nZT17b25DaGFuZ2V9XG4gICAgICBvcHRpb25zPXtvcHRpb25zfVxuICAgIC8+XG4gICk7XG59O1xuXG5leHBvcnQgZGVmYXVsdCBSZWFjdC5tZW1vKFNlYXJjaCk7XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFBQSxJQUFBQSxNQUFBLEdBQUFDLHVCQUFBLENBQUFDLE9BQUE7QUFDQSxJQUFBQyxLQUFBLEdBQUFDLHNCQUFBLENBQUFGLE9BQUE7QUFDQSxJQUFBRyxXQUFBLEdBQUFELHNCQUFBLENBQUFGLE9BQUE7QUFDQSxJQUFBSSxZQUFBLEdBQUFGLHNCQUFBLENBQUFGLE9BQUE7QUFDQUEsT0FBQTtBQUNBLElBQUFLLFlBQUEsR0FBQUgsc0JBQUEsQ0FBQUYsT0FBQTtBQUNBLElBQUFNLFFBQUEsR0FBQUosc0JBQUEsQ0FBQUYsT0FBQTtBQUFnQyxTQUFBTyx5QkFBQUMsV0FBQSxlQUFBQyxPQUFBLGtDQUFBQyxpQkFBQSxPQUFBRCxPQUFBLFFBQUFFLGdCQUFBLE9BQUFGLE9BQUEsWUFBQUYsd0JBQUEsWUFBQUEsQ0FBQUMsV0FBQSxXQUFBQSxXQUFBLEdBQUFHLGdCQUFBLEdBQUFELGlCQUFBLEtBQUFGLFdBQUE7QUFBQSxTQUFBVCx3QkFBQWEsR0FBQSxFQUFBSixXQUFBLFNBQUFBLFdBQUEsSUFBQUksR0FBQSxJQUFBQSxHQUFBLENB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
|
package/lib/i18n/en.json
CHANGED
|
@@ -3481,8 +3481,7 @@
|
|
|
3481
3481
|
"load": "Load",
|
|
3482
3482
|
"concentration": "Concentration",
|
|
3483
3483
|
"search": {
|
|
3484
|
-
"
|
|
3485
|
-
"placeholder_map": "Search a map",
|
|
3484
|
+
"placeholder": "Search",
|
|
3486
3485
|
"empty": "Could not find a match, please try another search"
|
|
3487
3486
|
},
|
|
3488
3487
|
"countries": {
|
package/lib/i18n/he.json
CHANGED
|
@@ -3389,8 +3389,7 @@
|
|
|
3389
3389
|
"factory-name-example": "שם מפעל",
|
|
3390
3390
|
"load": "עומס",
|
|
3391
3391
|
"search": {
|
|
3392
|
-
"
|
|
3393
|
-
"placeholder_map": "חיפוש מפה",
|
|
3392
|
+
"placeholder": "חיפוש",
|
|
3394
3393
|
"empty": "לא מצאנו דאשבורד מתאים, אנה נסה חיפוש שונה"
|
|
3395
3394
|
},
|
|
3396
3395
|
"concentration": "ריכוז",
|
package/lib/macros/getVersion.js
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
const packageJsonVersion = "1.2.363-alpha.
|
|
3
|
+
const packageJsonVersion = "1.2.363-alpha.23";
|
|
4
4
|
if (typeof packageJsonVersion === 'string') {
|
|
5
5
|
// eslint-disable-next-line no-console
|
|
6
6
|
console.log(`%c Kando UI %c v${packageJsonVersion} `, 'font-size: 15px; background-color: #fff; color: #e20f53;', 'font-weight: bold; font-size: 15px; background-color: #e20f53; color: #fff;', `with NODE_ENV=${process.env.NODE_ENV}`);
|
|
@@ -106,7 +106,8 @@ const List = props => {
|
|
|
106
106
|
}
|
|
107
107
|
}, [areas_data]);
|
|
108
108
|
(0, _react.useEffect)(() => {
|
|
109
|
-
|
|
109
|
+
var _points_data$items;
|
|
110
|
+
if (!focusedArea || !focusedArea.factories || focusedArea.factories.length === 0 || (points_data === null || points_data === void 0 ? void 0 : points_data.isFetching) === true || (points_data === null || points_data === void 0 ? void 0 : (_points_data$items = points_data.items) === null || _points_data$items === void 0 ? void 0 : _points_data$items.length) === 0) return;
|
|
110
111
|
dispatch((0, _WWTPDashboardSlice.setFocusedArea)({
|
|
111
112
|
...focusedArea,
|
|
112
113
|
factories: (0, _utils.getPoints)(focusedArea === null || focusedArea === void 0 ? void 0 : focusedArea.factories, points_data.items)
|
|
@@ -179,4 +180,4 @@ const ErrorMessage = _styledComponents.default.div.withConfig({
|
|
|
179
180
|
displayName: "List__ErrorMessage",
|
|
180
181
|
componentId: "sc-1f5wz2c-4"
|
|
181
182
|
})(["display:flex;height:100%;font-size:20px;justify-content:center;box-shadow:-0.9px -0.5px 5px 0 rgba(0,0,0,0.06);border:solid 1px #ebebeb;padding:20px;"]);
|
|
182
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_theme","_reactRedux","_utils","_AreaCard","_FactoryCard","_OrganicCard","_interopRequireDefault","_PotentialSaving","_ListContext","_i18n","_DischargePattern","_QualitySummary","_LineChart","_WWTPDashboardSlice","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","List","props","_WWTPInfo$point","_WWTPInfo$point2","ReduxState","useSelector","state","areas_data","points_data","dispatch","useDispatch","selectedItem","handleSelectItem","useSelectedItem","WWTPInfo","focusedArea","map","wwtp_dashboard","selectedRef","useRef","siteID","point","id","handleItemClick","item","noDataMessage","i18n","t","listDetails","useMemo","_focusedArea$sub_area","_focusedArea$sub_area2","is_no_areas","forWWTPMap","undefined","sub_areas","length","has_device","createElement","ListContainer","ErrorMessage","SummaryComponent","endpoint","className","LineChartComponent","title","DischargePattern","Number","sortAreas","filter","Boolean","area","AreaCard","area_id","object","mapRef","onClick","selected","itemRef","factories","sortPoints","factory","FactoryCard","useEffect","isFetching","subAreasChanged","areasScoreChangedById","newAreas","focusedAreaWithUpdatedSubAreas","getUpdatedAreasById","setFocusedArea","getPoints","items","arr1","arr2","item1","matchingItem","find","item2","area_score","array1","array2","updatedArray","obj2","some","obj1","_selectedRef$current","current","scrollIntoView","behavior","block","inline","group","type","clicked","WWTPDetails","style","overflow","name","area_name","exports","styled","div","withConfig","displayName","componentId","theme","WWTPMap","bg","QualitySummary","LineChart"],"sources":["../../../src/pages/DashboardMap/List.tsx"],"sourcesContent":["import { IArea } from '../../store/areas/models/IArea';\nimport React, { useEffect, useMemo, useRef } from 'react';\nimport styled from 'styled-components/macro';\nimport { theme } from 'src/styles/theme/theme';\nimport { useDispatch, useSelector } from 'react-redux';\nimport { appReducer } from '../../store/rootReducer';\nimport { sortAreas, getPoints, sortPoints } from './utils';\nimport { AreaCard } from './AreaCard';\nimport { FactoryCard } from './FactoryCard';\nimport OrganicCard from '../WwtpPage/OrganicCard';\nimport ImpactCard from '../WwtpPage/PotentialSaving';\nimport { useSelectedItem } from './ListContext';\nimport i18n from 'src/utilities/i18n';\nimport { DischargePattern } from '../SitePage/DischargePattern/DischargePattern';\nimport { QualitySummary } from 'src/Widgets/QualitySummary/QualitySummary';\nimport { LineChart } from 'src/pages/AreaPage/Dashboard/LineChart/LineChart';\nimport { setFocusedArea } from 'src/store/WWTPDashboard/WWTPDashboardSlice';\n\ntype IProps = {\n  global_data: any;\n  WWTPInfo: any;\n};\n\nexport const List: React.FC<IProps> = (props) => {\n  const ReduxState = useSelector((state) => state);\n  const { areas_data, points_data } = ReduxState;\n  const dispatch = useDispatch();\n  const { selectedItem, handleSelectItem } = useSelectedItem();\n  const { WWTPInfo } = props;\n  const { focusedArea, map } = useSelector(\n    (state: ReturnType<typeof appReducer>) => state.wwtp_dashboard,\n  );\n  const selectedRef = useRef(null);\n  const siteID = WWTPInfo.point?.id;\n\n  const handleItemClick = (item) => {\n    handleSelectItem(item);\n  };\n\n  const noDataMessage = i18n.t('wwtpPage.no_data_for_site');\n\n  let listDetails = useMemo(() => {\n    if (!siteID && !focusedArea) {\n      return;\n    }\n\n    const is_no_areas =\n      focusedArea &&\n      focusedArea?.forWWTPMap === true &&\n      siteID !== undefined &&\n      focusedArea.sub_areas?.length === 0;\n\n    if (is_no_areas) {\n      if (\n        // focusedArea?.clicked === undefined ||\n        focusedArea?.has_device === false ||\n        !siteID\n      ) {\n        return (\n          <ListContainer>\n            <ErrorMessage>{noDataMessage}</ErrorMessage>\n          </ListContainer>\n        );\n      } else {\n        return (\n          <ListContainer>\n            <SummaryComponent\n              endpoint={`/data/events-component-data/${siteID}`}\n              className=\"summary-component\"\n            />\n            <LineChartComponent\n              title={i18n.t('area_dashboard.trend')}\n              endpoint={`/points/${siteID}/trend-graph`}\n            />\n            <DischargePattern siteID={Number(siteID)} />\n          </ListContainer>\n        );\n      }\n    }\n\n    if (focusedArea && focusedArea?.sub_areas?.length > 0) {\n      return (\n        focusedArea.sub_areas &&\n        sortAreas(focusedArea.sub_areas)\n          .filter(Boolean)\n          .map((area: IArea) => (\n            <AreaCard\n              key={area.area_id}\n              object={area}\n              mapRef={map}\n              onClick={() => handleItemClick(area.area_id)}\n              selected={selectedItem === area.area_id}\n              itemRef={selectedItem === area.area_id ? selectedRef : null}\n            />\n          ))\n      );\n    } else {\n      if (focusedArea?.factories) {\n        return sortPoints(focusedArea.factories)\n          .filter(Boolean)\n          .map((factory) => (\n            <FactoryCard\n              key={factory.id}\n              object={factory}\n              mapRef={map}\n              onClick={() => handleItemClick(factory.id)}\n              selected={selectedItem === factory.id}\n              itemRef={selectedItem === factory.id ? selectedRef : null}\n            />\n          ));\n      }\n    }\n  }, [selectedItem, siteID, focusedArea]);\n\n  // Update the list only if the score of at least one of the sub-areas has changed\n  useEffect(() => {\n    if (\n      focusedArea &&\n      focusedArea.sub_areas &&\n      focusedArea.sub_areas.length > 0 &&\n      areas_data?.isFetching === false\n    ) {\n      const subAreasChanged = areasScoreChangedById(\n        focusedArea.sub_areas,\n        areas_data.newAreas,\n      );\n      if (!subAreasChanged) return;\n\n      const focusedAreaWithUpdatedSubAreas = {\n        ...focusedArea,\n        sub_areas: getUpdatedAreasById(\n          focusedArea.sub_areas,\n          areas_data.newAreas,\n        ),\n      };\n      dispatch(setFocusedArea(focusedAreaWithUpdatedSubAreas));\n    }\n  }, [areas_data]);\n\n  useEffect(() => {\n    if (\n      !focusedArea ||\n      !focusedArea.factories ||\n      focusedArea.factories.length === 0\n    )\n      return;\n\n    dispatch(\n      setFocusedArea({\n        ...focusedArea,\n        factories: getPoints(focusedArea?.factories, points_data.items),\n      }),\n    );\n  }, [points_data]);\n\n  const areasScoreChangedById = (arr1, arr2) => {\n    // go over the 1st array\n    for (let item1 of arr1) {\n      // Find the object with the same id in the second array\n      let matchingItem = arr2.find((item2) => item2.area_id === item1.area_id);\n\n      // Return true if one matching item is found in the second array and their scores changed\n      if (matchingItem && item1.area_score !== matchingItem.area_score) {\n        return true;\n      }\n    }\n\n    // If all items matched and had the same score, return false\n    return false;\n  };\n\n  const getUpdatedAreasById = (array1, array2) => {\n    const updatedArray = array2.filter((obj2) =>\n      array1.some((obj1) => obj1.area_id === obj2.area_id),\n    );\n\n    return updatedArray?.length > 0 ? updatedArray : array1;\n  };\n\n  useEffect(() => {\n    selectedRef.current?.scrollIntoView({\n      behavior: 'smooth',\n      block: 'center',\n      inline: 'center',\n    });\n  }, [selectedItem]);\n\n  if (\n    focusedArea?.group &&\n    focusedArea.group.type === 'Groups::WastewaterTreatmentPlant' &&\n    focusedArea?.clicked === undefined\n  )\n    return (\n      <WWTPDetails className=\"p-3\" style={{ overflow: 'scroll' }}>\n        <h3>{WWTPInfo.point?.name}</h3>\n        <div className={'h-auto my-4'}>\n          <OrganicCard />\n        </div>\n        <div className={'h-auto mt-2'}>\n          <ImpactCard />\n        </div>\n      </WWTPDetails>\n    );\n\n  return (\n    <WWTPDetails className=\"p-3\" style={{ overflow: 'scroll' }}>\n      <h3>{focusedArea?.area_name || focusedArea?.name}</h3>\n      <ul className={'mx-n3'}>{listDetails}</ul>\n    </WWTPDetails>\n  );\n};\n\nconst WWTPDetails = styled.div`\n  width: 100%;\n  height: calc(100vh - 134px);\n  background: ${theme.WWTPMap.bg};\n`;\n\nconst SummaryComponent = styled(QualitySummary)`\n  grid-area: summary;\n\n  summary-component {\n    background-color: blue;\n  }\n`;\n\nconst LineChartComponent = styled(LineChart)`\n  grid-area: graph;\n`;\n\nconst ListContainer = styled.div`\n  display: flex;\n  flex-direction: column;\n  justify-content: space-between;\n  height: 100%;\n  padding: 20px;\n  gap: 30px;\n`;\n\nconst ErrorMessage = styled.div`\n  display: flex;\n  height: 100%;\n  font-size: 20px;\n  justify-content: center;\n  box-shadow: -0.9px -0.5px 5px 0 rgba(0, 0, 0, 0.06);\n  border: solid 1px #ebebeb;\n  padding: 20px;\n`;\n"],"mappings":"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"}
|
|
183
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_theme","_reactRedux","_utils","_AreaCard","_FactoryCard","_OrganicCard","_interopRequireDefault","_PotentialSaving","_ListContext","_i18n","_DischargePattern","_QualitySummary","_LineChart","_WWTPDashboardSlice","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","List","props","_WWTPInfo$point","_WWTPInfo$point2","ReduxState","useSelector","state","areas_data","points_data","dispatch","useDispatch","selectedItem","handleSelectItem","useSelectedItem","WWTPInfo","focusedArea","map","wwtp_dashboard","selectedRef","useRef","siteID","point","id","handleItemClick","item","noDataMessage","i18n","t","listDetails","useMemo","_focusedArea$sub_area","_focusedArea$sub_area2","is_no_areas","forWWTPMap","undefined","sub_areas","length","has_device","createElement","ListContainer","ErrorMessage","SummaryComponent","endpoint","className","LineChartComponent","title","DischargePattern","Number","sortAreas","filter","Boolean","area","AreaCard","area_id","object","mapRef","onClick","selected","itemRef","factories","sortPoints","factory","FactoryCard","useEffect","isFetching","subAreasChanged","areasScoreChangedById","newAreas","focusedAreaWithUpdatedSubAreas","getUpdatedAreasById","setFocusedArea","_points_data$items","items","getPoints","arr1","arr2","item1","matchingItem","find","item2","area_score","array1","array2","updatedArray","obj2","some","obj1","_selectedRef$current","current","scrollIntoView","behavior","block","inline","group","type","clicked","WWTPDetails","style","overflow","name","area_name","exports","styled","div","withConfig","displayName","componentId","theme","WWTPMap","bg","QualitySummary","LineChart"],"sources":["../../../src/pages/DashboardMap/List.tsx"],"sourcesContent":["import { IArea } from '../../store/areas/models/IArea';\nimport React, { useEffect, useMemo, useRef } from 'react';\nimport styled from 'styled-components/macro';\nimport { theme } from 'src/styles/theme/theme';\nimport { useDispatch, useSelector } from 'react-redux';\nimport { appReducer } from '../../store/rootReducer';\nimport { sortAreas, getPoints, sortPoints } from './utils';\nimport { AreaCard } from './AreaCard';\nimport { FactoryCard } from './FactoryCard';\nimport OrganicCard from '../WwtpPage/OrganicCard';\nimport ImpactCard from '../WwtpPage/PotentialSaving';\nimport { useSelectedItem } from './ListContext';\nimport i18n from 'src/utilities/i18n';\nimport { DischargePattern } from '../SitePage/DischargePattern/DischargePattern';\nimport { QualitySummary } from 'src/Widgets/QualitySummary/QualitySummary';\nimport { LineChart } from 'src/pages/AreaPage/Dashboard/LineChart/LineChart';\nimport { setFocusedArea } from 'src/store/WWTPDashboard/WWTPDashboardSlice';\n\ntype IProps = {\n  global_data: any;\n  WWTPInfo: any;\n};\n\nexport const List: React.FC<IProps> = (props) => {\n  const ReduxState = useSelector((state) => state);\n  const { areas_data, points_data } = ReduxState;\n  const dispatch = useDispatch();\n  const { selectedItem, handleSelectItem } = useSelectedItem();\n  const { WWTPInfo } = props;\n  const { focusedArea, map } = useSelector(\n    (state: ReturnType<typeof appReducer>) => state.wwtp_dashboard,\n  );\n  const selectedRef = useRef(null);\n  const siteID = WWTPInfo.point?.id;\n\n  const handleItemClick = (item) => {\n    handleSelectItem(item);\n  };\n\n  const noDataMessage = i18n.t('wwtpPage.no_data_for_site');\n\n  let listDetails = useMemo(() => {\n    if (!siteID && !focusedArea) {\n      return;\n    }\n\n    const is_no_areas =\n      focusedArea &&\n      focusedArea?.forWWTPMap === true &&\n      siteID !== undefined &&\n      focusedArea.sub_areas?.length === 0;\n\n    if (is_no_areas) {\n      if (\n        // focusedArea?.clicked === undefined ||\n        focusedArea?.has_device === false ||\n        !siteID\n      ) {\n        return (\n          <ListContainer>\n            <ErrorMessage>{noDataMessage}</ErrorMessage>\n          </ListContainer>\n        );\n      } else {\n        return (\n          <ListContainer>\n            <SummaryComponent\n              endpoint={`/data/events-component-data/${siteID}`}\n              className=\"summary-component\"\n            />\n            <LineChartComponent\n              title={i18n.t('area_dashboard.trend')}\n              endpoint={`/points/${siteID}/trend-graph`}\n            />\n            <DischargePattern siteID={Number(siteID)} />\n          </ListContainer>\n        );\n      }\n    }\n\n    if (focusedArea && focusedArea?.sub_areas?.length > 0) {\n      return (\n        focusedArea.sub_areas &&\n        sortAreas(focusedArea.sub_areas)\n          .filter(Boolean)\n          .map((area: IArea) => (\n            <AreaCard\n              key={area.area_id}\n              object={area}\n              mapRef={map}\n              onClick={() => handleItemClick(area.area_id)}\n              selected={selectedItem === area.area_id}\n              itemRef={selectedItem === area.area_id ? selectedRef : null}\n            />\n          ))\n      );\n    } else {\n      if (focusedArea?.factories) {\n        return sortPoints(focusedArea.factories)\n          .filter(Boolean)\n          .map((factory) => (\n            <FactoryCard\n              key={factory.id}\n              object={factory}\n              mapRef={map}\n              onClick={() => handleItemClick(factory.id)}\n              selected={selectedItem === factory.id}\n              itemRef={selectedItem === factory.id ? selectedRef : null}\n            />\n          ));\n      }\n    }\n  }, [selectedItem, siteID, focusedArea]);\n\n  // Update the list only if the score of at least one of the sub-areas has changed\n  useEffect(() => {\n    if (\n      focusedArea &&\n      focusedArea.sub_areas &&\n      focusedArea.sub_areas.length > 0 &&\n      areas_data?.isFetching === false\n    ) {\n      const subAreasChanged = areasScoreChangedById(\n        focusedArea.sub_areas,\n        areas_data.newAreas,\n      );\n      if (!subAreasChanged) return;\n\n      const focusedAreaWithUpdatedSubAreas = {\n        ...focusedArea,\n        sub_areas: getUpdatedAreasById(\n          focusedArea.sub_areas,\n          areas_data.newAreas,\n        ),\n      };\n      dispatch(setFocusedArea(focusedAreaWithUpdatedSubAreas));\n    }\n  }, [areas_data]);\n\n  useEffect(() => {\n    if (\n      !focusedArea ||\n      !focusedArea.factories ||\n      focusedArea.factories.length === 0 ||\n      points_data?.isFetching === true ||\n      points_data?.items?.length === 0\n    )\n      return;\n\n    dispatch(\n      setFocusedArea({\n        ...focusedArea,\n        factories: getPoints(focusedArea?.factories, points_data.items),\n      }),\n    );\n  }, [points_data]);\n\n  const areasScoreChangedById = (arr1, arr2) => {\n    // go over the 1st array\n    for (let item1 of arr1) {\n      // Find the object with the same id in the second array\n      let matchingItem = arr2.find((item2) => item2.area_id === item1.area_id);\n\n      // Return true if one matching item is found in the second array and their scores changed\n      if (matchingItem && item1.area_score !== matchingItem.area_score) {\n        return true;\n      }\n    }\n\n    // If all items matched and had the same score, return false\n    return false;\n  };\n\n  const getUpdatedAreasById = (array1, array2) => {\n    const updatedArray = array2.filter((obj2) =>\n      array1.some((obj1) => obj1.area_id === obj2.area_id),\n    );\n\n    return updatedArray?.length > 0 ? updatedArray : array1;\n  };\n\n  useEffect(() => {\n    selectedRef.current?.scrollIntoView({\n      behavior: 'smooth',\n      block: 'center',\n      inline: 'center',\n    });\n  }, [selectedItem]);\n\n  if (\n    focusedArea?.group &&\n    focusedArea.group.type === 'Groups::WastewaterTreatmentPlant' &&\n    focusedArea?.clicked === undefined\n  )\n    return (\n      <WWTPDetails className=\"p-3\" style={{ overflow: 'scroll' }}>\n        <h3>{WWTPInfo.point?.name}</h3>\n        <div className={'h-auto my-4'}>\n          <OrganicCard />\n        </div>\n        <div className={'h-auto mt-2'}>\n          <ImpactCard />\n        </div>\n      </WWTPDetails>\n    );\n\n  return (\n    <WWTPDetails className=\"p-3\" style={{ overflow: 'scroll' }}>\n      <h3>{focusedArea?.area_name || focusedArea?.name}</h3>\n      <ul className={'mx-n3'}>{listDetails}</ul>\n    </WWTPDetails>\n  );\n};\n\nconst WWTPDetails = styled.div`\n  width: 100%;\n  height: calc(100vh - 134px);\n  background: ${theme.WWTPMap.bg};\n`;\n\nconst SummaryComponent = styled(QualitySummary)`\n  grid-area: summary;\n\n  summary-component {\n    background-color: blue;\n  }\n`;\n\nconst LineChartComponent = styled(LineChart)`\n  grid-area: graph;\n`;\n\nconst ListContainer = styled.div`\n  display: flex;\n  flex-direction: column;\n  justify-content: space-between;\n  height: 100%;\n  padding: 20px;\n  gap: 30px;\n`;\n\nconst ErrorMessage = styled.div`\n  display: flex;\n  height: 100%;\n  font-size: 20px;\n  justify-content: center;\n  box-shadow: -0.9px -0.5px 5px 0 rgba(0, 0, 0, 0.06);\n  border: solid 1px #ebebeb;\n  padding: 20px;\n`;\n"],"mappings":"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"}
|
|
@@ -137,10 +137,8 @@ const simpleTruncate = (str, length) => {
|
|
|
137
137
|
};
|
|
138
138
|
exports.simpleTruncate = simpleTruncate;
|
|
139
139
|
const getPoints = (list, points_data) => {
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
});
|
|
143
|
-
return returnedPoints;
|
|
140
|
+
if (points_data.length === 0) return list;
|
|
141
|
+
return list.map(item => points_data.find(point => point.id === item.id)).filter(Boolean);
|
|
144
142
|
};
|
|
145
143
|
exports.getPoints = getPoints;
|
|
146
144
|
const CardContainer = _styledComponents.default.div.withConfig({
|
|
@@ -162,4 +160,4 @@ const sendAnalyticsEvent = (subject, selection, eventFields) => {
|
|
|
162
160
|
(0, _Analytics.analyticsTrack)(subject, data);
|
|
163
161
|
};
|
|
164
162
|
exports.sendAnalyticsEvent = sendAnalyticsEvent;
|
|
165
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_jquery","_interopRequireDefault","require","_Analytics","initializeWWTPData","payload","dataExists","wwtpInfp","calculateWWTPInfo","setWWTPInfo","setPoints","points_data","items","setAreas","areas_data","newAreas","exports","sortAreas","areas","temp","sortedAreas","sort","a","b","is_assessment","area_score","sortPoints","points","sortedPoints","has_device","updateHistory","object","history","area","area_id","point","id","type","group","push","location","search","is_virtual","_ref","WWTP","find","parseInt","undefined","_points_data$items","WWTPArea","forWWTPMap","createPopupForObject","args","marker","bindPopup","maxWidth","minWidth","maxHeight","minHeight","on","setTimeout","$","contents","length","append","renderedElement","unbindPopup","focusMap","map","latlngs","property","_layers","kando_object","_bounds","sub_areas","forEach","sub_area","shape_data","latlng","inlets","inlet","latitude","longitude","fitBounds","simpleTruncate","str","Error","substring","getPoints","list","returnedPoints","item","CardContainer","styled","div","withConfig","displayName","componentId","sendAnalyticsEvent","subject","selection","eventFields","data","page_name","window","pathname","analyticsTrack"],"sources":["../../../src/pages/DashboardMap/utils.ts"],"sourcesContent":["import { IPoint } from '../../store/points/models/IPoint';\nimport { IArea } from '../../store/areas/models/IArea';\nimport $ from 'jquery';\nimport styled from 'styled-components/macro';\nimport { analyticsTrack } from 'src/utilities/Analytics';\n\nexport const initializeWWTPData = (payload) => {\n  if (payload.dataExists()) {\n    const wwtpInfp = calculateWWTPInfo(payload);\n    payload.setWWTPInfo(wwtpInfp);\n    payload.setPoints(payload.points_data.items);\n    payload.setAreas(payload.areas_data.newAreas);\n  }\n};\n\nexport const sortAreas = (areas) => {\n  if (!areas) return areas;\n\n  const temp = [...areas];\n  const sortedAreas = temp\n    .sort((a, b) =>\n      a.is_assessment === b.is_assessment ? 0 : a.is_assessment ? -1 : 1,\n    )\n    .sort((a, b) => b.area_score - a.area_score);\n\n  return sortedAreas;\n};\n\nexport const sortPoints = (points) => {\n  if (!points) return points;\n\n  const temp = [...points];\n  const sortedPoints = temp\n    .sort((a, b) => (a.has_device === b.has_device ? 0 : a.has_device ? -1 : 1))\n    .sort((a, b) => b.area_score - a.area_score);\n\n  return sortedPoints;\n};\n\nexport const updateHistory = (object, history) => {\n  const area = object.area_id ? object : null;\n  const point = object.id ? object : null;\n\n  if (point) {\n    const type =\n      point.group.type === 'Groups::WastewaterTreatmentPlant' ? 'wwtp' : 'site';\n    history.push(`/dashboard_v2/${type}/${point.id}${history.location.search}`);\n  } else {\n    if (area) {\n      const type = area.is_virtual ? 'varea' : 'area';\n      history.push(\n        `/dashboard_v2/${type}/${area.area_id}${history.location.search}`,\n      );\n    }\n  }\n};\n\nexport const calculateWWTPInfo = ({ id, points_data, areas_data }) => {\n  let WWTP: IPoint = points_data.items.find(\n    (point: IPoint) => point.id === parseInt(id),\n  );\n\n  if (WWTP === undefined) {\n    WWTP = points_data.items?.find(\n      (point: IPoint) => point.group.area_id === parseInt(id),\n    );\n  }\n\n  let WWTPArea: IArea = areas_data.newAreas.find(\n    (area: IArea) => parseInt(id) === area.area_id,\n  );\n\n  if (WWTP !== undefined) {\n    WWTP = {\n      ...WWTP,\n      forWWTPMap: true,\n    };\n  }\n\n  return { point: WWTP, area: WWTPArea };\n};\n\nexport const createPopupForObject = (args) => {\n  args.marker.bindPopup(`<div class=\"widget-container\"></div>`, {\n    maxWidth: 400,\n    minWidth: 400,\n    maxHeight: 400,\n    minHeight: 400,\n  });\n\n  args.marker.on('popupopen', function () {\n    setTimeout(() => {\n      if ($('.widget-container').contents().length <= 0) {\n        $('.widget-container').append(args.renderedElement);\n      }\n    }, 200);\n  });\n\n  args.marker.on('popupclose', function () {\n    args.marker.unbindPopup();\n  });\n};\n\nexport const focusMap = (object, map) => {\n  if (object === null || map === null) return;\n\n  let latlngs: any = [];\n  if (object === undefined) {\n    for (const property in map._layers) {\n      if (\n        map._layers[property].kando_object === 'Area' ||\n        map._layers[property].kando_object === 'Point'\n      ) {\n        latlngs.push(map._layers[property]._bounds);\n      }\n    }\n  } else {\n    if (object.sub_areas && object.sub_areas.length > 0) {\n      object.sub_areas.forEach((sub_area) => {\n        if (sub_area?.shape_data !== undefined) {\n          sub_area.shape_data.forEach((latlng) => {\n            latlngs.push(latlng);\n          });\n        }\n      });\n    } else {\n      if (object.inlets && object.inlets.length > 0) {\n        object.inlets.forEach((inlet) => {\n          latlngs.push([inlet.latitude, inlet.longitude]);\n        });\n      } else {\n        if (object?.shape_data !== undefined) {\n          object.shape_data.forEach((latlng) => {\n            latlngs.push(latlng);\n          });\n        } else {\n          latlngs.push([object.latitude, object.longitude]);\n        }\n      }\n    }\n  }\n  latlngs.length > 0 &&\n    map !== null &&\n    typeof map._layers === 'object' &&\n    map._layers.length === undefined &&\n    map.fitBounds(latlngs);\n};\n\nexport const simpleTruncate = (str, length) => {\n  if (typeof str !== 'string' || typeof length !== 'number') {\n    throw new Error('Invalid arguments. Please provide a string and a number.');\n  }\n\n  if (str.length <= length) {\n    return str;\n  } else {\n    return str.substring(0, length) + '...';\n  }\n};\n\nexport const getPoints = (list: any[], points_data: IPoint[]) => {\n  const returnedPoints = list.map((item) => {\n    return points_data.find((point) => point.id === item.id);\n  });\n  return returnedPoints;\n};\n\nexport const CardContainer = styled.div`\n  .card {\n    transition: 0.1s ease-in-out;\n    box-shadow: 0px 1px 3px rgba(0, 0, 0, 0.2);\n\n    &:hover {\n      transition: 0.2s ease-in-out;\n      box-shadow: 0px 3px 10px rgba(0, 0, 0, 0.2);\n      cursor: pointer;\n    }\n  }\n`;\n\n// Send analytics events from several places in wwtpmap.\n// subject is the name of the event\n// selection is the object that was selected\n// specificFields is an object with event fields to send which are combined with the rest of the fields\nexport const sendAnalyticsEvent = (\n  subject: string,\n  selection: string,\n  eventFields: Object,\n) => {\n  const data = {\n    selection: selection,\n    page_name: window.location.pathname,\n    ...eventFields,\n  };\n  analyticsTrack(subject, data);\n};\n"],"mappings":"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"}
|
|
163
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_jquery","_interopRequireDefault","require","_Analytics","initializeWWTPData","payload","dataExists","wwtpInfp","calculateWWTPInfo","setWWTPInfo","setPoints","points_data","items","setAreas","areas_data","newAreas","exports","sortAreas","areas","temp","sortedAreas","sort","a","b","is_assessment","area_score","sortPoints","points","sortedPoints","has_device","updateHistory","object","history","area","area_id","point","id","type","group","push","location","search","is_virtual","_ref","WWTP","find","parseInt","undefined","_points_data$items","WWTPArea","forWWTPMap","createPopupForObject","args","marker","bindPopup","maxWidth","minWidth","maxHeight","minHeight","on","setTimeout","$","contents","length","append","renderedElement","unbindPopup","focusMap","map","latlngs","property","_layers","kando_object","_bounds","sub_areas","forEach","sub_area","shape_data","latlng","inlets","inlet","latitude","longitude","fitBounds","simpleTruncate","str","Error","substring","getPoints","list","item","filter","Boolean","CardContainer","styled","div","withConfig","displayName","componentId","sendAnalyticsEvent","subject","selection","eventFields","data","page_name","window","pathname","analyticsTrack"],"sources":["../../../src/pages/DashboardMap/utils.ts"],"sourcesContent":["import { IPoint } from '../../store/points/models/IPoint';\nimport { IArea } from '../../store/areas/models/IArea';\nimport $ from 'jquery';\nimport styled from 'styled-components/macro';\nimport { analyticsTrack } from 'src/utilities/Analytics';\n\nexport const initializeWWTPData = (payload) => {\n  if (payload.dataExists()) {\n    const wwtpInfp = calculateWWTPInfo(payload);\n    payload.setWWTPInfo(wwtpInfp);\n    payload.setPoints(payload.points_data.items);\n    payload.setAreas(payload.areas_data.newAreas);\n  }\n};\n\nexport const sortAreas = (areas) => {\n  if (!areas) return areas;\n\n  const temp = [...areas];\n  const sortedAreas = temp\n    .sort((a, b) =>\n      a.is_assessment === b.is_assessment ? 0 : a.is_assessment ? -1 : 1,\n    )\n    .sort((a, b) => b.area_score - a.area_score);\n\n  return sortedAreas;\n};\n\nexport const sortPoints = (points) => {\n  if (!points) return points;\n\n  const temp = [...points];\n  const sortedPoints = temp\n    .sort((a, b) => (a.has_device === b.has_device ? 0 : a.has_device ? -1 : 1))\n    .sort((a, b) => b.area_score - a.area_score);\n\n  return sortedPoints;\n};\n\nexport const updateHistory = (object, history) => {\n  const area = object.area_id ? object : null;\n  const point = object.id ? object : null;\n\n  if (point) {\n    const type =\n      point.group.type === 'Groups::WastewaterTreatmentPlant' ? 'wwtp' : 'site';\n    history.push(`/dashboard_v2/${type}/${point.id}${history.location.search}`);\n  } else {\n    if (area) {\n      const type = area.is_virtual ? 'varea' : 'area';\n      history.push(\n        `/dashboard_v2/${type}/${area.area_id}${history.location.search}`,\n      );\n    }\n  }\n};\n\nexport const calculateWWTPInfo = ({ id, points_data, areas_data }) => {\n  let WWTP: IPoint = points_data.items.find(\n    (point: IPoint) => point.id === parseInt(id),\n  );\n\n  if (WWTP === undefined) {\n    WWTP = points_data.items?.find(\n      (point: IPoint) => point.group.area_id === parseInt(id),\n    );\n  }\n\n  let WWTPArea: IArea = areas_data.newAreas.find(\n    (area: IArea) => parseInt(id) === area.area_id,\n  );\n\n  if (WWTP !== undefined) {\n    WWTP = {\n      ...WWTP,\n      forWWTPMap: true,\n    };\n  }\n\n  return { point: WWTP, area: WWTPArea };\n};\n\nexport const createPopupForObject = (args) => {\n  args.marker.bindPopup(`<div class=\"widget-container\"></div>`, {\n    maxWidth: 400,\n    minWidth: 400,\n    maxHeight: 400,\n    minHeight: 400,\n  });\n\n  args.marker.on('popupopen', function () {\n    setTimeout(() => {\n      if ($('.widget-container').contents().length <= 0) {\n        $('.widget-container').append(args.renderedElement);\n      }\n    }, 200);\n  });\n\n  args.marker.on('popupclose', function () {\n    args.marker.unbindPopup();\n  });\n};\n\nexport const focusMap = (object, map) => {\n  if (object === null || map === null) return;\n\n  let latlngs: any = [];\n  if (object === undefined) {\n    for (const property in map._layers) {\n      if (\n        map._layers[property].kando_object === 'Area' ||\n        map._layers[property].kando_object === 'Point'\n      ) {\n        latlngs.push(map._layers[property]._bounds);\n      }\n    }\n  } else {\n    if (object.sub_areas && object.sub_areas.length > 0) {\n      object.sub_areas.forEach((sub_area) => {\n        if (sub_area?.shape_data !== undefined) {\n          sub_area.shape_data.forEach((latlng) => {\n            latlngs.push(latlng);\n          });\n        }\n      });\n    } else {\n      if (object.inlets && object.inlets.length > 0) {\n        object.inlets.forEach((inlet) => {\n          latlngs.push([inlet.latitude, inlet.longitude]);\n        });\n      } else {\n        if (object?.shape_data !== undefined) {\n          object.shape_data.forEach((latlng) => {\n            latlngs.push(latlng);\n          });\n        } else {\n          latlngs.push([object.latitude, object.longitude]);\n        }\n      }\n    }\n  }\n  latlngs.length > 0 &&\n    map !== null &&\n    typeof map._layers === 'object' &&\n    map._layers.length === undefined &&\n    map.fitBounds(latlngs);\n};\n\nexport const simpleTruncate = (str, length) => {\n  if (typeof str !== 'string' || typeof length !== 'number') {\n    throw new Error('Invalid arguments. Please provide a string and a number.');\n  }\n\n  if (str.length <= length) {\n    return str;\n  } else {\n    return str.substring(0, length) + '...';\n  }\n};\n\nexport const getPoints = (list: any[], points_data: IPoint[]) => {\n  if (points_data.length === 0) return list;\n\n  return list\n    .map((item) => points_data.find((point) => point.id === item.id))\n    .filter(Boolean);\n};\n\nexport const CardContainer = styled.div`\n  .card {\n    transition: 0.1s ease-in-out;\n    box-shadow: 0px 1px 3px rgba(0, 0, 0, 0.2);\n\n    &:hover {\n      transition: 0.2s ease-in-out;\n      box-shadow: 0px 3px 10px rgba(0, 0, 0, 0.2);\n      cursor: pointer;\n    }\n  }\n`;\n\n// Send analytics events from several places in wwtpmap.\n// subject is the name of the event\n// selection is the object that was selected\n// specificFields is an object with event fields to send which are combined with the rest of the fields\nexport const sendAnalyticsEvent = (\n  subject: string,\n  selection: string,\n  eventFields: Object,\n) => {\n  const data = {\n    selection: selection,\n    page_name: window.location.pathname,\n    ...eventFields,\n  };\n  analyticsTrack(subject, data);\n};\n"],"mappings":"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"}
|
package/lib/pages/NotificationsPageV2/components/NotificationsForm/NotificationsFormContent.js
CHANGED
|
@@ -99,7 +99,15 @@ const NotificationsFormContent = _ref => {
|
|
|
99
99
|
setModalDetails: setModalDetails,
|
|
100
100
|
hasTelegram: hasTelegram,
|
|
101
101
|
hasPhone: hasPhone
|
|
102
|
-
}))
|
|
102
|
+
}), showAdvancedConfigLogic() && notification.type === 'RollingEventAlertConfig' && allowedNotifications.includes(notification.type) && /*#__PURE__*/_react.default.createElement(_reactBootstrap.Form.Group, null, /*#__PURE__*/_react.default.createElement(_reactBootstrap.Form.Check, {
|
|
103
|
+
inline: true,
|
|
104
|
+
label: _i18n.default.t('notifications_page.edit_sampler_active'),
|
|
105
|
+
name: "pump_only",
|
|
106
|
+
type: "checkbox",
|
|
107
|
+
id: "pump_only",
|
|
108
|
+
onChange: e => (0, _NotificationsUtils.handleNotificationSample)(e, setNewNotification),
|
|
109
|
+
checked: notification.pump_only === '1'
|
|
110
|
+
})));
|
|
103
111
|
};
|
|
104
112
|
const advancedConfiguration = () => {
|
|
105
113
|
return /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, notification.type === 'RollingEventAlertConfig' && allowedNotifications.includes(notification.type) && /*#__PURE__*/_react.default.createElement(_reactBootstrap.Form.Group, {
|
|
@@ -127,15 +135,7 @@ const NotificationsFormContent = _ref => {
|
|
|
127
135
|
sensors: sensors
|
|
128
136
|
}));
|
|
129
137
|
};
|
|
130
|
-
return /*#__PURE__*/_react.default.createElement(NotificationSidebarFormAreaStyle, null, basicConfiguration(advancedConfiguration)
|
|
131
|
-
inline: true,
|
|
132
|
-
label: _i18n.default.t('notifications_page.edit_sampler_active'),
|
|
133
|
-
name: "pump_only",
|
|
134
|
-
type: "checkbox",
|
|
135
|
-
id: "pump_only",
|
|
136
|
-
onChange: e => (0, _NotificationsUtils.handleNotificationSample)(e, setNewNotification),
|
|
137
|
-
checked: notification.pump_only === '1'
|
|
138
|
-
})));
|
|
138
|
+
return /*#__PURE__*/_react.default.createElement(NotificationSidebarFormAreaStyle, null, basicConfiguration(advancedConfiguration));
|
|
139
139
|
};
|
|
140
140
|
var _default = NotificationsFormContent;
|
|
141
141
|
exports.default = _default;
|
|
@@ -208,4 +208,4 @@ const NotificationsCheckboxesStyle = _styledComponents.default.div.withConfig({
|
|
|
208
208
|
return gap + 'px';
|
|
209
209
|
});
|
|
210
210
|
exports.NotificationsCheckboxesStyle = NotificationsCheckboxesStyle;
|
|
211
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reactBootstrap","_i18n","_interopRequireDefault","_notificationUtils","_RadioButtonGroup","_NotificationsUtils","_EventType","_NotificationSendVia","_WaterAuthoritySelection","_NotificationSources","_NotificationTags","_NotificationSensors","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","NotificationsFormContent","_ref","notification","points","tags","sensors","waterAuthorities","allowedNotifications","setNewNotification","hasPhone","hasTelegram","initialAdvancedConfig","modalDetails","setModalDetails","useState","open","instance","isDirectImpact","direct_impact_only","undefined","showAdvancedConfig","setShowAdvancedConfig","showAdvancedConfigLogic","type","id","showAdvancedConfigCheckbox","defaultWaterAuthorityIfSingle","length","handleNotificationType","value","label","i18n","t","handleWaterAuthorities","selection_type","water_authority","useEffect","basicConfiguration","advancedComponents","createElement","Fragment","EventType","Form","Group","Check","inline","name","onChange","e","handleDirectImpact","checked","WaterAuthoritySelection","NotificationSendVia","advancedConfiguration","includes","controlId","Label","NotificationsCheckboxesStyle","gap","options","severitiesRadioButtons","handleChange","event","handleSeverities","className","severity","NotificationSources","NotificationTags","NotificationSensors","NotificationSidebarFormAreaStyle","handleNotificationSample","pump_only","_default","exports","styled","div","withConfig","displayName","componentId","_ref2","theme","colorScheme","natural","n30","_ref3","fontSize","md","_ref4","fontWeight","w600","_ref5","n80","_ref6","_ref7","primary","p1","_ref8","_ref9","data","O100","_ref10","_ref11","W100","_ref12","_ref13"],"sources":["../../../../../src/pages/NotificationsPageV2/components/NotificationsForm/NotificationsFormContent.tsx"],"sourcesContent":["import React, { useEffect, useState } from 'react';\nimport styled from 'styled-components/macro';\nimport { Form } from 'react-bootstrap';\nimport i18n from 'src/utilities/i18n';\nimport {\n  Notification,\n  severitiesRadioButtons,\n  AdvancedSelection,\n} from 'src/pages/NotificationsPageV2/notificationUtils';\nimport RadioButtonGroup from 'src/ui-kit/RadioButtons/RadioButtonGroup';\nimport {\n  handleDirectImpact,\n  handleNotificationSample,\n  handleNotificationType,\n  handleSeverities,\n  handleWaterAuthorities,\n} from '../NotificationsUtils';\nimport { AlertDetails } from '../../../SamplingsPage/SamplingProperties/samplingPropertiesUtils';\nimport { EventType } from './EventType';\nimport { NotificationSendVia } from './NotificationSendVia';\nimport { WaterAuthoritySelection } from './WaterAuthoritySelection';\nimport { NotificationSources } from './NotificationSources';\nimport { NotificationTags } from './NotificationTags';\nimport { NotificationSensors } from './NotificationSensors';\n\ninterface notificationFormContentProps {\n  notification: Notification;\n  points: AdvancedSelection[];\n  tags: AdvancedSelection[];\n  sensors: AdvancedSelection[];\n  waterAuthorities: AdvancedSelection[];\n  allowedNotifications: string[];\n  setNewNotification: any;\n  hasPhone: boolean;\n  hasTelegram: boolean;\n  initialAdvancedConfig: boolean;\n  direct_impact_only: boolean;\n}\n\nconst NotificationsFormContent: React.FC<notificationFormContentProps> = ({\n  notification,\n  points,\n  tags,\n  sensors,\n  waterAuthorities,\n  allowedNotifications,\n  setNewNotification,\n  hasPhone,\n  hasTelegram,\n  initialAdvancedConfig,\n}) => {\n  const [modalDetails, setModalDetails] = useState<AlertDetails>({\n    open: false,\n    instance: '',\n  });\n  const isDirectImpact = (notification) => {\n    return (\n      notification.direct_impact_only === '1' ||\n      notification.direct_impact_only === undefined\n    );\n  };\n  const [showAdvancedConfig, setShowAdvancedConfig] = useState(\n    isDirectImpact(notification) ? false : true,\n  );\n  const showAdvancedConfigLogic = () => {\n    return (\n      ((notification.type !== 'RollingEventAlertConfig' ||\n        initialAdvancedConfig) &&\n        showAdvancedConfig) ||\n      (notification.id === '' &&\n        notification.type !== 'RollingEventAlertConfig')\n    );\n  };\n\n  const showAdvancedConfigCheckbox = () => {\n    return (\n      notification.type === 'RollingEventAlertConfig' && initialAdvancedConfig\n    );\n  };\n\n  const defaultWaterAuthorityIfSingle = () => {\n    if (waterAuthorities.length === 1) {\n      handleNotificationType(\n        {\n          value: 'RollingEventAlertConfig',\n          label: i18n.t(`notifications_page.RollingEventAlertConfig`),\n        },\n        notification,\n        setNewNotification,\n      );\n      handleWaterAuthorities(\n        undefined,\n        {\n          selection_type: 'include',\n          set: [\n            {\n              value: waterAuthorities[0].water_authority.id,\n              label: waterAuthorities[0].water_authority.label,\n            },\n          ],\n        },\n        notification,\n        setNewNotification,\n      );\n    }\n  };\n\n  useEffect(() => {\n    defaultWaterAuthorityIfSingle();\n    if (notification.type === '') {\n      handleNotificationType(\n        {\n          value: 'RollingEventAlertConfig',\n          label: i18n.t(`notifications_page.RollingEventAlertConfig`),\n        },\n        notification,\n        setNewNotification,\n      );\n    }\n  }, []);\n\n  const basicConfiguration = (advancedComponents) => {\n    return (\n      <>\n        <EventType\n          notification={notification}\n          setNewNotification={setNewNotification}\n          allowedNotifications={allowedNotifications}\n        />\n\n        {showAdvancedConfigCheckbox() && (\n          <Form.Group>\n            <Form.Check\n              inline\n              label={i18n.t('notifications_page.advanced_configuration')}\n              name=\"advanced_configuration\"\n              type=\"checkbox\"\n              id=\"advanced_configuration\"\n              onChange={(e) => {\n                setShowAdvancedConfig(!showAdvancedConfig);\n                handleDirectImpact(e, setNewNotification, notification);\n              }}\n              checked={showAdvancedConfig}\n            />\n          </Form.Group>\n        )}\n\n        {waterAuthorities.length > 1 && (\n          <WaterAuthoritySelection\n            waterAuthorities={waterAuthorities}\n            allowedNotifications={allowedNotifications}\n            notification={notification}\n            setNewNotification={setNewNotification}\n          />\n        )}\n\n        {showAdvancedConfigLogic() && advancedComponents()}\n\n        <NotificationSendVia\n          notification={notification}\n          setNewNotification={setNewNotification}\n          modalDetails={modalDetails}\n          setModalDetails={setModalDetails}\n          hasTelegram={hasTelegram}\n          hasPhone={hasPhone}\n        />\n      </>\n    );\n  };\n\n  const advancedConfiguration = () => {\n    return (\n      <>\n        {notification.type === 'RollingEventAlertConfig' &&\n          allowedNotifications.includes(notification.type) && (\n            <Form.Group controlId=\"notification-severity\">\n              <Form.Label>\n                {i18n.t('notifications_page.edit_severity')}\n              </Form.Label>\n              <NotificationsCheckboxesStyle gap=\"10\">\n                <RadioButtonGroup\n                  options={severitiesRadioButtons}\n                  handleChange={(event) =>\n                    handleSeverities(event, setNewNotification)\n                  }\n                  className={notification.severity}\n                  checked={notification.severity}\n                  type=\"radio\"\n                />\n              </NotificationsCheckboxesStyle>\n            </Form.Group>\n          )}\n\n        {notification.type !== 'WbeWeeklyDigestAlertConfig' &&\n          notification.type !== 'DataloggerThresholdAlertConfig' &&\n          allowedNotifications.includes(notification.type) && (\n            <NotificationSources\n              notification={notification}\n              setNewNotification={setNewNotification}\n              points={points}\n            />\n          )}\n\n        {notification.type === 'WbeWeeklyDigestAlertConfig' &&\n          notification.tags !== undefined &&\n          allowedNotifications.includes(notification.type) && (\n            <NotificationTags\n              notification={notification}\n              setNewNotification={setNewNotification}\n              allowedNotifications={allowedNotifications}\n              tags={tags}\n            />\n          )}\n\n        {notification.type === 'DataloggerThresholdAlertConfig' &&\n          allowedNotifications.includes(notification.type) &&\n          notification.sensors !== undefined && (\n            <NotificationSensors\n              notification={notification}\n              setNewNotification={setNewNotification}\n              sensors={sensors}\n            />\n          )}\n      </>\n    );\n  };\n\n  return (\n    <NotificationSidebarFormAreaStyle>\n      {basicConfiguration(advancedConfiguration)}\n\n      {notification.type === 'RollingEventAlertConfig' &&\n        allowedNotifications.includes(notification.type) && (\n          <Form.Group>\n            <Form.Check\n              inline\n              label={i18n.t('notifications_page.edit_sampler_active')}\n              name=\"pump_only\"\n              type=\"checkbox\"\n              id=\"pump_only\"\n              onChange={(e) => handleNotificationSample(e, setNewNotification)}\n              checked={notification.pump_only === '1'}\n            />\n          </Form.Group>\n        )}\n    </NotificationSidebarFormAreaStyle>\n  );\n};\n\nexport default NotificationsFormContent;\n\nconst NotificationSidebarFormAreaStyle = styled.div`\n  @media (max-width: 500px) {\n    max-height: 60vh !important;\n  }\n\n  width: 100%;\n  max-height: 72vh;\n  box-shadow: 0px 0px 3px 1px ${({ theme }) => theme.colorScheme.natural.n30};\n  padding: 10px 30px;\n  overflow: auto;\n\n  label {\n    display: block;\n    font-size: ${({ theme }) => theme.fontSize.md};\n    font-weight: ${({ theme }) => theme.fontWeight.w600};\n    margin: 0;\n  }\n\n  .form-group {\n    display: flex;\n    flex-direction: column;\n    gap: 8px;\n  }\n\n  .all,\n  .include,\n  .exclude,\n  .telegram,\n  .email,\n  .sms {\n    border: 1px solid ${({ theme }) => theme.colorScheme.natural.n80};\n    color: ${({ theme }) => theme.colorScheme.natural.n80};\n  }\n  .extreme {\n    border: 1px solid ${({ theme }) => theme.colorScheme.primary.p1};\n    color: ${({ theme }) => theme.colorScheme.primary.p1};\n  }\n  .high {\n    border: 1px solid ${({ theme }) => theme.colorScheme.data.O100};\n    color: ${({ theme }) => theme.colorScheme.data.O100};\n  }\n  .medium {\n    border: 1px solid ${({ theme }) => theme.colorScheme.data.W100};\n    color: ${({ theme }) => theme.colorScheme.data.W100};\n  }\n\n  .form-check-inline {\n    align-items: self-start !important;\n\n    input {\n      margin-top: 7px !important;\n    }\n  }\n`;\n\nexport const NotificationsCheckboxesStyle = styled.div<{ gap: string }>`\n  display: flex;\n  gap: ${({ gap }) => gap + 'px'};\n  margin-bottom: 8px;\n`;\n"],"mappings":"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"}
|
|
211
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reactBootstrap","_i18n","_interopRequireDefault","_notificationUtils","_RadioButtonGroup","_NotificationsUtils","_EventType","_NotificationSendVia","_WaterAuthoritySelection","_NotificationSources","_NotificationTags","_NotificationSensors","_getRequireWildcardCache","nodeInterop","WeakMap","cacheBabelInterop","cacheNodeInterop","obj","__esModule","default","cache","has","get","newObj","hasPropertyDescriptor","Object","defineProperty","getOwnPropertyDescriptor","key","prototype","hasOwnProperty","call","desc","set","NotificationsFormContent","_ref","notification","points","tags","sensors","waterAuthorities","allowedNotifications","setNewNotification","hasPhone","hasTelegram","initialAdvancedConfig","modalDetails","setModalDetails","useState","open","instance","isDirectImpact","direct_impact_only","undefined","showAdvancedConfig","setShowAdvancedConfig","showAdvancedConfigLogic","type","id","showAdvancedConfigCheckbox","defaultWaterAuthorityIfSingle","length","handleNotificationType","value","label","i18n","t","handleWaterAuthorities","selection_type","water_authority","useEffect","basicConfiguration","advancedComponents","createElement","Fragment","EventType","Form","Group","Check","inline","name","onChange","e","handleDirectImpact","checked","WaterAuthoritySelection","NotificationSendVia","includes","handleNotificationSample","pump_only","advancedConfiguration","controlId","Label","NotificationsCheckboxesStyle","gap","options","severitiesRadioButtons","handleChange","event","handleSeverities","className","severity","NotificationSources","NotificationTags","NotificationSensors","NotificationSidebarFormAreaStyle","_default","exports","styled","div","withConfig","displayName","componentId","_ref2","theme","colorScheme","natural","n30","_ref3","fontSize","md","_ref4","fontWeight","w600","_ref5","n80","_ref6","_ref7","primary","p1","_ref8","_ref9","data","O100","_ref10","_ref11","W100","_ref12","_ref13"],"sources":["../../../../../src/pages/NotificationsPageV2/components/NotificationsForm/NotificationsFormContent.tsx"],"sourcesContent":["import React, { useEffect, useState } from 'react';\nimport styled from 'styled-components/macro';\nimport { Form } from 'react-bootstrap';\nimport i18n from 'src/utilities/i18n';\nimport {\n  Notification,\n  severitiesRadioButtons,\n  AdvancedSelection,\n} from 'src/pages/NotificationsPageV2/notificationUtils';\nimport RadioButtonGroup from 'src/ui-kit/RadioButtons/RadioButtonGroup';\nimport {\n  handleDirectImpact,\n  handleNotificationSample,\n  handleNotificationType,\n  handleSeverities,\n  handleWaterAuthorities,\n} from '../NotificationsUtils';\nimport { AlertDetails } from '../../../SamplingsPage/SamplingProperties/samplingPropertiesUtils';\nimport { EventType } from './EventType';\nimport { NotificationSendVia } from './NotificationSendVia';\nimport { WaterAuthoritySelection } from './WaterAuthoritySelection';\nimport { NotificationSources } from './NotificationSources';\nimport { NotificationTags } from './NotificationTags';\nimport { NotificationSensors } from './NotificationSensors';\n\ninterface notificationFormContentProps {\n  notification: Notification;\n  points: AdvancedSelection[];\n  tags: AdvancedSelection[];\n  sensors: AdvancedSelection[];\n  waterAuthorities: AdvancedSelection[];\n  allowedNotifications: string[];\n  setNewNotification: any;\n  hasPhone: boolean;\n  hasTelegram: boolean;\n  initialAdvancedConfig: boolean;\n  direct_impact_only: boolean;\n}\n\nconst NotificationsFormContent: React.FC<notificationFormContentProps> = ({\n  notification,\n  points,\n  tags,\n  sensors,\n  waterAuthorities,\n  allowedNotifications,\n  setNewNotification,\n  hasPhone,\n  hasTelegram,\n  initialAdvancedConfig,\n}) => {\n  const [modalDetails, setModalDetails] = useState<AlertDetails>({\n    open: false,\n    instance: '',\n  });\n  const isDirectImpact = (notification) => {\n    return (\n      notification.direct_impact_only === '1' ||\n      notification.direct_impact_only === undefined\n    );\n  };\n  const [showAdvancedConfig, setShowAdvancedConfig] = useState(\n    isDirectImpact(notification) ? false : true,\n  );\n  const showAdvancedConfigLogic = () => {\n    return (\n      ((notification.type !== 'RollingEventAlertConfig' ||\n        initialAdvancedConfig) &&\n        showAdvancedConfig) ||\n      (notification.id === '' &&\n        notification.type !== 'RollingEventAlertConfig')\n    );\n  };\n\n  const showAdvancedConfigCheckbox = () => {\n    return (\n      notification.type === 'RollingEventAlertConfig' && initialAdvancedConfig\n    );\n  };\n\n  const defaultWaterAuthorityIfSingle = () => {\n    if (waterAuthorities.length === 1) {\n      handleNotificationType(\n        {\n          value: 'RollingEventAlertConfig',\n          label: i18n.t(`notifications_page.RollingEventAlertConfig`),\n        },\n        notification,\n        setNewNotification,\n      );\n      handleWaterAuthorities(\n        undefined,\n        {\n          selection_type: 'include',\n          set: [\n            {\n              value: waterAuthorities[0].water_authority.id,\n              label: waterAuthorities[0].water_authority.label,\n            },\n          ],\n        },\n        notification,\n        setNewNotification,\n      );\n    }\n  };\n\n  useEffect(() => {\n    defaultWaterAuthorityIfSingle();\n    if (notification.type === '') {\n      handleNotificationType(\n        {\n          value: 'RollingEventAlertConfig',\n          label: i18n.t(`notifications_page.RollingEventAlertConfig`),\n        },\n        notification,\n        setNewNotification,\n      );\n    }\n  }, []);\n\n  const basicConfiguration = (advancedComponents) => {\n    return (\n      <>\n        <EventType\n          notification={notification}\n          setNewNotification={setNewNotification}\n          allowedNotifications={allowedNotifications}\n        />\n\n        {showAdvancedConfigCheckbox() && (\n          <Form.Group>\n            <Form.Check\n              inline\n              label={i18n.t('notifications_page.advanced_configuration')}\n              name=\"advanced_configuration\"\n              type=\"checkbox\"\n              id=\"advanced_configuration\"\n              onChange={(e) => {\n                setShowAdvancedConfig(!showAdvancedConfig);\n                handleDirectImpact(e, setNewNotification, notification);\n              }}\n              checked={showAdvancedConfig}\n            />\n          </Form.Group>\n        )}\n\n        {waterAuthorities.length > 1 && (\n          <WaterAuthoritySelection\n            waterAuthorities={waterAuthorities}\n            allowedNotifications={allowedNotifications}\n            notification={notification}\n            setNewNotification={setNewNotification}\n          />\n        )}\n\n        {showAdvancedConfigLogic() && advancedComponents()}\n\n        <NotificationSendVia\n          notification={notification}\n          setNewNotification={setNewNotification}\n          modalDetails={modalDetails}\n          setModalDetails={setModalDetails}\n          hasTelegram={hasTelegram}\n          hasPhone={hasPhone}\n        />\n\n        {showAdvancedConfigLogic() &&\n          notification.type === 'RollingEventAlertConfig' &&\n          allowedNotifications.includes(notification.type) && (\n            <Form.Group>\n              <Form.Check\n                inline\n                label={i18n.t('notifications_page.edit_sampler_active')}\n                name=\"pump_only\"\n                type=\"checkbox\"\n                id=\"pump_only\"\n                onChange={(e) =>\n                  handleNotificationSample(e, setNewNotification)\n                }\n                checked={notification.pump_only === '1'}\n              />\n            </Form.Group>\n          )}\n      </>\n    );\n  };\n\n  const advancedConfiguration = () => {\n    return (\n      <>\n        {notification.type === 'RollingEventAlertConfig' &&\n          allowedNotifications.includes(notification.type) && (\n            <Form.Group controlId=\"notification-severity\">\n              <Form.Label>\n                {i18n.t('notifications_page.edit_severity')}\n              </Form.Label>\n              <NotificationsCheckboxesStyle gap=\"10\">\n                <RadioButtonGroup\n                  options={severitiesRadioButtons}\n                  handleChange={(event) =>\n                    handleSeverities(event, setNewNotification)\n                  }\n                  className={notification.severity}\n                  checked={notification.severity}\n                  type=\"radio\"\n                />\n              </NotificationsCheckboxesStyle>\n            </Form.Group>\n          )}\n\n        {notification.type !== 'WbeWeeklyDigestAlertConfig' &&\n          notification.type !== 'DataloggerThresholdAlertConfig' &&\n          allowedNotifications.includes(notification.type) && (\n            <NotificationSources\n              notification={notification}\n              setNewNotification={setNewNotification}\n              points={points}\n            />\n          )}\n\n        {notification.type === 'WbeWeeklyDigestAlertConfig' &&\n          notification.tags !== undefined &&\n          allowedNotifications.includes(notification.type) && (\n            <NotificationTags\n              notification={notification}\n              setNewNotification={setNewNotification}\n              allowedNotifications={allowedNotifications}\n              tags={tags}\n            />\n          )}\n\n        {notification.type === 'DataloggerThresholdAlertConfig' &&\n          allowedNotifications.includes(notification.type) &&\n          notification.sensors !== undefined && (\n            <NotificationSensors\n              notification={notification}\n              setNewNotification={setNewNotification}\n              sensors={sensors}\n            />\n          )}\n      </>\n    );\n  };\n\n  return (\n    <NotificationSidebarFormAreaStyle>\n      {basicConfiguration(advancedConfiguration)}\n    </NotificationSidebarFormAreaStyle>\n  );\n};\n\nexport default NotificationsFormContent;\n\nconst NotificationSidebarFormAreaStyle = styled.div`\n  @media (max-width: 500px) {\n    max-height: 60vh !important;\n  }\n\n  width: 100%;\n  max-height: 72vh;\n  box-shadow: 0px 0px 3px 1px ${({ theme }) => theme.colorScheme.natural.n30};\n  padding: 10px 30px;\n  overflow: auto;\n\n  label {\n    display: block;\n    font-size: ${({ theme }) => theme.fontSize.md};\n    font-weight: ${({ theme }) => theme.fontWeight.w600};\n    margin: 0;\n  }\n\n  .form-group {\n    display: flex;\n    flex-direction: column;\n    gap: 8px;\n  }\n\n  .all,\n  .include,\n  .exclude,\n  .telegram,\n  .email,\n  .sms {\n    border: 1px solid ${({ theme }) => theme.colorScheme.natural.n80};\n    color: ${({ theme }) => theme.colorScheme.natural.n80};\n  }\n  .extreme {\n    border: 1px solid ${({ theme }) => theme.colorScheme.primary.p1};\n    color: ${({ theme }) => theme.colorScheme.primary.p1};\n  }\n  .high {\n    border: 1px solid ${({ theme }) => theme.colorScheme.data.O100};\n    color: ${({ theme }) => theme.colorScheme.data.O100};\n  }\n  .medium {\n    border: 1px solid ${({ theme }) => theme.colorScheme.data.W100};\n    color: ${({ theme }) => theme.colorScheme.data.W100};\n  }\n\n  .form-check-inline {\n    align-items: self-start !important;\n\n    input {\n      margin-top: 7px !important;\n    }\n  }\n`;\n\nexport const NotificationsCheckboxesStyle = styled.div<{ gap: string }>`\n  display: flex;\n  gap: ${({ gap }) => gap + 'px'};\n  margin-bottom: 8px;\n`;\n"],"mappings":"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"}
|