@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.
Files changed (241) hide show
  1. package/index.js +0 -0
  2. package/lib/display/Alerts/Alert.d.ts +2 -0
  3. package/lib/display/Alerts/Alert.js +121 -0
  4. package/lib/display/Alerts/AlertSection.d.ts +18 -0
  5. package/lib/display/Alerts/AlertSection.js +64 -0
  6. package/lib/display/Alerts/AlertWrapper.d.ts +6 -0
  7. package/lib/display/Alerts/AlertWrapper.js +39 -0
  8. package/lib/display/Alerts/DefaultAlert.d.ts +6 -0
  9. package/lib/display/Alerts/DefaultAlert.js +125 -0
  10. package/lib/display/Alerts/LoaderAlert.d.ts +5 -0
  11. package/lib/display/Alerts/LoaderAlert.js +36 -0
  12. package/lib/display/Alerts/types.d.ts +49 -0
  13. package/lib/display/Alerts/types.js +24 -0
  14. package/lib/display/Alerts/utils.d.ts +15 -0
  15. package/lib/display/Alerts/utils.js +102 -0
  16. package/lib/display/Badge/Badge.d.ts +16 -0
  17. package/lib/display/Badge/Badge.js +77 -0
  18. package/lib/display/Badge/enums.d.ts +9 -0
  19. package/lib/display/Badge/enums.js +23 -0
  20. package/lib/display/Badge/utils.d.ts +9 -0
  21. package/lib/display/Badge/utils.js +49 -0
  22. package/lib/display/Block.d.ts +369 -0
  23. package/lib/display/Block.js +38 -0
  24. package/lib/display/CodeViewer/CodeViewer.d.ts +13 -0
  25. package/lib/display/CodeViewer/CodeViewer.js +96 -0
  26. package/lib/display/Drawer/Drawer.d.ts +25 -0
  27. package/lib/display/Drawer/Drawer.js +99 -0
  28. package/lib/display/DropdownCustomItem.d.ts +7 -0
  29. package/lib/display/DropdownCustomItem.js +23 -0
  30. package/lib/display/Filter/Buttons.d.ts +11 -0
  31. package/lib/display/Filter/Buttons.js +42 -0
  32. package/lib/display/Filter/Filter.d.ts +8 -0
  33. package/lib/display/Filter/Filter.js +38 -0
  34. package/lib/display/HelpPopover.d.ts +16 -0
  35. package/lib/display/HelpPopover.js +104 -0
  36. package/lib/display/Html.d.ts +8 -0
  37. package/lib/display/Html.js +29 -0
  38. package/lib/display/Icon/Icon.d.ts +11 -0
  39. package/lib/display/Icon/Icon.js +42 -0
  40. package/lib/display/Image/Image.d.ts +30 -0
  41. package/lib/display/Image/Image.js +93 -0
  42. package/lib/display/Image/ImageInfo.d.ts +7 -0
  43. package/lib/display/Image/ImageInfo.js +23 -0
  44. package/lib/display/InputIcon.d.ts +13 -0
  45. package/lib/display/InputIcon.js +33 -0
  46. package/lib/display/NavItemImage/NavItemImage.d.ts +9 -0
  47. package/lib/display/NavItemImage/NavItemImage.js +35 -0
  48. package/lib/display/OutputList.d.ts +12 -0
  49. package/lib/display/OutputList.js +46 -0
  50. package/lib/display/OutputListItem.d.ts +10 -0
  51. package/lib/display/OutputListItem.js +58 -0
  52. package/lib/display/OutputText.d.ts +15 -0
  53. package/lib/display/OutputText.js +170 -0
  54. package/lib/display/Pagination/Pagination.d.ts +2 -0
  55. package/lib/display/Pagination/Pagination.js +273 -0
  56. package/lib/display/Pagination/PaginationButton.d.ts +13 -0
  57. package/lib/display/Pagination/PaginationButton.js +53 -0
  58. package/lib/display/Pagination/types.d.ts +62 -0
  59. package/lib/display/Pagination/types.js +36 -0
  60. package/lib/display/PopoverConfirm/PopoverConfirm.d.ts +30 -0
  61. package/lib/display/PopoverConfirm/PopoverConfirm.js +87 -0
  62. package/lib/display/ProgressControl/ProgressControl.d.ts +17 -0
  63. package/lib/display/ProgressControl/ProgressControl.js +68 -0
  64. package/lib/display/Slider.d.ts +23 -0
  65. package/lib/display/Slider.js +107 -0
  66. package/lib/display/Status.d.ts +9 -0
  67. package/lib/display/Status.js +40 -0
  68. package/lib/display/StatusText/StatusText.d.ts +10 -0
  69. package/lib/display/StatusText/StatusText.js +35 -0
  70. package/lib/display/StatusText/types.d.ts +18 -0
  71. package/lib/display/StatusText/types.js +19 -0
  72. package/lib/display/StatusText/utils.d.ts +3 -0
  73. package/lib/display/StatusText/utils.js +29 -0
  74. package/lib/display/Text.d.ts +12 -0
  75. package/lib/display/Text.js +38 -0
  76. package/lib/display/Typography/Base.d.ts +32 -0
  77. package/lib/display/Typography/Base.js +259 -0
  78. package/lib/display/Typography/ContentEditable.d.ts +15 -0
  79. package/lib/display/Typography/ContentEditable.js +86 -0
  80. package/lib/display/Typography/Paragraph.d.ts +4 -0
  81. package/lib/display/Typography/Paragraph.js +23 -0
  82. package/lib/display/Typography/Text.d.ts +9 -0
  83. package/lib/display/Typography/Text.js +37 -0
  84. package/lib/display/Typography/Title.d.ts +7 -0
  85. package/lib/display/Typography/Title.js +28 -0
  86. package/lib/display/Typography/utils.d.ts +13 -0
  87. package/lib/display/Typography/utils.js +75 -0
  88. package/lib/helpers/HelpPopover.d.ts +9 -0
  89. package/lib/helpers/HelpPopover.js +46 -0
  90. package/lib/helpers/withRightPlaceholder.d.ts +9 -0
  91. package/lib/helpers/withRightPlaceholder.js +35 -0
  92. package/lib/inputs/Checkbox/Checkbox.d.ts +29 -0
  93. package/lib/inputs/Checkbox/Checkbox.js +117 -0
  94. package/lib/inputs/Checkbox/CheckboxControl.d.ts +7 -0
  95. package/lib/inputs/Checkbox/CheckboxControl.js +33 -0
  96. package/lib/inputs/CheckboxGroup/CheckboxGroup.d.ts +11 -0
  97. package/lib/inputs/CheckboxGroup/CheckboxGroup.js +84 -0
  98. package/lib/inputs/CodeEditor/CodeEditor.d.ts +21 -0
  99. package/lib/inputs/CodeEditor/CodeEditor.js +85 -0
  100. package/lib/inputs/DatePicker/Calendar.d.ts +65 -0
  101. package/lib/inputs/DatePicker/Calendar.js +556 -0
  102. package/lib/inputs/DatePicker/CalendarHeader.d.ts +26 -0
  103. package/lib/inputs/DatePicker/CalendarHeader.js +213 -0
  104. package/lib/inputs/DatePicker/Clock.d.ts +10 -0
  105. package/lib/inputs/DatePicker/Clock.js +45 -0
  106. package/lib/inputs/DatePicker/DateInput.d.ts +44 -0
  107. package/lib/inputs/DatePicker/DateInput.js +262 -0
  108. package/lib/inputs/DatePicker/DateInputGroup.d.ts +20 -0
  109. package/lib/inputs/DatePicker/DateInputGroup.js +77 -0
  110. package/lib/inputs/DatePicker/DateInterval.d.ts +24 -0
  111. package/lib/inputs/DatePicker/DateInterval.js +92 -0
  112. package/lib/inputs/DatePicker/DatePicker.d.ts +22 -0
  113. package/lib/inputs/DatePicker/DatePicker.js +36 -0
  114. package/lib/inputs/DatePicker/DateTimeControl.d.ts +98 -0
  115. package/lib/inputs/DatePicker/DateTimeControl.js +452 -0
  116. package/lib/inputs/DatePicker/Day.d.ts +14 -0
  117. package/lib/inputs/DatePicker/Day.js +50 -0
  118. package/lib/inputs/DatePicker/PopUp.d.ts +19 -0
  119. package/lib/inputs/DatePicker/PopUp.js +71 -0
  120. package/lib/inputs/DatePicker/types.d.ts +31 -0
  121. package/lib/inputs/DatePicker/types.js +25 -0
  122. package/lib/inputs/DatePicker/utils.d.ts +39 -0
  123. package/lib/inputs/DatePicker/utils.js +304 -0
  124. package/lib/inputs/Input.d.ts +51 -0
  125. package/lib/inputs/Input.js +200 -0
  126. package/lib/inputs/InputMask/InputMask.d.ts +23 -0
  127. package/lib/inputs/InputMask/InputMask.js +310 -0
  128. package/lib/inputs/InputMoney/InputMoney.d.ts +101 -0
  129. package/lib/inputs/InputMoney/InputMoney.js +258 -0
  130. package/lib/inputs/InputNumber/InputNumber.d.ts +29 -0
  131. package/lib/inputs/InputNumber/InputNumber.js +316 -0
  132. package/lib/inputs/InputNumber/index.d.ts +1 -0
  133. package/lib/inputs/InputNumber/index.js +14 -0
  134. package/lib/inputs/InputNumber/types.d.ts +18 -0
  135. package/lib/inputs/InputNumber/types.js +14 -0
  136. package/lib/inputs/InputNumber/utils.d.ts +6 -0
  137. package/lib/inputs/InputNumber/utils.js +86 -0
  138. package/lib/inputs/InputPassword/InputPassword.d.ts +10 -0
  139. package/lib/inputs/InputPassword/InputPassword.js +81 -0
  140. package/lib/inputs/InputSelect/InputAddon.d.ts +17 -0
  141. package/lib/inputs/InputSelect/InputAddon.js +31 -0
  142. package/lib/inputs/InputSelect/InputContent.d.ts +63 -0
  143. package/lib/inputs/InputSelect/InputContent.js +188 -0
  144. package/lib/inputs/InputSelect/InputSelect.d.ts +296 -0
  145. package/lib/inputs/InputSelect/InputSelect.js +795 -0
  146. package/lib/inputs/InputSelect/InputSelectGroup.d.ts +43 -0
  147. package/lib/inputs/InputSelect/InputSelectGroup.js +113 -0
  148. package/lib/inputs/InputSelect/PopupItems.d.ts +55 -0
  149. package/lib/inputs/InputSelect/PopupItems.js +357 -0
  150. package/lib/inputs/InputSelect/PopupList.d.ts +82 -0
  151. package/lib/inputs/InputSelect/PopupList.js +138 -0
  152. package/lib/inputs/InputSelect/SelectedItems.d.ts +17 -0
  153. package/lib/inputs/InputSelect/SelectedItems.js +125 -0
  154. package/lib/inputs/InputSelect/constants.d.ts +4 -0
  155. package/lib/inputs/InputSelect/constants.js +15 -0
  156. package/lib/inputs/InputSelect/types.d.ts +16 -0
  157. package/lib/inputs/InputSelect/types.js +16 -0
  158. package/lib/inputs/InputSelect/utils.d.ts +9 -0
  159. package/lib/inputs/InputSelect/utils.js +142 -0
  160. package/lib/inputs/InputSelectTree/InputSelectTree.d.ts +114 -0
  161. package/lib/inputs/InputSelectTree/InputSelectTree.js +466 -0
  162. package/lib/inputs/InputSelectTree/TreeSelectNode.d.ts +36 -0
  163. package/lib/inputs/InputSelectTree/TreeSelectNode.js +63 -0
  164. package/lib/inputs/InputSelectTree/allProps.d.ts +123 -0
  165. package/lib/inputs/InputSelectTree/allProps.js +48 -0
  166. package/lib/inputs/InputSelectTree/until.d.ts +4 -0
  167. package/lib/inputs/InputSelectTree/until.js +83 -0
  168. package/lib/inputs/InputText.d.ts +41 -0
  169. package/lib/inputs/InputText.js +170 -0
  170. package/lib/inputs/NumberPicker/NumberPicker.d.ts +15 -0
  171. package/lib/inputs/NumberPicker/NumberPicker.js +129 -0
  172. package/lib/inputs/NumberPicker/NumberPickerButton.d.ts +8 -0
  173. package/lib/inputs/NumberPicker/NumberPickerButton.js +64 -0
  174. package/lib/inputs/NumberPicker/index.d.ts +1 -0
  175. package/lib/inputs/NumberPicker/index.js +14 -0
  176. package/lib/inputs/NumberPicker/utils.d.ts +2 -0
  177. package/lib/inputs/NumberPicker/utils.js +31 -0
  178. package/lib/inputs/RadioGroup/default/Group.d.ts +15 -0
  179. package/lib/inputs/RadioGroup/default/Group.js +63 -0
  180. package/lib/inputs/RadioGroup/default/Input.d.ts +17 -0
  181. package/lib/inputs/RadioGroup/default/Input.js +77 -0
  182. package/lib/inputs/RadioGroup/tabs/Group.d.ts +3 -0
  183. package/lib/inputs/RadioGroup/tabs/Group.js +24 -0
  184. package/lib/inputs/RadioGroup/tabs/Input.d.ts +3 -0
  185. package/lib/inputs/RadioGroup/tabs/Input.js +21 -0
  186. package/lib/inputs/Rating/Rating.d.ts +30 -0
  187. package/lib/inputs/Rating/Rating.js +212 -0
  188. package/lib/inputs/Select/Popup.d.ts +31 -0
  189. package/lib/inputs/Select/Popup.js +131 -0
  190. package/lib/inputs/Select/Select.d.ts +225 -0
  191. package/lib/inputs/Select/Select.js +705 -0
  192. package/lib/inputs/Select/SelectInput.d.ts +19 -0
  193. package/lib/inputs/Select/SelectInput.js +85 -0
  194. package/lib/inputs/Select/utils.d.ts +1 -0
  195. package/lib/inputs/Select/utils.js +28 -0
  196. package/lib/inputs/Switch/Switch.d.ts +11 -0
  197. package/lib/inputs/Switch/Switch.js +41 -0
  198. package/lib/inputs/TextArea.d.ts +12 -0
  199. package/lib/inputs/TextArea.js +54 -0
  200. package/lib/inputs/TextEditor/TextEditor.d.ts +11 -0
  201. package/lib/inputs/TextEditor/TextEditor.js +89 -0
  202. package/lib/inputs/TimePicker/TimePicker.d.ts +50 -0
  203. package/lib/inputs/TimePicker/TimePicker.js +398 -0
  204. package/lib/inputs/utils.d.ts +5 -0
  205. package/lib/inputs/utils.js +39 -0
  206. package/lib/layouts/ScrollContainer.d.ts +218 -0
  207. package/lib/layouts/ScrollContainer.js +128 -0
  208. package/lib/layouts/Spinner/CoverSpinner.d.ts +29 -0
  209. package/lib/layouts/Spinner/CoverSpinner.js +153 -0
  210. package/lib/layouts/Spinner/InlineSpinner.d.ts +5 -0
  211. package/lib/layouts/Spinner/InlineSpinner.js +27 -0
  212. package/lib/layouts/Spinner/Spinner.d.ts +31 -0
  213. package/lib/layouts/Spinner/Spinner.js +178 -0
  214. package/lib/styles/components/Calendar.scss +125 -0
  215. package/lib/styles/components/CalendarHeader.scss +75 -0
  216. package/lib/styles/components/DateInputGroup.scss +39 -0
  217. package/lib/styles/components/DatePicker.scss +18 -0
  218. package/lib/styles/components/Day.scss +29 -0
  219. package/lib/styles/components/OutputList.scss +14 -0
  220. package/lib/styles/components/OutputText.scss +50 -0
  221. package/lib/styles/controls/CodeEditor.scss +4 -0
  222. package/lib/styles/controls/InputNumber.scss +36 -0
  223. package/lib/styles/controls/InputPassword.scss +17 -0
  224. package/lib/styles/controls/InputText.scss +59 -0
  225. package/lib/styles/controls/NumberPicker.scss +36 -0
  226. package/lib/styles/controls/ProgressControl.scss +3 -0
  227. package/lib/styles/controls/Slider.scss +32 -0
  228. package/lib/styles/controls/Switch.scss +105 -0
  229. package/lib/styles/controls/TextEditor.scss +23 -0
  230. package/lib/styles/controls/TimePicker.scss +32 -0
  231. package/lib/styles/n2o/variables.scss +328 -0
  232. package/lib/styles/theme/variables.scss +81 -0
  233. package/lib/styles/variables.scss +10 -0
  234. package/lib/types.d.ts +25 -0
  235. package/lib/types.js +6 -0
  236. package/lib/utils/id.d.ts +3 -0
  237. package/lib/utils/id.js +46 -0
  238. package/lib/utils/isEmptyModel.d.ts +1 -0
  239. package/lib/utils/isEmptyModel.js +21 -0
  240. package/lib/utils/parseFormatter.js +153 -0
  241. 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"]}