@vkontakte/vkui 5.1.2 → 5.2.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 (281) hide show
  1. package/dist/cjs/components/Cell/CellCheckbox/CellCheckbox.js +7 -4
  2. package/dist/cjs/components/Cell/CellCheckbox/CellCheckbox.js.map +1 -1
  3. package/dist/cjs/components/ChipsSelect/ChipsSelect.js +0 -4
  4. package/dist/cjs/components/ChipsSelect/ChipsSelect.js.map +1 -1
  5. package/dist/cjs/components/ContentCard/ContentCard.js +2 -1
  6. package/dist/cjs/components/ContentCard/ContentCard.js.map +1 -1
  7. package/dist/cjs/components/CustomSelect/CustomSelect.js +4 -3
  8. package/dist/cjs/components/CustomSelect/CustomSelect.js.map +1 -1
  9. package/dist/cjs/components/CustomSelectDropdown/CustomSelectDropdown.d.ts +2 -3
  10. package/dist/cjs/components/CustomSelectDropdown/CustomSelectDropdown.js +21 -72
  11. package/dist/cjs/components/CustomSelectDropdown/CustomSelectDropdown.js.map +1 -1
  12. package/dist/cjs/components/DateInput/DateInput.d.ts +3 -2
  13. package/dist/cjs/components/DateInput/DateInput.js +3 -2
  14. package/dist/cjs/components/DateInput/DateInput.js.map +1 -1
  15. package/dist/cjs/components/DateRangeInput/DateRangeInput.d.ts +2 -2
  16. package/dist/cjs/components/DateRangeInput/DateRangeInput.js +3 -2
  17. package/dist/cjs/components/DateRangeInput/DateRangeInput.js.map +1 -1
  18. package/dist/cjs/components/FixedLayout/FixedLayout.js +2 -2
  19. package/dist/cjs/components/FixedLayout/FixedLayout.js.map +1 -1
  20. package/dist/cjs/components/FormField/FormField.js +6 -10
  21. package/dist/cjs/components/FormField/FormField.js.map +1 -1
  22. package/dist/cjs/components/IconButton/IconButton.js +9 -0
  23. package/dist/cjs/components/IconButton/IconButton.js.map +1 -1
  24. package/dist/cjs/components/ModalCard/ModalCard.d.ts +1 -1
  25. package/dist/cjs/components/ModalCard/ModalCard.js +4 -2
  26. package/dist/cjs/components/ModalCard/ModalCard.js.map +1 -1
  27. package/dist/cjs/components/ModalCardBase/ModalCardBase.d.ts +5 -1
  28. package/dist/cjs/components/ModalCardBase/ModalCardBase.js +9 -2
  29. package/dist/cjs/components/ModalCardBase/ModalCardBase.js.map +1 -1
  30. package/dist/cjs/components/ModalPage/ModalPage.d.ts +2 -6
  31. package/dist/cjs/components/ModalPage/ModalPage.js +13 -7
  32. package/dist/cjs/components/ModalPage/ModalPage.js.map +1 -1
  33. package/dist/cjs/components/ModalRoot/ModalRoot.js +1 -2
  34. package/dist/cjs/components/ModalRoot/ModalRoot.js.map +1 -1
  35. package/dist/cjs/components/Popper/Popper.d.ts +12 -9
  36. package/dist/cjs/components/Popper/Popper.js +92 -119
  37. package/dist/cjs/components/Popper/Popper.js.map +1 -1
  38. package/dist/cjs/components/PopperArrow/PopperArrow.d.ts +15 -5
  39. package/dist/cjs/components/PopperArrow/PopperArrow.js +44 -17
  40. package/dist/cjs/components/PopperArrow/PopperArrow.js.map +1 -1
  41. package/dist/cjs/components/Root/Root.js +2 -2
  42. package/dist/cjs/components/Root/Root.js.map +1 -1
  43. package/dist/cjs/components/SplitCol/SplitCol.d.ts +0 -6
  44. package/dist/cjs/components/SplitCol/SplitCol.js +3 -11
  45. package/dist/cjs/components/SplitCol/SplitCol.js.map +1 -1
  46. package/dist/cjs/components/SplitCol/SplitColContext.d.ts +7 -0
  47. package/dist/cjs/components/SplitCol/SplitColContext.js +18 -0
  48. package/dist/cjs/components/SplitCol/SplitColContext.js.map +1 -0
  49. package/dist/cjs/components/TabbarItem/TabbarItem.js +9 -0
  50. package/dist/cjs/components/TabbarItem/TabbarItem.js.map +1 -1
  51. package/dist/cjs/components/Tooltip/Tooltip.d.ts +3 -3
  52. package/dist/cjs/components/Tooltip/Tooltip.js +115 -151
  53. package/dist/cjs/components/Tooltip/Tooltip.js.map +1 -1
  54. package/dist/cjs/components/View/View.js +2 -2
  55. package/dist/cjs/components/View/View.js.map +1 -1
  56. package/dist/cjs/components/View/ViewInfinite.d.ts +1 -1
  57. package/dist/cjs/components/View/ViewInfinite.js +2 -2
  58. package/dist/cjs/components/View/ViewInfinite.js.map +1 -1
  59. package/dist/cjs/components/WriteBarIcon/WriteBarIcon.js +10 -8
  60. package/dist/cjs/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
  61. package/dist/cjs/index.d.ts +37 -30
  62. package/dist/cjs/index.js +13 -13
  63. package/dist/cjs/index.js.map +1 -1
  64. package/dist/cjs/lib/floating/adapters.d.ts +2 -0
  65. package/dist/cjs/lib/floating/adapters.js +63 -0
  66. package/dist/cjs/lib/floating/adapters.js.map +1 -0
  67. package/dist/cjs/lib/floating/functions.d.ts +10 -0
  68. package/dist/cjs/lib/floating/functions.js +36 -0
  69. package/dist/cjs/lib/floating/functions.js.map +1 -0
  70. package/dist/cjs/lib/floating/index.d.ts +4 -0
  71. package/dist/cjs/lib/floating/index.js +75 -0
  72. package/dist/cjs/lib/floating/index.js.map +1 -0
  73. package/dist/cjs/lib/floating/types.d.ts +4 -0
  74. package/dist/cjs/lib/floating/types.js +6 -0
  75. package/dist/cjs/lib/floating/types.js.map +1 -0
  76. package/dist/cjs/lib/useIsomorphicLayoutEffect.d.ts +1 -1
  77. package/dist/cjs/lib/warnOnce.d.ts +7 -0
  78. package/dist/cjs/lib/warnOnce.js +14 -0
  79. package/dist/cjs/lib/warnOnce.js.map +1 -1
  80. package/dist/components/Cell/CellCheckbox/CellCheckbox.js +7 -4
  81. package/dist/components/Cell/CellCheckbox/CellCheckbox.js.map +1 -1
  82. package/dist/components/ChipsSelect/ChipsSelect.js +0 -4
  83. package/dist/components/ChipsSelect/ChipsSelect.js.map +1 -1
  84. package/dist/components/ContentCard/ContentCard.js +2 -1
  85. package/dist/components/ContentCard/ContentCard.js.map +1 -1
  86. package/dist/components/CustomSelect/CustomSelect.js +5 -4
  87. package/dist/components/CustomSelect/CustomSelect.js.map +1 -1
  88. package/dist/components/CustomSelectDropdown/CustomSelectDropdown.d.ts +2 -3
  89. package/dist/components/CustomSelectDropdown/CustomSelectDropdown.js +22 -73
  90. package/dist/components/CustomSelectDropdown/CustomSelectDropdown.js.map +1 -1
  91. package/dist/components/DateInput/DateInput.d.ts +3 -2
  92. package/dist/components/DateInput/DateInput.js +3 -2
  93. package/dist/components/DateInput/DateInput.js.map +1 -1
  94. package/dist/components/DateRangeInput/DateRangeInput.d.ts +2 -2
  95. package/dist/components/DateRangeInput/DateRangeInput.js +3 -2
  96. package/dist/components/DateRangeInput/DateRangeInput.js.map +1 -1
  97. package/dist/components/FixedLayout/FixedLayout.js +1 -1
  98. package/dist/components/FixedLayout/FixedLayout.js.map +1 -1
  99. package/dist/components/FormField/FormField.js +6 -10
  100. package/dist/components/FormField/FormField.js.map +1 -1
  101. package/dist/components/IconButton/IconButton.js +9 -0
  102. package/dist/components/IconButton/IconButton.js.map +1 -1
  103. package/dist/components/ModalCard/ModalCard.d.ts +1 -1
  104. package/dist/components/ModalCard/ModalCard.js +4 -2
  105. package/dist/components/ModalCard/ModalCard.js.map +1 -1
  106. package/dist/components/ModalCardBase/ModalCardBase.d.ts +5 -1
  107. package/dist/components/ModalCardBase/ModalCardBase.js +9 -2
  108. package/dist/components/ModalCardBase/ModalCardBase.js.map +1 -1
  109. package/dist/components/ModalPage/ModalPage.d.ts +2 -6
  110. package/dist/components/ModalPage/ModalPage.js +13 -7
  111. package/dist/components/ModalPage/ModalPage.js.map +1 -1
  112. package/dist/components/ModalRoot/ModalRoot.js +1 -2
  113. package/dist/components/ModalRoot/ModalRoot.js.map +1 -1
  114. package/dist/components/Popper/Popper.d.ts +12 -9
  115. package/dist/components/Popper/Popper.js +93 -120
  116. package/dist/components/Popper/Popper.js.map +1 -1
  117. package/dist/components/PopperArrow/PopperArrow.d.ts +15 -5
  118. package/dist/components/PopperArrow/PopperArrow.js +40 -15
  119. package/dist/components/PopperArrow/PopperArrow.js.map +1 -1
  120. package/dist/components/Root/Root.js +1 -1
  121. package/dist/components/Root/Root.js.map +1 -1
  122. package/dist/components/SplitCol/SplitCol.d.ts +0 -6
  123. package/dist/components/SplitCol/SplitCol.js +1 -7
  124. package/dist/components/SplitCol/SplitCol.js.map +1 -1
  125. package/dist/components/SplitCol/SplitColContext.d.ts +7 -0
  126. package/dist/components/SplitCol/SplitColContext.js +9 -0
  127. package/dist/components/SplitCol/SplitColContext.js.map +1 -0
  128. package/dist/components/TabbarItem/TabbarItem.js +9 -0
  129. package/dist/components/TabbarItem/TabbarItem.js.map +1 -1
  130. package/dist/components/Tooltip/Tooltip.d.ts +3 -3
  131. package/dist/components/Tooltip/Tooltip.js +115 -151
  132. package/dist/components/Tooltip/Tooltip.js.map +1 -1
  133. package/dist/components/View/View.js +1 -1
  134. package/dist/components/View/View.js.map +1 -1
  135. package/dist/components/View/ViewInfinite.d.ts +1 -1
  136. package/dist/components/View/ViewInfinite.js +1 -1
  137. package/dist/components/View/ViewInfinite.js.map +1 -1
  138. package/dist/components/WriteBarIcon/WriteBarIcon.js +11 -9
  139. package/dist/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
  140. package/dist/components.css +142 -2
  141. package/dist/components.css.map +1 -1
  142. package/dist/components.js.tmp +61921 -4
  143. package/dist/cssm/components/Alert/Alert.module.css +1 -1
  144. package/dist/cssm/components/Avatar/Avatar.module.css +1 -1
  145. package/dist/cssm/components/Button/Button.module.css +1 -1
  146. package/dist/cssm/components/CalendarDay/CalendarDay.module.css +1 -1
  147. package/dist/cssm/components/CalendarTime/CalendarTime.module.css +1 -1
  148. package/dist/cssm/components/Cell/CellCheckbox/CellCheckbox.js +7 -4
  149. package/dist/cssm/components/Cell/CellCheckbox/CellCheckbox.js.map +1 -1
  150. package/dist/cssm/components/Cell/CellCheckbox/CellCheckbox.module.css +1 -1
  151. package/dist/cssm/components/Checkbox/Checkbox.module.css +1 -1
  152. package/dist/cssm/components/ChipsSelect/ChipsSelect.js +0 -4
  153. package/dist/cssm/components/ChipsSelect/ChipsSelect.js.map +1 -1
  154. package/dist/cssm/components/ContentCard/ContentCard.js +2 -1
  155. package/dist/cssm/components/ContentCard/ContentCard.js.map +1 -1
  156. package/dist/cssm/components/CustomSelect/CustomSelect.js +5 -4
  157. package/dist/cssm/components/CustomSelect/CustomSelect.js.map +1 -1
  158. package/dist/cssm/components/CustomSelectDropdown/CustomSelectDropdown.d.ts +2 -3
  159. package/dist/cssm/components/CustomSelectDropdown/CustomSelectDropdown.js +22 -73
  160. package/dist/cssm/components/CustomSelectDropdown/CustomSelectDropdown.js.map +1 -1
  161. package/dist/cssm/components/CustomSelectOption/CustomSelectOption.module.css +1 -1
  162. package/dist/cssm/components/DateInput/DateInput.d.ts +3 -2
  163. package/dist/cssm/components/DateInput/DateInput.js +4 -2
  164. package/dist/cssm/components/DateInput/DateInput.js.map +1 -1
  165. package/dist/cssm/components/DateRangeInput/DateRangeInput.d.ts +2 -2
  166. package/dist/cssm/components/DateRangeInput/DateRangeInput.js +3 -2
  167. package/dist/cssm/components/DateRangeInput/DateRangeInput.js.map +1 -1
  168. package/dist/cssm/components/FixedLayout/FixedLayout.js +1 -1
  169. package/dist/cssm/components/FixedLayout/FixedLayout.js.map +1 -1
  170. package/dist/cssm/components/FormField/FormField.js +6 -10
  171. package/dist/cssm/components/FormField/FormField.js.map +1 -1
  172. package/dist/cssm/components/FormField/FormField.module.css +1 -1
  173. package/dist/cssm/components/Header/Header.module.css +1 -1
  174. package/dist/cssm/components/HorizontalCell/HorizontalCell.module.css +1 -1
  175. package/dist/cssm/components/IconButton/IconButton.js +9 -0
  176. package/dist/cssm/components/IconButton/IconButton.js.map +1 -1
  177. package/dist/cssm/components/InputLike/InputLike.module.css +1 -1
  178. package/dist/cssm/components/ModalCard/ModalCard.d.ts +1 -1
  179. package/dist/cssm/components/ModalCard/ModalCard.js +4 -2
  180. package/dist/cssm/components/ModalCard/ModalCard.js.map +1 -1
  181. package/dist/cssm/components/ModalCardBase/ModalCardBase.d.ts +5 -1
  182. package/dist/cssm/components/ModalCardBase/ModalCardBase.js +9 -2
  183. package/dist/cssm/components/ModalCardBase/ModalCardBase.js.map +1 -1
  184. package/dist/cssm/components/ModalPage/ModalPage.d.ts +2 -6
  185. package/dist/cssm/components/ModalPage/ModalPage.js +13 -7
  186. package/dist/cssm/components/ModalPage/ModalPage.js.map +1 -1
  187. package/dist/cssm/components/ModalPage/ModalPage.module.css +1 -1
  188. package/dist/cssm/components/ModalRoot/ModalRoot.js +1 -2
  189. package/dist/cssm/components/ModalRoot/ModalRoot.js.map +1 -1
  190. package/dist/cssm/components/Pagination/Pagination.module.css +1 -1
  191. package/dist/cssm/components/PanelHeader/PanelHeader.module.css +1 -1
  192. package/dist/cssm/components/PanelHeaderContent/PanelHeaderContent.module.css +1 -1
  193. package/dist/cssm/components/Popper/Popper.d.ts +12 -9
  194. package/dist/cssm/components/Popper/Popper.js +93 -120
  195. package/dist/cssm/components/Popper/Popper.js.map +1 -1
  196. package/dist/cssm/components/PopperArrow/PopperArrow.d.ts +15 -5
  197. package/dist/cssm/components/PopperArrow/PopperArrow.js +40 -15
  198. package/dist/cssm/components/PopperArrow/PopperArrow.js.map +1 -1
  199. package/dist/cssm/components/PopperArrow/PopperArrow.module.css +1 -1
  200. package/dist/cssm/components/Radio/Radio.module.css +1 -1
  201. package/dist/cssm/components/RichCell/RichCell.module.css +1 -1
  202. package/dist/cssm/components/Root/Root.js +1 -1
  203. package/dist/cssm/components/Root/Root.js.map +1 -1
  204. package/dist/cssm/components/Search/Search.module.css +1 -1
  205. package/dist/cssm/components/SegmentedControl/SegmentedControl.module.css +1 -1
  206. package/dist/cssm/components/Select/Select.module.css +1 -1
  207. package/dist/cssm/components/SimpleCell/SimpleCell.module.css +1 -1
  208. package/dist/cssm/components/SplitCol/SplitCol.d.ts +0 -6
  209. package/dist/cssm/components/SplitCol/SplitCol.js +1 -7
  210. package/dist/cssm/components/SplitCol/SplitCol.js.map +1 -1
  211. package/dist/cssm/components/SplitCol/SplitColContext.d.ts +7 -0
  212. package/dist/cssm/components/SplitCol/SplitColContext.js +9 -0
  213. package/dist/cssm/components/SplitCol/SplitColContext.js.map +1 -0
  214. package/dist/cssm/components/TabbarItem/TabbarItem.js +9 -0
  215. package/dist/cssm/components/TabbarItem/TabbarItem.js.map +1 -1
  216. package/dist/cssm/components/Tabs/Tabs.module.css +1 -1
  217. package/dist/cssm/components/Tooltip/Tooltip.d.ts +3 -3
  218. package/dist/cssm/components/Tooltip/Tooltip.js +121 -151
  219. package/dist/cssm/components/Tooltip/Tooltip.js.map +1 -1
  220. package/dist/cssm/components/Tooltip/Tooltip.module.css +1 -1
  221. package/dist/cssm/components/Typography/Caption/Caption.module.css +1 -1
  222. package/dist/cssm/components/Typography/Footnote/Footnote.module.css +1 -1
  223. package/dist/cssm/components/Typography/Headline/Headline.module.css +1 -1
  224. package/dist/cssm/components/Typography/Paragraph/Paragraph.module.css +1 -1
  225. package/dist/cssm/components/Typography/Subhead/Subhead.module.css +1 -1
  226. package/dist/cssm/components/Typography/Text/Text.module.css +1 -1
  227. package/dist/cssm/components/Typography/Title/Title.module.css +1 -1
  228. package/dist/cssm/components/View/View.js +1 -1
  229. package/dist/cssm/components/View/View.js.map +1 -1
  230. package/dist/cssm/components/View/View.module.css +1 -1
  231. package/dist/cssm/components/View/ViewInfinite.d.ts +1 -1
  232. package/dist/cssm/components/View/ViewInfinite.js +1 -1
  233. package/dist/cssm/components/View/ViewInfinite.js.map +1 -1
  234. package/dist/cssm/components/WriteBarIcon/WriteBarIcon.js +11 -9
  235. package/dist/cssm/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
  236. package/dist/cssm/index.d.ts +37 -30
  237. package/dist/cssm/index.js +24 -18
  238. package/dist/cssm/index.js.map +1 -1
  239. package/dist/cssm/lib/floating/adapters.d.ts +2 -0
  240. package/dist/cssm/lib/floating/adapters.js +56 -0
  241. package/dist/cssm/lib/floating/adapters.js.map +1 -0
  242. package/dist/cssm/lib/floating/functions.d.ts +10 -0
  243. package/dist/cssm/lib/floating/functions.js +28 -0
  244. package/dist/cssm/lib/floating/functions.js.map +1 -0
  245. package/dist/cssm/lib/floating/index.d.ts +4 -0
  246. package/dist/cssm/lib/floating/index.js +4 -0
  247. package/dist/cssm/lib/floating/index.js.map +1 -0
  248. package/dist/cssm/lib/floating/types.d.ts +4 -0
  249. package/dist/cssm/lib/floating/types.js +2 -0
  250. package/dist/cssm/lib/floating/types.js.map +1 -0
  251. package/dist/cssm/lib/useIsomorphicLayoutEffect.d.ts +1 -1
  252. package/dist/cssm/lib/warnOnce.d.ts +7 -0
  253. package/dist/cssm/lib/warnOnce.js +12 -0
  254. package/dist/cssm/lib/warnOnce.js.map +1 -1
  255. package/dist/cssm/styles/common.css +1 -1
  256. package/dist/cssm/styles/themes.css +1 -1
  257. package/dist/index.d.ts +37 -30
  258. package/dist/index.js +22 -16
  259. package/dist/index.js.map +1 -1
  260. package/dist/lib/floating/adapters.d.ts +2 -0
  261. package/dist/lib/floating/adapters.js +56 -0
  262. package/dist/lib/floating/adapters.js.map +1 -0
  263. package/dist/lib/floating/functions.d.ts +10 -0
  264. package/dist/lib/floating/functions.js +28 -0
  265. package/dist/lib/floating/functions.js.map +1 -0
  266. package/dist/lib/floating/index.d.ts +4 -0
  267. package/dist/lib/floating/index.js +4 -0
  268. package/dist/lib/floating/index.js.map +1 -0
  269. package/dist/lib/floating/types.d.ts +4 -0
  270. package/dist/lib/floating/types.js +2 -0
  271. package/dist/lib/floating/types.js.map +1 -0
  272. package/dist/lib/useIsomorphicLayoutEffect.d.ts +1 -1
  273. package/dist/lib/warnOnce.d.ts +7 -0
  274. package/dist/lib/warnOnce.js +12 -0
  275. package/dist/lib/warnOnce.js.map +1 -1
  276. package/dist/stable.js.tmp +69 -21
  277. package/dist/vkui.css +143 -3
  278. package/dist/vkui.css.map +1 -1
  279. package/dist/vkui.js.tmp +61837 -0
  280. package/package.json +4 -5
  281. package/dist/cssm/styles/components.css +0 -3
