@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,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"]}