@dhis2/analytics 20.6.3 → 21.0.0-alpha.2
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/build/cjs/__demo__/Filter.stories.js +2 -2
- package/build/cjs/__demo__/FixedPeriodSelect.stories.js +2 -2
- package/build/cjs/__demo__/OpenFileDialog.stories.js +1 -1
- package/build/cjs/__demo__/OrgUnitDimension.stories.js +95 -0
- package/build/cjs/__demo__/PivotTable.stories.js +2 -2
- package/build/cjs/api/analytics/AnalyticsBase.js +1 -1
- package/build/cjs/api/analytics/AnalyticsRequest.js +1 -1
- package/build/cjs/api/analytics/AnalyticsRequestBase.js +3 -3
- package/build/cjs/api/analytics/AnalyticsRequestPropertiesMixin.js +7 -7
- package/build/cjs/api/analytics/AnalyticsResponse.js +2 -2
- package/build/cjs/api/analytics/__tests__/AnalyticsAggregate.spec.js +11 -1
- package/build/cjs/api/analytics/__tests__/AnalyticsRequest.spec.js +9 -9
- package/build/cjs/api/analytics/__tests__/AnalyticsRequestBase.spec.js +4 -4
- package/build/cjs/api/analytics/utils.js +1 -1
- package/build/cjs/api/dimensions.js +37 -37
- package/build/cjs/api/organisationUnits.js +100 -46
- package/build/cjs/components/DataDimension/DataTypesSelector.js +3 -3
- package/build/cjs/components/DataDimension/DetailSelector.js +2 -2
- package/build/cjs/components/DataDimension/GroupSelector.js +9 -9
- package/build/cjs/components/DataDimension/ItemSelector.js +19 -19
- package/build/cjs/components/DataDimension/MetricSelector.js +3 -3
- package/build/cjs/components/DataDimension/styles/DataTypesSelector.style.js +1 -1
- package/build/cjs/components/DataDimension/styles/DetailSelector.style.js +1 -1
- package/build/cjs/components/DataDimension/styles/GroupSelector.style.js +1 -1
- package/build/cjs/components/DataDimension/styles/MetricSelector.style.js +1 -1
- package/build/cjs/components/DimensionMenu.js +10 -10
- package/build/cjs/components/DimensionsPanel/DimensionsPanel.js +2 -2
- package/build/cjs/components/DimensionsPanel/List/DimensionItem.js +5 -5
- package/build/cjs/components/DimensionsPanel/List/DimensionLabel.js +2 -2
- package/build/cjs/components/DimensionsPanel/List/DimensionList.js +10 -10
- package/build/cjs/components/DimensionsPanel/List/styles/DimensionList.style.js +1 -1
- package/build/cjs/components/DimensionsPanel/styles/DimensionsPanel.style.js +1 -1
- package/build/cjs/components/DynamicDimension/DynamicDimension.js +4 -4
- package/build/cjs/components/DynamicDimension/ItemSelector.js +8 -8
- package/build/cjs/components/DynamicDimension/styles/DynamicDimension.style.js +1 -1
- package/build/cjs/components/FileMenu/DeleteDialog.js +4 -4
- package/build/cjs/components/FileMenu/FileMenu.js +7 -7
- package/build/cjs/components/FileMenu/FileMenu.styles.js +1 -1
- package/build/cjs/components/FileMenu/GetLinkDialog.js +3 -3
- package/build/cjs/components/FileMenu/RenameDialog.js +4 -4
- package/build/cjs/components/FileMenu/SaveAsDialog.js +4 -4
- package/build/cjs/components/FileMenu/__tests__/DeleteDialog.spec.js +1 -1
- package/build/cjs/components/FileMenu/__tests__/RenameDialog.spec.js +1 -1
- package/build/cjs/components/FileMenu/__tests__/SaveAsDialog.spec.js +1 -1
- package/build/cjs/components/FileMenu/utils.js +3 -3
- package/build/cjs/components/Filter/Filter.js +1 -1
- package/build/cjs/components/Filter/styles/Filter.style.js +1 -1
- package/build/cjs/components/LegendKey/LegendKey.js +9 -9
- package/build/cjs/components/LegendKey/styles/LegendKey.style.js +1 -1
- package/build/cjs/components/OpenFileDialog/CustomSelectOption.js +2 -2
- package/build/cjs/components/OpenFileDialog/OpenFileDialog.js +21 -21
- package/build/cjs/components/OpenFileDialog/OpenFileDialog.styles.js +1 -1
- package/build/cjs/components/OpenFileDialog/styles/CustomSelectOption.style.js +1 -1
- package/build/cjs/components/Options/VisualizationOptions.js +2 -2
- package/build/cjs/components/Options/styles/VisualizationOptions.style.js +10 -10
- package/build/cjs/components/OrgUnitDimension/OrgUnitDimension.js +168 -203
- package/build/cjs/components/OrgUnitDimension/OrgUnitDimensionOld.js +244 -0
- package/build/cjs/components/OrgUnitDimension/styles/OrgUnitDimension.style.js +5 -2
- package/build/cjs/components/PeriodDimension/FixedPeriodFilter.js +5 -5
- package/build/cjs/components/PeriodDimension/FixedPeriodSelect.js +6 -6
- package/build/cjs/components/PeriodDimension/PeriodTransfer.js +11 -11
- package/build/cjs/components/PeriodDimension/RelativePeriodFilter.js +2 -2
- package/build/cjs/components/PeriodDimension/styles/FixedPeriodSelect.style.js +1 -1
- package/build/cjs/components/PeriodDimension/styles/PeriodFilter.style.js +1 -1
- package/build/cjs/components/PeriodDimension/utils/fixedPeriods.js +49 -49
- package/build/cjs/components/PivotTable/PivotTable.js +2 -2
- package/build/cjs/components/PivotTable/PivotTableCell.js +3 -3
- package/build/cjs/components/PivotTable/PivotTableColumnHeaderCell.js +2 -2
- package/build/cjs/components/PivotTable/PivotTableContainer.js +2 -2
- package/build/cjs/components/PivotTable/PivotTableEngineContext.js +2 -2
- package/build/cjs/components/PivotTable/PivotTableSortIcon.js +2 -2
- package/build/cjs/components/PivotTable/PivotTableTitleRow.js +4 -4
- package/build/cjs/components/PivotTable/PivotTableValueCell.js +2 -2
- package/build/cjs/components/PivotTable/styles/PivotTable.style.js +3 -3
- package/build/cjs/components/TransferOption.js +7 -7
- package/build/cjs/components/styles/DimensionSelector.style.js +1 -1
- package/build/cjs/components/styles/TransferOption.style.js +1 -1
- package/build/cjs/index.js +6 -6
- package/build/cjs/locales/en/translations.json +5 -0
- package/build/cjs/locales/ru/translations.json +1 -1
- package/build/cjs/locales/zh/translations.json +7 -7
- package/build/cjs/modules/axis.js +1 -1
- package/build/cjs/modules/layoutUiRules/rules.js +1 -1
- package/build/cjs/modules/ouIdHelper/index.js +9 -3
- package/build/cjs/modules/pivotTable/PivotTableEngine.js +3 -3
- package/build/cjs/modules/pivotTable/measureText.js +1 -1
- package/build/cjs/modules/relativeItems/index.js +1 -1
- package/build/cjs/modules/visTypes.js +1 -1
- package/build/cjs/visualizations/config/adapters/dhis_highcharts/addTrendLines.js +1 -1
- package/build/cjs/visualizations/config/adapters/dhis_highcharts/axis.js +2 -2
- package/build/cjs/visualizations/config/adapters/dhis_highcharts/getAxisTitle.js +1 -1
- package/build/cjs/visualizations/config/adapters/dhis_highcharts/index.js +2 -2
- package/build/cjs/visualizations/config/adapters/dhis_highcharts/legend.js +19 -8
- package/build/cjs/visualizations/config/adapters/dhis_highcharts/legendSet.js +1 -1
- package/build/cjs/visualizations/config/adapters/dhis_highcharts/plotOptions.js +1 -1
- package/build/cjs/visualizations/config/adapters/dhis_highcharts/subtitle/index.js +1 -1
- package/build/cjs/visualizations/config/adapters/dhis_highcharts/title/index.js +1 -1
- package/build/cjs/visualizations/config/adapters/dhis_highcharts/title/scatter.js +1 -1
- package/build/cjs/visualizations/config/adapters/dhis_highcharts/xAxis/index.js +1 -1
- package/build/cjs/visualizations/config/adapters/dhis_highcharts/yAxis/gauge.js +3 -3
- package/build/cjs/visualizations/config/adapters/dhis_highcharts/yAxis/index.js +2 -2
- package/build/cjs/visualizations/config/generators/dhis/singleValue.js +5 -5
- package/build/cjs/visualizations/config/index.js +3 -3
- package/build/cjs/visualizations/store/adapters/dhis_dhis/index.js +1 -1
- package/build/cjs/visualizations/store/adapters/dhis_highcharts/index.js +1 -1
- package/build/cjs/visualizations/store/adapters/dhis_highcharts/twoCategory.js +1 -1
- package/build/cjs/visualizations/store/index.js +2 -2
- package/build/cjs/visualizations/util/axisId.js +1 -1
- package/build/cjs/visualizations/util/getFilterText.js +3 -3
- package/build/es/__demo__/OpenFileDialog.stories.js +1 -1
- package/build/es/__demo__/OrgUnitDimension.stories.js +84 -0
- package/build/es/api/analytics/AnalyticsBase.js +1 -1
- package/build/es/api/analytics/AnalyticsRequest.js +1 -1
- package/build/es/api/analytics/AnalyticsRequestBase.js +3 -3
- package/build/es/api/analytics/AnalyticsRequestPropertiesMixin.js +7 -7
- package/build/es/api/analytics/AnalyticsResponse.js +2 -2
- package/build/es/api/analytics/__tests__/AnalyticsAggregate.spec.js +11 -1
- package/build/es/api/analytics/__tests__/AnalyticsRequest.spec.js +9 -9
- package/build/es/api/analytics/__tests__/AnalyticsRequestBase.spec.js +4 -4
- package/build/es/api/analytics/utils.js +1 -1
- package/build/es/api/dimensions.js +39 -39
- package/build/es/api/organisationUnits.js +93 -43
- package/build/es/components/DataDimension/DataTypesSelector.js +3 -3
- package/build/es/components/DataDimension/DetailSelector.js +2 -2
- package/build/es/components/DataDimension/GroupSelector.js +7 -7
- package/build/es/components/DataDimension/ItemSelector.js +17 -17
- package/build/es/components/DataDimension/MetricSelector.js +3 -3
- package/build/es/components/DataDimension/styles/DataTypesSelector.style.js +1 -1
- package/build/es/components/DataDimension/styles/DetailSelector.style.js +1 -1
- package/build/es/components/DataDimension/styles/GroupSelector.style.js +1 -1
- package/build/es/components/DataDimension/styles/MetricSelector.style.js +1 -1
- package/build/es/components/DimensionMenu.js +10 -10
- package/build/es/components/DimensionsPanel/List/DimensionItem.js +3 -3
- package/build/es/components/DimensionsPanel/List/DimensionList.js +8 -8
- package/build/es/components/DimensionsPanel/List/styles/DimensionList.style.js +1 -1
- package/build/es/components/DimensionsPanel/styles/DimensionsPanel.style.js +1 -1
- package/build/es/components/DynamicDimension/DynamicDimension.js +4 -4
- package/build/es/components/DynamicDimension/ItemSelector.js +6 -6
- package/build/es/components/DynamicDimension/styles/DynamicDimension.style.js +1 -1
- package/build/es/components/FileMenu/DeleteDialog.js +1 -1
- package/build/es/components/FileMenu/FileMenu.js +4 -4
- package/build/es/components/FileMenu/FileMenu.styles.js +1 -1
- package/build/es/components/FileMenu/GetLinkDialog.js +2 -2
- package/build/es/components/FileMenu/RenameDialog.js +1 -1
- package/build/es/components/FileMenu/SaveAsDialog.js +1 -1
- package/build/es/components/FileMenu/__tests__/DeleteDialog.spec.js +1 -1
- package/build/es/components/FileMenu/__tests__/RenameDialog.spec.js +1 -1
- package/build/es/components/FileMenu/__tests__/SaveAsDialog.spec.js +1 -1
- package/build/es/components/FileMenu/utils.js +3 -3
- package/build/es/components/Filter/Filter.js +1 -1
- package/build/es/components/Filter/styles/Filter.style.js +1 -1
- package/build/es/components/LegendKey/LegendKey.js +9 -9
- package/build/es/components/LegendKey/styles/LegendKey.style.js +1 -1
- package/build/es/components/OpenFileDialog/CustomSelectOption.js +2 -2
- package/build/es/components/OpenFileDialog/OpenFileDialog.js +19 -19
- package/build/es/components/OpenFileDialog/OpenFileDialog.styles.js +1 -1
- package/build/es/components/OpenFileDialog/styles/CustomSelectOption.style.js +1 -1
- package/build/es/components/Options/styles/VisualizationOptions.style.js +10 -10
- package/build/es/components/OrgUnitDimension/OrgUnitDimension.js +168 -204
- package/build/es/components/OrgUnitDimension/OrgUnitDimensionOld.js +220 -0
- package/build/es/components/OrgUnitDimension/styles/OrgUnitDimension.style.js +3 -2
- package/build/es/components/PeriodDimension/FixedPeriodFilter.js +5 -5
- package/build/es/components/PeriodDimension/FixedPeriodSelect.js +3 -3
- package/build/es/components/PeriodDimension/PeriodTransfer.js +9 -9
- package/build/es/components/PeriodDimension/RelativePeriodFilter.js +2 -2
- package/build/es/components/PeriodDimension/styles/FixedPeriodSelect.style.js +1 -1
- package/build/es/components/PeriodDimension/styles/PeriodFilter.style.js +1 -1
- package/build/es/components/PeriodDimension/utils/fixedPeriods.js +49 -49
- package/build/es/components/PivotTable/PivotTableCell.js +3 -3
- package/build/es/components/PivotTable/PivotTableColumnHeaderCell.js +2 -2
- package/build/es/components/PivotTable/PivotTableContainer.js +2 -2
- package/build/es/components/PivotTable/PivotTableSortIcon.js +2 -2
- package/build/es/components/PivotTable/PivotTableTitleRow.js +2 -2
- package/build/es/components/PivotTable/styles/PivotTable.style.js +3 -3
- package/build/es/components/TransferOption.js +6 -6
- package/build/es/components/styles/DimensionSelector.style.js +1 -1
- package/build/es/components/styles/TransferOption.style.js +1 -1
- package/build/es/index.js +1 -1
- package/build/es/locales/en/translations.json +5 -0
- package/build/es/locales/ru/translations.json +1 -1
- package/build/es/locales/zh/translations.json +7 -7
- package/build/es/modules/axis.js +1 -1
- package/build/es/modules/layoutUiRules/rules.js +1 -1
- package/build/es/modules/ouIdHelper/index.js +5 -2
- package/build/es/modules/pivotTable/PivotTableEngine.js +3 -3
- package/build/es/modules/pivotTable/measureText.js +1 -1
- package/build/es/modules/relativeItems/index.js +2 -2
- package/build/es/modules/visTypes.js +1 -1
- package/build/es/visualizations/config/adapters/dhis_highcharts/addTrendLines.js +1 -1
- package/build/es/visualizations/config/adapters/dhis_highcharts/axis.js +2 -2
- package/build/es/visualizations/config/adapters/dhis_highcharts/getAxisTitle.js +1 -1
- package/build/es/visualizations/config/adapters/dhis_highcharts/legend.js +19 -8
- package/build/es/visualizations/config/adapters/dhis_highcharts/legendSet.js +1 -1
- package/build/es/visualizations/config/adapters/dhis_highcharts/plotOptions.js +1 -1
- package/build/es/visualizations/config/adapters/dhis_highcharts/subtitle/index.js +1 -1
- package/build/es/visualizations/config/adapters/dhis_highcharts/title/index.js +1 -1
- package/build/es/visualizations/config/adapters/dhis_highcharts/title/scatter.js +1 -1
- package/build/es/visualizations/config/adapters/dhis_highcharts/xAxis/index.js +1 -1
- package/build/es/visualizations/config/adapters/dhis_highcharts/yAxis/gauge.js +3 -3
- package/build/es/visualizations/config/adapters/dhis_highcharts/yAxis/index.js +2 -2
- package/build/es/visualizations/config/generators/dhis/singleValue.js +5 -5
- package/build/es/visualizations/config/index.js +3 -3
- package/build/es/visualizations/store/adapters/dhis_dhis/index.js +1 -1
- package/build/es/visualizations/store/adapters/dhis_highcharts/index.js +1 -1
- package/build/es/visualizations/store/adapters/dhis_highcharts/twoCategory.js +1 -1
- package/build/es/visualizations/store/index.js +2 -2
- package/build/es/visualizations/util/axisId.js +1 -1
- package/build/es/visualizations/util/getFilterText.js +3 -3
- package/package.json +2 -1
- package/CHANGELOG.md +0 -2742
- package/build/cjs/api/organisationUnits-dataEngine.js +0 -119
- package/build/cjs/components/OrgUnitDimension/__tests__/OrgUnitDimension.spec.js +0 -96
- package/build/es/api/organisationUnits-dataEngine.js +0 -96
- package/build/es/components/OrgUnitDimension/__tests__/OrgUnitDimension.spec.js +0 -86
|
@@ -12,19 +12,19 @@ export const modalContent = {
|
|
|
12
12
|
export const tabBar = {
|
|
13
13
|
styles: /*#__PURE__*/React.createElement(_JSXStyle, {
|
|
14
14
|
id: "3103009923"
|
|
15
|
-
}, [
|
|
15
|
+
}, [`div.jsx-3103009923{padding-right:${spacers.dp24};}`]),
|
|
16
16
|
className: "jsx-3103009923"
|
|
17
17
|
};
|
|
18
18
|
export const tabContent = {
|
|
19
19
|
styles: /*#__PURE__*/React.createElement(_JSXStyle, {
|
|
20
20
|
id: "2208787536"
|
|
21
|
-
}, [
|
|
21
|
+
}, [`div.jsx-2208787536{overflow:auto;padding-right:${spacers.dp24};}`]),
|
|
22
22
|
className: "jsx-2208787536"
|
|
23
23
|
};
|
|
24
24
|
export const tabSection = {
|
|
25
25
|
styles: /*#__PURE__*/React.createElement(_JSXStyle, {
|
|
26
26
|
id: "1427514941"
|
|
27
|
-
}, [
|
|
27
|
+
}, [`div.jsx-1427514941{padding:${spacers.dp16} 0;}`, `div.jsx-1427514941:not(:last-child){border-bottom:1px solid ${colors.grey300};margin-bottom:${spacers.dp8};}`]),
|
|
28
28
|
className: "jsx-1427514941"
|
|
29
29
|
};
|
|
30
30
|
export const tabSectionContent = {
|
|
@@ -36,37 +36,37 @@ export const tabSectionContent = {
|
|
|
36
36
|
export const tabSectionTitle = {
|
|
37
37
|
styles: /*#__PURE__*/React.createElement(_JSXStyle, {
|
|
38
38
|
id: "3115295887"
|
|
39
|
-
}, [
|
|
39
|
+
}, [`span.jsx-3115295887{display:inline-block;padding-bottom:${spacers.dp12};font-size:15px;color:${colors.grey900};font-weight:500;-webkit-letter-spacing:0.2px;-moz-letter-spacing:0.2px;-ms-letter-spacing:0.2px;letter-spacing:0.2px;}`]),
|
|
40
40
|
className: "jsx-3115295887"
|
|
41
41
|
};
|
|
42
42
|
export const tabSectionTitleMargin = {
|
|
43
43
|
styles: /*#__PURE__*/React.createElement(_JSXStyle, {
|
|
44
44
|
id: "642558349"
|
|
45
|
-
}, [
|
|
45
|
+
}, [`span.jsx-642558349{margin-top:${spacers.dp8};}`]),
|
|
46
46
|
className: "jsx-642558349"
|
|
47
47
|
};
|
|
48
48
|
export const tabSectionOption = {
|
|
49
49
|
styles: /*#__PURE__*/React.createElement(_JSXStyle, {
|
|
50
50
|
id: "1665807213"
|
|
51
|
-
}, [
|
|
51
|
+
}, [`div.jsx-1665807213:not(:last-child):not(.inline){padding-bottom:${spacers.dp16};}`]),
|
|
52
52
|
className: "jsx-1665807213"
|
|
53
53
|
};
|
|
54
54
|
export const tabSectionOptionItem = {
|
|
55
55
|
styles: /*#__PURE__*/React.createElement(_JSXStyle, {
|
|
56
56
|
id: "2983019948"
|
|
57
|
-
}, [
|
|
57
|
+
}, [`div.jsx-2983019948:not(:last-child){padding-bottom:${spacers.dp8};}`]),
|
|
58
58
|
className: "jsx-2983019948"
|
|
59
59
|
};
|
|
60
60
|
export const tabSectionOptionText = {
|
|
61
61
|
styles: /*#__PURE__*/React.createElement(_JSXStyle, {
|
|
62
62
|
id: "3330936769"
|
|
63
|
-
}, [
|
|
63
|
+
}, [`p.jsx-3330936769{margin:0;padding-bottom:${spacers.dp8};font-size:14px;line-height:19px;color:${colors.grey700};}`]),
|
|
64
64
|
className: "jsx-3330936769"
|
|
65
65
|
};
|
|
66
66
|
export const tabSectionOptionToggleable = {
|
|
67
67
|
styles: /*#__PURE__*/React.createElement(_JSXStyle, {
|
|
68
68
|
id: "684239008"
|
|
69
|
-
}, [
|
|
69
|
+
}, [`div.jsx-684239008{margin:${spacers.dp4} 0 0 23px;}`]),
|
|
70
70
|
className: "jsx-684239008"
|
|
71
71
|
};
|
|
72
72
|
export const tabSectionToggleableSubsection = {
|
|
@@ -84,6 +84,6 @@ export const tabSectionOptionComplexInline = {
|
|
|
84
84
|
export const tabSectionOptionIcon = {
|
|
85
85
|
styles: /*#__PURE__*/React.createElement(_JSXStyle, {
|
|
86
86
|
id: "112181591"
|
|
87
|
-
}, [
|
|
87
|
+
}, [`span.jsx-112181591{vertical-align:top;margin-right:${spacers.dp4};color:${colors.grey600};}`]),
|
|
88
88
|
className: "jsx-112181591"
|
|
89
89
|
};
|
|
@@ -1,220 +1,184 @@
|
|
|
1
1
|
import _JSXStyle from "styled-jsx/style";
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
import { OrgUnitSelector, userOrgUnits } from '@dhis2/d2-ui-org-unit-dialog';
|
|
6
|
-
import { CircularLoader, colors } from '@dhis2/ui';
|
|
7
|
-
import sortBy from 'lodash/sortBy';
|
|
2
|
+
import { useDataEngine } from '@dhis2/app-runtime';
|
|
3
|
+
import { OrganisationUnitTree, Checkbox, MultiSelect, MultiSelectOption } from '@dhis2/ui';
|
|
4
|
+
import cx from 'classnames';
|
|
8
5
|
import PropTypes from 'prop-types';
|
|
9
|
-
import React, {
|
|
10
|
-
import { apiFetchOrganisationUnitGroups, apiFetchOrganisationUnitLevels
|
|
11
|
-
import
|
|
6
|
+
import React, { useEffect, useState } from 'react';
|
|
7
|
+
import { apiFetchOrganisationUnitGroups, apiFetchOrganisationUnitLevels } from '../../api/organisationUnits';
|
|
8
|
+
import i18n from '../../locales/index.js';
|
|
9
|
+
import { ouIdHelper, USER_ORG_UNIT, USER_ORG_UNIT_CHILDREN, USER_ORG_UNIT_GRANDCHILDREN } from '../../modules/ouIdHelper';
|
|
12
10
|
import { DIMENSION_ID_ORGUNIT } from '../../modules/predefinedDimensions';
|
|
13
11
|
import styles from './styles/OrgUnitDimension.style';
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
selected
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
_defineProperty(this, "onLevelChange", event => {
|
|
45
|
-
const levelIds = event.target.value.filter(id => !!id);
|
|
46
|
-
this.props.onSelect({
|
|
47
|
-
dimensionId: DIMENSION_ID_ORGUNIT,
|
|
48
|
-
items: [...this.props.ouItems.filter(ou => !ouIdHelper.hasLevelPrefix(ou.id)), ...levelIds.map(id => {
|
|
49
|
-
const levelOu = this.state.ouLevels.find(ou => ou.id === id);
|
|
50
|
-
return { ...levelOu,
|
|
51
|
-
id: ouIdHelper.addLevelPrefix(levelOu.id)
|
|
52
|
-
};
|
|
53
|
-
})]
|
|
54
|
-
});
|
|
55
|
-
});
|
|
56
|
-
|
|
57
|
-
_defineProperty(this, "onGroupChange", event => {
|
|
58
|
-
const groupIds = event.target.value.filter(id => !!id);
|
|
59
|
-
this.props.onSelect({
|
|
60
|
-
dimensionId: DIMENSION_ID_ORGUNIT,
|
|
61
|
-
items: [...this.props.ouItems.filter(ou => !ouIdHelper.hasGroupPrefix(ou.id)), ...groupIds.map(id => {
|
|
62
|
-
const groupOu = this.state.ouGroups.find(ou => ou.id === id);
|
|
63
|
-
return { ...groupOu,
|
|
64
|
-
id: ouIdHelper.addGroupPrefix(id)
|
|
65
|
-
};
|
|
66
|
-
})]
|
|
12
|
+
const DYNAMIC_ORG_UNITS = [USER_ORG_UNIT, USER_ORG_UNIT_CHILDREN, USER_ORG_UNIT_GRANDCHILDREN];
|
|
13
|
+
|
|
14
|
+
const OrgUnitDimension = ({
|
|
15
|
+
root,
|
|
16
|
+
selected,
|
|
17
|
+
onSelect
|
|
18
|
+
}) => {
|
|
19
|
+
const [ouLevels, setOuLevels] = useState([]);
|
|
20
|
+
const [ouGroups, setOuGroups] = useState([]);
|
|
21
|
+
const dataEngine = useDataEngine();
|
|
22
|
+
|
|
23
|
+
const onSelectItems = selectedItem => {
|
|
24
|
+
const {
|
|
25
|
+
id,
|
|
26
|
+
checked,
|
|
27
|
+
displayName,
|
|
28
|
+
path
|
|
29
|
+
} = selectedItem;
|
|
30
|
+
let result = [...selected];
|
|
31
|
+
|
|
32
|
+
if (checked && DYNAMIC_ORG_UNITS.includes(id)) {
|
|
33
|
+
result = [...result.filter(item => DYNAMIC_ORG_UNITS.includes(item.id)), {
|
|
34
|
+
id,
|
|
35
|
+
displayName
|
|
36
|
+
}];
|
|
37
|
+
} else if (checked) {
|
|
38
|
+
result.push({
|
|
39
|
+
id,
|
|
40
|
+
path,
|
|
41
|
+
name: displayName
|
|
67
42
|
});
|
|
68
|
-
}
|
|
43
|
+
} else {
|
|
44
|
+
result = [...result.filter(item => item.id !== id)];
|
|
45
|
+
}
|
|
69
46
|
|
|
70
|
-
|
|
47
|
+
return onSelect({
|
|
71
48
|
dimensionId: DIMENSION_ID_ORGUNIT,
|
|
72
|
-
|
|
73
|
-
}));
|
|
74
|
-
|
|
75
|
-
_defineProperty(this, "loadOrgUnitTree", (d2, displayNameProperty) => {
|
|
76
|
-
apiFetchOrganisationUnits(d2, displayNameProperty).then(rootLevel => rootLevel.toArray()).then(roots => {
|
|
77
|
-
this.setState({
|
|
78
|
-
roots,
|
|
79
|
-
root: roots[0]
|
|
80
|
-
});
|
|
81
|
-
});
|
|
82
|
-
});
|
|
83
|
-
|
|
84
|
-
_defineProperty(this, "loadOrgUnitGroups", (d2, displayNameProperty) => {
|
|
85
|
-
apiFetchOrganisationUnitGroups(d2, displayNameProperty).then(organisationUnitGroups => this.setState({
|
|
86
|
-
ouGroups: organisationUnitGroups
|
|
87
|
-
}));
|
|
88
|
-
});
|
|
89
|
-
|
|
90
|
-
_defineProperty(this, "loadOrgUnitLevels", d2 => {
|
|
91
|
-
apiFetchOrganisationUnitLevels(d2).then(organisationUnitLevels => this.setState({
|
|
92
|
-
ouLevels: sortBy(organisationUnitLevels, ['level'])
|
|
93
|
-
}));
|
|
94
|
-
});
|
|
95
|
-
|
|
96
|
-
_defineProperty(this, "handleOrgUnitClick", (event, orgUnit) => {
|
|
97
|
-
const selected = this.props.ouItems;
|
|
98
|
-
|
|
99
|
-
if (selected.some(ou => ou.path === orgUnit.path)) {
|
|
100
|
-
this.props.onDeselect({
|
|
101
|
-
dimensionId: DIMENSION_ID_ORGUNIT,
|
|
102
|
-
itemIdsToRemove: [orgUnit.id]
|
|
103
|
-
});
|
|
104
|
-
} else {
|
|
105
|
-
this.props.onSelect({
|
|
106
|
-
dimensionId: DIMENSION_ID_ORGUNIT,
|
|
107
|
-
items: [...selected, { ...orgUnit,
|
|
108
|
-
name: orgUnit.name || orgUnit.displayName
|
|
109
|
-
}]
|
|
110
|
-
});
|
|
111
|
-
}
|
|
49
|
+
items: result
|
|
112
50
|
});
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
});
|
|
140
|
-
|
|
141
|
-
_defineProperty(this, "handleMultipleOrgUnitsSelect", orgUnits => {
|
|
142
|
-
const selected = this.props.ouItems;
|
|
143
|
-
this.props.onSelect({
|
|
144
|
-
dimensionId: DIMENSION_ID_ORGUNIT,
|
|
145
|
-
items: [...selected, ...orgUnits.reduce((obj, ou) => {
|
|
146
|
-
// avoid duplicates when clicking "Select children" multiple times
|
|
147
|
-
if (!selected.find(i => i.id === ou.id)) {
|
|
148
|
-
obj.push({ ...ou,
|
|
149
|
-
name: ou.name || ou.displayName
|
|
150
|
-
});
|
|
151
|
-
}
|
|
152
|
-
|
|
153
|
-
return obj;
|
|
154
|
-
}, [])]
|
|
155
|
-
});
|
|
51
|
+
};
|
|
52
|
+
|
|
53
|
+
useEffect(() => {
|
|
54
|
+
const doFetchOuLevels = async () => {
|
|
55
|
+
const result = await apiFetchOrganisationUnitLevels(dataEngine);
|
|
56
|
+
result.sort((a, b) => a.level > b.level ? 1 : -1);
|
|
57
|
+
setOuLevels(result);
|
|
58
|
+
};
|
|
59
|
+
|
|
60
|
+
const doFetchOuGroups = async () => {
|
|
61
|
+
const result = await apiFetchOrganisationUnitGroups(dataEngine);
|
|
62
|
+
setOuGroups(result);
|
|
63
|
+
};
|
|
64
|
+
|
|
65
|
+
doFetchOuLevels();
|
|
66
|
+
doFetchOuGroups();
|
|
67
|
+
}, [dataEngine]);
|
|
68
|
+
|
|
69
|
+
const onLevelChange = ids => {
|
|
70
|
+
const items = ids.map(id => ({
|
|
71
|
+
id: ouIdHelper.addLevelPrefix(id),
|
|
72
|
+
name: ouLevels.find(level => level.id === id).displayName
|
|
73
|
+
}));
|
|
74
|
+
onSelect({
|
|
75
|
+
dimensionId: DIMENSION_ID_ORGUNIT,
|
|
76
|
+
items: [...selected.filter(ou => !ouIdHelper.hasLevelPrefix(ou.id)), ...items]
|
|
156
77
|
});
|
|
78
|
+
};
|
|
157
79
|
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
root: this.state.root,
|
|
167
|
-
roots: this.state.roots,
|
|
168
|
-
selected: selected,
|
|
169
|
-
userOrgUnits: userOrgUnits,
|
|
170
|
-
level: level,
|
|
171
|
-
group: group,
|
|
172
|
-
levelOptions: this.state.ouLevels,
|
|
173
|
-
groupOptions: this.state.ouGroups,
|
|
174
|
-
onLevelChange: this.onLevelChange,
|
|
175
|
-
onGroupChange: this.onGroupChange,
|
|
176
|
-
onDeselectAllClick: this.onDeselectAllClick,
|
|
177
|
-
handleUserOrgUnitClick: this.handleUserOrgUnitClick,
|
|
178
|
-
handleOrgUnitClick: this.handleOrgUnitClick,
|
|
179
|
-
handleMultipleOrgUnitsSelect: this.handleMultipleOrgUnitsSelect,
|
|
180
|
-
checkboxColor: "secondary",
|
|
181
|
-
deselectAllTooltipFontColor: colors.grey900,
|
|
182
|
-
deselectAllTooltipBackgroundColor: colors.grey300,
|
|
183
|
-
displayNameProperty: this.props.displayNameProperty,
|
|
184
|
-
isUserDataViewFallback: true
|
|
185
|
-
}), !this.state.root && /*#__PURE__*/React.createElement("div", {
|
|
186
|
-
className: "jsx-".concat(styles.__hash) + " " + "loader"
|
|
187
|
-
}, /*#__PURE__*/React.createElement(CircularLoader, null)), /*#__PURE__*/React.createElement(_JSXStyle, {
|
|
188
|
-
id: styles.__hash
|
|
189
|
-
}, styles));
|
|
80
|
+
const onGroupChange = ids => {
|
|
81
|
+
const items = ids.map(id => ({
|
|
82
|
+
id: ouIdHelper.addGroupPrefix(id),
|
|
83
|
+
name: ouGroups.find(group => group.id === id).displayName
|
|
84
|
+
}));
|
|
85
|
+
onSelect({
|
|
86
|
+
dimensionId: DIMENSION_ID_ORGUNIT,
|
|
87
|
+
items: [...selected.filter(ou => !ouIdHelper.hasGroupPrefix(ou.id)), ...items]
|
|
190
88
|
});
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
}
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
}
|
|
209
|
-
|
|
210
|
-
|
|
89
|
+
};
|
|
90
|
+
|
|
91
|
+
return /*#__PURE__*/React.createElement("div", {
|
|
92
|
+
className: `jsx-${styles.__hash}` + " " + "container"
|
|
93
|
+
}, /*#__PURE__*/React.createElement("div", {
|
|
94
|
+
className: `jsx-${styles.__hash}` + " " + "userOrgUnitsWrapper"
|
|
95
|
+
}, /*#__PURE__*/React.createElement(Checkbox, {
|
|
96
|
+
label: i18n.t('User organisation unit'),
|
|
97
|
+
checked: selected.some(item => item.id === USER_ORG_UNIT),
|
|
98
|
+
onChange: ({
|
|
99
|
+
checked
|
|
100
|
+
}) => onSelectItems({
|
|
101
|
+
id: USER_ORG_UNIT,
|
|
102
|
+
checked,
|
|
103
|
+
displayName: i18n.t('User organisation unit')
|
|
104
|
+
}),
|
|
105
|
+
dense: true
|
|
106
|
+
}), /*#__PURE__*/React.createElement(Checkbox, {
|
|
107
|
+
label: i18n.t('User sub-units'),
|
|
108
|
+
checked: selected.some(item => item.id === USER_ORG_UNIT_CHILDREN),
|
|
109
|
+
onChange: ({
|
|
110
|
+
checked
|
|
111
|
+
}) => onSelectItems({
|
|
112
|
+
id: USER_ORG_UNIT_CHILDREN,
|
|
113
|
+
checked,
|
|
114
|
+
displayName: i18n.t('User sub-units')
|
|
115
|
+
}),
|
|
116
|
+
dense: true
|
|
117
|
+
}), /*#__PURE__*/React.createElement(Checkbox, {
|
|
118
|
+
label: i18n.t('User sub-x2-units'),
|
|
119
|
+
checked: selected.some(item => item.id === USER_ORG_UNIT_GRANDCHILDREN),
|
|
120
|
+
onChange: ({
|
|
121
|
+
checked
|
|
122
|
+
}) => onSelectItems({
|
|
123
|
+
id: USER_ORG_UNIT_GRANDCHILDREN,
|
|
124
|
+
checked,
|
|
125
|
+
displayName: i18n.t('User sub-x2-units')
|
|
126
|
+
}),
|
|
127
|
+
dense: true
|
|
128
|
+
})), /*#__PURE__*/React.createElement("div", {
|
|
129
|
+
className: `jsx-${styles.__hash}` + " " + (cx('orgUnitTreeWrapper', {
|
|
130
|
+
disabled: selected.some(item => DYNAMIC_ORG_UNITS.includes(item.id))
|
|
131
|
+
}) || "")
|
|
132
|
+
}, /*#__PURE__*/React.createElement(OrganisationUnitTree, {
|
|
133
|
+
roots: root,
|
|
134
|
+
initiallyExpanded: [root, ...selected.filter(item => !DYNAMIC_ORG_UNITS.includes(item.id) && !ouIdHelper.hasLevelPrefix(item.id) && !ouIdHelper.hasGroupPrefix(item.id)).map(item => item.path)],
|
|
135
|
+
selected: selected.filter(item => !DYNAMIC_ORG_UNITS.includes(item.id) && !ouIdHelper.hasLevelPrefix(item.id) && !ouIdHelper.hasGroupPrefix(item.id)).map(item => item.path),
|
|
136
|
+
onChange: onSelectItems,
|
|
137
|
+
dataTest: 'org-unit-tree'
|
|
138
|
+
})), /*#__PURE__*/React.createElement("div", {
|
|
139
|
+
className: `jsx-${styles.__hash}` + " " + (cx('selectsWrapper', {
|
|
140
|
+
disabled: selected.some(item => DYNAMIC_ORG_UNITS.includes(item.id))
|
|
141
|
+
}) || "")
|
|
142
|
+
}, /*#__PURE__*/React.createElement(MultiSelect, {
|
|
143
|
+
selected: ouLevels.length ? selected.filter(item => ouIdHelper.hasLevelPrefix(item.id)).map(item => ouIdHelper.removePrefix(item.id)) : [],
|
|
144
|
+
onChange: ({
|
|
145
|
+
selected
|
|
146
|
+
}) => onLevelChange(selected),
|
|
147
|
+
placeholder: i18n.t('Select a level'),
|
|
148
|
+
loading: !ouLevels.length,
|
|
149
|
+
dense: true,
|
|
150
|
+
dataTest: 'org-unit-level-select'
|
|
151
|
+
}, ouLevels.map(level => /*#__PURE__*/React.createElement(MultiSelectOption, {
|
|
152
|
+
key: level.id,
|
|
153
|
+
value: level.id,
|
|
154
|
+
label: level.displayName,
|
|
155
|
+
dataTest: `org-unit-level-select-option-${level.id}`
|
|
156
|
+
}))), /*#__PURE__*/React.createElement(MultiSelect, {
|
|
157
|
+
selected: ouGroups.length ? selected.filter(item => ouIdHelper.hasGroupPrefix(item.id)).map(item => ouIdHelper.removePrefix(item.id)) : [],
|
|
158
|
+
onChange: ({
|
|
159
|
+
selected
|
|
160
|
+
}) => onGroupChange(selected),
|
|
161
|
+
placeholder: i18n.t('Select a group'),
|
|
162
|
+
loading: !ouGroups.length,
|
|
163
|
+
dense: true,
|
|
164
|
+
dataTest: 'org-unit-group-select'
|
|
165
|
+
}, ouGroups.map(group => /*#__PURE__*/React.createElement(MultiSelectOption, {
|
|
166
|
+
key: group.id,
|
|
167
|
+
value: group.id,
|
|
168
|
+
label: group.displayName,
|
|
169
|
+
dataTest: `org-unit-group-select-option-${group.id}`
|
|
170
|
+
})))), /*#__PURE__*/React.createElement(_JSXStyle, {
|
|
171
|
+
id: styles.__hash
|
|
172
|
+
}, styles));
|
|
173
|
+
};
|
|
211
174
|
|
|
212
175
|
OrgUnitDimension.propTypes = {
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
176
|
+
root: PropTypes.string,
|
|
177
|
+
selected: PropTypes.arrayOf(PropTypes.shape({
|
|
178
|
+
id: PropTypes.string.isRequired,
|
|
179
|
+
name: PropTypes.string.isRequired,
|
|
180
|
+
path: PropTypes.string
|
|
181
|
+
})),
|
|
218
182
|
onSelect: PropTypes.func
|
|
219
183
|
};
|
|
220
184
|
export default OrgUnitDimension;
|