@vkontakte/vkui 4.28.1 → 4.30.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 (1159) hide show
  1. package/.cache/.eslintcache +1 -1
  2. package/.cache/.stylelintcache +1 -1
  3. package/.cache/.tsbuildinfo +5185 -9812
  4. package/.cache/ts/src/components/Alert/Alert.d.ts +4 -1
  5. package/.cache/ts/src/components/AppRoot/ScrollContext.d.ts +6 -14
  6. package/.cache/ts/src/components/Button/Button.d.ts +1 -2
  7. package/.cache/ts/src/components/Calendar/Calendar.d.ts +10 -1
  8. package/.cache/ts/src/components/CalendarHeader/CalendarHeader.d.ts +6 -0
  9. package/.cache/ts/src/components/Cell/Cell.d.ts +1 -1
  10. package/.cache/ts/src/components/ChipsInput/ChipsInput.d.ts +1 -2
  11. package/.cache/ts/src/components/ChipsSelect/ChipsSelect.d.ts +2 -2
  12. package/.cache/ts/src/components/ClickPopper/ClickPopper.d.ts +1 -1
  13. package/.cache/ts/src/components/CustomSelect/CustomSelect.d.ts +2 -2
  14. package/.cache/ts/src/components/CustomSelectOption/CustomSelectOption.d.ts +35 -6
  15. package/.cache/ts/src/components/DateInput/DateInput.d.ts +1 -1
  16. package/.cache/ts/src/components/FormField/FormField.d.ts +15 -1
  17. package/.cache/ts/src/components/Gallery/Gallery.d.ts +9 -1
  18. package/.cache/ts/src/components/GridAvatar/GridAvatar.d.ts +1 -0
  19. package/.cache/ts/src/components/HorizontalScroll/HorizontalScroll.d.ts +1 -2
  20. package/.cache/ts/src/components/Input/Input.d.ts +1 -2
  21. package/.cache/ts/src/components/ModalCard/ModalCard.d.ts +1 -1
  22. package/.cache/ts/src/components/ModalCardBase/ModalCardBase.d.ts +5 -1
  23. package/.cache/ts/src/components/ModalPage/ModalPage.d.ts +16 -1
  24. package/.cache/ts/src/components/ModalRoot/ModalRoot.d.ts +14 -2
  25. package/.cache/ts/src/components/ModalRoot/ModalRootAdaptive.d.ts +15 -3
  26. package/.cache/ts/src/components/ModalRoot/ModalRootDesktop.d.ts +14 -2
  27. package/.cache/ts/src/components/ModalRoot/types.d.ts +16 -1
  28. package/.cache/ts/src/components/ModalRoot/useModalManager.d.ts +6 -5
  29. package/.cache/ts/src/components/NativeSelect/NativeSelect.d.ts +1 -2
  30. package/.cache/ts/src/components/Pagination/Pagination.d.ts +3 -3
  31. package/.cache/ts/src/components/Select/Select.d.ts +1 -2
  32. package/.cache/ts/src/components/SelectMimicry/SelectMimicry.d.ts +3 -3
  33. package/.cache/ts/src/components/TabbarItem/TabbarItem.d.ts +1 -1
  34. package/.cache/ts/src/components/Touch/TouchContext.d.ts +1 -1
  35. package/.cache/ts/src/components/Typography/Paragraph/Paragraph.d.ts +10 -0
  36. package/.cache/ts/src/components/Typography/Subhead/Subhead.d.ts +1 -2
  37. package/.cache/ts/src/components/Typography/Title/Title.d.ts +1 -2
  38. package/.cache/ts/src/hooks/useBridgeAdaptivity.d.ts +6 -0
  39. package/.cache/ts/src/hooks/useCalendar.d.ts +4 -3
  40. package/.cache/ts/src/hooks/useKeyboard.d.ts +1 -1
  41. package/.cache/ts/src/hooks/usePagination.d.ts +3 -3
  42. package/.cache/ts/src/index.d.ts +21 -10
  43. package/.cache/ts/src/lib/date.d.ts +29 -0
  44. package/.cache/ts/src/lib/getNavId.d.ts +2 -1
  45. package/.cache/ts/src/lib/warnOnce.d.ts +2 -1
  46. package/.cache/ts/src/testing/utils.d.ts +1 -0
  47. package/.cache/ts/src/tokenized/index.d.ts +22 -4
  48. package/.eslintrc.json +8 -2
  49. package/dist/cjs/components/ActionSheet/ActionSheet.js +4 -1
  50. package/dist/cjs/components/ActionSheet/ActionSheet.js.map +1 -1
  51. package/dist/cjs/components/ActionSheet/ActionSheetDropdown.js +2 -1
  52. package/dist/cjs/components/ActionSheet/ActionSheetDropdown.js.map +1 -1
  53. package/dist/cjs/components/ActionSheet/ActionSheetDropdownDesktop.js +1 -1
  54. package/dist/cjs/components/ActionSheet/ActionSheetDropdownDesktop.js.map +1 -1
  55. package/dist/cjs/components/ActionSheetItem/ActionSheetItem.js +7 -6
  56. package/dist/cjs/components/ActionSheetItem/ActionSheetItem.js.map +1 -1
  57. package/dist/cjs/components/AdaptivityProvider/AdaptivityProvider.js +44 -11
  58. package/dist/cjs/components/AdaptivityProvider/AdaptivityProvider.js.map +1 -1
  59. package/dist/cjs/components/Alert/Alert.d.ts +4 -1
  60. package/dist/cjs/components/Alert/Alert.js +27 -8
  61. package/dist/cjs/components/Alert/Alert.js.map +1 -1
  62. package/dist/cjs/components/AppRoot/AppRoot.js +20 -3
  63. package/dist/cjs/components/AppRoot/AppRoot.js.map +1 -1
  64. package/dist/cjs/components/AppRoot/ScrollContext.d.ts +6 -14
  65. package/dist/cjs/components/AppRoot/ScrollContext.js +94 -2
  66. package/dist/cjs/components/AppRoot/ScrollContext.js.map +1 -1
  67. package/dist/cjs/components/Avatar/Avatar.js +4 -1
  68. package/dist/cjs/components/Avatar/Avatar.js.map +1 -1
  69. package/dist/cjs/components/Banner/Banner.js +5 -4
  70. package/dist/cjs/components/Banner/Banner.js.map +1 -1
  71. package/dist/cjs/components/Button/Button.d.ts +1 -2
  72. package/dist/cjs/components/Button/Button.js +36 -41
  73. package/dist/cjs/components/Button/Button.js.map +1 -1
  74. package/dist/cjs/components/Calendar/Calendar.d.ts +10 -1
  75. package/dist/cjs/components/Calendar/Calendar.js +16 -9
  76. package/dist/cjs/components/Calendar/Calendar.js.map +1 -1
  77. package/dist/cjs/components/CalendarDay/CalendarDay.js +4 -1
  78. package/dist/cjs/components/CalendarDay/CalendarDay.js.map +1 -1
  79. package/dist/cjs/components/CalendarDays/CalendarDays.js +3 -3
  80. package/dist/cjs/components/CalendarDays/CalendarDays.js.map +1 -1
  81. package/dist/cjs/components/CalendarHeader/CalendarHeader.d.ts +6 -0
  82. package/dist/cjs/components/CalendarHeader/CalendarHeader.js +15 -15
  83. package/dist/cjs/components/CalendarHeader/CalendarHeader.js.map +1 -1
  84. package/dist/cjs/components/CalendarRange/CalendarRange.js +12 -15
  85. package/dist/cjs/components/CalendarRange/CalendarRange.js.map +1 -1
  86. package/dist/cjs/components/CalendarTime/CalendarTime.js +8 -10
  87. package/dist/cjs/components/CalendarTime/CalendarTime.js.map +1 -1
  88. package/dist/cjs/components/CardScroll/CardScroll.js +3 -2
  89. package/dist/cjs/components/CardScroll/CardScroll.js.map +1 -1
  90. package/dist/cjs/components/Cell/Cell.d.ts +1 -1
  91. package/dist/cjs/components/Cell/Cell.js +4 -3
  92. package/dist/cjs/components/Cell/Cell.js.map +1 -1
  93. package/dist/cjs/components/CellButton/CellButton.js +1 -0
  94. package/dist/cjs/components/CellButton/CellButton.js.map +1 -1
  95. package/dist/cjs/components/Chip/Chip.js +1 -0
  96. package/dist/cjs/components/Chip/Chip.js.map +1 -1
  97. package/dist/cjs/components/ChipsInput/ChipsInput.d.ts +1 -2
  98. package/dist/cjs/components/ChipsInput/ChipsInput.js +7 -10
  99. package/dist/cjs/components/ChipsInput/ChipsInput.js.map +1 -1
  100. package/dist/cjs/components/ChipsSelect/ChipsSelect.d.ts +2 -2
  101. package/dist/cjs/components/ChipsSelect/ChipsSelect.js +8 -12
  102. package/dist/cjs/components/ChipsSelect/ChipsSelect.js.map +1 -1
  103. package/dist/cjs/components/ClickPopper/ClickPopper.d.ts +1 -1
  104. package/dist/cjs/components/ClickPopper/ClickPopper.js.map +1 -1
  105. package/dist/cjs/components/ConfigProvider/ConfigProvider.js +1 -1
  106. package/dist/cjs/components/ConfigProvider/ConfigProvider.js.map +1 -1
  107. package/dist/cjs/components/ContentCard/ContentCard.js +4 -3
  108. package/dist/cjs/components/ContentCard/ContentCard.js.map +1 -1
  109. package/dist/cjs/components/CustomSelect/CustomSelect.d.ts +2 -2
  110. package/dist/cjs/components/CustomSelect/CustomSelect.js +28 -34
  111. package/dist/cjs/components/CustomSelect/CustomSelect.js.map +1 -1
  112. package/dist/cjs/components/CustomSelectDropdown/CustomSelectDropdown.js +1 -5
  113. package/dist/cjs/components/CustomSelectDropdown/CustomSelectDropdown.js.map +1 -1
  114. package/dist/cjs/components/CustomSelectOption/CustomSelectOption.d.ts +35 -6
  115. package/dist/cjs/components/CustomSelectOption/CustomSelectOption.js +24 -14
  116. package/dist/cjs/components/CustomSelectOption/CustomSelectOption.js.map +1 -1
  117. package/dist/cjs/components/DateInput/DateInput.d.ts +1 -1
  118. package/dist/cjs/components/DateInput/DateInput.js +15 -7
  119. package/dist/cjs/components/DateInput/DateInput.js.map +1 -1
  120. package/dist/cjs/components/DatePicker/DatePicker.js +6 -6
  121. package/dist/cjs/components/DatePicker/DatePicker.js.map +1 -1
  122. package/dist/cjs/components/DateRangeInput/DateRangeInput.js +7 -7
  123. package/dist/cjs/components/DateRangeInput/DateRangeInput.js.map +1 -1
  124. package/dist/cjs/components/Epic/Epic.js +1 -1
  125. package/dist/cjs/components/Epic/Epic.js.map +1 -1
  126. package/dist/cjs/components/File/File.js +2 -2
  127. package/dist/cjs/components/File/File.js.map +1 -1
  128. package/dist/cjs/components/FixedLayout/FixedLayout.js +2 -1
  129. package/dist/cjs/components/FixedLayout/FixedLayout.js.map +1 -1
  130. package/dist/cjs/components/FormField/FormField.d.ts +15 -1
  131. package/dist/cjs/components/FormField/FormField.js +8 -8
  132. package/dist/cjs/components/FormField/FormField.js.map +1 -1
  133. package/dist/cjs/components/FormItem/FormItem.js +4 -3
  134. package/dist/cjs/components/FormItem/FormItem.js.map +1 -1
  135. package/dist/cjs/components/FormLayoutGroup/FormLayoutGroup.js +2 -1
  136. package/dist/cjs/components/FormLayoutGroup/FormLayoutGroup.js.map +1 -1
  137. package/dist/cjs/components/Gallery/Gallery.d.ts +9 -1
  138. package/dist/cjs/components/Gallery/Gallery.js +10 -2
  139. package/dist/cjs/components/Gallery/Gallery.js.map +1 -1
  140. package/dist/cjs/components/GridAvatar/GridAvatar.d.ts +1 -0
  141. package/dist/cjs/components/GridAvatar/GridAvatar.js +6 -6
  142. package/dist/cjs/components/GridAvatar/GridAvatar.js.map +1 -1
  143. package/dist/cjs/components/Group/Group.js +2 -1
  144. package/dist/cjs/components/Group/Group.js.map +1 -1
  145. package/dist/cjs/components/Header/Header.js +10 -7
  146. package/dist/cjs/components/Header/Header.js.map +1 -1
  147. package/dist/cjs/components/HorizontalCell/HorizontalCell.js +2 -2
  148. package/dist/cjs/components/HorizontalCell/HorizontalCell.js.map +1 -1
  149. package/dist/cjs/components/HorizontalScroll/HorizontalScroll.d.ts +1 -2
  150. package/dist/cjs/components/HorizontalScroll/HorizontalScroll.js +34 -24
  151. package/dist/cjs/components/HorizontalScroll/HorizontalScroll.js.map +1 -1
  152. package/dist/cjs/components/InfoRow/InfoRow.js +2 -2
  153. package/dist/cjs/components/InfoRow/InfoRow.js.map +1 -1
  154. package/dist/cjs/components/Input/Input.d.ts +1 -2
  155. package/dist/cjs/components/Input/Input.js +13 -15
  156. package/dist/cjs/components/Input/Input.js.map +1 -1
  157. package/dist/cjs/components/List/List.js +1 -0
  158. package/dist/cjs/components/List/List.js.map +1 -1
  159. package/dist/cjs/components/MiniInfoCell/MiniInfoCell.js +1 -0
  160. package/dist/cjs/components/MiniInfoCell/MiniInfoCell.js.map +1 -1
  161. package/dist/cjs/components/ModalCard/ModalCard.d.ts +1 -1
  162. package/dist/cjs/components/ModalCard/ModalCard.js +1 -0
  163. package/dist/cjs/components/ModalCard/ModalCard.js.map +1 -1
  164. package/dist/cjs/components/ModalCardBase/ModalCardBase.d.ts +5 -1
  165. package/dist/cjs/components/ModalCardBase/ModalCardBase.js +10 -4
  166. package/dist/cjs/components/ModalCardBase/ModalCardBase.js.map +1 -1
  167. package/dist/cjs/components/ModalPage/ModalPage.d.ts +16 -1
  168. package/dist/cjs/components/ModalPage/ModalPage.js +5 -1
  169. package/dist/cjs/components/ModalPage/ModalPage.js.map +1 -1
  170. package/dist/cjs/components/ModalPageHeader/ModalPageHeader.js +1 -0
  171. package/dist/cjs/components/ModalPageHeader/ModalPageHeader.js.map +1 -1
  172. package/dist/cjs/components/ModalRoot/ModalRoot.d.ts +14 -2
  173. package/dist/cjs/components/ModalRoot/ModalRoot.js +14 -11
  174. package/dist/cjs/components/ModalRoot/ModalRoot.js.map +1 -1
  175. package/dist/cjs/components/ModalRoot/ModalRootAdaptive.d.ts +15 -3
  176. package/dist/cjs/components/ModalRoot/ModalRootAdaptive.js +3 -0
  177. package/dist/cjs/components/ModalRoot/ModalRootAdaptive.js.map +1 -1
  178. package/dist/cjs/components/ModalRoot/ModalRootDesktop.d.ts +14 -2
  179. package/dist/cjs/components/ModalRoot/ModalRootDesktop.js +10 -7
  180. package/dist/cjs/components/ModalRoot/ModalRootDesktop.js.map +1 -1
  181. package/dist/cjs/components/ModalRoot/types.d.ts +16 -1
  182. package/dist/cjs/components/ModalRoot/types.js.map +1 -1
  183. package/dist/cjs/components/ModalRoot/useModalManager.d.ts +6 -5
  184. package/dist/cjs/components/ModalRoot/useModalManager.js +54 -16
  185. package/dist/cjs/components/ModalRoot/useModalManager.js.map +1 -1
  186. package/dist/cjs/components/NativeSelect/NativeSelect.d.ts +1 -2
  187. package/dist/cjs/components/NativeSelect/NativeSelect.js +7 -8
  188. package/dist/cjs/components/NativeSelect/NativeSelect.js.map +1 -1
  189. package/dist/cjs/components/Pagination/Pagination.d.ts +3 -3
  190. package/dist/cjs/components/Pagination/Pagination.js +3 -3
  191. package/dist/cjs/components/Pagination/Pagination.js.map +1 -1
  192. package/dist/cjs/components/Panel/Panel.js +2 -1
  193. package/dist/cjs/components/Panel/Panel.js.map +1 -1
  194. package/dist/cjs/components/PanelHeader/PanelHeader.js +4 -3
  195. package/dist/cjs/components/PanelHeader/PanelHeader.js.map +1 -1
  196. package/dist/cjs/components/PanelHeaderBack/PanelHeaderBack.js +1 -0
  197. package/dist/cjs/components/PanelHeaderBack/PanelHeaderBack.js.map +1 -1
  198. package/dist/cjs/components/PanelHeaderButton/PanelHeaderButton.js +5 -4
  199. package/dist/cjs/components/PanelHeaderButton/PanelHeaderButton.js.map +1 -1
  200. package/dist/cjs/components/PanelHeaderContext/PanelHeaderContext.js +5 -1
  201. package/dist/cjs/components/PanelHeaderContext/PanelHeaderContext.js.map +1 -1
  202. package/dist/cjs/components/Placeholder/Placeholder.js +4 -3
  203. package/dist/cjs/components/Placeholder/Placeholder.js.map +1 -1
  204. package/dist/cjs/components/PopoutWrapper/PopoutWrapper.js +1 -0
  205. package/dist/cjs/components/PopoutWrapper/PopoutWrapper.js.map +1 -1
  206. package/dist/cjs/components/Popper/Popper.js +2 -2
  207. package/dist/cjs/components/Popper/Popper.js.map +1 -1
  208. package/dist/cjs/components/PromoBanner/PromoBanner.js +2 -2
  209. package/dist/cjs/components/PromoBanner/PromoBanner.js.map +1 -1
  210. package/dist/cjs/components/PullToRefresh/PullToRefresh.js +2 -1
  211. package/dist/cjs/components/PullToRefresh/PullToRefresh.js.map +1 -1
  212. package/dist/cjs/components/PullToRefresh/PullToRefreshSpinner.js +1 -0
  213. package/dist/cjs/components/PullToRefresh/PullToRefreshSpinner.js.map +1 -1
  214. package/dist/cjs/components/RichCell/RichCell.js +3 -2
  215. package/dist/cjs/components/RichCell/RichCell.js.map +1 -1
  216. package/dist/cjs/components/RichTooltip/RichTooltip.js +2 -1
  217. package/dist/cjs/components/RichTooltip/RichTooltip.js.map +1 -1
  218. package/dist/cjs/components/Root/Root.js +8 -7
  219. package/dist/cjs/components/Root/Root.js.map +1 -1
  220. package/dist/cjs/components/ScreenSpinner/ScreenSpinner.js +3 -0
  221. package/dist/cjs/components/ScreenSpinner/ScreenSpinner.js.map +1 -1
  222. package/dist/cjs/components/Search/Search.js +3 -2
  223. package/dist/cjs/components/Search/Search.js.map +1 -1
  224. package/dist/cjs/components/SegmentedControl/SegmentedControl.js +19 -13
  225. package/dist/cjs/components/SegmentedControl/SegmentedControl.js.map +1 -1
  226. package/dist/cjs/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js +2 -1
  227. package/dist/cjs/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js.map +1 -1
  228. package/dist/cjs/components/Select/Select.d.ts +1 -2
  229. package/dist/cjs/components/Select/Select.js +9 -11
  230. package/dist/cjs/components/Select/Select.js.map +1 -1
  231. package/dist/cjs/components/SelectMimicry/SelectMimicry.d.ts +3 -3
  232. package/dist/cjs/components/SelectMimicry/SelectMimicry.js +5 -2
  233. package/dist/cjs/components/SelectMimicry/SelectMimicry.js.map +1 -1
  234. package/dist/cjs/components/Separator/Separator.js +3 -1
  235. package/dist/cjs/components/Separator/Separator.js.map +1 -1
  236. package/dist/cjs/components/SimpleCell/SimpleCell.js +5 -4
  237. package/dist/cjs/components/SimpleCell/SimpleCell.js.map +1 -1
  238. package/dist/cjs/components/SimpleCheckbox/SimpleCheckbox.js +6 -2
  239. package/dist/cjs/components/SimpleCheckbox/SimpleCheckbox.js.map +1 -1
  240. package/dist/cjs/components/SliderSwitch/SliderSwitch.js +1 -0
  241. package/dist/cjs/components/SliderSwitch/SliderSwitch.js.map +1 -1
  242. package/dist/cjs/components/SliderSwitch/SliderSwitchButton.js +1 -0
  243. package/dist/cjs/components/SliderSwitch/SliderSwitchButton.js.map +1 -1
  244. package/dist/cjs/components/Snackbar/Snackbar.js +3 -2
  245. package/dist/cjs/components/Snackbar/Snackbar.js.map +1 -1
  246. package/dist/cjs/components/Spacing/Spacing.js +2 -1
  247. package/dist/cjs/components/Spacing/Spacing.js.map +1 -1
  248. package/dist/cjs/components/SplitCol/SplitCol.js +2 -1
  249. package/dist/cjs/components/SplitCol/SplitCol.js.map +1 -1
  250. package/dist/cjs/components/SplitLayout/SplitLayout.js +2 -1
  251. package/dist/cjs/components/SplitLayout/SplitLayout.js.map +1 -1
  252. package/dist/cjs/components/SubnavigationBar/SubnavigationBar.js +2 -2
  253. package/dist/cjs/components/SubnavigationBar/SubnavigationBar.js.map +1 -1
  254. package/dist/cjs/components/SubnavigationButton/SubnavigationButton.js +4 -3
  255. package/dist/cjs/components/SubnavigationButton/SubnavigationButton.js.map +1 -1
  256. package/dist/cjs/components/Switch/Switch.js +1 -0
  257. package/dist/cjs/components/Switch/Switch.js.map +1 -1
  258. package/dist/cjs/components/Tabbar/Tabbar.js +1 -0
  259. package/dist/cjs/components/Tabbar/Tabbar.js.map +1 -1
  260. package/dist/cjs/components/TabbarItem/TabbarItem.d.ts +1 -1
  261. package/dist/cjs/components/TabbarItem/TabbarItem.js +2 -1
  262. package/dist/cjs/components/TabbarItem/TabbarItem.js.map +1 -1
  263. package/dist/cjs/components/TabsItem/TabsItem.js +3 -2
  264. package/dist/cjs/components/TabsItem/TabsItem.js.map +1 -1
  265. package/dist/cjs/components/Tappable/Tappable.js +5 -4
  266. package/dist/cjs/components/Tappable/Tappable.js.map +1 -1
  267. package/dist/cjs/components/TextTooltip/TextTooltip.js +3 -3
  268. package/dist/cjs/components/TextTooltip/TextTooltip.js.map +1 -1
  269. package/dist/cjs/components/Tooltip/Tooltip.js +6 -6
  270. package/dist/cjs/components/Tooltip/Tooltip.js.map +1 -1
  271. package/dist/cjs/components/Touch/Touch.js +9 -3
  272. package/dist/cjs/components/Touch/Touch.js.map +1 -1
  273. package/dist/cjs/components/Touch/TouchContext.d.ts +1 -1
  274. package/dist/cjs/components/Touch/TouchContext.js +1 -1
  275. package/dist/cjs/components/Touch/TouchContext.js.map +1 -1
  276. package/dist/cjs/components/Typography/Paragraph/Paragraph.d.ts +10 -0
  277. package/dist/cjs/components/Typography/Paragraph/Paragraph.js +42 -0
  278. package/dist/cjs/components/Typography/Paragraph/Paragraph.js.map +1 -0
  279. package/dist/cjs/components/Typography/Subhead/Subhead.d.ts +1 -2
  280. package/dist/cjs/components/Typography/Subhead/Subhead.js +4 -6
  281. package/dist/cjs/components/Typography/Subhead/Subhead.js.map +1 -1
  282. package/dist/cjs/components/Typography/Text/Text.js +1 -1
  283. package/dist/cjs/components/Typography/Text/Text.js.map +1 -1
  284. package/dist/cjs/components/Typography/Title/Title.d.ts +1 -2
  285. package/dist/cjs/components/Typography/Title/Title.js +5 -11
  286. package/dist/cjs/components/Typography/Title/Title.js.map +1 -1
  287. package/dist/cjs/components/UsersStack/UsersStack.js +3 -2
  288. package/dist/cjs/components/UsersStack/UsersStack.js.map +1 -1
  289. package/dist/cjs/components/View/View.js +5 -0
  290. package/dist/cjs/components/View/View.js.map +1 -1
  291. package/dist/cjs/components/View/ViewInfinite.js +5 -0
  292. package/dist/cjs/components/View/ViewInfinite.js.map +1 -1
  293. package/dist/cjs/components/View/utils.js +5 -2
  294. package/dist/cjs/components/View/utils.js.map +1 -1
  295. package/dist/cjs/components/WriteBarIcon/WriteBarIcon.js +3 -2
  296. package/dist/cjs/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
  297. package/dist/cjs/helpers/scheme.js +2 -2
  298. package/dist/cjs/helpers/scheme.js.map +1 -1
  299. package/dist/cjs/hooks/useBridgeAdaptivity.d.ts +6 -0
  300. package/dist/cjs/hooks/useBridgeAdaptivity.js +85 -0
  301. package/dist/cjs/hooks/useBridgeAdaptivity.js.map +1 -0
  302. package/dist/cjs/hooks/useCalendar.d.ts +4 -3
  303. package/dist/cjs/hooks/useCalendar.js +19 -10
  304. package/dist/cjs/hooks/useCalendar.js.map +1 -1
  305. package/dist/cjs/hooks/useKeyboard.d.ts +1 -1
  306. package/dist/cjs/hooks/useKeyboard.js +1 -1
  307. package/dist/cjs/hooks/useKeyboard.js.map +1 -1
  308. package/dist/cjs/hooks/usePagination.d.ts +3 -3
  309. package/dist/cjs/hooks/usePagination.js +3 -3
  310. package/dist/cjs/hooks/usePagination.js.map +1 -1
  311. package/dist/cjs/hooks/usePatchChildrenRef.js +1 -1
  312. package/dist/cjs/hooks/usePatchChildrenRef.js.map +1 -1
  313. package/dist/cjs/hooks/useWaitTransitionFinish.js +6 -1
  314. package/dist/cjs/hooks/useWaitTransitionFinish.js.map +1 -1
  315. package/dist/cjs/index.d.ts +21 -10
  316. package/dist/cjs/index.js +28 -20
  317. package/dist/cjs/index.js.map +1 -1
  318. package/dist/cjs/lib/calendar.js +12 -23
  319. package/dist/cjs/lib/calendar.js.map +1 -1
  320. package/dist/cjs/lib/date.d.ts +29 -0
  321. package/dist/cjs/lib/date.js +286 -0
  322. package/dist/cjs/lib/date.js.map +1 -0
  323. package/dist/cjs/lib/getNavId.d.ts +2 -1
  324. package/dist/cjs/lib/getNavId.js +1 -1
  325. package/dist/cjs/lib/getNavId.js.map +1 -1
  326. package/dist/cjs/lib/platform.js +29 -0
  327. package/dist/cjs/lib/platform.js.map +1 -1
  328. package/dist/cjs/lib/warnOnce.d.ts +2 -1
  329. package/dist/cjs/lib/warnOnce.js +3 -1
  330. package/dist/cjs/lib/warnOnce.js.map +1 -1
  331. package/dist/cjs/tokenized/index.d.ts +22 -4
  332. package/dist/cjs/tokenized/index.js +80 -10
  333. package/dist/cjs/tokenized/index.js.map +1 -1
  334. package/dist/components/ActionSheet/ActionSheet.js +3 -1
  335. package/dist/components/ActionSheet/ActionSheet.js.map +1 -1
  336. package/dist/components/ActionSheet/ActionSheetDropdown.js +2 -1
  337. package/dist/components/ActionSheet/ActionSheetDropdown.js.map +1 -1
  338. package/dist/components/ActionSheet/ActionSheetDropdownDesktop.js +1 -1
  339. package/dist/components/ActionSheet/ActionSheetDropdownDesktop.js.map +1 -1
  340. package/dist/components/ActionSheetItem/ActionSheetItem.js +4 -3
  341. package/dist/components/ActionSheetItem/ActionSheetItem.js.map +1 -1
  342. package/dist/components/AdaptivityProvider/AdaptivityProvider.js +43 -11
  343. package/dist/components/AdaptivityProvider/AdaptivityProvider.js.map +1 -1
  344. package/dist/components/Alert/Alert.d.ts +4 -1
  345. package/dist/components/Alert/Alert.js +22 -5
  346. package/dist/components/Alert/Alert.js.map +1 -1
  347. package/dist/components/AppRoot/AppRoot.js +19 -3
  348. package/dist/components/AppRoot/AppRoot.js.map +1 -1
  349. package/dist/components/AppRoot/ScrollContext.d.ts +6 -14
  350. package/dist/components/AppRoot/ScrollContext.js +87 -1
  351. package/dist/components/AppRoot/ScrollContext.js.map +1 -1
  352. package/dist/components/Avatar/Avatar.js +4 -1
  353. package/dist/components/Avatar/Avatar.js.map +1 -1
  354. package/dist/components/Banner/Banner.js +3 -2
  355. package/dist/components/Banner/Banner.js.map +1 -1
  356. package/dist/components/Button/Button.d.ts +1 -2
  357. package/dist/components/Button/Button.js +29 -33
  358. package/dist/components/Button/Button.js.map +1 -1
  359. package/dist/components/Calendar/Calendar.d.ts +10 -1
  360. package/dist/components/Calendar/Calendar.js +14 -7
  361. package/dist/components/Calendar/Calendar.js.map +1 -1
  362. package/dist/components/CalendarDay/CalendarDay.js +4 -1
  363. package/dist/components/CalendarDay/CalendarDay.js.map +1 -1
  364. package/dist/components/CalendarDays/CalendarDays.js +1 -1
  365. package/dist/components/CalendarDays/CalendarDays.js.map +1 -1
  366. package/dist/components/CalendarHeader/CalendarHeader.d.ts +6 -0
  367. package/dist/components/CalendarHeader/CalendarHeader.js +8 -8
  368. package/dist/components/CalendarHeader/CalendarHeader.js.map +1 -1
  369. package/dist/components/CalendarRange/CalendarRange.js +2 -5
  370. package/dist/components/CalendarRange/CalendarRange.js.map +1 -1
  371. package/dist/components/CalendarTime/CalendarTime.js +3 -3
  372. package/dist/components/CalendarTime/CalendarTime.js.map +1 -1
  373. package/dist/components/CardScroll/CardScroll.js +2 -1
  374. package/dist/components/CardScroll/CardScroll.js.map +1 -1
  375. package/dist/components/Cell/Cell.d.ts +1 -1
  376. package/dist/components/Cell/Cell.js +4 -3
  377. package/dist/components/Cell/Cell.js.map +1 -1
  378. package/dist/components/CellButton/CellButton.js +1 -0
  379. package/dist/components/CellButton/CellButton.js.map +1 -1
  380. package/dist/components/Chip/Chip.js +1 -0
  381. package/dist/components/Chip/Chip.js.map +1 -1
  382. package/dist/components/ChipsInput/ChipsInput.d.ts +1 -2
  383. package/dist/components/ChipsInput/ChipsInput.js +6 -11
  384. package/dist/components/ChipsInput/ChipsInput.js.map +1 -1
  385. package/dist/components/ChipsSelect/ChipsSelect.d.ts +2 -2
  386. package/dist/components/ChipsSelect/ChipsSelect.js +3 -6
  387. package/dist/components/ChipsSelect/ChipsSelect.js.map +1 -1
  388. package/dist/components/ClickPopper/ClickPopper.d.ts +1 -1
  389. package/dist/components/ClickPopper/ClickPopper.js.map +1 -1
  390. package/dist/components/ConfigProvider/ConfigProvider.js +1 -1
  391. package/dist/components/ConfigProvider/ConfigProvider.js.map +1 -1
  392. package/dist/components/ContentCard/ContentCard.js +3 -2
  393. package/dist/components/ContentCard/ContentCard.js.map +1 -1
  394. package/dist/components/CustomSelect/CustomSelect.d.ts +2 -2
  395. package/dist/components/CustomSelect/CustomSelect.js +24 -28
  396. package/dist/components/CustomSelect/CustomSelect.js.map +1 -1
  397. package/dist/components/CustomSelectDropdown/CustomSelectDropdown.js +1 -5
  398. package/dist/components/CustomSelectDropdown/CustomSelectDropdown.js.map +1 -1
  399. package/dist/components/CustomSelectOption/CustomSelectOption.d.ts +35 -6
  400. package/dist/components/CustomSelectOption/CustomSelectOption.js +19 -15
  401. package/dist/components/CustomSelectOption/CustomSelectOption.js.map +1 -1
  402. package/dist/components/DateInput/DateInput.d.ts +1 -1
  403. package/dist/components/DateInput/DateInput.js +13 -5
  404. package/dist/components/DateInput/DateInput.js.map +1 -1
  405. package/dist/components/DatePicker/DatePicker.js +2 -2
  406. package/dist/components/DatePicker/DatePicker.js.map +1 -1
  407. package/dist/components/DateRangeInput/DateRangeInput.js +2 -2
  408. package/dist/components/DateRangeInput/DateRangeInput.js.map +1 -1
  409. package/dist/components/Epic/Epic.js +1 -1
  410. package/dist/components/Epic/Epic.js.map +1 -1
  411. package/dist/components/File/File.js +1 -1
  412. package/dist/components/File/File.js.map +1 -1
  413. package/dist/components/FixedLayout/FixedLayout.js +2 -1
  414. package/dist/components/FixedLayout/FixedLayout.js.map +1 -1
  415. package/dist/components/FormField/FormField.d.ts +15 -1
  416. package/dist/components/FormField/FormField.js +8 -8
  417. package/dist/components/FormField/FormField.js.map +1 -1
  418. package/dist/components/FormItem/FormItem.js +3 -2
  419. package/dist/components/FormItem/FormItem.js.map +1 -1
  420. package/dist/components/FormLayoutGroup/FormLayoutGroup.js +2 -1
  421. package/dist/components/FormLayoutGroup/FormLayoutGroup.js.map +1 -1
  422. package/dist/components/Gallery/Gallery.d.ts +9 -1
  423. package/dist/components/Gallery/Gallery.js +10 -2
  424. package/dist/components/Gallery/Gallery.js.map +1 -1
  425. package/dist/components/GridAvatar/GridAvatar.d.ts +1 -0
  426. package/dist/components/GridAvatar/GridAvatar.js +5 -6
  427. package/dist/components/GridAvatar/GridAvatar.js.map +1 -1
  428. package/dist/components/Group/Group.js +2 -1
  429. package/dist/components/Group/Group.js.map +1 -1
  430. package/dist/components/Header/Header.js +7 -4
  431. package/dist/components/Header/Header.js.map +1 -1
  432. package/dist/components/HorizontalCell/HorizontalCell.js +1 -1
  433. package/dist/components/HorizontalCell/HorizontalCell.js.map +1 -1
  434. package/dist/components/HorizontalScroll/HorizontalScroll.d.ts +1 -2
  435. package/dist/components/HorizontalScroll/HorizontalScroll.js +32 -21
  436. package/dist/components/HorizontalScroll/HorizontalScroll.js.map +1 -1
  437. package/dist/components/InfoRow/InfoRow.js +1 -1
  438. package/dist/components/InfoRow/InfoRow.js.map +1 -1
  439. package/dist/components/Input/Input.d.ts +1 -2
  440. package/dist/components/Input/Input.js +10 -10
  441. package/dist/components/Input/Input.js.map +1 -1
  442. package/dist/components/List/List.js +1 -0
  443. package/dist/components/List/List.js.map +1 -1
  444. package/dist/components/MiniInfoCell/MiniInfoCell.js +1 -0
  445. package/dist/components/MiniInfoCell/MiniInfoCell.js.map +1 -1
  446. package/dist/components/ModalCard/ModalCard.d.ts +1 -1
  447. package/dist/components/ModalCard/ModalCard.js +1 -0
  448. package/dist/components/ModalCard/ModalCard.js.map +1 -1
  449. package/dist/components/ModalCardBase/ModalCardBase.d.ts +5 -1
  450. package/dist/components/ModalCardBase/ModalCardBase.js +9 -3
  451. package/dist/components/ModalCardBase/ModalCardBase.js.map +1 -1
  452. package/dist/components/ModalPage/ModalPage.d.ts +16 -1
  453. package/dist/components/ModalPage/ModalPage.js +5 -1
  454. package/dist/components/ModalPage/ModalPage.js.map +1 -1
  455. package/dist/components/ModalPageHeader/ModalPageHeader.js +1 -0
  456. package/dist/components/ModalPageHeader/ModalPageHeader.js.map +1 -1
  457. package/dist/components/ModalRoot/ModalRoot.d.ts +14 -2
  458. package/dist/components/ModalRoot/ModalRoot.js +14 -11
  459. package/dist/components/ModalRoot/ModalRoot.js.map +1 -1
  460. package/dist/components/ModalRoot/ModalRootAdaptive.d.ts +15 -3
  461. package/dist/components/ModalRoot/ModalRootAdaptive.js +2 -0
  462. package/dist/components/ModalRoot/ModalRootAdaptive.js.map +1 -1
  463. package/dist/components/ModalRoot/ModalRootDesktop.d.ts +14 -2
  464. package/dist/components/ModalRoot/ModalRootDesktop.js +10 -7
  465. package/dist/components/ModalRoot/ModalRootDesktop.js.map +1 -1
  466. package/dist/components/ModalRoot/types.d.ts +16 -1
  467. package/dist/components/ModalRoot/types.js.map +1 -1
  468. package/dist/components/ModalRoot/useModalManager.d.ts +6 -5
  469. package/dist/components/ModalRoot/useModalManager.js +54 -16
  470. package/dist/components/ModalRoot/useModalManager.js.map +1 -1
  471. package/dist/components/NativeSelect/NativeSelect.d.ts +1 -2
  472. package/dist/components/NativeSelect/NativeSelect.js +5 -5
  473. package/dist/components/NativeSelect/NativeSelect.js.map +1 -1
  474. package/dist/components/Pagination/Pagination.d.ts +3 -3
  475. package/dist/components/Pagination/Pagination.js +1 -1
  476. package/dist/components/Pagination/Pagination.js.map +1 -1
  477. package/dist/components/Panel/Panel.js +2 -1
  478. package/dist/components/Panel/Panel.js.map +1 -1
  479. package/dist/components/PanelHeader/PanelHeader.js +4 -3
  480. package/dist/components/PanelHeader/PanelHeader.js.map +1 -1
  481. package/dist/components/PanelHeaderBack/PanelHeaderBack.js +1 -0
  482. package/dist/components/PanelHeaderBack/PanelHeaderBack.js.map +1 -1
  483. package/dist/components/PanelHeaderButton/PanelHeaderButton.js +4 -3
  484. package/dist/components/PanelHeaderButton/PanelHeaderButton.js.map +1 -1
  485. package/dist/components/PanelHeaderContext/PanelHeaderContext.js +4 -1
  486. package/dist/components/PanelHeaderContext/PanelHeaderContext.js.map +1 -1
  487. package/dist/components/Placeholder/Placeholder.js +3 -2
  488. package/dist/components/Placeholder/Placeholder.js.map +1 -1
  489. package/dist/components/PopoutWrapper/PopoutWrapper.js +1 -0
  490. package/dist/components/PopoutWrapper/PopoutWrapper.js.map +1 -1
  491. package/dist/components/Popper/Popper.js +2 -2
  492. package/dist/components/Popper/Popper.js.map +1 -1
  493. package/dist/components/PromoBanner/PromoBanner.js +1 -1
  494. package/dist/components/PromoBanner/PromoBanner.js.map +1 -1
  495. package/dist/components/PullToRefresh/PullToRefresh.js +2 -1
  496. package/dist/components/PullToRefresh/PullToRefresh.js.map +1 -1
  497. package/dist/components/PullToRefresh/PullToRefreshSpinner.js +1 -0
  498. package/dist/components/PullToRefresh/PullToRefreshSpinner.js.map +1 -1
  499. package/dist/components/RichCell/RichCell.js +2 -1
  500. package/dist/components/RichCell/RichCell.js.map +1 -1
  501. package/dist/components/RichTooltip/RichTooltip.js +2 -1
  502. package/dist/components/RichTooltip/RichTooltip.js.map +1 -1
  503. package/dist/components/Root/Root.js +8 -7
  504. package/dist/components/Root/Root.js.map +1 -1
  505. package/dist/components/ScreenSpinner/ScreenSpinner.js +2 -0
  506. package/dist/components/ScreenSpinner/ScreenSpinner.js.map +1 -1
  507. package/dist/components/Search/Search.js +2 -1
  508. package/dist/components/Search/Search.js.map +1 -1
  509. package/dist/components/SegmentedControl/SegmentedControl.js +19 -13
  510. package/dist/components/SegmentedControl/SegmentedControl.js.map +1 -1
  511. package/dist/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js +2 -1
  512. package/dist/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js.map +1 -1
  513. package/dist/components/Select/Select.d.ts +1 -2
  514. package/dist/components/Select/Select.js +5 -6
  515. package/dist/components/Select/Select.js.map +1 -1
  516. package/dist/components/SelectMimicry/SelectMimicry.d.ts +3 -3
  517. package/dist/components/SelectMimicry/SelectMimicry.js +5 -2
  518. package/dist/components/SelectMimicry/SelectMimicry.js.map +1 -1
  519. package/dist/components/Separator/Separator.js +3 -1
  520. package/dist/components/Separator/Separator.js.map +1 -1
  521. package/dist/components/SimpleCell/SimpleCell.js +3 -2
  522. package/dist/components/SimpleCell/SimpleCell.js.map +1 -1
  523. package/dist/components/SimpleCheckbox/SimpleCheckbox.js +6 -2
  524. package/dist/components/SimpleCheckbox/SimpleCheckbox.js.map +1 -1
  525. package/dist/components/SliderSwitch/SliderSwitch.js +1 -0
  526. package/dist/components/SliderSwitch/SliderSwitch.js.map +1 -1
  527. package/dist/components/SliderSwitch/SliderSwitchButton.js +1 -0
  528. package/dist/components/SliderSwitch/SliderSwitchButton.js.map +1 -1
  529. package/dist/components/Snackbar/Snackbar.js +2 -1
  530. package/dist/components/Snackbar/Snackbar.js.map +1 -1
  531. package/dist/components/Spacing/Spacing.js +2 -1
  532. package/dist/components/Spacing/Spacing.js.map +1 -1
  533. package/dist/components/SplitCol/SplitCol.js +2 -1
  534. package/dist/components/SplitCol/SplitCol.js.map +1 -1
  535. package/dist/components/SplitLayout/SplitLayout.js +2 -1
  536. package/dist/components/SplitLayout/SplitLayout.js.map +1 -1
  537. package/dist/components/SubnavigationBar/SubnavigationBar.js +1 -1
  538. package/dist/components/SubnavigationBar/SubnavigationBar.js.map +1 -1
  539. package/dist/components/SubnavigationButton/SubnavigationButton.js +3 -2
  540. package/dist/components/SubnavigationButton/SubnavigationButton.js.map +1 -1
  541. package/dist/components/Switch/Switch.js +1 -0
  542. package/dist/components/Switch/Switch.js.map +1 -1
  543. package/dist/components/Tabbar/Tabbar.js +1 -0
  544. package/dist/components/Tabbar/Tabbar.js.map +1 -1
  545. package/dist/components/TabbarItem/TabbarItem.d.ts +1 -1
  546. package/dist/components/TabbarItem/TabbarItem.js +2 -1
  547. package/dist/components/TabbarItem/TabbarItem.js.map +1 -1
  548. package/dist/components/TabsItem/TabsItem.js +2 -1
  549. package/dist/components/TabsItem/TabsItem.js.map +1 -1
  550. package/dist/components/Tappable/Tappable.js +5 -4
  551. package/dist/components/Tappable/Tappable.js.map +1 -1
  552. package/dist/components/TextTooltip/TextTooltip.js +1 -1
  553. package/dist/components/TextTooltip/TextTooltip.js.map +1 -1
  554. package/dist/components/Tooltip/Tooltip.js +4 -4
  555. package/dist/components/Tooltip/Tooltip.js.map +1 -1
  556. package/dist/components/Touch/Touch.js +9 -3
  557. package/dist/components/Touch/Touch.js.map +1 -1
  558. package/dist/components/Touch/TouchContext.d.ts +1 -1
  559. package/dist/components/Touch/TouchContext.js +1 -1
  560. package/dist/components/Touch/TouchContext.js.map +1 -1
  561. package/dist/components/Typography/Paragraph/Paragraph.d.ts +10 -0
  562. package/dist/components/Typography/Paragraph/Paragraph.js +25 -0
  563. package/dist/components/Typography/Paragraph/Paragraph.js.map +1 -0
  564. package/dist/components/Typography/Subhead/Subhead.d.ts +1 -2
  565. package/dist/components/Typography/Subhead/Subhead.js +3 -7
  566. package/dist/components/Typography/Subhead/Subhead.js.map +1 -1
  567. package/dist/components/Typography/Text/Text.js +1 -1
  568. package/dist/components/Typography/Text/Text.js.map +1 -1
  569. package/dist/components/Typography/Title/Title.d.ts +1 -2
  570. package/dist/components/Typography/Title/Title.js +3 -9
  571. package/dist/components/Typography/Title/Title.js.map +1 -1
  572. package/dist/components/UsersStack/UsersStack.js +2 -1
  573. package/dist/components/UsersStack/UsersStack.js.map +1 -1
  574. package/dist/components/View/View.js +5 -0
  575. package/dist/components/View/View.js.map +1 -1
  576. package/dist/components/View/ViewInfinite.js +5 -0
  577. package/dist/components/View/ViewInfinite.js.map +1 -1
  578. package/dist/components/View/utils.js +5 -2
  579. package/dist/components/View/utils.js.map +1 -1
  580. package/dist/components/WriteBarIcon/WriteBarIcon.js +3 -2
  581. package/dist/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
  582. package/dist/components.css +21 -6
  583. package/dist/components.css.map +1 -1
  584. package/dist/cssm/components/ActionSheet/ActionSheet.js +3 -1
  585. package/dist/cssm/components/ActionSheet/ActionSheet.js.map +1 -1
  586. package/dist/cssm/components/ActionSheet/ActionSheetDropdown.js +2 -1
  587. package/dist/cssm/components/ActionSheet/ActionSheetDropdown.js.map +1 -1
  588. package/dist/cssm/components/ActionSheet/ActionSheetDropdownDesktop.js +1 -1
  589. package/dist/cssm/components/ActionSheet/ActionSheetDropdownDesktop.js.map +1 -1
  590. package/dist/cssm/components/ActionSheetItem/ActionSheetItem.js +4 -3
  591. package/dist/cssm/components/ActionSheetItem/ActionSheetItem.js.map +1 -1
  592. package/dist/cssm/components/AdaptivityProvider/AdaptivityProvider.js +43 -11
  593. package/dist/cssm/components/AdaptivityProvider/AdaptivityProvider.js.map +1 -1
  594. package/dist/cssm/components/Alert/Alert.css +1 -1
  595. package/dist/cssm/components/Alert/Alert.d.ts +4 -1
  596. package/dist/cssm/components/Alert/Alert.js +22 -5
  597. package/dist/cssm/components/Alert/Alert.js.map +1 -1
  598. package/dist/cssm/components/AppRoot/AppRoot.js +19 -3
  599. package/dist/cssm/components/AppRoot/AppRoot.js.map +1 -1
  600. package/dist/cssm/components/AppRoot/ScrollContext.d.ts +6 -14
  601. package/dist/cssm/components/AppRoot/ScrollContext.js +87 -1
  602. package/dist/cssm/components/AppRoot/ScrollContext.js.map +1 -1
  603. package/dist/cssm/components/Avatar/Avatar.js +4 -1
  604. package/dist/cssm/components/Avatar/Avatar.js.map +1 -1
  605. package/dist/cssm/components/Banner/Banner.js +3 -2
  606. package/dist/cssm/components/Banner/Banner.js.map +1 -1
  607. package/dist/cssm/components/Button/Button.css +1 -1
  608. package/dist/cssm/components/Button/Button.d.ts +1 -2
  609. package/dist/cssm/components/Button/Button.js +29 -33
  610. package/dist/cssm/components/Button/Button.js.map +1 -1
  611. package/dist/cssm/components/Calendar/Calendar.d.ts +10 -1
  612. package/dist/cssm/components/Calendar/Calendar.js +14 -7
  613. package/dist/cssm/components/Calendar/Calendar.js.map +1 -1
  614. package/dist/cssm/components/CalendarDay/CalendarDay.css +1 -1
  615. package/dist/cssm/components/CalendarDay/CalendarDay.js +4 -1
  616. package/dist/cssm/components/CalendarDay/CalendarDay.js.map +1 -1
  617. package/dist/cssm/components/CalendarDays/CalendarDays.js +1 -1
  618. package/dist/cssm/components/CalendarDays/CalendarDays.js.map +1 -1
  619. package/dist/cssm/components/CalendarHeader/CalendarHeader.d.ts +6 -0
  620. package/dist/cssm/components/CalendarHeader/CalendarHeader.js +8 -8
  621. package/dist/cssm/components/CalendarHeader/CalendarHeader.js.map +1 -1
  622. package/dist/cssm/components/CalendarRange/CalendarRange.js +2 -5
  623. package/dist/cssm/components/CalendarRange/CalendarRange.js.map +1 -1
  624. package/dist/cssm/components/CalendarTime/CalendarTime.js +3 -3
  625. package/dist/cssm/components/CalendarTime/CalendarTime.js.map +1 -1
  626. package/dist/cssm/components/Card/Card.css +1 -1
  627. package/dist/cssm/components/CardScroll/CardScroll.js +2 -1
  628. package/dist/cssm/components/CardScroll/CardScroll.js.map +1 -1
  629. package/dist/cssm/components/Cell/Cell.d.ts +1 -1
  630. package/dist/cssm/components/Cell/Cell.js +4 -3
  631. package/dist/cssm/components/Cell/Cell.js.map +1 -1
  632. package/dist/cssm/components/CellButton/CellButton.js +1 -0
  633. package/dist/cssm/components/CellButton/CellButton.js.map +1 -1
  634. package/dist/cssm/components/Chip/Chip.js +1 -0
  635. package/dist/cssm/components/Chip/Chip.js.map +1 -1
  636. package/dist/cssm/components/ChipsInput/ChipsInput.css +1 -1
  637. package/dist/cssm/components/ChipsInput/ChipsInput.d.ts +1 -2
  638. package/dist/cssm/components/ChipsInput/ChipsInput.js +6 -11
  639. package/dist/cssm/components/ChipsInput/ChipsInput.js.map +1 -1
  640. package/dist/cssm/components/ChipsSelect/ChipsSelect.css +1 -1
  641. package/dist/cssm/components/ChipsSelect/ChipsSelect.d.ts +2 -2
  642. package/dist/cssm/components/ChipsSelect/ChipsSelect.js +3 -6
  643. package/dist/cssm/components/ChipsSelect/ChipsSelect.js.map +1 -1
  644. package/dist/cssm/components/ClickPopper/ClickPopper.d.ts +1 -1
  645. package/dist/cssm/components/ClickPopper/ClickPopper.js.map +1 -1
  646. package/dist/cssm/components/ConfigProvider/ConfigProvider.js +1 -1
  647. package/dist/cssm/components/ConfigProvider/ConfigProvider.js.map +1 -1
  648. package/dist/cssm/components/ContentCard/ContentCard.js +3 -2
  649. package/dist/cssm/components/ContentCard/ContentCard.js.map +1 -1
  650. package/dist/cssm/components/CustomSelect/CustomSelect.css +1 -1
  651. package/dist/cssm/components/CustomSelect/CustomSelect.d.ts +2 -2
  652. package/dist/cssm/components/CustomSelect/CustomSelect.js +24 -28
  653. package/dist/cssm/components/CustomSelect/CustomSelect.js.map +1 -1
  654. package/dist/cssm/components/CustomSelectDropdown/CustomSelectDropdown.css +3 -1
  655. package/dist/cssm/components/CustomSelectDropdown/CustomSelectDropdown.js +1 -5
  656. package/dist/cssm/components/CustomSelectDropdown/CustomSelectDropdown.js.map +1 -1
  657. package/dist/cssm/components/CustomSelectOption/CustomSelectOption.css +3 -1
  658. package/dist/cssm/components/CustomSelectOption/CustomSelectOption.d.ts +35 -6
  659. package/dist/cssm/components/CustomSelectOption/CustomSelectOption.js +19 -15
  660. package/dist/cssm/components/CustomSelectOption/CustomSelectOption.js.map +1 -1
  661. package/dist/cssm/components/DateInput/DateInput.css +1 -1
  662. package/dist/cssm/components/DateInput/DateInput.d.ts +1 -1
  663. package/dist/cssm/components/DateInput/DateInput.js +13 -5
  664. package/dist/cssm/components/DateInput/DateInput.js.map +1 -1
  665. package/dist/cssm/components/DatePicker/DatePicker.js +2 -2
  666. package/dist/cssm/components/DatePicker/DatePicker.js.map +1 -1
  667. package/dist/cssm/components/DateRangeInput/DateRangeInput.css +1 -1
  668. package/dist/cssm/components/DateRangeInput/DateRangeInput.js +2 -2
  669. package/dist/cssm/components/DateRangeInput/DateRangeInput.js.map +1 -1
  670. package/dist/cssm/components/Epic/Epic.js +1 -1
  671. package/dist/cssm/components/Epic/Epic.js.map +1 -1
  672. package/dist/cssm/components/File/File.js +1 -1
  673. package/dist/cssm/components/File/File.js.map +1 -1
  674. package/dist/cssm/components/FixedLayout/FixedLayout.css +1 -1
  675. package/dist/cssm/components/FixedLayout/FixedLayout.js +2 -1
  676. package/dist/cssm/components/FixedLayout/FixedLayout.js.map +1 -1
  677. package/dist/cssm/components/FormField/FormField.css +5 -1
  678. package/dist/cssm/components/FormField/FormField.d.ts +15 -1
  679. package/dist/cssm/components/FormField/FormField.js +8 -8
  680. package/dist/cssm/components/FormField/FormField.js.map +1 -1
  681. package/dist/cssm/components/FormItem/FormItem.js +3 -2
  682. package/dist/cssm/components/FormItem/FormItem.js.map +1 -1
  683. package/dist/cssm/components/FormLayoutGroup/FormLayoutGroup.js +2 -1
  684. package/dist/cssm/components/FormLayoutGroup/FormLayoutGroup.js.map +1 -1
  685. package/dist/cssm/components/FormStatus/FormStatus.css +1 -1
  686. package/dist/cssm/components/Gallery/Gallery.d.ts +9 -1
  687. package/dist/cssm/components/Gallery/Gallery.js +10 -2
  688. package/dist/cssm/components/Gallery/Gallery.js.map +1 -1
  689. package/dist/cssm/components/Gradient/Gradient.css +1 -1
  690. package/dist/cssm/components/GridAvatar/GridAvatar.css +1 -1
  691. package/dist/cssm/components/GridAvatar/GridAvatar.d.ts +1 -0
  692. package/dist/cssm/components/GridAvatar/GridAvatar.js +5 -6
  693. package/dist/cssm/components/GridAvatar/GridAvatar.js.map +1 -1
  694. package/dist/cssm/components/Group/Group.js +2 -1
  695. package/dist/cssm/components/Group/Group.js.map +1 -1
  696. package/dist/cssm/components/Header/Header.js +7 -4
  697. package/dist/cssm/components/Header/Header.js.map +1 -1
  698. package/dist/cssm/components/HorizontalCell/HorizontalCell.js +1 -1
  699. package/dist/cssm/components/HorizontalCell/HorizontalCell.js.map +1 -1
  700. package/dist/cssm/components/HorizontalScroll/HorizontalScroll.d.ts +1 -2
  701. package/dist/cssm/components/HorizontalScroll/HorizontalScroll.js +32 -21
  702. package/dist/cssm/components/HorizontalScroll/HorizontalScroll.js.map +1 -1
  703. package/dist/cssm/components/InfoRow/InfoRow.js +1 -1
  704. package/dist/cssm/components/InfoRow/InfoRow.js.map +1 -1
  705. package/dist/cssm/components/Input/Input.css +1 -1
  706. package/dist/cssm/components/Input/Input.d.ts +1 -2
  707. package/dist/cssm/components/Input/Input.js +10 -10
  708. package/dist/cssm/components/Input/Input.js.map +1 -1
  709. package/dist/cssm/components/InputLike/InputLike.css +1 -1
  710. package/dist/cssm/components/InputLike/InputLikeDivider.css +1 -1
  711. package/dist/cssm/components/List/List.js +1 -0
  712. package/dist/cssm/components/List/List.js.map +1 -1
  713. package/dist/cssm/components/MiniInfoCell/MiniInfoCell.js +1 -0
  714. package/dist/cssm/components/MiniInfoCell/MiniInfoCell.js.map +1 -1
  715. package/dist/cssm/components/ModalCard/ModalCard.css +1 -1
  716. package/dist/cssm/components/ModalCard/ModalCard.d.ts +1 -1
  717. package/dist/cssm/components/ModalCard/ModalCard.js +1 -0
  718. package/dist/cssm/components/ModalCard/ModalCard.js.map +1 -1
  719. package/dist/cssm/components/ModalCardBase/ModalCardBase.css +1 -1
  720. package/dist/cssm/components/ModalCardBase/ModalCardBase.d.ts +5 -1
  721. package/dist/cssm/components/ModalCardBase/ModalCardBase.js +9 -3
  722. package/dist/cssm/components/ModalCardBase/ModalCardBase.js.map +1 -1
  723. package/dist/cssm/components/ModalPage/ModalPage.d.ts +16 -1
  724. package/dist/cssm/components/ModalPage/ModalPage.js +5 -1
  725. package/dist/cssm/components/ModalPage/ModalPage.js.map +1 -1
  726. package/dist/cssm/components/ModalPageHeader/ModalPageHeader.js +1 -0
  727. package/dist/cssm/components/ModalPageHeader/ModalPageHeader.js.map +1 -1
  728. package/dist/cssm/components/ModalRoot/ModalRoot.css +1 -1
  729. package/dist/cssm/components/ModalRoot/ModalRoot.d.ts +14 -2
  730. package/dist/cssm/components/ModalRoot/ModalRoot.js +14 -11
  731. package/dist/cssm/components/ModalRoot/ModalRoot.js.map +1 -1
  732. package/dist/cssm/components/ModalRoot/ModalRootAdaptive.d.ts +15 -3
  733. package/dist/cssm/components/ModalRoot/ModalRootAdaptive.js +2 -0
  734. package/dist/cssm/components/ModalRoot/ModalRootAdaptive.js.map +1 -1
  735. package/dist/cssm/components/ModalRoot/ModalRootDesktop.d.ts +14 -2
  736. package/dist/cssm/components/ModalRoot/ModalRootDesktop.js +10 -7
  737. package/dist/cssm/components/ModalRoot/ModalRootDesktop.js.map +1 -1
  738. package/dist/cssm/components/ModalRoot/types.d.ts +16 -1
  739. package/dist/cssm/components/ModalRoot/types.js.map +1 -1
  740. package/dist/cssm/components/ModalRoot/useModalManager.d.ts +6 -5
  741. package/dist/cssm/components/ModalRoot/useModalManager.js +54 -16
  742. package/dist/cssm/components/ModalRoot/useModalManager.js.map +1 -1
  743. package/dist/cssm/components/NativeSelect/NativeSelect.d.ts +1 -2
  744. package/dist/cssm/components/NativeSelect/NativeSelect.js +5 -5
  745. package/dist/cssm/components/NativeSelect/NativeSelect.js.map +1 -1
  746. package/dist/cssm/components/Pagination/Pagination.css +1 -1
  747. package/dist/cssm/components/Pagination/Pagination.d.ts +3 -3
  748. package/dist/cssm/components/Pagination/Pagination.js +1 -1
  749. package/dist/cssm/components/Pagination/Pagination.js.map +1 -1
  750. package/dist/cssm/components/Panel/Panel.js +2 -1
  751. package/dist/cssm/components/Panel/Panel.js.map +1 -1
  752. package/dist/cssm/components/PanelHeader/PanelHeader.css +1 -1
  753. package/dist/cssm/components/PanelHeader/PanelHeader.js +4 -3
  754. package/dist/cssm/components/PanelHeader/PanelHeader.js.map +1 -1
  755. package/dist/cssm/components/PanelHeaderBack/PanelHeaderBack.js +1 -0
  756. package/dist/cssm/components/PanelHeaderBack/PanelHeaderBack.js.map +1 -1
  757. package/dist/cssm/components/PanelHeaderButton/PanelHeaderButton.css +1 -1
  758. package/dist/cssm/components/PanelHeaderButton/PanelHeaderButton.js +4 -3
  759. package/dist/cssm/components/PanelHeaderButton/PanelHeaderButton.js.map +1 -1
  760. package/dist/cssm/components/PanelHeaderContent/PanelHeaderContent.css +1 -1
  761. package/dist/cssm/components/PanelHeaderContext/PanelHeaderContext.js +4 -1
  762. package/dist/cssm/components/PanelHeaderContext/PanelHeaderContext.js.map +1 -1
  763. package/dist/cssm/components/Placeholder/Placeholder.js +3 -2
  764. package/dist/cssm/components/Placeholder/Placeholder.js.map +1 -1
  765. package/dist/cssm/components/PopoutWrapper/PopoutWrapper.js +1 -0
  766. package/dist/cssm/components/PopoutWrapper/PopoutWrapper.js.map +1 -1
  767. package/dist/cssm/components/Popper/Popper.js +2 -2
  768. package/dist/cssm/components/Popper/Popper.js.map +1 -1
  769. package/dist/cssm/components/PromoBanner/PromoBanner.js +1 -1
  770. package/dist/cssm/components/PromoBanner/PromoBanner.js.map +1 -1
  771. package/dist/cssm/components/PullToRefresh/PullToRefresh.js +2 -1
  772. package/dist/cssm/components/PullToRefresh/PullToRefresh.js.map +1 -1
  773. package/dist/cssm/components/PullToRefresh/PullToRefreshSpinner.js +1 -0
  774. package/dist/cssm/components/PullToRefresh/PullToRefreshSpinner.js.map +1 -1
  775. package/dist/cssm/components/Removable/Removable.css +1 -1
  776. package/dist/cssm/components/RichCell/RichCell.js +2 -1
  777. package/dist/cssm/components/RichCell/RichCell.js.map +1 -1
  778. package/dist/cssm/components/RichTooltip/RichTooltip.js +2 -1
  779. package/dist/cssm/components/RichTooltip/RichTooltip.js.map +1 -1
  780. package/dist/cssm/components/Root/Root.css +1 -1
  781. package/dist/cssm/components/Root/Root.js +8 -7
  782. package/dist/cssm/components/Root/Root.js.map +1 -1
  783. package/dist/cssm/components/ScreenSpinner/ScreenSpinner.js +2 -0
  784. package/dist/cssm/components/ScreenSpinner/ScreenSpinner.js.map +1 -1
  785. package/dist/cssm/components/Search/Search.css +1 -1
  786. package/dist/cssm/components/Search/Search.js +2 -1
  787. package/dist/cssm/components/Search/Search.js.map +1 -1
  788. package/dist/cssm/components/SegmentedControl/SegmentedControl.js +19 -13
  789. package/dist/cssm/components/SegmentedControl/SegmentedControl.js.map +1 -1
  790. package/dist/cssm/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.css +1 -1
  791. package/dist/cssm/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js +2 -1
  792. package/dist/cssm/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js.map +1 -1
  793. package/dist/cssm/components/Select/Select.css +1 -1
  794. package/dist/cssm/components/Select/Select.d.ts +1 -2
  795. package/dist/cssm/components/Select/Select.js +5 -6
  796. package/dist/cssm/components/Select/Select.js.map +1 -1
  797. package/dist/cssm/components/SelectMimicry/SelectMimicry.d.ts +3 -3
  798. package/dist/cssm/components/SelectMimicry/SelectMimicry.js +5 -2
  799. package/dist/cssm/components/SelectMimicry/SelectMimicry.js.map +1 -1
  800. package/dist/cssm/components/Separator/Separator.js +3 -1
  801. package/dist/cssm/components/Separator/Separator.js.map +1 -1
  802. package/dist/cssm/components/SimpleCell/SimpleCell.css +1 -1
  803. package/dist/cssm/components/SimpleCell/SimpleCell.js +3 -2
  804. package/dist/cssm/components/SimpleCell/SimpleCell.js.map +1 -1
  805. package/dist/cssm/components/SimpleCheckbox/SimpleCheckbox.js +6 -2
  806. package/dist/cssm/components/SimpleCheckbox/SimpleCheckbox.js.map +1 -1
  807. package/dist/cssm/components/SliderSwitch/SliderSwitch.js +1 -0
  808. package/dist/cssm/components/SliderSwitch/SliderSwitch.js.map +1 -1
  809. package/dist/cssm/components/SliderSwitch/SliderSwitchButton.js +1 -0
  810. package/dist/cssm/components/SliderSwitch/SliderSwitchButton.js.map +1 -1
  811. package/dist/cssm/components/Snackbar/Snackbar.css +1 -1
  812. package/dist/cssm/components/Snackbar/Snackbar.js +2 -1
  813. package/dist/cssm/components/Snackbar/Snackbar.js.map +1 -1
  814. package/dist/cssm/components/Spacing/Spacing.js +2 -1
  815. package/dist/cssm/components/Spacing/Spacing.js.map +1 -1
  816. package/dist/cssm/components/SplitCol/SplitCol.js +2 -1
  817. package/dist/cssm/components/SplitCol/SplitCol.js.map +1 -1
  818. package/dist/cssm/components/SplitLayout/SplitLayout.css +1 -1
  819. package/dist/cssm/components/SplitLayout/SplitLayout.js +2 -1
  820. package/dist/cssm/components/SplitLayout/SplitLayout.js.map +1 -1
  821. package/dist/cssm/components/SubnavigationBar/SubnavigationBar.js +1 -1
  822. package/dist/cssm/components/SubnavigationBar/SubnavigationBar.js.map +1 -1
  823. package/dist/cssm/components/SubnavigationButton/SubnavigationButton.js +3 -2
  824. package/dist/cssm/components/SubnavigationButton/SubnavigationButton.js.map +1 -1
  825. package/dist/cssm/components/Switch/Switch.js +1 -0
  826. package/dist/cssm/components/Switch/Switch.js.map +1 -1
  827. package/dist/cssm/components/Tabbar/Tabbar.js +1 -0
  828. package/dist/cssm/components/Tabbar/Tabbar.js.map +1 -1
  829. package/dist/cssm/components/TabbarItem/TabbarItem.css +1 -1
  830. package/dist/cssm/components/TabbarItem/TabbarItem.d.ts +1 -1
  831. package/dist/cssm/components/TabbarItem/TabbarItem.js +2 -1
  832. package/dist/cssm/components/TabbarItem/TabbarItem.js.map +1 -1
  833. package/dist/cssm/components/Tabs/Tabs.css +1 -1
  834. package/dist/cssm/components/TabsItem/TabsItem.js +2 -1
  835. package/dist/cssm/components/TabsItem/TabsItem.js.map +1 -1
  836. package/dist/cssm/components/Tappable/Tappable.css +1 -1
  837. package/dist/cssm/components/Tappable/Tappable.js +5 -4
  838. package/dist/cssm/components/Tappable/Tappable.js.map +1 -1
  839. package/dist/cssm/components/TextTooltip/TextTooltip.js +1 -1
  840. package/dist/cssm/components/TextTooltip/TextTooltip.js.map +1 -1
  841. package/dist/cssm/components/Textarea/Textarea.css +1 -1
  842. package/dist/cssm/components/Tooltip/Tooltip.js +4 -4
  843. package/dist/cssm/components/Tooltip/Tooltip.js.map +1 -1
  844. package/dist/cssm/components/Touch/Touch.js +9 -3
  845. package/dist/cssm/components/Touch/Touch.js.map +1 -1
  846. package/dist/cssm/components/Touch/TouchContext.d.ts +1 -1
  847. package/dist/cssm/components/Touch/TouchContext.js +1 -1
  848. package/dist/cssm/components/Touch/TouchContext.js.map +1 -1
  849. package/dist/cssm/components/Typography/Caption/Caption.css +1 -1
  850. package/dist/cssm/components/Typography/Headline/Headline.css +1 -1
  851. package/dist/cssm/components/Typography/Paragraph/Paragraph.css +1 -0
  852. package/dist/cssm/components/Typography/Paragraph/Paragraph.d.ts +10 -0
  853. package/dist/cssm/components/Typography/Paragraph/Paragraph.js +26 -0
  854. package/dist/cssm/components/Typography/Paragraph/Paragraph.js.map +1 -0
  855. package/dist/cssm/components/Typography/Subhead/Subhead.css +1 -1
  856. package/dist/cssm/components/Typography/Subhead/Subhead.d.ts +1 -2
  857. package/dist/cssm/components/Typography/Subhead/Subhead.js +3 -7
  858. package/dist/cssm/components/Typography/Subhead/Subhead.js.map +1 -1
  859. package/dist/cssm/components/Typography/Text/Text.css +1 -1
  860. package/dist/cssm/components/Typography/Text/Text.js +1 -1
  861. package/dist/cssm/components/Typography/Text/Text.js.map +1 -1
  862. package/dist/cssm/components/Typography/Title/Title.css +1 -1
  863. package/dist/cssm/components/Typography/Title/Title.d.ts +1 -2
  864. package/dist/cssm/components/Typography/Title/Title.js +3 -9
  865. package/dist/cssm/components/Typography/Title/Title.js.map +1 -1
  866. package/dist/cssm/components/UsersStack/UsersStack.js +2 -1
  867. package/dist/cssm/components/UsersStack/UsersStack.js.map +1 -1
  868. package/dist/cssm/components/View/View.css +1 -1
  869. package/dist/cssm/components/View/View.js +5 -0
  870. package/dist/cssm/components/View/View.js.map +1 -1
  871. package/dist/cssm/components/View/ViewIOS.css +1 -1
  872. package/dist/cssm/components/View/ViewInfinite.js +5 -0
  873. package/dist/cssm/components/View/ViewInfinite.js.map +1 -1
  874. package/dist/cssm/components/View/utils.js +5 -2
  875. package/dist/cssm/components/View/utils.js.map +1 -1
  876. package/dist/cssm/components/WriteBar/WriteBar.css +1 -1
  877. package/dist/cssm/components/WriteBarIcon/WriteBarIcon.js +3 -2
  878. package/dist/cssm/components/WriteBarIcon/WriteBarIcon.js.map +1 -1
  879. package/dist/cssm/helpers/scheme.js +2 -2
  880. package/dist/cssm/helpers/scheme.js.map +1 -1
  881. package/dist/cssm/hooks/useBridgeAdaptivity.d.ts +6 -0
  882. package/dist/cssm/hooks/useBridgeAdaptivity.js +68 -0
  883. package/dist/cssm/hooks/useBridgeAdaptivity.js.map +1 -0
  884. package/dist/cssm/hooks/useCalendar.d.ts +4 -3
  885. package/dist/cssm/hooks/useCalendar.js +16 -7
  886. package/dist/cssm/hooks/useCalendar.js.map +1 -1
  887. package/dist/cssm/hooks/useKeyboard.d.ts +1 -1
  888. package/dist/cssm/hooks/useKeyboard.js +1 -1
  889. package/dist/cssm/hooks/useKeyboard.js.map +1 -1
  890. package/dist/cssm/hooks/usePagination.d.ts +3 -3
  891. package/dist/cssm/hooks/usePagination.js +3 -3
  892. package/dist/cssm/hooks/usePagination.js.map +1 -1
  893. package/dist/cssm/hooks/usePatchChildrenRef.js +1 -1
  894. package/dist/cssm/hooks/usePatchChildrenRef.js.map +1 -1
  895. package/dist/cssm/hooks/useWaitTransitionFinish.js +5 -1
  896. package/dist/cssm/hooks/useWaitTransitionFinish.js.map +1 -1
  897. package/dist/cssm/index.d.ts +21 -10
  898. package/dist/cssm/index.js +12 -14
  899. package/dist/cssm/index.js.map +1 -1
  900. package/dist/cssm/lib/calendar.js +4 -15
  901. package/dist/cssm/lib/calendar.js.map +1 -1
  902. package/dist/cssm/lib/date.d.ts +29 -0
  903. package/dist/cssm/lib/date.js +223 -0
  904. package/dist/cssm/lib/date.js.map +1 -0
  905. package/dist/cssm/lib/getNavId.d.ts +2 -1
  906. package/dist/cssm/lib/getNavId.js +1 -1
  907. package/dist/cssm/lib/getNavId.js.map +1 -1
  908. package/dist/cssm/lib/platform.js +26 -0
  909. package/dist/cssm/lib/platform.js.map +1 -1
  910. package/dist/cssm/lib/warnOnce.d.ts +2 -1
  911. package/dist/cssm/lib/warnOnce.js +3 -1
  912. package/dist/cssm/lib/warnOnce.js.map +1 -1
  913. package/dist/cssm/styles/bright_light.css +1 -1
  914. package/dist/cssm/styles/common.css +1 -1
  915. package/dist/cssm/styles/components.css +21 -6
  916. package/dist/cssm/styles/constants.css +9 -2
  917. package/dist/cssm/styles/space_gray.css +1 -1
  918. package/dist/cssm/styles/themes.css +3 -3
  919. package/dist/cssm/styles/unstable.css +1 -1
  920. package/dist/cssm/styles/vkcom_dark.css +2 -2
  921. package/dist/cssm/styles/vkcom_light.css +1 -1
  922. package/dist/cssm/tokenized/index.d.ts +22 -4
  923. package/dist/cssm/tokenized/index.js +13 -4
  924. package/dist/cssm/tokenized/index.js.map +1 -1
  925. package/dist/default_scheme.css +1 -1
  926. package/dist/default_scheme.css.map +1 -1
  927. package/dist/helpers/scheme.js +2 -2
  928. package/dist/helpers/scheme.js.map +1 -1
  929. package/dist/hooks/useBridgeAdaptivity.d.ts +6 -0
  930. package/dist/hooks/useBridgeAdaptivity.js +68 -0
  931. package/dist/hooks/useBridgeAdaptivity.js.map +1 -0
  932. package/dist/hooks/useCalendar.d.ts +4 -3
  933. package/dist/hooks/useCalendar.js +16 -7
  934. package/dist/hooks/useCalendar.js.map +1 -1
  935. package/dist/hooks/useKeyboard.d.ts +1 -1
  936. package/dist/hooks/useKeyboard.js +1 -1
  937. package/dist/hooks/useKeyboard.js.map +1 -1
  938. package/dist/hooks/usePagination.d.ts +3 -3
  939. package/dist/hooks/usePagination.js +3 -3
  940. package/dist/hooks/usePagination.js.map +1 -1
  941. package/dist/hooks/usePatchChildrenRef.js +1 -1
  942. package/dist/hooks/usePatchChildrenRef.js.map +1 -1
  943. package/dist/hooks/useWaitTransitionFinish.js +5 -1
  944. package/dist/hooks/useWaitTransitionFinish.js.map +1 -1
  945. package/dist/index.d.ts +21 -10
  946. package/dist/index.js +12 -14
  947. package/dist/index.js.map +1 -1
  948. package/dist/lib/calendar.js +4 -15
  949. package/dist/lib/calendar.js.map +1 -1
  950. package/dist/lib/date.d.ts +29 -0
  951. package/dist/lib/date.js +223 -0
  952. package/dist/lib/date.js.map +1 -0
  953. package/dist/lib/getNavId.d.ts +2 -1
  954. package/dist/lib/getNavId.js +1 -1
  955. package/dist/lib/getNavId.js.map +1 -1
  956. package/dist/lib/platform.js +26 -0
  957. package/dist/lib/platform.js.map +1 -1
  958. package/dist/lib/warnOnce.d.ts +2 -1
  959. package/dist/lib/warnOnce.js +3 -1
  960. package/dist/lib/warnOnce.js.map +1 -1
  961. package/dist/tokenized/index.d.ts +22 -4
  962. package/dist/tokenized/index.js +13 -4
  963. package/dist/tokenized/index.js.map +1 -1
  964. package/dist/unstable.css +1 -1
  965. package/dist/unstable.css.map +1 -1
  966. package/dist/vkui.css +24 -9
  967. package/dist/vkui.css.map +1 -1
  968. package/eslint-plugin-vkui/index.js +64 -0
  969. package/eslint-plugin-vkui/package.json +5 -0
  970. package/jest.unit.config.js +4 -1
  971. package/package.json +5 -4
  972. package/postcss-plugin-vk-sans/__tests__/custom_properties.css +4 -0
  973. package/postcss-plugin-vk-sans/index.js +350 -0
  974. package/src/components/ActionSheet/ActionSheet.tsx +7 -1
  975. package/src/components/ActionSheet/ActionSheetDropdown.tsx +1 -0
  976. package/src/components/ActionSheet/ActionSheetDropdownDesktop.tsx +1 -1
  977. package/src/components/ActionSheet/Readme.md +1 -0
  978. package/src/components/ActionSheetItem/ActionSheetItem.tsx +3 -2
  979. package/src/components/AdaptivityProvider/AdaptivityProvider.tsx +50 -19
  980. package/src/components/Alert/Alert.tsx +28 -8
  981. package/src/components/AppRoot/AppRoot.tsx +18 -2
  982. package/src/components/AppRoot/ScrollContext.ts +90 -2
  983. package/src/components/Avatar/Avatar.tsx +3 -0
  984. package/src/components/Banner/Banner.tsx +3 -2
  985. package/src/components/Button/Button.css +9 -7
  986. package/src/components/Button/Button.tsx +25 -36
  987. package/src/components/Calendar/Calendar.tsx +30 -6
  988. package/src/components/Calendar/Readme.md +2 -2
  989. package/src/components/CalendarDay/CalendarDay.tsx +3 -0
  990. package/src/components/CalendarDays/CalendarDays.tsx +1 -1
  991. package/src/components/CalendarHeader/CalendarHeader.tsx +17 -10
  992. package/src/components/CalendarRange/CalendarRange.tsx +2 -5
  993. package/src/components/CalendarRange/Readme.md +2 -2
  994. package/src/components/CalendarTime/CalendarTime.tsx +3 -3
  995. package/src/components/Card/Card.css +2 -1
  996. package/src/components/CardScroll/CardScroll.tsx +3 -1
  997. package/src/components/Cell/Cell.tsx +4 -3
  998. package/src/components/CellButton/CellButton.tsx +1 -0
  999. package/src/components/Chip/Chip.tsx +1 -0
  1000. package/src/components/ChipsInput/ChipsInput.css +4 -4
  1001. package/src/components/ChipsInput/ChipsInput.tsx +9 -8
  1002. package/src/components/ChipsSelect/ChipsSelect.css +1 -1
  1003. package/src/components/ChipsSelect/ChipsSelect.tsx +9 -7
  1004. package/src/components/ClickPopper/ClickPopper.tsx +1 -1
  1005. package/src/components/ConfigProvider/ConfigProvider.tsx +1 -1
  1006. package/src/components/ContentCard/ContentCard.tsx +2 -1
  1007. package/src/components/CustomSelect/CustomSelect.css +1 -1
  1008. package/src/components/CustomSelect/CustomSelect.tsx +28 -22
  1009. package/src/components/CustomSelectDropdown/CustomSelectDropdown.css +10 -5
  1010. package/src/components/CustomSelectDropdown/CustomSelectDropdown.tsx +6 -5
  1011. package/src/components/CustomSelectOption/CustomSelectOption.css +17 -5
  1012. package/src/components/CustomSelectOption/CustomSelectOption.tsx +55 -17
  1013. package/src/components/CustomSelectOption/Readme.md +47 -28
  1014. package/src/components/DateInput/DateInput.css +1 -1
  1015. package/src/components/DateInput/DateInput.tsx +15 -3
  1016. package/src/components/DateInput/Readme.md +1 -1
  1017. package/src/components/DatePicker/DatePicker.tsx +2 -2
  1018. package/src/components/DateRangeInput/DateRangeInput.tsx +3 -3
  1019. package/src/components/DateRangeInput/Readme.md +1 -1
  1020. package/src/components/Epic/Epic.tsx +3 -1
  1021. package/src/components/Epic/Readme.md +5 -1
  1022. package/src/components/File/File.tsx +1 -1
  1023. package/src/components/FixedLayout/FixedLayout.css +2 -0
  1024. package/src/components/FixedLayout/FixedLayout.tsx +1 -0
  1025. package/src/components/FormField/FormField.css +30 -45
  1026. package/src/components/FormField/FormField.tsx +26 -7
  1027. package/src/components/FormField/Readme.md +85 -19
  1028. package/src/components/FormItem/FormItem.tsx +2 -1
  1029. package/src/components/FormLayoutGroup/FormLayoutGroup.tsx +1 -0
  1030. package/src/components/Gallery/Gallery.tsx +14 -2
  1031. package/src/components/Gradient/Gradient.css +4 -2
  1032. package/src/components/GridAvatar/GridAvatar.css +10 -13
  1033. package/src/components/GridAvatar/GridAvatar.tsx +12 -24
  1034. package/src/components/Group/Group.tsx +1 -0
  1035. package/src/components/Header/Header.tsx +9 -3
  1036. package/src/components/HorizontalCell/HorizontalCell.tsx +1 -1
  1037. package/src/components/HorizontalScroll/HorizontalScroll.tsx +50 -42
  1038. package/src/components/InfoRow/InfoRow.tsx +1 -1
  1039. package/src/components/Input/Input.css +4 -4
  1040. package/src/components/Input/Input.tsx +7 -9
  1041. package/src/components/InputLike/InputLike.css +1 -1
  1042. package/src/components/InputLike/InputLikeDivider.css +1 -1
  1043. package/src/components/List/List.tsx +1 -0
  1044. package/src/components/MiniInfoCell/MiniInfoCell.tsx +1 -0
  1045. package/src/components/ModalCard/ModalCard.css +1 -11
  1046. package/src/components/ModalCard/ModalCard.tsx +1 -0
  1047. package/src/components/ModalCardBase/ModalCardBase.css +10 -0
  1048. package/src/components/ModalCardBase/ModalCardBase.tsx +15 -2
  1049. package/src/components/ModalPage/ModalPage.tsx +19 -0
  1050. package/src/components/ModalPageHeader/ModalPageHeader.tsx +1 -0
  1051. package/src/components/ModalRoot/ModalRoot.css +3 -2
  1052. package/src/components/ModalRoot/ModalRoot.tsx +37 -10
  1053. package/src/components/ModalRoot/ModalRootAdaptive.tsx +20 -2
  1054. package/src/components/ModalRoot/ModalRootDesktop.tsx +25 -7
  1055. package/src/components/ModalRoot/Readme.md +112 -0
  1056. package/src/components/ModalRoot/types.ts +16 -1
  1057. package/src/components/ModalRoot/useModalManager.tsx +63 -15
  1058. package/src/components/NativeSelect/NativeSelect.tsx +3 -3
  1059. package/src/components/Pagination/Pagination.tsx +4 -4
  1060. package/src/components/Pagination/Readme.md +1 -1
  1061. package/src/components/Panel/Panel.tsx +1 -0
  1062. package/src/components/PanelHeader/PanelHeader.css +13 -13
  1063. package/src/components/PanelHeader/PanelHeader.tsx +4 -3
  1064. package/src/components/PanelHeaderBack/PanelHeaderBack.tsx +1 -0
  1065. package/src/components/PanelHeaderButton/PanelHeaderButton.tsx +4 -2
  1066. package/src/components/PanelHeaderContext/PanelHeaderContext.tsx +4 -0
  1067. package/src/components/Placeholder/Placeholder.tsx +2 -1
  1068. package/src/components/PopoutWrapper/PopoutWrapper.tsx +1 -0
  1069. package/src/components/Popper/Popper.tsx +2 -2
  1070. package/src/components/PromoBanner/PromoBanner.tsx +1 -1
  1071. package/src/components/PullToRefresh/PullToRefresh.tsx +1 -0
  1072. package/src/components/PullToRefresh/PullToRefreshSpinner.tsx +1 -0
  1073. package/src/components/RichCell/RichCell.tsx +2 -1
  1074. package/src/components/RichTooltip/Readme.md +2 -2
  1075. package/src/components/RichTooltip/RichTooltip.tsx +1 -0
  1076. package/src/components/Root/Root.css +4 -11
  1077. package/src/components/Root/Root.tsx +7 -6
  1078. package/src/components/ScreenSpinner/ScreenSpinner.tsx +3 -0
  1079. package/src/components/Search/Search.tsx +2 -1
  1080. package/src/components/SegmentedControl/SegmentedControl.tsx +20 -10
  1081. package/src/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.css +1 -1
  1082. package/src/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.tsx +1 -0
  1083. package/src/components/Select/Select.css +2 -2
  1084. package/src/components/Select/Select.tsx +4 -5
  1085. package/src/components/SelectMimicry/SelectMimicry.tsx +6 -3
  1086. package/src/components/Separator/Separator.tsx +2 -0
  1087. package/src/components/SimpleCell/SimpleCell.tsx +3 -2
  1088. package/src/components/SimpleCheckbox/SimpleCheckbox.tsx +7 -2
  1089. package/src/components/SliderSwitch/SliderSwitch.tsx +1 -0
  1090. package/src/components/SliderSwitch/SliderSwitchButton.tsx +1 -0
  1091. package/src/components/Snackbar/Snackbar.css +6 -3
  1092. package/src/components/Snackbar/Snackbar.tsx +2 -1
  1093. package/src/components/Spacing/Spacing.tsx +1 -0
  1094. package/src/components/SplitCol/SplitCol.tsx +1 -0
  1095. package/src/components/SplitLayout/SplitLayout.css +3 -1
  1096. package/src/components/SplitLayout/SplitLayout.tsx +1 -0
  1097. package/src/components/SubnavigationBar/SubnavigationBar.tsx +2 -1
  1098. package/src/components/SubnavigationButton/SubnavigationButton.tsx +2 -1
  1099. package/src/components/Switch/Readme.md +12 -36
  1100. package/src/components/Switch/Switch.tsx +1 -0
  1101. package/src/components/Tabbar/Tabbar.tsx +1 -0
  1102. package/src/components/TabbarItem/TabbarItem.css +1 -0
  1103. package/src/components/TabbarItem/TabbarItem.tsx +2 -1
  1104. package/src/components/Tabs/Readme.md +7 -7
  1105. package/src/components/TabsItem/TabsItem.tsx +2 -1
  1106. package/src/components/Tappable/Tappable.css +5 -0
  1107. package/src/components/Tappable/Tappable.tsx +5 -2
  1108. package/src/components/TextTooltip/TextTooltip.tsx +1 -1
  1109. package/src/components/Tooltip/Tooltip.tsx +7 -6
  1110. package/src/components/Touch/Touch.tsx +6 -3
  1111. package/src/components/Touch/TouchContext.ts +1 -1
  1112. package/src/components/Typography/Caption/Caption.css +3 -3
  1113. package/src/components/Typography/Paragraph/Paragraph.css +17 -0
  1114. package/src/components/Typography/Paragraph/Paragraph.tsx +42 -0
  1115. package/src/components/Typography/Paragraph/Readme.md +19 -0
  1116. package/src/components/Typography/Subhead/Subhead.tsx +3 -7
  1117. package/src/components/Typography/Text/Text.tsx +4 -1
  1118. package/src/components/Typography/Title/Title.tsx +7 -10
  1119. package/src/components/UsersStack/UsersStack.tsx +2 -1
  1120. package/src/components/View/Readme.md +1 -1
  1121. package/src/components/View/View.css +1 -1
  1122. package/src/components/View/View.tsx +4 -0
  1123. package/src/components/View/ViewIOS.css +2 -2
  1124. package/src/components/View/ViewInfinite.tsx +4 -0
  1125. package/src/components/View/utils.ts +2 -1
  1126. package/src/components/WriteBarIcon/WriteBarIcon.tsx +3 -1
  1127. package/src/helpers/scheme.ts +3 -2
  1128. package/src/hooks/useBridgeAdaptivity.ts +83 -0
  1129. package/src/hooks/useCalendar.ts +26 -10
  1130. package/src/hooks/useKeyboard.ts +1 -1
  1131. package/src/hooks/usePagination.ts +5 -5
  1132. package/src/hooks/usePatchChildrenRef.ts +2 -2
  1133. package/src/hooks/useWaitTransitionFinish.ts +7 -1
  1134. package/src/index.ts +21 -10
  1135. package/src/lib/calendar.ts +7 -7
  1136. package/src/lib/date.ts +274 -0
  1137. package/src/lib/getNavId.ts +4 -2
  1138. package/src/lib/platform.ts +34 -0
  1139. package/src/lib/warnOnce.ts +9 -3
  1140. package/src/styles/bright_light.css +2 -0
  1141. package/src/styles/components.css +1 -0
  1142. package/src/styles/constants.css +10 -3
  1143. package/src/styles/space_gray.css +10 -8
  1144. package/src/styles/vkcom_dark.css +6 -4
  1145. package/src/styles/vkcom_light.css +4 -2
  1146. package/src/testing/utils.tsx +15 -2
  1147. package/src/tokenized/index.ts +31 -4
  1148. package/tsconfig.json +2 -0
  1149. package/.cache/ts/src/helpers/typography.d.ts +0 -1
  1150. package/dist/cjs/helpers/typography.d.ts +0 -1
  1151. package/dist/cjs/helpers/typography.js +0 -25
  1152. package/dist/cjs/helpers/typography.js.map +0 -1
  1153. package/dist/cssm/helpers/typography.d.ts +0 -1
  1154. package/dist/cssm/helpers/typography.js +0 -18
  1155. package/dist/cssm/helpers/typography.js.map +0 -1
  1156. package/dist/helpers/typography.d.ts +0 -1
  1157. package/dist/helpers/typography.js +0 -18
  1158. package/dist/helpers/typography.js.map +0 -1
  1159. package/src/helpers/typography.ts +0 -24
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/PanelHeaderButton/PanelHeaderButton.tsx"],"names":["ButtonTypography","primary","children","platform","IOS","VKCOM","warn","PanelHeaderButton","label","restProps","isPrimitive","isPrimitiveLabel","hoverMode","activeMode","ANDROID","process","env","NODE_ENV","hasAccessibleName","Boolean","href"],"mappings":";;;;;;;;;;;;;;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;;;AAYA,IAAMA,gBAAiD,GAAG,SAApDA,gBAAoD,OAG7B;AAAA,MAF3BC,OAE2B,QAF3BA,OAE2B;AAAA,MAD3BC,QAC2B,QAD3BA,QAC2B;AAC3B,MAAMC,QAAQ,GAAG,+BAAjB;;AAEA,MAAIA,QAAQ,KAAKC,aAAjB,EAAsB;AACpB,WACE,qCAAC,cAAD;AAAO,MAAA,SAAS,EAAC,MAAjB;AAAwB,MAAA,KAAK,EAAC,GAA9B;AAAkC,MAAA,MAAM,EAAEH,OAAO,GAAG,GAAH,GAAS;AAA1D,OACGC,QADH,CADF;AAKD;;AAED,SACE,qCAAC,aAAD;AAAM,IAAA,MAAM,EAAEC,QAAQ,KAAKE,eAAb,GAAqB,SAArB,GAAiC;AAA/C,KAA0DH,QAA1D,CADF;AAGD,CAjBD;;AAmBA,IAAMI,IAAI,GAAG,wBAAS,mBAAT,CAAb;;AACO,IAAMC,iBAAmD,GAAG,SAAtDA,iBAAsD,QAKrC;AAAA,MAJ5BL,QAI4B,SAJ5BA,QAI4B;AAAA,4BAH5BD,OAG4B;AAAA,MAH5BA,OAG4B,8BAHlB,KAGkB;AAAA,MAF5BO,KAE4B,SAF5BA,KAE4B;AAAA,MADzBC,SACyB;AAC5B,MAAMC,WAAW,GAAG,iCAAqBR,QAArB,CAApB;AACA,MAAMS,gBAAgB,GAAG,iCAAqBH,KAArB,CAAzB;AACA,MAAML,QAAQ,GAAG,+BAAjB;AAEA,MAAIS,SAAJ;AACA,MAAIC,UAAJ;;AAEA,UAAQV,QAAR;AACE,SAAKW,iBAAL;AACEF,MAAAA,SAAS,GAAG,YAAZ;AACAC,MAAAA,UAAU,GAAG,YAAb;AACA;;AACF,SAAKT,aAAL;AACEQ,MAAAA,SAAS,GAAG,YAAZ;AACAC,MAAAA,UAAU,GAAG,SAAb;AACA;;AACF,SAAKR,eAAL;AACEO,MAAAA,SAAS,GAAG,0BAAZ;AACAC,MAAAA,UAAU,GAAG,2BAAb;AAXJ;;AAcA,MAAIE,OAAO,CAACC,GAAR,CAAYC,QAAZ,KAAyB,aAA7B,EAA4C;AAC1C,QAAMC,iBAAiB,GAAGC,OAAO,CAC/B,iCAAqBjB,QAArB,KACE,iCAAqBM,KAArB,CADF,IAEEC,SAAS,CAAC,YAAD,CAFX,IAGEA,SAAS,CAAC,iBAAD,CAJoB,CAAjC;;AAOA,QAAI,CAACS,iBAAL,EAAwB;AACtBZ,MAAAA,IAAI,CACF,oMADE,CAAJ;AAGD;AACF;;AAED,SACE,qCAAC,iBAAD,6BACMG,SADN;AAEE,IAAA,SAAS,EAAEG,SAFb;AAGE,IAAA,SAAS,EAAEH,SAAS,CAACW,IAAV,GAAiB,GAAjB,GAAuB,QAHpC;AAIE,IAAA,iBAAiB,EAAE,GAJrB;AAKE,IAAA,UAAU,EAAEP,UALd;AAME,IAAA,SAAS,EAAE,4BAAW,gCAAa,mBAAb,EAAkCV,QAAlC,CAAX,EAAwD;AACjE,oCAA8BF,OADmC;AAEjE,sCAAgCS,WAFiC;AAGjE,yCAAmC,CAACA,WAAD,IAAgB,CAACC;AAHa,KAAxD;AANb,MAYGD,WAAW,GACV,qCAAC,gBAAD;AAAkB,IAAA,OAAO,EAAET;AAA3B,KAAqCC,QAArC,CADU,GAGVA,QAfJ,EAiBGS,gBAAgB,GACf,qCAAC,gBAAD;AAAkB,IAAA,OAAO,EAAEV;AAA3B,KAAqCO,KAArC,CADe,GAGfA,KApBJ,CADF;AAyBD,CAnEM","sourcesContent":["import * as React from \"react\";\nimport Tappable, { TappableProps } from \"../Tappable/Tappable\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport { classNames } from \"../../lib/classNames\";\nimport { warnOnce } from \"../../lib/warnOnce\";\nimport { usePlatform } from \"../../hooks/usePlatform\";\nimport { getTitleFromChildren, isPrimitiveReactNode } from \"../../lib/utils\";\nimport { IOS, VKCOM, ANDROID } from \"../../lib/platform\";\nimport Text from \"../Typography/Text/Text\";\nimport Title from \"../Typography/Title/Title\";\nimport \"./PanelHeaderButton.css\";\n\nexport interface PanelHeaderButtonProps extends Omit<TappableProps, \"label\"> {\n primary?: boolean;\n label?: React.ReactNode;\n}\n\ninterface ButtonTypographyProps extends React.AllHTMLAttributes<HTMLElement> {\n primary?: PanelHeaderButtonProps[\"primary\"];\n}\n\nconst ButtonTypography: React.FC<ButtonTypographyProps> = ({\n primary,\n children,\n}: ButtonTypographyProps) => {\n const platform = usePlatform();\n\n if (platform === IOS) {\n return (\n <Title Component=\"span\" level=\"3\" weight={primary ? \"1\" : \"3\"}>\n {children}\n </Title>\n );\n }\n\n return (\n <Text weight={platform === VKCOM ? \"regular\" : \"medium\"}>{children}</Text>\n );\n};\n\nconst warn = warnOnce(\"PanelHeaderButton\");\nexport const PanelHeaderButton: React.FC<PanelHeaderButtonProps> = ({\n children,\n primary = false,\n label,\n ...restProps\n}: PanelHeaderButtonProps) => {\n const isPrimitive = isPrimitiveReactNode(children);\n const isPrimitiveLabel = isPrimitiveReactNode(label);\n const platform = usePlatform();\n\n let hoverMode;\n let activeMode;\n\n switch (platform) {\n case ANDROID:\n hoverMode = \"background\";\n activeMode = \"background\";\n break;\n case IOS:\n hoverMode = \"background\";\n activeMode = \"opacity\";\n break;\n case VKCOM:\n hoverMode = \"PanelHeaderButton--hover\";\n activeMode = \"PanelHeaderButton--active\";\n }\n\n if (process.env.NODE_ENV === \"development\") {\n const hasAccessibleName = Boolean(\n getTitleFromChildren(children) ||\n getTitleFromChildren(label) ||\n restProps[\"aria-label\"] ||\n restProps[\"aria-labelledby\"]\n );\n\n if (!hasAccessibleName) {\n warn(\n \"a11y: У кнопки нет названия, которое может прочитать скринридер, и она недоступна для части пользователей. Замените содержимое на текст или добавьте описание действия с помощью пропа aria-label.\"\n );\n }\n }\n\n return (\n <Tappable\n {...restProps}\n hoverMode={hoverMode}\n Component={restProps.href ? \"a\" : \"button\"}\n activeEffectDelay={200}\n activeMode={activeMode}\n vkuiClass={classNames(getClassName(\"PanelHeaderButton\", platform), {\n \"PanelHeaderButton--primary\": primary,\n \"PanelHeaderButton--primitive\": isPrimitive,\n \"PanelHeaderButton--notPrimitive\": !isPrimitive && !isPrimitiveLabel,\n })}\n >\n {isPrimitive ? (\n <ButtonTypography primary={primary}>{children}</ButtonTypography>\n ) : (\n children\n )}\n {isPrimitiveLabel ? (\n <ButtonTypography primary={primary}>{label}</ButtonTypography>\n ) : (\n label\n )}\n </Tappable>\n );\n};\n"],"file":"PanelHeaderButton.js"}
1
+ {"version":3,"sources":["../../../../src/components/PanelHeaderButton/PanelHeaderButton.tsx"],"names":["ButtonTypography","primary","children","platform","IOS","VKCOM","warn","PanelHeaderButton","label","restProps","isPrimitive","isPrimitiveLabel","hoverMode","activeMode","ANDROID","process","env","NODE_ENV","hasAccessibleName","Boolean","href"],"mappings":";;;;;;;;;;;;;;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;;;AAYA,IAAMA,gBAAiD,GAAG,SAApDA,gBAAoD,OAG7B;AAAA,MAF3BC,OAE2B,QAF3BA,OAE2B;AAAA,MAD3BC,QAC2B,QAD3BA,QAC2B;AAC3B,MAAMC,QAAQ,GAAG,+BAAjB;;AAEA,MAAIA,QAAQ,KAAKC,aAAjB,EAAsB;AACpB,WACE,qCAAC,YAAD;AAAO,MAAA,SAAS,EAAC,MAAjB;AAAwB,MAAA,KAAK,EAAC,GAA9B;AAAkC,MAAA,MAAM,EAAEH,OAAO,GAAG,GAAH,GAAS;AAA1D,OACGC,QADH,CADF;AAKD;;AAED,SACE,qCAAC,aAAD;AAAM,IAAA,MAAM,EAAEC,QAAQ,KAAKE,eAAb,GAAqB,SAArB,GAAiC;AAA/C,KAA0DH,QAA1D,CADF;AAGD,CAjBD;;AAmBA,IAAMI,IAAI,GAAG,wBAAS,mBAAT,CAAb;;AACO,IAAMC,iBAAmD,GAAG,SAAtDA,iBAAsD,QAKrC;AAAA,MAJ5BL,QAI4B,SAJ5BA,QAI4B;AAAA,4BAH5BD,OAG4B;AAAA,MAH5BA,OAG4B,8BAHlB,KAGkB;AAAA,MAF5BO,KAE4B,SAF5BA,KAE4B;AAAA,MADzBC,SACyB;AAC5B,MAAMC,WAAW,GAAG,iCAAqBR,QAArB,CAApB;AACA,MAAMS,gBAAgB,GAAG,iCAAqBH,KAArB,CAAzB;AACA,MAAML,QAAQ,GAAG,+BAAjB;AAEA,MAAIS,SAAJ;AACA,MAAIC,UAAJ;;AAEA,UAAQV,QAAR;AACE,SAAKW,iBAAL;AACEF,MAAAA,SAAS,GAAG,YAAZ;AACAC,MAAAA,UAAU,GAAG,YAAb;AACA;;AACF,SAAKT,aAAL;AACEQ,MAAAA,SAAS,GAAG,YAAZ;AACAC,MAAAA,UAAU,GAAG,SAAb;AACA;;AACF,SAAKR,eAAL;AACEO,MAAAA,SAAS,GAAG,0BAAZ;AACAC,MAAAA,UAAU,GAAG,2BAAb;AAXJ;;AAcA,MAAIE,OAAO,CAACC,GAAR,CAAYC,QAAZ,KAAyB,aAA7B,EAA4C;AAC1C,QAAMC,iBAAiB,GAAGC,OAAO,CAC/B,iCAAqBjB,QAArB,KACE,iCAAqBM,KAArB,CADF,IAEEC,SAAS,CAAC,YAAD,CAFX,IAGEA,SAAS,CAAC,iBAAD,CAJoB,CAAjC;;AAOA,QAAI,CAACS,iBAAL,EAAwB;AACtBZ,MAAAA,IAAI,CACF,oMADE,EAEF,OAFE,CAAJ;AAID;AACF;;AAED,SACE,qCAAC,iBAAD,6BACMG,SADN;AAEE,IAAA,SAAS,EAAEG,SAFb;AAGE,IAAA,SAAS,EAAEH,SAAS,CAACW,IAAV,GAAiB,GAAjB,GAAuB,QAHpC;AAIE,IAAA,iBAAiB,EAAE,GAJrB;AAKE,IAAA,UAAU,EAAEP,UALd,CAME;AANF;AAOE,IAAA,SAAS,EAAE,4BAAW,gCAAa,mBAAb,EAAkCV,QAAlC,CAAX,EAAwD;AACjE,oCAA8BF,OADmC;AAEjE,sCAAgCS,WAFiC;AAGjE,yCAAmC,CAACA,WAAD,IAAgB,CAACC;AAHa,KAAxD;AAPb,MAaGD,WAAW,GACV,qCAAC,gBAAD;AAAkB,IAAA,OAAO,EAAET;AAA3B,KAAqCC,QAArC,CADU,GAGVA,QAhBJ,EAkBGS,gBAAgB,GACf,qCAAC,gBAAD;AAAkB,IAAA,OAAO,EAAEV;AAA3B,KAAqCO,KAArC,CADe,GAGfA,KArBJ,CADF;AA0BD,CArEM","sourcesContent":["import * as React from \"react\";\nimport Tappable, { TappableProps } from \"../Tappable/Tappable\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport { classNames } from \"../../lib/classNames\";\nimport { warnOnce } from \"../../lib/warnOnce\";\nimport { usePlatform } from \"../../hooks/usePlatform\";\nimport { getTitleFromChildren, isPrimitiveReactNode } from \"../../lib/utils\";\nimport { IOS, VKCOM, ANDROID } from \"../../lib/platform\";\nimport Text from \"../Typography/Text/Text\";\nimport { Title } from \"../Typography/Title/Title\";\nimport \"./PanelHeaderButton.css\";\n\nexport interface PanelHeaderButtonProps extends Omit<TappableProps, \"label\"> {\n primary?: boolean;\n label?: React.ReactNode;\n}\n\ninterface ButtonTypographyProps extends React.AllHTMLAttributes<HTMLElement> {\n primary?: PanelHeaderButtonProps[\"primary\"];\n}\n\nconst ButtonTypography: React.FC<ButtonTypographyProps> = ({\n primary,\n children,\n}: ButtonTypographyProps) => {\n const platform = usePlatform();\n\n if (platform === IOS) {\n return (\n <Title Component=\"span\" level=\"3\" weight={primary ? \"1\" : \"3\"}>\n {children}\n </Title>\n );\n }\n\n return (\n <Text weight={platform === VKCOM ? \"regular\" : \"medium\"}>{children}</Text>\n );\n};\n\nconst warn = warnOnce(\"PanelHeaderButton\");\nexport const PanelHeaderButton: React.FC<PanelHeaderButtonProps> = ({\n children,\n primary = false,\n label,\n ...restProps\n}: PanelHeaderButtonProps) => {\n const isPrimitive = isPrimitiveReactNode(children);\n const isPrimitiveLabel = isPrimitiveReactNode(label);\n const platform = usePlatform();\n\n let hoverMode;\n let activeMode;\n\n switch (platform) {\n case ANDROID:\n hoverMode = \"background\";\n activeMode = \"background\";\n break;\n case IOS:\n hoverMode = \"background\";\n activeMode = \"opacity\";\n break;\n case VKCOM:\n hoverMode = \"PanelHeaderButton--hover\";\n activeMode = \"PanelHeaderButton--active\";\n }\n\n if (process.env.NODE_ENV === \"development\") {\n const hasAccessibleName = Boolean(\n getTitleFromChildren(children) ||\n getTitleFromChildren(label) ||\n restProps[\"aria-label\"] ||\n restProps[\"aria-labelledby\"]\n );\n\n if (!hasAccessibleName) {\n warn(\n \"a11y: У кнопки нет названия, которое может прочитать скринридер, и она недоступна для части пользователей. Замените содержимое на текст или добавьте описание действия с помощью пропа aria-label.\",\n \"error\"\n );\n }\n }\n\n return (\n <Tappable\n {...restProps}\n hoverMode={hoverMode}\n Component={restProps.href ? \"a\" : \"button\"}\n activeEffectDelay={200}\n activeMode={activeMode}\n // eslint-disable-next-line vkui/no-object-expression-in-arguments\n vkuiClass={classNames(getClassName(\"PanelHeaderButton\", platform), {\n \"PanelHeaderButton--primary\": primary,\n \"PanelHeaderButton--primitive\": isPrimitive,\n \"PanelHeaderButton--notPrimitive\": !isPrimitive && !isPrimitiveLabel,\n })}\n >\n {isPrimitive ? (\n <ButtonTypography primary={primary}>{children}</ButtonTypography>\n ) : (\n children\n )}\n {isPrimitiveLabel ? (\n <ButtonTypography primary={primary}>{label}</ButtonTypography>\n ) : (\n label\n )}\n </Tappable>\n );\n};\n"],"file":"PanelHeaderButton.js"}
@@ -39,6 +39,8 @@ var _useTimeout = require("../../hooks/useTimeout");
39
39
 