@@ -7,7 +7,6 @@ Object.defineProperty(exports, "__esModule", {
7
7
  });
8
8
  exports.CustomSelectDropdown = void 0;
9
9
  var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends"));
10
- var _createForOfIteratorHelper2 = _interopRequireDefault(require("@babel/runtime/helpers/createForOfIteratorHelper"));
11
10
  var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
12
11
  var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
13
12
  var React = _interopRequireWildcard(require("react"));
@@ -15,85 +14,35 @@ var _CustomScrollView = require("../CustomScrollView/CustomScrollView");
15
14
  var _vkjs = require("@vkontakte/vkjs");
16
15
  var _Popper = require("../Popper/Popper");
17
16
  var _Spinner = require("../Spinner/Spinner");
18
- var _useIsomorphicLayoutEffect = require("../../lib/useIsomorphicLayoutEffect");
19
- var _excluded = ["children", "targetRef", "scrollBoxRef", "placement", "fetching", "onPlacementChange", "offsetDistance", "sameWidth", "forcePortal", "autoHideScrollbar", "autoHideScrollbarDelay", "observableRefs", "className"];
17
+ var _excluded = ["children", "targetRef", "scrollBoxRef", "placement", "fetching", "onPlacementChange", "offsetDistance", "sameWidth", "forcePortal", "autoHideScrollbar", "autoHideScrollbarDelay", "className"];
20
18
  var calcIsTop = function calcIsTop(placement) {
21
19
  return placement === null || placement === void 0 ? void 0 : placement.includes('top');
22
20
  };
