@i-novus/n2o-components 1.0.0
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/index.js +0 -0
- package/lib/display/Alerts/Alert.d.ts +2 -0
- package/lib/display/Alerts/Alert.js +121 -0
- package/lib/display/Alerts/AlertSection.d.ts +18 -0
- package/lib/display/Alerts/AlertSection.js +64 -0
- package/lib/display/Alerts/AlertWrapper.d.ts +6 -0
- package/lib/display/Alerts/AlertWrapper.js +39 -0
- package/lib/display/Alerts/DefaultAlert.d.ts +6 -0
- package/lib/display/Alerts/DefaultAlert.js +125 -0
- package/lib/display/Alerts/LoaderAlert.d.ts +5 -0
- package/lib/display/Alerts/LoaderAlert.js +36 -0
- package/lib/display/Alerts/types.d.ts +49 -0
- package/lib/display/Alerts/types.js +24 -0
- package/lib/display/Alerts/utils.d.ts +15 -0
- package/lib/display/Alerts/utils.js +102 -0
- package/lib/display/Badge/Badge.d.ts +16 -0
- package/lib/display/Badge/Badge.js +77 -0
- package/lib/display/Badge/enums.d.ts +9 -0
- package/lib/display/Badge/enums.js +23 -0
- package/lib/display/Badge/utils.d.ts +9 -0
- package/lib/display/Badge/utils.js +49 -0
- package/lib/display/Block.d.ts +369 -0
- package/lib/display/Block.js +38 -0
- package/lib/display/CodeViewer/CodeViewer.d.ts +13 -0
- package/lib/display/CodeViewer/CodeViewer.js +96 -0
- package/lib/display/Drawer/Drawer.d.ts +25 -0
- package/lib/display/Drawer/Drawer.js +99 -0
- package/lib/display/DropdownCustomItem.d.ts +7 -0
- package/lib/display/DropdownCustomItem.js +23 -0
- package/lib/display/Filter/Buttons.d.ts +11 -0
- package/lib/display/Filter/Buttons.js +42 -0
- package/lib/display/Filter/Filter.d.ts +8 -0
- package/lib/display/Filter/Filter.js +38 -0
- package/lib/display/HelpPopover.d.ts +16 -0
- package/lib/display/HelpPopover.js +104 -0
- package/lib/display/Html.d.ts +8 -0
- package/lib/display/Html.js +29 -0
- package/lib/display/Icon/Icon.d.ts +11 -0
- package/lib/display/Icon/Icon.js +42 -0
- package/lib/display/Image/Image.d.ts +30 -0
- package/lib/display/Image/Image.js +93 -0
- package/lib/display/Image/ImageInfo.d.ts +7 -0
- package/lib/display/Image/ImageInfo.js +23 -0
- package/lib/display/InputIcon.d.ts +13 -0
- package/lib/display/InputIcon.js +33 -0
- package/lib/display/NavItemImage/NavItemImage.d.ts +9 -0
- package/lib/display/NavItemImage/NavItemImage.js +35 -0
- package/lib/display/OutputList.d.ts +12 -0
- package/lib/display/OutputList.js +46 -0
- package/lib/display/OutputListItem.d.ts +10 -0
- package/lib/display/OutputListItem.js +58 -0
- package/lib/display/OutputText.d.ts +15 -0
- package/lib/display/OutputText.js +170 -0
- package/lib/display/Pagination/Pagination.d.ts +2 -0
- package/lib/display/Pagination/Pagination.js +273 -0
- package/lib/display/Pagination/PaginationButton.d.ts +13 -0
- package/lib/display/Pagination/PaginationButton.js +53 -0
- package/lib/display/Pagination/types.d.ts +62 -0
- package/lib/display/Pagination/types.js +36 -0
- package/lib/display/PopoverConfirm/PopoverConfirm.d.ts +30 -0
- package/lib/display/PopoverConfirm/PopoverConfirm.js +87 -0
- package/lib/display/ProgressControl/ProgressControl.d.ts +17 -0
- package/lib/display/ProgressControl/ProgressControl.js +68 -0
- package/lib/display/Slider.d.ts +23 -0
- package/lib/display/Slider.js +107 -0
- package/lib/display/Status.d.ts +9 -0
- package/lib/display/Status.js +40 -0
- package/lib/display/StatusText/StatusText.d.ts +10 -0
- package/lib/display/StatusText/StatusText.js +35 -0
- package/lib/display/StatusText/types.d.ts +18 -0
- package/lib/display/StatusText/types.js +19 -0
- package/lib/display/StatusText/utils.d.ts +3 -0
- package/lib/display/StatusText/utils.js +29 -0
- package/lib/display/Text.d.ts +12 -0
- package/lib/display/Text.js +38 -0
- package/lib/display/Typography/Base.d.ts +32 -0
- package/lib/display/Typography/Base.js +259 -0
- package/lib/display/Typography/ContentEditable.d.ts +15 -0
- package/lib/display/Typography/ContentEditable.js +86 -0
- package/lib/display/Typography/Paragraph.d.ts +4 -0
- package/lib/display/Typography/Paragraph.js +23 -0
- package/lib/display/Typography/Text.d.ts +9 -0
- package/lib/display/Typography/Text.js +37 -0
- package/lib/display/Typography/Title.d.ts +7 -0
- package/lib/display/Typography/Title.js +28 -0
- package/lib/display/Typography/utils.d.ts +13 -0
- package/lib/display/Typography/utils.js +75 -0
- package/lib/helpers/HelpPopover.d.ts +9 -0
- package/lib/helpers/HelpPopover.js +46 -0
- package/lib/helpers/withRightPlaceholder.d.ts +9 -0
- package/lib/helpers/withRightPlaceholder.js +35 -0
- package/lib/inputs/Checkbox/Checkbox.d.ts +29 -0
- package/lib/inputs/Checkbox/Checkbox.js +117 -0
- package/lib/inputs/Checkbox/CheckboxControl.d.ts +7 -0
- package/lib/inputs/Checkbox/CheckboxControl.js +33 -0
- package/lib/inputs/CheckboxGroup/CheckboxGroup.d.ts +11 -0
- package/lib/inputs/CheckboxGroup/CheckboxGroup.js +84 -0
- package/lib/inputs/CodeEditor/CodeEditor.d.ts +21 -0
- package/lib/inputs/CodeEditor/CodeEditor.js +85 -0
- package/lib/inputs/DatePicker/Calendar.d.ts +65 -0
- package/lib/inputs/DatePicker/Calendar.js +556 -0
- package/lib/inputs/DatePicker/CalendarHeader.d.ts +26 -0
- package/lib/inputs/DatePicker/CalendarHeader.js +213 -0
- package/lib/inputs/DatePicker/Clock.d.ts +10 -0
- package/lib/inputs/DatePicker/Clock.js +45 -0
- package/lib/inputs/DatePicker/DateInput.d.ts +44 -0
- package/lib/inputs/DatePicker/DateInput.js +262 -0
- package/lib/inputs/DatePicker/DateInputGroup.d.ts +20 -0
- package/lib/inputs/DatePicker/DateInputGroup.js +77 -0
- package/lib/inputs/DatePicker/DateInterval.d.ts +24 -0
- package/lib/inputs/DatePicker/DateInterval.js +92 -0
- package/lib/inputs/DatePicker/DatePicker.d.ts +22 -0
- package/lib/inputs/DatePicker/DatePicker.js +36 -0
- package/lib/inputs/DatePicker/DateTimeControl.d.ts +98 -0
- package/lib/inputs/DatePicker/DateTimeControl.js +452 -0
- package/lib/inputs/DatePicker/Day.d.ts +14 -0
- package/lib/inputs/DatePicker/Day.js +50 -0
- package/lib/inputs/DatePicker/PopUp.d.ts +19 -0
- package/lib/inputs/DatePicker/PopUp.js +71 -0
- package/lib/inputs/DatePicker/types.d.ts +31 -0
- package/lib/inputs/DatePicker/types.js +25 -0
- package/lib/inputs/DatePicker/utils.d.ts +39 -0
- package/lib/inputs/DatePicker/utils.js +304 -0
- package/lib/inputs/Input.d.ts +51 -0
- package/lib/inputs/Input.js +200 -0
- package/lib/inputs/InputMask/InputMask.d.ts +23 -0
- package/lib/inputs/InputMask/InputMask.js +310 -0
- package/lib/inputs/InputMoney/InputMoney.d.ts +101 -0
- package/lib/inputs/InputMoney/InputMoney.js +258 -0
- package/lib/inputs/InputNumber/InputNumber.d.ts +29 -0
- package/lib/inputs/InputNumber/InputNumber.js +316 -0
- package/lib/inputs/InputNumber/index.d.ts +1 -0
- package/lib/inputs/InputNumber/index.js +14 -0
- package/lib/inputs/InputNumber/types.d.ts +18 -0
- package/lib/inputs/InputNumber/types.js +14 -0
- package/lib/inputs/InputNumber/utils.d.ts +6 -0
- package/lib/inputs/InputNumber/utils.js +86 -0
- package/lib/inputs/InputPassword/InputPassword.d.ts +10 -0
- package/lib/inputs/InputPassword/InputPassword.js +81 -0
- package/lib/inputs/InputSelect/InputAddon.d.ts +17 -0
- package/lib/inputs/InputSelect/InputAddon.js +31 -0
- package/lib/inputs/InputSelect/InputContent.d.ts +63 -0
- package/lib/inputs/InputSelect/InputContent.js +188 -0
- package/lib/inputs/InputSelect/InputSelect.d.ts +296 -0
- package/lib/inputs/InputSelect/InputSelect.js +795 -0
- package/lib/inputs/InputSelect/InputSelectGroup.d.ts +43 -0
- package/lib/inputs/InputSelect/InputSelectGroup.js +113 -0
- package/lib/inputs/InputSelect/PopupItems.d.ts +55 -0
- package/lib/inputs/InputSelect/PopupItems.js +357 -0
- package/lib/inputs/InputSelect/PopupList.d.ts +82 -0
- package/lib/inputs/InputSelect/PopupList.js +138 -0
- package/lib/inputs/InputSelect/SelectedItems.d.ts +17 -0
- package/lib/inputs/InputSelect/SelectedItems.js +125 -0
- package/lib/inputs/InputSelect/constants.d.ts +4 -0
- package/lib/inputs/InputSelect/constants.js +15 -0
- package/lib/inputs/InputSelect/types.d.ts +16 -0
- package/lib/inputs/InputSelect/types.js +16 -0
- package/lib/inputs/InputSelect/utils.d.ts +9 -0
- package/lib/inputs/InputSelect/utils.js +142 -0
- package/lib/inputs/InputSelectTree/InputSelectTree.d.ts +114 -0
- package/lib/inputs/InputSelectTree/InputSelectTree.js +466 -0
- package/lib/inputs/InputSelectTree/TreeSelectNode.d.ts +36 -0
- package/lib/inputs/InputSelectTree/TreeSelectNode.js +63 -0
- package/lib/inputs/InputSelectTree/allProps.d.ts +123 -0
- package/lib/inputs/InputSelectTree/allProps.js +48 -0
- package/lib/inputs/InputSelectTree/until.d.ts +4 -0
- package/lib/inputs/InputSelectTree/until.js +83 -0
- package/lib/inputs/InputText.d.ts +41 -0
- package/lib/inputs/InputText.js +170 -0
- package/lib/inputs/NumberPicker/NumberPicker.d.ts +15 -0
- package/lib/inputs/NumberPicker/NumberPicker.js +129 -0
- package/lib/inputs/NumberPicker/NumberPickerButton.d.ts +8 -0
- package/lib/inputs/NumberPicker/NumberPickerButton.js +64 -0
- package/lib/inputs/NumberPicker/index.d.ts +1 -0
- package/lib/inputs/NumberPicker/index.js +14 -0
- package/lib/inputs/NumberPicker/utils.d.ts +2 -0
- package/lib/inputs/NumberPicker/utils.js +31 -0
- package/lib/inputs/RadioGroup/default/Group.d.ts +15 -0
- package/lib/inputs/RadioGroup/default/Group.js +63 -0
- package/lib/inputs/RadioGroup/default/Input.d.ts +17 -0
- package/lib/inputs/RadioGroup/default/Input.js +77 -0
- package/lib/inputs/RadioGroup/tabs/Group.d.ts +3 -0
- package/lib/inputs/RadioGroup/tabs/Group.js +24 -0
- package/lib/inputs/RadioGroup/tabs/Input.d.ts +3 -0
- package/lib/inputs/RadioGroup/tabs/Input.js +21 -0
- package/lib/inputs/Rating/Rating.d.ts +30 -0
- package/lib/inputs/Rating/Rating.js +212 -0
- package/lib/inputs/Select/Popup.d.ts +31 -0
- package/lib/inputs/Select/Popup.js +131 -0
- package/lib/inputs/Select/Select.d.ts +225 -0
- package/lib/inputs/Select/Select.js +705 -0
- package/lib/inputs/Select/SelectInput.d.ts +19 -0
- package/lib/inputs/Select/SelectInput.js +85 -0
- package/lib/inputs/Select/utils.d.ts +1 -0
- package/lib/inputs/Select/utils.js +28 -0
- package/lib/inputs/Switch/Switch.d.ts +11 -0
- package/lib/inputs/Switch/Switch.js +41 -0
- package/lib/inputs/TextArea.d.ts +12 -0
- package/lib/inputs/TextArea.js +54 -0
- package/lib/inputs/TextEditor/TextEditor.d.ts +11 -0
- package/lib/inputs/TextEditor/TextEditor.js +89 -0
- package/lib/inputs/TimePicker/TimePicker.d.ts +50 -0
- package/lib/inputs/TimePicker/TimePicker.js +398 -0
- package/lib/inputs/utils.d.ts +5 -0
- package/lib/inputs/utils.js +39 -0
- package/lib/layouts/ScrollContainer.d.ts +218 -0
- package/lib/layouts/ScrollContainer.js +128 -0
- package/lib/layouts/Spinner/CoverSpinner.d.ts +29 -0
- package/lib/layouts/Spinner/CoverSpinner.js +153 -0
- package/lib/layouts/Spinner/InlineSpinner.d.ts +5 -0
- package/lib/layouts/Spinner/InlineSpinner.js +27 -0
- package/lib/layouts/Spinner/Spinner.d.ts +31 -0
- package/lib/layouts/Spinner/Spinner.js +178 -0
- package/lib/styles/components/Calendar.scss +125 -0
- package/lib/styles/components/CalendarHeader.scss +75 -0
- package/lib/styles/components/DateInputGroup.scss +39 -0
- package/lib/styles/components/DatePicker.scss +18 -0
- package/lib/styles/components/Day.scss +29 -0
- package/lib/styles/components/OutputList.scss +14 -0
- package/lib/styles/components/OutputText.scss +50 -0
- package/lib/styles/controls/CodeEditor.scss +4 -0
- package/lib/styles/controls/InputNumber.scss +36 -0
- package/lib/styles/controls/InputPassword.scss +17 -0
- package/lib/styles/controls/InputText.scss +59 -0
- package/lib/styles/controls/NumberPicker.scss +36 -0
- package/lib/styles/controls/ProgressControl.scss +3 -0
- package/lib/styles/controls/Slider.scss +32 -0
- package/lib/styles/controls/Switch.scss +105 -0
- package/lib/styles/controls/TextEditor.scss +23 -0
- package/lib/styles/controls/TimePicker.scss +32 -0
- package/lib/styles/n2o/variables.scss +328 -0
- package/lib/styles/theme/variables.scss +81 -0
- package/lib/styles/variables.scss +10 -0
- package/lib/types.d.ts +25 -0
- package/lib/types.js +6 -0
- package/lib/utils/id.d.ts +3 -0
- package/lib/utils/id.js +46 -0
- package/lib/utils/isEmptyModel.d.ts +1 -0
- package/lib/utils/isEmptyModel.js +21 -0
- package/lib/utils/parseFormatter.js +153 -0
- package/package.json +196 -0
|
@@ -0,0 +1,114 @@
|
|
|
1
|
+
import { ReactNode } from 'react';
|
|
2
|
+
import { Filter, TOption } from '../InputSelect/types';
|
|
3
|
+
import { TreeNode } from './TreeSelectNode';
|
|
4
|
+
/**
|
|
5
|
+
* @reactProps {function} onBlur
|
|
6
|
+
* @reactProps {string} placeholder
|
|
7
|
+
* @reactProps {function} setTreeExpandedKeys
|
|
8
|
+
* @reactProps {array} treeExpandedKeys
|
|
9
|
+
* @reactProps {node} children
|
|
10
|
+
* @returns {*}
|
|
11
|
+
* @constructor
|
|
12
|
+
* @param props
|
|
13
|
+
*/
|
|
14
|
+
declare function InputSelectTree({ t, fetchData, onFocus, value, onBlur, placeholder, notFoundContent, loading, parentFieldId, valueFieldId, labelFieldId, iconFieldId, imageFieldId, badge, hasChildrenFieldId, options, onSearch, onSelect, onChange, hasCheckboxes, filter, multiSelect, children, onClose, onToggle, ajax, className, showCheckedStrategy, maxTagTextLength, disabled, }: Props): JSX.Element;
|
|
15
|
+
declare namespace InputSelectTree {
|
|
16
|
+
var defaultProps: Props;
|
|
17
|
+
}
|
|
18
|
+
declare type Props = {
|
|
19
|
+
/**
|
|
20
|
+
* Флаг динамичексой подгрузки данных. В данных обязательно указывать параметр hasChildrens
|
|
21
|
+
*/
|
|
22
|
+
ajax?: boolean;
|
|
23
|
+
/**
|
|
24
|
+
* Данные для badge
|
|
25
|
+
*/
|
|
26
|
+
badge: object;
|
|
27
|
+
children: ReactNode;
|
|
28
|
+
className?: string;
|
|
29
|
+
/**
|
|
30
|
+
* Флаг неактивности
|
|
31
|
+
*/
|
|
32
|
+
disabled: boolean;
|
|
33
|
+
/**
|
|
34
|
+
* Callback на открытие
|
|
35
|
+
*/
|
|
36
|
+
fetchData?: any;
|
|
37
|
+
/**
|
|
38
|
+
* Варианты фильтрации
|
|
39
|
+
*/
|
|
40
|
+
filter: Filter;
|
|
41
|
+
/**
|
|
42
|
+
* Флаг для показа чекбоксов в элементах дерева. Переводит InputSelectTree в мульти режим
|
|
43
|
+
*/
|
|
44
|
+
hasCheckboxes: boolean;
|
|
45
|
+
/**
|
|
46
|
+
* Значение ключа hasChildren в данных
|
|
47
|
+
*/
|
|
48
|
+
hasChildrenFieldId: string;
|
|
49
|
+
/**
|
|
50
|
+
* Значение ключа icon в данных
|
|
51
|
+
*/
|
|
52
|
+
iconFieldId: string;
|
|
53
|
+
/**
|
|
54
|
+
* Значение ключа image в данных
|
|
55
|
+
*/
|
|
56
|
+
imageFieldId: string;
|
|
57
|
+
/**
|
|
58
|
+
* Значение ключа label в данных
|
|
59
|
+
*/
|
|
60
|
+
labelFieldId: string;
|
|
61
|
+
/**
|
|
62
|
+
* Флаг анимации загрузки
|
|
63
|
+
*/
|
|
64
|
+
loading: boolean;
|
|
65
|
+
/**
|
|
66
|
+
* Количество символов выбранных элементов в chechbox режиме
|
|
67
|
+
*/
|
|
68
|
+
maxTagTextLength: number;
|
|
69
|
+
/**
|
|
70
|
+
* Мульти выбор значений
|
|
71
|
+
*/
|
|
72
|
+
multiSelect: boolean;
|
|
73
|
+
notFoundContent?: any;
|
|
74
|
+
onBlur(arg?: Props['value']): void;
|
|
75
|
+
/**
|
|
76
|
+
* Calback изменения
|
|
77
|
+
*/
|
|
78
|
+
onChange(arg: Props['value']): void;
|
|
79
|
+
/**
|
|
80
|
+
* Callback на закрытие
|
|
81
|
+
*/
|
|
82
|
+
onClose(): void;
|
|
83
|
+
onFocus(): void;
|
|
84
|
+
/**
|
|
85
|
+
* Callback на поиск
|
|
86
|
+
*/
|
|
87
|
+
onSearch(arg: Props['value']): void;
|
|
88
|
+
onSelect(arg: Props['value']): void;
|
|
89
|
+
onToggle(arg: boolean): void;
|
|
90
|
+
/**
|
|
91
|
+
* Данные для построения дерева
|
|
92
|
+
*/
|
|
93
|
+
options: TOption[];
|
|
94
|
+
/**
|
|
95
|
+
* Значение ключа parent в данных
|
|
96
|
+
*/
|
|
97
|
+
parentFieldId: string;
|
|
98
|
+
/**
|
|
99
|
+
* Placeholder контрола
|
|
100
|
+
*/
|
|
101
|
+
placeholder: string;
|
|
102
|
+
showCheckedStrategy: string;
|
|
103
|
+
t(arg: string): void;
|
|
104
|
+
/**
|
|
105
|
+
* Значение
|
|
106
|
+
*/
|
|
107
|
+
value?: any;
|
|
108
|
+
/**
|
|
109
|
+
* Значение ключа value в данных
|
|
110
|
+
*/
|
|
111
|
+
valueFieldId: string;
|
|
112
|
+
};
|
|
113
|
+
export { TreeNode, InputSelectTree };
|
|
114
|
+
export declare const InputSelectTreeComponent: any;
|
|
@@ -0,0 +1,466 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
var _typeof = require("@babel/runtime/helpers/typeof");
|
|
6
|
+
|
|
7
|
+
Object.defineProperty(exports, "__esModule", {
|
|
8
|
+
value: true
|
|
9
|
+
});
|
|
10
|
+
exports.InputSelectTree = InputSelectTree;
|
|
11
|
+
Object.defineProperty(exports, "TreeNode", {
|
|
12
|
+
enumerable: true,
|
|
13
|
+
get: function get() {
|
|
14
|
+
return _TreeSelectNode.TreeNode;
|
|
15
|
+
}
|
|
16
|
+
});
|
|
17
|
+
exports.InputSelectTreeComponent = void 0;
|
|
18
|
+
|
|
19
|
+
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
|
|
20
|
+
|
|
21
|
+
var _asyncToGenerator2 = _interopRequireDefault(require("@babel/runtime/helpers/asyncToGenerator"));
|
|
22
|
+
|
|
23
|
+
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
24
|
+
|
|
25
|
+
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
|
|
26
|
+
|
|
27
|
+
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
28
|
+
|
|
29
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
30
|
+
|
|
31
|
+
var _rcTreeSelect = _interopRequireDefault(require("rc-tree-select"));
|
|
32
|
+
|
|
33
|
+
var _difference = _interopRequireDefault(require("lodash/difference"));
|
|
34
|
+
|
|
35
|
+
var _filter = _interopRequireDefault(require("lodash/filter"));
|
|
36
|
+
|
|
37
|
+
var _find = _interopRequireDefault(require("lodash/find"));
|
|
38
|
+
|
|
39
|
+
var _isArray = _interopRequireDefault(require("lodash/isArray"));
|
|
40
|
+
|
|
41
|
+
var _isEmpty = _interopRequireDefault(require("lodash/isEmpty"));
|
|
42
|
+
|
|
43
|
+
var _keys = _interopRequireDefault(require("lodash/keys"));
|
|
44
|
+
|
|
45
|
+
var _map = _interopRequireDefault(require("lodash/map"));
|
|
46
|
+
|
|
47
|
+
var _some = _interopRequireDefault(require("lodash/some"));
|
|
48
|
+
|
|
49
|
+
var _classnames = _interopRequireDefault(require("classnames"));
|
|
50
|
+
|
|
51
|
+
var _reactI18next = require("react-i18next");
|
|
52
|
+
|
|
53
|
+
var _reactOnclickoutside = _interopRequireDefault(require("react-onclickoutside"));
|
|
54
|
+
|
|
55
|
+
var _Icon = require("../../display/Icon/Icon");
|
|
56
|
+
|
|
57
|
+
var _InlineSpinner = require("../../layouts/Spinner/InlineSpinner");
|
|
58
|
+
|
|
59
|
+
var _Checkbox = require("../Checkbox/Checkbox");
|
|
60
|
+
|
|
61
|
+
var _TreeSelectNode = require("./TreeSelectNode");
|
|
62
|
+
|
|
63
|
+
var _until = require("./until");
|
|
64
|
+
|
|
65
|
+
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function _getRequireWildcardCache(nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
|
|
66
|
+
|
|
67
|
+
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { "default": obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj["default"] = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
|
|
68
|
+
|
|
69
|
+
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
|
|
70
|
+
|
|
71
|
+
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { (0, _defineProperty2["default"])(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
|
|
72
|
+
|
|
73
|
+
var renderSwitcherIcon = function renderSwitcherIcon(_ref) {
|
|
74
|
+
var isLeaf = _ref.isLeaf;
|
|
75
|
+
return isLeaf ? null : /*#__PURE__*/_react["default"].createElement(_Icon.Icon, {
|
|
76
|
+
name: "fa fa-chevron-right"
|
|
77
|
+
});
|
|
78
|
+
}; // eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
79
|
+
|
|
80
|
+
|
|
81
|
+
var getPopupContainer = function getPopupContainer(container) {
|
|
82
|
+
return container;
|
|
83
|
+
};
|
|
84
|
+
/**
|
|
85
|
+
* Взять данные по ids.
|
|
86
|
+
* ['id', 'id'] => [{ id: 'id', ... },{ id: 'id', ... }]
|
|
87
|
+
* @param options
|
|
88
|
+
* @param ids
|
|
89
|
+
* @param valueFieldId
|
|
90
|
+
*/
|
|
91
|
+
|
|
92
|
+
|
|
93
|
+
var getDataByIds = function getDataByIds(options, ids, valueFieldId) {
|
|
94
|
+
return (0, _filter["default"])(options, function (node) {
|
|
95
|
+
return (0, _some["default"])(ids, function (v) {
|
|
96
|
+
return v === node[valueFieldId];
|
|
97
|
+
});
|
|
98
|
+
});
|
|
99
|
+
};
|
|
100
|
+
|
|
101
|
+
var getSingleValue = function getSingleValue(options, value, valueFieldId) {
|
|
102
|
+
return (0, _find["default"])(options, [valueFieldId, value]);
|
|
103
|
+
};
|
|
104
|
+
|
|
105
|
+
var getMultiValue = function getMultiValue(options, value, valueFieldId) {
|
|
106
|
+
return getDataByIds(options, value, valueFieldId);
|
|
107
|
+
};
|
|
108
|
+
/**
|
|
109
|
+
* Функция преобразования value rcTreeSelect в формат n2o
|
|
110
|
+
* Производит поиск по родителям и потомкам.
|
|
111
|
+
* rcTreeSelect не дает информации о выделенных потомках при моде 'SHOW_PARENT'
|
|
112
|
+
* и о выделенных родителях при 'SHOW_CHILD'
|
|
113
|
+
* ['id', 'id'] => [{ id: 'id', ... },{ id: 'id', ... }]
|
|
114
|
+
* @param options
|
|
115
|
+
* @param value
|
|
116
|
+
* @param multiSelect
|
|
117
|
+
* @param valueFieldId
|
|
118
|
+
* @returns {*}
|
|
119
|
+
*/
|
|
120
|
+
|
|
121
|
+
|
|
122
|
+
var getItemByValue = function getItemByValue(options, value, multiSelect, valueFieldId) {
|
|
123
|
+
if (!value) {
|
|
124
|
+
return null;
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
if (!multiSelect) {
|
|
128
|
+
return getSingleValue(options, value, valueFieldId);
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
return getMultiValue(options, value, valueFieldId);
|
|
132
|
+
};
|
|
133
|
+
/**
|
|
134
|
+
* @reactProps {function} onBlur
|
|
135
|
+
* @reactProps {string} placeholder
|
|
136
|
+
* @reactProps {function} setTreeExpandedKeys
|
|
137
|
+
* @reactProps {array} treeExpandedKeys
|
|
138
|
+
* @reactProps {node} children
|
|
139
|
+
* @returns {*}
|
|
140
|
+
* @constructor
|
|
141
|
+
* @param props
|
|
142
|
+
*/
|
|
143
|
+
// TODO переделать в класс
|
|
144
|
+
|
|
145
|
+
|
|
146
|
+
function InputSelectTree(_ref2) {
|
|
147
|
+
var t = _ref2.t,
|
|
148
|
+
fetchData = _ref2.fetchData,
|
|
149
|
+
onFocus = _ref2.onFocus,
|
|
150
|
+
value = _ref2.value,
|
|
151
|
+
onBlur = _ref2.onBlur,
|
|
152
|
+
placeholder = _ref2.placeholder,
|
|
153
|
+
_ref2$notFoundContent = _ref2.notFoundContent,
|
|
154
|
+
notFoundContent = _ref2$notFoundContent === void 0 ? t('noData') : _ref2$notFoundContent,
|
|
155
|
+
loading = _ref2.loading,
|
|
156
|
+
parentFieldId = _ref2.parentFieldId,
|
|
157
|
+
valueFieldId = _ref2.valueFieldId,
|
|
158
|
+
labelFieldId = _ref2.labelFieldId,
|
|
159
|
+
iconFieldId = _ref2.iconFieldId,
|
|
160
|
+
imageFieldId = _ref2.imageFieldId,
|
|
161
|
+
badge = _ref2.badge,
|
|
162
|
+
hasChildrenFieldId = _ref2.hasChildrenFieldId,
|
|
163
|
+
options = _ref2.options,
|
|
164
|
+
onSearch = _ref2.onSearch,
|
|
165
|
+
onSelect = _ref2.onSelect,
|
|
166
|
+
onChange = _ref2.onChange,
|
|
167
|
+
hasCheckboxes = _ref2.hasCheckboxes,
|
|
168
|
+
filter = _ref2.filter,
|
|
169
|
+
multiSelect = _ref2.multiSelect,
|
|
170
|
+
children = _ref2.children,
|
|
171
|
+
onClose = _ref2.onClose,
|
|
172
|
+
onToggle = _ref2.onToggle,
|
|
173
|
+
ajax = _ref2.ajax,
|
|
174
|
+
className = _ref2.className,
|
|
175
|
+
showCheckedStrategy = _ref2.showCheckedStrategy,
|
|
176
|
+
maxTagTextLength = _ref2.maxTagTextLength,
|
|
177
|
+
disabled = _ref2.disabled;
|
|
178
|
+
var treeExpandedKeys = (0, _react.useRef)([]);
|
|
179
|
+
|
|
180
|
+
var _useState = (0, _react.useState)(''),
|
|
181
|
+
_useState2 = (0, _slicedToArray2["default"])(_useState, 2),
|
|
182
|
+
searchValue = _useState2[0],
|
|
183
|
+
setSearchValue = _useState2[1]; // eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
184
|
+
|
|
185
|
+
|
|
186
|
+
InputSelectTree.handleClickOutside = function () {
|
|
187
|
+
return setSearchValue('');
|
|
188
|
+
};
|
|
189
|
+
/**
|
|
190
|
+
* Функуия для создания дерева.
|
|
191
|
+
* Преобразует коллекцию вида [..., { ... }] в [ ..., {..., children: [...]}]
|
|
192
|
+
* Вложение происходит при совпадении valueFieldId и parentFieldId.
|
|
193
|
+
* @param items
|
|
194
|
+
* @returns {*}
|
|
195
|
+
*/
|
|
196
|
+
|
|
197
|
+
|
|
198
|
+
var treeData = (0, _react.useMemo)(function () {
|
|
199
|
+
var popupProps = {
|
|
200
|
+
prefixCls: 'n2o-select-tree',
|
|
201
|
+
iconFieldId: iconFieldId,
|
|
202
|
+
imageFieldId: imageFieldId,
|
|
203
|
+
labelFieldId: labelFieldId,
|
|
204
|
+
badge: badge
|
|
205
|
+
};
|
|
206
|
+
var items = options || [];
|
|
207
|
+
var itemsByID = (0, _toConsumableArray2["default"])(items).reduce(function (acc, item) {
|
|
208
|
+
return _objectSpread(_objectSpread({}, acc), {}, (0, _defineProperty2["default"])({}, item[valueFieldId], _objectSpread(_objectSpread(_objectSpread({}, item), {}, {
|
|
209
|
+
key: item[valueFieldId],
|
|
210
|
+
value: item[valueFieldId],
|
|
211
|
+
title: item.formattedTitle || (0, _until.visiblePartPopup)(item, popupProps)
|
|
212
|
+
}, ajax && {
|
|
213
|
+
isLeaf: !item[hasChildrenFieldId]
|
|
214
|
+
}), {}, {
|
|
215
|
+
children: []
|
|
216
|
+
})));
|
|
217
|
+
}, {} // eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
218
|
+
);
|
|
219
|
+
(0, _keys["default"])(itemsByID).forEach(function (key) {
|
|
220
|
+
if (itemsByID[key][parentFieldId] && itemsByID[itemsByID[key][parentFieldId]] && itemsByID[itemsByID[key][parentFieldId]].children) {
|
|
221
|
+
itemsByID[itemsByID[key][parentFieldId]].children.push(_objectSpread({}, itemsByID[key]));
|
|
222
|
+
}
|
|
223
|
+
});
|
|
224
|
+
return (0, _keys["default"])(itemsByID).filter(function (key) {
|
|
225
|
+
if (!itemsByID[key][parentFieldId]) {
|
|
226
|
+
return true;
|
|
227
|
+
}
|
|
228
|
+
|
|
229
|
+
return !!(itemsByID[key][parentFieldId] && // eslint-disable-next-line no-prototype-builtins
|
|
230
|
+
!itemsByID.hasOwnProperty(itemsByID[key][parentFieldId]));
|
|
231
|
+
}) // eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
232
|
+
.reduce(function (acc, key) {
|
|
233
|
+
return [].concat((0, _toConsumableArray2["default"])(acc), [_objectSpread({}, itemsByID[key])]);
|
|
234
|
+
}, []);
|
|
235
|
+
}, [ajax, badge, options, hasChildrenFieldId, iconFieldId, imageFieldId, labelFieldId, parentFieldId, valueFieldId]);
|
|
236
|
+
/**
|
|
237
|
+
* Функция для поиска.
|
|
238
|
+
* При поиске вызов функции происходит для каждого элемента дерева.
|
|
239
|
+
* @param input
|
|
240
|
+
* @param node
|
|
241
|
+
* @returns {*}
|
|
242
|
+
*/
|
|
243
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
244
|
+
|
|
245
|
+
var handlerFilter = (0, _react.useCallback)(function (input, node) {
|
|
246
|
+
var mode = ['includes', 'startsWith', 'endsWith'];
|
|
247
|
+
|
|
248
|
+
if (mode.includes(filter)) {
|
|
249
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
250
|
+
return String.prototype[filter].call(node.props[labelFieldId].toLowerCase(), input.toLowerCase());
|
|
251
|
+
}
|
|
252
|
+
|
|
253
|
+
return true;
|
|
254
|
+
}, [filter, labelFieldId]);
|
|
255
|
+
/**
|
|
256
|
+
* Функция для обратного преобразования value n2o в формат rcTreeSelect
|
|
257
|
+
* ['id', 'id'] => [{ id: 'id', ... },{ id: 'id', ... }]
|
|
258
|
+
* @param value
|
|
259
|
+
* @returns {*}
|
|
260
|
+
*/
|
|
261
|
+
|
|
262
|
+
var setValue = function setValue(value) {
|
|
263
|
+
if (!value) {
|
|
264
|
+
return [];
|
|
265
|
+
}
|
|
266
|
+
|
|
267
|
+
if ((0, _isArray["default"])(value)) {
|
|
268
|
+
return (0, _map["default"])(value, function (v) {
|
|
269
|
+
return v[valueFieldId];
|
|
270
|
+
});
|
|
271
|
+
}
|
|
272
|
+
|
|
273
|
+
return value[valueFieldId];
|
|
274
|
+
};
|
|
275
|
+
/**
|
|
276
|
+
* Функция для переопределения onChange
|
|
277
|
+
* @param value
|
|
278
|
+
*/
|
|
279
|
+
|
|
280
|
+
|
|
281
|
+
var handleChange = (0, _react.useCallback)(function (value) {
|
|
282
|
+
onChange(getItemByValue(options, value, multiSelect, valueFieldId));
|
|
283
|
+
onBlur(getItemByValue(options, value, multiSelect, valueFieldId)); // eslint-disable-next-line react-hooks/exhaustive-deps
|
|
284
|
+
}, [options, multiSelect, onChange, valueFieldId]);
|
|
285
|
+
/**
|
|
286
|
+
* Функция для переопределения onSelect
|
|
287
|
+
* @param value
|
|
288
|
+
*/
|
|
289
|
+
|
|
290
|
+
var handleSelect = (0, _react.useCallback)(function (value) {
|
|
291
|
+
onSelect(getItemByValue(options, value, multiSelect, valueFieldId));
|
|
292
|
+
onBlur(); // eslint-disable-next-line react-hooks/exhaustive-deps
|
|
293
|
+
}, [options, multiSelect, onSelect, valueFieldId]);
|
|
294
|
+
/**
|
|
295
|
+
* Функция для переопределения onSearch
|
|
296
|
+
* @param value
|
|
297
|
+
*/
|
|
298
|
+
|
|
299
|
+
var handleSearch = (0, _react.useCallback)(function (value) {
|
|
300
|
+
setSearchValue(value);
|
|
301
|
+
onSearch(value);
|
|
302
|
+
return true;
|
|
303
|
+
}, [onSearch]);
|
|
304
|
+
var clearSearch = (0, _react.useCallback)(function () {
|
|
305
|
+
setSearchValue('');
|
|
306
|
+
}, []);
|
|
307
|
+
/**
|
|
308
|
+
* Функция для контроля открытия/закрытия popup
|
|
309
|
+
* @param visible
|
|
310
|
+
* @returns {boolean}
|
|
311
|
+
*/
|
|
312
|
+
|
|
313
|
+
var handleDropdownVisibleChange = (0, _react.useCallback)(function (visible) {
|
|
314
|
+
if (visible) {
|
|
315
|
+
onFocus();
|
|
316
|
+
} // onToggle(visible)
|
|
317
|
+
// setDropdownExpanded(visible)
|
|
318
|
+
|
|
319
|
+
|
|
320
|
+
if (visible && !options.length) {
|
|
321
|
+
fetchData();
|
|
322
|
+
} else {
|
|
323
|
+
onClose();
|
|
324
|
+
}
|
|
325
|
+
|
|
326
|
+
if (ajax) {
|
|
327
|
+
treeExpandedKeys.current = [];
|
|
328
|
+
}
|
|
329
|
+
|
|
330
|
+
return false; // eslint-disable-next-line react-hooks/exhaustive-deps
|
|
331
|
+
}, [ajax, onClose, onFocus, fetchData, onToggle]);
|
|
332
|
+
/**
|
|
333
|
+
* Функция для контроля открытия/закрытия элемента дерева
|
|
334
|
+
* @param keys
|
|
335
|
+
*/
|
|
336
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
337
|
+
|
|
338
|
+
var onTreeExpand = (0, _react.useCallback)( /*#__PURE__*/function () {
|
|
339
|
+
var _ref3 = (0, _asyncToGenerator2["default"])( /*#__PURE__*/_regenerator["default"].mark(function _callee(keys) {
|
|
340
|
+
var currentKey;
|
|
341
|
+
return _regenerator["default"].wrap(function _callee$(_context) {
|
|
342
|
+
while (1) {
|
|
343
|
+
switch (_context.prev = _context.next) {
|
|
344
|
+
case 0:
|
|
345
|
+
currentKey = (0, _difference["default"])(keys, treeExpandedKeys.current);
|
|
346
|
+
|
|
347
|
+
if (!ajax) {
|
|
348
|
+
_context.next = 4;
|
|
349
|
+
break;
|
|
350
|
+
}
|
|
351
|
+
|
|
352
|
+
_context.next = 4;
|
|
353
|
+
return fetchData({
|
|
354
|
+
'filter.parent_id': currentKey[0]
|
|
355
|
+
}, true);
|
|
356
|
+
|
|
357
|
+
case 4:
|
|
358
|
+
treeExpandedKeys.current = keys;
|
|
359
|
+
|
|
360
|
+
case 5:
|
|
361
|
+
case "end":
|
|
362
|
+
return _context.stop();
|
|
363
|
+
}
|
|
364
|
+
}
|
|
365
|
+
}, _callee);
|
|
366
|
+
}));
|
|
367
|
+
|
|
368
|
+
return function (_x) {
|
|
369
|
+
return _ref3.apply(this, arguments);
|
|
370
|
+
};
|
|
371
|
+
}(), [ajax, fetchData]);
|
|
372
|
+
|
|
373
|
+
var clearIcon = /*#__PURE__*/_react["default"].createElement(_Icon.Icon, {
|
|
374
|
+
onClick: clearSearch,
|
|
375
|
+
name: "fa fa-times n2o-input-select-tree__clear-icon"
|
|
376
|
+
});
|
|
377
|
+
|
|
378
|
+
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
379
|
+
className: (0, _classnames["default"])('n2o-select-tree-container', className, {
|
|
380
|
+
empty: (0, _isEmpty["default"])(value),
|
|
381
|
+
multi: multiSelect,
|
|
382
|
+
single: !multiSelect
|
|
383
|
+
})
|
|
384
|
+
}, /*#__PURE__*/_react["default"].createElement(_rcTreeSelect["default"], {
|
|
385
|
+
allowClear: !(0, _isEmpty["default"])(value),
|
|
386
|
+
value: setValue(value),
|
|
387
|
+
onDropdownVisibleChange: handleDropdownVisibleChange,
|
|
388
|
+
switcherIcon: renderSwitcherIcon,
|
|
389
|
+
suffixIcon: /*#__PURE__*/_react["default"].createElement(_Icon.Icon, {
|
|
390
|
+
name: "fa fa-chevron-down"
|
|
391
|
+
}),
|
|
392
|
+
multiple: multiSelect,
|
|
393
|
+
treeCheckable: hasCheckboxes && /*#__PURE__*/_react["default"].createElement(_Checkbox.Checkbox, {
|
|
394
|
+
inline: true
|
|
395
|
+
}),
|
|
396
|
+
treeData: treeData,
|
|
397
|
+
filterTreeNode: handlerFilter,
|
|
398
|
+
treeNodeFilterProp: labelFieldId,
|
|
399
|
+
treeNodeLabelProp: labelFieldId,
|
|
400
|
+
maxTagTextLength: maxTagTextLength,
|
|
401
|
+
clearIcon: clearIcon // иконка очищения всего инпута
|
|
402
|
+
,
|
|
403
|
+
removeIcon: (0, _isEmpty["default"])(value) ? null : clearIcon // иконка очищения итема
|
|
404
|
+
,
|
|
405
|
+
onChange: handleChange,
|
|
406
|
+
onSelect: handleSelect,
|
|
407
|
+
onSearch: handleSearch,
|
|
408
|
+
onTreeExpand: onTreeExpand,
|
|
409
|
+
showCheckedStrategy: (0, _until.getCheckedStrategy)(showCheckedStrategy),
|
|
410
|
+
getPopupContainer: getPopupContainer,
|
|
411
|
+
notFoundContent: loading ? /*#__PURE__*/_react["default"].createElement(_InlineSpinner.InlineSpinner, null) : notFoundContent,
|
|
412
|
+
placeholder: searchValue ? null : placeholder,
|
|
413
|
+
disabled: disabled,
|
|
414
|
+
searchValue: searchValue,
|
|
415
|
+
showSearch: !multiSelect,
|
|
416
|
+
listHeight: 400,
|
|
417
|
+
prefixCls: "n2o-select-tree"
|
|
418
|
+
}, children));
|
|
419
|
+
}
|
|
420
|
+
|
|
421
|
+
InputSelectTree.defaultProps = {
|
|
422
|
+
children: null,
|
|
423
|
+
hasChildrenFieldId: 'hasChildren',
|
|
424
|
+
disabled: false,
|
|
425
|
+
loading: false,
|
|
426
|
+
parentFieldId: 'parentId',
|
|
427
|
+
valueFieldId: 'id',
|
|
428
|
+
labelFieldId: 'name',
|
|
429
|
+
iconFieldId: 'icon',
|
|
430
|
+
badge: {
|
|
431
|
+
fieldId: 'badge',
|
|
432
|
+
colorFieldId: 'color'
|
|
433
|
+
},
|
|
434
|
+
imageFieldId: 'image',
|
|
435
|
+
sortFieldId: 'name',
|
|
436
|
+
filter: 'startsWith',
|
|
437
|
+
hasCheckboxes: false,
|
|
438
|
+
multiSelect: false,
|
|
439
|
+
options: [],
|
|
440
|
+
transitionName: 'slide-up',
|
|
441
|
+
choiceTransitionName: 'zoom',
|
|
442
|
+
showCheckedStrategy: 'all',
|
|
443
|
+
allowClear: true,
|
|
444
|
+
placeholder: '',
|
|
445
|
+
showSearch: true,
|
|
446
|
+
maxTagTextLength: 10,
|
|
447
|
+
onSearch: function onSearch() {},
|
|
448
|
+
onSelect: function onSelect() {},
|
|
449
|
+
onChange: function onChange() {},
|
|
450
|
+
onClose: function onClose() {},
|
|
451
|
+
onToggle: function onToggle() {},
|
|
452
|
+
onFocus: function onFocus() {},
|
|
453
|
+
onBlur: function onBlur() {},
|
|
454
|
+
onInput: function onInput() {},
|
|
455
|
+
t: function t() {}
|
|
456
|
+
};
|
|
457
|
+
var clickOutsideConfig = {
|
|
458
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
459
|
+
handleClickOutside: function handleClickOutside() {
|
|
460
|
+
return InputSelectTree.handleClickOutside;
|
|
461
|
+
}
|
|
462
|
+
};
|
|
463
|
+
var InputSelectTreeComponent = // eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
464
|
+
(0, _reactOnclickoutside["default"])((0, _reactI18next.withTranslation)()(InputSelectTree), clickOutsideConfig);
|
|
465
|
+
exports.InputSelectTreeComponent = InputSelectTreeComponent;
|
|
466
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/inputs/InputSelectTree/InputSelectTree.tsx"],"names":["renderSwitcherIcon","isLeaf","getPopupContainer","container","getDataByIds","options","ids","valueFieldId","node","v","getSingleValue","value","getMultiValue","getItemByValue","multiSelect","InputSelectTree","t","fetchData","onFocus","onBlur","placeholder","notFoundContent","loading","parentFieldId","labelFieldId","iconFieldId","imageFieldId","badge","hasChildrenFieldId","onSearch","onSelect","onChange","hasCheckboxes","filter","children","onClose","onToggle","ajax","className","showCheckedStrategy","maxTagTextLength","disabled","treeExpandedKeys","searchValue","setSearchValue","handleClickOutside","treeData","popupProps","prefixCls","items","itemsByID","reduce","acc","item","key","title","formattedTitle","forEach","push","hasOwnProperty","handlerFilter","input","mode","includes","String","prototype","call","props","toLowerCase","setValue","handleChange","handleSelect","handleSearch","clearSearch","handleDropdownVisibleChange","visible","length","current","onTreeExpand","keys","currentKey","clearIcon","empty","multi","single","defaultProps","fieldId","colorFieldId","sortFieldId","transitionName","choiceTransitionName","allowClear","showSearch","onInput","clickOutsideConfig","InputSelectTreeComponent"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AAGA;;AACA;;AACA;;AAEA;;AACA;;;;;;;;;;AAEA,IAAMA,kBAAkB,GAAG,SAArBA,kBAAqB;AAAA,MAAGC,MAAH,QAAGA,MAAH;AAAA,SAAoCA,MAAM,GAAG,IAAH,gBAAU,gCAAC,UAAD;AAAM,IAAA,IAAI,EAAC;AAAX,IAApD;AAAA,CAA3B,C,CACA;;;AACA,IAAMC,iBAAiB,GAAG,SAApBA,iBAAoB,CAACC,SAAD;AAAA,SAAoBA,SAApB;AAAA,CAA1B;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AACA,IAAMC,YAAY,GAAG,SAAfA,YAAe,CAACC,OAAD,EAA4BC,GAA5B,EAA2CC,YAA3C;AAAA,SAAmF,wBAAQF,OAAR,EAAiB,UAAAG,IAAI;AAAA,WAAI,sBAAKF,GAAL,EAAU,UAAAG,CAAC;AAAA,aAAIA,CAAC,KAAKD,IAAI,CAACD,YAAD,CAAd;AAAA,KAAX,CAAJ;AAAA,GAArB,CAAnF;AAAA,CAArB;;AAEA,IAAMG,cAAc,GAAG,SAAjBA,cAAiB,CAACL,OAAD,EAA4BM,KAA5B,EAAmDJ,YAAnD;AAAA,SAA2F,sBAAKF,OAAL,EAAc,CAACE,YAAD,EAAeI,KAAf,CAAd,CAA3F;AAAA,CAAvB;;AACA,IAAMC,aAAa,GAAG,SAAhBA,aAAgB,CAACP,OAAD,EAA4BM,KAA5B,EAAmDJ,YAAnD;AAAA,SAA2FH,YAAY,CAACC,OAAD,EAAUM,KAAV,EAAiBJ,YAAjB,CAAvG;AAAA,CAAtB;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AACA,IAAMM,cAAc,GAAG,SAAjBA,cAAiB,CAACR,OAAD,EAA4BM,KAA5B,EAAmDG,WAAnD,EAAsFP,YAAtF,EAA8H;AACjJ,MAAI,CAACI,KAAL,EAAY;AAAE,WAAO,IAAP;AAAa;;AAC3B,MAAI,CAACG,WAAL,EAAkB;AACd,WAAOJ,cAAc,CAACL,OAAD,EAAUM,KAAV,EAAiBJ,YAAjB,CAArB;AACH;;AAED,SAAOK,aAAa,CAACP,OAAD,EAAUM,KAAV,EAAiBJ,YAAjB,CAApB;AACH,CAPD;AASA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AACA,SAASQ,eAAT,QA+BU;AAAA,MA9BNC,CA8BM,SA9BNA,CA8BM;AAAA,MA7BNC,SA6BM,SA7BNA,SA6BM;AAAA,MA5BNC,OA4BM,SA5BNA,OA4BM;AAAA,MA3BNP,KA2BM,SA3BNA,KA2BM;AAAA,MA1BNQ,MA0BM,SA1BNA,MA0BM;AAAA,MAzBNC,WAyBM,SAzBNA,WAyBM;AAAA,oCAxBNC,eAwBM;AAAA,MAxBNA,eAwBM,sCAxBYL,CAAC,CAAC,QAAD,CAwBb;AAAA,MAvBNM,OAuBM,SAvBNA,OAuBM;AAAA,MAtBNC,aAsBM,SAtBNA,aAsBM;AAAA,MArBNhB,YAqBM,SArBNA,YAqBM;AAAA,MApBNiB,YAoBM,SApBNA,YAoBM;AAAA,MAnBNC,WAmBM,SAnBNA,WAmBM;AAAA,MAlBNC,YAkBM,SAlBNA,YAkBM;AAAA,MAjBNC,KAiBM,SAjBNA,KAiBM;AAAA,MAhBNC,kBAgBM,SAhBNA,kBAgBM;AAAA,MAfNvB,OAeM,SAfNA,OAeM;AAAA,MAdNwB,QAcM,SAdNA,QAcM;AAAA,MAbNC,QAaM,SAbNA,QAaM;AAAA,MAZNC,QAYM,SAZNA,QAYM;AAAA,MAXNC,aAWM,SAXNA,aAWM;AAAA,MAVNC,MAUM,SAVNA,MAUM;AAAA,MATNnB,WASM,SATNA,WASM;AAAA,MARNoB,QAQM,SARNA,QAQM;AAAA,MAPNC,OAOM,SAPNA,OAOM;AAAA,MANNC,QAMM,SANNA,QAMM;AAAA,MALNC,IAKM,SALNA,IAKM;AAAA,MAJNC,SAIM,SAJNA,SAIM;AAAA,MAHNC,mBAGM,SAHNA,mBAGM;AAAA,MAFNC,gBAEM,SAFNA,gBAEM;AAAA,MADNC,QACM,SADNA,QACM;AACN,MAAMC,gBAAgB,GAAG,mBAAO,EAAP,CAAzB;;AACA,kBAAsC,qBAAS,EAAT,CAAtC;AAAA;AAAA,MAAOC,WAAP;AAAA,MAAoBC,cAApB,iBAFM,CAIN;;;AACC7B,EAAAA,eAAD,CAAyB8B,kBAAzB,GAA8C;AAAA,WAAMD,cAAc,CAAC,EAAD,CAApB;AAAA,GAA9C;AAEA;AACJ;AACA;AACA;AACA;AACA;AACA;;;AACI,MAAME,QAAQ,GAAG,oBAAQ,YAAM;AAC3B,QAAMC,UAAU,GAAG;AACfC,MAAAA,SAAS,EAAE,iBADI;AAEfvB,MAAAA,WAAW,EAAXA,WAFe;AAGfC,MAAAA,YAAY,EAAZA,YAHe;AAIfF,MAAAA,YAAY,EAAZA,YAJe;AAKfG,MAAAA,KAAK,EAALA;AALe,KAAnB;AAOA,QAAMsB,KAAK,GAAG5C,OAAO,IAAI,EAAzB;AACA,QAAM6C,SAAS,GAAG,oCAAID,KAAJ,EAAWE,MAAX,CACd,UAACC,GAAD,EAAMC,IAAN;AAAA,6CACOD,GADP,4CAEKC,IAAI,CAAC9C,YAAD,CAFT,gDAGW8C,IAHX;AAIQC,QAAAA,GAAG,EAAED,IAAI,CAAC9C,YAAD,CAJjB;AAKQI,QAAAA,KAAK,EAAE0C,IAAI,CAAC9C,YAAD,CALnB;AAMQgD,QAAAA,KAAK,EAAEF,IAAI,CAACG,cAAL,IAAuB,6BAAiBH,IAAjB,EAAuBN,UAAvB;AANtC,SAOYV,IAAI,IAAI;AAAEpC,QAAAA,MAAM,EAAE,CAACoD,IAAI,CAACzB,kBAAD;AAAf,OAPpB;AAQQM,QAAAA,QAAQ,EAAE;AARlB;AAAA,KADc,EAYd,EAZc,CAalB;AAbkB,KAAlB;AAgBA,0BAAKgB,SAAL,EAAgBO,OAAhB,CAAwB,UAACH,GAAD,EAAS;AAC7B,UACIJ,SAAS,CAACI,GAAD,CAAT,CAAe/B,aAAf,KACA2B,SAAS,CAACA,SAAS,CAACI,GAAD,CAAT,CAAe/B,aAAf,CAAD,CADT,IAEA2B,SAAS,CAACA,SAAS,CAACI,GAAD,CAAT,CAAe/B,aAAf,CAAD,CAAT,CAAyCW,QAH7C,EAIE;AACEgB,QAAAA,SAAS,CAACA,SAAS,CAACI,GAAD,CAAT,CAAe/B,aAAf,CAAD,CAAT,CAAyCW,QAAzC,CAAkDwB,IAAlD,mBACOR,SAAS,CAACI,GAAD,CADhB;AAGH;AACJ,KAVD;AAYA,WAAO,sBAAKJ,SAAL,EACFjB,MADE,CACK,UAACqB,GAAD,EAAS;AACb,UAAI,CAACJ,SAAS,CAACI,GAAD,CAAT,CAAe/B,aAAf,CAAL,EAAoC;AAChC,eAAO,IAAP;AACH;;AAED,aAAO,CAAC,EAAE2B,SAAS,CAACI,GAAD,CAAT,CAAe/B,aAAf,KACN;AACA,OAAC2B,SAAS,CAACS,cAAV,CAAyBT,SAAS,CAACI,GAAD,CAAT,CAAe/B,aAAf,CAAzB,CAFG,CAAR;AAGH,KATE,EAUH;AAVG,KAWF4B,MAXE,CAWK,UAACC,GAAD,EAAME,GAAN;AAAA,2DAAkBF,GAAlB,sBAA4BF,SAAS,CAACI,GAAD,CAArC;AAAA,KAXL,EAW2D,EAX3D,CAAP;AAYH,GAjDgB,EAiDd,CACCjB,IADD,EACOV,KADP,EACctB,OADd,EACuBuB,kBADvB,EAECH,WAFD,EAEcC,YAFd,EAE4BF,YAF5B,EAGCD,aAHD,EAGgBhB,YAHhB,CAjDc,CAAjB;AAuDA;AACJ;AACA;AACA;AACA;AACA;AACA;AACI;;AACA,MAAMqD,aAAa,GAAG,wBAAY,UAACC,KAAD,EAAgBrD,IAAhB,EAA8B;AAC5D,QAAMsD,IAAI,GAAG,CAAC,UAAD,EAAa,YAAb,EAA2B,UAA3B,CAAb;;AAEA,QAAIA,IAAI,CAACC,QAAL,CAAc9B,MAAd,CAAJ,EAA2B;AACvB;AACA,aAAQ+B,MAAM,CAACC,SAAP,CAAiBhC,MAAjB,CAAD,CAAyCiC,IAAzC,CACH1D,IAAI,CAAC2D,KAAL,CAAW3C,YAAX,EAAyB4C,WAAzB,EADG,EAEHP,KAAK,CAACO,WAAN,EAFG,CAAP;AAIH;;AAED,WAAO,IAAP;AACH,GAZqB,EAYnB,CAACnC,MAAD,EAAST,YAAT,CAZmB,CAAtB;AAcA;AACJ;AACA;AACA;AACA;AACA;;AACI,MAAM6C,QAAQ,GAAG,SAAXA,QAAW,CAAC1D,KAAD,EAA2B;AACxC,QAAI,CAACA,KAAL,EAAY;AAAE,aAAO,EAAP;AAAW;;AACzB,QAAI,yBAAQA,KAAR,CAAJ,EAAoB;AAChB,aAAO,qBAAIA,KAAJ,EAAW,UAAAF,CAAC;AAAA,eAAIA,CAAC,CAACF,YAAD,CAAL;AAAA,OAAZ,CAAP;AACH;;AAED,WAAOI,KAAK,CAACJ,YAAD,CAAZ;AACH,GAPD;AASA;AACJ;AACA;AACA;;;AACI,MAAM+D,YAAY,GAAG,wBAAY,UAAC3D,KAAD,EAA2B;AACxDoB,IAAAA,QAAQ,CAAClB,cAAc,CAACR,OAAD,EAAUM,KAAV,EAAiBG,WAAjB,EAA8BP,YAA9B,CAAf,CAAR;AACAY,IAAAA,MAAM,CAACN,cAAc,CAACR,OAAD,EAAUM,KAAV,EAAiBG,WAAjB,EAA8BP,YAA9B,CAAf,CAAN,CAFwD,CAGxD;AACH,GAJoB,EAIlB,CAACF,OAAD,EAAUS,WAAV,EAAuBiB,QAAvB,EAAiCxB,YAAjC,CAJkB,CAArB;AAMA;AACJ;AACA;AACA;;AACI,MAAMgE,YAAY,GAAG,wBAAY,UAAC5D,KAAD,EAA2B;AACxDmB,IAAAA,QAAQ,CAACjB,cAAc,CAACR,OAAD,EAAUM,KAAV,EAAiBG,WAAjB,EAA8BP,YAA9B,CAAf,CAAR;AACAY,IAAAA,MAAM,GAFkD,CAGxD;AACH,GAJoB,EAIlB,CAACd,OAAD,EAAUS,WAAV,EAAuBgB,QAAvB,EAAiCvB,YAAjC,CAJkB,CAArB;AAMA;AACJ;AACA;AACA;;AACI,MAAMiE,YAAY,GAAG,wBAAY,UAAC7D,KAAD,EAA2B;AACxDiC,IAAAA,cAAc,CAACjC,KAAD,CAAd;AACAkB,IAAAA,QAAQ,CAAClB,KAAD,CAAR;AAEA,WAAO,IAAP;AACH,GALoB,EAKlB,CAACkB,QAAD,CALkB,CAArB;AAOA,MAAM4C,WAAW,GAAG,wBAAY,YAAM;AAClC7B,IAAAA,cAAc,CAAC,EAAD,CAAd;AACH,GAFmB,EAEjB,EAFiB,CAApB;AAIA;AACJ;AACA;AACA;AACA;;AACI,MAAM8B,2BAA2B,GAAG,wBAAY,UAACC,OAAD,EAAsB;AAClE,QAAIA,OAAJ,EAAa;AACTzD,MAAAA,OAAO;AACV,KAHiE,CAIlE;AACA;;;AAEA,QAAIyD,OAAO,IAAI,CAACtE,OAAO,CAACuE,MAAxB,EAAgC;AAC5B3D,MAAAA,SAAS;AACZ,KAFD,MAEO;AACHkB,MAAAA,OAAO;AACV;;AACD,QAAIE,IAAJ,EAAU;AAAEK,MAAAA,gBAAgB,CAACmC,OAAjB,GAA2B,EAA3B;AAA+B;;AAE3C,WAAO,KAAP,CAdkE,CAelE;AACH,GAhBmC,EAgBjC,CAACxC,IAAD,EAAOF,OAAP,EAAgBjB,OAAhB,EAAyBD,SAAzB,EAAoCmB,QAApC,CAhBiC,CAApC;AAkBA;AACJ;AACA;AACA;AACI;;AACA,MAAM0C,YAAY,GAAG;AAAA,8FAAY,iBAAOC,IAAP;AAAA;AAAA;AAAA;AAAA;AAAA;AACvBC,cAAAA,UADuB,GACV,4BAAWD,IAAX,EAAiBrC,gBAAgB,CAACmC,OAAlC,CADU;;AAAA,mBAGzBxC,IAHyB;AAAA;AAAA;AAAA;;AAAA;AAAA,qBAInBpB,SAAS,CAAC;AAAE,oCAAoB+D,UAAU,CAAC,CAAD;AAAhC,eAAD,EAAwC,IAAxC,CAJU;;AAAA;AAM7BtC,cAAAA,gBAAgB,CAACmC,OAAjB,GAA2BE,IAA3B;;AAN6B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,KAAZ;;AAAA;AAAA;AAAA;AAAA,OAOlB,CAAC1C,IAAD,EAAOpB,SAAP,CAPkB,CAArB;;AASA,MAAMgE,SAAS,gBACX,gCAAC,UAAD;AACI,IAAA,OAAO,EAAER,WADb;AAEI,IAAA,IAAI,EAAC;AAFT,IADJ;;AAOA,sBACI;AAAK,IAAA,SAAS,EAAE,4BACZ,2BADY,EAEZnC,SAFY,EAGZ;AACI4C,MAAAA,KAAK,EAAE,yBAAQvE,KAAR,CADX;AAC2BwE,MAAAA,KAAK,EAAErE,WADlC;AAC+CsE,MAAAA,MAAM,EAAE,CAACtE;AADxD,KAHY;AAAhB,kBAQI,gCAAC,wBAAD;AACI,IAAA,UAAU,EAAE,CAAC,yBAAQH,KAAR,CADjB;AAEI,IAAA,KAAK,EAAE0D,QAAQ,CAAC1D,KAAD,CAFnB;AAGI,IAAA,uBAAuB,EAAE+D,2BAH7B;AAII,IAAA,YAAY,EAAE1E,kBAJlB;AAKI,IAAA,UAAU,eAAE,gCAAC,UAAD;AAAM,MAAA,IAAI,EAAC;AAAX,MALhB;AAMI,IAAA,QAAQ,EAAEc,WANd;AAOI,IAAA,aAAa,EAAEkB,aAAa,iBAAI,gCAAC,kBAAD;AAAU,MAAA,MAAM;AAAhB,MAPpC;AAQI,IAAA,QAAQ,EAAEc,QARd;AASI,IAAA,cAAc,EAAEc,aATpB;AAUI,IAAA,kBAAkB,EAAEpC,YAVxB;AAWI,IAAA,iBAAiB,EAAEA,YAXvB;AAYI,IAAA,gBAAgB,EAAEgB,gBAZtB;AAaI,IAAA,SAAS,EAAEyC,SAbf,CAa0B;AAb1B;AAcI,IAAA,UAAU,EAAE,yBAAQtE,KAAR,IAAiB,IAAjB,GAAwBsE,SAdxC,CAcmD;AAdnD;AAeI,IAAA,QAAQ,EAAEX,YAfd;AAgBI,IAAA,QAAQ,EAAEC,YAhBd;AAiBI,IAAA,QAAQ,EAAEC,YAjBd;AAkBI,IAAA,YAAY,EAAEM,YAlBlB;AAmBI,IAAA,mBAAmB,EAAE,+BAAmBvC,mBAAnB,CAnBzB;AAoBI,IAAA,iBAAiB,EAAErC,iBApBvB;AAqBI,IAAA,eAAe,EAAEoB,OAAO,gBAAG,gCAAC,4BAAD,OAAH,GAAuBD,eArBnD;AAsBI,IAAA,WAAW,EAAEsB,WAAW,GAAG,IAAH,GAAUvB,WAtBtC;AAuBI,IAAA,QAAQ,EAAEqB,QAvBd;AAwBI,IAAA,WAAW,EAAEE,WAxBjB;AAyBI,IAAA,UAAU,EAAE,CAAC7B,WAzBjB;AA0BI,IAAA,UAAU,EAAE,GA1BhB;AA2BI,IAAA,SAAS,EAAC;AA3Bd,KA6BKoB,QA7BL,CARJ,CADJ;AA0CH;;AAEDnB,eAAe,CAACsE,YAAhB,GAA+B;AAC3BnD,EAAAA,QAAQ,EAAE,IADiB;AAE3BN,EAAAA,kBAAkB,EAAE,aAFO;AAG3Ba,EAAAA,QAAQ,EAAE,KAHiB;AAI3BnB,EAAAA,OAAO,EAAE,KAJkB;AAK3BC,EAAAA,aAAa,EAAE,UALY;AAM3BhB,EAAAA,YAAY,EAAE,IANa;AAO3BiB,EAAAA,YAAY,EAAE,MAPa;AAQ3BC,EAAAA,WAAW,EAAE,MARc;AAS3BE,EAAAA,KAAK,EAAE;AACH2D,IAAAA,OAAO,EAAE,OADN;AAEHC,IAAAA,YAAY,EAAE;AAFX,GAToB;AAa3B7D,EAAAA,YAAY,EAAE,OAba;AAc3B8D,EAAAA,WAAW,EAAE,MAdc;AAe3BvD,EAAAA,MAAM,EAAE,YAfmB;AAgB3BD,EAAAA,aAAa,EAAE,KAhBY;AAiB3BlB,EAAAA,WAAW,EAAE,KAjBc;AAkB3BT,EAAAA,OAAO,EAAE,EAlBkB;AAmB3BoF,EAAAA,cAAc,EAAE,UAnBW;AAoB3BC,EAAAA,oBAAoB,EAAE,MApBK;AAqB3BnD,EAAAA,mBAAmB,EAAE,KArBM;AAsB3BoD,EAAAA,UAAU,EAAE,IAtBe;AAuB3BvE,EAAAA,WAAW,EAAE,EAvBc;AAwB3BwE,EAAAA,UAAU,EAAE,IAxBe;AAyB3BpD,EAAAA,gBAAgB,EAAE,EAzBS;AA0B3BX,EAAAA,QAAQ,EAAE,oBAAM,CAAE,CA1BS;AA2B3BC,EAAAA,QAAQ,EAAE,oBAAM,CAAE,CA3BS;AA4B3BC,EAAAA,QAAQ,EAAE,oBAAM,CAAE,CA5BS;AA6B3BI,EAAAA,OAAO,EAAE,mBAAM,CAAE,CA7BU;AA8B3BC,EAAAA,QAAQ,EAAE,oBAAM,CAAE,CA9BS;AA+B3BlB,EAAAA,OAAO,EAAE,mBAAM,CAAE,CA/BU;AAgC3BC,EAAAA,MAAM,EAAE,kBAAM,CAAE,CAhCW;AAiC3B0E,EAAAA,OAAO,EAAE,mBAAM,CAAE,CAjCU;AAkC3B7E,EAAAA,CAAC,EAAE,aAAM,CAAE;AAlCgB,CAA/B;AA0IA,IAAM8E,kBAAkB,GAAG;AACvB;AACAjD,EAAAA,kBAAkB,EAAE;AAAA,WAAO9B,eAAD,CAAyB8B,kBAA/B;AAAA;AAFG,CAA3B;AAKO,IAAMkD,wBAAwB,GACjC;AACA,qCAAkB,qCAAkBhF,eAAlB,CAAlB,EAA6D+E,kBAA7D,CAFG","sourcesContent":["import React, { useCallback, ReactNode, useMemo, useRef, useState } from 'react'\nimport TreeSelect from 'rc-tree-select'\nimport difference from 'lodash/difference'\nimport filterF from 'lodash/filter'\nimport find from 'lodash/find'\nimport isArray from 'lodash/isArray'\nimport isEmpty from 'lodash/isEmpty'\nimport keys from 'lodash/keys'\nimport map from 'lodash/map'\nimport some from 'lodash/some'\nimport classNames from 'classnames'\nimport { withTranslation } from 'react-i18next'\nimport onClickOutsideHOC from 'react-onclickoutside'\n\nimport { Filter, TOption } from '../InputSelect/types'\nimport { Icon } from '../../display/Icon/Icon'\nimport { InlineSpinner } from '../../layouts/Spinner/InlineSpinner'\nimport { Checkbox } from '../Checkbox/Checkbox'\n\nimport { TreeNode } from './TreeSelectNode'\nimport { visiblePartPopup, getCheckedStrategy } from './until'\n\nconst renderSwitcherIcon = ({ isLeaf }: {isLeaf: boolean}) => (isLeaf ? null : <Icon name=\"fa fa-chevron-right\" />)\n// eslint-disable-next-line @typescript-eslint/no-explicit-any\nconst getPopupContainer = (container: any) => container\n/**\n * Взять данные по ids.\n * ['id', 'id'] => [{ id: 'id', ... },{ id: 'id', ... }]\n * @param options\n * @param ids\n * @param valueFieldId\n */\nconst getDataByIds = (options: Props['options'], ids: string[], valueFieldId: Props['valueFieldId']) => filterF(options, node => some(ids, v => v === node[valueFieldId as keyof TOption]))\n\nconst getSingleValue = (options: Props['options'], value: Props['value'], valueFieldId: Props['valueFieldId']) => find(options, [valueFieldId, value])\nconst getMultiValue = (options: Props['options'], value: Props['value'], valueFieldId: Props['valueFieldId']) => getDataByIds(options, value, valueFieldId)\n\n/**\n * Функция преобразования value rcTreeSelect в формат n2o\n * Производит поиск по родителям и потомкам.\n * rcTreeSelect не дает информации о выделенных потомках при моде 'SHOW_PARENT'\n * и о выделенных родителях при 'SHOW_CHILD'\n * ['id', 'id'] => [{ id: 'id', ... },{ id: 'id', ... }]\n * @param options\n * @param value\n * @param multiSelect\n * @param valueFieldId\n * @returns {*}\n */\nconst getItemByValue = (options: Props['options'], value: Props['value'], multiSelect: Props['multiSelect'], valueFieldId: Props['valueFieldId']) => {\n    if (!value) { return null }\n    if (!multiSelect) {\n        return getSingleValue(options, value, valueFieldId)\n    }\n\n    return getMultiValue(options, value, valueFieldId)\n}\n\n/**\n * @reactProps {function} onBlur\n * @reactProps {string} placeholder\n * @reactProps {function} setTreeExpandedKeys\n * @reactProps {array} treeExpandedKeys\n * @reactProps {node} children\n * @returns {*}\n * @constructor\n * @param props\n */\n// TODO переделать в класс\nfunction InputSelectTree({\n    t,\n    fetchData,\n    onFocus,\n    value,\n    onBlur,\n    placeholder,\n    notFoundContent = t('noData'),\n    loading,\n    parentFieldId,\n    valueFieldId,\n    labelFieldId,\n    iconFieldId,\n    imageFieldId,\n    badge,\n    hasChildrenFieldId,\n    options,\n    onSearch,\n    onSelect,\n    onChange,\n    hasCheckboxes,\n    filter,\n    multiSelect,\n    children,\n    onClose,\n    onToggle,\n    ajax,\n    className,\n    showCheckedStrategy,\n    maxTagTextLength,\n    disabled,\n}: Props) {\n    const treeExpandedKeys = useRef([])\n    const [searchValue, setSearchValue] = useState('');\n\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    (InputSelectTree as any).handleClickOutside = () => setSearchValue('')\n\n    /**\n     * Функуия для создания дерева.\n     * Преобразует коллекцию вида [..., { ... }] в [ ..., {..., children: [...]}]\n     * Вложение происходит при совпадении valueFieldId и parentFieldId.\n     * @param items\n     * @returns {*}\n     */\n    const treeData = useMemo(() => {\n        const popupProps = {\n            prefixCls: 'n2o-select-tree',\n            iconFieldId,\n            imageFieldId,\n            labelFieldId,\n            badge,\n        }\n        const items = options || []\n        const itemsByID = [...items].reduce(\n            (acc, item) => ({\n                ...acc,\n                [item[valueFieldId as keyof TOption]]: {\n                    ...item,\n                    key: item[valueFieldId as keyof TOption],\n                    value: item[valueFieldId as keyof TOption],\n                    title: item.formattedTitle || visiblePartPopup(item, popupProps),\n                    ...(ajax && { isLeaf: !item[hasChildrenFieldId as keyof TOption] }),\n                    children: [],\n                },\n            }),\n            {},\n        // eslint-disable-next-line @typescript-eslint/no-explicit-any\n        ) as any\n\n        keys(itemsByID).forEach((key) => {\n            if (\n                itemsByID[key][parentFieldId] &&\n                itemsByID[itemsByID[key][parentFieldId]] &&\n                itemsByID[itemsByID[key][parentFieldId]].children\n            ) {\n                itemsByID[itemsByID[key][parentFieldId]].children.push({\n                    ...itemsByID[key],\n                })\n            }\n        })\n\n        return keys(itemsByID)\n            .filter((key) => {\n                if (!itemsByID[key][parentFieldId]) {\n                    return true\n                }\n\n                return !!(itemsByID[key][parentFieldId] &&\n                    // eslint-disable-next-line no-prototype-builtins\n                    !itemsByID.hasOwnProperty(itemsByID[key][parentFieldId]))\n            })\n            // eslint-disable-next-line @typescript-eslint/no-explicit-any\n            .reduce((acc, key) => [...acc, { ...itemsByID[key] }] as any, [])\n    }, [\n        ajax, badge, options, hasChildrenFieldId,\n        iconFieldId, imageFieldId, labelFieldId,\n        parentFieldId, valueFieldId,\n    ])\n\n    /**\n     * Функция для поиска.\n     * При поиске вызов функции происходит для каждого элемента дерева.\n     * @param input\n     * @param node\n     * @returns {*}\n     */\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    const handlerFilter = useCallback((input: string, node: any) => {\n        const mode = ['includes', 'startsWith', 'endsWith']\n\n        if (mode.includes(filter)) {\n            // eslint-disable-next-line @typescript-eslint/no-explicit-any\n            return (String.prototype[filter as any] as any).call(\n                node.props[labelFieldId].toLowerCase(),\n                input.toLowerCase(),\n            )\n        }\n\n        return true\n    }, [filter, labelFieldId])\n\n    /**\n     * Функция для обратного преобразования value n2o в формат rcTreeSelect\n     * ['id', 'id'] => [{ id: 'id', ... },{ id: 'id', ... }]\n     * @param value\n     * @returns {*}\n     */\n    const setValue = (value: Props['value']) => {\n        if (!value) { return [] }\n        if (isArray(value)) {\n            return map(value, v => v[valueFieldId])\n        }\n\n        return value[valueFieldId]\n    }\n\n    /**\n     * Функция для переопределения onChange\n     * @param value\n     */\n    const handleChange = useCallback((value: Props['value']) => {\n        onChange(getItemByValue(options, value, multiSelect, valueFieldId))\n        onBlur(getItemByValue(options, value, multiSelect, valueFieldId))\n        // eslint-disable-next-line react-hooks/exhaustive-deps\n    }, [options, multiSelect, onChange, valueFieldId])\n\n    /**\n     * Функция для переопределения onSelect\n     * @param value\n     */\n    const handleSelect = useCallback((value: Props['value']) => {\n        onSelect(getItemByValue(options, value, multiSelect, valueFieldId))\n        onBlur()\n        // eslint-disable-next-line react-hooks/exhaustive-deps\n    }, [options, multiSelect, onSelect, valueFieldId])\n\n    /**\n     * Функция для переопределения onSearch\n     * @param value\n     */\n    const handleSearch = useCallback((value: Props['value']) => {\n        setSearchValue(value)\n        onSearch(value)\n\n        return true\n    }, [onSearch])\n\n    const clearSearch = useCallback(() => {\n        setSearchValue('')\n    }, [])\n\n    /**\n     * Функция для контроля открытия/закрытия popup\n     * @param visible\n     * @returns {boolean}\n     */\n    const handleDropdownVisibleChange = useCallback((visible: boolean) => {\n        if (visible) {\n            onFocus()\n        }\n        // onToggle(visible)\n        // setDropdownExpanded(visible)\n\n        if (visible && !options.length) {\n            fetchData()\n        } else {\n            onClose()\n        }\n        if (ajax) { treeExpandedKeys.current = [] }\n\n        return false\n        // eslint-disable-next-line react-hooks/exhaustive-deps\n    }, [ajax, onClose, onFocus, fetchData, onToggle])\n\n    /**\n     * Функция для контроля открытия/закрытия элемента дерева\n     * @param keys\n     */\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    const onTreeExpand = useCallback(async (keys: any) => {\n        const currentKey = difference(keys, treeExpandedKeys.current)\n\n        if (ajax) {\n            await fetchData({ 'filter.parent_id': currentKey[0] }, true)\n        }\n        treeExpandedKeys.current = keys\n    }, [ajax, fetchData])\n\n    const clearIcon = (\n        <Icon\n            onClick={clearSearch}\n            name=\"fa fa-times n2o-input-select-tree__clear-icon\"\n        />\n    )\n\n    return (\n        <div className={classNames(\n            'n2o-select-tree-container',\n            className,\n            {\n                empty: isEmpty(value), multi: multiSelect, single: !multiSelect,\n            },\n        )}\n        >\n            <TreeSelect\n                allowClear={!isEmpty(value)}\n                value={setValue(value)}\n                onDropdownVisibleChange={handleDropdownVisibleChange}\n                switcherIcon={renderSwitcherIcon}\n                suffixIcon={<Icon name=\"fa fa-chevron-down\" />}\n                multiple={multiSelect}\n                treeCheckable={hasCheckboxes && <Checkbox inline />}\n                treeData={treeData}\n                filterTreeNode={handlerFilter}\n                treeNodeFilterProp={labelFieldId}\n                treeNodeLabelProp={labelFieldId}\n                maxTagTextLength={maxTagTextLength}\n                clearIcon={clearIcon} // иконка очищения всего инпута\n                removeIcon={isEmpty(value) ? null : clearIcon} // иконка очищения итема\n                onChange={handleChange}\n                onSelect={handleSelect}\n                onSearch={handleSearch}\n                onTreeExpand={onTreeExpand}\n                showCheckedStrategy={getCheckedStrategy(showCheckedStrategy)}\n                getPopupContainer={getPopupContainer}\n                notFoundContent={loading ? <InlineSpinner /> : notFoundContent}\n                placeholder={searchValue ? null : placeholder}\n                disabled={disabled}\n                searchValue={searchValue}\n                showSearch={!multiSelect}\n                listHeight={400}\n                prefixCls=\"n2o-select-tree\"\n            >\n                {children}\n            </TreeSelect>\n        </div>\n    )\n}\n\nInputSelectTree.defaultProps = {\n    children: null,\n    hasChildrenFieldId: 'hasChildren',\n    disabled: false,\n    loading: false,\n    parentFieldId: 'parentId',\n    valueFieldId: 'id',\n    labelFieldId: 'name',\n    iconFieldId: 'icon',\n    badge: {\n        fieldId: 'badge',\n        colorFieldId: 'color',\n    },\n    imageFieldId: 'image',\n    sortFieldId: 'name',\n    filter: 'startsWith',\n    hasCheckboxes: false,\n    multiSelect: false,\n    options: [],\n    transitionName: 'slide-up',\n    choiceTransitionName: 'zoom',\n    showCheckedStrategy: 'all',\n    allowClear: true,\n    placeholder: '',\n    showSearch: true,\n    maxTagTextLength: 10,\n    onSearch: () => {},\n    onSelect: () => {},\n    onChange: () => {},\n    onClose: () => {},\n    onToggle: () => {},\n    onFocus: () => {},\n    onBlur: () => {},\n    onInput: () => {},\n    t: () => {},\n} as Props\n\ntype Props = {\n    /**\n     * Флаг динамичексой подгрузки данных. В данных обязательно указывать параметр hasChildrens\n     */\n    ajax?: boolean,\n    /**\n     * Данные для badge\n     */\n    badge: object,\n    children: ReactNode,\n    className?: string,\n    /**\n     * Флаг неактивности\n     */\n    disabled: boolean,\n    /**\n     * Callback на открытие\n     */\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    fetchData?: any,\n    /**\n     * Варианты фильтрации\n     */\n    filter: Filter,\n    /**\n     * Флаг для показа чекбоксов в элементах дерева. Переводит InputSelectTree в мульти режим\n     */\n    hasCheckboxes: boolean,\n    /**\n     * Значение ключа hasChildren в данных\n     */\n    hasChildrenFieldId: string,\n    /**\n     * Значение ключа icon в данных\n     */\n    iconFieldId: string,\n    /**\n     *  Значение ключа image в данных\n     */\n    imageFieldId: string,\n    /**\n     * Значение ключа label в данных\n     */\n    labelFieldId: string,\n    /**\n     * Флаг анимации загрузки\n     */\n    loading: boolean,\n    /**\n     * Количество символов выбранных элементов в chechbox режиме\n     */\n    maxTagTextLength: number,\n    /**\n     * Мульти выбор значений\n     */\n    multiSelect: boolean,\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    notFoundContent?: any,\n    onBlur(arg?: Props['value']): void,\n    /**\n     * Calback изменения\n     */\n    onChange(arg: Props['value']): void,\n    /**\n     * Callback на закрытие\n     */\n    onClose(): void,\n    onFocus(): void,\n    /**\n     * Callback на поиск\n     */\n    onSearch(arg: Props['value']): void,\n    onSelect(arg: Props['value']): void,\n    onToggle(arg: boolean): void,\n    /**\n     * Данные для построения дерева\n     */\n    options: TOption[],\n    /**\n     * Значение ключа parent в данных\n     */\n    parentFieldId: string,\n    /**\n     * Placeholder контрола\n     */\n    placeholder: string,\n    showCheckedStrategy: string,\n    t(arg: string): void,\n    /**\n     * Значение\n     */\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    value?: any,\n    /**\n     * Значение ключа value в данных\n     */\n    valueFieldId: string\n}\n\nexport { TreeNode, InputSelectTree }\n\nconst clickOutsideConfig = {\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    handleClickOutside: () => (InputSelectTree as any).handleClickOutside,\n}\n\nexport const InputSelectTreeComponent = (\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    onClickOutsideHOC(withTranslation()(InputSelectTree as any), clickOutsideConfig) as any\n)\n"]}
|