40
40
  var _usePlatform = require("../../hooks/usePlatform");
41
41
 
42
+ var _ScrollContext = require("../AppRoot/ScrollContext");
43
+
42
44
  var _excluded = ["children", "onClose", "opened"];
43
45
 
44
46
  var PanelHeaderContext = function PanelHeaderContext(_ref) {
@@ -67,7 +69,8 @@ var PanelHeaderContext = function PanelHeaderContext(_ref) {
67
69
  var elementRef = React.useRef(null);
68
70
  (0, _useIsomorphicLayoutEffect.useIsomorphicLayoutEffect)(function () {
69
71
  opened && setVisible(true);
70
- }, [opened]); // start closing on outer click
72
+ }, [opened]);
73
+ (0, _ScrollContext.useScrollLock)(!isDesktop && opened); // start closing on outer click
71
74
 
72
75
  (0, _useGlobalEventListener.useGlobalEventListener)(document, "click", isDesktop && opened && !closing && function (event) {
73
76
  if (elementRef.current && !elementRef.current.contains(event.target)) {
@@ -84,6 +87,7 @@ var PanelHeaderContext = function PanelHeaderContext(_ref) {
84
87
  return closing ? animationFallback.set() : animationFallback.clear();
85
88
  }, [animationFallback, closing]);
86
89
  return (0, _jsxRuntime.createScopedElement)(_FixedLayout.default, (0, _extends2.default)({}, restProps, {
90
+ // eslint-disable-next-line vkui/no-object-expression-in-arguments
87
91
  vkuiClass: (0, _classNames.classNames)((0, _getClassName.getClassName)("PanelHeaderContext", platform), {
88
92
  "PanelHeaderContext--opened": opened,
89
93
  "PanelHeaderContext--closing": closing,
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/PanelHeaderContext/PanelHeaderContext.tsx"],"names":["PanelHeaderContext","children","onClose","opened","restProps","document","platform","React","useState","visible","setVisible","closing","viewWidth","isDesktop","ViewWidth","SMALL_TABLET","elementRef","useRef","event","current","contains","target","onAnimationEnd","animationFallback","useEffect","set","clear","undefined"],"mappings":";;;;;;;;;;;;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;;;AASO,IAAMA,kBAAqD,GAAG,SAAxDA,kBAAwD,OAK/D;AAAA,MAJJC,QAII,QAJJA,QAII;AAAA,MAHJC,OAGI,QAHJA,OAGI;AAAA,yBAFJC,MAEI;AAAA,MAFJA,MAEI,4BAFK,KAEL;AAAA,MADDC,SACC;;AACJ,gBAAqB,kBAArB;AAAA,MAAQC,QAAR,WAAQA,QAAR;;AACA,MAAMC,QAAQ,GAAG,+BAAjB;;AACA,wBAA8BC,KAAK,CAACC,QAAN,CAAeL,MAAf,CAA9B;AAAA;AAAA,MAAOM,OAAP;AAAA,MAAgBC,UAAhB;;AACA,MAAMC,OAAO,GAAGF,OAAO,IAAI,CAACN,MAA5B;;AACA,uBAAsB,oCAAtB;AAAA,MAAQS,SAAR,kBAAQA,SAAR;;AACA,MAAMC,SAAS,GAAGD,SAAS,IAAIE,6BAAUC,YAAzC;AACA,MAAMC,UAAU,GAAGT,KAAK,CAACU,MAAN,CAA6B,IAA7B,CAAnB;AAEA,4DAA0B,YAAM;AAC9Bd,IAAAA,MAAM,IAAIO,UAAU,CAAC,IAAD,CAApB;AACD,GAFD,EAEG,CAACP,MAAD,CAFH,EATI,CAaJ;;AACA,sDACEE,QADF,EAEE,OAFF,EAGEQ,SAAS,IACPV,MADF,IAEE,CAACQ,OAFH,IAGG,UAACO,KAAD,EAAW;AACV,QACEF,UAAU,CAACG,OAAX,IACA,CAACH,UAAU,CAACG,OAAX,CAAmBC,QAAnB,CAA4BF,KAAK,CAACG,MAAlC,CAFH,EAGE;AACAnB,MAAAA,OAAO;AACR;AACF,GAbL,EAdI,CA8BJ;;AACA,MAAMoB,cAAc,GAAG,SAAjBA,cAAiB;AAAA,WAAMZ,UAAU,CAAC,KAAD,CAAhB;AAAA,GAAvB;;AACA,MAAMa,iBAAiB,GAAG,4BAAWD,cAAX,EAA2B,GAA3B,CAA1B;AACAf,EAAAA,KAAK,CAACiB,SAAN,CACE;AAAA,WAAOb,OAAO,GAAGY,iBAAiB,CAACE,GAAlB,EAAH,GAA6BF,iBAAiB,CAACG,KAAlB,EAA3C;AAAA,GADF,EAEE,CAACH,iBAAD,EAAoBZ,OAApB,CAFF;AAKA,SACE,qCAAC,oBAAD,6BACMP,SADN;AAEE,IAAA,SAAS,EAAE,4BAAW,gCAAa,oBAAb,EAAmCE,QAAnC,CAAX,EAAyD;AAClE,oCAA8BH,MADoC;AAElE,qCAA+BQ,OAFmC;AAGlE,qCAA+BE;AAHmC,KAAzD,CAFb;AAOE,IAAA,QAAQ,EAAC;AAPX,MASE;AACE,IAAA,SAAS,EAAC,wBADZ;AAEE,IAAA,GAAG,EAAEG,UAFP;AAGE,IAAA,cAAc,EAAEL,OAAO,GAAGW,cAAH,GAAoBK;AAH7C,KAKE;AAAK,IAAA,SAAS,EAAC;AAAf,KAA8ClB,OAAO,IAAIR,QAAzD,CALF,CATF,EAgBG,CAACY,SAAD,IAAcJ,OAAd,IACC;AAAK,IAAA,OAAO,EAAEP,OAAd;AAAuB,IAAA,SAAS,EAAC;AAAjC,IAjBJ,CADF;AAsBD,CAjEM","sourcesContent":["import * as React from \"react\";\nimport FixedLayout from \"../FixedLayout/FixedLayout\";\nimport { classNames } from \"../../lib/classNames\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport { ViewWidth } from \"../AdaptivityProvider/AdaptivityContext\";\nimport { useAdaptivity } from \"../../hooks/useAdaptivity\";\nimport { useDOM } from \"../../lib/dom\";\nimport { useIsomorphicLayoutEffect } from \"../../lib/useIsomorphicLayoutEffect\";\nimport { useGlobalEventListener } from \"../../hooks/useGlobalEventListener\";\nimport { useTimeout } from \"../../hooks/useTimeout\";\nimport { usePlatform } from \"../../hooks/usePlatform\";\nimport \"./PanelHeaderContext.css\";\n\nexport interface PanelHeaderContextProps\n extends React.HTMLAttributes<HTMLDivElement> {\n opened: boolean;\n onClose: VoidFunction;\n}\n\nexport const PanelHeaderContext: React.FC<PanelHeaderContextProps> = ({\n children,\n onClose,\n opened = false,\n ...restProps\n}) => {\n const { document } = useDOM();\n const platform = usePlatform();\n const [visible, setVisible] = React.useState(opened);\n const closing = visible && !opened;\n const { viewWidth } = useAdaptivity();\n const isDesktop = viewWidth >= ViewWidth.SMALL_TABLET;\n const elementRef = React.useRef<HTMLDivElement>(null);\n\n useIsomorphicLayoutEffect(() => {\n opened && setVisible(true);\n }, [opened]);\n\n // start closing on outer click\n useGlobalEventListener(\n document,\n \"click\",\n isDesktop &&\n opened &&\n !closing &&\n ((event) => {\n if (\n elementRef.current &&\n !elementRef.current.contains(event.target as Node)\n ) {\n onClose();\n }\n })\n );\n\n // fallback onAnimationEnd when animationend not supported\n const onAnimationEnd = () => setVisible(false);\n const animationFallback = useTimeout(onAnimationEnd, 200);\n React.useEffect(\n () => (closing ? animationFallback.set() : animationFallback.clear()),\n [animationFallback, closing]\n );\n\n return (\n <FixedLayout\n {...restProps}\n vkuiClass={classNames(getClassName(\"PanelHeaderContext\", platform), {\n \"PanelHeaderContext--opened\": opened,\n \"PanelHeaderContext--closing\": closing,\n \"PanelHeaderContext--desktop\": isDesktop,\n })}\n vertical=\"top\"\n >\n <div\n vkuiClass=\"PanelHeaderContext__in\"\n ref={elementRef}\n onAnimationEnd={closing ? onAnimationEnd : undefined}\n >\n <div vkuiClass=\"PanelHeaderContext__content\">{visible && children}</div>\n </div>\n {!isDesktop && visible && (\n <div onClick={onClose} vkuiClass=\"PanelHeaderContext__fade\" />\n )}\n </FixedLayout>\n );\n};\n"],"file":"PanelHeaderContext.js"}
1
+ {"version":3,"sources":["../../../../src/components/PanelHeaderContext/PanelHeaderContext.tsx"],"names":["PanelHeaderContext","children","onClose","opened","restProps","document","platform","React","useState","visible","setVisible","closing","viewWidth","isDesktop","ViewWidth","SMALL_TABLET","elementRef","useRef","event","current","contains","target","onAnimationEnd","animationFallback","useEffect","set","clear","undefined"],"mappings":";;;;;;;;;;;;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;;;AASO,IAAMA,kBAAqD,GAAG,SAAxDA,kBAAwD,OAK/D;AAAA,MAJJC,QAII,QAJJA,QAII;AAAA,MAHJC,OAGI,QAHJA,OAGI;AAAA,yBAFJC,MAEI;AAAA,MAFJA,MAEI,4BAFK,KAEL;AAAA,MADDC,SACC;;AACJ,gBAAqB,kBAArB;AAAA,MAAQC,QAAR,WAAQA,QAAR;;AACA,MAAMC,QAAQ,GAAG,+BAAjB;;AACA,wBAA8BC,KAAK,CAACC,QAAN,CAAeL,MAAf,CAA9B;AAAA;AAAA,MAAOM,OAAP;AAAA,MAAgBC,UAAhB;;AACA,MAAMC,OAAO,GAAGF,OAAO,IAAI,CAACN,MAA5B;;AACA,uBAAsB,oCAAtB;AAAA,MAAQS,SAAR,kBAAQA,SAAR;;AACA,MAAMC,SAAS,GAAGD,SAAS,IAAIE,6BAAUC,YAAzC;AACA,MAAMC,UAAU,GAAGT,KAAK,CAACU,MAAN,CAA6B,IAA7B,CAAnB;AAEA,4DAA0B,YAAM;AAC9Bd,IAAAA,MAAM,IAAIO,UAAU,CAAC,IAAD,CAApB;AACD,GAFD,EAEG,CAACP,MAAD,CAFH;AAIA,oCAAc,CAACU,SAAD,IAAcV,MAA5B,EAbI,CAeJ;;AACA,sDACEE,QADF,EAEE,OAFF,EAGEQ,SAAS,IACPV,MADF,IAEE,CAACQ,OAFH,IAGG,UAACO,KAAD,EAAW;AACV,QACEF,UAAU,CAACG,OAAX,IACA,CAACH,UAAU,CAACG,OAAX,CAAmBC,QAAnB,CAA4BF,KAAK,CAACG,MAAlC,CAFH,EAGE;AACAnB,MAAAA,OAAO;AACR;AACF,GAbL,EAhBI,CAgCJ;;AACA,MAAMoB,cAAc,GAAG,SAAjBA,cAAiB;AAAA,WAAMZ,UAAU,CAAC,KAAD,CAAhB;AAAA,GAAvB;;AACA,MAAMa,iBAAiB,GAAG,4BAAWD,cAAX,EAA2B,GAA3B,CAA1B;AACAf,EAAAA,KAAK,CAACiB,SAAN,CACE;AAAA,WAAOb,OAAO,GAAGY,iBAAiB,CAACE,GAAlB,EAAH,GAA6BF,iBAAiB,CAACG,KAAlB,EAA3C;AAAA,GADF,EAEE,CAACH,iBAAD,EAAoBZ,OAApB,CAFF;AAKA,SACE,qCAAC,oBAAD,6BACMP,SADN;AAEE;AACA,IAAA,SAAS,EAAE,4BAAW,gCAAa,oBAAb,EAAmCE,QAAnC,CAAX,EAAyD;AAClE,oCAA8BH,MADoC;AAElE,qCAA+BQ,OAFmC;AAGlE,qCAA+BE;AAHmC,KAAzD,CAHb;AAQE,IAAA,QAAQ,EAAC;AARX,MAUE;AACE,IAAA,SAAS,EAAC,wBADZ;AAEE,IAAA,GAAG,EAAEG,UAFP;AAGE,IAAA,cAAc,EAAEL,OAAO,GAAGW,cAAH,GAAoBK;AAH7C,KAKE;AAAK,IAAA,SAAS,EAAC;AAAf,KAA8ClB,OAAO,IAAIR,QAAzD,CALF,CAVF,EAiBG,CAACY,SAAD,IAAcJ,OAAd,IACC;AAAK,IAAA,OAAO,EAAEP,OAAd;AAAuB,IAAA,SAAS,EAAC;AAAjC,IAlBJ,CADF;AAuBD,CApEM","sourcesContent":["import * as React from \"react\";\nimport FixedLayout from \"../FixedLayout/FixedLayout\";\nimport { classNames } from \"../../lib/classNames\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport { ViewWidth } from \"../AdaptivityProvider/AdaptivityContext\";\nimport { useAdaptivity } from \"../../hooks/useAdaptivity\";\nimport { useDOM } from \"../../lib/dom\";\nimport { useIsomorphicLayoutEffect } from \"../../lib/useIsomorphicLayoutEffect\";\nimport { useGlobalEventListener } from \"../../hooks/useGlobalEventListener\";\nimport { useTimeout } from \"../../hooks/useTimeout\";\nimport { usePlatform } from \"../../hooks/usePlatform\";\nimport { useScrollLock } from \"../AppRoot/ScrollContext\";\nimport \"./PanelHeaderContext.css\";\n\nexport interface PanelHeaderContextProps\n extends React.HTMLAttributes<HTMLDivElement> {\n opened: boolean;\n onClose: VoidFunction;\n}\n\nexport const PanelHeaderContext: React.FC<PanelHeaderContextProps> = ({\n children,\n onClose,\n opened = false,\n ...restProps\n}) => {\n const { document } = useDOM();\n const platform = usePlatform();\n const [visible, setVisible] = React.useState(opened);\n const closing = visible && !opened;\n const { viewWidth } = useAdaptivity();\n const isDesktop = viewWidth >= ViewWidth.SMALL_TABLET;\n const elementRef = React.useRef<HTMLDivElement>(null);\n\n useIsomorphicLayoutEffect(() => {\n opened && setVisible(true);\n }, [opened]);\n\n useScrollLock(!isDesktop && opened);\n\n // start closing on outer click\n useGlobalEventListener(\n document,\n \"click\",\n isDesktop &&\n opened &&\n !closing &&\n ((event) => {\n if (\n elementRef.current &&\n !elementRef.current.contains(event.target as Node)\n ) {\n onClose();\n }\n })\n );\n\n // fallback onAnimationEnd when animationend not supported\n const onAnimationEnd = () => setVisible(false);\n const animationFallback = useTimeout(onAnimationEnd, 200);\n React.useEffect(\n () => (closing ? animationFallback.set() : animationFallback.clear()),\n [animationFallback, closing]\n );\n\n return (\n <FixedLayout\n {...restProps}\n // eslint-disable-next-line vkui/no-object-expression-in-arguments\n vkuiClass={classNames(getClassName(\"PanelHeaderContext\", platform), {\n \"PanelHeaderContext--opened\": opened,\n \"PanelHeaderContext--closing\": closing,\n \"PanelHeaderContext--desktop\": isDesktop,\n })}\n vertical=\"top\"\n >\n <div\n vkuiClass=\"PanelHeaderContext__in\"\n ref={elementRef}\n onAnimationEnd={closing ? onAnimationEnd : undefined}\n >\n <div vkuiClass=\"PanelHeaderContext__content\">{visible && children}</div>\n </div>\n {!isDesktop && visible && (\n <div onClick={onClose} vkuiClass=\"PanelHeaderContext__fade\" />\n )}\n </FixedLayout>\n );\n};\n"],"file":"PanelHeaderContext.js"}
@@ -17,7 +17,7 @@ var _classNames = require("../../lib/classNames");
17
17
 
18
18
  var _utils = require("../../lib/utils");
19
19
 
20
- var _Title = _interopRequireDefault(require("../Typography/Title/Title"));
20
+ var _Title = require("../Typography/Title/Title");
21
21
 
22
22
  var _Headline = _interopRequireDefault(require("../Typography/Headline/Headline"));
23
23
 
@@ -32,7 +32,8 @@ var Placeholder = function Placeholder(props) {
32
32
  getRootRef = props.getRootRef,
33
33
  restProps = (0, _objectWithoutProperties2.default)(props, _excluded);
34
34
  return (0, _jsxRuntime.createScopedElement)("div", (0, _extends2.default)({}, restProps, {
35
- ref: getRootRef,
35
+ ref: getRootRef // eslint-disable-next-line vkui/no-object-expression-in-arguments
36
+ ,
36
37
  vkuiClass: (0, _classNames.classNames)("Placeholder", {
37
38
  "Placeholder--stretched": stretched
38
39
  })
@@ -40,7 +41,7 @@ var Placeholder = function Placeholder(props) {
40
41
  vkuiClass: "Placeholder__in"
41
42
  }, (0, _utils.hasReactNode)(icon) && (0, _jsxRuntime.createScopedElement)("div", {
42
43
  vkuiClass: "Placeholder__icon"
43
- }, icon), (0, _utils.hasReactNode)(header) && (0, _jsxRuntime.createScopedElement)(_Title.default, {
44
+ }, icon), (0, _utils.hasReactNode)(header) && (0, _jsxRuntime.createScopedElement)(_Title.Title, {
44
45
  level: "2",
45
46
  weight: "2",
46
47
  vkuiClass: "Placeholder__header"
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/Placeholder/Placeholder.tsx"],"names":["Placeholder","props","icon","header","action","children","stretched","getRootRef","restProps"],"mappings":";;;;;;;;;;;;;;;AACA;;AACA;;AACA;;AACA;;;;AAyBA,IAAMA,WAAuC,GAAG,SAA1CA,WAA0C,CAACC,KAAD,EAA6B;AAC3E,MACEC,IADF,GAQID,KARJ,CACEC,IADF;AAAA,MAEEC,MAFF,GAQIF,KARJ,CAEEE,MAFF;AAAA,MAGEC,MAHF,GAQIH,KARJ,CAGEG,MAHF;AAAA,MAIEC,QAJF,GAQIJ,KARJ,CAIEI,QAJF;AAAA,MAKEC,SALF,GAQIL,KARJ,CAKEK,SALF;AAAA,MAMEC,UANF,GAQIN,KARJ,CAMEM,UANF;AAAA,MAOKC,SAPL,0CAQIP,KARJ;AAUA,SACE,uEACMO,SADN;AAEE,IAAA,GAAG,EAAED,UAFP;AAGE,IAAA,SAAS,EAAE,4BAAW,aAAX,EAA0B;AACnC,gCAA0BD;AADS,KAA1B;AAHb,MAOE;AAAK,IAAA,SAAS,EAAC;AAAf,KACG,yBAAaJ,IAAb,KAAsB;AAAK,IAAA,SAAS,EAAC;AAAf,KAAoCA,IAApC,CADzB,EAEG,yBAAaC,MAAb,KACC,qCAAC,cAAD;AAAO,IAAA,KAAK,EAAC,GAAb;AAAiB,IAAA,MAAM,EAAC,GAAxB;AAA4B,IAAA,SAAS,EAAC;AAAtC,KACGA,MADH,CAHJ,EAOG,yBAAaE,QAAb,KACC,qCAAC,iBAAD;AAAU,IAAA,MAAM,EAAC,SAAjB;AAA2B,IAAA,SAAS,EAAC;AAArC,KACGA,QADH,CARJ,EAYG,yBAAaD,MAAb,KACC;AAAK,IAAA,SAAS,EAAC;AAAf,KAAsCA,MAAtC,CAbJ,CAPF,CADF;AA0BD,CArCD,C,CAuCA;;;eACeJ,W","sourcesContent":["import * as React from \"react\";\nimport { classNames } from \"../../lib/classNames\";\nimport { hasReactNode } from \"../../lib/utils\";\nimport Title from \"../Typography/Title/Title\";\nimport Headline from \"../Typography/Headline/Headline\";\nimport { HasRootRef } from \"../../types\";\nimport \"./Placeholder.css\";\n\nexport interface PlaceholderProps\n extends React.HTMLAttributes<HTMLDivElement>,\n HasRootRef<HTMLDivElement> {\n /**\n * Иконка\n */\n icon?: React.ReactNode;\n /**\n * Заголовок плейсхолдера\n */\n header?: React.ReactNode;\n /**\n * Кнопка действия\n */\n action?: React.ReactNode;\n /**\n * Растягивает плейсхолдер на весь экран, но в таком случае на экране должен быть только плейсхолдер\n */\n stretched?: boolean;\n}\n\nconst Placeholder: React.FC<PlaceholderProps> = (props: PlaceholderProps) => {\n const {\n icon,\n header,\n action,\n children,\n stretched,\n getRootRef,\n ...restProps\n } = props;\n\n return (\n <div\n {...restProps}\n ref={getRootRef}\n vkuiClass={classNames(\"Placeholder\", {\n \"Placeholder--stretched\": stretched,\n })}\n >\n <div vkuiClass=\"Placeholder__in\">\n {hasReactNode(icon) && <div vkuiClass=\"Placeholder__icon\">{icon}</div>}\n {hasReactNode(header) && (\n <Title level=\"2\" weight=\"2\" vkuiClass=\"Placeholder__header\">\n {header}\n </Title>\n )}\n {hasReactNode(children) && (\n <Headline weight=\"regular\" vkuiClass=\"Placeholder__text\">\n {children}\n </Headline>\n )}\n {hasReactNode(action) && (\n <div vkuiClass=\"Placeholder__action\">{action}</div>\n )}\n </div>\n </div>\n );\n};\n\n// eslint-disable-next-line import/no-default-export\nexport default Placeholder;\n"],"file":"Placeholder.js"}
1
+ {"version":3,"sources":["../../../../src/components/Placeholder/Placeholder.tsx"],"names":["Placeholder","props","icon","header","action","children","stretched","getRootRef","restProps"],"mappings":";;;;;;;;;;;;;;;AACA;;AACA;;AACA;;AACA;;;;AAyBA,IAAMA,WAAuC,GAAG,SAA1CA,WAA0C,CAACC,KAAD,EAA6B;AAC3E,MACEC,IADF,GAQID,KARJ,CACEC,IADF;AAAA,MAEEC,MAFF,GAQIF,KARJ,CAEEE,MAFF;AAAA,MAGEC,MAHF,GAQIH,KARJ,CAGEG,MAHF;AAAA,MAIEC,QAJF,GAQIJ,KARJ,CAIEI,QAJF;AAAA,MAKEC,SALF,GAQIL,KARJ,CAKEK,SALF;AAAA,MAMEC,UANF,GAQIN,KARJ,CAMEM,UANF;AAAA,MAOKC,SAPL,0CAQIP,KARJ;AAUA,SACE,uEACMO,SADN;AAEE,IAAA,GAAG,EAAED,UAFP,CAGE;AAHF;AAIE,IAAA,SAAS,EAAE,4BAAW,aAAX,EAA0B;AACnC,gCAA0BD;AADS,KAA1B;AAJb,MAQE;AAAK,IAAA,SAAS,EAAC;AAAf,KACG,yBAAaJ,IAAb,KAAsB;AAAK,IAAA,SAAS,EAAC;AAAf,KAAoCA,IAApC,CADzB,EAEG,yBAAaC,MAAb,KACC,qCAAC,YAAD;AAAO,IAAA,KAAK,EAAC,GAAb;AAAiB,IAAA,MAAM,EAAC,GAAxB;AAA4B,IAAA,SAAS,EAAC;AAAtC,KACGA,MADH,CAHJ,EAOG,yBAAaE,QAAb,KACC,qCAAC,iBAAD;AAAU,IAAA,MAAM,EAAC,SAAjB;AAA2B,IAAA,SAAS,EAAC;AAArC,KACGA,QADH,CARJ,EAYG,yBAAaD,MAAb,KACC;AAAK,IAAA,SAAS,EAAC;AAAf,KAAsCA,MAAtC,CAbJ,CARF,CADF;AA2BD,CAtCD,C,CAwCA;;;eACeJ,W","sourcesContent":["import * as React from \"react\";\nimport { classNames } from \"../../lib/classNames\";\nimport { hasReactNode } from \"../../lib/utils\";\nimport { Title } from \"../Typography/Title/Title\";\nimport Headline from \"../Typography/Headline/Headline\";\nimport { HasRootRef } from \"../../types\";\nimport \"./Placeholder.css\";\n\nexport interface PlaceholderProps\n extends React.HTMLAttributes<HTMLDivElement>,\n HasRootRef<HTMLDivElement> {\n /**\n * Иконка\n */\n icon?: React.ReactNode;\n /**\n * Заголовок плейсхолдера\n */\n header?: React.ReactNode;\n /**\n * Кнопка действия\n */\n action?: React.ReactNode;\n /**\n * Растягивает плейсхолдер на весь экран, но в таком случае на экране должен быть только плейсхолдер\n */\n stretched?: boolean;\n}\n\nconst Placeholder: React.FC<PlaceholderProps> = (props: PlaceholderProps) => {\n const {\n icon,\n header,\n action,\n children,\n stretched,\n getRootRef,\n ...restProps\n } = props;\n\n return (\n <div\n {...restProps}\n ref={getRootRef}\n // eslint-disable-next-line vkui/no-object-expression-in-arguments\n vkuiClass={classNames(\"Placeholder\", {\n \"Placeholder--stretched\": stretched,\n })}\n >\n <div vkuiClass=\"Placeholder__in\">\n {hasReactNode(icon) && <div vkuiClass=\"Placeholder__icon\">{icon}</div>}\n {hasReactNode(header) && (\n <Title level=\"2\" weight=\"2\" vkuiClass=\"Placeholder__header\">\n {header}\n </Title>\n )}\n {hasReactNode(children) && (\n <Headline weight=\"regular\" vkuiClass=\"Placeholder__text\">\n {children}\n </Headline>\n )}\n {hasReactNode(action) && (\n <div vkuiClass=\"Placeholder__action\">{action}</div>\n )}\n </div>\n </div>\n );\n};\n\n// eslint-disable-next-line import/no-default-export\nexport default Placeholder;\n"],"file":"Placeholder.js"}
@@ -79,6 +79,7 @@ var PopoutWrapper = function PopoutWrapper(_ref) {
79
79
  });
80
80
  var baseClassNames = (0, _getClassName.getClassName)("PopoutWrapper", platform);
81
81
  return (0, _jsxRuntime.createScopedElement)("div", (0, _extends2.default)({}, restProps, {
82
+ // eslint-disable-next-line vkui/no-object-expression-in-arguments
82
83
  vkuiClass: (0, _classNames.classNames)(baseClassNames, "PopoutWrapper--v-".concat(alignY), "PopoutWrapper--h-".concat(alignX), {
83
84
  "PopoutWrapper--closing": closing,
84
85
  "PopoutWrapper--opened": opened,
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/PopoutWrapper/PopoutWrapper.tsx"],"names":["PopoutWrapper","alignY","alignX","closing","hasMask","fixed","children","onClick","restProps","platform","React","useState","opened","setOpened","elRef","useRef","onFadeInEnd","e","animationName","animationFinishFallback","IOS","useEffect","set","window","preventDefault","passive","baseClassNames","undefined"],"mappings":";;;;;;;;;;;;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;;;AAYO,IAAMA,aAA2C,GAAG,SAA9CA,aAA8C,OASjC;AAAA,yBARxBC,MAQwB;AAAA,MARxBA,MAQwB,4BARf,QAQe;AAAA,yBAPxBC,MAOwB;AAAA,MAPxBA,MAOwB,4BAPf,QAOe;AAAA,0BANxBC,OAMwB;AAAA,MANxBA,OAMwB,6BANd,KAMc;AAAA,0BALxBC,OAKwB;AAAA,MALxBA,OAKwB,6BALd,IAKc;AAAA,wBAJxBC,KAIwB;AAAA,MAJxBA,KAIwB,2BAJhB,IAIgB;AAAA,MAHxBC,QAGwB,QAHxBA,QAGwB;AAAA,MAFxBC,OAEwB,QAFxBA,OAEwB;AAAA,MADrBC,SACqB;AACxB,MAAMC,QAAQ,GAAG,+BAAjB;;AACA,wBAA4BC,KAAK,CAACC,QAAN,CAAe,CAACP,OAAhB,CAA5B;AAAA;AAAA,MAAOQ,MAAP;AAAA,MAAeC,SAAf;;AACA,MAAMC,KAAK,GAAGJ,KAAK,CAACK,MAAN,CAA6B,IAA7B,CAAd;;AAEA,MAAMC,WAAW,GAAG,SAAdA,WAAc,CAACC,CAAD,EAA8B;AAChD,QAAI,CAACA,CAAD,IAAMA,CAAC,CAACC,aAAF,KAAoB,6BAA9B,EAA6D;AAC3DL,MAAAA,SAAS,CAAC,IAAD,CAAT;AACD;AACF,GAJD;;AAKA,MAAMM,uBAAuB,GAAG,4BAC9BH,WAD8B,EAE9BP,QAAQ,KAAKW,aAAb,GAAmB,GAAnB,GAAyB,GAFK,CAAhC;AAIAV,EAAAA,KAAK,CAACW,SAAN,CAAgB,YAAM;AACpB,KAACT,MAAD,IAAWO,uBAAuB,CAACG,GAAxB,EAAX;AACD,GAFD,EAEG,CAACH,uBAAD,EAA0BP,MAA1B,CAFH;;AAIA,gBAAmB,kBAAnB;AAAA,MAAQW,MAAR,WAAQA,MAAR;;AACA,sDAAuBA,MAAvB,EAA+B,WAA/B,EAA4C,UAACN,CAAD;AAAA,WAAOA,CAAC,CAACO,cAAF,EAAP;AAAA,GAA5C,EAAuE;AACrEC,IAAAA,OAAO,EAAE;AAD4D,GAAvE;AAIA,MAAMC,cAAc,GAAG,gCAAa,eAAb,EAA8BjB,QAA9B,CAAvB;AAEA,SACE,uEACMD,SADN;AAEE,IAAA,SAAS,EAAE,4BACTkB,cADS,6BAEWzB,MAFX,8BAGWC,MAHX,GAIT;AACE,gCAA0BC,OAD5B;AAEE,+BAAyBS,MAF3B;AAGE,8BAAwBP,KAH1B;AAIE,+BAAyBD;AAJ3B,KAJS,CAFb;AAaE,IAAA,cAAc,EAAEQ,MAAM,GAAGe,SAAH,GAAeX,WAbvC;AAcE,IAAA,GAAG,EAAEF;AAdP,MAgBE;AAAK,IAAA,SAAS,EAAC;AAAf,KACE;AAAK,IAAA,SAAS,EAAC,wBAAf;AAAwC,IAAA,OAAO,EAAEP;AAAjD,IADF,EAEE;AAAK,IAAA,SAAS,EAAC;AAAf,KAAyCD,QAAzC,CAFF,CAhBF,CADF;AAuBD,CAzDM","sourcesContent":["import * as React from \"react\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport { classNames } from \"../../lib/classNames\";\nimport { IOS } from \"../../lib/platform\";\nimport { useTimeout } from \"../../hooks/useTimeout\";\nimport { usePlatform } from \"../../hooks/usePlatform\";\nimport { useGlobalEventListener } from \"../../hooks/useGlobalEventListener\";\nimport { useDOM } from \"../../lib/dom\";\nimport \"./PopoutWrapper.css\";\n\nexport interface PopoutWrapperProps\n extends React.HTMLAttributes<HTMLDivElement> {\n hasMask?: boolean;\n fixed?: boolean;\n alignY?: \"top\" | \"center\" | \"bottom\";\n alignX?: \"left\" | \"center\" | \"right\";\n closing?: boolean;\n}\n\nexport const PopoutWrapper: React.FC<PopoutWrapperProps> = ({\n alignY = \"center\",\n alignX = \"center\",\n closing = false,\n hasMask = true,\n fixed = true,\n children,\n onClick,\n ...restProps\n}: PopoutWrapperProps) => {\n const platform = usePlatform();\n const [opened, setOpened] = React.useState(!hasMask);\n const elRef = React.useRef<HTMLDivElement>(null);\n\n const onFadeInEnd = (e?: React.AnimationEvent) => {\n if (!e || e.animationName === \"vkui-animation-full-fade-in\") {\n setOpened(true);\n }\n };\n const animationFinishFallback = useTimeout(\n onFadeInEnd,\n platform === IOS ? 300 : 200\n );\n React.useEffect(() => {\n !opened && animationFinishFallback.set();\n }, [animationFinishFallback, opened]);\n\n const { window } = useDOM();\n useGlobalEventListener(window, \"touchmove\", (e) => e.preventDefault(), {\n passive: false,\n });\n\n const baseClassNames = getClassName(\"PopoutWrapper\", platform);\n\n return (\n <div\n {...restProps}\n vkuiClass={classNames(\n baseClassNames,\n `PopoutWrapper--v-${alignY}`,\n `PopoutWrapper--h-${alignX}`,\n {\n \"PopoutWrapper--closing\": closing,\n \"PopoutWrapper--opened\": opened,\n \"PopoutWrapper--fixed\": fixed,\n \"PopoutWrapper--masked\": hasMask,\n }\n )}\n onAnimationEnd={opened ? undefined : onFadeInEnd}\n ref={elRef}\n >\n <div vkuiClass=\"PopoutWrapper__container\">\n <div vkuiClass=\"PopoutWrapper__overlay\" onClick={onClick} />\n <div vkuiClass=\"PopoutWrapper__content\">{children}</div>\n </div>\n </div>\n );\n};\n"],"file":"PopoutWrapper.js"}
1
+ {"version":3,"sources":["../../../../src/components/PopoutWrapper/PopoutWrapper.tsx"],"names":["PopoutWrapper","alignY","alignX","closing","hasMask","fixed","children","onClick","restProps","platform","React","useState","opened","setOpened","elRef","useRef","onFadeInEnd","e","animationName","animationFinishFallback","IOS","useEffect","set","window","preventDefault","passive","baseClassNames","undefined"],"mappings":";;;;;;;;;;;;;;;;;;;AAAA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;;;AAYO,IAAMA,aAA2C,GAAG,SAA9CA,aAA8C,OASjC;AAAA,yBARxBC,MAQwB;AAAA,MARxBA,MAQwB,4BARf,QAQe;AAAA,yBAPxBC,MAOwB;AAAA,MAPxBA,MAOwB,4BAPf,QAOe;AAAA,0BANxBC,OAMwB;AAAA,MANxBA,OAMwB,6BANd,KAMc;AAAA,0BALxBC,OAKwB;AAAA,MALxBA,OAKwB,6BALd,IAKc;AAAA,wBAJxBC,KAIwB;AAAA,MAJxBA,KAIwB,2BAJhB,IAIgB;AAAA,MAHxBC,QAGwB,QAHxBA,QAGwB;AAAA,MAFxBC,OAEwB,QAFxBA,OAEwB;AAAA,MADrBC,SACqB;AACxB,MAAMC,QAAQ,GAAG,+BAAjB;;AACA,wBAA4BC,KAAK,CAACC,QAAN,CAAe,CAACP,OAAhB,CAA5B;AAAA;AAAA,MAAOQ,MAAP;AAAA,MAAeC,SAAf;;AACA,MAAMC,KAAK,GAAGJ,KAAK,CAACK,MAAN,CAA6B,IAA7B,CAAd;;AAEA,MAAMC,WAAW,GAAG,SAAdA,WAAc,CAACC,CAAD,EAA8B;AAChD,QAAI,CAACA,CAAD,IAAMA,CAAC,CAACC,aAAF,KAAoB,6BAA9B,EAA6D;AAC3DL,MAAAA,SAAS,CAAC,IAAD,CAAT;AACD;AACF,GAJD;;AAKA,MAAMM,uBAAuB,GAAG,4BAC9BH,WAD8B,EAE9BP,QAAQ,KAAKW,aAAb,GAAmB,GAAnB,GAAyB,GAFK,CAAhC;AAIAV,EAAAA,KAAK,CAACW,SAAN,CAAgB,YAAM;AACpB,KAACT,MAAD,IAAWO,uBAAuB,CAACG,GAAxB,EAAX;AACD,GAFD,EAEG,CAACH,uBAAD,EAA0BP,MAA1B,CAFH;;AAIA,gBAAmB,kBAAnB;AAAA,MAAQW,MAAR,WAAQA,MAAR;;AACA,sDAAuBA,MAAvB,EAA+B,WAA/B,EAA4C,UAACN,CAAD;AAAA,WAAOA,CAAC,CAACO,cAAF,EAAP;AAAA,GAA5C,EAAuE;AACrEC,IAAAA,OAAO,EAAE;AAD4D,GAAvE;AAIA,MAAMC,cAAc,GAAG,gCAAa,eAAb,EAA8BjB,QAA9B,CAAvB;AAEA,SACE,uEACMD,SADN;AAEE;AACA,IAAA,SAAS,EAAE,4BACTkB,cADS,6BAEWzB,MAFX,8BAGWC,MAHX,GAIT;AACE,gCAA0BC,OAD5B;AAEE,+BAAyBS,MAF3B;AAGE,8BAAwBP,KAH1B;AAIE,+BAAyBD;AAJ3B,KAJS,CAHb;AAcE,IAAA,cAAc,EAAEQ,MAAM,GAAGe,SAAH,GAAeX,WAdvC;AAeE,IAAA,GAAG,EAAEF;AAfP,MAiBE;AAAK,IAAA,SAAS,EAAC;AAAf,KACE;AAAK,IAAA,SAAS,EAAC,wBAAf;AAAwC,IAAA,OAAO,EAAEP;AAAjD,IADF,EAEE;AAAK,IAAA,SAAS,EAAC;AAAf,KAAyCD,QAAzC,CAFF,CAjBF,CADF;AAwBD,CA1DM","sourcesContent":["import * as React from \"react\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport { classNames } from \"../../lib/classNames\";\nimport { IOS } from \"../../lib/platform\";\nimport { useTimeout } from \"../../hooks/useTimeout\";\nimport { usePlatform } from \"../../hooks/usePlatform\";\nimport { useGlobalEventListener } from \"../../hooks/useGlobalEventListener\";\nimport { useDOM } from \"../../lib/dom\";\nimport \"./PopoutWrapper.css\";\n\nexport interface PopoutWrapperProps\n extends React.HTMLAttributes<HTMLDivElement> {\n hasMask?: boolean;\n fixed?: boolean;\n alignY?: \"top\" | \"center\" | \"bottom\";\n alignX?: \"left\" | \"center\" | \"right\";\n closing?: boolean;\n}\n\nexport const PopoutWrapper: React.FC<PopoutWrapperProps> = ({\n alignY = \"center\",\n alignX = \"center\",\n closing = false,\n hasMask = true,\n fixed = true,\n children,\n onClick,\n ...restProps\n}: PopoutWrapperProps) => {\n const platform = usePlatform();\n const [opened, setOpened] = React.useState(!hasMask);\n const elRef = React.useRef<HTMLDivElement>(null);\n\n const onFadeInEnd = (e?: React.AnimationEvent) => {\n if (!e || e.animationName === \"vkui-animation-full-fade-in\") {\n setOpened(true);\n }\n };\n const animationFinishFallback = useTimeout(\n onFadeInEnd,\n platform === IOS ? 300 : 200\n );\n React.useEffect(() => {\n !opened && animationFinishFallback.set();\n }, [animationFinishFallback, opened]);\n\n const { window } = useDOM();\n useGlobalEventListener(window, \"touchmove\", (e) => e.preventDefault(), {\n passive: false,\n });\n\n const baseClassNames = getClassName(\"PopoutWrapper\", platform);\n\n return (\n <div\n {...restProps}\n // eslint-disable-next-line vkui/no-object-expression-in-arguments\n vkuiClass={classNames(\n baseClassNames,\n `PopoutWrapper--v-${alignY}`,\n `PopoutWrapper--h-${alignX}`,\n {\n \"PopoutWrapper--closing\": closing,\n \"PopoutWrapper--opened\": opened,\n \"PopoutWrapper--fixed\": fixed,\n \"PopoutWrapper--masked\": hasMask,\n }\n )}\n onAnimationEnd={opened ? undefined : onFadeInEnd}\n ref={elRef}\n >\n <div vkuiClass=\"PopoutWrapper__container\">\n <div vkuiClass=\"PopoutWrapper__overlay\" onClick={onClick} />\n <div vkuiClass=\"PopoutWrapper__content\">{children}</div>\n </div>\n </div>\n );\n};\n"],"file":"PopoutWrapper.js"}
@@ -122,8 +122,8 @@ var Popper = function Popper(_ref) {
122
122
  attributes = _usePopper.attributes;
123
123
 
124
124
  var resolvedPlacement = state === null || state === void 0 ? void 0 : state.placement;
125
- var isEdgePlacement = !!resolvedPlacement && resolvedPlacement.includes("-"); // true, если поппер отрисован скраю
126
- // Если поппер рисуется скраю, то нужно опционально сместить его в тех случаях, когда стрелка не дотягивается до
125
+ var isEdgePlacement = !!resolvedPlacement && resolvedPlacement.includes("-"); // true, если поппер отрисован с краю
126
+ // Если поппер рисуется с краю, то нужно опционально сместить его в тех случаях, когда стрелка не дотягивается до
127
127
  // таргета из-за маленьких размеров последнего
128
128
 
129
129
  (0, _useIsomorphicLayoutEffect.useIsomorphicLayoutEffect)(function () {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/Popper/Popper.tsx"],"names":["ARROW_PADDING","ARROW_WIDTH","ARROW_HEIGHT","Popper","targetRef","children","getRef","placement","onPlacementChange","arrow","arrowClassName","sameWidth","offsetDistance","offsetSkidding","forcePortal","compStyles","style","restProps","React","useState","popperNode","setPopperNode","smallTargetOffsetSkidding","setSmallTargetOffsetSkidding","platform","setExternalRef","modifiers","useMemo","name","options","offset","push","padding","enabled","phase","requires","fn","state","styles","popper","width","rects","reference","effect","elements","offsetWidth","current","attributes","resolvedPlacement","isEdgePlacement","includes","placementDirection","startsWith","arrowSize","targetSize","offsetHeight","useEffect","dropdown","minWidth","scrollWidth","undefined"],"mappings":"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","sourcesContent":["import * as React from \"react\";\nimport { usePopper, Modifier } from \"react-popper\";\nimport { AppRootPortal } from \"../AppRoot/AppRootPortal\";\nimport { HasRef } from \"../../types\";\nimport { usePlatform } from \"../../hooks/usePlatform\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport { useExternRef } from \"../../hooks/useExternRef\";\nimport { useIsomorphicLayoutEffect } from \"../../lib/useIsomorphicLayoutEffect\";\nimport \"./Popper.css\";\n\nexport type Placement =\n | \"auto\"\n | \"auto-start\"\n | \"auto-end\"\n | \"top-start\"\n | \"top-end\"\n | \"bottom-start\"\n | \"bottom-end\"\n | \"right-start\"\n | \"right-end\"\n | \"left-start\"\n | \"left-end\"\n | \"top\"\n | \"bottom\"\n | \"left\"\n | \"right\";\n\nexport interface PopperCommonProps\n extends React.HTMLAttributes<HTMLDivElement>,\n HasRef<HTMLDivElement> {\n /**\n * По умолчанию компонент выберет наилучшее расположение сам. Но его можно задать извне с помощью этого свойства\n */\n placement?: Placement;\n /**\n * Отступ по вспомогательной оси\n */\n offsetSkidding?: number;\n /**\n * Отступ по главной оси\n */\n offsetDistance?: number;\n arrow?: boolean;\n arrowClassName?: string;\n /**\n * Выставлять ширину равной target элементу\n */\n sameWidth?: boolean;\n forcePortal?: boolean;\n onPlacementChange?: (data: { placement?: Placement }) => void;\n}\n\nexport interface PopperProps extends PopperCommonProps {\n targetRef: React.RefObject<HTMLElement>;\n}\n\nconst ARROW_PADDING = 8;\nconst ARROW_WIDTH = 20;\nconst ARROW_HEIGHT = 8;\n\nexport const Popper: React.FC<PopperProps> = ({\n targetRef,\n children,\n getRef,\n placement = \"bottom-start\",\n onPlacementChange,\n arrow,\n arrowClassName,\n sameWidth,\n offsetDistance = 8,\n offsetSkidding = 0,\n forcePortal = true,\n style: compStyles,\n ...restProps\n}: PopperProps) => {\n const [popperNode, setPopperNode] = React.useState<HTMLDivElement | null>(\n null\n );\n const [smallTargetOffsetSkidding, setSmallTargetOffsetSkidding] =\n React.useState(0);\n const platform = usePlatform();\n\n const setExternalRef = useExternRef<HTMLDivElement>(getRef, setPopperNode);\n\n const modifiers = React.useMemo(() => {\n const modifiers: Array<Modifier<string>> = [\n {\n name: \"preventOverflow\",\n },\n {\n name: \"offset\",\n options: {\n offset: [\n arrow ? offsetSkidding - smallTargetOffsetSkidding : offsetSkidding,\n arrow ? offsetDistance + ARROW_HEIGHT : offsetDistance,\n ],\n },\n },\n {\n name: \"flip\",\n },\n ];\n\n if (arrow) {\n modifiers.push({\n name: \"arrow\",\n options: {\n padding: ARROW_PADDING,\n },\n });\n }\n\n if (sameWidth) {\n const sameWidth: Modifier<string> = {\n name: \"sameWidth\",\n enabled: true,\n phase: \"beforeWrite\",\n requires: [\"computeStyles\"],\n fn: ({ state }) => {\n state.styles.popper.width = `${state.rects.reference.width}px`;\n },\n effect: ({ state }) => {\n state.elements.popper.style.width = `${\n (state.elements.reference as HTMLElement).offsetWidth\n }px`;\n },\n };\n\n modifiers.push(sameWidth);\n }\n\n return modifiers;\n }, [\n arrow,\n sameWidth,\n smallTargetOffsetSkidding,\n offsetSkidding,\n offsetDistance,\n ]);\n\n const { styles, state, attributes } = usePopper(\n targetRef.current,\n popperNode,\n {\n placement,\n modifiers,\n }\n );\n\n const resolvedPlacement = state?.placement;\n const isEdgePlacement =\n !!resolvedPlacement && resolvedPlacement.includes(\"-\"); // true, если поппер отрисован скраю\n\n // Если поппер рисуется скраю, то нужно опционально сместить его в тех случаях, когда стрелка не дотягивается до\n // таргета из-за маленьких размеров последнего\n useIsomorphicLayoutEffect(() => {\n if (arrow && isEdgePlacement) {\n const placementDirection =\n resolvedPlacement?.startsWith(\"bottom\") ||\n resolvedPlacement?.startsWith(\"top\")\n ? \"vertical\"\n : \"horizontal\";\n\n const arrowSize =\n placementDirection === \"vertical\" ? ARROW_WIDTH : ARROW_HEIGHT;\n const targetSize =\n (placementDirection === \"vertical\"\n ? targetRef.current?.offsetWidth\n : targetRef.current?.offsetHeight) ?? 0;\n\n if (targetSize < arrowSize + 2 * ARROW_PADDING) {\n setSmallTargetOffsetSkidding(ARROW_PADDING + arrowSize / 2);\n }\n } else {\n setSmallTargetOffsetSkidding(0);\n }\n }, [arrow, isEdgePlacement]);\n\n React.useEffect(() => {\n if (resolvedPlacement) {\n onPlacementChange && onPlacementChange({ placement: resolvedPlacement });\n }\n }, [onPlacementChange, resolvedPlacement]);\n\n const dropdown = (\n <div\n {...restProps}\n {...attributes.popper}\n vkuiClass={getClassName(\"Popper\", platform)}\n ref={setExternalRef}\n style={{\n ...compStyles,\n ...styles.popper,\n minWidth: sameWidth ? targetRef.current?.scrollWidth : undefined,\n }}\n >\n {arrow && (\n <div\n {...attributes.arrow}\n vkuiClass=\"Popper__arrow\"\n data-popper-arrow={true}\n style={styles.arrow}\n >\n <svg\n vkuiClass=\"Popper__arrow-in\"\n className={arrowClassName}\n width=\"20\"\n height=\"8\"\n viewBox=\"0 0 20 8\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M10 0C13 0 15.9999 8 20 8H0C3.9749 8 7 0 10 0Z\"\n fill=\"currentColor\"\n />\n </svg>\n </div>\n )}\n <div vkuiClass=\"Popper__content\">{children}</div>\n </div>\n );\n\n return (\n <AppRootPortal forcePortal={forcePortal} vkuiClass=\"PopperPortal\">\n {dropdown}\n </AppRootPortal>\n );\n};\n"],"file":"Popper.js"}
1
+ {"version":3,"sources":["../../../../src/components/Popper/Popper.tsx"],"names":["ARROW_PADDING","ARROW_WIDTH","ARROW_HEIGHT","Popper","targetRef","children","getRef","placement","onPlacementChange","arrow","arrowClassName","sameWidth","offsetDistance","offsetSkidding","forcePortal","compStyles","style","restProps","React","useState","popperNode","setPopperNode","smallTargetOffsetSkidding","setSmallTargetOffsetSkidding","platform","setExternalRef","modifiers","useMemo","name","options","offset","push","padding","enabled","phase","requires","fn","state","styles","popper","width","rects","reference","effect","elements","offsetWidth","current","attributes","resolvedPlacement","isEdgePlacement","includes","placementDirection","startsWith","arrowSize","targetSize","offsetHeight","useEffect","dropdown","minWidth","scrollWidth","undefined"],"mappings":"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","sourcesContent":["import * as React from \"react\";\nimport { usePopper, Modifier } from \"react-popper\";\nimport { AppRootPortal } from \"../AppRoot/AppRootPortal\";\nimport { HasRef } from \"../../types\";\nimport { usePlatform } from \"../../hooks/usePlatform\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport { useExternRef } from \"../../hooks/useExternRef\";\nimport { useIsomorphicLayoutEffect } from \"../../lib/useIsomorphicLayoutEffect\";\nimport \"./Popper.css\";\n\nexport type Placement =\n | \"auto\"\n | \"auto-start\"\n | \"auto-end\"\n | \"top-start\"\n | \"top-end\"\n | \"bottom-start\"\n | \"bottom-end\"\n | \"right-start\"\n | \"right-end\"\n | \"left-start\"\n | \"left-end\"\n | \"top\"\n | \"bottom\"\n | \"left\"\n | \"right\";\n\nexport interface PopperCommonProps\n extends React.HTMLAttributes<HTMLDivElement>,\n HasRef<HTMLDivElement> {\n /**\n * По умолчанию компонент выберет наилучшее расположение сам. Но его можно задать извне с помощью этого свойства\n */\n placement?: Placement;\n /**\n * Отступ по вспомогательной оси\n */\n offsetSkidding?: number;\n /**\n * Отступ по главной оси\n */\n offsetDistance?: number;\n arrow?: boolean;\n arrowClassName?: string;\n /**\n * Выставлять ширину равной target элементу\n */\n sameWidth?: boolean;\n forcePortal?: boolean;\n onPlacementChange?: (data: { placement?: Placement }) => void;\n}\n\nexport interface PopperProps extends PopperCommonProps {\n targetRef: React.RefObject<HTMLElement>;\n}\n\nconst ARROW_PADDING = 8;\nconst ARROW_WIDTH = 20;\nconst ARROW_HEIGHT = 8;\n\nexport const Popper: React.FC<PopperProps> = ({\n targetRef,\n children,\n getRef,\n placement = \"bottom-start\",\n onPlacementChange,\n arrow,\n arrowClassName,\n sameWidth,\n offsetDistance = 8,\n offsetSkidding = 0,\n forcePortal = true,\n style: compStyles,\n ...restProps\n}: PopperProps) => {\n const [popperNode, setPopperNode] = React.useState<HTMLDivElement | null>(\n null\n );\n const [smallTargetOffsetSkidding, setSmallTargetOffsetSkidding] =\n React.useState(0);\n const platform = usePlatform();\n\n const setExternalRef = useExternRef<HTMLDivElement>(getRef, setPopperNode);\n\n const modifiers = React.useMemo(() => {\n const modifiers: Array<Modifier<string>> = [\n {\n name: \"preventOverflow\",\n },\n {\n name: \"offset\",\n options: {\n offset: [\n arrow ? offsetSkidding - smallTargetOffsetSkidding : offsetSkidding,\n arrow ? offsetDistance + ARROW_HEIGHT : offsetDistance,\n ],\n },\n },\n {\n name: \"flip\",\n },\n ];\n\n if (arrow) {\n modifiers.push({\n name: \"arrow\",\n options: {\n padding: ARROW_PADDING,\n },\n });\n }\n\n if (sameWidth) {\n const sameWidth: Modifier<string> = {\n name: \"sameWidth\",\n enabled: true,\n phase: \"beforeWrite\",\n requires: [\"computeStyles\"],\n fn: ({ state }) => {\n state.styles.popper.width = `${state.rects.reference.width}px`;\n },\n effect: ({ state }) => {\n state.elements.popper.style.width = `${\n (state.elements.reference as HTMLElement).offsetWidth\n }px`;\n },\n };\n\n modifiers.push(sameWidth);\n }\n\n return modifiers;\n }, [\n arrow,\n sameWidth,\n smallTargetOffsetSkidding,\n offsetSkidding,\n offsetDistance,\n ]);\n\n const { styles, state, attributes } = usePopper(\n targetRef.current,\n popperNode,\n {\n placement,\n modifiers,\n }\n );\n\n const resolvedPlacement = state?.placement;\n const isEdgePlacement =\n !!resolvedPlacement && resolvedPlacement.includes(\"-\"); // true, если поппер отрисован с краю\n\n // Если поппер рисуется с краю, то нужно опционально сместить его в тех случаях, когда стрелка не дотягивается до\n // таргета из-за маленьких размеров последнего\n useIsomorphicLayoutEffect(() => {\n if (arrow && isEdgePlacement) {\n const placementDirection =\n resolvedPlacement?.startsWith(\"bottom\") ||\n resolvedPlacement?.startsWith(\"top\")\n ? \"vertical\"\n : \"horizontal\";\n\n const arrowSize =\n placementDirection === \"vertical\" ? ARROW_WIDTH : ARROW_HEIGHT;\n const targetSize =\n (placementDirection === \"vertical\"\n ? targetRef.current?.offsetWidth\n : targetRef.current?.offsetHeight) ?? 0;\n\n if (targetSize < arrowSize + 2 * ARROW_PADDING) {\n setSmallTargetOffsetSkidding(ARROW_PADDING + arrowSize / 2);\n }\n } else {\n setSmallTargetOffsetSkidding(0);\n }\n }, [arrow, isEdgePlacement]);\n\n React.useEffect(() => {\n if (resolvedPlacement) {\n onPlacementChange && onPlacementChange({ placement: resolvedPlacement });\n }\n }, [onPlacementChange, resolvedPlacement]);\n\n const dropdown = (\n <div\n {...restProps}\n {...attributes.popper}\n vkuiClass={getClassName(\"Popper\", platform)}\n ref={setExternalRef}\n style={{\n ...compStyles,\n ...styles.popper,\n minWidth: sameWidth ? targetRef.current?.scrollWidth : undefined,\n }}\n >\n {arrow && (\n <div\n {...attributes.arrow}\n vkuiClass=\"Popper__arrow\"\n data-popper-arrow={true}\n style={styles.arrow}\n >\n <svg\n vkuiClass=\"Popper__arrow-in\"\n className={arrowClassName}\n width=\"20\"\n height=\"8\"\n viewBox=\"0 0 20 8\"\n fill=\"none\"\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <path\n fillRule=\"evenodd\"\n clipRule=\"evenodd\"\n d=\"M10 0C13 0 15.9999 8 20 8H0C3.9749 8 7 0 10 0Z\"\n fill=\"currentColor\"\n />\n </svg>\n </div>\n )}\n <div vkuiClass=\"Popper__content\">{children}</div>\n </div>\n );\n\n return (\n <AppRootPortal forcePortal={forcePortal} vkuiClass=\"PopperPortal\">\n {dropdown}\n </AppRootPortal>\n );\n};\n"],"file":"Popper.js"}
@@ -25,7 +25,7 @@ var React = _interopRequireWildcard(require("react"));
25
25
 
26
26
  var _icons = require("@vkontakte/icons");
27
27
 
28
- var _Button = _interopRequireDefault(require("../Button/Button"));
28
+ var _Button = require("../Button/Button");
29
29
 
30
30
  var _SimpleCell = _interopRequireDefault(require("../SimpleCell/SimpleCell"));
31
31
 
@@ -94,7 +94,7 @@ var PromoBanner = function PromoBanner(props) {
94
94
  src: bannerData.iconLink,
95
95
  alt: bannerData.title
96
96
  }),
97
- after: (0, _jsxRuntime.createScopedElement)(_Button.default, {
97
+ after: (0, _jsxRuntime.createScopedElement)(_Button.Button, {
98
98
  mode: "outline"
99
99
  }, bannerData.ctaText),
100
100
  description: bannerData.domain
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/PromoBanner/PromoBanner.tsx"],"names":["warn","PromoBanner","props","platform","bannerData","onClose","restProps","ageRestrictions","parseInt","ageRestriction","process","env","NODE_ENV","React","useState","currentPixel","setCurrentPixel","statsPixels","useMemo","statistics","reduce","acc","item","type","url","onClick","useCallback","click","useEffect","playbackStarted","advertisingLabel","isCloseButtonHidden","trackingLink","iconLink","title","ctaText","domain","length"],"mappings":"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","sourcesContent":["import * as React from \"react\";\nimport { Icon24Dismiss } from \"@vkontakte/icons\";\nimport Button from \"../Button/Button\";\nimport SimpleCell from \"../SimpleCell/SimpleCell\";\nimport Avatar from \"../Avatar/Avatar\";\nimport { Caption } from \"../Typography/Caption/Caption\";\nimport { usePlatform } from \"../../hooks/usePlatform\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport { warnOnce } from \"../../lib/warnOnce\";\nimport \"./PromoBanner.css\";\n\ntype StatsType =\n | \"playbackStarted\" // Начало показа\n | \"click\"; // Клик по баннеру\n\ntype BannerData = {\n title?: string;\n url_types?: string; // eslint-disable-line camelcase\n bannerID?: string;\n imageWidth?: number;\n imageHeight?: number;\n imageLink?: string;\n trackingLink?: string;\n type?: string;\n iconWidth?: number;\n domain?: string;\n ctaText?: string;\n advertisingLabel?: string;\n iconLink?: string;\n statistics?: Array<{ type: StatsType; url: string }>;\n openInBrowser?: boolean;\n iconHeight?: number;\n directLink?: boolean;\n navigationType?: string;\n description?: string;\n ageRestrictions?: string;\n /** @deprecated */\n ageRestriction?: number;\n};\n\nexport interface PromoBannerProps extends React.HTMLAttributes<HTMLDivElement> {\n /** Данные рекламного баннера, полученные из VKWebAppGetAds */\n bannerData: BannerData;\n /** Флаг скрытия кнопки закрытия рекламы */\n isCloseButtonHidden?: boolean;\n /** Хандлер закрытия рекламы */\n onClose: () => void;\n}\n\nconst warn = warnOnce(\"PromoBanner\");\nconst PromoBanner = (props: PromoBannerProps) => {\n const platform = usePlatform();\n const { bannerData = {}, onClose, ...restProps } = props;\n\n const ageRestrictions =\n bannerData.ageRestrictions != null\n ? parseInt(bannerData.ageRestrictions)\n : bannerData.ageRestriction;\n\n if (bannerData.ageRestriction && process.env.NODE_ENV === \"development\") {\n warn(\n \"Свойство bannerData.ageRestriction устарело и будет удалено в 5.0.0. Используйте bannerData.ageRestrictions\"\n );\n }\n\n const [currentPixel, setCurrentPixel] = React.useState(\"\");\n\n const statsPixels = React.useMemo(\n () =>\n (bannerData.statistics\n ? bannerData.statistics.reduce(\n (acc, item) => ({ ...acc, [item.type]: item.url }),\n {}\n )\n : {}) as Record<StatsType, string | void>,\n [bannerData.statistics]\n );\n\n const onClick = React.useCallback(\n () => setCurrentPixel(statsPixels.click || \"\"),\n [statsPixels.click]\n );\n\n React.useEffect(() => {\n if (statsPixels.playbackStarted) {\n setCurrentPixel(statsPixels.playbackStarted);\n }\n }, [statsPixels.playbackStarted]);\n\n return (\n <div vkuiClass={getClassName(\"PromoBanner\", platform)} {...restProps}>\n <div vkuiClass=\"PromoBanner__head\">\n <Caption vkuiClass=\"PromoBanner__label\">\n {bannerData.advertisingLabel || \"Advertisement\"}\n </Caption>\n {ageRestrictions != null && (\n <Caption vkuiClass=\"PromoBanner__age\">{ageRestrictions}+</Caption>\n )}\n\n {!props.isCloseButtonHidden && (\n <div vkuiClass=\"PromoBanner__close\" onClick={props.onClose}>\n <Icon24Dismiss />\n </div>\n )}\n </div>\n <SimpleCell\n href={bannerData.trackingLink}\n onClick={onClick}\n rel=\"nofollow noopener noreferrer\"\n target=\"_blank\"\n before={\n <Avatar\n mode=\"image\"\n size={48}\n src={bannerData.iconLink}\n alt={bannerData.title}\n />\n }\n after={<Button mode=\"outline\">{bannerData.ctaText}</Button>}\n description={bannerData.domain}\n >\n {bannerData.title}\n </SimpleCell>\n\n {currentPixel.length > 0 && (\n <div vkuiClass=\"PromoBanner__pixels\">\n <img src={currentPixel} alt=\"\" />\n </div>\n )}\n </div>\n );\n};\n\n// eslint-disable-next-line import/no-default-export\nexport default PromoBanner;\n"],"file":"PromoBanner.js"}
1
+ {"version":3,"sources":["../../../../src/components/PromoBanner/PromoBanner.tsx"],"names":["warn","PromoBanner","props","platform","bannerData","onClose","restProps","ageRestrictions","parseInt","ageRestriction","process","env","NODE_ENV","React","useState","currentPixel","setCurrentPixel","statsPixels","useMemo","statistics","reduce","acc","item","type","url","onClick","useCallback","click","useEffect","playbackStarted","advertisingLabel","isCloseButtonHidden","trackingLink","iconLink","title","ctaText","domain","length"],"mappings":"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","sourcesContent":["import * as React from \"react\";\nimport { Icon24Dismiss } from \"@vkontakte/icons\";\nimport { Button } from \"../Button/Button\";\nimport SimpleCell from \"../SimpleCell/SimpleCell\";\nimport Avatar from \"../Avatar/Avatar\";\nimport { Caption } from \"../Typography/Caption/Caption\";\nimport { usePlatform } from \"../../hooks/usePlatform\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport { warnOnce } from \"../../lib/warnOnce\";\nimport \"./PromoBanner.css\";\n\ntype StatsType =\n | \"playbackStarted\" // Начало показа\n | \"click\"; // Клик по баннеру\n\ntype BannerData = {\n title?: string;\n url_types?: string; // eslint-disable-line camelcase\n bannerID?: string;\n imageWidth?: number;\n imageHeight?: number;\n imageLink?: string;\n trackingLink?: string;\n type?: string;\n iconWidth?: number;\n domain?: string;\n ctaText?: string;\n advertisingLabel?: string;\n iconLink?: string;\n statistics?: Array<{ type: StatsType; url: string }>;\n openInBrowser?: boolean;\n iconHeight?: number;\n directLink?: boolean;\n navigationType?: string;\n description?: string;\n ageRestrictions?: string;\n /** @deprecated */\n ageRestriction?: number;\n};\n\nexport interface PromoBannerProps extends React.HTMLAttributes<HTMLDivElement> {\n /** Данные рекламного баннера, полученные из VKWebAppGetAds */\n bannerData: BannerData;\n /** Флаг скрытия кнопки закрытия рекламы */\n isCloseButtonHidden?: boolean;\n /** Хандлер закрытия рекламы */\n onClose: () => void;\n}\n\nconst warn = warnOnce(\"PromoBanner\");\nconst PromoBanner = (props: PromoBannerProps) => {\n const platform = usePlatform();\n const { bannerData = {}, onClose, ...restProps } = props;\n\n const ageRestrictions =\n bannerData.ageRestrictions != null\n ? parseInt(bannerData.ageRestrictions)\n : bannerData.ageRestriction;\n\n if (bannerData.ageRestriction && process.env.NODE_ENV === \"development\") {\n warn(\n \"Свойство bannerData.ageRestriction устарело и будет удалено в 5.0.0. Используйте bannerData.ageRestrictions\"\n );\n }\n\n const [currentPixel, setCurrentPixel] = React.useState(\"\");\n\n const statsPixels = React.useMemo(\n () =>\n (bannerData.statistics\n ? bannerData.statistics.reduce(\n (acc, item) => ({ ...acc, [item.type]: item.url }),\n {}\n )\n : {}) as Record<StatsType, string | void>,\n [bannerData.statistics]\n );\n\n const onClick = React.useCallback(\n () => setCurrentPixel(statsPixels.click || \"\"),\n [statsPixels.click]\n );\n\n React.useEffect(() => {\n if (statsPixels.playbackStarted) {\n setCurrentPixel(statsPixels.playbackStarted);\n }\n }, [statsPixels.playbackStarted]);\n\n return (\n <div vkuiClass={getClassName(\"PromoBanner\", platform)} {...restProps}>\n <div vkuiClass=\"PromoBanner__head\">\n <Caption vkuiClass=\"PromoBanner__label\">\n {bannerData.advertisingLabel || \"Advertisement\"}\n </Caption>\n {ageRestrictions != null && (\n <Caption vkuiClass=\"PromoBanner__age\">{ageRestrictions}+</Caption>\n )}\n\n {!props.isCloseButtonHidden && (\n <div vkuiClass=\"PromoBanner__close\" onClick={props.onClose}>\n <Icon24Dismiss />\n </div>\n )}\n </div>\n <SimpleCell\n href={bannerData.trackingLink}\n onClick={onClick}\n rel=\"nofollow noopener noreferrer\"\n target=\"_blank\"\n before={\n <Avatar\n mode=\"image\"\n size={48}\n src={bannerData.iconLink}\n alt={bannerData.title}\n />\n }\n after={<Button mode=\"outline\">{bannerData.ctaText}</Button>}\n description={bannerData.domain}\n >\n {bannerData.title}\n </SimpleCell>\n\n {currentPixel.length > 0 && (\n <div vkuiClass=\"PromoBanner__pixels\">\n <img src={currentPixel} alt=\"\" />\n </div>\n )}\n </div>\n );\n};\n\n// eslint-disable-next-line import/no-default-export\nexport default PromoBanner;\n"],"file":"PromoBanner.js"}
@@ -303,7 +303,8 @@ var PullToRefresh = /*#__PURE__*/function (_React$PureComponent) {
303
303
  }, (0, _jsxRuntime.createScopedElement)(_Touch.Touch, (0, _extends2.default)({}, restProps, {
304
304
  onStart: this.onTouchStart,
305
305
  onMove: this.onTouchMove,
306
- onEnd: this.onTouchEnd,
306
+ onEnd: this.onTouchEnd // eslint-disable-next-line vkui/no-object-expression-in-arguments
307
+ ,
307
308
  vkuiClass: (0, _classNames.classNames)((0, _getClassName.getClassName)("PullToRefresh", platform), {
308
309
  "PullToRefresh--watching": watching,
309
310
  "PullToRefresh--refreshing": refreshing
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/PullToRefresh/PullToRefresh.tsx"],"names":["cancelEvent","event","originalEvent","preventDefault","cancelable","stopPropagation","PullToRefresh","props","undefined","e","state","refreshing","setState","touchDown","isY","shiftY","params","start","max","pageYOffset","scroll","getScroll","y","watching","positionMultiplier","shift","Math","touchY","currentY","min","maxY","progress","abs","spinnerY","spinnerProgress","canRefresh","contentShift","platform","IOS","runRefreshing","resetRefreshingState","ANDROID","VKCOM","contentRef","React","createRef","document","canUseDOM","addEventListener","onWindowTouchMove","passive","removeEventListener","waitFetchingTimeout","clearTimeout","prevProps","prevState","isFetching","onRefreshingFinish","onRefresh","setTimeout","children","window","restProps","spinnerTransform","contentTransform","onTouchStart","onTouchMove","onTouchEnd","transform","WebkitTransform","opacity","PureComponent","ScrollContext"],"mappings":"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","sourcesContent":["import * as React from \"react\";\nimport { Touch, TouchProps, TouchEvent } from \"../Touch/Touch\";\nimport TouchRootContext from \"../Touch/TouchContext\";\nimport FixedLayout from \"../FixedLayout/FixedLayout\";\nimport { classNames } from \"../../lib/classNames\";\nimport { IOS, ANDROID, VKCOM } from \"../../lib/platform\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport PullToRefreshSpinner from \"./PullToRefreshSpinner\";\nimport { withPlatform } from \"../../hoc/withPlatform\";\nimport { AnyFunction, HasPlatform } from \"../../types\";\nimport { canUseDOM, DOMProps, withDOM } from \"../../lib/dom\";\nimport { runTapticImpactOccurred } from \"../../lib/taptic\";\nimport { withContext } from \"../../hoc/withContext\";\nimport {\n ScrollContext,\n ScrollContextInterface,\n} from \"../AppRoot/ScrollContext\";\nimport \"./PullToRefresh.css\";\n\nexport interface PullToRefreshProps extends TouchProps, HasPlatform {\n /**\n * Будет вызвана для обновления контента\n */\n onRefresh: AnyFunction;\n /**\n * Определяет, выполняется ли обновление. Для скрытия спиннера после получения контента необходимо передать `false`\n */\n isFetching?: boolean;\n /** @ignore */\n scroll?: ScrollContextInterface;\n}\n\nexport interface PullToRefreshState {\n watching: boolean;\n refreshing: boolean;\n canRefresh: boolean;\n\n touchDown: boolean;\n\n touchY: number;\n spinnerY: PullToRefreshParams[\"start\"];\n spinnerProgress: number;\n contentShift: number;\n}\n\nexport interface PullToRefreshParams {\n start: number;\n max: number;\n maxY: number;\n refreshing: number;\n positionMultiplier: number;\n}\n\nexport type TouchEventHandler = (event: TouchEvent) => void;\n\nfunction cancelEvent(event: any) {\n if (!event) {\n return false;\n }\n while (event.originalEvent) {\n event = event.originalEvent;\n }\n if (event.preventDefault && event.cancelable) {\n event.preventDefault();\n }\n if (event.stopPropagation) {\n event.stopPropagation();\n }\n return false;\n}\n\nclass PullToRefresh extends React.PureComponent<\n PullToRefreshProps & DOMProps,\n PullToRefreshState\n> {\n constructor(props: PullToRefreshProps) {\n super(props);\n\n this.params = {\n start: props.platform === ANDROID || props.platform === VKCOM ? -45 : -10,\n max: props.platform === ANDROID || props.platform === VKCOM ? 80 : 50,\n maxY: props.platform === ANDROID || props.platform === VKCOM ? 80 : 400,\n refreshing:\n props.platform === ANDROID || props.platform === VKCOM ? 50 : 36,\n\n positionMultiplier:\n props.platform === ANDROID || props.platform === VKCOM ? 1 : 0.21,\n };\n\n this.state = {\n watching: false,\n refreshing: false,\n canRefresh: false,\n\n touchDown: false,\n\n touchY: 0,\n spinnerY: this.params.start,\n spinnerProgress: 0,\n contentShift: 0,\n };\n\n this.contentRef = React.createRef();\n }\n\n params: PullToRefreshParams;\n contentRef: React.RefObject<HTMLDivElement>;\n waitFetchingTimeout: ReturnType<typeof setTimeout> | undefined = undefined;\n\n get document() {\n return this.props.document;\n }\n\n componentDidMount() {\n if (canUseDOM) {\n this.document!.addEventListener(\"touchmove\", this.onWindowTouchMove, {\n // @ts-ignore\n cancelable: true,\n passive: false,\n });\n }\n }\n\n componentWillUnmount() {\n // Здесь нужен последний аргумент с такими же параметрами, потому что\n // некоторые браузеры на странных вендорах типа Meizu не удаляют обработчик.\n // https://github.com/VKCOM/VKUI/issues/444\n if (canUseDOM) {\n this.document!.removeEventListener(\"touchmove\", this.onWindowTouchMove, {\n // @ts-ignore\n cancelable: true,\n passive: false,\n });\n }\n if (this.waitFetchingTimeout) {\n clearTimeout(this.waitFetchingTimeout);\n }\n }\n\n componentDidUpdate(\n prevProps: PullToRefreshProps,\n prevState: PullToRefreshState\n ) {\n if (prevProps.isFetching && !this.props.isFetching) {\n this.onRefreshingFinish();\n }\n if (\n !prevProps.isFetching &&\n this.props.isFetching &&\n this.waitFetchingTimeout\n ) {\n clearTimeout(this.waitFetchingTimeout);\n }\n\n if (prevState.touchDown && !this.state.touchDown) {\n const { refreshing, canRefresh } = this.state;\n if (!refreshing && canRefresh) {\n this.runRefreshing();\n } else if (refreshing && !this.props.isFetching) {\n // only iOS can start refresh before gesture end\n this.resetRefreshingState();\n } else {\n // refreshing && isFetching: refresh in progress\n // OR !refreshing && !canRefresh: pull was not strong enough\n this.setState({\n spinnerY: refreshing ? this.params.refreshing : this.params.start,\n spinnerProgress: 0,\n contentShift: 0,\n });\n }\n }\n }\n\n onTouchStart: TouchEventHandler = (e: TouchEvent) => {\n if (this.state.refreshing) {\n cancelEvent(e);\n }\n this.setState({ touchDown: true });\n };\n\n onWindowTouchMove: EventListener = (event: Event) => {\n if (this.state.refreshing) {\n event.preventDefault();\n event.stopPropagation();\n }\n };\n\n onTouchMove: TouchEventHandler = (e: TouchEvent) => {\n const { isY, shiftY } = e;\n const { start, max } = this.params;\n const pageYOffset = this.props.scroll?.getScroll().y;\n\n const { refreshing, watching, touchDown } = this.state;\n\n if (watching && touchDown) {\n cancelEvent(e);\n\n const { positionMultiplier } = this.params;\n\n const shift = Math.max(0, shiftY - this.state.touchY);\n\n const currentY = Math.max(\n start,\n Math.min(this.params.maxY, start + shift * positionMultiplier)\n );\n const progress =\n currentY > -10 ? Math.abs((currentY + 10) / max) * 80 : 0;\n\n this.setState({\n spinnerY: currentY,\n spinnerProgress: Math.min(80, Math.max(0, progress)),\n canRefresh: progress > 80,\n contentShift: (currentY + 10) * 2.3,\n });\n\n if (progress > 85 && !refreshing && this.props.platform === IOS) {\n this.runRefreshing();\n }\n } else if (\n isY &&\n pageYOffset === 0 &&\n shiftY > 0 &&\n !refreshing &&\n touchDown\n ) {\n cancelEvent(e);\n\n this.setState({\n watching: true,\n touchY: shiftY,\n spinnerY: start,\n spinnerProgress: 0,\n });\n }\n };\n\n onTouchEnd = () => {\n this.setState({\n watching: false,\n touchDown: false,\n });\n };\n\n runRefreshing() {\n if (!this.state.refreshing && this.props.onRefresh) {\n // cleanup if the consumer does not start fetching in 1s\n this.waitFetchingTimeout = setTimeout(this.onRefreshingFinish, 1000);\n this.setState({\n refreshing: true,\n spinnerY:\n this.props.platform === ANDROID || this.props.platform === VKCOM\n ? this.params.refreshing\n : this.state.spinnerY,\n });\n\n this.props.onRefresh();\n runTapticImpactOccurred(\"light\");\n }\n }\n\n onRefreshingFinish: VoidFunction = () => {\n if (!this.state.touchDown) {\n this.resetRefreshingState();\n }\n };\n\n resetRefreshingState() {\n this.setState({\n watching: false,\n canRefresh: false,\n refreshing: false,\n spinnerY: this.params.start,\n spinnerProgress: 0,\n contentShift: 0,\n });\n }\n\n render() {\n const {\n children,\n onRefresh,\n isFetching,\n platform,\n window,\n document,\n scroll,\n ...restProps\n } = this.props;\n const {\n watching,\n refreshing,\n spinnerY,\n spinnerProgress,\n canRefresh,\n touchDown,\n contentShift,\n } = this.state;\n\n const spinnerTransform = `translate3d(0, ${spinnerY}px, 0)`;\n let contentTransform = \"\";\n\n if (platform === IOS && refreshing && !touchDown) {\n contentTransform = \"translate3d(0, 100px, 0)\";\n } else if (platform === IOS && (contentShift || refreshing)) {\n contentTransform = `translate3d(0, ${contentShift}px, 0)`;\n }\n\n return (\n <TouchRootContext.Provider value={true}>\n <Touch\n {...restProps}\n onStart={this.onTouchStart}\n onMove={this.onTouchMove}\n onEnd={this.onTouchEnd}\n vkuiClass={classNames(getClassName(\"PullToRefresh\", platform), {\n \"PullToRefresh--watching\": watching,\n \"PullToRefresh--refreshing\": refreshing,\n })}\n >\n <FixedLayout vkuiClass=\"PullToRefresh__controls\">\n <PullToRefreshSpinner\n style={{\n transform: spinnerTransform,\n WebkitTransform: spinnerTransform,\n opacity: watching || refreshing || canRefresh ? 1 : 0,\n }}\n on={refreshing}\n progress={refreshing ? undefined : spinnerProgress}\n />\n </FixedLayout>\n\n <div\n vkuiClass=\"PullToRefresh__content\"\n ref={this.contentRef}\n style={{\n transform: contentTransform,\n WebkitTransform: contentTransform,\n }}\n >\n {children}\n </div>\n </Touch>\n </TouchRootContext.Provider>\n );\n }\n}\n\n// eslint-disable-next-line import/no-default-export\nexport default withContext(\n withPlatform(withDOM<PullToRefreshProps>(PullToRefresh)),\n ScrollContext,\n \"scroll\"\n);\n"],"file":"PullToRefresh.js"}
1
+ {"version":3,"sources":["../../../../src/components/PullToRefresh/PullToRefresh.tsx"],"names":["cancelEvent","event","originalEvent","preventDefault","cancelable","stopPropagation","PullToRefresh","props","undefined","e","state","refreshing","setState","touchDown","isY","shiftY","params","start","max","pageYOffset","scroll","getScroll","y","watching","positionMultiplier","shift","Math","touchY","currentY","min","maxY","progress","abs","spinnerY","spinnerProgress","canRefresh","contentShift","platform","IOS","runRefreshing","resetRefreshingState","ANDROID","VKCOM","contentRef","React","createRef","document","canUseDOM","addEventListener","onWindowTouchMove","passive","removeEventListener","waitFetchingTimeout","clearTimeout","prevProps","prevState","isFetching","onRefreshingFinish","onRefresh","setTimeout","children","window","restProps","spinnerTransform","contentTransform","onTouchStart","onTouchMove","onTouchEnd","transform","WebkitTransform","opacity","PureComponent","ScrollContext"],"mappings":"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","sourcesContent":["import * as React from \"react\";\nimport { Touch, TouchProps, TouchEvent } from \"../Touch/Touch\";\nimport TouchRootContext from \"../Touch/TouchContext\";\nimport FixedLayout from \"../FixedLayout/FixedLayout\";\nimport { classNames } from \"../../lib/classNames\";\nimport { IOS, ANDROID, VKCOM } from \"../../lib/platform\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport PullToRefreshSpinner from \"./PullToRefreshSpinner\";\nimport { withPlatform } from \"../../hoc/withPlatform\";\nimport { AnyFunction, HasPlatform } from \"../../types\";\nimport { canUseDOM, DOMProps, withDOM } from \"../../lib/dom\";\nimport { runTapticImpactOccurred } from \"../../lib/taptic\";\nimport { withContext } from \"../../hoc/withContext\";\nimport {\n ScrollContext,\n ScrollContextInterface,\n} from \"../AppRoot/ScrollContext\";\nimport \"./PullToRefresh.css\";\n\nexport interface PullToRefreshProps extends TouchProps, HasPlatform {\n /**\n * Будет вызвана для обновления контента\n */\n onRefresh: AnyFunction;\n /**\n * Определяет, выполняется ли обновление. Для скрытия спиннера после получения контента необходимо передать `false`\n */\n isFetching?: boolean;\n /** @ignore */\n scroll?: ScrollContextInterface;\n}\n\nexport interface PullToRefreshState {\n watching: boolean;\n refreshing: boolean;\n canRefresh: boolean;\n\n touchDown: boolean;\n\n touchY: number;\n spinnerY: PullToRefreshParams[\"start\"];\n spinnerProgress: number;\n contentShift: number;\n}\n\nexport interface PullToRefreshParams {\n start: number;\n max: number;\n maxY: number;\n refreshing: number;\n positionMultiplier: number;\n}\n\nexport type TouchEventHandler = (event: TouchEvent) => void;\n\nfunction cancelEvent(event: any) {\n if (!event) {\n return false;\n }\n while (event.originalEvent) {\n event = event.originalEvent;\n }\n if (event.preventDefault && event.cancelable) {\n event.preventDefault();\n }\n if (event.stopPropagation) {\n event.stopPropagation();\n }\n return false;\n}\n\nclass PullToRefresh extends React.PureComponent<\n PullToRefreshProps & DOMProps,\n PullToRefreshState\n> {\n constructor(props: PullToRefreshProps) {\n super(props);\n\n this.params = {\n start: props.platform === ANDROID || props.platform === VKCOM ? -45 : -10,\n max: props.platform === ANDROID || props.platform === VKCOM ? 80 : 50,\n maxY: props.platform === ANDROID || props.platform === VKCOM ? 80 : 400,\n refreshing:\n props.platform === ANDROID || props.platform === VKCOM ? 50 : 36,\n\n positionMultiplier:\n props.platform === ANDROID || props.platform === VKCOM ? 1 : 0.21,\n };\n\n this.state = {\n watching: false,\n refreshing: false,\n canRefresh: false,\n\n touchDown: false,\n\n touchY: 0,\n spinnerY: this.params.start,\n spinnerProgress: 0,\n contentShift: 0,\n };\n\n this.contentRef = React.createRef();\n }\n\n params: PullToRefreshParams;\n contentRef: React.RefObject<HTMLDivElement>;\n waitFetchingTimeout: ReturnType<typeof setTimeout> | undefined = undefined;\n\n get document() {\n return this.props.document;\n }\n\n componentDidMount() {\n if (canUseDOM) {\n this.document!.addEventListener(\"touchmove\", this.onWindowTouchMove, {\n // @ts-ignore\n cancelable: true,\n passive: false,\n });\n }\n }\n\n componentWillUnmount() {\n // Здесь нужен последний аргумент с такими же параметрами, потому что\n // некоторые браузеры на странных вендорах типа Meizu не удаляют обработчик.\n // https://github.com/VKCOM/VKUI/issues/444\n if (canUseDOM) {\n this.document!.removeEventListener(\"touchmove\", this.onWindowTouchMove, {\n // @ts-ignore\n cancelable: true,\n passive: false,\n });\n }\n if (this.waitFetchingTimeout) {\n clearTimeout(this.waitFetchingTimeout);\n }\n }\n\n componentDidUpdate(\n prevProps: PullToRefreshProps,\n prevState: PullToRefreshState\n ) {\n if (prevProps.isFetching && !this.props.isFetching) {\n this.onRefreshingFinish();\n }\n if (\n !prevProps.isFetching &&\n this.props.isFetching &&\n this.waitFetchingTimeout\n ) {\n clearTimeout(this.waitFetchingTimeout);\n }\n\n if (prevState.touchDown && !this.state.touchDown) {\n const { refreshing, canRefresh } = this.state;\n if (!refreshing && canRefresh) {\n this.runRefreshing();\n } else if (refreshing && !this.props.isFetching) {\n // only iOS can start refresh before gesture end\n this.resetRefreshingState();\n } else {\n // refreshing && isFetching: refresh in progress\n // OR !refreshing && !canRefresh: pull was not strong enough\n this.setState({\n spinnerY: refreshing ? this.params.refreshing : this.params.start,\n spinnerProgress: 0,\n contentShift: 0,\n });\n }\n }\n }\n\n onTouchStart: TouchEventHandler = (e: TouchEvent) => {\n if (this.state.refreshing) {\n cancelEvent(e);\n }\n this.setState({ touchDown: true });\n };\n\n onWindowTouchMove: EventListener = (event: Event) => {\n if (this.state.refreshing) {\n event.preventDefault();\n event.stopPropagation();\n }\n };\n\n onTouchMove: TouchEventHandler = (e: TouchEvent) => {\n const { isY, shiftY } = e;\n const { start, max } = this.params;\n const pageYOffset = this.props.scroll?.getScroll().y;\n\n const { refreshing, watching, touchDown } = this.state;\n\n if (watching && touchDown) {\n cancelEvent(e);\n\n const { positionMultiplier } = this.params;\n\n const shift = Math.max(0, shiftY - this.state.touchY);\n\n const currentY = Math.max(\n start,\n Math.min(this.params.maxY, start + shift * positionMultiplier)\n );\n const progress =\n currentY > -10 ? Math.abs((currentY + 10) / max) * 80 : 0;\n\n this.setState({\n spinnerY: currentY,\n spinnerProgress: Math.min(80, Math.max(0, progress)),\n canRefresh: progress > 80,\n contentShift: (currentY + 10) * 2.3,\n });\n\n if (progress > 85 && !refreshing && this.props.platform === IOS) {\n this.runRefreshing();\n }\n } else if (\n isY &&\n pageYOffset === 0 &&\n shiftY > 0 &&\n !refreshing &&\n touchDown\n ) {\n cancelEvent(e);\n\n this.setState({\n watching: true,\n touchY: shiftY,\n spinnerY: start,\n spinnerProgress: 0,\n });\n }\n };\n\n onTouchEnd = () => {\n this.setState({\n watching: false,\n touchDown: false,\n });\n };\n\n runRefreshing() {\n if (!this.state.refreshing && this.props.onRefresh) {\n // cleanup if the consumer does not start fetching in 1s\n this.waitFetchingTimeout = setTimeout(this.onRefreshingFinish, 1000);\n this.setState({\n refreshing: true,\n spinnerY:\n this.props.platform === ANDROID || this.props.platform === VKCOM\n ? this.params.refreshing\n : this.state.spinnerY,\n });\n\n this.props.onRefresh();\n runTapticImpactOccurred(\"light\");\n }\n }\n\n onRefreshingFinish: VoidFunction = () => {\n if (!this.state.touchDown) {\n this.resetRefreshingState();\n }\n };\n\n resetRefreshingState() {\n this.setState({\n watching: false,\n canRefresh: false,\n refreshing: false,\n spinnerY: this.params.start,\n spinnerProgress: 0,\n contentShift: 0,\n });\n }\n\n render() {\n const {\n children,\n onRefresh,\n isFetching,\n platform,\n window,\n document,\n scroll,\n ...restProps\n } = this.props;\n const {\n watching,\n refreshing,\n spinnerY,\n spinnerProgress,\n canRefresh,\n touchDown,\n contentShift,\n } = this.state;\n\n const spinnerTransform = `translate3d(0, ${spinnerY}px, 0)`;\n let contentTransform = \"\";\n\n if (platform === IOS && refreshing && !touchDown) {\n contentTransform = \"translate3d(0, 100px, 0)\";\n } else if (platform === IOS && (contentShift || refreshing)) {\n contentTransform = `translate3d(0, ${contentShift}px, 0)`;\n }\n\n return (\n <TouchRootContext.Provider value={true}>\n <Touch\n {...restProps}\n onStart={this.onTouchStart}\n onMove={this.onTouchMove}\n onEnd={this.onTouchEnd}\n // eslint-disable-next-line vkui/no-object-expression-in-arguments\n vkuiClass={classNames(getClassName(\"PullToRefresh\", platform), {\n \"PullToRefresh--watching\": watching,\n \"PullToRefresh--refreshing\": refreshing,\n })}\n >\n <FixedLayout vkuiClass=\"PullToRefresh__controls\">\n <PullToRefreshSpinner\n style={{\n transform: spinnerTransform,\n WebkitTransform: spinnerTransform,\n opacity: watching || refreshing || canRefresh ? 1 : 0,\n }}\n on={refreshing}\n progress={refreshing ? undefined : spinnerProgress}\n />\n </FixedLayout>\n\n <div\n vkuiClass=\"PullToRefresh__content\"\n ref={this.contentRef}\n style={{\n transform: contentTransform,\n WebkitTransform: contentTransform,\n }}\n >\n {children}\n </div>\n </Touch>\n </TouchRootContext.Provider>\n );\n }\n}\n\n// eslint-disable-next-line import/no-default-export\nexport default withContext(\n withPlatform(withDOM<PullToRefreshProps>(PullToRefresh)),\n ScrollContext,\n \"scroll\"\n);\n"],"file":"PullToRefresh.js"}
@@ -35,6 +35,7 @@ var PullToRefreshSpinner = function PullToRefreshSpinner(_ref) {
35
35
  var circleCenter = 0.5 * size;
36
36
  var dashoffset = calcStrokeDashOffset(on ? 80 : progress, radius);
37
37
  return (0, _jsxRuntime.createScopedElement)("div", {
38
+ // eslint-disable-next-line vkui/no-object-expression-in-arguments
38
39
  vkuiClass: (0, _classNames.classNames)("PullToRefresh__spinner", {
39
40
  "PullToRefresh__spinner--on": on
40
41
  }),
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/PullToRefresh/PullToRefreshSpinner.tsx"],"names":["calcStrokeDashOffset","value","radius","progress","Math","PI","PullToRefreshSpinner","on","size","strokeWidth","style","ariaLabel","dasharray","circleCenter","dashoffset","undefined","width","height","transformOrigin","React","memo"],"mappings":";;;;;;;;;;;AAAA;;AACA;;AAGA,SAASA,oBAAT,CAA8BC,KAA9B,EAA6CC,MAA7C,EAA6D;AAC3D,MAAMC,QAAQ,GAAGF,KAAK,GAAG,GAAzB;AACA,SAAO,IAAIG,IAAI,CAACC,EAAT,GAAcH,MAAd,IAAwB,IAAIC,QAA5B,CAAP;AACD;;AAWD,IAAMG,oBAEL,GAAG,SAFEA,oBAEF,OAO6B;AAAA,qBAN/BC,EAM+B;AAAA,MAN/BA,EAM+B,wBAN1B,IAM0B;AAAA,uBAL/BC,IAK+B;AAAA,MAL/BA,IAK+B,0BALxB,EAKwB;AAAA,8BAJ/BC,WAI+B;AAAA,MAJ/BA,WAI+B,iCAJjB,GAIiB;AAAA,MAH/BC,KAG+B,QAH/BA,KAG+B;AAAA,2BAF/BP,QAE+B;AAAA,MAF/BA,QAE+B,8BAFpB,CAEoB;AAAA,4BAD/B,YAC+B;AAAA,MADjBQ,SACiB,+BADL,0BACK;AAC/B,MAAMT,MAAM,GAAG,MAAMM,IAAN,GAAa,MAAMC,WAAlC;AACA,MAAMG,SAAS,GAAG,IAAIR,IAAI,CAACC,EAAT,GAAcH,MAAhC;AACA,MAAMW,YAAY,GAAG,MAAML,IAA3B;AAEA,MAAMM,UAAU,GAAGd,oBAAoB,CAACO,EAAE,GAAG,EAAH,GAAQJ,QAAX,EAAqBD,MAArB,CAAvC;AAEA,SACE;AACE,IAAA,SAAS,EAAE,4BAAW,wBAAX,EAAqC;AAC9C,oCAA8BK;AADgB,KAArC,CADb;AAIE,IAAA,KAAK,EAAEG,KAJT;AAKE,kBAAYH,EAAE,GAAGI,SAAH,GAAeI;AAL/B,KAOE;AACE,IAAA,IAAI,EAAC,cADP;AAEE,IAAA,SAAS,EAAC,6BAFZ;AAGE,IAAA,KAAK,EAAE;AACLC,MAAAA,KAAK,EAAER,IADF;AAELS,MAAAA,MAAM,EAAET;AAFH,KAHT;AAOE,IAAA,OAAO,gBAASA,IAAT,cAAiBA,IAAjB,CAPT;AAQE,IAAA,KAAK,EAAC;AARR,KAUE;AACE,IAAA,KAAK,EAAE;AACLQ,MAAAA,KAAK,EAAER,IADF;AAELS,MAAAA,MAAM,EAAET,IAFH;AAGLU,MAAAA,eAAe,YAAKL,YAAL,gBAAuBA,YAAvB;AAHV;AADT,KAOE;AACE,IAAA,SAAS,EAAC,6BADZ;AAEE,IAAA,IAAI,EAAC,MAFP;AAGE,IAAA,eAAe,EAAED,SAHnB;AAIE,IAAA,gBAAgB,EAAEE,UAJpB;AAKE,IAAA,WAAW,EAAEL,WALf;AAME,IAAA,aAAa,EAAC,OANhB;AAOE,IAAA,EAAE,EAAEI,YAPN;AAQE,IAAA,EAAE,EAAEA,YARN;AASE,IAAA,CAAC,EAAEX;AATL,IAPF,CAVF,CAPF,CADF;AAwCD,CAxDD,C,CA0DA;;;4BACeiB,KAAK,CAACC,IAAN,CAAWd,oBAAX,C","sourcesContent":["import * as React from \"react\";\nimport { classNames } from \"../../lib/classNames\";\nimport \"./PullToRefresh.css\";\n\nfunction calcStrokeDashOffset(value: number, radius: number) {\n const progress = value / 100;\n return 2 * Math.PI * radius * (1 - progress);\n}\n\nexport interface PullToRefreshSpinnerProps\n extends React.HTMLAttributes<HTMLDivElement> {\n size?: number;\n strokeWidth?: number;\n on?: boolean;\n progress?: number;\n \"aria-label\"?: string;\n}\n\nconst PullToRefreshSpinner: React.FunctionComponent<\n PullToRefreshSpinnerProps\n> = ({\n on = true,\n size = 24,\n strokeWidth = 2.5,\n style,\n progress = 0,\n \"aria-label\": ariaLabel = \"Пожалуйста, подождите...\",\n}: PullToRefreshSpinnerProps) => {\n const radius = 0.5 * size - 0.5 * strokeWidth;\n const dasharray = 2 * Math.PI * radius;\n const circleCenter = 0.5 * size;\n\n const dashoffset = calcStrokeDashOffset(on ? 80 : progress, radius);\n\n return (\n <div\n vkuiClass={classNames(\"PullToRefresh__spinner\", {\n \"PullToRefresh__spinner--on\": on,\n })}\n style={style}\n aria-label={on ? ariaLabel : undefined}\n >\n <svg\n role=\"presentation\"\n vkuiClass=\"PullToRefresh__spinner-self\"\n style={{\n width: size,\n height: size,\n }}\n viewBox={`0 0 ${size} ${size}`}\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <g\n style={{\n width: size,\n height: size,\n transformOrigin: `${circleCenter}px ${circleCenter}px`,\n }}\n >\n <circle\n vkuiClass=\"PullToRefresh__spinner-path\"\n fill=\"none\"\n strokeDasharray={dasharray}\n strokeDashoffset={dashoffset}\n strokeWidth={strokeWidth}\n strokeLinecap=\"round\"\n cx={circleCenter}\n cy={circleCenter}\n r={radius}\n />\n </g>\n </svg>\n </div>\n );\n};\n\n// eslint-disable-next-line import/no-default-export\nexport default React.memo(PullToRefreshSpinner);\n"],"file":"PullToRefreshSpinner.js"}
1
+ {"version":3,"sources":["../../../../src/components/PullToRefresh/PullToRefreshSpinner.tsx"],"names":["calcStrokeDashOffset","value","radius","progress","Math","PI","PullToRefreshSpinner","on","size","strokeWidth","style","ariaLabel","dasharray","circleCenter","dashoffset","undefined","width","height","transformOrigin","React","memo"],"mappings":";;;;;;;;;;;AAAA;;AACA;;AAGA,SAASA,oBAAT,CAA8BC,KAA9B,EAA6CC,MAA7C,EAA6D;AAC3D,MAAMC,QAAQ,GAAGF,KAAK,GAAG,GAAzB;AACA,SAAO,IAAIG,IAAI,CAACC,EAAT,GAAcH,MAAd,IAAwB,IAAIC,QAA5B,CAAP;AACD;;AAWD,IAAMG,oBAEL,GAAG,SAFEA,oBAEF,OAO6B;AAAA,qBAN/BC,EAM+B;AAAA,MAN/BA,EAM+B,wBAN1B,IAM0B;AAAA,uBAL/BC,IAK+B;AAAA,MAL/BA,IAK+B,0BALxB,EAKwB;AAAA,8BAJ/BC,WAI+B;AAAA,MAJ/BA,WAI+B,iCAJjB,GAIiB;AAAA,MAH/BC,KAG+B,QAH/BA,KAG+B;AAAA,2BAF/BP,QAE+B;AAAA,MAF/BA,QAE+B,8BAFpB,CAEoB;AAAA,4BAD/B,YAC+B;AAAA,MADjBQ,SACiB,+BADL,0BACK;AAC/B,MAAMT,MAAM,GAAG,MAAMM,IAAN,GAAa,MAAMC,WAAlC;AACA,MAAMG,SAAS,GAAG,IAAIR,IAAI,CAACC,EAAT,GAAcH,MAAhC;AACA,MAAMW,YAAY,GAAG,MAAML,IAA3B;AAEA,MAAMM,UAAU,GAAGd,oBAAoB,CAACO,EAAE,GAAG,EAAH,GAAQJ,QAAX,EAAqBD,MAArB,CAAvC;AAEA,SACE;AACE;AACA,IAAA,SAAS,EAAE,4BAAW,wBAAX,EAAqC;AAC9C,oCAA8BK;AADgB,KAArC,CAFb;AAKE,IAAA,KAAK,EAAEG,KALT;AAME,kBAAYH,EAAE,GAAGI,SAAH,GAAeI;AAN/B,KAQE;AACE,IAAA,IAAI,EAAC,cADP;AAEE,IAAA,SAAS,EAAC,6BAFZ;AAGE,IAAA,KAAK,EAAE;AACLC,MAAAA,KAAK,EAAER,IADF;AAELS,MAAAA,MAAM,EAAET;AAFH,KAHT;AAOE,IAAA,OAAO,gBAASA,IAAT,cAAiBA,IAAjB,CAPT;AAQE,IAAA,KAAK,EAAC;AARR,KAUE;AACE,IAAA,KAAK,EAAE;AACLQ,MAAAA,KAAK,EAAER,IADF;AAELS,MAAAA,MAAM,EAAET,IAFH;AAGLU,MAAAA,eAAe,YAAKL,YAAL,gBAAuBA,YAAvB;AAHV;AADT,KAOE;AACE,IAAA,SAAS,EAAC,6BADZ;AAEE,IAAA,IAAI,EAAC,MAFP;AAGE,IAAA,eAAe,EAAED,SAHnB;AAIE,IAAA,gBAAgB,EAAEE,UAJpB;AAKE,IAAA,WAAW,EAAEL,WALf;AAME,IAAA,aAAa,EAAC,OANhB;AAOE,IAAA,EAAE,EAAEI,YAPN;AAQE,IAAA,EAAE,EAAEA,YARN;AASE,IAAA,CAAC,EAAEX;AATL,IAPF,CAVF,CARF,CADF;AAyCD,CAzDD,C,CA2DA;;;4BACeiB,KAAK,CAACC,IAAN,CAAWd,oBAAX,C","sourcesContent":["import * as React from \"react\";\nimport { classNames } from \"../../lib/classNames\";\nimport \"./PullToRefresh.css\";\n\nfunction calcStrokeDashOffset(value: number, radius: number) {\n const progress = value / 100;\n return 2 * Math.PI * radius * (1 - progress);\n}\n\nexport interface PullToRefreshSpinnerProps\n extends React.HTMLAttributes<HTMLDivElement> {\n size?: number;\n strokeWidth?: number;\n on?: boolean;\n progress?: number;\n \"aria-label\"?: string;\n}\n\nconst PullToRefreshSpinner: React.FunctionComponent<\n PullToRefreshSpinnerProps\n> = ({\n on = true,\n size = 24,\n strokeWidth = 2.5,\n style,\n progress = 0,\n \"aria-label\": ariaLabel = \"Пожалуйста, подождите...\",\n}: PullToRefreshSpinnerProps) => {\n const radius = 0.5 * size - 0.5 * strokeWidth;\n const dasharray = 2 * Math.PI * radius;\n const circleCenter = 0.5 * size;\n\n const dashoffset = calcStrokeDashOffset(on ? 80 : progress, radius);\n\n return (\n <div\n // eslint-disable-next-line vkui/no-object-expression-in-arguments\n vkuiClass={classNames(\"PullToRefresh__spinner\", {\n \"PullToRefresh__spinner--on\": on,\n })}\n style={style}\n aria-label={on ? ariaLabel : undefined}\n >\n <svg\n role=\"presentation\"\n vkuiClass=\"PullToRefresh__spinner-self\"\n style={{\n width: size,\n height: size,\n }}\n viewBox={`0 0 ${size} ${size}`}\n xmlns=\"http://www.w3.org/2000/svg\"\n >\n <g\n style={{\n width: size,\n height: size,\n transformOrigin: `${circleCenter}px ${circleCenter}px`,\n }}\n >\n <circle\n vkuiClass=\"PullToRefresh__spinner-path\"\n fill=\"none\"\n strokeDasharray={dasharray}\n strokeDashoffset={dashoffset}\n strokeWidth={strokeWidth}\n strokeLinecap=\"round\"\n cx={circleCenter}\n cy={circleCenter}\n r={radius}\n />\n </g>\n </svg>\n </div>\n );\n};\n\n// eslint-disable-next-line import/no-default-export\nexport default React.memo(PullToRefreshSpinner);\n"],"file":"PullToRefreshSpinner.js"}
@@ -25,7 +25,7 @@ var _utils = require("../../lib/utils");
25
25
 
26
26
  var _Text = _interopRequireDefault(require("../Typography/Text/Text"));
27
27
 
28
- var _Subhead = _interopRequireDefault(require("../Typography/Subhead/Subhead"));
28
+ var _Subhead = require("../Typography/Subhead/Subhead");
29
29
 
30
30
  var _withAdaptivity = require("../../hoc/withAdaptivity");
31
31
 
@@ -44,6 +44,7 @@ var RichCell = function RichCell(_ref) {
44
44
  restProps = (0, _objectWithoutProperties2.default)(_ref, _excluded);
45
45
  var platform = (0, _usePlatform.usePlatform)();
46
46
  return (0, _jsxRuntime.createScopedElement)(_Tappable.default, (0, _extends2.default)({}, restProps, {
47
+ // eslint-disable-next-line vkui/no-object-expression-in-arguments
47
48
  vkuiClass: (0, _classNames.classNames)((0, _getClassName.getClassName)("RichCell", platform), {
48
49
  "RichCell--mult": multiline
49
50
  }, "RichCell--sizeY-".concat(sizeY))
@@ -59,7 +60,7 @@ var RichCell = function RichCell(_ref) {
59
60
  }, after)), (0, _utils.hasReactNode)(text) && (0, _jsxRuntime.createScopedElement)(_Text.default, {
60
61
  weight: "regular",
61
62
  vkuiClass: "RichCell__text"
62
- }, text), (0, _utils.hasReactNode)(caption) && (0, _jsxRuntime.createScopedElement)(_Subhead.default, {
63
+ }, text), (0, _utils.hasReactNode)(caption) && (0, _jsxRuntime.createScopedElement)(_Subhead.Subhead, {
63
64
  Component: "span",
64
65
  vkuiClass: "RichCell__caption"
65
66
  }, caption), ((0, _utils.hasReactNode)(bottom) || (0, _utils.hasReactNode)(actions)) && (0, _jsxRuntime.createScopedElement)("div", {
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/RichCell/RichCell.tsx"],"names":["RichCell","children","text","caption","before","after","bottom","actions","multiline","sizeY","restProps","platform"],"mappings":";;;;;;;;;;;;;;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;;;AAoCA,IAAMA,QAAiC,GAAG,SAApCA,QAAoC,OAWpC;AAAA,MAVJC,QAUI,QAVJA,QAUI;AAAA,MATJC,IASI,QATJA,IASI;AAAA,MARJC,OAQI,QARJA,OAQI;AAAA,MAPJC,MAOI,QAPJA,MAOI;AAAA,MANJC,KAMI,QANJA,KAMI;AAAA,MALJC,MAKI,QALJA,MAKI;AAAA,MAJJC,OAII,QAJJA,OAII;AAAA,MAHJC,SAGI,QAHJA,SAGI;AAAA,MAFJC,KAEI,QAFJA,KAEI;AAAA,MADDC,SACC;AACJ,MAAMC,QAAQ,GAAG,+BAAjB;AAEA,SACE,qCAAC,iBAAD,6BACMD,SADN;AAEE,IAAA,SAAS,EAAE,4BACT,gCAAa,UAAb,EAAyBC,QAAzB,CADS,EAET;AACE,wBAAkBH;AADpB,KAFS,4BAKUC,KALV;AAFb,MAUGL,MAVH,EAWE;AAAK,IAAA,SAAS,EAAC;AAAf,KAEGC,KAFH,EAGE,qCAAC,aAAD;AAAM,IAAA,MAAM,EAAC,QAAb;AAAsB,IAAA,SAAS,EAAC;AAAhC,KACE;AAAK,IAAA,SAAS,EAAC;AAAf,KAAqCJ,QAArC,CADF,EAEG,yBAAaI,KAAb,KACC;AAAK,IAAA,SAAS,EAAC;AAAf,KAAkCA,KAAlC,CAHJ,CAHF,EASG,yBAAaH,IAAb,KACC,qCAAC,aAAD;AAAM,IAAA,MAAM,EAAC,SAAb;AAAuB,IAAA,SAAS,EAAC;AAAjC,KACGA,IADH,CAVJ,EAcG,yBAAaC,OAAb,KACC,qCAAC,gBAAD;AAAS,IAAA,SAAS,EAAC,MAAnB;AAA0B,IAAA,SAAS,EAAC;AAApC,KACGA,OADH,CAfJ,EAmBG,CAAC,yBAAaG,MAAb,KAAwB,yBAAaC,OAAb,CAAzB,KACC;AAAK,IAAA,SAAS,EAAC;AAAf,KACGD,MADH,EAEG,yBAAaC,OAAb,KACC;AAAK,IAAA,SAAS,EAAC;AAAf,KAAoCA,OAApC,CAHJ,CApBJ,CAXF,CADF;AA0CD,CAxDD,C,CA0DA;;;eACe,oCAAeP,QAAf,EAAyB;AAAES,EAAAA,KAAK,EAAE;AAAT,CAAzB,C","sourcesContent":["import * as React from \"react\";\nimport { classNames } from \"../../lib/classNames\";\nimport { usePlatform } from \"../../hooks/usePlatform\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport Tappable, { TappableProps } from \"../Tappable/Tappable\";\nimport { hasReactNode } from \"../../lib/utils\";\nimport Text from \"../Typography/Text/Text\";\nimport Subhead from \"../Typography/Subhead/Subhead\";\nimport { withAdaptivity } from \"../../hoc/withAdaptivity\";\nimport \"./RichCell.css\";\n\nexport interface RichCellProps extends TappableProps {\n /**\n * Контейнер для текста под `children`.\n */\n text?: React.ReactNode;\n /**\n * Контейнер для текста под `text`.\n */\n caption?: React.ReactNode;\n /**\n * Контейнер для контента под `caption`. Например `<UsersStack size=\"s\" />`\n */\n bottom?: React.ReactNode;\n /**\n * Кнопка `<Button size=\"s\" />`. Располагается под `bottom`.\n * Для набора кнопок следует использовать обёртку `<ButtonGroup mode=\"horizontal\" gap=\"s\">...</ButtonGroup>`.\n */\n actions?: React.ReactNode;\n /**\n * `<Avatar size={48|72} />`\n */\n before?: React.ReactNode;\n /**\n * Иконка 28 или текст\n */\n after?: React.ReactNode;\n /**\n * Убирает анимацию нажатия\n */\n disabled?: boolean;\n multiline?: boolean;\n}\n\nconst RichCell: React.FC<RichCellProps> = ({\n children,\n text,\n caption,\n before,\n after,\n bottom,\n actions,\n multiline,\n sizeY,\n ...restProps\n}) => {\n const platform = usePlatform();\n\n return (\n <Tappable\n {...restProps}\n vkuiClass={classNames(\n getClassName(\"RichCell\", platform),\n {\n \"RichCell--mult\": multiline,\n },\n `RichCell--sizeY-${sizeY}`\n )}\n >\n {before}\n <div vkuiClass=\"RichCell__in\">\n {/* Этот after будет скрыт из верстки. Он нужен для CSS */}\n {after}\n <Text weight=\"medium\" vkuiClass=\"RichCell__content\">\n <div vkuiClass=\"RichCell__children\">{children}</div>\n {hasReactNode(after) && (\n <div vkuiClass=\"RichCell__after\">{after}</div>\n )}\n </Text>\n {hasReactNode(text) && (\n <Text weight=\"regular\" vkuiClass=\"RichCell__text\">\n {text}\n </Text>\n )}\n {hasReactNode(caption) && (\n <Subhead Component=\"span\" vkuiClass=\"RichCell__caption\">\n {caption}\n </Subhead>\n )}\n {(hasReactNode(bottom) || hasReactNode(actions)) && (\n <div vkuiClass=\"RichCell__bottom\">\n {bottom}\n {hasReactNode(actions) && (\n <div vkuiClass=\"RichCell__actions\">{actions}</div>\n )}\n </div>\n )}\n </div>\n </Tappable>\n );\n};\n\n// eslint-disable-next-line import/no-default-export\nexport default withAdaptivity(RichCell, { sizeY: true });\n"],"file":"RichCell.js"}
1
+ {"version":3,"sources":["../../../../src/components/RichCell/RichCell.tsx"],"names":["RichCell","children","text","caption","before","after","bottom","actions","multiline","sizeY","restProps","platform"],"mappings":";;;;;;;;;;;;;;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;;;AAoCA,IAAMA,QAAiC,GAAG,SAApCA,QAAoC,OAWpC;AAAA,MAVJC,QAUI,QAVJA,QAUI;AAAA,MATJC,IASI,QATJA,IASI;AAAA,MARJC,OAQI,QARJA,OAQI;AAAA,MAPJC,MAOI,QAPJA,MAOI;AAAA,MANJC,KAMI,QANJA,KAMI;AAAA,MALJC,MAKI,QALJA,MAKI;AAAA,MAJJC,OAII,QAJJA,OAII;AAAA,MAHJC,SAGI,QAHJA,SAGI;AAAA,MAFJC,KAEI,QAFJA,KAEI;AAAA,MADDC,SACC;AACJ,MAAMC,QAAQ,GAAG,+BAAjB;AAEA,SACE,qCAAC,iBAAD,6BACMD,SADN;AAEE;AACA,IAAA,SAAS,EAAE,4BACT,gCAAa,UAAb,EAAyBC,QAAzB,CADS,EAET;AACE,wBAAkBH;AADpB,KAFS,4BAKUC,KALV;AAHb,MAWGL,MAXH,EAYE;AAAK,IAAA,SAAS,EAAC;AAAf,KAEGC,KAFH,EAGE,qCAAC,aAAD;AAAM,IAAA,MAAM,EAAC,QAAb;AAAsB,IAAA,SAAS,EAAC;AAAhC,KACE;AAAK,IAAA,SAAS,EAAC;AAAf,KAAqCJ,QAArC,CADF,EAEG,yBAAaI,KAAb,KACC;AAAK,IAAA,SAAS,EAAC;AAAf,KAAkCA,KAAlC,CAHJ,CAHF,EASG,yBAAaH,IAAb,KACC,qCAAC,aAAD;AAAM,IAAA,MAAM,EAAC,SAAb;AAAuB,IAAA,SAAS,EAAC;AAAjC,KACGA,IADH,CAVJ,EAcG,yBAAaC,OAAb,KACC,qCAAC,gBAAD;AAAS,IAAA,SAAS,EAAC,MAAnB;AAA0B,IAAA,SAAS,EAAC;AAApC,KACGA,OADH,CAfJ,EAmBG,CAAC,yBAAaG,MAAb,KAAwB,yBAAaC,OAAb,CAAzB,KACC;AAAK,IAAA,SAAS,EAAC;AAAf,KACGD,MADH,EAEG,yBAAaC,OAAb,KACC;AAAK,IAAA,SAAS,EAAC;AAAf,KAAoCA,OAApC,CAHJ,CApBJ,CAZF,CADF;AA2CD,CAzDD,C,CA2DA;;;eACe,oCAAeP,QAAf,EAAyB;AAAES,EAAAA,KAAK,EAAE;AAAT,CAAzB,C","sourcesContent":["import * as React from \"react\";\nimport { classNames } from \"../../lib/classNames\";\nimport { usePlatform } from \"../../hooks/usePlatform\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport Tappable, { TappableProps } from \"../Tappable/Tappable\";\nimport { hasReactNode } from \"../../lib/utils\";\nimport Text from \"../Typography/Text/Text\";\nimport { Subhead } from \"../Typography/Subhead/Subhead\";\nimport { withAdaptivity } from \"../../hoc/withAdaptivity\";\nimport \"./RichCell.css\";\n\nexport interface RichCellProps extends TappableProps {\n /**\n * Контейнер для текста под `children`.\n */\n text?: React.ReactNode;\n /**\n * Контейнер для текста под `text`.\n */\n caption?: React.ReactNode;\n /**\n * Контейнер для контента под `caption`. Например `<UsersStack size=\"s\" />`\n */\n bottom?: React.ReactNode;\n /**\n * Кнопка `<Button size=\"s\" />`. Располагается под `bottom`.\n * Для набора кнопок следует использовать обёртку `<ButtonGroup mode=\"horizontal\" gap=\"s\">...</ButtonGroup>`.\n */\n actions?: React.ReactNode;\n /**\n * `<Avatar size={48|72} />`\n */\n before?: React.ReactNode;\n /**\n * Иконка 28 или текст\n */\n after?: React.ReactNode;\n /**\n * Убирает анимацию нажатия\n */\n disabled?: boolean;\n multiline?: boolean;\n}\n\nconst RichCell: React.FC<RichCellProps> = ({\n children,\n text,\n caption,\n before,\n after,\n bottom,\n actions,\n multiline,\n sizeY,\n ...restProps\n}) => {\n const platform = usePlatform();\n\n return (\n <Tappable\n {...restProps}\n // eslint-disable-next-line vkui/no-object-expression-in-arguments\n vkuiClass={classNames(\n getClassName(\"RichCell\", platform),\n {\n \"RichCell--mult\": multiline,\n },\n `RichCell--sizeY-${sizeY}`\n )}\n >\n {before}\n <div vkuiClass=\"RichCell__in\">\n {/* Этот after будет скрыт из верстки. Он нужен для CSS */}\n {after}\n <Text weight=\"medium\" vkuiClass=\"RichCell__content\">\n <div vkuiClass=\"RichCell__children\">{children}</div>\n {hasReactNode(after) && (\n <div vkuiClass=\"RichCell__after\">{after}</div>\n )}\n </Text>\n {hasReactNode(text) && (\n <Text weight=\"regular\" vkuiClass=\"RichCell__text\">\n {text}\n </Text>\n )}\n {hasReactNode(caption) && (\n <Subhead Component=\"span\" vkuiClass=\"RichCell__caption\">\n {caption}\n </Subhead>\n )}\n {(hasReactNode(bottom) || hasReactNode(actions)) && (\n <div vkuiClass=\"RichCell__bottom\">\n {bottom}\n {hasReactNode(actions) && (\n <div vkuiClass=\"RichCell__actions\">{actions}</div>\n )}\n </div>\n )}\n </div>\n </Tappable>\n );\n};\n\n// eslint-disable-next-line import/no-default-export\nexport default withAdaptivity(RichCell, { sizeY: true });\n"],"file":"RichCell.js"}
@@ -36,7 +36,8 @@ var RichTooltip = function RichTooltip(_ref) {
36
36
  popperProps = (0, _objectWithoutProperties2.default)(_ref, _excluded);
37
37
  var platform = (0, _usePlatform.usePlatform)();
38
38
  var appearance = (0, _useAppearance.useAppearance)();
39
- return (0, _jsxRuntime.createScopedElement)(_HoverPopper.HoverPopper, (0, _extends2.default)({
39
+ return (0, _jsxRuntime.createScopedElement)(_HoverPopper.HoverPopper // eslint-disable-next-line vkui/no-object-expression-in-arguments
40
+ , (0, _extends2.default)({
40
41
  vkuiClass: (0, _classNames2.classNames)((0, _getClassName.getClassName)("RichTooltip", platform), (0, _defineProperty2.default)({}, "RichTooltip--".concat(appearance), !!appearance)),
41
42
  arrow: arrow,
42
43
  arrowClassName: (0, _prefixClass.prefixClass)("RichTooltip__arrow")
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../src/components/RichTooltip/RichTooltip.tsx"],"names":["RichTooltip","children","arrow","popperProps","platform","appearance"],"mappings":";;;;;;;;;;;;;;;;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;;;AAKO,IAAMA,WAAuC,GAAG,SAA1CA,WAA0C,OAI/B;AAAA,MAHtBC,QAGsB,QAHtBA,QAGsB;AAAA,wBAFtBC,KAEsB;AAAA,MAFtBA,KAEsB,2BAFd,IAEc;AAAA,MADnBC,WACmB;AACtB,MAAMC,QAAQ,GAAG,+BAAjB;AACA,MAAMC,UAAU,GAAG,mCAAnB;AAEA,SACE,qCAAC,wBAAD;AACE,IAAA,SAAS,EAAE,6BAAW,gCAAa,aAAb,EAA4BD,QAA5B,CAAX,2DACQC,UADR,GACuB,CAAC,CAACA,UADzB,EADb;AAIE,IAAA,KAAK,EAAEH,KAJT;AAKE,IAAA,cAAc,EAAE,8BAAY,oBAAZ;AALlB,KAMMC,WANN,GAQGF,QARH,CADF;AAYD,CApBM","sourcesContent":["import * as React from \"react\";\nimport { HoverPopper, HoverPopperProps } from \"../HoverPopper/HoverPopper\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport { usePlatform } from \"../../hooks/usePlatform\";\nimport { useAppearance } from \"../../hooks/useAppearance\";\nimport { classNames } from \"../../lib/classNames\";\nimport { prefixClass } from \"../../lib/prefixClass\";\nimport \"./RichTooltip.css\";\n\nexport type RichTooltipProps = Omit<HoverPopperProps, \"arrowClassName\">;\n\nexport const RichTooltip: React.FC<RichTooltipProps> = ({\n children,\n arrow = true,\n ...popperProps\n}: RichTooltipProps) => {\n const platform = usePlatform();\n const appearance = useAppearance();\n\n return (\n <HoverPopper\n vkuiClass={classNames(getClassName(\"RichTooltip\", platform), {\n [`RichTooltip--${appearance}`]: !!appearance,\n })}\n arrow={arrow}\n arrowClassName={prefixClass(\"RichTooltip__arrow\")}\n {...popperProps}\n >\n {children}\n </HoverPopper>\n );\n};\n"],"file":"RichTooltip.js"}
1
+ {"version":3,"sources":["../../../../src/components/RichTooltip/RichTooltip.tsx"],"names":["RichTooltip","children","arrow","popperProps","platform","appearance"],"mappings":";;;;;;;;;;;;;;;;;AACA;;AACA;;AACA;;AACA;;AACA;;AACA;;;;AAKO,IAAMA,WAAuC,GAAG,SAA1CA,WAA0C,OAI/B;AAAA,MAHtBC,QAGsB,QAHtBA,QAGsB;AAAA,wBAFtBC,KAEsB;AAAA,MAFtBA,KAEsB,2BAFd,IAEc;AAAA,MADnBC,WACmB;AACtB,MAAMC,QAAQ,GAAG,+BAAjB;AACA,MAAMC,UAAU,GAAG,mCAAnB;AAEA,SACE,qCAAC,wBAAD,CACE;AADF;AAEE,IAAA,SAAS,EAAE,6BAAW,gCAAa,aAAb,EAA4BD,QAA5B,CAAX,2DACQC,UADR,GACuB,CAAC,CAACA,UADzB,EAFb;AAKE,IAAA,KAAK,EAAEH,KALT;AAME,IAAA,cAAc,EAAE,8BAAY,oBAAZ;AANlB,KAOMC,WAPN,GASGF,QATH,CADF;AAaD,CArBM","sourcesContent":["import * as React from \"react\";\nimport { HoverPopper, HoverPopperProps } from \"../HoverPopper/HoverPopper\";\nimport { getClassName } from \"../../helpers/getClassName\";\nimport { usePlatform } from \"../../hooks/usePlatform\";\nimport { useAppearance } from \"../../hooks/useAppearance\";\nimport { classNames } from \"../../lib/classNames\";\nimport { prefixClass } from \"../../lib/prefixClass\";\nimport \"./RichTooltip.css\";\n\nexport type RichTooltipProps = Omit<HoverPopperProps, \"arrowClassName\">;\n\nexport const RichTooltip: React.FC<RichTooltipProps> = ({\n children,\n arrow = true,\n ...popperProps\n}: RichTooltipProps) => {\n const platform = usePlatform();\n const appearance = useAppearance();\n\n return (\n <HoverPopper\n // eslint-disable-next-line vkui/no-object-expression-in-arguments\n vkuiClass={classNames(getClassName(\"RichTooltip\", platform), {\n [`RichTooltip--${appearance}`]: !!appearance,\n })}\n arrow={arrow}\n arrowClassName={prefixClass(\"RichTooltip__arrow\")}\n {...popperProps}\n >\n {children}\n </HoverPopper>\n );\n};\n"],"file":"RichTooltip.js"}
@@ -103,7 +103,7 @@ var Root = function Root(_ref) {
103
103
  _setState({
104
104
  activeView: panel,
105
105
  prevView: activeView,
106
- transition: true,
106
+ transition: !disableAnimation,
107
107
  isBack: _isBack
108
108
  });
109
109
  }
@@ -134,7 +134,7 @@ var Root = function Root(_ref) {
134
134
  to: activeView
135
135
  });
136
136
  }
137
- }, [transition]);
137
+ }, [transition, prevView]);
138
138
  var fallbackTransition = (0, _useTimeout.useTimeout)(finishTransition, platform === _platform.IOS ? 600 : 300);
139
139
  React.useEffect(function () {
140
140
  if (!transition) {
@@ -142,8 +142,8 @@ var Root = function Root(_ref) {
142
142
  return;
143
143
  }
144
144
 
145
- disableAnimation ? finishTransition() : fallbackTransition.set();
146
- }, [disableAnimation, fallbackTransition, finishTransition, transition]);
145
+ fallbackTransition.set();
146
+ }, [fallbackTransition, transition]);
147
147
 
148
148
  var onAnimationEnd = function onAnimationEnd(e) {
149
149
  if (["vkui-root-android-animation-hide-back", "vkui-root-android-animation-show-forward", "vkui-root-ios-animation-hide-back", "vkui-root-ios-animation-show-forward"].includes(e.animationName)) {
@@ -157,9 +157,9 @@ var Root = function Root(_ref) {
157
157
  }
158
158
 
159
159
  return (0, _jsxRuntime.createScopedElement)("div", (0, _extends2.default)({}, restProps, {
160
+ // eslint-disable-next-line vkui/no-object-expression-in-arguments
160
161
  vkuiClass: (0, _classNames.classNames)((0, _getClassName.getClassName)("Root", platform), {
161
- "Root--transition": !disableAnimation && transition,
162
- "Root--no-motion": disableAnimation
162
+ "Root--transition": transition
163
163
  })
164
164
  }), views.map(function (view) {
165
165
  var _scrolls$viewId;
@@ -177,7 +177,8 @@ var Root = function Root(_ref) {
177
177
  ref: function ref(e) {
178
178
  return viewId && (viewNodes[viewId] = e);
179
179
  },
180
- onAnimationEnd: isTransitionTarget ? onAnimationEnd : undefined,
180
+ onAnimationEnd: isTransitionTarget ? onAnimationEnd : undefined // eslint-disable-next-line vkui/no-object-expression-in-arguments
181
+ ,
181
182
  vkuiClass: (0, _classNames.classNames)("Root__view", {
182
183
  "Root__view--hide-back": transition && viewId === prevView && isBack,
183
184
  "Root__view--hide-forward": transition && viewId === prevView && !isBack,