23
- function getObserverModifier(element) {
24
- return {
25
- name: 'customSelectChildrenChange',
26
- enabled: true,
27
- phase: 'main',
28
- fn: _vkjs.noop,
29
- effect: function effect(_ref) {
30
- var instance = _ref.instance;
31
- var observer = new MutationObserver(instance.forceUpdate);
32
- observer.observe(element, {
33
- childList: true,
34
- subtree: true
35
- });
36
- return function () {
37
- observer.disconnect();
38
- };
39
- }
40
- };
41
- }
42
- var CustomSelectDropdown = function CustomSelectDropdown(_ref2) {
43
- var children = _ref2.children,
44
- targetRef = _ref2.targetRef,
45
- scrollBoxRef = _ref2.scrollBoxRef,
46
- placement = _ref2.placement,
47
- fetching = _ref2.fetching,
48
- parentOnPlacementChange = _ref2.onPlacementChange,
49
- _ref2$offsetDistance = _ref2.offsetDistance,
50
- offsetDistance = _ref2$offsetDistance === void 0 ? 0 : _ref2$offsetDistance,
51
- _ref2$sameWidth = _ref2.sameWidth,
52
- sameWidth = _ref2$sameWidth === void 0 ? true : _ref2$sameWidth,
53
- _ref2$forcePortal = _ref2.forcePortal,
54
- forcePortal = _ref2$forcePortal === void 0 ? true : _ref2$forcePortal,
55
- autoHideScrollbar = _ref2.autoHideScrollbar,
56
- autoHideScrollbarDelay = _ref2.autoHideScrollbarDelay,
57
- observableRefs = _ref2.observableRefs,
58
- className = _ref2.className,
59
- restProps = (0, _objectWithoutProperties2.default)(_ref2, _excluded);
21
+ var CustomSelectDropdown = function CustomSelectDropdown(_ref) {
22
+ var children = _ref.children,
23
+ targetRef = _ref.targetRef,
24
+ scrollBoxRef = _ref.scrollBoxRef,
25
+ placement = _ref.placement,
26
+ fetching = _ref.fetching,
27
+ parentOnPlacementChange = _ref.onPlacementChange,
28
+ _ref$offsetDistance = _ref.offsetDistance,
29
+ offsetDistance = _ref$offsetDistance === void 0 ? 0 : _ref$offsetDistance,
30
+ _ref$sameWidth = _ref.sameWidth,
31
+ sameWidth = _ref$sameWidth === void 0 ? true : _ref$sameWidth,
32
+ _ref$forcePortal = _ref.forcePortal,
33
+ forcePortal = _ref$forcePortal === void 0 ? true : _ref$forcePortal,
34
+ autoHideScrollbar = _ref.autoHideScrollbar,
35
+ autoHideScrollbarDelay = _ref.autoHideScrollbarDelay,
36
+ className = _ref.className,
37
+ restProps = (0, _objectWithoutProperties2.default)(_ref, _excluded);
60
38
  var _React$useState = React.useState(function () {
61
39
  return calcIsTop(placement);
62
40
  }),
63
41
  _React$useState2 = (0, _slicedToArray2.default)(_React$useState, 2),
64
42
  isTop = _React$useState2[0],
65
43
  setIsTop = _React$useState2[1];
66
- var _React$useState3 = React.useState([]),
67
- _React$useState4 = (0, _slicedToArray2.default)(_React$useState3, 2),
68
- customModifiers = _React$useState4[0],
69
- setCustomModifiers = _React$useState4[1];
70
- (0, _useIsomorphicLayoutEffect.useIsomorphicLayoutEffect)(function () {
71
- if (!observableRefs) {
72
- return;
73
- }
74
- var customModifiers = [];
75
- if (Array.isArray(observableRefs)) {
76
- var _iterator = (0, _createForOfIteratorHelper2.default)(observableRefs),
77
- _step;
78
- try {
79
- for (_iterator.s(); !(_step = _iterator.n()).done;) {
80
- var ref = _step.value;
81
- if (ref !== null && ref !== void 0 && ref.current) {
82
- customModifiers.push(getObserverModifier(ref.current));
83
- }
84
- }
85
- } catch (err) {
86
- _iterator.e(err);
87
- } finally {
88
- _iterator.f();
89
- }
90
- } else if (observableRefs.current) {
91
- customModifiers.push(getObserverModifier(observableRefs.current));
92
- }
93
- setCustomModifiers(customModifiers);
94
- }, [observableRefs]);
95
- var onPlacementChange = React.useCallback(function (_ref3) {
96
- var placement = _ref3.placement;
44
+ var onPlacementChange = React.useCallback(function (_ref2) {
45
+ var placement = _ref2.placement;
97
46
  setIsTop(calcIsTop(placement));
98
47
  parentOnPlacementChange === null || parentOnPlacementChange === void 0 ? void 0 : parentOnPlacementChange(placement);
99
48
  }, [parentOnPlacementChange, setIsTop]);
@@ -105,7 +54,7 @@ var CustomSelectDropdown = function CustomSelectDropdown(_ref2) {
105
54
  placement: placement,
106
55
  className: (0, _vkjs.classNames)("vkuiCustomSelectDropdown", offsetDistance === 0 && (isTop ? "vkuiCustomSelectDropdown--top" : "vkuiCustomSelectDropdown--bottom"), sameWidth && "vkuiCustomSelectDropdown--wide", className),
107
56
  forcePortal: forcePortal,
108
- customModifiers: customModifiers
57
+ autoUpdateOnTargetResize: true
109
58
  }, restProps), /*#__PURE__*/React.createElement(_CustomScrollView.CustomScrollView, {
110
59
  boxRef: scrollBoxRef,
111
60
  className: "vkuiCustomSelectDropdown__in",
@@ -1 +1 @@
1
- {"version":3,"file":"CustomSelectDropdown.js","names":["calcIsTop","placement","includes","getObserverModifier","element","name","enabled","phase","fn","noop","effect","instance","observer","MutationObserver","forceUpdate","observe","childList","subtree","disconnect","CustomSelectDropdown","children","targetRef","scrollBoxRef","fetching","parentOnPlacementChange","onPlacementChange","offsetDistance","sameWidth","forcePortal","autoHideScrollbar","autoHideScrollbarDelay","observableRefs","className","restProps","React","useState","isTop","setIsTop","customModifiers","setCustomModifiers","useIsomorphicLayoutEffect","Array","isArray","ref","current","push","useCallback","classNames"],"sources":["../../../../src/components/CustomSelectDropdown/CustomSelectDropdown.tsx"],"sourcesContent":["import * as React from 'react';\nimport { Modifier } from 'react-popper';\nimport { CustomScrollView } from '../CustomScrollView/CustomScrollView';\nimport { TrackerOptionsProps } from '../CustomScrollView/useTrackerVisibility';\nimport { classNames, noop } from '@vkontakte/vkjs';\nimport { Popper, Placement } from '../Popper/Popper';\nimport { Spinner } from '../Spinner/Spinner';\nimport { HasRef } from '../../types';\nimport { useIsomorphicLayoutEffect } from '../../lib/useIsomorphicLayoutEffect';\nimport styles from './CustomSelectDropdown.module.css';\n\nexport interface CustomSelectDropdownProps\n extends React.HTMLAttributes<HTMLElement>,\n HasRef<HTMLDivElement>,\n TrackerOptionsProps {\n targetRef: React.RefObject<HTMLElement>;\n placement?: Placement;\n scrollBoxRef?: React.Ref<HTMLDivElement>;\n observableRefs?: Array<React.RefObject<HTMLElement>> | React.RefObject<HTMLElement>;\n fetching?: boolean;\n offsetDistance?: number;\n sameWidth?: boolean;\n forcePortal?: boolean;\n onPlacementChange?: (placement?: Placement) => void;\n}\n\nconst calcIsTop = (placement?: Placement) => placement?.includes('top');\n\nfunction getObserverModifier<T extends HTMLElement>(element: T): Modifier<string> {\n return {\n name: 'customSelectChildrenChange',\n enabled: true,\n phase: 'main',\n fn: noop,\n effect: ({ instance }) => {\n const observer = new MutationObserver(instance.forceUpdate);\n\n observer.observe(element, {\n childList: true,\n subtree: true,\n });\n\n return () => {\n observer.disconnect();\n };\n },\n };\n}\n\nexport const CustomSelectDropdown = ({\n children,\n targetRef,\n scrollBoxRef,\n placement,\n fetching,\n onPlacementChange: parentOnPlacementChange,\n offsetDistance = 0,\n sameWidth = true,\n forcePortal = true,\n autoHideScrollbar,\n autoHideScrollbarDelay,\n observableRefs,\n className,\n ...restProps\n}: CustomSelectDropdownProps) => {\n const [isTop, setIsTop] = React.useState(() => calcIsTop(placement));\n const [customModifiers, setCustomModifiers] = React.useState<Array<Modifier<string>>>([]);\n\n useIsomorphicLayoutEffect(() => {\n if (!observableRefs) {\n return;\n }\n const customModifiers: Array<Modifier<string>> = [];\n\n if (Array.isArray(observableRefs)) {\n for (const ref of observableRefs) {\n if (ref?.current) {\n customModifiers.push(getObserverModifier(ref.current));\n }\n }\n } else if (observableRefs.current) {\n customModifiers.push(getObserverModifier(observableRefs.current));\n }\n\n setCustomModifiers(customModifiers);\n }, [observableRefs]);\n\n const onPlacementChange = React.useCallback(\n ({ placement }: { placement?: Placement }) => {\n setIsTop(calcIsTop(placement));\n parentOnPlacementChange?.(placement);\n },\n [parentOnPlacementChange, setIsTop],\n );\n\n return (\n <Popper\n targetRef={targetRef}\n offsetDistance={offsetDistance}\n sameWidth={sameWidth}\n onPlacementChange={onPlacementChange}\n placement={placement}\n className={classNames(\n styles['CustomSelectDropdown'],\n offsetDistance === 0 &&\n (isTop ? styles['CustomSelectDropdown--top'] : styles['CustomSelectDropdown--bottom']),\n sameWidth && styles['CustomSelectDropdown--wide'],\n className,\n )}\n forcePortal={forcePortal}\n customModifiers={customModifiers}\n {...restProps}\n >\n <CustomScrollView\n boxRef={scrollBoxRef}\n className={styles['CustomSelectDropdown__in']}\n autoHideScrollbar={autoHideScrollbar}\n autoHideScrollbarDelay={autoHideScrollbarDelay}\n >\n {fetching ? (\n <div className={styles['CustomSelectDropdown__fetching']}>\n <Spinner size=\"small\" />\n </div>\n ) : (\n children\n )}\n </CustomScrollView>\n </Popper>\n );\n};\n"],"mappings":"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"}
1
+ {"version":3,"file":"CustomSelectDropdown.js","names":["calcIsTop","placement","includes","CustomSelectDropdown","children","targetRef","scrollBoxRef","fetching","parentOnPlacementChange","onPlacementChange","offsetDistance","sameWidth","forcePortal","autoHideScrollbar","autoHideScrollbarDelay","className","restProps","React","useState","isTop","setIsTop","useCallback","classNames"],"sources":["../../../../src/components/CustomSelectDropdown/CustomSelectDropdown.tsx"],"sourcesContent":["import * as React from 'react';\nimport { CustomScrollView } from '../CustomScrollView/CustomScrollView';\nimport { TrackerOptionsProps } from '../CustomScrollView/useTrackerVisibility';\nimport { classNames } from '@vkontakte/vkjs';\nimport { Popper } from '../Popper/Popper';\nimport { Spinner } from '../Spinner/Spinner';\nimport { HasRef } from '../../types';\nimport type { Placement } from '../../lib/floating';\nimport styles from './CustomSelectDropdown.module.css';\n\nexport interface CustomSelectDropdownProps\n extends React.HTMLAttributes<HTMLElement>,\n HasRef<HTMLDivElement>,\n TrackerOptionsProps {\n targetRef: React.RefObject<HTMLElement>;\n placement?: Placement;\n scrollBoxRef?: React.Ref<HTMLDivElement>;\n fetching?: boolean;\n offsetDistance?: number;\n sameWidth?: boolean;\n forcePortal?: boolean;\n onPlacementChange?: (placement?: Placement) => void;\n}\n\nconst calcIsTop = (placement?: Placement) => placement?.includes('top');\n\nexport const CustomSelectDropdown = ({\n children,\n targetRef,\n scrollBoxRef,\n placement,\n fetching,\n onPlacementChange: parentOnPlacementChange,\n offsetDistance = 0,\n sameWidth = true,\n forcePortal = true,\n autoHideScrollbar,\n autoHideScrollbarDelay,\n className,\n ...restProps\n}: CustomSelectDropdownProps) => {\n const [isTop, setIsTop] = React.useState(() => calcIsTop(placement));\n\n const onPlacementChange = React.useCallback(\n ({ placement }: { placement?: Placement }) => {\n setIsTop(calcIsTop(placement));\n parentOnPlacementChange?.(placement);\n },\n [parentOnPlacementChange, setIsTop],\n );\n\n return (\n <Popper\n targetRef={targetRef}\n offsetDistance={offsetDistance}\n sameWidth={sameWidth}\n onPlacementChange={onPlacementChange}\n placement={placement}\n className={classNames(\n styles['CustomSelectDropdown'],\n offsetDistance === 0 &&\n (isTop ? styles['CustomSelectDropdown--top'] : styles['CustomSelectDropdown--bottom']),\n sameWidth && styles['CustomSelectDropdown--wide'],\n className,\n )}\n forcePortal={forcePortal}\n autoUpdateOnTargetResize\n {...restProps}\n >\n <CustomScrollView\n boxRef={scrollBoxRef}\n className={styles['CustomSelectDropdown__in']}\n autoHideScrollbar={autoHideScrollbar}\n autoHideScrollbarDelay={autoHideScrollbarDelay}\n >\n {fetching ? (\n <div className={styles['CustomSelectDropdown__fetching']}>\n <Spinner size=\"small\" />\n </div>\n ) : (\n children\n )}\n </CustomScrollView>\n </Popper>\n );\n};\n"],"mappings":";;;;;;;;;;;AAAA;AACA;AAEA;AACA;AACA;AAA6C;AAmB7C,IAAMA,SAAS,GAAG,SAAZA,SAAS,CAAIC,SAAqB;EAAA,OAAKA,SAAS,aAATA,SAAS,uBAATA,SAAS,CAAEC,QAAQ,CAAC,KAAK,CAAC;AAAA;AAEhE,IAAMC,oBAAoB,GAAG,SAAvBA,oBAAoB,OAcA;EAAA,IAb/BC,QAAQ,QAARA,QAAQ;IACRC,SAAS,QAATA,SAAS;IACTC,YAAY,QAAZA,YAAY;IACZL,SAAS,QAATA,SAAS;IACTM,QAAQ,QAARA,QAAQ;IACWC,uBAAuB,QAA1CC,iBAAiB;IAAA,2BACjBC,cAAc;IAAdA,cAAc,oCAAG,CAAC;IAAA,sBAClBC,SAAS;IAATA,SAAS,+BAAG,IAAI;IAAA,wBAChBC,WAAW;IAAXA,WAAW,iCAAG,IAAI;IAClBC,iBAAiB,QAAjBA,iBAAiB;IACjBC,sBAAsB,QAAtBA,sBAAsB;IACtBC,SAAS,QAATA,SAAS;IACNC,SAAS;EAEZ,sBAA0BC,KAAK,CAACC,QAAQ,CAAC;MAAA,OAAMlB,SAAS,CAACC,SAAS,CAAC;IAAA,EAAC;IAAA;IAA7DkB,KAAK;IAAEC,QAAQ;EAEtB,IAAMX,iBAAiB,GAAGQ,KAAK,CAACI,WAAW,CACzC,iBAA8C;IAAA,IAA3CpB,SAAS,SAATA,SAAS;IACVmB,QAAQ,CAACpB,SAAS,CAACC,SAAS,CAAC,CAAC;IAC9BO,uBAAuB,aAAvBA,uBAAuB,uBAAvBA,uBAAuB,CAAGP,SAAS,CAAC;EACtC,CAAC,EACD,CAACO,uBAAuB,EAAEY,QAAQ,CAAC,CACpC;EAED,oBACE,oBAAC,cAAM;IACL,SAAS,EAAEf,SAAU;IACrB,cAAc,EAAEK,cAAe;IAC/B,SAAS,EAAEC,SAAU;IACrB,iBAAiB,EAAEF,iBAAkB;IACrC,SAAS,EAAER,SAAU;IACrB,SAAS,EAAE,IAAAqB,gBAAU,8BAEnBZ,cAAc,KAAK,CAAC,KACjBS,KAAK,uEAA+E,CAAC,EACxFR,SAAS,oCAAwC,EACjDI,SAAS,CACT;IACF,WAAW,EAAEH,WAAY;IACzB,wBAAwB;EAAA,GACpBI,SAAS,gBAEb,oBAAC,kCAAgB;IACf,MAAM,EAAEV,YAAa;IACrB,SAAS,gCAAqC;IAC9C,iBAAiB,EAAEO,iBAAkB;IACrC,sBAAsB,EAAEC;EAAuB,GAE9CP,QAAQ,gBACP;IAAK,SAAS;EAA2C,gBACvD,oBAAC,gBAAO;IAAC,IAAI,EAAC;EAAO,EAAG,CACpB,GAENH,QACD,CACgB,CACZ;AAEb,CAAC;AAAC"}
@@ -1,10 +1,11 @@
1
1
  import * as React from 'react';
2
2
  import { CalendarProps } from '../Calendar/Calendar';
3
- import { Placement } from '../Popper/Popper';
4
3
  import { FormFieldProps } from '../FormField/FormField';
5
4
  import { HasRootRef } from '../../types';
5
+ import type { PlacementWithAuto } from '../../lib/floating';
6
+ import '../InputLike/InputLikeDivider.module.css';
6
7
  export interface DateInputProps extends Omit<React.InputHTMLAttributes<HTMLDivElement>, 'value' | 'onChange' | 'size'>, Pick<CalendarProps, 'disablePast' | 'disableFuture' | 'enableTime' | 'shouldDisableDate' | 'onChange' | 'value' | 'doneButtonText' | 'weekStartsOn' | 'disablePickers' | 'changeHoursAriaLabel' | 'changeMinutesAriaLabel' | 'prevMonthAriaLabel' | 'nextMonthAriaLabel' | 'changeMonthAriaLabel' | 'changeYearAriaLabel' | 'changeDayAriaLabel' | 'showNeighboringMonth' | 'size' | 'viewDate' | 'onHeaderChange' | 'onNextMonth' | 'onPrevMonth' | 'prevMonthIcon' | 'nextMonthIcon'>, HasRootRef<HTMLDivElement>, FormFieldProps {
7
- calendarPlacement?: Placement;
8
+ calendarPlacement?: PlacementWithAuto;
8
9
  closeOnChange?: boolean;
9
10
  clearFieldAriaLabel?: string;
10
11
  showCalendarAriaLabel?: string;
@@ -13,11 +13,11 @@ var _date = require("../../lib/date");
13
13
  var _icons = require("@vkontakte/icons");
14
14
  var _Calendar = require("../Calendar/Calendar");
15
15
  var _Popper = require("../Popper/Popper");
16
- var _utils = require("../../lib/utils");
17
16
  var _IconButton = require("../IconButton/IconButton");
18
17
  var _vkjs = require("@vkontakte/vkjs");
19
18
  var _FormField = require("../FormField/FormField");
20
19
  var _useDateInput2 = require("../../hooks/useDateInput");
20
+ var _useExternRef = require("../../hooks/useExternRef");
21
21
  var _InputLike = require("../InputLike/InputLike");
22
22
  var _InputLikeDivider = require("../InputLike/InputLikeDivider");
23
23
  var _useAdaptivity2 = require("../../hooks/useAdaptivity");
@@ -165,6 +165,7 @@ var DateInput = function DateInput(_ref) {
165
165
  removeFocusFromField = _useDateInput.removeFocusFromField;
166
166
  var _useAdaptivity = (0, _useAdaptivity2.useAdaptivity)(),
167
167
  sizeY = _useAdaptivity.sizeY;
168
+ var handleRootRef = (0, _useExternRef.useExternRef)(rootRef, getRootRef);
168
169
  var onCalendarChange = React.useCallback(function (value) {
169
170
  onChange === null || onChange === void 0 ? void 0 : onChange(value);
170
171
  if (closeOnChange && !enableTime) {
@@ -174,7 +175,7 @@ var DateInput = function DateInput(_ref) {
174
175
  return /*#__PURE__*/React.createElement(_FormField.FormField, (0, _extends2.default)({
175
176
  style: style,
176
177
  className: (0, _vkjs.classNames)("vkuiDateInput", (0, _getSizeYClassName.getSizeYClassName)("vkuiDateInput", sizeY), className),
177
- getRootRef: (0, _utils.multiRef)(rootRef, getRootRef),
178
+ getRootRef: handleRootRef,
178
179
  after: value ? /*#__PURE__*/React.createElement(_IconButton.IconButton, {
179
180
  hoverMode: "opacity",
180
181
  "aria-label": clearFieldAriaLabel,
@@ -1 +1 @@
1
- {"version":3,"file":"DateInput.js","names":["elementsConfig","index","length","min","max","getInternalValue","value","newValue","String","getDate","padStart","getMonth","getFullYear","getHours","getMinutes","DateInput","enableTime","shouldDisableDate","disableFuture","disablePast","onChange","calendarPlacement","style","className","doneButtonText","closeOnChange","disablePickers","getRootRef","name","autoFocus","disabled","onClick","onFocus","prevMonthAriaLabel","nextMonthAriaLabel","showNeighboringMonth","size","changeMonthAriaLabel","changeYearAriaLabel","changeDayAriaLabel","changeHoursAriaLabel","changeMinutesAriaLabel","clearFieldAriaLabel","showCalendarAriaLabel","viewDate","onHeaderChange","onNextMonth","onPrevMonth","prevMonthIcon","nextMonthIcon","disableCalendar","props","daysRef","React","useRef","monthsRef","yearsRef","hoursRef","minutesRef","maxElement","onInternalValueChange","useCallback","internalValue","i","formattedValue","mask","isMatch","parse","Date","refs","useMemo","useDateInput","rootRef","calendarRef","open","openCalendar","closeCalendar","handleKeyDown","setFocusedElement","handleFieldEnter","clear","removeFocusFromField","useAdaptivity","sizeY","onCalendarChange","classNames","getSizeYClassName","multiRef","callMultiple","format"],"sources":["../../../../src/components/DateInput/DateInput.tsx"],"sourcesContent":["import * as React from 'react';\nimport { format, isMatch, parse } from '../../lib/date';\nimport { Icon16Clear, Icon20CalendarOutline } from '@vkontakte/icons';\nimport { Calendar, CalendarProps } from '../Calendar/Calendar';\nimport { Popper, Placement } from '../Popper/Popper';\nimport { multiRef } from '../../lib/utils';\nimport { IconButton } from '../IconButton/IconButton';\nimport { classNames } from '@vkontakte/vkjs';\nimport { FormField, FormFieldProps } from '../FormField/FormField';\nimport { HasRootRef } from '../../types';\nimport { useDateInput } from '../../hooks/useDateInput';\nimport { InputLike } from '../InputLike/InputLike';\nimport { InputLikeDivider } from '../InputLike/InputLikeDivider';\nimport { useAdaptivity } from '../../hooks/useAdaptivity';\nimport { callMultiple } from '../../lib/callMultiple';\nimport { getSizeYClassName } from '../../helpers/getSizeYClassName';\nimport styles from './DateInput.module.css';\n\nexport interface DateInputProps\n extends Omit<React.InputHTMLAttributes<HTMLDivElement>, 'value' | 'onChange' | 'size'>,\n Pick<\n CalendarProps,\n | 'disablePast'\n | 'disableFuture'\n | 'enableTime'\n | 'shouldDisableDate'\n | 'onChange'\n | 'value'\n | 'doneButtonText'\n | 'weekStartsOn'\n | 'disablePickers'\n | 'changeHoursAriaLabel'\n | 'changeMinutesAriaLabel'\n | 'prevMonthAriaLabel'\n | 'nextMonthAriaLabel'\n | 'changeMonthAriaLabel'\n | 'changeYearAriaLabel'\n | 'changeDayAriaLabel'\n | 'showNeighboringMonth'\n | 'size'\n | 'viewDate'\n | 'onHeaderChange'\n | 'onNextMonth'\n | 'onPrevMonth'\n | 'prevMonthIcon'\n | 'nextMonthIcon'\n >,\n HasRootRef<HTMLDivElement>,\n FormFieldProps {\n calendarPlacement?: Placement;\n closeOnChange?: boolean;\n clearFieldAriaLabel?: string;\n showCalendarAriaLabel?: string;\n disableCalendar?: boolean;\n}\n\nconst elementsConfig = (index: number) => {\n let length = 2;\n let min = 1;\n let max = 0;\n\n switch (index) {\n case 0:\n max = 31;\n break;\n case 1:\n max = 12;\n break;\n case 2:\n max = 2100;\n min = 1900;\n length = 4;\n break;\n case 3:\n max = 23;\n break;\n case 4:\n max = 59;\n break;\n }\n\n return { length, min, max };\n};\n\nconst getInternalValue = (value: CalendarProps['value']) => {\n const newValue = ['', '', '', '', ''];\n if (value) {\n newValue[0] = String(value.getDate()).padStart(2, '0');\n newValue[1] = String(value.getMonth() + 1).padStart(2, '0');\n newValue[2] = String(value.getFullYear()).padStart(4, '0');\n newValue[3] = String(value.getHours()).padStart(2, '0');\n newValue[4] = String(value.getMinutes()).padStart(2, '0');\n }\n return newValue;\n};\n\n/**\n * @see https://vkcom.github.io/VKUI/#/DateInput\n */\nexport const DateInput = ({\n enableTime,\n shouldDisableDate,\n disableFuture,\n disablePast,\n value,\n onChange,\n calendarPlacement = 'bottom-start',\n style,\n className,\n doneButtonText,\n closeOnChange = true,\n disablePickers,\n getRootRef,\n name,\n autoFocus,\n disabled,\n onClick,\n onFocus,\n prevMonthAriaLabel,\n nextMonthAriaLabel,\n showNeighboringMonth,\n size,\n changeMonthAriaLabel = 'Изменить месяц',\n changeYearAriaLabel = 'Изменить год',\n changeDayAriaLabel = 'Изменить день',\n changeHoursAriaLabel = 'Изменить час',\n changeMinutesAriaLabel = 'Изменить минуту',\n clearFieldAriaLabel = 'Очистить поле',\n showCalendarAriaLabel = 'Показать календарь',\n viewDate,\n onHeaderChange,\n onNextMonth,\n onPrevMonth,\n prevMonthIcon,\n nextMonthIcon,\n disableCalendar = false,\n ...props\n}: DateInputProps) => {\n const daysRef = React.useRef<HTMLSpanElement>(null);\n const monthsRef = React.useRef<HTMLSpanElement>(null);\n const yearsRef = React.useRef<HTMLSpanElement>(null);\n const hoursRef = React.useRef<HTMLSpanElement>(null);\n const minutesRef = React.useRef<HTMLSpanElement>(null);\n\n const maxElement = enableTime ? 4 : 2;\n\n const onInternalValueChange = React.useCallback(\n (internalValue: string[]) => {\n for (let i = 0; i <= maxElement; i += 1) {\n if (internalValue[i].length < elementsConfig(i).length) {\n return;\n }\n }\n\n let formattedValue = `${internalValue[0]}.${internalValue[1]}.${internalValue[2]}`;\n let mask = 'DD.MM.YYYY';\n if (enableTime) {\n formattedValue += ` ${internalValue[3]}:${internalValue[4]}`;\n mask += ' HH:mm';\n }\n\n if (isMatch(formattedValue, mask)) {\n onChange?.(parse(formattedValue, mask, value ?? new Date()));\n }\n },\n [enableTime, maxElement, onChange, value],\n );\n\n const refs = React.useMemo(\n () => [daysRef, monthsRef, yearsRef, hoursRef, minutesRef],\n [daysRef, monthsRef, yearsRef, hoursRef, minutesRef],\n );\n\n const {\n rootRef,\n calendarRef,\n open,\n openCalendar,\n closeCalendar,\n internalValue,\n handleKeyDown,\n setFocusedElement,\n handleFieldEnter,\n clear,\n removeFocusFromField,\n } = useDateInput({\n maxElement,\n refs,\n autoFocus,\n disabled,\n elementsConfig,\n onChange,\n onInternalValueChange,\n getInternalValue,\n value,\n });\n\n const { sizeY } = useAdaptivity();\n\n const onCalendarChange = React.useCallback(\n (value?: Date | undefined) => {\n onChange?.(value);\n if (closeOnChange && !enableTime) {\n removeFocusFromField();\n }\n },\n [onChange, removeFocusFromField, closeOnChange, enableTime],\n );\n\n return (\n <FormField\n style={style}\n className={classNames(\n styles['DateInput'],\n getSizeYClassName(styles['DateInput'], sizeY),\n className,\n )}\n getRootRef={multiRef(rootRef, getRootRef)}\n after={\n value ? (\n <IconButton hoverMode=\"opacity\" aria-label={clearFieldAriaLabel} onClick={clear}>\n <Icon16Clear />\n </IconButton>\n ) : (\n <IconButton hoverMode=\"opacity\" aria-label={showCalendarAriaLabel} onClick={openCalendar}>\n <Icon20CalendarOutline />\n </IconButton>\n )\n }\n disabled={disabled}\n onClick={callMultiple(handleFieldEnter, onClick)}\n onFocus={callMultiple(handleFieldEnter, onFocus)}\n {...props}\n >\n <input\n type=\"hidden\"\n name={name}\n value={value ? format(value, enableTime ? 'DD.MM.YYYYTHH:mm' : 'DD.MM.YYYY') : ''}\n />\n <span className={styles['DateInput__input']} onKeyDown={handleKeyDown}>\n <InputLike\n length={2}\n getRootRef={daysRef}\n index={0}\n onElementSelect={setFocusedElement}\n value={internalValue[0]}\n aria-label={changeDayAriaLabel}\n />\n <InputLikeDivider>.</InputLikeDivider>\n <InputLike\n length={2}\n getRootRef={monthsRef}\n index={1}\n onElementSelect={setFocusedElement}\n value={internalValue[1]}\n aria-label={changeMonthAriaLabel}\n />\n <InputLikeDivider>.</InputLikeDivider>\n <InputLike\n length={4}\n getRootRef={yearsRef}\n index={2}\n onElementSelect={setFocusedElement}\n value={internalValue[2]}\n aria-label={changeYearAriaLabel}\n />\n {enableTime && (\n <React.Fragment>\n <InputLikeDivider className={styles['DateInput__input--time-divider']}>\n {' '}\n </InputLikeDivider>\n <InputLike\n length={2}\n getRootRef={hoursRef}\n index={3}\n onElementSelect={setFocusedElement}\n value={internalValue[3]}\n aria-label={changeHoursAriaLabel}\n />\n <InputLikeDivider>:</InputLikeDivider>\n <InputLike\n length={2}\n getRootRef={minutesRef}\n index={4}\n onElementSelect={setFocusedElement}\n value={internalValue[4]}\n aria-label={changeMinutesAriaLabel}\n />\n </React.Fragment>\n )}\n </span>\n {open && !disableCalendar && (\n <Popper targetRef={rootRef} offsetDistance={8} placement={calendarPlacement}>\n <Calendar\n value={value}\n onChange={onCalendarChange}\n enableTime={enableTime}\n disablePast={disablePast}\n disableFuture={disableFuture}\n shouldDisableDate={shouldDisableDate}\n onClose={closeCalendar}\n getRootRef={calendarRef}\n doneButtonText={doneButtonText}\n disablePickers={disablePickers}\n changeHoursAriaLabel={changeHoursAriaLabel}\n changeMinutesAriaLabel={changeMinutesAriaLabel}\n prevMonthAriaLabel={prevMonthAriaLabel}\n nextMonthAriaLabel={nextMonthAriaLabel}\n changeMonthAriaLabel={changeMonthAriaLabel}\n changeYearAriaLabel={changeYearAriaLabel}\n changeDayAriaLabel={changeDayAriaLabel}\n showNeighboringMonth={showNeighboringMonth}\n size={size}\n viewDate={viewDate}\n onHeaderChange={onHeaderChange}\n onNextMonth={onNextMonth}\n onPrevMonth={onPrevMonth}\n prevMonthIcon={prevMonthIcon}\n nextMonthIcon={nextMonthIcon}\n />\n </Popper>\n )}\n </FormField>\n );\n};\n"],"mappings":"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"}
1
+ {"version":3,"file":"DateInput.js","names":["elementsConfig","index","length","min","max","getInternalValue","value","newValue","String","getDate","padStart","getMonth","getFullYear","getHours","getMinutes","DateInput","enableTime","shouldDisableDate","disableFuture","disablePast","onChange","calendarPlacement","style","className","doneButtonText","closeOnChange","disablePickers","getRootRef","name","autoFocus","disabled","onClick","onFocus","prevMonthAriaLabel","nextMonthAriaLabel","showNeighboringMonth","size","changeMonthAriaLabel","changeYearAriaLabel","changeDayAriaLabel","changeHoursAriaLabel","changeMinutesAriaLabel","clearFieldAriaLabel","showCalendarAriaLabel","viewDate","onHeaderChange","onNextMonth","onPrevMonth","prevMonthIcon","nextMonthIcon","disableCalendar","props","daysRef","React","useRef","monthsRef","yearsRef","hoursRef","minutesRef","maxElement","onInternalValueChange","useCallback","internalValue","i","formattedValue","mask","isMatch","parse","Date","refs","useMemo","useDateInput","rootRef","calendarRef","open","openCalendar","closeCalendar","handleKeyDown","setFocusedElement","handleFieldEnter","clear","removeFocusFromField","useAdaptivity","sizeY","handleRootRef","useExternRef","onCalendarChange","classNames","getSizeYClassName","callMultiple","format"],"sources":["../../../../src/components/DateInput/DateInput.tsx"],"sourcesContent":["import * as React from 'react';\nimport { format, isMatch, parse } from '../../lib/date';\nimport { Icon16Clear, Icon20CalendarOutline } from '@vkontakte/icons';\nimport { Calendar, CalendarProps } from '../Calendar/Calendar';\nimport { Popper } from '../Popper/Popper';\nimport { IconButton } from '../IconButton/IconButton';\nimport { classNames } from '@vkontakte/vkjs';\nimport { FormField, FormFieldProps } from '../FormField/FormField';\nimport { HasRootRef } from '../../types';\nimport { useDateInput } from '../../hooks/useDateInput';\nimport { useExternRef } from '../../hooks/useExternRef';\nimport { InputLike } from '../InputLike/InputLike';\nimport { InputLikeDivider } from '../InputLike/InputLikeDivider';\nimport { useAdaptivity } from '../../hooks/useAdaptivity';\nimport type { PlacementWithAuto } from '../../lib/floating';\nimport { callMultiple } from '../../lib/callMultiple';\nimport { getSizeYClassName } from '../../helpers/getSizeYClassName';\nimport '../InputLike/InputLikeDivider.module.css'; // Reorder css\nimport styles from './DateInput.module.css';\n\nexport interface DateInputProps\n extends Omit<React.InputHTMLAttributes<HTMLDivElement>, 'value' | 'onChange' | 'size'>,\n Pick<\n CalendarProps,\n | 'disablePast'\n | 'disableFuture'\n | 'enableTime'\n | 'shouldDisableDate'\n | 'onChange'\n | 'value'\n | 'doneButtonText'\n | 'weekStartsOn'\n | 'disablePickers'\n | 'changeHoursAriaLabel'\n | 'changeMinutesAriaLabel'\n | 'prevMonthAriaLabel'\n | 'nextMonthAriaLabel'\n | 'changeMonthAriaLabel'\n | 'changeYearAriaLabel'\n | 'changeDayAriaLabel'\n | 'showNeighboringMonth'\n | 'size'\n | 'viewDate'\n | 'onHeaderChange'\n | 'onNextMonth'\n | 'onPrevMonth'\n | 'prevMonthIcon'\n | 'nextMonthIcon'\n >,\n HasRootRef<HTMLDivElement>,\n FormFieldProps {\n calendarPlacement?: PlacementWithAuto;\n closeOnChange?: boolean;\n clearFieldAriaLabel?: string;\n showCalendarAriaLabel?: string;\n disableCalendar?: boolean;\n}\n\nconst elementsConfig = (index: number) => {\n let length = 2;\n let min = 1;\n let max = 0;\n\n switch (index) {\n case 0:\n max = 31;\n break;\n case 1:\n max = 12;\n break;\n case 2:\n max = 2100;\n min = 1900;\n length = 4;\n break;\n case 3:\n max = 23;\n break;\n case 4:\n max = 59;\n break;\n }\n\n return { length, min, max };\n};\n\nconst getInternalValue = (value: CalendarProps['value']) => {\n const newValue = ['', '', '', '', ''];\n if (value) {\n newValue[0] = String(value.getDate()).padStart(2, '0');\n newValue[1] = String(value.getMonth() + 1).padStart(2, '0');\n newValue[2] = String(value.getFullYear()).padStart(4, '0');\n newValue[3] = String(value.getHours()).padStart(2, '0');\n newValue[4] = String(value.getMinutes()).padStart(2, '0');\n }\n return newValue;\n};\n\n/**\n * @see https://vkcom.github.io/VKUI/#/DateInput\n */\nexport const DateInput = ({\n enableTime,\n shouldDisableDate,\n disableFuture,\n disablePast,\n value,\n onChange,\n calendarPlacement = 'bottom-start',\n style,\n className,\n doneButtonText,\n closeOnChange = true,\n disablePickers,\n getRootRef,\n name,\n autoFocus,\n disabled,\n onClick,\n onFocus,\n prevMonthAriaLabel,\n nextMonthAriaLabel,\n showNeighboringMonth,\n size,\n changeMonthAriaLabel = 'Изменить месяц',\n changeYearAriaLabel = 'Изменить год',\n changeDayAriaLabel = 'Изменить день',\n changeHoursAriaLabel = 'Изменить час',\n changeMinutesAriaLabel = 'Изменить минуту',\n clearFieldAriaLabel = 'Очистить поле',\n showCalendarAriaLabel = 'Показать календарь',\n viewDate,\n onHeaderChange,\n onNextMonth,\n onPrevMonth,\n prevMonthIcon,\n nextMonthIcon,\n disableCalendar = false,\n ...props\n}: DateInputProps) => {\n const daysRef = React.useRef<HTMLSpanElement>(null);\n const monthsRef = React.useRef<HTMLSpanElement>(null);\n const yearsRef = React.useRef<HTMLSpanElement>(null);\n const hoursRef = React.useRef<HTMLSpanElement>(null);\n const minutesRef = React.useRef<HTMLSpanElement>(null);\n\n const maxElement = enableTime ? 4 : 2;\n\n const onInternalValueChange = React.useCallback(\n (internalValue: string[]) => {\n for (let i = 0; i <= maxElement; i += 1) {\n if (internalValue[i].length < elementsConfig(i).length) {\n return;\n }\n }\n\n let formattedValue = `${internalValue[0]}.${internalValue[1]}.${internalValue[2]}`;\n let mask = 'DD.MM.YYYY';\n if (enableTime) {\n formattedValue += ` ${internalValue[3]}:${internalValue[4]}`;\n mask += ' HH:mm';\n }\n\n if (isMatch(formattedValue, mask)) {\n onChange?.(parse(formattedValue, mask, value ?? new Date()));\n }\n },\n [enableTime, maxElement, onChange, value],\n );\n\n const refs = React.useMemo(\n () => [daysRef, monthsRef, yearsRef, hoursRef, minutesRef],\n [daysRef, monthsRef, yearsRef, hoursRef, minutesRef],\n );\n\n const {\n rootRef,\n calendarRef,\n open,\n openCalendar,\n closeCalendar,\n internalValue,\n handleKeyDown,\n setFocusedElement,\n handleFieldEnter,\n clear,\n removeFocusFromField,\n } = useDateInput({\n maxElement,\n refs,\n autoFocus,\n disabled,\n elementsConfig,\n onChange,\n onInternalValueChange,\n getInternalValue,\n value,\n });\n\n const { sizeY } = useAdaptivity();\n\n const handleRootRef = useExternRef(rootRef, getRootRef);\n\n const onCalendarChange = React.useCallback(\n (value?: Date | undefined) => {\n onChange?.(value);\n if (closeOnChange && !enableTime) {\n removeFocusFromField();\n }\n },\n [onChange, removeFocusFromField, closeOnChange, enableTime],\n );\n\n return (\n <FormField\n style={style}\n className={classNames(\n styles['DateInput'],\n getSizeYClassName(styles['DateInput'], sizeY),\n className,\n )}\n getRootRef={handleRootRef}\n after={\n value ? (\n <IconButton hoverMode=\"opacity\" aria-label={clearFieldAriaLabel} onClick={clear}>\n <Icon16Clear />\n </IconButton>\n ) : (\n <IconButton hoverMode=\"opacity\" aria-label={showCalendarAriaLabel} onClick={openCalendar}>\n <Icon20CalendarOutline />\n </IconButton>\n )\n }\n disabled={disabled}\n onClick={callMultiple(handleFieldEnter, onClick)}\n onFocus={callMultiple(handleFieldEnter, onFocus)}\n {...props}\n >\n <input\n type=\"hidden\"\n name={name}\n value={value ? format(value, enableTime ? 'DD.MM.YYYYTHH:mm' : 'DD.MM.YYYY') : ''}\n />\n <span className={styles['DateInput__input']} onKeyDown={handleKeyDown}>\n <InputLike\n length={2}\n getRootRef={daysRef}\n index={0}\n onElementSelect={setFocusedElement}\n value={internalValue[0]}\n aria-label={changeDayAriaLabel}\n />\n <InputLikeDivider>.</InputLikeDivider>\n <InputLike\n length={2}\n getRootRef={monthsRef}\n index={1}\n onElementSelect={setFocusedElement}\n value={internalValue[1]}\n aria-label={changeMonthAriaLabel}\n />\n <InputLikeDivider>.</InputLikeDivider>\n <InputLike\n length={4}\n getRootRef={yearsRef}\n index={2}\n onElementSelect={setFocusedElement}\n value={internalValue[2]}\n aria-label={changeYearAriaLabel}\n />\n {enableTime && (\n <React.Fragment>\n <InputLikeDivider className={styles['DateInput__input--time-divider']}>\n {' '}\n </InputLikeDivider>\n <InputLike\n length={2}\n getRootRef={hoursRef}\n index={3}\n onElementSelect={setFocusedElement}\n value={internalValue[3]}\n aria-label={changeHoursAriaLabel}\n />\n <InputLikeDivider>:</InputLikeDivider>\n <InputLike\n length={2}\n getRootRef={minutesRef}\n index={4}\n onElementSelect={setFocusedElement}\n value={internalValue[4]}\n aria-label={changeMinutesAriaLabel}\n />\n </React.Fragment>\n )}\n </span>\n {open && !disableCalendar && (\n <Popper targetRef={rootRef} offsetDistance={8} placement={calendarPlacement}>\n <Calendar\n value={value}\n onChange={onCalendarChange}\n enableTime={enableTime}\n disablePast={disablePast}\n disableFuture={disableFuture}\n shouldDisableDate={shouldDisableDate}\n onClose={closeCalendar}\n getRootRef={calendarRef}\n doneButtonText={doneButtonText}\n disablePickers={disablePickers}\n changeHoursAriaLabel={changeHoursAriaLabel}\n changeMinutesAriaLabel={changeMinutesAriaLabel}\n prevMonthAriaLabel={prevMonthAriaLabel}\n nextMonthAriaLabel={nextMonthAriaLabel}\n changeMonthAriaLabel={changeMonthAriaLabel}\n changeYearAriaLabel={changeYearAriaLabel}\n changeDayAriaLabel={changeDayAriaLabel}\n showNeighboringMonth={showNeighboringMonth}\n size={size}\n viewDate={viewDate}\n onHeaderChange={onHeaderChange}\n onNextMonth={onNextMonth}\n onPrevMonth={onPrevMonth}\n prevMonthIcon={prevMonthIcon}\n nextMonthIcon={nextMonthIcon}\n />\n </Popper>\n )}\n </FormField>\n );\n};\n"],"mappings":"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"}
@@ -1,10 +1,10 @@
1
1
  import * as React from 'react';
2
2
  import { CalendarRangeProps } from '../CalendarRange/CalendarRange';
3
- import { Placement } from '../Popper/Popper';
4
3
  import { HasRootRef } from '../../types';
4
+ import type { PlacementWithAuto } from '../../lib/floating';
5
5
  import { FormFieldProps } from '../FormField/FormField';
6
6
  export interface DateRangeInputProps extends Omit<React.InputHTMLAttributes<HTMLDivElement>, 'value' | 'onChange'>, Pick<CalendarRangeProps, 'disablePast' | 'disableFuture' | 'shouldDisableDate' | 'onChange' | 'value' | 'weekStartsOn' | 'disablePickers' | 'prevMonthAriaLabel' | 'nextMonthAriaLabel' | 'changeMonthAriaLabel' | 'changeYearAriaLabel' | 'changeDayAriaLabel' | 'prevMonthIcon' | 'nextMonthIcon'>, HasRootRef<HTMLDivElement>, FormFieldProps {
7
- calendarPlacement?: Placement;
7
+ calendarPlacement?: PlacementWithAuto;
8
8
  closeOnChange?: boolean;
9
9
  clearFieldAriaLabel?: string;
10
10
  showCalendarAriaLabel?: string;
@@ -16,8 +16,8 @@ var _Popper = require("../Popper/Popper");
16
16
  var _IconButton = require("../IconButton/IconButton");
17
17
  var _useDateInput2 = require("../../hooks/useDateInput");
18
18
  var _useAdaptivity2 = require("../../hooks/useAdaptivity");
19
+ var _useExternRef = require("../../hooks/useExternRef");
19
20
  var _vkjs = require("@vkontakte/vkjs");
20
- var _utils = require("../../lib/utils");
21
21
  var _FormField = require("../FormField/FormField");
22
22
  var _InputLike = require("../InputLike/InputLike");
23
23
  var _InputLikeDivider = require("../InputLike/InputLikeDivider");
@@ -179,6 +179,7 @@ var DateRangeInput = function DateRangeInput(_ref) {
179
179
  removeFocusFromField = _useDateInput.removeFocusFromField;
180
180
  var _useAdaptivity = (0, _useAdaptivity2.useAdaptivity)(),
181
181
  sizeY = _useAdaptivity.sizeY;
182
+ var handleRootRef = (0, _useExternRef.useExternRef)(rootRef, getRootRef);
182
183
  var onCalendarChange = React.useCallback(function (newValue) {
183
184
  onChange === null || onChange === void 0 ? void 0 : onChange(newValue);
184
185
  if (closeOnChange && newValue !== null && newValue !== void 0 && newValue[1] && newValue[1] !== (value === null || value === void 0 ? void 0 : value[1])) {
@@ -188,7 +189,7 @@ var DateRangeInput = function DateRangeInput(_ref) {
188
189
  return /*#__PURE__*/React.createElement(_FormField.FormField, (0, _extends2.default)({
189
190
  style: style,
190
191
  className: (0, _vkjs.classNames)("vkuiDateRangeInput", (0, _getSizeYClassName.getSizeYClassName)("vkuiDateRangeInput", sizeY), className),
191
- getRootRef: (0, _utils.multiRef)(rootRef, getRootRef),
192
+ getRootRef: handleRootRef,
192
193
  after: value ? /*#__PURE__*/React.createElement(_IconButton.IconButton, {
193
194
  hoverMode: "opacity",
194
195
  "aria-label": clearFieldAriaLabel,
@@ -1 +1 @@
1
- {"version":3,"file":"DateRangeInput.js","names":["elementsConfig","index","length","min","max","getInternalValue","value","newValue","String","getDate","padStart","getMonth","getFullYear","DateRangeInput","shouldDisableDate","disableFuture","disablePast","onChange","calendarPlacement","style","className","closeOnChange","disablePickers","getRootRef","name","autoFocus","disabled","onClick","onFocus","prevMonthAriaLabel","nextMonthAriaLabel","changeDayAriaLabel","changeMonthAriaLabel","changeYearAriaLabel","changeStartDayAriaLabel","changeStartMonthAriaLabel","changeStartYearAriaLabel","changeEndDayAriaLabel","changeEndMonthAriaLabel","changeEndYearAriaLabel","clearFieldAriaLabel","showCalendarAriaLabel","prevMonthIcon","nextMonthIcon","disableCalendar","props","daysStartRef","React","useRef","monthsStartRef","yearsStartRef","daysEndRef","monthsEndRef","yearsEndRef","onInternalValueChange","useCallback","internalValue","isStartValid","isEndValid","i","formattedStartValue","formattedEndValue","mask","isMatch","valueExists","Array","isArray","now","Date","start","parse","end","isAfter","refs","useMemo","useDateInput","maxElement","rootRef","calendarRef","open","openCalendar","closeCalendar","handleKeyDown","setFocusedElement","handleFieldEnter","clear","removeFocusFromField","useAdaptivity","sizeY","onCalendarChange","classNames","getSizeYClassName","multiRef","callMultiple","format"],"sources":["../../../../src/components/DateRangeInput/DateRangeInput.tsx"],"sourcesContent":["import * as React from 'react';\nimport { format, isMatch, parse, isAfter } from '../../lib/date';\nimport { Icon16Clear, Icon20CalendarOutline } from '@vkontakte/icons';\nimport { CalendarRange, CalendarRangeProps } from '../CalendarRange/CalendarRange';\nimport { Popper, Placement } from '../Popper/Popper';\nimport { IconButton } from '../IconButton/IconButton';\nimport { HasRootRef } from '../../types';\nimport { useDateInput } from '../../hooks/useDateInput';\nimport { useAdaptivity } from '../../hooks/useAdaptivity';\nimport { classNames } from '@vkontakte/vkjs';\nimport { multiRef } from '../../lib/utils';\nimport { FormField, FormFieldProps } from '../FormField/FormField';\nimport { InputLike } from '../InputLike/InputLike';\nimport { InputLikeDivider } from '../InputLike/InputLikeDivider';\nimport { callMultiple } from '../../lib/callMultiple';\nimport { getSizeYClassName } from '../../helpers/getSizeYClassName';\nimport styles from './DateRangeInput.module.css';\nimport dateInputStyles from '../DateInput/DateInput.module.css';\n\nexport interface DateRangeInputProps\n extends Omit<React.InputHTMLAttributes<HTMLDivElement>, 'value' | 'onChange'>,\n Pick<\n CalendarRangeProps,\n | 'disablePast'\n | 'disableFuture'\n | 'shouldDisableDate'\n | 'onChange'\n | 'value'\n | 'weekStartsOn'\n | 'disablePickers'\n | 'prevMonthAriaLabel'\n | 'nextMonthAriaLabel'\n | 'changeMonthAriaLabel'\n | 'changeYearAriaLabel'\n | 'changeDayAriaLabel'\n | 'prevMonthIcon'\n | 'nextMonthIcon'\n >,\n HasRootRef<HTMLDivElement>,\n FormFieldProps {\n calendarPlacement?: Placement;\n closeOnChange?: boolean;\n clearFieldAriaLabel?: string;\n showCalendarAriaLabel?: string;\n changeStartDayAriaLabel?: string;\n changeStartMonthAriaLabel?: string;\n changeStartYearAriaLabel?: string;\n changeEndDayAriaLabel?: string;\n changeEndMonthAriaLabel?: string;\n changeEndYearAriaLabel?: string;\n disableCalendar?: boolean;\n}\n\nconst elementsConfig = (index: number) => {\n let length = 2;\n let min = 1;\n let max = 0;\n\n switch (index) {\n case 0:\n case 3:\n max = 31;\n break;\n case 1:\n case 4:\n max = 12;\n break;\n case 2:\n case 5:\n max = 2100;\n min = 1900;\n length = 4;\n break;\n }\n\n return { length, min, max };\n};\n\nconst getInternalValue = (value: CalendarRangeProps['value']) => {\n const newValue = ['', '', '', '', '', ''];\n if (value?.[0]) {\n newValue[0] = String(value[0].getDate()).padStart(2, '0');\n newValue[1] = String(value[0].getMonth() + 1).padStart(2, '0');\n newValue[2] = String(value[0].getFullYear()).padStart(4, '0');\n }\n if (value?.[1]) {\n newValue[3] = String(value[1].getDate()).padStart(2, '0');\n newValue[4] = String(value[1].getMonth() + 1).padStart(2, '0');\n newValue[5] = String(value[1].getFullYear()).padStart(4, '0');\n }\n return newValue;\n};\n\n/**\n * @see https://vkcom.github.io/VKUI/#/DateRangeInput\n */\nexport const DateRangeInput = ({\n shouldDisableDate,\n disableFuture,\n disablePast,\n value,\n onChange,\n calendarPlacement = 'bottom-start',\n style,\n className,\n closeOnChange = true,\n disablePickers,\n getRootRef,\n name,\n autoFocus,\n disabled,\n onClick,\n onFocus,\n prevMonthAriaLabel,\n nextMonthAriaLabel,\n changeDayAriaLabel,\n changeMonthAriaLabel,\n changeYearAriaLabel,\n changeStartDayAriaLabel = 'Изменить день начала',\n changeStartMonthAriaLabel = 'Изменить месяц начала',\n changeStartYearAriaLabel = 'Изменить год начала',\n changeEndDayAriaLabel = 'Изменить день окончания',\n changeEndMonthAriaLabel = 'Изменить месяц окончания',\n changeEndYearAriaLabel = 'Изменить год окончания',\n clearFieldAriaLabel = 'Очистить поле',\n showCalendarAriaLabel = 'Показать календарь',\n prevMonthIcon,\n nextMonthIcon,\n disableCalendar = false,\n ...props\n}: DateRangeInputProps) => {\n const daysStartRef = React.useRef<HTMLSpanElement>(null);\n const monthsStartRef = React.useRef<HTMLSpanElement>(null);\n const yearsStartRef = React.useRef<HTMLSpanElement>(null);\n const daysEndRef = React.useRef<HTMLSpanElement>(null);\n const monthsEndRef = React.useRef<HTMLSpanElement>(null);\n const yearsEndRef = React.useRef<HTMLSpanElement>(null);\n\n const onInternalValueChange = React.useCallback(\n (internalValue: string[]) => {\n let isStartValid = true;\n let isEndValid = true;\n for (let i = 0; i <= 2; i += 1) {\n if (internalValue[i].length < elementsConfig(i).length) {\n isStartValid = false;\n }\n }\n for (let i = 3; i <= 5; i += 1) {\n if (internalValue[i].length < elementsConfig(i).length) {\n isEndValid = false;\n }\n }\n const formattedStartValue = `${internalValue[0]}.${internalValue[1]}.${internalValue[2]}`;\n const formattedEndValue = `${internalValue[3]}.${internalValue[4]}.${internalValue[5]}`;\n const mask = 'dd.MM.yyyy';\n\n if (!isMatch(formattedStartValue, mask)) {\n isStartValid = false;\n }\n if (!isMatch(formattedEndValue, mask)) {\n isEndValid = false;\n }\n\n if (!isStartValid && !isEndValid) {\n return;\n }\n\n const valueExists = Array.isArray(value);\n const now = new Date();\n const start = isStartValid\n ? parse(formattedStartValue, mask, (valueExists && value?.[0]) || now)\n : null;\n const end = isEndValid\n ? parse(formattedEndValue, mask, (valueExists && value?.[1]) || now)\n : null;\n if (start && end && isAfter(end, start)) {\n onChange?.([start, end]);\n }\n },\n [onChange, value],\n );\n\n const refs = React.useMemo(\n () => [daysStartRef, monthsStartRef, yearsStartRef, daysEndRef, monthsEndRef, yearsEndRef],\n [daysStartRef, monthsStartRef, yearsStartRef, daysEndRef, monthsEndRef, yearsEndRef],\n );\n\n const {\n rootRef,\n calendarRef,\n open,\n openCalendar,\n closeCalendar,\n internalValue,\n handleKeyDown,\n setFocusedElement,\n handleFieldEnter,\n clear,\n removeFocusFromField,\n } = useDateInput({\n maxElement: 5,\n refs,\n autoFocus,\n disabled,\n elementsConfig,\n onChange,\n onInternalValueChange,\n getInternalValue,\n value,\n });\n\n const { sizeY } = useAdaptivity();\n\n const onCalendarChange = React.useCallback(\n (newValue?: Array<Date | null> | undefined) => {\n onChange?.(newValue);\n if (closeOnChange && newValue?.[1] && newValue[1] !== value?.[1]) {\n removeFocusFromField();\n }\n },\n [onChange, closeOnChange, value, removeFocusFromField],\n );\n\n return (\n <FormField\n style={style}\n className={classNames(\n styles['DateRangeInput'],\n getSizeYClassName(styles['DateRangeInput'], sizeY),\n className,\n )}\n getRootRef={multiRef(rootRef, getRootRef)}\n after={\n value ? (\n <IconButton hoverMode=\"opacity\" aria-label={clearFieldAriaLabel} onClick={clear}>\n <Icon16Clear />\n </IconButton>\n ) : (\n <IconButton hoverMode=\"opacity\" aria-label={showCalendarAriaLabel} onClick={openCalendar}>\n <Icon20CalendarOutline />\n </IconButton>\n )\n }\n disabled={disabled}\n onClick={callMultiple(handleFieldEnter, onClick)}\n onFocus={callMultiple(handleFieldEnter, onFocus)}\n {...props}\n >\n <input\n type=\"hidden\"\n name={name}\n value={\n value\n ? `${value[0] ? format(value[0], 'DD.MM.YYYY') : ''} - ${\n value[1] ? format(value[1], 'DD.MM.YYYY') : ''\n }`\n : ''\n }\n />\n <span className={dateInputStyles['DateInput__input']} onKeyDown={handleKeyDown}>\n <InputLike\n length={2}\n getRootRef={daysStartRef}\n index={0}\n onElementSelect={setFocusedElement}\n value={internalValue[0]}\n aria-label={changeStartDayAriaLabel}\n />\n <InputLikeDivider>.</InputLikeDivider>\n <InputLike\n length={2}\n getRootRef={monthsStartRef}\n index={1}\n onElementSelect={setFocusedElement}\n value={internalValue[1]}\n aria-label={changeStartMonthAriaLabel}\n />\n <InputLikeDivider>.</InputLikeDivider>\n <InputLike\n length={4}\n getRootRef={yearsStartRef}\n index={2}\n onElementSelect={setFocusedElement}\n value={internalValue[2]}\n aria-label={changeStartYearAriaLabel}\n />\n <InputLikeDivider>{' — '}</InputLikeDivider>\n <InputLike\n length={2}\n getRootRef={daysEndRef}\n index={3}\n onElementSelect={setFocusedElement}\n value={internalValue[3]}\n aria-label={changeEndDayAriaLabel}\n />\n <InputLikeDivider>.</InputLikeDivider>\n <InputLike\n length={2}\n getRootRef={monthsEndRef}\n index={4}\n onElementSelect={setFocusedElement}\n value={internalValue[4]}\n aria-label={changeEndMonthAriaLabel}\n />\n <InputLikeDivider>.</InputLikeDivider>\n <InputLike\n length={4}\n getRootRef={yearsEndRef}\n index={5}\n onElementSelect={setFocusedElement}\n value={internalValue[5]}\n aria-label={changeEndYearAriaLabel}\n />\n </span>\n {open && !disableCalendar && (\n <Popper targetRef={rootRef} offsetDistance={8} placement={calendarPlacement}>\n <CalendarRange\n value={value}\n onChange={onCalendarChange}\n disablePast={disablePast}\n disableFuture={disableFuture}\n shouldDisableDate={shouldDisableDate}\n onClose={closeCalendar}\n getRootRef={calendarRef}\n disablePickers={disablePickers}\n prevMonthAriaLabel={prevMonthAriaLabel}\n nextMonthAriaLabel={nextMonthAriaLabel}\n changeMonthAriaLabel={changeMonthAriaLabel}\n changeYearAriaLabel={changeYearAriaLabel}\n changeDayAriaLabel={changeDayAriaLabel}\n prevMonthIcon={prevMonthIcon}\n nextMonthIcon={nextMonthIcon}\n />\n </Popper>\n )}\n </FormField>\n );\n};\n"],"mappings":"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"}
1
+ {"version":3,"file":"DateRangeInput.js","names":["elementsConfig","index","length","min","max","getInternalValue","value","newValue","String","getDate","padStart","getMonth","getFullYear","DateRangeInput","shouldDisableDate","disableFuture","disablePast","onChange","calendarPlacement","style","className","closeOnChange","disablePickers","getRootRef","name","autoFocus","disabled","onClick","onFocus","prevMonthAriaLabel","nextMonthAriaLabel","changeDayAriaLabel","changeMonthAriaLabel","changeYearAriaLabel","changeStartDayAriaLabel","changeStartMonthAriaLabel","changeStartYearAriaLabel","changeEndDayAriaLabel","changeEndMonthAriaLabel","changeEndYearAriaLabel","clearFieldAriaLabel","showCalendarAriaLabel","prevMonthIcon","nextMonthIcon","disableCalendar","props","daysStartRef","React","useRef","monthsStartRef","yearsStartRef","daysEndRef","monthsEndRef","yearsEndRef","onInternalValueChange","useCallback","internalValue","isStartValid","isEndValid","i","formattedStartValue","formattedEndValue","mask","isMatch","valueExists","Array","isArray","now","Date","start","parse","end","isAfter","refs","useMemo","useDateInput","maxElement","rootRef","calendarRef","open","openCalendar","closeCalendar","handleKeyDown","setFocusedElement","handleFieldEnter","clear","removeFocusFromField","useAdaptivity","sizeY","handleRootRef","useExternRef","onCalendarChange","classNames","getSizeYClassName","callMultiple","format"],"sources":["../../../../src/components/DateRangeInput/DateRangeInput.tsx"],"sourcesContent":["import * as React from 'react';\nimport { format, isMatch, parse, isAfter } from '../../lib/date';\nimport { Icon16Clear, Icon20CalendarOutline } from '@vkontakte/icons';\nimport { CalendarRange, CalendarRangeProps } from '../CalendarRange/CalendarRange';\nimport { Popper } from '../Popper/Popper';\nimport { IconButton } from '../IconButton/IconButton';\nimport { HasRootRef } from '../../types';\nimport type { PlacementWithAuto } from '../../lib/floating';\nimport { useDateInput } from '../../hooks/useDateInput';\nimport { useAdaptivity } from '../../hooks/useAdaptivity';\nimport { useExternRef } from '../../hooks/useExternRef';\nimport { classNames } from '@vkontakte/vkjs';\nimport { FormField, FormFieldProps } from '../FormField/FormField';\nimport { InputLike } from '../InputLike/InputLike';\nimport { InputLikeDivider } from '../InputLike/InputLikeDivider';\nimport { callMultiple } from '../../lib/callMultiple';\nimport { getSizeYClassName } from '../../helpers/getSizeYClassName';\nimport styles from './DateRangeInput.module.css';\nimport dateInputStyles from '../DateInput/DateInput.module.css';\n\nexport interface DateRangeInputProps\n extends Omit<React.InputHTMLAttributes<HTMLDivElement>, 'value' | 'onChange'>,\n Pick<\n CalendarRangeProps,\n | 'disablePast'\n | 'disableFuture'\n | 'shouldDisableDate'\n | 'onChange'\n | 'value'\n | 'weekStartsOn'\n | 'disablePickers'\n | 'prevMonthAriaLabel'\n | 'nextMonthAriaLabel'\n | 'changeMonthAriaLabel'\n | 'changeYearAriaLabel'\n | 'changeDayAriaLabel'\n | 'prevMonthIcon'\n | 'nextMonthIcon'\n >,\n HasRootRef<HTMLDivElement>,\n FormFieldProps {\n calendarPlacement?: PlacementWithAuto;\n closeOnChange?: boolean;\n clearFieldAriaLabel?: string;\n showCalendarAriaLabel?: string;\n changeStartDayAriaLabel?: string;\n changeStartMonthAriaLabel?: string;\n changeStartYearAriaLabel?: string;\n changeEndDayAriaLabel?: string;\n changeEndMonthAriaLabel?: string;\n changeEndYearAriaLabel?: string;\n disableCalendar?: boolean;\n}\n\nconst elementsConfig = (index: number) => {\n let length = 2;\n let min = 1;\n let max = 0;\n\n switch (index) {\n case 0:\n case 3:\n max = 31;\n break;\n case 1:\n case 4:\n max = 12;\n break;\n case 2:\n case 5:\n max = 2100;\n min = 1900;\n length = 4;\n break;\n }\n\n return { length, min, max };\n};\n\nconst getInternalValue = (value: CalendarRangeProps['value']) => {\n const newValue = ['', '', '', '', '', ''];\n if (value?.[0]) {\n newValue[0] = String(value[0].getDate()).padStart(2, '0');\n newValue[1] = String(value[0].getMonth() + 1).padStart(2, '0');\n newValue[2] = String(value[0].getFullYear()).padStart(4, '0');\n }\n if (value?.[1]) {\n newValue[3] = String(value[1].getDate()).padStart(2, '0');\n newValue[4] = String(value[1].getMonth() + 1).padStart(2, '0');\n newValue[5] = String(value[1].getFullYear()).padStart(4, '0');\n }\n return newValue;\n};\n\n/**\n * @see https://vkcom.github.io/VKUI/#/DateRangeInput\n */\nexport const DateRangeInput = ({\n shouldDisableDate,\n disableFuture,\n disablePast,\n value,\n onChange,\n calendarPlacement = 'bottom-start',\n style,\n className,\n closeOnChange = true,\n disablePickers,\n getRootRef,\n name,\n autoFocus,\n disabled,\n onClick,\n onFocus,\n prevMonthAriaLabel,\n nextMonthAriaLabel,\n changeDayAriaLabel,\n changeMonthAriaLabel,\n changeYearAriaLabel,\n changeStartDayAriaLabel = 'Изменить день начала',\n changeStartMonthAriaLabel = 'Изменить месяц начала',\n changeStartYearAriaLabel = 'Изменить год начала',\n changeEndDayAriaLabel = 'Изменить день окончания',\n changeEndMonthAriaLabel = 'Изменить месяц окончания',\n changeEndYearAriaLabel = 'Изменить год окончания',\n clearFieldAriaLabel = 'Очистить поле',\n showCalendarAriaLabel = 'Показать календарь',\n prevMonthIcon,\n nextMonthIcon,\n disableCalendar = false,\n ...props\n}: DateRangeInputProps) => {\n const daysStartRef = React.useRef<HTMLSpanElement>(null);\n const monthsStartRef = React.useRef<HTMLSpanElement>(null);\n const yearsStartRef = React.useRef<HTMLSpanElement>(null);\n const daysEndRef = React.useRef<HTMLSpanElement>(null);\n const monthsEndRef = React.useRef<HTMLSpanElement>(null);\n const yearsEndRef = React.useRef<HTMLSpanElement>(null);\n\n const onInternalValueChange = React.useCallback(\n (internalValue: string[]) => {\n let isStartValid = true;\n let isEndValid = true;\n for (let i = 0; i <= 2; i += 1) {\n if (internalValue[i].length < elementsConfig(i).length) {\n isStartValid = false;\n }\n }\n for (let i = 3; i <= 5; i += 1) {\n if (internalValue[i].length < elementsConfig(i).length) {\n isEndValid = false;\n }\n }\n const formattedStartValue = `${internalValue[0]}.${internalValue[1]}.${internalValue[2]}`;\n const formattedEndValue = `${internalValue[3]}.${internalValue[4]}.${internalValue[5]}`;\n const mask = 'dd.MM.yyyy';\n\n if (!isMatch(formattedStartValue, mask)) {\n isStartValid = false;\n }\n if (!isMatch(formattedEndValue, mask)) {\n isEndValid = false;\n }\n\n if (!isStartValid && !isEndValid) {\n return;\n }\n\n const valueExists = Array.isArray(value);\n const now = new Date();\n const start = isStartValid\n ? parse(formattedStartValue, mask, (valueExists && value?.[0]) || now)\n : null;\n const end = isEndValid\n ? parse(formattedEndValue, mask, (valueExists && value?.[1]) || now)\n : null;\n if (start && end && isAfter(end, start)) {\n onChange?.([start, end]);\n }\n },\n [onChange, value],\n );\n\n const refs = React.useMemo(\n () => [daysStartRef, monthsStartRef, yearsStartRef, daysEndRef, monthsEndRef, yearsEndRef],\n [daysStartRef, monthsStartRef, yearsStartRef, daysEndRef, monthsEndRef, yearsEndRef],\n );\n\n const {\n rootRef,\n calendarRef,\n open,\n openCalendar,\n closeCalendar,\n internalValue,\n handleKeyDown,\n setFocusedElement,\n handleFieldEnter,\n clear,\n removeFocusFromField,\n } = useDateInput({\n maxElement: 5,\n refs,\n autoFocus,\n disabled,\n elementsConfig,\n onChange,\n onInternalValueChange,\n getInternalValue,\n value,\n });\n\n const { sizeY } = useAdaptivity();\n\n const handleRootRef = useExternRef(rootRef, getRootRef);\n\n const onCalendarChange = React.useCallback(\n (newValue?: Array<Date | null> | undefined) => {\n onChange?.(newValue);\n if (closeOnChange && newValue?.[1] && newValue[1] !== value?.[1]) {\n removeFocusFromField();\n }\n },\n [onChange, closeOnChange, value, removeFocusFromField],\n );\n\n return (\n <FormField\n style={style}\n className={classNames(\n styles['DateRangeInput'],\n getSizeYClassName(styles['DateRangeInput'], sizeY),\n className,\n )}\n getRootRef={handleRootRef}\n after={\n value ? (\n <IconButton hoverMode=\"opacity\" aria-label={clearFieldAriaLabel} onClick={clear}>\n <Icon16Clear />\n </IconButton>\n ) : (\n <IconButton hoverMode=\"opacity\" aria-label={showCalendarAriaLabel} onClick={openCalendar}>\n <Icon20CalendarOutline />\n </IconButton>\n )\n }\n disabled={disabled}\n onClick={callMultiple(handleFieldEnter, onClick)}\n onFocus={callMultiple(handleFieldEnter, onFocus)}\n {...props}\n >\n <input\n type=\"hidden\"\n name={name}\n value={\n value\n ? `${value[0] ? format(value[0], 'DD.MM.YYYY') : ''} - ${\n value[1] ? format(value[1], 'DD.MM.YYYY') : ''\n }`\n : ''\n }\n />\n <span className={dateInputStyles['DateInput__input']} onKeyDown={handleKeyDown}>\n <InputLike\n length={2}\n getRootRef={daysStartRef}\n index={0}\n onElementSelect={setFocusedElement}\n value={internalValue[0]}\n aria-label={changeStartDayAriaLabel}\n />\n <InputLikeDivider>.</InputLikeDivider>\n <InputLike\n length={2}\n getRootRef={monthsStartRef}\n index={1}\n onElementSelect={setFocusedElement}\n value={internalValue[1]}\n aria-label={changeStartMonthAriaLabel}\n />\n <InputLikeDivider>.</InputLikeDivider>\n <InputLike\n length={4}\n getRootRef={yearsStartRef}\n index={2}\n onElementSelect={setFocusedElement}\n value={internalValue[2]}\n aria-label={changeStartYearAriaLabel}\n />\n <InputLikeDivider>{' — '}</InputLikeDivider>\n <InputLike\n length={2}\n getRootRef={daysEndRef}\n index={3}\n onElementSelect={setFocusedElement}\n value={internalValue[3]}\n aria-label={changeEndDayAriaLabel}\n />\n <InputLikeDivider>.</InputLikeDivider>\n <InputLike\n length={2}\n getRootRef={monthsEndRef}\n index={4}\n onElementSelect={setFocusedElement}\n value={internalValue[4]}\n aria-label={changeEndMonthAriaLabel}\n />\n <InputLikeDivider>.</InputLikeDivider>\n <InputLike\n length={4}\n getRootRef={yearsEndRef}\n index={5}\n onElementSelect={setFocusedElement}\n value={internalValue[5]}\n aria-label={changeEndYearAriaLabel}\n />\n </span>\n {open && !disableCalendar && (\n <Popper targetRef={rootRef} offsetDistance={8} placement={calendarPlacement}>\n <CalendarRange\n value={value}\n onChange={onCalendarChange}\n disablePast={disablePast}\n disableFuture={disableFuture}\n shouldDisableDate={shouldDisableDate}\n onClose={closeCalendar}\n getRootRef={calendarRef}\n disablePickers={disablePickers}\n prevMonthAriaLabel={prevMonthAriaLabel}\n nextMonthAriaLabel={nextMonthAriaLabel}\n changeMonthAriaLabel={changeMonthAriaLabel}\n changeYearAriaLabel={changeYearAriaLabel}\n changeDayAriaLabel={changeDayAriaLabel}\n prevMonthIcon={prevMonthIcon}\n nextMonthIcon={nextMonthIcon}\n />\n </Popper>\n )}\n </FormField>\n );\n};\n"],"mappings":"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"}
@@ -13,7 +13,7 @@ var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/h
13
13
  var React = _interopRequireWildcard(require("react"));
14
14
  var _platform = require("../../lib/platform");
15
15
  var _vkjs = require("@vkontakte/vkjs");
16
- var _SplitCol = require("../SplitCol/SplitCol");
16
+ var _SplitColContext = require("../SplitCol/SplitColContext");
17
17
  var _TooltipContainer = require("../Tooltip/TooltipContainer");
18
18
  var _dom = require("../../lib/dom");
19
19
  var _useGlobalEventListener = require("../../hooks/useGlobalEventListener");
@@ -40,7 +40,7 @@ var FixedLayout = function FixedLayout(_ref) {
40
40
  setWidth = _React$useState2[1];
41
41
  var _useDOM = (0, _dom.useDOM)(),
42
42
  window = _useDOM.window;
43
- var _React$useContext = React.useContext(_SplitCol.SplitColContext),
43
+ var _React$useContext = React.useContext(_SplitColContext.SplitColContext),
44
44
  colRef = _React$useContext.colRef;
45
45
  var doResize = function doResize() {
46
46
  if (colRef !== null && colRef !== void 0 && colRef.current) {
@@ -1 +1 @@
1
- {"version":3,"file":"FixedLayout.js","names":["FixedLayout","children","style","vertical","getRootRef","getRef","filled","className","restProps","platform","usePlatform","ref","useExternRef","React","useState","undefined","width","setWidth","useDOM","window","useContext","SplitColContext","colRef","doResize","current","computedStyle","getComputedStyle","clientWidth","parseFloat","paddingLeft","paddingRight","useEffect","useGlobalEventListener","classNames","Platform","IOS","styles"],"sources":["../../../../src/components/FixedLayout/FixedLayout.tsx"],"sourcesContent":["import * as React from 'react';\nimport { Platform } from '../../lib/platform';\nimport { classNames } from '@vkontakte/vkjs';\nimport { HasRef, HasRootRef } from '../../types';\nimport { SplitColContext } from '../SplitCol/SplitCol';\nimport { TooltipContainer } from '../Tooltip/TooltipContainer';\nimport { useDOM } from '../../lib/dom';\nimport { useGlobalEventListener } from '../../hooks/useGlobalEventListener';\nimport { usePlatform } from '../../hooks/usePlatform';\nimport { useExternRef } from '../../hooks/useExternRef';\nimport styles from './FixedLayout.module.css';\n\nexport interface FixedLayoutProps\n extends React.HTMLAttributes<HTMLDivElement>,\n HasRootRef<HTMLDivElement>,\n HasRef<HTMLDivElement> {\n vertical?: 'top' | 'bottom';\n /**\n * Это свойство определяет, будет ли фон компонента окрашен в цвет фона контента.\n * Это часто необходимо для фиксированных кнопок в нижней части экрана.\n */\n filled?: boolean;\n}\n\nexport interface FixedLayoutState {\n position: 'absolute' | null;\n top: number;\n bottom: number;\n width: string;\n}\n\n/**\n * @see https://vkcom.github.io/VKUI/#/FixedLayout\n */\nexport const FixedLayout = ({\n children,\n style,\n vertical,\n getRootRef,\n getRef,\n filled,\n className,\n ...restProps\n}: FixedLayoutProps) => {\n const platform = usePlatform();\n const ref = useExternRef(getRootRef, getRef); // TODO: v6 удалить getRef\n const [width, setWidth] = React.useState<string | undefined>(undefined);\n const { window } = useDOM();\n const { colRef } = React.useContext(SplitColContext);\n const doResize = () => {\n if (colRef?.current) {\n const computedStyle = getComputedStyle(colRef.current);\n\n setWidth(\n `${\n colRef.current.clientWidth -\n parseFloat(computedStyle.paddingLeft) -\n parseFloat(computedStyle.paddingRight)\n }px`,\n );\n } else {\n setWidth(undefined);\n }\n };\n React.useEffect(doResize, [colRef, platform]);\n useGlobalEventListener(window, 'resize', doResize);\n\n return (\n <TooltipContainer\n {...restProps}\n fixed\n ref={ref}\n className={classNames(\n styles['FixedLayout'],\n platform === Platform.IOS && styles['FixedLayout--ios'],\n filled && styles['FixedLayout--filled'],\n vertical && styles[`FixedLayout--vertical-${vertical}`],\n className,\n )}\n style={{ ...style, width }}\n >\n {children}\n </TooltipContainer>\n );\n};\n"],"mappings":";;;;;;;;;;;;AAAA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAAwD;AAsBxD;AACA;AACA;AACO,IAAMA,WAAW,GAAG,SAAdA,WAAW,OASA;EAAA,IARtBC,QAAQ,QAARA,QAAQ;IACRC,KAAK,QAALA,KAAK;IACLC,QAAQ,QAARA,QAAQ;IACRC,UAAU,QAAVA,UAAU;IACVC,MAAM,QAANA,MAAM;IACNC,MAAM,QAANA,MAAM;IACNC,SAAS,QAATA,SAAS;IACNC,SAAS;EAEZ,IAAMC,QAAQ,GAAG,IAAAC,wBAAW,GAAE;EAC9B,IAAMC,GAAG,GAAG,IAAAC,0BAAY,EAACR,UAAU,EAAEC,MAAM,CAAC,CAAC,CAAC;EAC9C,sBAA0BQ,KAAK,CAACC,QAAQ,CAAqBC,SAAS,CAAC;IAAA;IAAhEC,KAAK;IAAEC,QAAQ;EACtB,cAAmB,IAAAC,WAAM,GAAE;IAAnBC,MAAM,WAANA,MAAM;EACd,wBAAmBN,KAAK,CAACO,UAAU,CAACC,yBAAe,CAAC;IAA5CC,MAAM,qBAANA,MAAM;EACd,IAAMC,QAAQ,GAAG,SAAXA,QAAQ,GAAS;IACrB,IAAID,MAAM,aAANA,MAAM,eAANA,MAAM,CAAEE,OAAO,EAAE;MACnB,IAAMC,aAAa,GAAGC,gBAAgB,CAACJ,MAAM,CAACE,OAAO,CAAC;MAEtDP,QAAQ,WAEJK,MAAM,CAACE,OAAO,CAACG,WAAW,GAC1BC,UAAU,CAACH,aAAa,CAACI,WAAW,CAAC,GACrCD,UAAU,CAACH,aAAa,CAACK,YAAY,CAAC,QAEzC;IACH,CAAC,MAAM;MACLb,QAAQ,CAACF,SAAS,CAAC;IACrB;EACF,CAAC;EACDF,KAAK,CAACkB,SAAS,CAACR,QAAQ,EAAE,CAACD,MAAM,EAAEb,QAAQ,CAAC,CAAC;EAC7C,IAAAuB,8CAAsB,EAACb,MAAM,EAAE,QAAQ,EAAEI,QAAQ,CAAC;EAElD,oBACE,oBAAC,kCAAgB,6BACXf,SAAS;IACb,KAAK;IACL,GAAG,EAAEG,GAAI;IACT,SAAS,EAAE,IAAAsB,gBAAU,qBAEnBxB,QAAQ,KAAKyB,kBAAQ,CAACC,GAAG,0BAA8B,EACvD7B,MAAM,6BAAiC,EACvCH,QAAQ,IAAIiC,MAAM,iCAA0BjC,QAAQ,EAAG,EACvDI,SAAS,CACT;IACF,KAAK,8DAAOL,KAAK;MAAEc,KAAK,EAALA;IAAK;EAAG,IAE1Bf,QAAQ,CACQ;AAEvB,CAAC;AAAC;AAAA;EAAA;EAAA;AAAA"}
1
+ {"version":3,"file":"FixedLayout.js","names":["FixedLayout","children","style","vertical","getRootRef","getRef","filled","className","restProps","platform","usePlatform","ref","useExternRef","React","useState","undefined","width","setWidth","useDOM","window","useContext","SplitColContext","colRef","doResize","current","computedStyle","getComputedStyle","clientWidth","parseFloat","paddingLeft","paddingRight","useEffect","useGlobalEventListener","classNames","Platform","IOS","styles"],"sources":["../../../../src/components/FixedLayout/FixedLayout.tsx"],"sourcesContent":["import * as React from 'react';\nimport { Platform } from '../../lib/platform';\nimport { classNames } from '@vkontakte/vkjs';\nimport { HasRef, HasRootRef } from '../../types';\nimport { SplitColContext } from '../SplitCol/SplitColContext';\nimport { TooltipContainer } from '../Tooltip/TooltipContainer';\nimport { useDOM } from '../../lib/dom';\nimport { useGlobalEventListener } from '../../hooks/useGlobalEventListener';\nimport { usePlatform } from '../../hooks/usePlatform';\nimport { useExternRef } from '../../hooks/useExternRef';\nimport styles from './FixedLayout.module.css';\n\nexport interface FixedLayoutProps\n extends React.HTMLAttributes<HTMLDivElement>,\n HasRootRef<HTMLDivElement>,\n HasRef<HTMLDivElement> {\n vertical?: 'top' | 'bottom';\n /**\n * Это свойство определяет, будет ли фон компонента окрашен в цвет фона контента.\n * Это часто необходимо для фиксированных кнопок в нижней части экрана.\n */\n filled?: boolean;\n}\n\nexport interface FixedLayoutState {\n position: 'absolute' | null;\n top: number;\n bottom: number;\n width: string;\n}\n\n/**\n * @see https://vkcom.github.io/VKUI/#/FixedLayout\n */\nexport const FixedLayout = ({\n children,\n style,\n vertical,\n getRootRef,\n getRef,\n filled,\n className,\n ...restProps\n}: FixedLayoutProps) => {\n const platform = usePlatform();\n const ref = useExternRef(getRootRef, getRef); // TODO: v6 удалить getRef\n const [width, setWidth] = React.useState<string | undefined>(undefined);\n const { window } = useDOM();\n const { colRef } = React.useContext(SplitColContext);\n const doResize = () => {\n if (colRef?.current) {\n const computedStyle = getComputedStyle(colRef.current);\n\n setWidth(\n `${\n colRef.current.clientWidth -\n parseFloat(computedStyle.paddingLeft) -\n parseFloat(computedStyle.paddingRight)\n }px`,\n );\n } else {\n setWidth(undefined);\n }\n };\n React.useEffect(doResize, [colRef, platform]);\n useGlobalEventListener(window, 'resize', doResize);\n\n return (\n <TooltipContainer\n {...restProps}\n fixed\n ref={ref}\n className={classNames(\n styles['FixedLayout'],\n platform === Platform.IOS && styles['FixedLayout--ios'],\n filled && styles['FixedLayout--filled'],\n vertical && styles[`FixedLayout--vertical-${vertical}`],\n className,\n )}\n style={{ ...style, width }}\n >\n {children}\n </TooltipContainer>\n );\n};\n"],"mappings":";;;;;;;;;;;;AAAA;AACA;AACA;AAEA;AACA;AACA;AACA;AACA;AACA;AAAwD;AAsBxD;AACA;AACA;AACO,IAAMA,WAAW,GAAG,SAAdA,WAAW,OASA;EAAA,IARtBC,QAAQ,QAARA,QAAQ;IACRC,KAAK,QAALA,KAAK;IACLC,QAAQ,QAARA,QAAQ;IACRC,UAAU,QAAVA,UAAU;IACVC,MAAM,QAANA,MAAM;IACNC,MAAM,QAANA,MAAM;IACNC,SAAS,QAATA,SAAS;IACNC,SAAS;EAEZ,IAAMC,QAAQ,GAAG,IAAAC,wBAAW,GAAE;EAC9B,IAAMC,GAAG,GAAG,IAAAC,0BAAY,EAACR,UAAU,EAAEC,MAAM,CAAC,CAAC,CAAC;EAC9C,sBAA0BQ,KAAK,CAACC,QAAQ,CAAqBC,SAAS,CAAC;IAAA;IAAhEC,KAAK;IAAEC,QAAQ;EACtB,cAAmB,IAAAC,WAAM,GAAE;IAAnBC,MAAM,WAANA,MAAM;EACd,wBAAmBN,KAAK,CAACO,UAAU,CAACC,gCAAe,CAAC;IAA5CC,MAAM,qBAANA,MAAM;EACd,IAAMC,QAAQ,GAAG,SAAXA,QAAQ,GAAS;IACrB,IAAID,MAAM,aAANA,MAAM,eAANA,MAAM,CAAEE,OAAO,EAAE;MACnB,IAAMC,aAAa,GAAGC,gBAAgB,CAACJ,MAAM,CAACE,OAAO,CAAC;MAEtDP,QAAQ,WAEJK,MAAM,CAACE,OAAO,CAACG,WAAW,GAC1BC,UAAU,CAACH,aAAa,CAACI,WAAW,CAAC,GACrCD,UAAU,CAACH,aAAa,CAACK,YAAY,CAAC,QAEzC;IACH,CAAC,MAAM;MACLb,QAAQ,CAACF,SAAS,CAAC;IACrB;EACF,CAAC;EACDF,KAAK,CAACkB,SAAS,CAACR,QAAQ,EAAE,CAACD,MAAM,EAAEb,QAAQ,CAAC,CAAC;EAC7C,IAAAuB,8CAAsB,EAACb,MAAM,EAAE,QAAQ,EAAEI,QAAQ,CAAC;EAElD,oBACE,oBAAC,kCAAgB,6BACXf,SAAS;IACb,KAAK;IACL,GAAG,EAAEG,GAAI;IACT,SAAS,EAAE,IAAAsB,gBAAU,qBAEnBxB,QAAQ,KAAKyB,kBAAQ,CAACC,GAAG,0BAA8B,EACvD7B,MAAM,6BAAiC,EACvCH,QAAQ,IAAIiC,MAAM,iCAA0BjC,QAAQ,EAAG,EACvDI,SAAS,CACT;IACF,KAAK,8DAAOL,KAAK;MAAEc,KAAK,EAALA;IAAK;EAAG,IAE1Bf,QAAQ,CACQ;AAEvB,CAAC;AAAC;AAAA;EAAA;EAAA;AAAA"}
@@ -19,7 +19,7 @@ var _excluded = ["Component", "status", "children", "getRootRef", "before", "aft
19
19
  */
20
20
  var FormField = function FormField(_ref) {
21
21
  var _ref$Component = _ref.Component,
22
- Component = _ref$Component === void 0 ? 'div' : _ref$Component,
22
+ Component = _ref$Component === void 0 ? 'span' : _ref$Component,
23
23
  _ref$status = _ref.status,
24
24
  status = _ref$status === void 0 ? 'default' : _ref$status,
25
25
  children = _ref.children,
@@ -45,21 +45,17 @@ var FormField = function FormField(_ref) {
45
45
  e.stopPropagation();
46
46
  setHover(false);
47
47
  };
48
- return /*#__PURE__*/React.createElement(Component, (0, _extends2.default)({
49
- role: "presentation"
50
- }, restProps, {
48
+ return /*#__PURE__*/React.createElement(Component, (0, _extends2.default)({}, restProps, {
51
49
  ref: getRootRef,
52
50
  onMouseEnter: handleMouseEnter,
53
51
  onMouseLeave: handleMouseLeave,
54
52
  className: (0, _vkjs.classNames)("vkuiFormField", styles["FormField--mode-".concat(mode)], styles["FormField--status-".concat(status)], (0, _getSizeYClassName.getSizeYClassName)("vkuiFormField", sizeY), disabled && "vkuiFormField--disabled", !disabled && hover && "vkuiFormField--hover", className)
55
- }), before && /*#__PURE__*/React.createElement("div", {
56
- role: "presentation",
53
+ }), before && /*#__PURE__*/React.createElement("span", {
57
54
  className: "vkuiFormField__before"
58
- }, before), children, after && /*#__PURE__*/React.createElement("div", {
59
- role: "presentation",
55
+ }, before), children, after && /*#__PURE__*/React.createElement("span", {
60
56
  className: "vkuiFormField__after"
61
- }, after), /*#__PURE__*/React.createElement("div", {
62
- role: "presentation",
57
+ }, after), /*#__PURE__*/React.createElement("span", {
58
+ "aria-hidden": true,
63
59
  className: "vkuiFormField__border"
64
60
  }));
65
61
  };
@@ -1 +1 @@
1
- {"version":3,"file":"FormField.js","names":["FormField","Component","status","children","getRootRef","before","after","disabled","mode","className","restProps","useAdaptivity","sizeY","React","useState","hover","setHover","handleMouseEnter","e","stopPropagation","handleMouseLeave","classNames","styles","getSizeYClassName"],"sources":["../../../../src/components/FormField/FormField.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames } from '@vkontakte/vkjs';\nimport { HasComponent, HasRootRef } from '../../types';\nimport { useAdaptivity } from '../../hooks/useAdaptivity';\nimport { getSizeYClassName } from '../../helpers/getSizeYClassName';\nimport styles from './FormField.module.css';\n\nexport interface FormFieldProps {\n status?: 'default' | 'error' | 'valid';\n /**\n * Добавляет иконку слева.\n *\n * Рекомендации:\n *\n * - Используйте следующие размеры иконок `12` | `16` | `20` | `24` | `28`.\n * - Используйте [IconButton](https://vkcom.github.io/VKUI/#/IconButton), если вам нужна кликабельная иконка.\n */\n before?: React.ReactNode;\n /**\n * Добавляет иконку справа.\n *\n * Рекомендации:\n *\n * - Используйте следующие размеры иконок `12` | `16` | `20` | `24` | `28`.\n * - Используйте [IconButton](https://vkcom.github.io/VKUI/#/IconButton), если вам нужна кликабельная иконка.\n */\n after?: React.ReactNode;\n mode?: 'default' | 'plain';\n}\n\ninterface FormFieldOwnProps\n extends React.AllHTMLAttributes<HTMLElement>,\n HasRootRef<HTMLElement>,\n HasComponent,\n FormFieldProps {\n disabled?: boolean;\n}\n\n/**\n * @see https://vkcom.github.io/VKUI/#/FormField\n */\nexport const FormField = ({\n Component = 'div',\n status = 'default',\n children,\n getRootRef,\n before,\n after,\n disabled,\n mode = 'default',\n className,\n ...restProps\n}: FormFieldOwnProps) => {\n const { sizeY } = useAdaptivity();\n const [hover, setHover] = React.useState(false);\n\n const handleMouseEnter = (e: MouseEvent) => {\n e.stopPropagation();\n setHover(true);\n };\n\n const handleMouseLeave = (e: MouseEvent) => {\n e.stopPropagation();\n setHover(false);\n };\n\n return (\n <Component\n role=\"presentation\"\n {...restProps}\n ref={getRootRef}\n onMouseEnter={handleMouseEnter}\n onMouseLeave={handleMouseLeave}\n className={classNames(\n styles['FormField'],\n styles[`FormField--mode-${mode}`],\n styles[`FormField--status-${status}`],\n getSizeYClassName(styles['FormField'], sizeY),\n disabled && styles['FormField--disabled'],\n !disabled && hover && styles['FormField--hover'],\n className,\n )}\n >\n {before && (\n <div role=\"presentation\" className={styles['FormField__before']}>\n {before}\n </div>\n )}\n {children}\n {after && (\n <div role=\"presentation\" className={styles['FormField__after']}>\n {after}\n </div>\n )}\n <div role=\"presentation\" className={styles['FormField__border']} />\n </Component>\n );\n};\n"],"mappings":";;;;;;;;;;;AAAA;AACA;AAEA;AACA;AAAoE;AAkCpE;AACA;AACA;AACO,IAAMA,SAAS,GAAG,SAAZA,SAAS,OAWG;EAAA,0BAVvBC,SAAS;IAATA,SAAS,+BAAG,KAAK;IAAA,mBACjBC,MAAM;IAANA,MAAM,4BAAG,SAAS;IAClBC,QAAQ,QAARA,QAAQ;IACRC,UAAU,QAAVA,UAAU;IACVC,MAAM,QAANA,MAAM;IACNC,KAAK,QAALA,KAAK;IACLC,QAAQ,QAARA,QAAQ;IAAA,iBACRC,IAAI;IAAJA,IAAI,0BAAG,SAAS;IAChBC,SAAS,QAATA,SAAS;IACNC,SAAS;EAEZ,qBAAkB,IAAAC,6BAAa,GAAE;IAAzBC,KAAK,kBAALA,KAAK;EACb,sBAA0BC,KAAK,CAACC,QAAQ,CAAC,KAAK,CAAC;IAAA;IAAxCC,KAAK;IAAEC,QAAQ;EAEtB,IAAMC,gBAAgB,GAAG,SAAnBA,gBAAgB,CAAIC,CAAa,EAAK;IAC1CA,CAAC,CAACC,eAAe,EAAE;IACnBH,QAAQ,CAAC,IAAI,CAAC;EAChB,CAAC;EAED,IAAMI,gBAAgB,GAAG,SAAnBA,gBAAgB,CAAIF,CAAa,EAAK;IAC1CA,CAAC,CAACC,eAAe,EAAE;IACnBH,QAAQ,CAAC,KAAK,CAAC;EACjB,CAAC;EAED,oBACE,oBAAC,SAAS;IACR,IAAI,EAAC;EAAc,GACfN,SAAS;IACb,GAAG,EAAEN,UAAW;IAChB,YAAY,EAAEa,gBAAiB;IAC/B,YAAY,EAAEG,gBAAiB;IAC/B,SAAS,EAAE,IAAAC,gBAAU,mBAEnBC,MAAM,2BAAoBd,IAAI,EAAG,EACjCc,MAAM,6BAAsBpB,MAAM,EAAG,EACrC,IAAAqB,oCAAiB,mBAAsBX,KAAK,CAAC,EAC7CL,QAAQ,6BAAiC,EACzC,CAACA,QAAQ,IAAIQ,KAAK,0BAA8B,EAChDN,SAAS;EACT,IAEDJ,MAAM,iBACL;IAAK,IAAI,EAAC,cAAc;IAAC,SAAS;EAA8B,GAC7DA,MAAM,CAEV,EACAF,QAAQ,EACRG,KAAK,iBACJ;IAAK,IAAI,EAAC,cAAc;IAAC,SAAS;EAA6B,GAC5DA,KAAK,CAET,eACD;IAAK,IAAI,EAAC,cAAc;IAAC,SAAS;EAA8B,EAAG,CACzD;AAEhB,CAAC;AAAC;AAAA;EAAA;EAAA;EAAA;EAAA;EAAA;AAAA"}
1
+ {"version":3,"file":"FormField.js","names":["FormField","Component","status","children","getRootRef","before","after","disabled","mode","className","restProps","useAdaptivity","sizeY","React","useState","hover","setHover","handleMouseEnter","e","stopPropagation","handleMouseLeave","classNames","styles","getSizeYClassName"],"sources":["../../../../src/components/FormField/FormField.tsx"],"sourcesContent":["import * as React from 'react';\nimport { classNames } from '@vkontakte/vkjs';\nimport { HasComponent, HasRootRef } from '../../types';\nimport { useAdaptivity } from '../../hooks/useAdaptivity';\nimport { getSizeYClassName } from '../../helpers/getSizeYClassName';\nimport styles from './FormField.module.css';\n\nexport interface FormFieldProps {\n status?: 'default' | 'error' | 'valid';\n /**\n * Добавляет иконку слева.\n *\n * Рекомендации:\n *\n * - Используйте следующие размеры иконок `12` | `16` | `20` | `24` | `28`.\n * - Используйте [IconButton](https://vkcom.github.io/VKUI/#/IconButton), если вам нужна кликабельная иконка.\n */\n before?: React.ReactNode;\n /**\n * Добавляет иконку справа.\n *\n * Рекомендации:\n *\n * - Используйте следующие размеры иконок `12` | `16` | `20` | `24` | `28`.\n * - Используйте [IconButton](https://vkcom.github.io/VKUI/#/IconButton), если вам нужна кликабельная иконка.\n */\n after?: React.ReactNode;\n mode?: 'default' | 'plain';\n}\n\ninterface FormFieldOwnProps\n extends React.AllHTMLAttributes<HTMLElement>,\n HasRootRef<HTMLElement>,\n HasComponent,\n FormFieldProps {\n disabled?: boolean;\n}\n\n/**\n * @see https://vkcom.github.io/VKUI/#/FormField\n */\nexport const FormField = ({\n Component = 'span',\n status = 'default',\n children,\n getRootRef,\n before,\n after,\n disabled,\n mode = 'default',\n className,\n ...restProps\n}: FormFieldOwnProps) => {\n const { sizeY } = useAdaptivity();\n const [hover, setHover] = React.useState(false);\n\n const handleMouseEnter = (e: MouseEvent) => {\n e.stopPropagation();\n setHover(true);\n };\n\n const handleMouseLeave = (e: MouseEvent) => {\n e.stopPropagation();\n setHover(false);\n };\n\n return (\n <Component\n {...restProps}\n ref={getRootRef}\n onMouseEnter={handleMouseEnter}\n onMouseLeave={handleMouseLeave}\n className={classNames(\n styles['FormField'],\n styles[`FormField--mode-${mode}`],\n styles[`FormField--status-${status}`],\n getSizeYClassName(styles['FormField'], sizeY),\n disabled && styles['FormField--disabled'],\n !disabled && hover && styles['FormField--hover'],\n className,\n )}\n >\n {before && <span className={styles['FormField__before']}>{before}</span>}\n {children}\n {after && <span className={styles['FormField__after']}>{after}</span>}\n <span aria-hidden className={styles['FormField__border']} />\n </Component>\n );\n};\n"],"mappings":";;;;;;;;;;;AAAA;AACA;AAEA;AACA;AAAoE;AAkCpE;AACA;AACA;AACO,IAAMA,SAAS,GAAG,SAAZA,SAAS,OAWG;EAAA,0BAVvBC,SAAS;IAATA,SAAS,+BAAG,MAAM;IAAA,mBAClBC,MAAM;IAANA,MAAM,4BAAG,SAAS;IAClBC,QAAQ,QAARA,QAAQ;IACRC,UAAU,QAAVA,UAAU;IACVC,MAAM,QAANA,MAAM;IACNC,KAAK,QAALA,KAAK;IACLC,QAAQ,QAARA,QAAQ;IAAA,iBACRC,IAAI;IAAJA,IAAI,0BAAG,SAAS;IAChBC,SAAS,QAATA,SAAS;IACNC,SAAS;EAEZ,qBAAkB,IAAAC,6BAAa,GAAE;IAAzBC,KAAK,kBAALA,KAAK;EACb,sBAA0BC,KAAK,CAACC,QAAQ,CAAC,KAAK,CAAC;IAAA;IAAxCC,KAAK;IAAEC,QAAQ;EAEtB,IAAMC,gBAAgB,GAAG,SAAnBA,gBAAgB,CAAIC,CAAa,EAAK;IAC1CA,CAAC,CAACC,eAAe,EAAE;IACnBH,QAAQ,CAAC,IAAI,CAAC;EAChB,CAAC;EAED,IAAMI,gBAAgB,GAAG,SAAnBA,gBAAgB,CAAIF,CAAa,EAAK;IAC1CA,CAAC,CAACC,eAAe,EAAE;IACnBH,QAAQ,CAAC,KAAK,CAAC;EACjB,CAAC;EAED,oBACE,oBAAC,SAAS,6BACJN,SAAS;IACb,GAAG,EAAEN,UAAW;IAChB,YAAY,EAAEa,gBAAiB;IAC/B,YAAY,EAAEG,gBAAiB;IAC/B,SAAS,EAAE,IAAAC,gBAAU,mBAEnBC,MAAM,2BAAoBd,IAAI,EAAG,EACjCc,MAAM,6BAAsBpB,MAAM,EAAG,EACrC,IAAAqB,oCAAiB,mBAAsBX,KAAK,CAAC,EAC7CL,QAAQ,6BAAiC,EACzC,CAACA,QAAQ,IAAIQ,KAAK,0BAA8B,EAChDN,SAAS;EACT,IAEDJ,MAAM,iBAAI;IAAM,SAAS;EAA8B,GAAEA,MAAM,CAAQ,EACvEF,QAAQ,EACRG,KAAK,iBAAI;IAAM,SAAS;EAA6B,GAAEA,KAAK,CAAQ,eACrE;IAAM,mBAAW;IAAC,SAAS;EAA8B,EAAG,CAClD;AAEhB,CAAC;AAAC;AAAA;EAAA;EAAA;EAAA;EAAA;EAAA;AAAA"}
@@ -15,7 +15,10 @@ var _usePlatform = require("../../hooks/usePlatform");
15
15
  var _platform = require("../../lib/platform");
16
16
  var _getSizeYClassName = require("../../helpers/getSizeYClassName");
17
17
  var _useAdaptivity2 = require("../../hooks/useAdaptivity");
18
+ var _warnOnce = require("../../lib/warnOnce");
18
19
  var _excluded = ["children", "Component", "className"];
20
+ var warn = (0, _warnOnce.warnOnce)('IconButton');
21
+
19
22
  /**
20
23
  * @see https://vkcom.github.io/VKUI/#/IconButton
21
24
  */
@@ -28,6 +31,12 @@ var IconButton = function IconButton(_ref) {
28
31
  var platform = (0, _usePlatform.usePlatform)();
29
32
  var _useAdaptivity = (0, _useAdaptivity2.useAdaptivity)(),
30
33
  sizeY = _useAdaptivity.sizeY;
34
+ if (process.env.NODE_ENV === 'development') {
35
+ var isAccessible = restProps['aria-label'] || restProps['aria-labelledby'];
36
+ if (!isAccessible) {
37
+ warn(_warnOnce.COMMON_WARNINGS.a11y[restProps.href ? 'link-name' : 'button-name'], 'error');
38
+ }
39
+ }
31
40
  return /*#__PURE__*/React.createElement(_Tappable.Tappable, (0, _extends2.default)({
32
41
  activeEffectDelay: 200,
33
42
  activeMode: "background"