@dhis2/analytics 20.6.2 → 21.0.0-alpha.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/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 +2 -2
- package/build/cjs/components/FileMenu/FileMenu.js +5 -5
- package/build/cjs/components/FileMenu/FileMenu.styles.js +1 -1
- package/build/cjs/components/FileMenu/GetLinkDialog.js +1 -1
- package/build/cjs/components/FileMenu/RenameDialog.js +2 -2
- package/build/cjs/components/FileMenu/SaveAsDialog.js +2 -2
- 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 +163 -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 +4 -4
- 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 +5 -5
- 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/es/translations.json +6 -6
- 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/FileMenu.js +3 -3
- package/build/es/components/FileMenu/FileMenu.styles.js +1 -1
- package/build/es/components/FileMenu/GetLinkDialog.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 +163 -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 +2 -2
- 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 +5 -5
- 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/es/translations.json +6 -6
- 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 +1 -1
- package/CHANGELOG.md +0 -2735
- 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
|
@@ -1,220 +1,179 @@
|
|
|
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
|
+
})), /*#__PURE__*/React.createElement("div", {
|
|
138
|
+
className: `jsx-${styles.__hash}` + " " + (cx('selectsWrapper', {
|
|
139
|
+
disabled: selected.some(item => DYNAMIC_ORG_UNITS.includes(item.id))
|
|
140
|
+
}) || "")
|
|
141
|
+
}, /*#__PURE__*/React.createElement(MultiSelect, {
|
|
142
|
+
selected: ouLevels.length ? selected.filter(item => ouIdHelper.hasLevelPrefix(item.id)).map(item => ouIdHelper.removePrefix(item.id)) : [],
|
|
143
|
+
onChange: ({
|
|
144
|
+
selected
|
|
145
|
+
}) => onLevelChange(selected),
|
|
146
|
+
placeholder: i18n.t('Select a level'),
|
|
147
|
+
loading: !ouLevels.length,
|
|
148
|
+
dense: true
|
|
149
|
+
}, ouLevels.map(level => /*#__PURE__*/React.createElement(MultiSelectOption, {
|
|
150
|
+
key: level.id,
|
|
151
|
+
value: level.id,
|
|
152
|
+
label: level.displayName
|
|
153
|
+
}))), /*#__PURE__*/React.createElement(MultiSelect, {
|
|
154
|
+
selected: ouGroups.length ? selected.filter(item => ouIdHelper.hasGroupPrefix(item.id)).map(item => ouIdHelper.removePrefix(item.id)) : [],
|
|
155
|
+
onChange: ({
|
|
156
|
+
selected
|
|
157
|
+
}) => onGroupChange(selected),
|
|
158
|
+
placeholder: i18n.t('Select a group'),
|
|
159
|
+
loading: !ouGroups.length,
|
|
160
|
+
dense: true
|
|
161
|
+
}, ouGroups.map(group => /*#__PURE__*/React.createElement(MultiSelectOption, {
|
|
162
|
+
key: group.id,
|
|
163
|
+
value: group.id,
|
|
164
|
+
label: group.displayName
|
|
165
|
+
})))), /*#__PURE__*/React.createElement(_JSXStyle, {
|
|
166
|
+
id: styles.__hash
|
|
167
|
+
}, styles));
|
|
168
|
+
};
|
|
211
169
|
|
|
212
170
|
OrgUnitDimension.propTypes = {
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
171
|
+
root: PropTypes.string,
|
|
172
|
+
selected: PropTypes.arrayOf(PropTypes.shape({
|
|
173
|
+
id: PropTypes.string.isRequired,
|
|
174
|
+
name: PropTypes.string.isRequired,
|
|
175
|
+
path: PropTypes.string
|
|
176
|
+
})),
|
|
218
177
|
onSelect: PropTypes.func
|
|
219
178
|
};
|
|
220
179
|
export default OrgUnitDimension;
|
|
@@ -0,0 +1,220 @@
|
|
|
1
|
+
import _JSXStyle from "styled-jsx/style";
|
|
2
|
+
|
|
3
|
+
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
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';
|
|
8
|
+
import PropTypes from 'prop-types';
|
|
9
|
+
import React, { Component, Fragment } from 'react';
|
|
10
|
+
import { apiFetchOrganisationUnitGroups, apiFetchOrganisationUnitLevels, apiFetchOrganisationUnits } from '../../api/organisationUnits';
|
|
11
|
+
import { ouIdHelper } from '../../modules/ouIdHelper';
|
|
12
|
+
import { DIMENSION_ID_ORGUNIT } from '../../modules/predefinedDimensions';
|
|
13
|
+
import styles from './styles/OrgUnitDimension.style';
|
|
14
|
+
export const defaultState = {
|
|
15
|
+
root: undefined,
|
|
16
|
+
roots: undefined,
|
|
17
|
+
// use "selected" property for cloning org units while user org unit(s) is (are) selected
|
|
18
|
+
selected: [],
|
|
19
|
+
ouLevels: [],
|
|
20
|
+
ouGroups: [],
|
|
21
|
+
showOrgUnitsTree: true
|
|
22
|
+
};
|
|
23
|
+
|
|
24
|
+
class OrgUnitDimension extends Component {
|
|
25
|
+
constructor(props) {
|
|
26
|
+
super(props);
|
|
27
|
+
|
|
28
|
+
_defineProperty(this, "showOrgUnitsTree", () => {
|
|
29
|
+
this.setState({
|
|
30
|
+
showOrgUnitsTree: true
|
|
31
|
+
});
|
|
32
|
+
});
|
|
33
|
+
|
|
34
|
+
_defineProperty(this, "hideOrgUnitsTree", () => {
|
|
35
|
+
this.setState({
|
|
36
|
+
showOrgUnitsTree: false
|
|
37
|
+
});
|
|
38
|
+
});
|
|
39
|
+
|
|
40
|
+
_defineProperty(this, "getUserOrgUnitsFromIds", ids => {
|
|
41
|
+
return userOrgUnits.filter(ou => ids.includes(ou.id));
|
|
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
|
+
})]
|
|
67
|
+
});
|
|
68
|
+
});
|
|
69
|
+
|
|
70
|
+
_defineProperty(this, "onDeselectAllClick", () => this.props.onDeselect({
|
|
71
|
+
dimensionId: DIMENSION_ID_ORGUNIT,
|
|
72
|
+
itemIdsToRemove: this.props.ouItems.map(ou => ou.id)
|
|
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
|
+
}
|
|
112
|
+
});
|
|
113
|
+
|
|
114
|
+
_defineProperty(this, "handleUserOrgUnitClick", (event, checked) => {
|
|
115
|
+
if (checked) {
|
|
116
|
+
if (!this.state.selected.length) {
|
|
117
|
+
this.setState({
|
|
118
|
+
selected: this.props.ouItems.slice()
|
|
119
|
+
});
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
this.props.onSelect({
|
|
123
|
+
dimensionId: DIMENSION_ID_ORGUNIT,
|
|
124
|
+
items: [...this.props.ouItems.filter(ou => this.userOrgUnitIds.includes(ou.id)), userOrgUnits.find(ou => ou.id === event.target.name)]
|
|
125
|
+
});
|
|
126
|
+
} else {
|
|
127
|
+
if (this.props.ouItems.length === 1 && this.state.selected.length > 0) {
|
|
128
|
+
this.props.onSelect({
|
|
129
|
+
dimensionId: DIMENSION_ID_ORGUNIT,
|
|
130
|
+
items: this.state.selected
|
|
131
|
+
});
|
|
132
|
+
} else {
|
|
133
|
+
this.props.onDeselect({
|
|
134
|
+
dimensionId: DIMENSION_ID_ORGUNIT,
|
|
135
|
+
itemIdsToRemove: [event.target.name]
|
|
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
|
+
});
|
|
156
|
+
});
|
|
157
|
+
|
|
158
|
+
_defineProperty(this, "render", () => {
|
|
159
|
+
const ids = this.props.ouItems.map(ou => ou.id);
|
|
160
|
+
const selected = this.props.ouItems.filter(ou => !this.userOrgUnitIds.includes(ou.id) && !ouIdHelper.hasLevelPrefix(ou.id) && !ouIdHelper.hasGroupPrefix(ou.id));
|
|
161
|
+
const userOrgUnits = this.getUserOrgUnitsFromIds(ids);
|
|
162
|
+
const level = ids.filter(ouIdHelper.hasLevelPrefix).map(ouIdHelper.removePrefix);
|
|
163
|
+
const group = ids.filter(ouIdHelper.hasGroupPrefix).map(ouIdHelper.removePrefix);
|
|
164
|
+
return /*#__PURE__*/React.createElement(Fragment, null, this.state.root && this.state.showOrgUnitsTree && /*#__PURE__*/React.createElement(OrgUnitSelector, {
|
|
165
|
+
d2: this.props.d2,
|
|
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-${styles.__hash}` + " " + "loader"
|
|
187
|
+
}, /*#__PURE__*/React.createElement(CircularLoader, null)), /*#__PURE__*/React.createElement(_JSXStyle, {
|
|
188
|
+
id: styles.__hash
|
|
189
|
+
}, styles));
|
|
190
|
+
});
|
|
191
|
+
|
|
192
|
+
this.state = defaultState;
|
|
193
|
+
this.userOrgUnitIds = userOrgUnits.map(ou => ou.id);
|
|
194
|
+
this.loadOrgUnitTree(props.d2, props.displayNameProperty);
|
|
195
|
+
this.loadOrgUnitGroups(props.d2, props.displayNameProperty);
|
|
196
|
+
this.loadOrgUnitLevels(props.d2);
|
|
197
|
+
}
|
|
198
|
+
|
|
199
|
+
componentDidUpdate(prevProps) {
|
|
200
|
+
const previousId = prevProps.current ? prevProps.current.id : null;
|
|
201
|
+
const currentId = this.props.current ? this.props.current.id : null; // remount org units selector component to ensure
|
|
202
|
+
// only selected org units are expanded
|
|
203
|
+
|
|
204
|
+
if (previousId !== currentId) {
|
|
205
|
+
this.hideOrgUnitsTree();
|
|
206
|
+
setTimeout(this.showOrgUnitsTree, 0);
|
|
207
|
+
}
|
|
208
|
+
}
|
|
209
|
+
|
|
210
|
+
}
|
|
211
|
+
|
|
212
|
+
OrgUnitDimension.propTypes = {
|
|
213
|
+
current: PropTypes.object,
|
|
214
|
+
d2: PropTypes.object,
|
|
215
|
+
displayNameProperty: PropTypes.string,
|
|
216
|
+
ouItems: PropTypes.array,
|
|
217
|
+
onDeselect: PropTypes.func,
|
|
218
|
+
onSelect: PropTypes.func
|
|
219
|
+
};
|
|
220
|
+
export default OrgUnitDimension;
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
-
|
|
2
|
-
_defaultExport
|
|
1
|
+
import { colors, spacers } from '@dhis2/ui';
|
|
2
|
+
const _defaultExport = [".container.jsx-1731397832{height:100%;display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-flex-direction:column;-ms-flex-direction:column;flex-direction:column;}", ".orgUnitTreeWrapper.jsx-1731397832{height:418px;-webkit-box-flex:1;-webkit-flex-grow:1;-ms-flex-positive:1;flex-grow:1;overflow:auto;}", ".orgUnitTreeWrapper.jsx-1731397832>*{-webkit-box-flex:1;-webkit-flex-grow:1;-ms-flex-positive:1;flex-grow:1;}", ".disabled.jsx-1731397832{cursor:not-allowed;opacity:0.5;}", ".disabled.jsx-1731397832>*{pointer-events:none;}", `.userOrgUnitsWrapper.jsx-1731397832{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;background:${colors.grey200};padding:${spacers.dp8} ${spacers.dp8} ${spacers.dp8} ${spacers.dp24};margin-bottom:${spacers.dp12};}`, `.userOrgUnitsWrapper.jsx-1731397832>*{margin-right:${spacers.dp48};}`, `.selectsWrapper.jsx-1731397832{display:-webkit-box;display:-webkit-flex;display:-ms-flexbox;display:flex;-webkit-align-items:flex-start;-webkit-box-align:flex-start;-ms-flex-align:flex-start;align-items:flex-start;gap:${spacers.dp12};margin-top:${spacers.dp12};}`, ".selectsWrapper.jsx-1731397832>*{width:50%;}"];
|
|
3
|
+
_defaultExport.__hash = "1731397832";
|
|
3
4
|
export default _defaultExport;
|
|
@@ -18,7 +18,7 @@ const FixedPeriodFilter = ({
|
|
|
18
18
|
}) => {
|
|
19
19
|
const onlyAllowedTypeIsSelected = Array.isArray(allowedPeriodTypes) && allowedPeriodTypes.length === 1 && allowedPeriodTypes[0] === currentPeriodType;
|
|
20
20
|
return /*#__PURE__*/React.createElement(React.Fragment, null, /*#__PURE__*/React.createElement("div", {
|
|
21
|
-
className:
|
|
21
|
+
className: `jsx-${styles.__hash}` + " " + "leftSection"
|
|
22
22
|
}, /*#__PURE__*/React.createElement(SingleSelectField, {
|
|
23
23
|
label: i18n.t('Period type'),
|
|
24
24
|
onChange: ({
|
|
@@ -28,14 +28,14 @@ const FixedPeriodFilter = ({
|
|
|
28
28
|
selected: currentPeriodType,
|
|
29
29
|
disabled: onlyAllowedTypeIsSelected,
|
|
30
30
|
className: "filterElement",
|
|
31
|
-
dataTest:
|
|
31
|
+
dataTest: `${dataTest}-period-type`
|
|
32
32
|
}, (allowedPeriodTypes ? getFixedPeriodsOptions().filter(option => allowedPeriodTypes.some(type => type === option.id)) : filterPeriodTypesById(getFixedPeriodsOptions(), excludedPeriodTypes)).map(option => /*#__PURE__*/React.createElement(SingleSelectOption, {
|
|
33
33
|
key: option.id,
|
|
34
34
|
value: option.id,
|
|
35
35
|
label: option.name,
|
|
36
|
-
dataTest:
|
|
36
|
+
dataTest: `${dataTest}-period-type-option-${option.id}`
|
|
37
37
|
})))), /*#__PURE__*/React.createElement("div", {
|
|
38
|
-
className:
|
|
38
|
+
className: `jsx-${styles.__hash}` + " " + "rightSection"
|
|
39
39
|
}, /*#__PURE__*/React.createElement(InputField, {
|
|
40
40
|
label: i18n.t('Year'),
|
|
41
41
|
className: "filterElement",
|
|
@@ -46,7 +46,7 @@ const FixedPeriodFilter = ({
|
|
|
46
46
|
value
|
|
47
47
|
}) => onSelectYear(value),
|
|
48
48
|
dense: true,
|
|
49
|
-
dataTest:
|
|
49
|
+
dataTest: `${dataTest}-year`
|
|
50
50
|
})), /*#__PURE__*/React.createElement(_JSXStyle, {
|
|
51
51
|
id: styles.__hash
|
|
52
52
|
}, styles));
|
|
@@ -73,9 +73,9 @@ class FixedPeriodSelect extends Component {
|
|
|
73
73
|
render() {
|
|
74
74
|
return /*#__PURE__*/React.createElement("div", {
|
|
75
75
|
"data-test": this.props.dataTest,
|
|
76
|
-
className:
|
|
76
|
+
className: `jsx-${styles.__hash}` + " " + (this.props.className || "")
|
|
77
77
|
}, /*#__PURE__*/React.createElement("div", {
|
|
78
|
-
className:
|
|
78
|
+
className: `jsx-${styles.__hash}` + " " + "row"
|
|
79
79
|
}, /*#__PURE__*/React.createElement(FixedPeriodFilter, {
|
|
80
80
|
allowedPeriodTypes: this.props.allowedPeriodTypes,
|
|
81
81
|
currentPeriodType: this.state.periodType,
|