@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,705 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
|
|
5
|
+
var _typeof3 = require("@babel/runtime/helpers/typeof");
|
|
6
|
+
|
|
7
|
+
Object.defineProperty(exports, "__esModule", {
|
|
8
|
+
value: true
|
|
9
|
+
});
|
|
10
|
+
exports.Select = void 0;
|
|
11
|
+
|
|
12
|
+
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
13
|
+
|
|
14
|
+
var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
|
|
15
|
+
|
|
16
|
+
var _typeof2 = _interopRequireDefault(require("@babel/runtime/helpers/typeof"));
|
|
17
|
+
|
|
18
|
+
var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
|
|
19
|
+
|
|
20
|
+
var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
|
|
21
|
+
|
|
22
|
+
var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
|
|
23
|
+
|
|
24
|
+
var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
|
|
25
|
+
|
|
26
|
+
var _possibleConstructorReturn2 = _interopRequireDefault(require("@babel/runtime/helpers/possibleConstructorReturn"));
|
|
27
|
+
|
|
28
|
+
var _getPrototypeOf2 = _interopRequireDefault(require("@babel/runtime/helpers/getPrototypeOf"));
|
|
29
|
+
|
|
30
|
+
var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
|
|
31
|
+
|
|
32
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
33
|
+
|
|
34
|
+
var _reactOnclickoutside = _interopRequireDefault(require("react-onclickoutside"));
|
|
35
|
+
|
|
36
|
+
var _isEqual = _interopRequireDefault(require("lodash/isEqual"));
|
|
37
|
+
|
|
38
|
+
var _get = _interopRequireDefault(require("lodash/get"));
|
|
39
|
+
|
|
40
|
+
var _first = _interopRequireDefault(require("lodash/first"));
|
|
41
|
+
|
|
42
|
+
var _isEmpty = _interopRequireDefault(require("lodash/isEmpty"));
|
|
43
|
+
|
|
44
|
+
var _find = _interopRequireDefault(require("lodash/find"));
|
|
45
|
+
|
|
46
|
+
var _reactstrap = require("reactstrap");
|
|
47
|
+
|
|
48
|
+
var _InputSelectGroup = require("../InputSelect/InputSelectGroup");
|
|
49
|
+
|
|
50
|
+
var _PopupList = require("../InputSelect/PopupList");
|
|
51
|
+
|
|
52
|
+
var _utils = require("./utils");
|
|
53
|
+
|
|
54
|
+
var _Popup = require("./Popup");
|
|
55
|
+
|
|
56
|
+
var _SelectInput = require("./SelectInput");
|
|
57
|
+
|
|
58
|
+
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); }
|
|
59
|
+
|
|
60
|
+
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || _typeof3(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; }
|
|
61
|
+
|
|
62
|
+
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; }
|
|
63
|
+
|
|
64
|
+
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; }
|
|
65
|
+
|
|
66
|
+
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = (0, _getPrototypeOf2["default"])(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = (0, _getPrototypeOf2["default"])(this).constructor; result = Reflect.construct(Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return (0, _possibleConstructorReturn2["default"])(this, result); }; }
|
|
67
|
+
|
|
68
|
+
function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !Reflect.construct) return false; if (Reflect.construct.sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(Reflect.construct(Boolean, [], function () {})); return true; } catch (e) { return false; } }
|
|
69
|
+
|
|
70
|
+
/**
|
|
71
|
+
* N2OSelect
|
|
72
|
+
* @reactProps {boolean} loading - флаг анимации загрузки
|
|
73
|
+
* @reactProps {array} options - данные
|
|
74
|
+
* @reactProps {string} valueFieldId - значение ключа value в данных
|
|
75
|
+
* @reactProps {string} labelFieldId - значение ключа label в данных
|
|
76
|
+
* @reactProps {string} iconFieldId - поле для иконки
|
|
77
|
+
* @reactProps {string} imageFieldId - поле для картинки
|
|
78
|
+
* @reactProps {string} statusFieldId - поле для статуса
|
|
79
|
+
* @reactProps {object} badge - данные для баджа
|
|
80
|
+
* @reactProps {boolean} disabled - флаг неактивности
|
|
81
|
+
* @reactProps {array} disabledValues - неактивные данные
|
|
82
|
+
* @reactProps {string} enabledFieldId - поле для активности
|
|
83
|
+
* @reactProps {string} filter - варианты фильтрации
|
|
84
|
+
* @reactProps {string} value - текущее значение
|
|
85
|
+
* @reactProps {function} onInput - callback при вводе в инпут
|
|
86
|
+
* @reactProps {function} onChange - callback при выборе значения или вводе
|
|
87
|
+
* @reactProps {string} placeHolder - подсказка в инпуте
|
|
88
|
+
* @reactProps {boolean} resetOnBlur - фича, при которой сбрасывается значение контрола, если оно не выбрано из popup
|
|
89
|
+
* @reactProps {function} onClose - callback на закрытие попапа
|
|
90
|
+
* @reactProps {string} groupFieldId - поле для группировки
|
|
91
|
+
* @reactProps {boolean} closePopupOnSelect - флаг закрытия попапа при выборе
|
|
92
|
+
* @reactProps {boolean} hasCheckboxes - флаг наличия чекбоксов
|
|
93
|
+
* @reactProps {string} format - формат
|
|
94
|
+
* @reactProps {boolean} searchByTap - поиск по нажатию кнопки
|
|
95
|
+
*/
|
|
96
|
+
var selectType = {
|
|
97
|
+
SINGLE: 'single',
|
|
98
|
+
CHECKBOXES: 'checkboxes'
|
|
99
|
+
};
|
|
100
|
+
|
|
101
|
+
function getSelected(value) {
|
|
102
|
+
if (Array.isArray(value)) {
|
|
103
|
+
return value;
|
|
104
|
+
}
|
|
105
|
+
|
|
106
|
+
if (!(0, _isEmpty["default"])(value)) {
|
|
107
|
+
return [value];
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
return [];
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
var SelectComponent = /*#__PURE__*/function (_React$Component) {
|
|
114
|
+
(0, _inherits2["default"])(SelectComponent, _React$Component);
|
|
115
|
+
|
|
116
|
+
var _super = _createSuper(SelectComponent);
|
|
117
|
+
|
|
118
|
+
function SelectComponent(props) {
|
|
119
|
+
var _this;
|
|
120
|
+
|
|
121
|
+
(0, _classCallCheck2["default"])(this, SelectComponent);
|
|
122
|
+
_this = _super.call(this, props);
|
|
123
|
+
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "control", null);
|
|
124
|
+
(0, _defineProperty2["default"])((0, _assertThisInitialized2["default"])(_this), "handleDataSearch", function (input, delay, callback) {
|
|
125
|
+
var _this$props = _this.props,
|
|
126
|
+
onSearch = _this$props.onSearch,
|
|
127
|
+
filter = _this$props.filter,
|
|
128
|
+
options = _this$props.options,
|
|
129
|
+
labelFieldId = _this$props.labelFieldId;
|
|
130
|
+
|
|
131
|
+
if (filter) {
|
|
132
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
133
|
+
var filterFunc = function filterFunc(item) {
|
|
134
|
+
return String.prototype[filter].call(item, input);
|
|
135
|
+
};
|
|
136
|
+
|
|
137
|
+
var filteredOptions = options.filter(function (item) {
|
|
138
|
+
return filterFunc(item[labelFieldId].toString());
|
|
139
|
+
});
|
|
140
|
+
|
|
141
|
+
_this.setState({
|
|
142
|
+
options: filteredOptions
|
|
143
|
+
});
|
|
144
|
+
} else {
|
|
145
|
+
onSearch(input, delay === false ? delay : true, callback);
|
|
146
|
+
}
|
|
147
|
+
});
|
|
148
|
+
var _this$props2 = _this.props,
|
|
149
|
+
value = _this$props2.value,
|
|
150
|
+
_options = _this$props2.options,
|
|
151
|
+
type = _this$props2.type;
|
|
152
|
+
_this.state = {
|
|
153
|
+
value: '',
|
|
154
|
+
isExpanded: false,
|
|
155
|
+
options: _options,
|
|
156
|
+
selected: getSelected(value),
|
|
157
|
+
hasCheckboxes: type === selectType.CHECKBOXES
|
|
158
|
+
};
|
|
159
|
+
_this.control = null;
|
|
160
|
+
_this.n2oSelectRef = /*#__PURE__*/(0, _react.createRef)();
|
|
161
|
+
_this.handleButtonClick = _this.handleButtonClick.bind((0, _assertThisInitialized2["default"])(_this));
|
|
162
|
+
_this.handleInputChange = _this.handleInputChange.bind((0, _assertThisInitialized2["default"])(_this));
|
|
163
|
+
_this.handleInputFocus = _this.handleInputFocus.bind((0, _assertThisInitialized2["default"])(_this));
|
|
164
|
+
_this.hideOptionsList = _this.hideOptionsList.bind((0, _assertThisInitialized2["default"])(_this));
|
|
165
|
+
_this.handleItemSelect = _this.handleItemSelect.bind((0, _assertThisInitialized2["default"])(_this));
|
|
166
|
+
_this.removeSelectedItem = _this.removeSelectedItem.bind((0, _assertThisInitialized2["default"])(_this));
|
|
167
|
+
_this.clearSelected = _this.clearSelected.bind((0, _assertThisInitialized2["default"])(_this));
|
|
168
|
+
_this.handleSearchButton = _this.handleSearchButton.bind((0, _assertThisInitialized2["default"])(_this));
|
|
169
|
+
_this.handleOnBlur = _this.handleOnBlur.bind((0, _assertThisInitialized2["default"])(_this));
|
|
170
|
+
_this.setControlRef = _this.setControlRef.bind((0, _assertThisInitialized2["default"])(_this));
|
|
171
|
+
return _this;
|
|
172
|
+
}
|
|
173
|
+
|
|
174
|
+
(0, _createClass2["default"])(SelectComponent, [{
|
|
175
|
+
key: "componentDidMount",
|
|
176
|
+
value: function componentDidMount() {
|
|
177
|
+
var _this$props3 = this.props,
|
|
178
|
+
initial = _this$props3.initial,
|
|
179
|
+
options = _this$props3.options,
|
|
180
|
+
valueFieldId = _this$props3.valueFieldId;
|
|
181
|
+
|
|
182
|
+
if (Array.isArray(initial)) {
|
|
183
|
+
this.setStateFromInitial(initial, options, valueFieldId);
|
|
184
|
+
}
|
|
185
|
+
} // eslint-disable-next-line react/no-deprecated
|
|
186
|
+
|
|
187
|
+
}, {
|
|
188
|
+
key: "componentWillReceiveProps",
|
|
189
|
+
value: function componentWillReceiveProps(nextProps) {
|
|
190
|
+
var options = this.props.options;
|
|
191
|
+
var state = {};
|
|
192
|
+
|
|
193
|
+
if (!(0, _isEqual["default"])(options, nextProps.options)) {
|
|
194
|
+
state.options = nextProps.options;
|
|
195
|
+
}
|
|
196
|
+
|
|
197
|
+
this.setState(state);
|
|
198
|
+
}
|
|
199
|
+
}, {
|
|
200
|
+
key: "componentDidUpdate",
|
|
201
|
+
value: function componentDidUpdate(prevProps) {
|
|
202
|
+
var _this$props4 = this.props,
|
|
203
|
+
initial = _this$props4.initial,
|
|
204
|
+
options = _this$props4.options,
|
|
205
|
+
valueFieldId = _this$props4.valueFieldId,
|
|
206
|
+
value = _this$props4.value;
|
|
207
|
+
|
|
208
|
+
if (Array.isArray(initial) && !(0, _isEqual["default"])(initial, prevProps.initial)) {
|
|
209
|
+
this.setStateFromInitial(initial, options, valueFieldId);
|
|
210
|
+
return;
|
|
211
|
+
}
|
|
212
|
+
|
|
213
|
+
if (!(0, _isEqual["default"])(value, prevProps.value)) {
|
|
214
|
+
this.setState({
|
|
215
|
+
selected: getSelected(value)
|
|
216
|
+
});
|
|
217
|
+
}
|
|
218
|
+
}
|
|
219
|
+
/**
|
|
220
|
+
* Хак для мапинга айдишников, которые берутся из адресной строки в виде строк, но ожидается число
|
|
221
|
+
* TODO удалить после того, как починится поведение парсинга адресной строки будет опираться на указанные типы
|
|
222
|
+
* @param {Array.<object>} [initial]
|
|
223
|
+
* @param options
|
|
224
|
+
* @param {String} valueFieldId
|
|
225
|
+
* @private
|
|
226
|
+
*/
|
|
227
|
+
|
|
228
|
+
}, {
|
|
229
|
+
key: "setStateFromInitial",
|
|
230
|
+
value: function setStateFromInitial(initial, options, valueFieldId) {
|
|
231
|
+
var mapOptions = function mapOptions(options) {
|
|
232
|
+
var type = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'string';
|
|
233
|
+
return options.map(function (option) {
|
|
234
|
+
return _objectSpread(_objectSpread({}, option), (0, _defineProperty2["default"])({}, valueFieldId, type === 'number' ? Number(option[valueFieldId]) : String(option[valueFieldId])));
|
|
235
|
+
});
|
|
236
|
+
};
|
|
237
|
+
|
|
238
|
+
if ((0, _isEmpty["default"])(options)) {
|
|
239
|
+
this.setState({
|
|
240
|
+
selected: mapOptions(initial)
|
|
241
|
+
});
|
|
242
|
+
} else {
|
|
243
|
+
var selected = options.filter(function (option) {
|
|
244
|
+
var idType = (0, _typeof2["default"])(option[valueFieldId]);
|
|
245
|
+
return (0, _find["default"])(mapOptions(initial, idType), option);
|
|
246
|
+
});
|
|
247
|
+
this.setState({
|
|
248
|
+
selected: selected
|
|
249
|
+
});
|
|
250
|
+
}
|
|
251
|
+
}
|
|
252
|
+
/**
|
|
253
|
+
* Удаляет элемент из списка выбранных
|
|
254
|
+
* @param item - элемент
|
|
255
|
+
* @private
|
|
256
|
+
*/
|
|
257
|
+
|
|
258
|
+
}, {
|
|
259
|
+
key: "removeSelectedItem",
|
|
260
|
+
value: function removeSelectedItem(item) {
|
|
261
|
+
var _this$props5 = this.props,
|
|
262
|
+
valueFieldId = _this$props5.valueFieldId,
|
|
263
|
+
onChange = _this$props5.onChange;
|
|
264
|
+
var stateSelected = this.state.selected;
|
|
265
|
+
var selected = typeof stateSelected !== 'string' ? stateSelected.filter(function (i) {
|
|
266
|
+
return i[valueFieldId] !== item[valueFieldId];
|
|
267
|
+
}) : stateSelected;
|
|
268
|
+
this.setState({
|
|
269
|
+
selected: selected
|
|
270
|
+
});
|
|
271
|
+
|
|
272
|
+
if (onChange) {
|
|
273
|
+
onChange(selected);
|
|
274
|
+
}
|
|
275
|
+
}
|
|
276
|
+
/**
|
|
277
|
+
* Изменение видимости попапа
|
|
278
|
+
* @param newIsExpanded - новое значение видимости
|
|
279
|
+
* @private
|
|
280
|
+
*/
|
|
281
|
+
|
|
282
|
+
}, {
|
|
283
|
+
key: "changePopUpVision",
|
|
284
|
+
value: function changePopUpVision(newIsExpanded) {
|
|
285
|
+
var _this$props6 = this.props,
|
|
286
|
+
fetchData = _this$props6.fetchData,
|
|
287
|
+
onClose = _this$props6.onClose;
|
|
288
|
+
var isExpanded = this.state.isExpanded;
|
|
289
|
+
|
|
290
|
+
if (isExpanded === newIsExpanded) {
|
|
291
|
+
return;
|
|
292
|
+
}
|
|
293
|
+
|
|
294
|
+
var onOpen = fetchData({
|
|
295
|
+
page: 1
|
|
296
|
+
});
|
|
297
|
+
this.setState({
|
|
298
|
+
isExpanded: newIsExpanded
|
|
299
|
+
}, newIsExpanded ? onOpen : onClose);
|
|
300
|
+
}
|
|
301
|
+
/**
|
|
302
|
+
* Обрабатывает нажатие на кнопку
|
|
303
|
+
* @private
|
|
304
|
+
*/
|
|
305
|
+
|
|
306
|
+
}, {
|
|
307
|
+
key: "handleButtonClick",
|
|
308
|
+
value: function handleButtonClick() {
|
|
309
|
+
var disabled = this.props.disabled;
|
|
310
|
+
var isExpanded = this.state.isExpanded;
|
|
311
|
+
|
|
312
|
+
if (!disabled) {
|
|
313
|
+
this.changePopUpVision(!isExpanded);
|
|
314
|
+
}
|
|
315
|
+
}
|
|
316
|
+
/**
|
|
317
|
+
* Обрабатывает форкус на инпуте
|
|
318
|
+
* @private
|
|
319
|
+
*/
|
|
320
|
+
|
|
321
|
+
}, {
|
|
322
|
+
key: "handleInputFocus",
|
|
323
|
+
value: function handleInputFocus() {
|
|
324
|
+
this.changePopUpVision(true);
|
|
325
|
+
}
|
|
326
|
+
/**
|
|
327
|
+
* Скрывает popUp
|
|
328
|
+
* @private
|
|
329
|
+
*/
|
|
330
|
+
|
|
331
|
+
}, {
|
|
332
|
+
key: "hideOptionsList",
|
|
333
|
+
value: function hideOptionsList() {
|
|
334
|
+
this.changePopUpVision(false);
|
|
335
|
+
}
|
|
336
|
+
/**
|
|
337
|
+
* Уставнавливает новое значение инпута
|
|
338
|
+
* @param newValue - новое значение
|
|
339
|
+
* @private
|
|
340
|
+
*/
|
|
341
|
+
|
|
342
|
+
}, {
|
|
343
|
+
key: "setNewValue",
|
|
344
|
+
value: function setNewValue(newValue) {
|
|
345
|
+
this.setState({
|
|
346
|
+
value: newValue
|
|
347
|
+
});
|
|
348
|
+
}
|
|
349
|
+
/**
|
|
350
|
+
* Удаляет выбранные элементы
|
|
351
|
+
* @private
|
|
352
|
+
*/
|
|
353
|
+
|
|
354
|
+
}, {
|
|
355
|
+
key: "clearSelected",
|
|
356
|
+
value: function clearSelected(e) {
|
|
357
|
+
e.stopPropagation();
|
|
358
|
+
e.preventDefault();
|
|
359
|
+
var _this$props7 = this.props,
|
|
360
|
+
disabled = _this$props7.disabled,
|
|
361
|
+
onChange = _this$props7.onChange,
|
|
362
|
+
onBlur = _this$props7.onBlur;
|
|
363
|
+
|
|
364
|
+
if (disabled) {
|
|
365
|
+
return;
|
|
366
|
+
}
|
|
367
|
+
|
|
368
|
+
this.setState({
|
|
369
|
+
selected: []
|
|
370
|
+
});
|
|
371
|
+
onChange(null);
|
|
372
|
+
onBlur(null);
|
|
373
|
+
}
|
|
374
|
+
/**
|
|
375
|
+
* Выполняет поиск элементов для popUp, если установлен фильтр
|
|
376
|
+
* @param input - значение для поиска
|
|
377
|
+
* @param {boolean} delay
|
|
378
|
+
* @param {Function} callback
|
|
379
|
+
* @private
|
|
380
|
+
*/
|
|
381
|
+
|
|
382
|
+
}, {
|
|
383
|
+
key: "insertSelected",
|
|
384
|
+
value:
|
|
385
|
+
/**
|
|
386
|
+
* Устанавливает выбранный элемент
|
|
387
|
+
* @param item - элемент массива options
|
|
388
|
+
* @private
|
|
389
|
+
*/
|
|
390
|
+
function insertSelected(item) {
|
|
391
|
+
var _this$props8 = this.props,
|
|
392
|
+
onChange = _this$props8.onChange,
|
|
393
|
+
onBlur = _this$props8.onBlur;
|
|
394
|
+
var _this$state = this.state,
|
|
395
|
+
stateSelected = _this$state.selected,
|
|
396
|
+
hasCheckboxes = _this$state.hasCheckboxes;
|
|
397
|
+
var selected = [item];
|
|
398
|
+
var value = item;
|
|
399
|
+
|
|
400
|
+
if (hasCheckboxes) {
|
|
401
|
+
selected = [].concat((0, _toConsumableArray2["default"])(stateSelected || []), [item]);
|
|
402
|
+
value = selected;
|
|
403
|
+
}
|
|
404
|
+
|
|
405
|
+
this.setState({
|
|
406
|
+
selected: selected
|
|
407
|
+
});
|
|
408
|
+
|
|
409
|
+
if (onChange) {
|
|
410
|
+
onChange(value);
|
|
411
|
+
onBlur(value);
|
|
412
|
+
}
|
|
413
|
+
}
|
|
414
|
+
/**
|
|
415
|
+
* Обрабатывает изменение инпута
|
|
416
|
+
* @param newValue - новое значение
|
|
417
|
+
* @private
|
|
418
|
+
*/
|
|
419
|
+
|
|
420
|
+
}, {
|
|
421
|
+
key: "handleInputChange",
|
|
422
|
+
value: function handleInputChange(newValue) {
|
|
423
|
+
var _this$props9 = this.props,
|
|
424
|
+
searchByTap = _this$props9.searchByTap,
|
|
425
|
+
onChange = _this$props9.onChange,
|
|
426
|
+
onInput = _this$props9.onInput,
|
|
427
|
+
resetOnBlur = _this$props9.resetOnBlur;
|
|
428
|
+
this.setNewValue(newValue);
|
|
429
|
+
|
|
430
|
+
if (!searchByTap) {
|
|
431
|
+
this.handleDataSearch(newValue);
|
|
432
|
+
}
|
|
433
|
+
|
|
434
|
+
if (!resetOnBlur) {
|
|
435
|
+
onChange(newValue);
|
|
436
|
+
}
|
|
437
|
+
|
|
438
|
+
onInput(newValue);
|
|
439
|
+
}
|
|
440
|
+
/**
|
|
441
|
+
* Обрабатывает поиск по нажатию
|
|
442
|
+
* @private
|
|
443
|
+
*/
|
|
444
|
+
|
|
445
|
+
}, {
|
|
446
|
+
key: "handleSearchButton",
|
|
447
|
+
value: function handleSearchButton() {
|
|
448
|
+
var value = this.state.value;
|
|
449
|
+
this.handleDataSearch(value);
|
|
450
|
+
}
|
|
451
|
+
/**
|
|
452
|
+
* Очищает инпут и результаты поиска
|
|
453
|
+
* @private
|
|
454
|
+
*/
|
|
455
|
+
|
|
456
|
+
}, {
|
|
457
|
+
key: "clearSearchField",
|
|
458
|
+
value: function clearSearchField() {
|
|
459
|
+
var options = this.props.options;
|
|
460
|
+
this.setState({
|
|
461
|
+
value: '',
|
|
462
|
+
options: options
|
|
463
|
+
});
|
|
464
|
+
}
|
|
465
|
+
/**
|
|
466
|
+
* Обрабатывает выбор элемента из popUp
|
|
467
|
+
* @param item - элемент массива options
|
|
468
|
+
* @private
|
|
469
|
+
*/
|
|
470
|
+
|
|
471
|
+
}, {
|
|
472
|
+
key: "handleItemSelect",
|
|
473
|
+
value: function handleItemSelect(item) {
|
|
474
|
+
var closePopupOnSelect = this.props.closePopupOnSelect;
|
|
475
|
+
this.insertSelected(item);
|
|
476
|
+
|
|
477
|
+
if (closePopupOnSelect) {
|
|
478
|
+
this.hideOptionsList();
|
|
479
|
+
}
|
|
480
|
+
|
|
481
|
+
this.clearSearchField();
|
|
482
|
+
|
|
483
|
+
if (this.control) {
|
|
484
|
+
// eslint-disable-next-line @typescript-eslint/no-explicit-any
|
|
485
|
+
this.control.focus();
|
|
486
|
+
}
|
|
487
|
+
}
|
|
488
|
+
/**
|
|
489
|
+
* Обрабатывает поведение инпута при потери фокуса, если есть resetOnBlur
|
|
490
|
+
* @private
|
|
491
|
+
*/
|
|
492
|
+
|
|
493
|
+
}, {
|
|
494
|
+
key: "handleResetOnBlur",
|
|
495
|
+
value: function handleResetOnBlur() {
|
|
496
|
+
var selected = this.state.selected;
|
|
497
|
+
var _this$props10 = this.props,
|
|
498
|
+
resetOnBlur = _this$props10.resetOnBlur,
|
|
499
|
+
options = _this$props10.options;
|
|
500
|
+
|
|
501
|
+
if (resetOnBlur && !selected) {
|
|
502
|
+
this.setState({
|
|
503
|
+
value: '',
|
|
504
|
+
options: options
|
|
505
|
+
});
|
|
506
|
+
}
|
|
507
|
+
}
|
|
508
|
+
/**
|
|
509
|
+
* Обрабатывает клик за пределы компонента
|
|
510
|
+
* вызывается библиотекой react-onclickoutside
|
|
511
|
+
*/
|
|
512
|
+
|
|
513
|
+
}, {
|
|
514
|
+
key: "handleClickOutside",
|
|
515
|
+
value: function handleClickOutside() {
|
|
516
|
+
var _this$props11 = this.props,
|
|
517
|
+
onBlur = _this$props11.onBlur,
|
|
518
|
+
value = _this$props11.value;
|
|
519
|
+
var isExpanded = this.state.isExpanded;
|
|
520
|
+
|
|
521
|
+
if (isExpanded) {
|
|
522
|
+
this.hideOptionsList();
|
|
523
|
+
onBlur(value);
|
|
524
|
+
}
|
|
525
|
+
}
|
|
526
|
+
}, {
|
|
527
|
+
key: "handleOnBlur",
|
|
528
|
+
value: function handleOnBlur(e) {
|
|
529
|
+
e.preventDefault();
|
|
530
|
+
this.handleResetOnBlur();
|
|
531
|
+
}
|
|
532
|
+
}, {
|
|
533
|
+
key: "setControlRef",
|
|
534
|
+
value: function setControlRef(el) {
|
|
535
|
+
this.control = el;
|
|
536
|
+
}
|
|
537
|
+
}, {
|
|
538
|
+
key: "renderPlaceholder",
|
|
539
|
+
value: function renderPlaceholder() {
|
|
540
|
+
var _this$props12 = this.props,
|
|
541
|
+
_this$props12$selectF = _this$props12.selectFormat,
|
|
542
|
+
selectFormat = _this$props12$selectF === void 0 ? 'Объектов {size} шт' : _this$props12$selectF,
|
|
543
|
+
_this$props12$selectF2 = _this$props12.selectFormatOne,
|
|
544
|
+
selectFormatOne = _this$props12$selectF2 === void 0 ? '' : _this$props12$selectF2,
|
|
545
|
+
_this$props12$selectF3 = _this$props12.selectFormatFew,
|
|
546
|
+
selectFormatFew = _this$props12$selectF3 === void 0 ? '' : _this$props12$selectF3,
|
|
547
|
+
_this$props12$selectF4 = _this$props12.selectFormatMany,
|
|
548
|
+
selectFormatMany = _this$props12$selectF4 === void 0 ? '' : _this$props12$selectF4;
|
|
549
|
+
var _this$state2 = this.state,
|
|
550
|
+
selected = _this$state2.selected,
|
|
551
|
+
hasCheckboxes = _this$state2.hasCheckboxes;
|
|
552
|
+
var selectedCount = selected.length;
|
|
553
|
+
var text;
|
|
554
|
+
|
|
555
|
+
if (!(0, _isEmpty["default"])(selectFormatOne) && !(0, _isEmpty["default"])(selectFormatFew) && !(0, _isEmpty["default"])(selectFormatMany) && selectedCount >= 1 && hasCheckboxes) {
|
|
556
|
+
text = (0, _utils.getNoun)(selectedCount, selectFormatOne, selectFormatFew, selectFormatMany).replace('{size}', "".concat(selectedCount));
|
|
557
|
+
} else if (selectedCount >= 1 && hasCheckboxes) {
|
|
558
|
+
text = selectFormat.replace('{size}', "".concat(selectedCount));
|
|
559
|
+
} else {
|
|
560
|
+
text = null;
|
|
561
|
+
}
|
|
562
|
+
|
|
563
|
+
return text;
|
|
564
|
+
}
|
|
565
|
+
}, {
|
|
566
|
+
key: "renderValue",
|
|
567
|
+
value: function renderValue() {
|
|
568
|
+
var _this$props13 = this.props,
|
|
569
|
+
labelFieldId = _this$props13.labelFieldId,
|
|
570
|
+
_this$props13$placeho = _this$props13.placeholder,
|
|
571
|
+
placeholder = _this$props13$placeho === void 0 ? '' : _this$props13$placeho;
|
|
572
|
+
var selected = this.state.selected;
|
|
573
|
+
|
|
574
|
+
if ((0, _isEmpty["default"])(selected)) {
|
|
575
|
+
return placeholder;
|
|
576
|
+
}
|
|
577
|
+
|
|
578
|
+
var _selected = (0, _slicedToArray2["default"])(selected, 1),
|
|
579
|
+
selectedElement = _selected[0];
|
|
580
|
+
|
|
581
|
+
return (0, _get["default"])(selectedElement, labelFieldId);
|
|
582
|
+
}
|
|
583
|
+
}, {
|
|
584
|
+
key: "render",
|
|
585
|
+
value: function render() {
|
|
586
|
+
var _this$props14 = this.props,
|
|
587
|
+
loading = _this$props14.loading,
|
|
588
|
+
className = _this$props14.className,
|
|
589
|
+
valueFieldId = _this$props14.valueFieldId,
|
|
590
|
+
labelFieldId = _this$props14.labelFieldId,
|
|
591
|
+
iconFieldId = _this$props14.iconFieldId,
|
|
592
|
+
disabled = _this$props14.disabled,
|
|
593
|
+
disabledValues = _this$props14.disabledValues,
|
|
594
|
+
enabledFieldId = _this$props14.enabledFieldId,
|
|
595
|
+
imageFieldId = _this$props14.imageFieldId,
|
|
596
|
+
statusFieldId = _this$props14.statusFieldId,
|
|
597
|
+
groupFieldId = _this$props14.groupFieldId,
|
|
598
|
+
descriptionFieldId = _this$props14.descriptionFieldId,
|
|
599
|
+
format = _this$props14.format,
|
|
600
|
+
placeholder = _this$props14.placeholder,
|
|
601
|
+
badge = _this$props14.badge,
|
|
602
|
+
fetchData = _this$props14.fetchData,
|
|
603
|
+
page = _this$props14.page,
|
|
604
|
+
hasSearch = _this$props14.hasSearch,
|
|
605
|
+
cleanable = _this$props14.cleanable,
|
|
606
|
+
style = _this$props14.style;
|
|
607
|
+
|
|
608
|
+
var inputSelectStyle = _objectSpread({
|
|
609
|
+
width: '100%'
|
|
610
|
+
}, style);
|
|
611
|
+
|
|
612
|
+
var _this$state3 = this.state,
|
|
613
|
+
selected = _this$state3.selected,
|
|
614
|
+
isExpanded = _this$state3.isExpanded,
|
|
615
|
+
hasCheckboxes = _this$state3.hasCheckboxes,
|
|
616
|
+
value = _this$state3.value,
|
|
617
|
+
options = _this$state3.options;
|
|
618
|
+
var title = (0, _get["default"])((0, _first["default"])(selected), "".concat(labelFieldId));
|
|
619
|
+
return /*#__PURE__*/_react["default"].createElement("div", {
|
|
620
|
+
className: "n2o-input-select",
|
|
621
|
+
title: title,
|
|
622
|
+
style: inputSelectStyle,
|
|
623
|
+
onBlur: this.handleOnBlur,
|
|
624
|
+
ref: this.n2oSelectRef
|
|
625
|
+
}, /*#__PURE__*/_react["default"].createElement(_reactstrap.Button, {
|
|
626
|
+
innerRef: this.setControlRef,
|
|
627
|
+
onClick: this.handleButtonClick
|
|
628
|
+
}, /*#__PURE__*/_react["default"].createElement(_InputSelectGroup.InputSelectGroup, {
|
|
629
|
+
className: className,
|
|
630
|
+
isExpanded: isExpanded,
|
|
631
|
+
loading: loading,
|
|
632
|
+
disabled: disabled,
|
|
633
|
+
iconFieldId: iconFieldId,
|
|
634
|
+
imageFieldId: imageFieldId,
|
|
635
|
+
cleanable: cleanable,
|
|
636
|
+
selected: selected,
|
|
637
|
+
onClearClick: this.clearSelected
|
|
638
|
+
}, /*#__PURE__*/_react["default"].createElement("span", {
|
|
639
|
+
className: "valueText"
|
|
640
|
+
}, hasCheckboxes ? this.renderPlaceholder() : this.renderValue()))), /*#__PURE__*/_react["default"].createElement(_Popup.Popup, {
|
|
641
|
+
isExpanded: isExpanded,
|
|
642
|
+
inputSelect: this.n2oSelectRef.current
|
|
643
|
+
}, /*#__PURE__*/_react["default"].createElement(_react["default"].Fragment, null, hasSearch && /*#__PURE__*/_react["default"].createElement(_SelectInput.N2OSelectInput, {
|
|
644
|
+
placeholder: placeholder || '',
|
|
645
|
+
onChange: this.handleInputChange,
|
|
646
|
+
onSearch: this.handleSearchButton,
|
|
647
|
+
value: value
|
|
648
|
+
}), /*#__PURE__*/_react["default"].createElement(_PopupList.PopupList, {
|
|
649
|
+
options: options,
|
|
650
|
+
valueFieldId: valueFieldId,
|
|
651
|
+
labelFieldId: labelFieldId,
|
|
652
|
+
iconFieldId: iconFieldId,
|
|
653
|
+
imageFieldId: imageFieldId,
|
|
654
|
+
statusFieldId: statusFieldId,
|
|
655
|
+
badge: badge,
|
|
656
|
+
descriptionFieldId: descriptionFieldId,
|
|
657
|
+
enabledFieldId: enabledFieldId,
|
|
658
|
+
onSelect: this.handleItemSelect,
|
|
659
|
+
fetchData: fetchData,
|
|
660
|
+
page: page,
|
|
661
|
+
isExpanded: isExpanded,
|
|
662
|
+
selected: selected,
|
|
663
|
+
disabledValues: disabledValues,
|
|
664
|
+
groupFieldId: groupFieldId,
|
|
665
|
+
hasCheckboxes: hasCheckboxes,
|
|
666
|
+
onRemoveItem: this.removeSelectedItem,
|
|
667
|
+
format: format,
|
|
668
|
+
loading: loading
|
|
669
|
+
}))));
|
|
670
|
+
}
|
|
671
|
+
}]);
|
|
672
|
+
return SelectComponent;
|
|
673
|
+
}(_react["default"].Component);
|
|
674
|
+
|
|
675
|
+
(0, _defineProperty2["default"])(SelectComponent, "defaultProps", {
|
|
676
|
+
cleanable: true,
|
|
677
|
+
valueFieldId: 'id',
|
|
678
|
+
labelFieldId: 'name',
|
|
679
|
+
iconFieldId: 'icon',
|
|
680
|
+
loading: false,
|
|
681
|
+
disabled: false,
|
|
682
|
+
disabledValues: [],
|
|
683
|
+
resetOnBlur: false,
|
|
684
|
+
searchByTap: false,
|
|
685
|
+
hasSearch: false,
|
|
686
|
+
options: [],
|
|
687
|
+
value: {},
|
|
688
|
+
descriptionFieldId: '',
|
|
689
|
+
enabledFieldId: '',
|
|
690
|
+
statusFieldId: '',
|
|
691
|
+
groupFieldId: '',
|
|
692
|
+
imageFieldId: '',
|
|
693
|
+
closePopupOnSelect: true,
|
|
694
|
+
onSearch: function onSearch() {},
|
|
695
|
+
onChange: function onChange() {},
|
|
696
|
+
fetchData: function fetchData() {
|
|
697
|
+
return function () {};
|
|
698
|
+
},
|
|
699
|
+
onInput: function onInput() {},
|
|
700
|
+
onClose: function onClose() {},
|
|
701
|
+
onBlur: function onBlur() {}
|
|
702
|
+
});
|
|
703
|
+
var Select = (0, _reactOnclickoutside["default"])(SelectComponent);
|
|
704
|
+
exports.Select = Select;
|
|
705
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/inputs/Select/Select.tsx"],"names":["selectType","SINGLE","CHECKBOXES","getSelected","value","Array","isArray","SelectComponent","props","input","delay","callback","onSearch","filter","options","labelFieldId","filterFunc","item","String","prototype","call","filteredOptions","toString","setState","type","state","isExpanded","selected","hasCheckboxes","control","n2oSelectRef","handleButtonClick","bind","handleInputChange","handleInputFocus","hideOptionsList","handleItemSelect","removeSelectedItem","clearSelected","handleSearchButton","handleOnBlur","setControlRef","initial","valueFieldId","setStateFromInitial","nextProps","prevProps","mapOptions","map","option","Number","idType","onChange","stateSelected","i","newIsExpanded","fetchData","onClose","onOpen","page","disabled","changePopUpVision","newValue","e","stopPropagation","preventDefault","onBlur","searchByTap","onInput","resetOnBlur","setNewValue","handleDataSearch","closePopupOnSelect","insertSelected","clearSearchField","focus","handleResetOnBlur","el","selectFormat","selectFormatOne","selectFormatFew","selectFormatMany","selectedCount","length","text","replace","placeholder","selectedElement","loading","className","iconFieldId","disabledValues","enabledFieldId","imageFieldId","statusFieldId","groupFieldId","descriptionFieldId","format","badge","hasSearch","cleanable","style","inputSelectStyle","width","title","renderPlaceholder","renderValue","current","React","Component","Select"],"mappings":"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","sourcesContent":["import React, { FocusEvent, RefObject, createRef } from 'react'\nimport onClickOutside from 'react-onclickoutside'\nimport isEqual from 'lodash/isEqual'\nimport get from 'lodash/get'\nimport first from 'lodash/first'\nimport isEmpty from 'lodash/isEmpty'\nimport find from 'lodash/find'\nimport { Button } from 'reactstrap'\n\nimport { InputSelectGroup } from '../InputSelect/InputSelectGroup'\nimport { Filter, TOption } from '../InputSelect/types'\nimport { BadgeType, PopupList } from '../InputSelect/PopupList'\n\nimport { getNoun } from './utils'\nimport { Popup } from './Popup'\nimport { N2OSelectInput } from './SelectInput'\n\n/**\n * N2OSelect\n * @reactProps {boolean} loading - флаг анимации загрузки\n * @reactProps {array} options - данные\n * @reactProps {string} valueFieldId - значение ключа value в данных\n * @reactProps {string} labelFieldId - значение ключа label в данных\n * @reactProps {string} iconFieldId - поле для иконки\n * @reactProps {string} imageFieldId - поле для картинки\n * @reactProps {string} statusFieldId - поле для статуса\n * @reactProps {object} badge - данные для баджа\n * @reactProps {boolean} disabled - флаг неактивности\n * @reactProps {array} disabledValues - неактивные данные\n * @reactProps {string} enabledFieldId - поле для активности\n * @reactProps {string} filter - варианты фильтрации\n * @reactProps {string} value - текущее значение\n * @reactProps {function} onInput - callback при вводе в инпут\n * @reactProps {function} onChange - callback при выборе значения или вводе\n * @reactProps {string} placeHolder - подсказка в инпуте\n * @reactProps {boolean} resetOnBlur - фича, при которой сбрасывается значение контрола, если оно не выбрано из popup\n * @reactProps {function} onClose - callback на закрытие попапа\n * @reactProps {string} groupFieldId - поле для группировки\n * @reactProps {boolean} closePopupOnSelect - флаг закрытия попапа при выборе\n * @reactProps {boolean} hasCheckboxes - флаг наличия чекбоксов\n * @reactProps {string} format - формат\n * @reactProps {boolean} searchByTap - поиск по нажатию кнопки\n */\n\nconst selectType = {\n    SINGLE: 'single',\n    CHECKBOXES: 'checkboxes',\n}\n\ntype State = {\n    hasCheckboxes: boolean,\n    input?: string\n    isExpanded: boolean,\n    options?: TOption[],\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    selected: any[]\n    value: string\n}\n\nfunction getSelected(value: Props['value']) {\n    if (Array.isArray(value)) {\n        return value\n    }\n    if (!isEmpty(value)) {\n        return [value]\n    }\n\n    return []\n}\n\nclass SelectComponent extends React.Component<Props, State> {\n    private control: null | HTMLButtonElement = null\n\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    n2oSelectRef: RefObject<any>\n\n    constructor(props: Props) {\n        super(props)\n        const { value, options, type } = this.props\n\n        this.state = {\n            value: '',\n            isExpanded: false,\n            options,\n            selected: getSelected(value),\n            hasCheckboxes: type === selectType.CHECKBOXES,\n        }\n\n        this.control = null\n        this.n2oSelectRef = createRef()\n\n        this.handleButtonClick = this.handleButtonClick.bind(this)\n        this.handleInputChange = this.handleInputChange.bind(this)\n        this.handleInputFocus = this.handleInputFocus.bind(this)\n        this.hideOptionsList = this.hideOptionsList.bind(this)\n        this.handleItemSelect = this.handleItemSelect.bind(this)\n        this.removeSelectedItem = this.removeSelectedItem.bind(this)\n        this.clearSelected = this.clearSelected.bind(this)\n        this.handleSearchButton = this.handleSearchButton.bind(this)\n        this.handleOnBlur = this.handleOnBlur.bind(this)\n        this.setControlRef = this.setControlRef.bind(this)\n    }\n\n    componentDidMount() {\n        const { initial, options, valueFieldId } = this.props\n\n        if (Array.isArray(initial)) {\n            this.setStateFromInitial(initial, options, valueFieldId)\n        }\n    }\n\n    // eslint-disable-next-line react/no-deprecated\n    componentWillReceiveProps(nextProps: Props) {\n        const { options } = this.props\n        const state = {} as State\n\n        if (!isEqual(options, nextProps.options)) {\n            state.options = nextProps.options\n        }\n        this.setState(state)\n    }\n\n    componentDidUpdate(prevProps: Props) {\n        const { initial, options, valueFieldId, value } = this.props\n\n        if (Array.isArray(initial) && !isEqual(initial, prevProps.initial)) {\n            this.setStateFromInitial(initial, options, valueFieldId)\n\n            return\n        }\n        if (!isEqual(value, prevProps.value)) {\n            this.setState({\n                selected: getSelected(value),\n            })\n        }\n    }\n\n    /**\n     * Хак для мапинга айдишников, которые берутся из адресной строки в виде строк, но ожидается число\n     * TODO удалить после того, как починится поведение парсинга адресной строки будет опираться на указанные типы\n     * @param {Array.<object>} [initial]\n     * @param options\n     * @param {String} valueFieldId\n     * @private\n     */\n    setStateFromInitial(initial: Props['options'], options: Props['options'], valueFieldId: Props['valueFieldId']) {\n        const mapOptions = (options: Props['options'], type = 'string') => options.map(option => ({\n            ...option,\n            ...{\n                [valueFieldId]:\n                    type === 'number'\n                        ? Number(option[valueFieldId as keyof TOption])\n                        : String(option[valueFieldId as keyof TOption]),\n            },\n        }))\n\n        if (isEmpty(options)) {\n            this.setState({\n                selected: mapOptions(initial),\n            })\n        } else {\n            const selected = options.filter((option) => {\n                const idType = typeof option[valueFieldId as keyof TOption]\n\n                return find(mapOptions(initial, idType), option)\n            })\n\n            this.setState({\n                selected,\n            })\n        }\n    }\n\n    /**\n     * Удаляет элемент из списка выбранных\n     * @param item - элемент\n     * @private\n     */\n    removeSelectedItem(item: TOption) {\n        const { valueFieldId, onChange } = this.props\n        const { selected: stateSelected } = this.state\n        const selected = typeof stateSelected !== 'string' ? stateSelected.filter(\n            i => i[valueFieldId] !== item[valueFieldId as keyof TOption],\n        ) : stateSelected\n\n        this.setState({\n            selected,\n        })\n        if (onChange) {\n            onChange(selected)\n        }\n    }\n\n    /**\n     * Изменение видимости попапа\n     * @param newIsExpanded - новое значение видимости\n     * @private\n     */\n    changePopUpVision(newIsExpanded: State['isExpanded']) {\n        const { fetchData, onClose } = this.props\n        const { isExpanded } = this.state\n\n        if (isExpanded === newIsExpanded) { return }\n\n        const onOpen = fetchData({ page: 1 })\n\n        this.setState(\n            {\n                isExpanded: newIsExpanded,\n            },\n            newIsExpanded ? onOpen : onClose,\n        )\n    }\n\n    /**\n     * Обрабатывает нажатие на кнопку\n     * @private\n     */\n    handleButtonClick() {\n        const { disabled } = this.props\n        const { isExpanded } = this.state\n\n        if (!disabled) {\n            this.changePopUpVision(!isExpanded)\n        }\n    }\n\n    /**\n     * Обрабатывает форкус на инпуте\n     * @private\n     */\n    handleInputFocus() {\n        this.changePopUpVision(true)\n    }\n\n    /**\n     * Скрывает popUp\n     * @private\n     */\n    hideOptionsList() {\n        this.changePopUpVision(false)\n    }\n\n    /**\n     * Уставнавливает новое значение инпута\n     * @param newValue - новое значение\n     * @private\n     */\n    setNewValue(newValue: State['value']) {\n        this.setState({\n            value: newValue,\n        })\n    }\n\n    /**\n     * Удаляет выбранные элементы\n     * @private\n     */\n    clearSelected(e: Event) {\n        e.stopPropagation()\n        e.preventDefault()\n\n        const { disabled, onChange, onBlur } = this.props\n\n        if (disabled) {\n            return\n        }\n\n        this.setState({\n            selected: [],\n        })\n        onChange(null)\n        onBlur(null)\n    }\n\n    /**\n     * Выполняет поиск элементов для popUp, если установлен фильтр\n     * @param input - значение для поиска\n     * @param {boolean} delay\n     * @param {Function} callback\n     * @private\n     */\n    handleDataSearch: Props['onSearch'] = (input, delay, callback) => {\n        const { onSearch, filter, options, labelFieldId } = this.props\n\n        if (filter) {\n            // eslint-disable-next-line @typescript-eslint/no-explicit-any\n            const filterFunc = (item: TOption) => (String.prototype[filter as any] as any).call(item, input)\n            const filteredOptions = options.filter(item => filterFunc(item[labelFieldId as keyof TOption].toString()))\n\n            this.setState({ options: filteredOptions })\n        } else {\n            onSearch(input, delay === false ? delay : true, callback)\n        }\n    }\n\n    /**\n     * Устанавливает выбранный элемент\n     * @param item - элемент массива options\n     * @private\n     */\n    insertSelected(item: TOption) {\n        const { onChange, onBlur } = this.props\n        const { selected: stateSelected, hasCheckboxes } = this.state\n        let selected = [item]\n        let value: TOption | TOption[] = item\n\n        if (hasCheckboxes) {\n            selected = [...(stateSelected || []), item]\n            value = selected\n        }\n\n        this.setState({\n            selected,\n        })\n\n        if (onChange) {\n            onChange(value)\n            onBlur(value)\n        }\n    }\n\n    /**\n     * Обрабатывает изменение инпута\n     * @param newValue - новое значение\n     * @private\n     */\n    handleInputChange(newValue: string) {\n        const { searchByTap, onChange, onInput, resetOnBlur } = this.props\n\n        this.setNewValue(newValue)\n\n        if (!searchByTap) {\n            this.handleDataSearch(newValue)\n        }\n        if (!resetOnBlur) {\n            onChange(newValue)\n        }\n        onInput(newValue)\n    }\n\n    /**\n     * Обрабатывает поиск по нажатию\n     * @private\n     */\n    handleSearchButton() {\n        const { value } = this.state\n\n        this.handleDataSearch(value)\n    }\n\n    /**\n     * Очищает инпут и результаты поиска\n     * @private\n     */\n    clearSearchField() {\n        const { options } = this.props\n\n        this.setState({\n            value: '',\n            options,\n        })\n    }\n\n    /**\n     * Обрабатывает выбор элемента из popUp\n     * @param item - элемент массива options\n     * @private\n     */\n    handleItemSelect(item: TOption) {\n        const { closePopupOnSelect } = this.props\n\n        this.insertSelected(item)\n\n        if (closePopupOnSelect) {\n            this.hideOptionsList()\n        }\n\n        this.clearSearchField()\n\n        if (this.control) {\n            // eslint-disable-next-line @typescript-eslint/no-explicit-any\n            (this.control as any).focus()\n        }\n    }\n\n    /**\n     * Обрабатывает поведение инпута при потери фокуса, если есть resetOnBlur\n     * @private\n     */\n    handleResetOnBlur() {\n        const { selected } = this.state\n        const { resetOnBlur, options } = this.props\n\n        if (resetOnBlur && !selected) {\n            this.setState({\n                value: '',\n                options,\n            })\n        }\n    }\n\n    /**\n     * Обрабатывает клик за пределы компонента\n     * вызывается библиотекой react-onclickoutside\n     */\n    handleClickOutside() {\n        const { onBlur, value } = this.props\n        const { isExpanded } = this.state\n\n        if (isExpanded) {\n            this.hideOptionsList()\n            onBlur(value)\n        }\n    }\n\n    handleOnBlur(e: FocusEvent<HTMLDivElement>) {\n        e.preventDefault()\n        this.handleResetOnBlur()\n    }\n\n    setControlRef(el: HTMLButtonElement) {\n        this.control = el\n    }\n\n    renderPlaceholder() {\n        const {\n            selectFormat = 'Объектов {size} шт',\n            selectFormatOne = '',\n            selectFormatFew = '',\n            selectFormatMany = '',\n        } = this.props\n\n        const { selected, hasCheckboxes } = this.state\n        const selectedCount = selected.length\n        let text\n\n        if (\n            !isEmpty(selectFormatOne) &&\n            !isEmpty(selectFormatFew) &&\n            !isEmpty(selectFormatMany) &&\n            selectedCount >= 1 &&\n            hasCheckboxes\n        ) {\n            text = getNoun(\n                selectedCount,\n                selectFormatOne,\n                selectFormatFew,\n                selectFormatMany,\n            ).replace('{size}', `${selectedCount}`)\n        } else if (selectedCount >= 1 && hasCheckboxes) {\n            text = selectFormat.replace('{size}', `${selectedCount}`)\n        } else {\n            text = null\n        }\n\n        return text\n    }\n\n    renderValue() {\n        const { labelFieldId, placeholder = '' } = this.props\n        const { selected } = this.state\n\n        if (isEmpty(selected)) {\n            return placeholder\n        }\n\n        const [selectedElement] = selected\n\n        return get(selectedElement, labelFieldId)\n    }\n\n    render() {\n        const {\n            loading,\n            className,\n            valueFieldId,\n            labelFieldId,\n            iconFieldId,\n            disabled,\n            disabledValues,\n            enabledFieldId,\n            imageFieldId,\n            statusFieldId,\n            groupFieldId,\n            descriptionFieldId,\n            format,\n            placeholder,\n            badge,\n            fetchData,\n            page,\n            hasSearch,\n            cleanable,\n            style,\n        } = this.props\n        const inputSelectStyle = { width: '100%', ...style }\n\n        const { selected, isExpanded, hasCheckboxes, value, options } = this.state\n\n        const title = get(first(selected), `${labelFieldId}`)\n\n        return (\n            <div\n                className=\"n2o-input-select\"\n                title={title}\n                style={inputSelectStyle}\n                onBlur={this.handleOnBlur}\n                ref={this.n2oSelectRef}\n            >\n                <Button innerRef={this.setControlRef} onClick={this.handleButtonClick}>\n                    <InputSelectGroup\n                        className={className}\n                        isExpanded={isExpanded}\n                        loading={loading}\n                        disabled={disabled}\n                        iconFieldId={iconFieldId}\n                        imageFieldId={imageFieldId}\n                        cleanable={cleanable}\n                        selected={selected}\n                        onClearClick={this.clearSelected}\n                    >\n                        <span className=\"valueText\">\n                            {\n                                hasCheckboxes\n                                    ? this.renderPlaceholder()\n                                    : this.renderValue()\n                            }\n                        </span>\n                    </InputSelectGroup>\n                </Button>\n                <Popup isExpanded={isExpanded} inputSelect={this.n2oSelectRef.current}>\n                    <>\n                        {hasSearch && (\n                            <N2OSelectInput\n                                placeholder={placeholder || ''}\n                                onChange={this.handleInputChange}\n                                onSearch={this.handleSearchButton}\n                                value={value}\n                            />\n                        )}\n                        <PopupList\n                            options={options}\n                            valueFieldId={valueFieldId}\n                            labelFieldId={labelFieldId}\n                            iconFieldId={iconFieldId}\n                            imageFieldId={imageFieldId}\n                            statusFieldId={statusFieldId}\n                            badge={badge}\n                            descriptionFieldId={descriptionFieldId}\n                            enabledFieldId={enabledFieldId}\n                            onSelect={this.handleItemSelect}\n                            fetchData={fetchData}\n                            page={page}\n                            isExpanded={isExpanded}\n                            selected={selected}\n                            disabledValues={disabledValues}\n                            groupFieldId={groupFieldId}\n                            hasCheckboxes={hasCheckboxes}\n                            onRemoveItem={this.removeSelectedItem}\n                            format={format}\n                            loading={loading}\n                        />\n                    </>\n                </Popup>\n            </div>\n        )\n    }\n\n    static defaultProps = {\n        cleanable: true,\n        valueFieldId: 'id',\n        labelFieldId: 'name',\n        iconFieldId: 'icon',\n        loading: false,\n        disabled: false,\n        disabledValues: [],\n        resetOnBlur: false,\n        searchByTap: false,\n        hasSearch: false,\n        options: [],\n        value: {},\n        descriptionFieldId: '',\n        enabledFieldId: '',\n        statusFieldId: '',\n        groupFieldId: '',\n        imageFieldId: '',\n        closePopupOnSelect: true,\n        onSearch() {},\n        onChange() {},\n        fetchData: () => () => {},\n        onInput() {},\n        onClose() {},\n        onBlur() {},\n    } as Props\n}\n\ntype Props = {\n    /**\n     * Данные для badge\n     */\n    badge?: BadgeType,\n    className?: string,\n    cleanable: boolean,\n    closePopupOnSelect: boolean,\n    descriptionFieldId: string,\n    /**\n     * Флаг активности\n     */\n    disabled: boolean,\n    /**\n     * Неактивные данные\n     */\n    disabledValues: [],\n    /**\n     * Ключ enabled в данных\n     */\n    enabledFieldId: string,\n    fetchData(arg: object): () => void,\n    /**\n     * Фильтрация\n     */\n    filter?: Filter,\n    /**\n     * Формат\n     */\n    format?: string,\n    groupFieldId: string,\n    /**\n     * Флаг наличия поиска\n     */\n    hasSearch: boolean,\n    /**\n     * Ключ icon в данных\n     */\n    iconFieldId: string,\n    /**\n     * Ключ image в данных\n     */\n    imageFieldId: string,\n    initial?: string | number,\n    /**\n     * Ключ label в данных\n     */\n    labelFieldId: string,\n    /**\n     * Флаг загрузки\n     */\n    loading: boolean,\n    onBlur(arg: Props['value']): void,\n    /**\n     * Callback на изменение\n     */\n    onChange(arg: TOption | TOption[] | null | string): void,\n    /**\n     * Callback на закрытие попапа\n     */\n    onClose(): void,\n    /**\n     * Callback при вводе в инпут\n     */\n    onInput(input: string): void,\n    /**\n     * Callback на поиск\n     */\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    onSearch(input: State['input'], delay?: boolean, callback?: any): void,\n    /**\n     * Данные\n     */\n    options: TOption[],\n    page?: number,\n    /**\n     * Placeholder контрола\n     */\n    placeholder?: string,\n    /**\n     * Сброс значения при потере фокуса\n     */\n    resetOnBlur: boolean,\n    /**\n     * Поиск по нажатию кнопки\n     */\n    searchByTap: boolean,\n    selectFormat?: string,\n    selectFormatFew?: string,\n    selectFormatMany?: string,\n    selectFormatOne?: string,\n    /**\n     * Ключ image в данных\n     */\n    statusFieldId: string,\n    style?: object,\n    type?: string,\n    /**\n     * Значение\n     */\n    // eslint-disable-next-line @typescript-eslint/no-explicit-any\n    value: any,\n    /**\n     * Ключ id в данных\n     */\n    valueFieldId: string\n}\n\nexport const Select = onClickOutside(SelectComponent)\n"]}
|