@vkontakte/vkui 8.1.2 → 8.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (653) hide show
  1. package/dist/components/ActionSheet/ActionSheet.d.ts +5 -4
  2. package/dist/components/ActionSheet/ActionSheet.d.ts.map +1 -1
  3. package/dist/components/ActionSheet/ActionSheet.js +2 -1
  4. package/dist/components/ActionSheet/ActionSheet.js.map +1 -1
  5. package/dist/components/AdaptivityProvider/AdaptivityContext.d.ts +3 -3
  6. package/dist/components/AdaptivityProvider/AdaptivityContext.js.map +1 -1
  7. package/dist/components/AdaptivityProvider/AdaptivityProvider.js +2 -2
  8. package/dist/components/AdaptivityProvider/AdaptivityProvider.js.map +1 -1
  9. package/dist/components/AppRoot/AppRoot.d.ts.map +1 -1
  10. package/dist/components/AppRoot/AppRoot.js +0 -6
  11. package/dist/components/AppRoot/AppRoot.js.map +1 -1
  12. package/dist/components/AppRoot/AppRootContext.d.ts +0 -1
  13. package/dist/components/AppRoot/AppRootContext.d.ts.map +1 -1
  14. package/dist/components/AppRoot/AppRootContext.js +0 -1
  15. package/dist/components/AppRoot/AppRootContext.js.map +1 -1
  16. package/dist/components/Calendar/Calendar.d.ts +1 -1
  17. package/dist/components/Calendar/Calendar.js +2 -1
  18. package/dist/components/Calendar/Calendar.js.map +1 -1
  19. package/dist/components/CalendarDay/CalendarDay.d.ts.map +1 -1
  20. package/dist/components/CalendarDay/CalendarDay.js +4 -2
  21. package/dist/components/CalendarDay/CalendarDay.js.map +1 -1
  22. package/dist/components/CalendarDays/CalendarDays.d.ts.map +1 -1
  23. package/dist/components/CalendarDays/CalendarDays.js +2 -2
  24. package/dist/components/CalendarDays/CalendarDays.js.map +1 -1
  25. package/dist/components/CalendarHeader/CalendarHeader.d.ts.map +1 -1
  26. package/dist/components/CalendarHeader/CalendarHeader.js +4 -2
  27. package/dist/components/CalendarHeader/CalendarHeader.js.map +1 -1
  28. package/dist/components/CalendarRange/CalendarRange.d.ts +2 -2
  29. package/dist/components/CalendarRange/CalendarRange.js.map +1 -1
  30. package/dist/components/CalendarTime/CalendarTime.d.ts +1 -1
  31. package/dist/components/CalendarTime/CalendarTime.d.ts.map +1 -1
  32. package/dist/components/CalendarTime/CalendarTime.js +61 -50
  33. package/dist/components/CalendarTime/CalendarTime.js.map +1 -1
  34. package/dist/components/CalendarTime/CalendarTimePicker.d.ts +11 -7
  35. package/dist/components/CalendarTime/CalendarTimePicker.d.ts.map +1 -1
  36. package/dist/components/CalendarTime/CalendarTimePicker.js +108 -48
  37. package/dist/components/CalendarTime/CalendarTimePicker.js.map +1 -1
  38. package/dist/components/CalendarTime/ComboBox.d.ts +25 -0
  39. package/dist/components/CalendarTime/ComboBox.d.ts.map +1 -0
  40. package/dist/components/CalendarTime/ComboBox.js +112 -0
  41. package/dist/components/CalendarTime/ComboBox.js.map +1 -0
  42. package/dist/components/CardScroll/CardScroll.d.ts.map +1 -1
  43. package/dist/components/CardScroll/CardScroll.js +2 -2
  44. package/dist/components/CardScroll/CardScroll.js.map +1 -1
  45. package/dist/components/CarouselBase/CarouselBase.d.ts.map +1 -1
  46. package/dist/components/CarouselBase/CarouselBase.js +3 -1
  47. package/dist/components/CarouselBase/CarouselBase.js.map +1 -1
  48. package/dist/components/ChipsSelect/useChipsSelect.d.ts.map +1 -1
  49. package/dist/components/ChipsSelect/useChipsSelect.js +2 -1
  50. package/dist/components/ChipsSelect/useChipsSelect.js.map +1 -1
  51. package/dist/components/ConfigProvider/ConfigProvider.d.ts.map +1 -1
  52. package/dist/components/ConfigProvider/ConfigProvider.js +8 -4
  53. package/dist/components/ConfigProvider/ConfigProvider.js.map +1 -1
  54. package/dist/components/ConfigProvider/ConfigProviderOverride.d.ts.map +1 -1
  55. package/dist/components/ConfigProvider/ConfigProviderOverride.js +5 -1
  56. package/dist/components/ConfigProvider/ConfigProviderOverride.js.map +1 -1
  57. package/dist/components/ConfigProvider/ConfigProviderSubContexts.d.ts +15 -0
  58. package/dist/components/ConfigProvider/ConfigProviderSubContexts.d.ts.map +1 -0
  59. package/dist/components/ConfigProvider/ConfigProviderSubContexts.js +25 -0
  60. package/dist/components/ConfigProvider/ConfigProviderSubContexts.js.map +1 -0
  61. package/dist/components/ContentBadge/ContentBadge.d.ts +14 -1
  62. package/dist/components/ContentBadge/ContentBadge.d.ts.map +1 -1
  63. package/dist/components/ContentBadge/ContentBadge.js +39 -1
  64. package/dist/components/ContentBadge/ContentBadge.js.map +1 -1
  65. package/dist/components/CustomSelect/CustomSelect.d.ts.map +1 -1
  66. package/dist/components/CustomSelect/CustomSelect.js +16 -10
  67. package/dist/components/CustomSelect/CustomSelect.js.map +1 -1
  68. package/dist/components/DateInput/DateInput.d.ts.map +1 -1
  69. package/dist/components/DateInput/DateInput.js +4 -3
  70. package/dist/components/DateInput/DateInput.js.map +1 -1
  71. package/dist/components/DateRangeInput/DateRangeInput.d.ts.map +1 -1
  72. package/dist/components/DateRangeInput/DateRangeInput.js +2 -2
  73. package/dist/components/DateRangeInput/DateRangeInput.js.map +1 -1
  74. package/dist/components/Epic/ScrollSaver.d.ts.map +1 -1
  75. package/dist/components/Epic/ScrollSaver.js +1 -0
  76. package/dist/components/Epic/ScrollSaver.js.map +1 -1
  77. package/dist/components/FixedLayout/ParentWidthWrapper.d.ts +6 -0
  78. package/dist/components/FixedLayout/ParentWidthWrapper.d.ts.map +1 -0
  79. package/dist/components/FixedLayout/ParentWidthWrapper.js +43 -0
  80. package/dist/components/FixedLayout/ParentWidthWrapper.js.map +1 -0
  81. package/dist/components/Flex/Flex.d.ts +7 -4
  82. package/dist/components/Flex/Flex.d.ts.map +1 -1
  83. package/dist/components/Flex/Flex.js +5 -2
  84. package/dist/components/Flex/Flex.js.map +1 -1
  85. package/dist/components/ImageBase/ImageBaseFloatElement/ImageBaseFloatElement.js +3 -1
  86. package/dist/components/ImageBase/ImageBaseFloatElement/ImageBaseFloatElement.js.map +1 -1
  87. package/dist/components/NativeSelect/NativeSelect.d.ts.map +1 -1
  88. package/dist/components/NativeSelect/NativeSelect.js +6 -2
  89. package/dist/components/NativeSelect/NativeSelect.js.map +1 -1
  90. package/dist/components/NavTransitionContext/NavTransitionContext.d.ts +2 -1
  91. package/dist/components/NavTransitionContext/NavTransitionContext.d.ts.map +1 -1
  92. package/dist/components/NavTransitionContext/NavTransitionContext.js +8 -4
  93. package/dist/components/NavTransitionContext/NavTransitionContext.js.map +1 -1
  94. package/dist/components/OnboardingTooltip/OnboardingTooltip.d.ts.map +1 -1
  95. package/dist/components/OnboardingTooltip/OnboardingTooltip.js +4 -5
  96. package/dist/components/OnboardingTooltip/OnboardingTooltip.js.map +1 -1
  97. package/dist/components/PanelHeader/PanelHeader.d.ts +1 -1
  98. package/dist/components/PanelHeader/PanelHeader.js.map +1 -1
  99. package/dist/components/Popper/Popper.d.ts.map +1 -1
  100. package/dist/components/Popper/Popper.js +7 -4
  101. package/dist/components/Popper/Popper.js.map +1 -1
  102. package/dist/components/PullToRefresh/PullToRefresh.d.ts.map +1 -1
  103. package/dist/components/PullToRefresh/PullToRefresh.js +8 -4
  104. package/dist/components/PullToRefresh/PullToRefresh.js.map +1 -1
  105. package/dist/components/Root/Root.d.ts +1 -1
  106. package/dist/components/Root/Root.d.ts.map +1 -1
  107. package/dist/components/Root/Root.js +43 -37
  108. package/dist/components/Root/Root.js.map +1 -1
  109. package/dist/components/SimpleGrid/SimpleGrid.d.ts +9 -8
  110. package/dist/components/SimpleGrid/SimpleGrid.d.ts.map +1 -1
  111. package/dist/components/SimpleGrid/SimpleGrid.js +9 -2
  112. package/dist/components/SimpleGrid/SimpleGrid.js.map +1 -1
  113. package/dist/components/Skeleton/Skeleton.d.ts.map +1 -1
  114. package/dist/components/Skeleton/Skeleton.js +3 -4
  115. package/dist/components/Skeleton/Skeleton.js.map +1 -1
  116. package/dist/components/Snackbar/Snackbar.d.ts.map +1 -1
  117. package/dist/components/Snackbar/Snackbar.js +6 -3
  118. package/dist/components/Snackbar/Snackbar.js.map +1 -1
  119. package/dist/components/Spacing/Spacing.d.ts +1 -1
  120. package/dist/components/Spacing/Spacing.js.map +1 -1
  121. package/dist/components/Spinner/ExpressiveSpinner/ExpressiveSpinner.d.ts +10 -0
  122. package/dist/components/Spinner/ExpressiveSpinner/ExpressiveSpinner.d.ts.map +1 -0
  123. package/dist/components/Spinner/ExpressiveSpinner/ExpressiveSpinner.js +54 -0
  124. package/dist/components/Spinner/ExpressiveSpinner/ExpressiveSpinner.js.map +1 -0
  125. package/dist/components/Spinner/ExpressiveSpinner/icons.d.ts +18 -0
  126. package/dist/components/Spinner/ExpressiveSpinner/icons.d.ts.map +1 -0
  127. package/dist/components/Spinner/ExpressiveSpinner/icons.js +79 -0
  128. package/dist/components/Spinner/ExpressiveSpinner/icons.js.map +1 -0
  129. package/dist/components/Spinner/SvgIcon.d.ts +14 -0
  130. package/dist/components/Spinner/SvgIcon.d.ts.map +1 -0
  131. package/dist/components/Spinner/SvgIcon.js +20 -0
  132. package/dist/components/Spinner/SvgIcon.js.map +1 -0
  133. package/dist/components/Spinner/icons.d.ts +1 -1
  134. package/dist/components/Spinner/icons.d.ts.map +1 -1
  135. package/dist/components/Spinner/icons.js +10 -23
  136. package/dist/components/Spinner/icons.js.map +1 -1
  137. package/dist/components/SplitLayout/SplitLayout.d.ts +3 -3
  138. package/dist/components/SplitLayout/SplitLayout.js.map +1 -1
  139. package/dist/components/TabsItem/TabsItem.d.ts.map +1 -1
  140. package/dist/components/TabsItem/TabsItem.js +2 -5
  141. package/dist/components/TabsItem/TabsItem.js.map +1 -1
  142. package/dist/components/Tappable/Tappable.d.ts +2 -2
  143. package/dist/components/Tappable/Tappable.js.map +1 -1
  144. package/dist/components/View/View.d.ts.map +1 -1
  145. package/dist/components/View/View.js +50 -53
  146. package/dist/components/View/View.js.map +1 -1
  147. package/dist/components/View/ViewInfinite.d.ts.map +1 -1
  148. package/dist/components/View/ViewInfinite.js +34 -37
  149. package/dist/components/View/ViewInfinite.js.map +1 -1
  150. package/dist/components/WriteBar/WriteBar.d.ts +15 -1
  151. package/dist/components/WriteBar/WriteBar.d.ts.map +1 -1
  152. package/dist/components/WriteBar/WriteBar.js +35 -63
  153. package/dist/components/WriteBar/WriteBar.js.map +1 -1
  154. package/dist/components/WriteBar/WriteBarBeforeOrAfter/WriteBarBeforeOrAfter.d.ts +5 -0
  155. package/dist/components/WriteBar/WriteBarBeforeOrAfter/WriteBarBeforeOrAfter.d.ts.map +1 -0
  156. package/dist/components/WriteBar/WriteBarBeforeOrAfter/WriteBarBeforeOrAfter.js +15 -0
  157. package/dist/components/WriteBar/WriteBarBeforeOrAfter/WriteBarBeforeOrAfter.js.map +1 -0
  158. package/dist/components/WriteBar/WriteBarFormField/WriteBarFormField.d.ts +8 -0
  159. package/dist/components/WriteBar/WriteBarFormField/WriteBarFormField.d.ts.map +1 -0
  160. package/dist/components/WriteBar/WriteBarFormField/WriteBarFormField.js +16 -0
  161. package/dist/components/WriteBar/WriteBarFormField/WriteBarFormField.js.map +1 -0
  162. package/dist/components/WriteBar/WriteBarFormField/WriteBarFormFieldInlineAfter/WriteBarFormFieldInlineAfter.d.ts +5 -0
  163. package/dist/components/WriteBar/WriteBarFormField/WriteBarFormFieldInlineAfter/WriteBarFormFieldInlineAfter.d.ts.map +1 -0
  164. package/dist/components/WriteBar/WriteBarFormField/WriteBarFormFieldInlineAfter/WriteBarFormFieldInlineAfter.js +15 -0
  165. package/dist/components/WriteBar/WriteBarFormField/WriteBarFormFieldInlineAfter/WriteBarFormFieldInlineAfter.js.map +1 -0
  166. package/dist/components/WriteBar/WriteBarRoot/WriteBarRoot.d.ts +10 -0
  167. package/dist/components/WriteBar/WriteBarRoot/WriteBarRoot.d.ts.map +1 -0
  168. package/dist/components/WriteBar/WriteBarRoot/WriteBarRoot.js +16 -0
  169. package/dist/components/WriteBar/WriteBarRoot/WriteBarRoot.js.map +1 -0
  170. package/dist/components/WriteBar/WriteBarTextarea/WriteBarTextarea.d.ts +10 -0
  171. package/dist/components/WriteBar/WriteBarTextarea/WriteBarTextarea.d.ts.map +1 -0
  172. package/dist/components/WriteBar/WriteBarTextarea/WriteBarTextarea.js +39 -0
  173. package/dist/components/WriteBar/WriteBarTextarea/WriteBarTextarea.js.map +1 -0
  174. package/dist/components.css +1 -1
  175. package/dist/components.css.map +1 -1
  176. package/dist/cssm/components/ActionSheet/ActionSheet.js +2 -1
  177. package/dist/cssm/components/ActionSheet/ActionSheet.js.map +1 -1
  178. package/dist/cssm/components/AdaptivityProvider/AdaptivityContext.js.map +1 -1
  179. package/dist/cssm/components/AdaptivityProvider/AdaptivityProvider.js +2 -2
  180. package/dist/cssm/components/AdaptivityProvider/AdaptivityProvider.js.map +1 -1
  181. package/dist/cssm/components/AppRoot/AppRoot.js +0 -6
  182. package/dist/cssm/components/AppRoot/AppRoot.js.map +1 -1
  183. package/dist/cssm/components/AppRoot/AppRootContext.js +0 -1
  184. package/dist/cssm/components/AppRoot/AppRootContext.js.map +1 -1
  185. package/dist/cssm/components/Calendar/Calendar.js +2 -1
  186. package/dist/cssm/components/Calendar/Calendar.js.map +1 -1
  187. package/dist/cssm/components/CalendarDay/CalendarDay.js +4 -2
  188. package/dist/cssm/components/CalendarDay/CalendarDay.js.map +1 -1
  189. package/dist/cssm/components/CalendarDays/CalendarDays.js +2 -2
  190. package/dist/cssm/components/CalendarDays/CalendarDays.js.map +1 -1
  191. package/dist/cssm/components/CalendarHeader/CalendarHeader.js +4 -2
  192. package/dist/cssm/components/CalendarHeader/CalendarHeader.js.map +1 -1
  193. package/dist/cssm/components/CalendarRange/CalendarRange.js.map +1 -1
  194. package/dist/cssm/components/CalendarTime/CalendarTime.js +61 -50
  195. package/dist/cssm/components/CalendarTime/CalendarTime.js.map +1 -1
  196. package/dist/cssm/components/CalendarTime/CalendarTime.module.css +38 -0
  197. package/dist/cssm/components/CalendarTime/CalendarTimePicker.js +108 -48
  198. package/dist/cssm/components/CalendarTime/CalendarTimePicker.js.map +1 -1
  199. package/dist/cssm/components/CalendarTime/ComboBox.js +113 -0
  200. package/dist/cssm/components/CalendarTime/ComboBox.js.map +1 -0
  201. package/dist/cssm/components/CardScroll/CardScroll.js +2 -2
  202. package/dist/cssm/components/CardScroll/CardScroll.js.map +1 -1
  203. package/dist/cssm/components/CarouselBase/CarouselBase.js +3 -1
  204. package/dist/cssm/components/CarouselBase/CarouselBase.js.map +1 -1
  205. package/dist/cssm/components/ChipsSelect/useChipsSelect.js +2 -1
  206. package/dist/cssm/components/ChipsSelect/useChipsSelect.js.map +1 -1
  207. package/dist/cssm/components/ConfigProvider/ConfigProvider.js +8 -4
  208. package/dist/cssm/components/ConfigProvider/ConfigProvider.js.map +1 -1
  209. package/dist/cssm/components/ConfigProvider/ConfigProviderOverride.js +5 -1
  210. package/dist/cssm/components/ConfigProvider/ConfigProviderOverride.js.map +1 -1
  211. package/dist/cssm/components/ConfigProvider/ConfigProviderSubContexts.js +25 -0
  212. package/dist/cssm/components/ConfigProvider/ConfigProviderSubContexts.js.map +1 -0
  213. package/dist/cssm/components/ContentBadge/ContentBadge.js +39 -1
  214. package/dist/cssm/components/ContentBadge/ContentBadge.js.map +1 -1
  215. package/dist/cssm/components/ContentBadge/ContentBadge.module.css +88 -90
  216. package/dist/cssm/components/CustomSelect/CustomSelect.js +16 -10
  217. package/dist/cssm/components/CustomSelect/CustomSelect.js.map +1 -1
  218. package/dist/cssm/components/DateInput/DateInput.js +4 -3
  219. package/dist/cssm/components/DateInput/DateInput.js.map +1 -1
  220. package/dist/cssm/components/DateRangeInput/DateRangeInput.js +2 -2
  221. package/dist/cssm/components/DateRangeInput/DateRangeInput.js.map +1 -1
  222. package/dist/cssm/components/Epic/ScrollSaver.js +1 -0
  223. package/dist/cssm/components/Epic/ScrollSaver.js.map +1 -1
  224. package/dist/cssm/components/FixedLayout/ParentWidthWrapper.js +43 -0
  225. package/dist/cssm/components/FixedLayout/ParentWidthWrapper.js.map +1 -0
  226. package/dist/cssm/components/Flex/Flex.js +5 -2
  227. package/dist/cssm/components/Flex/Flex.js.map +1 -1
  228. package/dist/cssm/components/GridAvatar/GridAvatar.module.css +1 -1
  229. package/dist/cssm/components/ImageBase/ImageBaseFloatElement/ImageBaseFloatElement.js +3 -1
  230. package/dist/cssm/components/ImageBase/ImageBaseFloatElement/ImageBaseFloatElement.js.map +1 -1
  231. package/dist/cssm/components/NativeSelect/NativeSelect.js +6 -2
  232. package/dist/cssm/components/NativeSelect/NativeSelect.js.map +1 -1
  233. package/dist/cssm/components/NavTransitionContext/NavTransitionContext.js +8 -4
  234. package/dist/cssm/components/NavTransitionContext/NavTransitionContext.js.map +1 -1
  235. package/dist/cssm/components/OnboardingTooltip/OnboardingTooltip.js +4 -5
  236. package/dist/cssm/components/OnboardingTooltip/OnboardingTooltip.js.map +1 -1
  237. package/dist/cssm/components/PanelHeader/PanelHeader.js.map +1 -1
  238. package/dist/cssm/components/Popper/Popper.js +7 -4
  239. package/dist/cssm/components/Popper/Popper.js.map +1 -1
  240. package/dist/cssm/components/PullToRefresh/PullToRefresh.js +8 -4
  241. package/dist/cssm/components/PullToRefresh/PullToRefresh.js.map +1 -1
  242. package/dist/cssm/components/PullToRefresh/PullToRefresh.module.css +1 -1
  243. package/dist/cssm/components/Root/Root.js +43 -37
  244. package/dist/cssm/components/Root/Root.js.map +1 -1
  245. package/dist/cssm/components/SimpleGrid/SimpleGrid.js +9 -2
  246. package/dist/cssm/components/SimpleGrid/SimpleGrid.js.map +1 -1
  247. package/dist/cssm/components/Skeleton/Skeleton.js +3 -4
  248. package/dist/cssm/components/Skeleton/Skeleton.js.map +1 -1
  249. package/dist/cssm/components/Snackbar/Snackbar.js +6 -3
  250. package/dist/cssm/components/Snackbar/Snackbar.js.map +1 -1
  251. package/dist/cssm/components/Spacing/Spacing.js.map +1 -1
  252. package/dist/cssm/components/Spinner/ExpressiveSpinner/ExpressiveSpinner.js +56 -0
  253. package/dist/cssm/components/Spinner/ExpressiveSpinner/ExpressiveSpinner.js.map +1 -0
  254. package/dist/cssm/components/Spinner/ExpressiveSpinner/ExpressiveSpinner.module.css +13 -0
  255. package/dist/cssm/components/Spinner/ExpressiveSpinner/icons.js +79 -0
  256. package/dist/cssm/components/Spinner/ExpressiveSpinner/icons.js.map +1 -0
  257. package/dist/cssm/components/Spinner/SvgIcon.js +20 -0
  258. package/dist/cssm/components/Spinner/SvgIcon.js.map +1 -0
  259. package/dist/cssm/components/Spinner/icons.js +10 -23
  260. package/dist/cssm/components/Spinner/icons.js.map +1 -1
  261. package/dist/cssm/components/SplitLayout/SplitLayout.js.map +1 -1
  262. package/dist/cssm/components/TabsItem/TabsItem.js +2 -5
  263. package/dist/cssm/components/TabsItem/TabsItem.js.map +1 -1
  264. package/dist/cssm/components/Tappable/Tappable.js.map +1 -1
  265. package/dist/cssm/components/View/View.js +50 -53
  266. package/dist/cssm/components/View/View.js.map +1 -1
  267. package/dist/cssm/components/View/ViewInfinite.js +34 -37
  268. package/dist/cssm/components/View/ViewInfinite.js.map +1 -1
  269. package/dist/cssm/components/WriteBar/WriteBar.js +35 -64
  270. package/dist/cssm/components/WriteBar/WriteBar.js.map +1 -1
  271. package/dist/cssm/components/WriteBar/WriteBarBeforeOrAfter/WriteBarBeforeOrAfter.js +16 -0
  272. package/dist/cssm/components/WriteBar/WriteBarBeforeOrAfter/WriteBarBeforeOrAfter.js.map +1 -0
  273. package/dist/cssm/components/WriteBar/WriteBarBeforeOrAfter/WriteBarBeforeOrAfter.module.css +12 -0
  274. package/dist/cssm/components/WriteBar/WriteBarFormField/WriteBarFormField.js +17 -0
  275. package/dist/cssm/components/WriteBar/WriteBarFormField/WriteBarFormField.js.map +1 -0
  276. package/dist/cssm/components/WriteBar/WriteBarFormField/WriteBarFormField.module.css +18 -0
  277. package/dist/cssm/components/WriteBar/WriteBarFormField/WriteBarFormFieldInlineAfter/WriteBarFormFieldInlineAfter.js +16 -0
  278. package/dist/cssm/components/WriteBar/WriteBarFormField/WriteBarFormFieldInlineAfter/WriteBarFormFieldInlineAfter.js.map +1 -0
  279. package/dist/cssm/components/WriteBar/WriteBarFormField/WriteBarFormFieldInlineAfter/WriteBarFormFieldInlineAfter.module.css +3 -0
  280. package/dist/cssm/components/WriteBar/WriteBarRoot/WriteBarRoot.js +17 -0
  281. package/dist/cssm/components/WriteBar/WriteBarRoot/WriteBarRoot.js.map +1 -0
  282. package/dist/cssm/components/WriteBar/WriteBarRoot/WriteBarRoot.module.css +15 -0
  283. package/dist/cssm/components/WriteBar/WriteBarTextarea/WriteBarTextarea.js +40 -0
  284. package/dist/cssm/components/WriteBar/WriteBarTextarea/WriteBarTextarea.js.map +1 -0
  285. package/dist/cssm/components/WriteBar/WriteBarTextarea/WriteBarTextarea.module.css +43 -0
  286. package/dist/cssm/helpers/math.js +6 -0
  287. package/dist/cssm/helpers/math.js.map +1 -1
  288. package/dist/cssm/hoc/withPlatform.js +3 -2
  289. package/dist/cssm/hoc/withPlatform.js.map +1 -1
  290. package/dist/cssm/hooks/useAdaptivityConditionalRender/types.js.map +1 -1
  291. package/dist/cssm/hooks/useAnimationFrame.js +40 -0
  292. package/dist/cssm/hooks/useAnimationFrame.js.map +1 -0
  293. package/dist/cssm/hooks/useAutoFocus.js +4 -1
  294. package/dist/cssm/hooks/useAutoFocus.js.map +1 -1
  295. package/dist/cssm/hooks/useColorScheme.js +3 -3
  296. package/dist/cssm/hooks/useColorScheme.js.map +1 -1
  297. package/dist/cssm/hooks/useConfigDirection.js +3 -3
  298. package/dist/cssm/hooks/useConfigDirection.js.map +1 -1
  299. package/dist/cssm/hooks/useDateInput.js +1 -2
  300. package/dist/cssm/hooks/useDateInput.js.map +1 -1
  301. package/dist/cssm/hooks/useFocusTrap/useAutoFocus.js +1 -0
  302. package/dist/cssm/hooks/useFocusTrap/useAutoFocus.js.map +1 -1
  303. package/dist/cssm/hooks/useFocusTrap/useFocusTrap.js +2 -0
  304. package/dist/cssm/hooks/useFocusTrap/useFocusTrap.js.map +1 -1
  305. package/dist/cssm/hooks/useFocusVisible.js +8 -13
  306. package/dist/cssm/hooks/useFocusVisible.js.map +1 -1
  307. package/dist/cssm/hooks/useFocusWithin.js +5 -4
  308. package/dist/cssm/hooks/useFocusWithin.js.map +1 -1
  309. package/dist/cssm/hooks/useGlobalEscKeyDown.js +17 -15
  310. package/dist/cssm/hooks/useGlobalEscKeyDown.js.map +1 -1
  311. package/dist/cssm/hooks/useGlobalOnClickOutside.js +6 -2
  312. package/dist/cssm/hooks/useGlobalOnClickOutside.js.map +1 -1
  313. package/dist/cssm/hooks/useKeyboardInputTracker.js +48 -41
  314. package/dist/cssm/hooks/useKeyboardInputTracker.js.map +1 -1
  315. package/dist/cssm/hooks/useLatestRef.js +13 -0
  316. package/dist/cssm/hooks/useLatestRef.js.map +1 -0
  317. package/dist/cssm/hooks/useLocale.js +3 -3
  318. package/dist/cssm/hooks/useLocale.js.map +1 -1
  319. package/dist/cssm/hooks/useMediaQueryMatch.js +1 -0
  320. package/dist/cssm/hooks/useMediaQueryMatch.js.map +1 -1
  321. package/dist/cssm/hooks/useMutationObserver.js +3 -3
  322. package/dist/cssm/hooks/useMutationObserver.js.map +1 -1
  323. package/dist/cssm/hooks/usePlatform.js +3 -3
  324. package/dist/cssm/hooks/usePlatform.js.map +1 -1
  325. package/dist/cssm/hooks/useResizeObserver.js +4 -6
  326. package/dist/cssm/hooks/useResizeObserver.js.map +1 -1
  327. package/dist/cssm/hooks/useSyncHTMLWithBaseVKUIClasses.js +2 -1
  328. package/dist/cssm/hooks/useSyncHTMLWithBaseVKUIClasses.js.map +1 -1
  329. package/dist/cssm/hooks/useSyncHTMLWithTokens.js +3 -1
  330. package/dist/cssm/hooks/useSyncHTMLWithTokens.js.map +1 -1
  331. package/dist/cssm/hooks/useWaitTransitionFinish.js +13 -15
  332. package/dist/cssm/hooks/useWaitTransitionFinish.js.map +1 -1
  333. package/dist/cssm/index.js +1 -0
  334. package/dist/cssm/index.js.map +1 -1
  335. package/dist/cssm/lib/array.js +18 -0
  336. package/dist/cssm/lib/array.js.map +1 -0
  337. package/dist/cssm/lib/curve.js +21 -0
  338. package/dist/cssm/lib/curve.js.map +1 -0
  339. package/dist/cssm/lib/dom.js +5 -2
  340. package/dist/cssm/lib/dom.js.map +1 -1
  341. package/dist/cssm/lib/floating/useFloatingWithInteractions/useFloatingWithInteractions.js +4 -4
  342. package/dist/cssm/lib/floating/useFloatingWithInteractions/useFloatingWithInteractions.js.map +1 -1
  343. package/dist/cssm/lib/fx.js +4 -55
  344. package/dist/cssm/lib/fx.js.map +1 -1
  345. package/dist/cssm/lib/layouts/index.js.map +1 -1
  346. package/dist/cssm/lib/layouts/layoutProps.js +11 -0
  347. package/dist/cssm/lib/layouts/layoutProps.js.map +1 -1
  348. package/dist/cssm/lib/layouts/resolveLayoutProps.js +13 -11
  349. package/dist/cssm/lib/layouts/resolveLayoutProps.js.map +1 -1
  350. package/dist/cssm/lib/layouts/types.js.map +1 -1
  351. package/dist/cssm/lib/material/shapes/Shape.js +18 -0
  352. package/dist/cssm/lib/material/shapes/Shape.js.map +1 -0
  353. package/dist/cssm/lib/material/shapes/shapes.js +2250 -0
  354. package/dist/cssm/lib/material/shapes/shapes.js.map +1 -0
  355. package/dist/cssm/lib/math.js +31 -0
  356. package/dist/cssm/lib/math.js.map +1 -0
  357. package/dist/cssm/lib/svg/path/approximate.js +57 -0
  358. package/dist/cssm/lib/svg/path/approximate.js.map +1 -0
  359. package/dist/cssm/lib/svg/path/interpolate.js +121 -0
  360. package/dist/cssm/lib/svg/path/interpolate.js.map +1 -0
  361. package/dist/cssm/lib/svg/path/path.js +50 -0
  362. package/dist/cssm/lib/svg/path/path.js.map +1 -0
  363. package/dist/cssm/lib/svg/path/point.js +3 -0
  364. package/dist/cssm/lib/svg/path/point.js.map +1 -0
  365. package/dist/cssm/lib/svg/path/transform.js +110 -0
  366. package/dist/cssm/lib/svg/path/transform.js.map +1 -0
  367. package/dist/cssm/lib/tokens/useTokenClassName.js +4 -1
  368. package/dist/cssm/lib/tokens/useTokenClassName.js.map +1 -1
  369. package/dist/cssm/lib/touch/UIPanGestureRecognizer.js +2 -2
  370. package/dist/cssm/lib/touch/UIPanGestureRecognizer.js.map +1 -1
  371. package/dist/cssm/styles/layout.css +273 -0
  372. package/dist/cssm/types.js +1 -4
  373. package/dist/cssm/types.js.map +1 -1
  374. package/dist/helpers/math.d.ts +4 -0
  375. package/dist/helpers/math.d.ts.map +1 -1
  376. package/dist/helpers/math.js +6 -0
  377. package/dist/helpers/math.js.map +1 -1
  378. package/dist/hoc/withPlatform.d.ts +1 -1
  379. package/dist/hoc/withPlatform.d.ts.map +1 -1
  380. package/dist/hoc/withPlatform.js +3 -2
  381. package/dist/hoc/withPlatform.js.map +1 -1
  382. package/dist/hooks/useAdaptivityConditionalRender/types.d.ts +2 -2
  383. package/dist/hooks/useAdaptivityConditionalRender/types.js.map +1 -1
  384. package/dist/hooks/useAnimationFrame.d.ts +16 -0
  385. package/dist/hooks/useAnimationFrame.d.ts.map +1 -0
  386. package/dist/hooks/useAnimationFrame.js +40 -0
  387. package/dist/hooks/useAnimationFrame.js.map +1 -0
  388. package/dist/hooks/useAutoFocus.js +4 -1
  389. package/dist/hooks/useAutoFocus.js.map +1 -1
  390. package/dist/hooks/useColorScheme.d.ts.map +1 -1
  391. package/dist/hooks/useColorScheme.js +3 -3
  392. package/dist/hooks/useColorScheme.js.map +1 -1
  393. package/dist/hooks/useConfigDirection.d.ts.map +1 -1
  394. package/dist/hooks/useConfigDirection.js +3 -3
  395. package/dist/hooks/useConfigDirection.js.map +1 -1
  396. package/dist/hooks/useDateInput.d.ts.map +1 -1
  397. package/dist/hooks/useDateInput.js +1 -2
  398. package/dist/hooks/useDateInput.js.map +1 -1
  399. package/dist/hooks/useFocusTrap/useAutoFocus.js +1 -0
  400. package/dist/hooks/useFocusTrap/useAutoFocus.js.map +1 -1
  401. package/dist/hooks/useFocusTrap/useFocusTrap.d.ts.map +1 -1
  402. package/dist/hooks/useFocusTrap/useFocusTrap.js +2 -0
  403. package/dist/hooks/useFocusTrap/useFocusTrap.js.map +1 -1
  404. package/dist/hooks/useFocusVisible.d.ts.map +1 -1
  405. package/dist/hooks/useFocusVisible.js +8 -13
  406. package/dist/hooks/useFocusVisible.js.map +1 -1
  407. package/dist/hooks/useFocusWithin.d.ts.map +1 -1
  408. package/dist/hooks/useFocusWithin.js +5 -4
  409. package/dist/hooks/useFocusWithin.js.map +1 -1
  410. package/dist/hooks/useGlobalEscKeyDown.d.ts.map +1 -1
  411. package/dist/hooks/useGlobalEscKeyDown.js +17 -15
  412. package/dist/hooks/useGlobalEscKeyDown.js.map +1 -1
  413. package/dist/hooks/useGlobalOnClickOutside.d.ts.map +1 -1
  414. package/dist/hooks/useGlobalOnClickOutside.js +6 -2
  415. package/dist/hooks/useGlobalOnClickOutside.js.map +1 -1
  416. package/dist/hooks/useKeyboardInputTracker.d.ts +1 -19
  417. package/dist/hooks/useKeyboardInputTracker.d.ts.map +1 -1
  418. package/dist/hooks/useKeyboardInputTracker.js +48 -41
  419. package/dist/hooks/useKeyboardInputTracker.js.map +1 -1
  420. package/dist/hooks/useLatestRef.d.ts +3 -0
  421. package/dist/hooks/useLatestRef.d.ts.map +1 -0
  422. package/dist/hooks/useLatestRef.js +13 -0
  423. package/dist/hooks/useLatestRef.js.map +1 -0
  424. package/dist/hooks/useLocale.d.ts.map +1 -1
  425. package/dist/hooks/useLocale.js +3 -3
  426. package/dist/hooks/useLocale.js.map +1 -1
  427. package/dist/hooks/useMediaQueryMatch.js +1 -0
  428. package/dist/hooks/useMediaQueryMatch.js.map +1 -1
  429. package/dist/hooks/useMutationObserver.d.ts +1 -2
  430. package/dist/hooks/useMutationObserver.d.ts.map +1 -1
  431. package/dist/hooks/useMutationObserver.js +3 -3
  432. package/dist/hooks/useMutationObserver.js.map +1 -1
  433. package/dist/hooks/usePlatform.d.ts.map +1 -1
  434. package/dist/hooks/usePlatform.js +3 -3
  435. package/dist/hooks/usePlatform.js.map +1 -1
  436. package/dist/hooks/useResizeObserver.d.ts.map +1 -1
  437. package/dist/hooks/useResizeObserver.js +4 -6
  438. package/dist/hooks/useResizeObserver.js.map +1 -1
  439. package/dist/hooks/useSyncHTMLWithBaseVKUIClasses.js +2 -1
  440. package/dist/hooks/useSyncHTMLWithBaseVKUIClasses.js.map +1 -1
  441. package/dist/hooks/useSyncHTMLWithTokens.js +3 -1
  442. package/dist/hooks/useSyncHTMLWithTokens.js.map +1 -1
  443. package/dist/hooks/useWaitTransitionFinish.d.ts.map +1 -1
  444. package/dist/hooks/useWaitTransitionFinish.js +13 -15
  445. package/dist/hooks/useWaitTransitionFinish.js.map +1 -1
  446. package/dist/index.d.ts +1 -0
  447. package/dist/index.d.ts.map +1 -1
  448. package/dist/index.js +1 -0
  449. package/dist/index.js.map +1 -1
  450. package/dist/lib/array.d.ts +17 -0
  451. package/dist/lib/array.d.ts.map +1 -0
  452. package/dist/lib/array.js +18 -0
  453. package/dist/lib/array.js.map +1 -0
  454. package/dist/lib/curve.d.ts +9 -0
  455. package/dist/lib/curve.d.ts.map +1 -0
  456. package/dist/lib/curve.js +21 -0
  457. package/dist/lib/curve.js.map +1 -0
  458. package/dist/lib/dom.d.ts +2 -1
  459. package/dist/lib/dom.d.ts.map +1 -1
  460. package/dist/lib/dom.js +5 -2
  461. package/dist/lib/dom.js.map +1 -1
  462. package/dist/lib/floating/useFloatingWithInteractions/useFloatingWithInteractions.d.ts.map +1 -1
  463. package/dist/lib/floating/useFloatingWithInteractions/useFloatingWithInteractions.js +4 -4
  464. package/dist/lib/floating/useFloatingWithInteractions/useFloatingWithInteractions.js.map +1 -1
  465. package/dist/lib/fx.d.ts +1 -8
  466. package/dist/lib/fx.d.ts.map +1 -1
  467. package/dist/lib/fx.js +4 -55
  468. package/dist/lib/fx.js.map +1 -1
  469. package/dist/lib/layouts/index.d.ts +1 -1
  470. package/dist/lib/layouts/index.d.ts.map +1 -1
  471. package/dist/lib/layouts/index.js.map +1 -1
  472. package/dist/lib/layouts/layoutProps.d.ts +7 -0
  473. package/dist/lib/layouts/layoutProps.d.ts.map +1 -1
  474. package/dist/lib/layouts/layoutProps.js +11 -0
  475. package/dist/lib/layouts/layoutProps.js.map +1 -1
  476. package/dist/lib/layouts/resolveLayoutProps.d.ts.map +1 -1
  477. package/dist/lib/layouts/resolveLayoutProps.js +13 -11
  478. package/dist/lib/layouts/resolveLayoutProps.js.map +1 -1
  479. package/dist/lib/layouts/types.d.ts +29 -0
  480. package/dist/lib/layouts/types.d.ts.map +1 -1
  481. package/dist/lib/layouts/types.js.map +1 -1
  482. package/dist/lib/material/shapes/Shape.d.ts +8 -0
  483. package/dist/lib/material/shapes/Shape.d.ts.map +1 -0
  484. package/dist/lib/material/shapes/Shape.js +18 -0
  485. package/dist/lib/material/shapes/Shape.js.map +1 -0
  486. package/dist/lib/material/shapes/shapes.d.ts +43 -0
  487. package/dist/lib/material/shapes/shapes.d.ts.map +1 -0
  488. package/dist/lib/material/shapes/shapes.js +2250 -0
  489. package/dist/lib/material/shapes/shapes.js.map +1 -0
  490. package/dist/lib/math.d.ts +23 -0
  491. package/dist/lib/math.d.ts.map +1 -0
  492. package/dist/lib/math.js +31 -0
  493. package/dist/lib/math.js.map +1 -0
  494. package/dist/lib/svg/path/approximate.d.ts +21 -0
  495. package/dist/lib/svg/path/approximate.d.ts.map +1 -0
  496. package/dist/lib/svg/path/approximate.js +57 -0
  497. package/dist/lib/svg/path/approximate.js.map +1 -0
  498. package/dist/lib/svg/path/interpolate.d.ts +5 -0
  499. package/dist/lib/svg/path/interpolate.d.ts.map +1 -0
  500. package/dist/lib/svg/path/interpolate.js +121 -0
  501. package/dist/lib/svg/path/interpolate.js.map +1 -0
  502. package/dist/lib/svg/path/path.d.ts +48 -0
  503. package/dist/lib/svg/path/path.d.ts.map +1 -0
  504. package/dist/lib/svg/path/path.js +50 -0
  505. package/dist/lib/svg/path/path.js.map +1 -0
  506. package/dist/lib/svg/path/point.d.ts +3 -0
  507. package/dist/lib/svg/path/point.d.ts.map +1 -0
  508. package/dist/lib/svg/path/point.js +3 -0
  509. package/dist/lib/svg/path/point.js.map +1 -0
  510. package/dist/lib/svg/path/transform.d.ts +64 -0
  511. package/dist/lib/svg/path/transform.d.ts.map +1 -0
  512. package/dist/lib/svg/path/transform.js +110 -0
  513. package/dist/lib/svg/path/transform.js.map +1 -0
  514. package/dist/lib/tokens/useTokenClassName.d.ts.map +1 -1
  515. package/dist/lib/tokens/useTokenClassName.js +4 -1
  516. package/dist/lib/tokens/useTokenClassName.js.map +1 -1
  517. package/dist/lib/touch/UIPanGestureRecognizer.d.ts.map +1 -1
  518. package/dist/lib/touch/UIPanGestureRecognizer.js +2 -2
  519. package/dist/lib/touch/UIPanGestureRecognizer.js.map +1 -1
  520. package/dist/types.d.ts +9 -0
  521. package/dist/types.d.ts.map +1 -1
  522. package/dist/types.js +1 -4
  523. package/dist/types.js.map +1 -1
  524. package/dist/vkui.css +1 -1
  525. package/dist/vkui.css.map +1 -1
  526. package/package.json +7 -6
  527. package/src/components/ActionSheet/ActionSheet.tsx +6 -3
  528. package/src/components/AdaptivityProvider/AdaptivityContext.tsx +3 -3
  529. package/src/components/AdaptivityProvider/AdaptivityProvider.tsx +2 -2
  530. package/src/components/AppRoot/AppRoot.tsx +1 -14
  531. package/src/components/AppRoot/AppRootContext.ts +0 -2
  532. package/src/components/Calendar/Calendar.tsx +2 -2
  533. package/src/components/CalendarDay/CalendarDay.tsx +4 -2
  534. package/src/components/CalendarDays/CalendarDays.tsx +2 -2
  535. package/src/components/CalendarHeader/CalendarHeader.tsx +4 -2
  536. package/src/components/CalendarRange/CalendarRange.tsx +2 -2
  537. package/src/components/CalendarTime/CalendarTime.module.css +38 -0
  538. package/src/components/CalendarTime/CalendarTime.module.css.d.ts.map +1 -1
  539. package/src/components/CalendarTime/CalendarTime.tsx +68 -55
  540. package/src/components/CalendarTime/CalendarTimePicker.tsx +148 -62
  541. package/src/components/CalendarTime/ComboBox.tsx +189 -0
  542. package/src/components/CardScroll/CardScroll.tsx +6 -5
  543. package/src/components/CarouselBase/CarouselBase.tsx +2 -1
  544. package/src/components/ChipsSelect/useChipsSelect.ts +1 -0
  545. package/src/components/ConfigProvider/ConfigProvider.tsx +6 -3
  546. package/src/components/ConfigProvider/ConfigProviderOverride.tsx +2 -1
  547. package/src/components/ConfigProvider/ConfigProviderSubContexts.tsx +43 -0
  548. package/src/components/ContentBadge/ContentBadge.module.css +84 -91
  549. package/src/components/ContentBadge/ContentBadge.module.css.d.ts.map +1 -1
  550. package/src/components/ContentBadge/ContentBadge.tsx +73 -5
  551. package/src/components/CustomSelect/CustomSelect.tsx +19 -10
  552. package/src/components/DateInput/DateInput.tsx +3 -3
  553. package/src/components/DateRangeInput/DateRangeInput.tsx +2 -2
  554. package/src/components/Epic/ScrollSaver.tsx +1 -0
  555. package/src/components/FixedLayout/ParentWidthWrapper.tsx +48 -0
  556. package/src/components/Flex/Flex.tsx +11 -6
  557. package/src/components/GridAvatar/GridAvatar.module.css +1 -1
  558. package/src/components/GridAvatar/GridAvatar.module.css.d.ts.map +1 -1
  559. package/src/components/ImageBase/ImageBaseFloatElement/ImageBaseFloatElement.tsx +1 -1
  560. package/src/components/NativeSelect/NativeSelect.tsx +4 -2
  561. package/src/components/NavTransitionContext/NavTransitionContext.tsx +5 -1
  562. package/src/components/OnboardingTooltip/OnboardingTooltip.tsx +3 -6
  563. package/src/components/PanelHeader/PanelHeader.tsx +1 -1
  564. package/src/components/Popper/Popper.tsx +8 -5
  565. package/src/components/PullToRefresh/PullToRefresh.module.css +1 -1
  566. package/src/components/PullToRefresh/PullToRefresh.tsx +10 -3
  567. package/src/components/Root/Root.tsx +60 -59
  568. package/src/components/SimpleGrid/SimpleGrid.tsx +25 -11
  569. package/src/components/Skeleton/Skeleton.tsx +6 -4
  570. package/src/components/Snackbar/Snackbar.tsx +6 -3
  571. package/src/components/Spacing/Spacing.tsx +1 -1
  572. package/src/components/Spinner/ExpressiveSpinner/ExpressiveSpinner.module.css +13 -0
  573. package/src/components/Spinner/ExpressiveSpinner/ExpressiveSpinner.module.css.d.ts.map +1 -0
  574. package/src/components/Spinner/ExpressiveSpinner/ExpressiveSpinner.tsx +73 -0
  575. package/src/components/Spinner/ExpressiveSpinner/icons.tsx +104 -0
  576. package/src/components/Spinner/SvgIcon.tsx +31 -0
  577. package/src/components/Spinner/icons.tsx +10 -13
  578. package/src/components/SplitLayout/SplitLayout.tsx +3 -3
  579. package/src/components/TabsItem/TabsItem.tsx +4 -5
  580. package/src/components/Tappable/Tappable.tsx +2 -2
  581. package/src/components/View/View.tsx +83 -89
  582. package/src/components/View/ViewInfinite.tsx +65 -69
  583. package/src/components/WriteBar/WriteBar.tsx +25 -59
  584. package/src/components/WriteBar/WriteBarBeforeOrAfter/WriteBarBeforeOrAfter.module.css +12 -0
  585. package/src/components/WriteBar/WriteBarBeforeOrAfter/WriteBarBeforeOrAfter.module.css.d.ts.map +1 -0
  586. package/src/components/WriteBar/WriteBarBeforeOrAfter/WriteBarBeforeOrAfter.tsx +20 -0
  587. package/src/components/WriteBar/WriteBarFormField/WriteBarFormField.module.css +18 -0
  588. package/src/components/WriteBar/WriteBarFormField/WriteBarFormField.module.css.d.ts.map +1 -0
  589. package/src/components/WriteBar/WriteBarFormField/WriteBarFormField.tsx +22 -0
  590. package/src/components/WriteBar/WriteBarFormField/WriteBarFormFieldInlineAfter/WriteBarFormFieldInlineAfter.module.css +3 -0
  591. package/src/components/WriteBar/WriteBarFormField/WriteBarFormFieldInlineAfter/WriteBarFormFieldInlineAfter.module.css.d.ts.map +1 -0
  592. package/src/components/WriteBar/WriteBarFormField/WriteBarFormFieldInlineAfter/WriteBarFormFieldInlineAfter.tsx +23 -0
  593. package/src/components/WriteBar/WriteBarRoot/WriteBarRoot.module.css +14 -0
  594. package/src/components/WriteBar/WriteBarRoot/WriteBarRoot.module.css.d.ts.map +1 -0
  595. package/src/components/WriteBar/WriteBarRoot/WriteBarRoot.tsx +31 -0
  596. package/src/components/WriteBar/WriteBarTextarea/WriteBarTextarea.module.css +42 -0
  597. package/src/components/WriteBar/WriteBarTextarea/WriteBarTextarea.module.css.d.ts.map +1 -0
  598. package/src/components/WriteBar/WriteBarTextarea/WriteBarTextarea.tsx +48 -0
  599. package/src/helpers/math.ts +8 -0
  600. package/src/hoc/withPlatform.tsx +3 -3
  601. package/src/hooks/useAdaptivityConditionalRender/types.ts +2 -2
  602. package/src/hooks/useAnimationFrame.tsx +42 -0
  603. package/src/hooks/useAutoFocus.ts +1 -1
  604. package/src/hooks/useColorScheme.ts +3 -4
  605. package/src/hooks/useConfigDirection.ts +3 -4
  606. package/src/hooks/useDateInput.ts +1 -2
  607. package/src/hooks/useFocusTrap/useAutoFocus.ts +1 -1
  608. package/src/hooks/useFocusTrap/useFocusTrap.tsx +2 -0
  609. package/src/hooks/useFocusVisible.ts +10 -18
  610. package/src/hooks/useFocusWithin.ts +26 -23
  611. package/src/hooks/useGlobalEscKeyDown.ts +12 -15
  612. package/src/hooks/useGlobalOnClickOutside.ts +5 -2
  613. package/src/hooks/useKeyboardInputTracker.ts +68 -55
  614. package/src/hooks/useLatestRef.ts +12 -0
  615. package/src/hooks/useLocale.ts +3 -4
  616. package/src/hooks/useMediaQueryMatch.ts +1 -1
  617. package/src/hooks/useMutationObserver.ts +2 -3
  618. package/src/hooks/usePlatform.ts +3 -4
  619. package/src/hooks/useResizeObserver.ts +4 -5
  620. package/src/hooks/useSyncHTMLWithBaseVKUIClasses.ts +1 -1
  621. package/src/hooks/useSyncHTMLWithTokens.ts +1 -1
  622. package/src/hooks/useWaitTransitionFinish.ts +15 -15
  623. package/src/index.ts +1 -0
  624. package/src/lib/array.ts +19 -0
  625. package/src/lib/curve.ts +36 -0
  626. package/src/lib/dom.tsx +10 -4
  627. package/src/lib/floating/useFloatingWithInteractions/useFloatingWithInteractions.ts +4 -5
  628. package/src/lib/fx.ts +5 -63
  629. package/src/lib/layouts/index.ts +1 -0
  630. package/src/lib/layouts/layoutProps.ts +8 -0
  631. package/src/lib/layouts/resolveLayoutProps.ts +19 -17
  632. package/src/lib/layouts/types.ts +29 -0
  633. package/src/lib/material/shapes/Shape.tsx +17 -0
  634. package/src/lib/material/shapes/shapes.ts +329 -0
  635. package/src/lib/math.ts +37 -0
  636. package/src/lib/svg/path/approximate.ts +81 -0
  637. package/src/lib/svg/path/interpolate.ts +151 -0
  638. package/src/lib/svg/path/path.ts +102 -0
  639. package/src/lib/svg/path/point.ts +2 -0
  640. package/src/lib/svg/path/transform.ts +147 -0
  641. package/src/lib/tokens/useTokenClassName.ts +7 -5
  642. package/src/lib/touch/UIPanGestureRecognizer.ts +2 -2
  643. package/src/types.ts +16 -0
  644. package/dist/cssm/components/WriteBar/WriteBar.module.css +0 -118
  645. package/dist/cssm/lib/floating/LockFloatingPosition/LockFloatingPosition.js +0 -6
  646. package/dist/cssm/lib/floating/LockFloatingPosition/LockFloatingPosition.js.map +0 -1
  647. package/dist/lib/floating/LockFloatingPosition/LockFloatingPosition.d.ts +0 -6
  648. package/dist/lib/floating/LockFloatingPosition/LockFloatingPosition.d.ts.map +0 -1
  649. package/dist/lib/floating/LockFloatingPosition/LockFloatingPosition.js +0 -6
  650. package/dist/lib/floating/LockFloatingPosition/LockFloatingPosition.js.map +0 -1
  651. package/src/components/WriteBar/WriteBar.module.css +0 -116
  652. package/src/components/WriteBar/WriteBar.module.css.d.ts.map +0 -1
  653. package/src/lib/floating/LockFloatingPosition/LockFloatingPosition.tsx +0 -6
package/src/lib/fx.ts CHANGED
@@ -1,3 +1,5 @@
1
+ import { cubicBezierTwoDimensional } from './curve';
2
+
1
3
  /**
2
4
  * ease function
3
5
  * @param x absolute progress of the animation in bounds 0 (beginning) and 1 (end)
@@ -6,68 +8,8 @@ export function easeInOutSine(x: number): number {
6
8
  return 0.5 * (1 - Math.cos(Math.PI * x));
7
9
  }
8
10
 
9
- /**
10
- * JS-реализация cubic bezier
11
- *
12
- * Алгебраический метод решения взят из PRа {@link https://github.com/gre/bezier-easing/pull/57}
13
- */
14
- export function cubicBezier(mX1: number, mY1: number, mX2: number, mY2: number) {
15
- if (!(0 <= mX1 && mX1 <= 1 && 0 <= mX2 && mX2 <= 1)) {
16
- throw new Error('Bezier x values must be in [0, 1] range');
17
- }
18
-
19
- if (mX1 === mY1 && mX2 === mY2) {
20
- return LinearEasing;
21
- }
22
-
23
- const a = 6 * (3 * mX1 - 3 * mX2 + 1);
24
- const b = 6 * (mX2 - 2 * mX1);
25
- const c = 3 * mX1;
26
- const a2 = a * a;
27
- const b2 = b * b;
28
- const d = b / a;
29
- const e = (3 * b * c) / a2 - (b2 * b) / (a2 * a);
30
- const w1 = (2 * c) / a - b2 / a2;
31
- const w = w1 * w1 * w1;
32
- const o = 3 / a;
33
- const ay = 3 * mY1 - 3 * mY2 + 1;
34
- const by = mY2 - 2 * mY1;
35
- const cy = 3 * mY1;
36
-
37
- const funcX2T = a ? x2t : LinearEasing;
38
-
39
- return (x: number) => {
40
- if (x === 0 || x === 1) {
41
- return x;
42
- }
43
- return funcY(funcX2T(x, e, o, w, d), ay, by, cy);
11
+ export function cubicBezier(x1: number, y1: number, x2: number, y2: number) {
12
+ return function (progress: number): number {
13
+ return cubicBezierTwoDimensional(0, 0, x1, y1, x2, y2, 1, 1, progress)[1];
44
14
  };
45
15
  }
46
-
47
- function LinearEasing(x: number) {
48
- return x;
49
- }
50
-
51
- function x2t(x: number, a: number, b: number, c: number, d: number) {
52
- const q = a + b * x;
53
- const s = q ** 2 + c;
54
- if (s > 0) {
55
- const root = Math.sqrt(s);
56
- return Math.cbrt(q + root) + Math.cbrt(q - root) - d;
57
- }
58
- const l = Math.cbrt(Math.sqrt(q * q - s));
59
- const angle = q ? Math.atan(Math.sqrt(-s) / q) : -Math.PI / 2;
60
- let φ;
61
- if (b < 0) {
62
- φ = (q > 0 ? 2 * Math.PI : Math.PI) - angle;
63
- } else if (d < 0) {
64
- φ = (q > 0 ? 2 * Math.PI : -3 * Math.PI) + angle;
65
- } else {
66
- φ = (q > 0 ? 0 : Math.PI) + angle;
67
- }
68
- return 2 * l * Math.cos(φ / 3) - d;
69
- }
70
-
71
- function funcY(t: number, ay: number, by: number, cy: number) {
72
- return ((ay * t + 3 * by) * t + cy) * t;
73
- }
@@ -7,6 +7,7 @@ export {
7
7
  } from './gaps';
8
8
 
9
9
  export type {
10
+ MarginProp,
10
11
  PaddingProp,
11
12
  InsetProp,
12
13
  SizeProp,
@@ -27,6 +27,7 @@ const CSS_GLOBAL_KEYWORDS: CSSGlobalValue[] = ['inherit', 'initial', 'unset'];
27
27
 
28
28
  const CSS_KEYWORDS = [...CSS_INTRINSIC_KEYWORDS, ...CSS_GLOBAL_KEYWORDS];
29
29
  const PADDING_VALUES = [...DESIGN_SYSTEM_SIZES, ...CSS_GLOBAL_KEYWORDS, 'system'];
30
+ const MARGIN_VALUES = [...DESIGN_SYSTEM_SIZES, ...CSS_GLOBAL_KEYWORDS];
30
31
  const SIZE_VALUES = CSS_KEYWORDS;
31
32
  const MINMAX_SIZE_VALUES = [...CSS_KEYWORDS.filter((opt) => opt !== 'auto')];
32
33
  const FLEX_VALUES = CSS_GLOBAL_KEYWORDS;
@@ -49,6 +50,13 @@ export const SYSTEM_PADDING_VERTICAL = 'var(--vkui--size_base_padding_vertical--
49
50
  export const SYSTEM_PADDING_HORIZONTAL = 'var(--vkui--size_base_padding_horizontal--regular)';
50
51
 
51
52
  export const LAYOUT_PROPS = {
53
+ margin: MARGIN_VALUES,
54
+ marginInline: MARGIN_VALUES,
55
+ marginBlock: MARGIN_VALUES,
56
+ marginInlineStart: MARGIN_VALUES,
57
+ marginInlineEnd: MARGIN_VALUES,
58
+ marginBlockStart: MARGIN_VALUES,
59
+ marginBlockEnd: MARGIN_VALUES,
52
60
  padding: PADDING_VALUES,
53
61
  paddingInline: PADDING_VALUES,
54
62
  paddingBlock: PADDING_VALUES,
@@ -24,23 +24,25 @@ export function resolveLayoutProps<T extends ComponentProps>(
24
24
  let resolvedStyle: React.CSSProperties | undefined;
25
25
 
26
26
  for (const key in LAYOUT_PROPS) {
27
- if (key in outProps && outProps[key] !== undefined) {
28
- const propDef = LAYOUT_PROPS[key as LayoutPropKeys];
29
- const value = outProps[key];
30
- const cssProperty = key.replace(/([A-Z])/g, '-$1').toLowerCase();
31
- if (typeof value === 'string' && (propDef as string[]).includes(value)) {
32
- resolvedClassName = classNames(
33
- resolvedClassName,
34
- generateConstantClassName(cssProperty, value),
35
- );
36
- } else if (key !== 'position' && !key.startsWith('overflow')) {
37
- resolvedClassName = classNames(resolvedClassName, generateVariableClassName(cssProperty));
38
- resolvedStyle = mergeStyle(resolvedStyle, {
39
- [generateVariable(cssProperty)]:
40
- typeof value === 'number' && key !== 'flexGrow' && key !== 'flexShrink'
41
- ? `${value}px`
42
- : value,
43
- });
27
+ if (key in outProps) {
28
+ if (outProps[key] !== undefined) {
29
+ const propDef = LAYOUT_PROPS[key as LayoutPropKeys];
30
+ const value = outProps[key];
31
+ const cssProperty = key.replace(/([A-Z])/g, '-$1').toLowerCase();
32
+ if (typeof value === 'string' && (propDef as string[]).includes(value)) {
33
+ resolvedClassName = classNames(
34
+ resolvedClassName,
35
+ generateConstantClassName(cssProperty, value),
36
+ );
37
+ } else if (key !== 'position' && !key.startsWith('overflow')) {
38
+ resolvedClassName = classNames(resolvedClassName, generateVariableClassName(cssProperty));
39
+ resolvedStyle = mergeStyle(resolvedStyle, {
40
+ [generateVariable(cssProperty)]:
41
+ typeof value === 'number' && key !== 'flexGrow' && key !== 'flexShrink'
42
+ ? `${value}px`
43
+ : value,
44
+ });
45
+ }
44
46
  }
45
47
  delete outProps[key];
46
48
  }
@@ -18,6 +18,7 @@ export type PaddingProp = LiteralUnion<
18
18
  DesignSystemSize | CSSGlobalValue | 'system',
19
19
  number | string
20
20
  >;
21
+ export type MarginProp = LiteralUnion<DesignSystemSize | CSSGlobalValue, number | string>;
21
22
 
22
23
  // Типы для параметров позиционирования
23
24
  export type InsetProp = LiteralUnion<DesignSystemSize | CSSGlobalValue | 'auto', number | string>;
@@ -39,6 +40,34 @@ type AlignSelfProp = SelfPositionProp | 'baseline' | 'stretch';
39
40
  type JustifySelfProp = SelfPositionProp | 'baseline' | 'stretch';
40
41
 
41
42
  export interface LayoutProps {
43
+ /**
44
+ * Внешние отступы со всех сторон.
45
+ */
46
+ margin?: MarginProp | undefined;
47
+ /**
48
+ * Внешние отступы по строчной оси.
49
+ */
50
+ marginInline?: MarginProp | undefined;
51
+ /**
52
+ * Внешние отступы по блочной оси.
53
+ */
54
+ marginBlock?: MarginProp | undefined;
55
+ /**
56
+ * Внешний начальный отступ по строчной оси.
57
+ */
58
+ marginInlineStart?: MarginProp | undefined;
59
+ /**
60
+ * Внешний конечный отступ по строчной оси.
61
+ */
62
+ marginInlineEnd?: MarginProp | undefined;
63
+ /**
64
+ * Внешний начальный отступ по блочной оси.
65
+ */
66
+ marginBlockStart?: MarginProp | undefined;
67
+ /**
68
+ * Внешний конечный отступ по блочной оси.
69
+ */
70
+ marginBlockEnd?: MarginProp | undefined;
42
71
  /**
43
72
  * Внутренние отступы со всех сторон.
44
73
  */
@@ -0,0 +1,17 @@
1
+ import { RootComponent } from '../../../components/RootComponent/RootComponent';
2
+ import { type HasRootRef } from '../../../types';
3
+ import { svgPathToString } from '../../svg/path/path';
4
+ import * as shapes from './shapes';
5
+
6
+ export interface ShapeProps extends React.ComponentProps<'svg'>, HasRootRef<SVGElement> {
7
+ size?: number;
8
+ params: shapes.ShapeParameters;
9
+ }
10
+
11
+ export function Shape({ size = 24, params, ...props }: ShapeProps) {
12
+ return (
13
+ <RootComponent Component="svg" width={size} height={size} {...props}>
14
+ <path d={svgPathToString(shapes.shape(params, size))} fill="currentColor" />
15
+ </RootComponent>
16
+ );
17
+ }
@@ -0,0 +1,329 @@
1
+ /**
2
+ * Набор форм M3
3
+ *
4
+ * https://m3.material.io/styles/shape/overview-principles
5
+ */
6
+ import { type DeepReadonly, type ReadonlyWeakMap } from '../../../types';
7
+ import { type SVGPathSupport } from '../../svg/path/path';
8
+ import * as transform from '../../svg/path/transform';
9
+
10
+ export interface ShapeParameters {
11
+ /**
12
+ * SVG путь для фигуры размером [0,1] на [0,1]
13
+ */
14
+ readonly path: DeepReadonly<SVGPathSupport>;
15
+ /**
16
+ * Масштабирующий коэффициент предназначен для возможности помещения
17
+ * в произвольный контейнер фигуры учитывая вращение
18
+ */
19
+ readonly rotateScaleFactor: number;
20
+ }
21
+
22
+ /**
23
+ * Возвращает фигуру определенного размера
24
+ */
25
+ export function shape(shapeParams: ShapeParameters, size: number): SVGPathSupport {
26
+ return transform.scale(shapeParams.path, size, size);
27
+ }
28
+
29
+ /**
30
+ * Возвращает фигуру с возможностью поворота, которая помещается в контейнер
31
+ * определенного размера
32
+ */
33
+ export function shapeWithRotate(shapeParams: ShapeParameters, size: number): SVGPathSupport {
34
+ const scaleSize = shapeParams.rotateScaleFactor * size;
35
+ const translateFactor = (size - scaleSize) / 2;
36
+
37
+ return transform.translate(shape(shapeParams, scaleSize), translateFactor, translateFactor);
38
+ }
39
+
40
+ export const ovalParams: ShapeParameters = {
41
+ path: [
42
+ ['M', [0.771, 0.771]],
43
+ ['C', [0.539, 1.003, 0.2296, 1.0698, 0.0799, 0.9201]],
44
+ ['C', [-0.0698, 0.7704, -0.003, 0.461, 0.229, 0.229]],
45
+ ['C', [0.461, -0.003, 0.7704, -0.0698, 0.9201, 0.0799]],
46
+ ['C', [1.0698, 0.2296, 1.003, 0.539, 0.771, 0.771]],
47
+ ['Z', []],
48
+ ],
49
+ rotateScaleFactor: 30 / 38,
50
+ };
51
+
52
+ export const cookie4Params: ShapeParameters = {
53
+ path: [
54
+ ['M', [0.6383, 0.0222]],
55
+ ['C', [0.8531, -0.0711, 1.0711, 0.1469, 0.9778, 0.3617]],
56
+ ['L', [0.9624, 0.3972]],
57
+ ['C', [0.9339, 0.4628, 0.9339, 0.5372, 0.9624, 0.6028]],
58
+ ['L', [0.9778, 0.6383]],
59
+ ['C', [1.0711, 0.8531, 0.8531, 1.0711, 0.6383, 0.9778]],
60
+ ['L', [0.6028, 0.9624]],
61
+ ['C', [0.5372, 0.9339, 0.4628, 0.9339, 0.3972, 0.9624]],
62
+ ['L', [0.3617, 0.9778]],
63
+ ['C', [0.1469, 1.0711, -0.0711, 0.8531, 0.0222, 0.6383]],
64
+ ['L', [0.0376, 0.6028]],
65
+ ['C', [0.0661, 0.5372, 0.0661, 0.4628, 0.0376, 0.3972]],
66
+ ['L', [0.0222, 0.3617]],
67
+ ['C', [-0.0711, 0.1469, 0.1469, -0.0711, 0.3617, 0.0222]],
68
+ ['L', [0.3972, 0.0376]],
69
+ ['C', [0.4628, 0.0661, 0.5372, 0.0661, 0.6028, 0.0376]],
70
+ ['L', [0.6383, 0.0222]],
71
+ ['Z', []],
72
+ ],
73
+ rotateScaleFactor: 28 / 38,
74
+ };
75
+
76
+ export const sunnyParams: ShapeParameters = {
77
+ path: [
78
+ ['M', [0.7702, 0.1213]],
79
+ ['C', [0.8013, 0.1234, 0.8168, 0.1245, 0.8294, 0.13]],
80
+ ['C', [0.8476, 0.1379, 0.8621, 0.1524, 0.87, 0.1706]],
81
+ ['C', [0.8755, 0.1832, 0.8766, 0.1987, 0.8787, 0.2298]],
82
+ ['L', [0.8835, 0.3008]],
83
+ ['C', [0.8844, 0.3134, 0.8848, 0.3197, 0.8862, 0.3257]],
84
+ ['C', [0.8882, 0.3344, 0.8916, 0.3426, 0.8963, 0.3502]],
85
+ ['C', [0.8996, 0.3554, 0.9038, 0.3601, 0.912, 0.3696]],
86
+ ['L', [0.9588, 0.4232]],
87
+ ['C', [0.9793, 0.4467, 0.9896, 0.4585, 0.9946, 0.4712]],
88
+ ['C', [1.0018, 0.4897, 1.0018, 0.5103, 0.9946, 0.5287]],
89
+ ['C', [0.9896, 0.5415, 0.9793, 0.5533, 0.9588, 0.5768]],
90
+ ['L', [0.912, 0.6303]],
91
+ ['C', [0.9038, 0.6398, 0.8996, 0.6446, 0.8963, 0.6498]],
92
+ ['C', [0.8916, 0.6573, 0.8882, 0.6656, 0.8862, 0.6743]],
93
+ ['C', [0.8848, 0.6803, 0.8844, 0.6866, 0.8835, 0.6992]],
94
+ ['L', [0.8787, 0.7702]],
95
+ ['C', [0.8766, 0.8013, 0.8755, 0.8168, 0.87, 0.8294]],
96
+ ['C', [0.8621, 0.8476, 0.8476, 0.8621, 0.8294, 0.87]],
97
+ ['C', [0.8168, 0.8755, 0.8013, 0.8766, 0.7702, 0.8787]],
98
+ ['L', [0.6992, 0.8835]],
99
+ ['C', [0.6866, 0.8844, 0.6803, 0.8848, 0.6743, 0.8862]],
100
+ ['C', [0.6656, 0.8882, 0.6573, 0.8916, 0.6498, 0.8963]],
101
+ ['C', [0.6446, 0.8996, 0.6398, 0.9038, 0.6303, 0.912]],
102
+ ['L', [0.5768, 0.9588]],
103
+ ['C', [0.5533, 0.9793, 0.5415, 0.9896, 0.5287, 0.9946]],
104
+ ['C', [0.5103, 1.0018, 0.4897, 1.0018, 0.4712, 0.9946]],
105
+ ['C', [0.4585, 0.9896, 0.4467, 0.9793, 0.4232, 0.9588]],
106
+ ['L', [0.3696, 0.912]],
107
+ ['C', [0.3601, 0.9038, 0.3554, 0.8996, 0.3502, 0.8963]],
108
+ ['C', [0.3426, 0.8916, 0.3344, 0.8882, 0.3257, 0.8862]],
109
+ ['C', [0.3197, 0.8848, 0.3134, 0.8844, 0.3008, 0.8835]],
110
+ ['L', [0.2298, 0.8787]],
111
+ ['C', [0.1987, 0.8766, 0.1832, 0.8755, 0.1706, 0.87]],
112
+ ['C', [0.1524, 0.8621, 0.1379, 0.8476, 0.13, 0.8294]],
113
+ ['C', [0.1245, 0.8168, 0.1234, 0.8013, 0.1213, 0.7702]],
114
+ ['L', [0.1165, 0.6992]],
115
+ ['C', [0.1156, 0.6866, 0.1152, 0.6803, 0.1138, 0.6743]],
116
+ ['C', [0.1118, 0.6656, 0.1084, 0.6573, 0.1037, 0.6498]],
117
+ ['C', [0.1004, 0.6446, 0.0962, 0.6398, 0.0879, 0.6303]],
118
+ ['L', [0.0412, 0.5768]],
119
+ ['C', [0.0207, 0.5533, 0.0104, 0.5415, 0.0054, 0.5287]],
120
+ ['C', [-0.0018, 0.5103, -0.0018, 0.4897, 0.0054, 0.4712]],
121
+ ['C', [0.0104, 0.4585, 0.0207, 0.4467, 0.0412, 0.4232]],
122
+ ['L', [0.0879, 0.3696]],
123
+ ['C', [0.0962, 0.3601, 0.1004, 0.3554, 0.1037, 0.3502]],
124
+ ['C', [0.1084, 0.3426, 0.1118, 0.3344, 0.1138, 0.3257]],
125
+ ['C', [0.1152, 0.3197, 0.1156, 0.3134, 0.1165, 0.3008]],
126
+ ['L', [0.1213, 0.2298]],
127
+ ['C', [0.1234, 0.1987, 0.1245, 0.1832, 0.13, 0.1706]],
128
+ ['C', [0.1379, 0.1524, 0.1524, 0.1379, 0.1706, 0.13]],
129
+ ['C', [0.1832, 0.1245, 0.1987, 0.1234, 0.2298, 0.1213]],
130
+ ['L', [0.3008, 0.1165]],
131
+ ['C', [0.3134, 0.1156, 0.3197, 0.1152, 0.3257, 0.1138]],
132
+ ['C', [0.3344, 0.1118, 0.3426, 0.1084, 0.3502, 0.1037]],
133
+ ['C', [0.3554, 0.1004, 0.3601, 0.0962, 0.3696, 0.0879]],
134
+ ['L', [0.4232, 0.0412]],
135
+ ['C', [0.4467, 0.0207, 0.4585, 0.0104, 0.4712, 0.0054]],
136
+ ['C', [0.4897, -0.0018, 0.5103, -0.0018, 0.5287, 0.0054]],
137
+ ['C', [0.5415, 0.0104, 0.5533, 0.0207, 0.5768, 0.0412]],
138
+ ['L', [0.6303, 0.0879]],
139
+ ['C', [0.6398, 0.0962, 0.6446, 0.1004, 0.6498, 0.1037]],
140
+ ['C', [0.6573, 0.1084, 0.6656, 0.1118, 0.6743, 0.1138]],
141
+ ['C', [0.6803, 0.1152, 0.6866, 0.1156, 0.6992, 0.1165]],
142
+ ['L', [0.7702, 0.1213]],
143
+ ['Z', []],
144
+ ],
145
+ rotateScaleFactor: 34 / 38,
146
+ };
147
+
148
+ export const pillParams: ShapeParameters = {
149
+ path: [
150
+ ['M', [0.2662, 0.1259]],
151
+ ['C', [0.4341, -0.042, 0.7062, -0.042, 0.8741, 0.1259]],
152
+ ['C', [1.042, 0.2938, 1.042, 0.5659, 0.8741, 0.7338]],
153
+ ['L', [0.7338, 0.8741]],
154
+ ['C', [0.5659, 1.042, 0.2938, 1.042, 0.1259, 0.8741]],
155
+ ['C', [-0.042, 0.7062, -0.042, 0.4341, 0.1259, 0.2662]],
156
+ ['L', [0.2662, 0.1259]],
157
+ ['Z', []],
158
+ ],
159
+ rotateScaleFactor: 30 / 38,
160
+ };
161
+
162
+ export const pentagonParams: ShapeParameters = {
163
+ path: [
164
+ ['M', [0.3426, 0.0864]],
165
+ ['C', [0.3914, 0.0509, 0.4158, 0.0331, 0.4418, 0.0243]],
166
+ ['C', [0.4795, 0.0115, 0.5205, 0.0115, 0.5582, 0.0243]],
167
+ ['C', [0.5842, 0.0331, 0.6086, 0.0509, 0.6574, 0.0864]],
168
+ ['L', [0.7641, 0.1641]],
169
+ ['L', [0.8707, 0.237]],
170
+ ['C', [0.9213, 0.2715, 0.9466, 0.2888, 0.9635, 0.3105]],
171
+ ['C', [0.988, 0.3419, 1.0008, 0.3806, 1, 0.4201]],
172
+ ['C', [0.9994, 0.4474, 0.9893, 0.4759, 0.9692, 0.533]],
173
+ ['L', [0.9273, 0.6519]],
174
+ ['L', [0.8887, 0.7738]],
175
+ ['C', [0.8705, 0.8309, 0.8615, 0.8595, 0.8456, 0.8818]],
176
+ ['C', [0.8227, 0.9139, 0.7894, 0.9376, 0.751, 0.9489]],
177
+ ['C', [0.7245, 0.9568, 0.6939, 0.9563, 0.6328, 0.9554]],
178
+ ['L', [0.5, 0.9534]],
179
+ ['L', [0.3672, 0.9554]],
180
+ ['C', [0.3061, 0.9563, 0.2755, 0.9568, 0.249, 0.9489]],
181
+ ['C', [0.2106, 0.9376, 0.1773, 0.9139, 0.1544, 0.8818]],
182
+ ['C', [0.1385, 0.8595, 0.1295, 0.8309, 0.1113, 0.7738]],
183
+ ['L', [0.0727, 0.6519]],
184
+ ['L', [0.0308, 0.533]],
185
+ ['C', [0.0107, 0.4759, 0.0006, 0.4474, 0, 0.4201]],
186
+ ['C', [-0.0008, 0.3806, 0.012, 0.3419, 0.0365, 0.3105]],
187
+ ['C', [0.0534, 0.2888, 0.0787, 0.2715, 0.1293, 0.237]],
188
+ ['L', [0.2359, 0.1641]],
189
+ ['L', [0.3426, 0.0864]],
190
+ ['Z', []],
191
+ ],
192
+ rotateScaleFactor: 34 / 38,
193
+ };
194
+
195
+ export const cookie9Params: ShapeParameters = {
196
+ path: [
197
+ ['M', [0.3914, 0.0472]],
198
+ ['C', [0.3968, 0.0428, 0.3995, 0.0406, 0.402, 0.0387]],
199
+ ['C', [0.46, -0.0051, 0.54, -0.0051, 0.598, 0.0387]],
200
+ ['C', [0.6005, 0.0406, 0.6032, 0.0428, 0.6086, 0.0472]],
201
+ ['C', [0.611, 0.0491, 0.6122, 0.0501, 0.6134, 0.051]],
202
+ ['C', [0.6406, 0.0725, 0.6741, 0.0846, 0.7088, 0.0857]],
203
+ ['C', [0.7103, 0.0858, 0.7119, 0.0858, 0.715, 0.0858]],
204
+ ['C', [0.7219, 0.0859, 0.7254, 0.0859, 0.7285, 0.0861]],
205
+ ['C', [0.8011, 0.0898, 0.8625, 0.1411, 0.8787, 0.2118]],
206
+ ['C', [0.8794, 0.2148, 0.88, 0.2182, 0.8813, 0.2251]],
207
+ ['C', [0.8819, 0.2281, 0.8822, 0.2296, 0.8825, 0.2311]],
208
+ ['C', [0.8896, 0.265, 0.9074, 0.2958, 0.9333, 0.3189]],
209
+ ['C', [0.9344, 0.3199, 0.9356, 0.3209, 0.9379, 0.3229]],
210
+ ['C', [0.9432, 0.3274, 0.9458, 0.3297, 0.9481, 0.3318]],
211
+ ['C', [1.0014, 0.3812, 1.0153, 0.4598, 0.9821, 0.5244]],
212
+ ['C', [0.9807, 0.5271, 0.979, 0.5302, 0.9756, 0.5362]],
213
+ ['C', [0.9741, 0.5389, 0.9733, 0.5403, 0.9726, 0.5416]],
214
+ ['C', [0.9562, 0.5722, 0.95, 0.6071, 0.955, 0.6414]],
215
+ ['C', [0.9552, 0.6429, 0.9555, 0.6445, 0.956, 0.6475]],
216
+ ['C', [0.9571, 0.6544, 0.9576, 0.6578, 0.958, 0.6609]],
217
+ ['C', [0.967, 0.7328, 0.927, 0.802, 0.86, 0.8302]],
218
+ ['C', [0.8572, 0.8314, 0.8539, 0.8327, 0.8474, 0.8351]],
219
+ ['C', [0.8445, 0.8362, 0.843, 0.8368, 0.8416, 0.8373]],
220
+ ['C', [0.8094, 0.8502, 0.7821, 0.873, 0.7638, 0.9025]],
221
+ ['C', [0.763, 0.9038, 0.7622, 0.9051, 0.7606, 0.9078]],
222
+ ['C', [0.7571, 0.9137, 0.7553, 0.9167, 0.7536, 0.9193]],
223
+ ['C', [0.7142, 0.9802, 0.6389, 1.0075, 0.5694, 0.9862]],
224
+ ['C', [0.5665, 0.9853, 0.5632, 0.9841, 0.5566, 0.9818]],
225
+ ['C', [0.5537, 0.9808, 0.5522, 0.9803, 0.5508, 0.9798]],
226
+ ['C', [0.5178, 0.969, 0.4822, 0.969, 0.4492, 0.9798]],
227
+ ['C', [0.4478, 0.9803, 0.4463, 0.9808, 0.4434, 0.9818]],
228
+ ['C', [0.4368, 0.9841, 0.4335, 0.9853, 0.4306, 0.9862]],
229
+ ['C', [0.3611, 1.0075, 0.2858, 0.9802, 0.2464, 0.9193]],
230
+ ['C', [0.2447, 0.9167, 0.2429, 0.9137, 0.2394, 0.9078]],
231
+ ['C', [0.2378, 0.9051, 0.237, 0.9038, 0.2362, 0.9025]],
232
+ ['C', [0.2179, 0.873, 0.1906, 0.8502, 0.1584, 0.8373]],
233
+ ['C', [0.157, 0.8368, 0.1555, 0.8362, 0.1526, 0.8351]],
234
+ ['C', [0.1461, 0.8327, 0.1428, 0.8314, 0.14, 0.8302]],
235
+ ['C', [0.073, 0.802, 0.033, 0.7328, 0.042, 0.6609]],
236
+ ['C', [0.0424, 0.6578, 0.0429, 0.6544, 0.044, 0.6475]],
237
+ ['C', [0.0445, 0.6445, 0.0448, 0.6429, 0.045, 0.6414]],
238
+ ['C', [0.05, 0.6071, 0.0438, 0.5722, 0.0274, 0.5416]],
239
+ ['C', [0.0267, 0.5403, 0.0259, 0.5389, 0.0244, 0.5362]],
240
+ ['C', [0.021, 0.5302, 0.0193, 0.5271, 0.0179, 0.5244]],
241
+ ['C', [-0.0153, 0.4598, -0.0014, 0.3812, 0.0519, 0.3318]],
242
+ ['C', [0.0542, 0.3297, 0.0568, 0.3274, 0.0621, 0.3229]],
243
+ ['C', [0.0644, 0.3209, 0.0656, 0.3199, 0.0667, 0.3189]],
244
+ ['C', [0.0926, 0.2958, 0.1104, 0.265, 0.1175, 0.2311]],
245
+ ['C', [0.1178, 0.2296, 0.1181, 0.2281, 0.1187, 0.2251]],
246
+ ['C', [0.12, 0.2182, 0.1206, 0.2148, 0.1213, 0.2118]],
247
+ ['C', [0.1375, 0.1411, 0.1989, 0.0898, 0.2715, 0.0861]],
248
+ ['C', [0.2746, 0.0859, 0.2781, 0.0859, 0.285, 0.0858]],
249
+ ['C', [0.2881, 0.0858, 0.2897, 0.0858, 0.2912, 0.0857]],
250
+ ['C', [0.3259, 0.0846, 0.3594, 0.0725, 0.3866, 0.051]],
251
+ ['C', [0.3878, 0.0501, 0.389, 0.0491, 0.3914, 0.0472]],
252
+ ['Z', []],
253
+ ],
254
+ rotateScaleFactor: 34 / 38,
255
+ };
256
+
257
+ export const softBurstParams: ShapeParameters = {
258
+ path: [
259
+ ['M', [0.4549, 0.0247]],
260
+ ['C', [0.4757, -0.0082, 0.5243, -0.0082, 0.545, 0.0247]],
261
+ ['L', [0.5947, 0.1036]],
262
+ ['C', [0.6084, 0.1253, 0.6359, 0.1341, 0.6598, 0.1245]],
263
+ ['L', [0.7471, 0.0894]],
264
+ ['C', [0.7835, 0.0747, 0.8229, 0.1029, 0.82, 0.1416]],
265
+ ['L', [0.8131, 0.2342]],
266
+ ['C', [0.8112, 0.2596, 0.8282, 0.2827, 0.8533, 0.2887]],
267
+ ['L', [0.9449, 0.3109]],
268
+ ['C', [0.9831, 0.3202, 0.9981, 0.3657, 0.9727, 0.3953]],
269
+ ['L', [0.9119, 0.4663]],
270
+ ['C', [0.8952, 0.4858, 0.8952, 0.5142, 0.9119, 0.5337]],
271
+ ['L', [0.9727, 0.6047]],
272
+ ['C', [0.9981, 0.6343, 0.9831, 0.6798, 0.9449, 0.6891]],
273
+ ['L', [0.8533, 0.7113]],
274
+ ['C', [0.8282, 0.7173, 0.8112, 0.7404, 0.8131, 0.7658]],
275
+ ['L', [0.82, 0.8584]],
276
+ ['C', [0.8229, 0.8971, 0.7835, 0.9252, 0.7471, 0.9106]],
277
+ ['L', [0.6598, 0.8755]],
278
+ ['C', [0.6359, 0.8659, 0.6084, 0.8747, 0.5947, 0.8964]],
279
+ ['L', [0.545, 0.9753]],
280
+ ['C', [0.5243, 1.0082, 0.4757, 1.0082, 0.4549, 0.9753]],
281
+ ['L', [0.4053, 0.8964]],
282
+ ['C', [0.3916, 0.8747, 0.3641, 0.8659, 0.3402, 0.8755]],
283
+ ['L', [0.2529, 0.9106]],
284
+ ['C', [0.2165, 0.9252, 0.1771, 0.8971, 0.18, 0.8584]],
285
+ ['L', [0.1869, 0.7658]],
286
+ ['C', [0.1888, 0.7404, 0.1718, 0.7173, 0.1467, 0.7113]],
287
+ ['L', [0.0551, 0.6891]],
288
+ ['C', [0.0169, 0.6798, 0.0019, 0.6343, 0.0273, 0.6047]],
289
+ ['L', [0.0881, 0.5337]],
290
+ ['C', [0.1048, 0.5142, 0.1048, 0.4858, 0.0881, 0.4663]],
291
+ ['L', [0.0273, 0.3953]],
292
+ ['C', [0.0019, 0.3657, 0.0169, 0.3202, 0.0551, 0.3109]],
293
+ ['L', [0.1467, 0.2887]],
294
+ ['C', [0.1718, 0.2827, 0.1888, 0.2596, 0.1869, 0.2342]],
295
+ ['L', [0.18, 0.1416]],
296
+ ['C', [0.1771, 0.1029, 0.2165, 0.0747, 0.2529, 0.0894]],
297
+ ['L', [0.3402, 0.1245]],
298
+ ['C', [0.3641, 0.1341, 0.3916, 0.1253, 0.4053, 0.1036]],
299
+ ['L', [0.4549, 0.0247]],
300
+ ['Z', []],
301
+ ],
302
+ rotateScaleFactor: 34 / 38,
303
+ };
304
+
305
+ /**
306
+ * Список всех форм
307
+ */
308
+ export const shapeList = [
309
+ ovalParams,
310
+ pillParams,
311
+ pentagonParams,
312
+ sunnyParams,
313
+ cookie4Params,
314
+ cookie9Params,
315
+ softBurstParams,
316
+ ] as const;
317
+
318
+ /**
319
+ * Название форм
320
+ */
321
+ export const shapeNameMap: ReadonlyWeakMap<ShapeParameters, string> = new WeakMap([
322
+ [ovalParams, 'Oval'],
323
+ [pillParams, 'Pill'],
324
+ [pentagonParams, 'Pentagon'],
325
+ [sunnyParams, 'Sunny'],
326
+ [cookie4Params, '4-sided cookie'],
327
+ [cookie9Params, '9-sided cookie'],
328
+ [softBurstParams, 'Soft burst'],
329
+ ]);
@@ -0,0 +1,37 @@
1
+ /**
2
+ * Длина гипотенузы
3
+ */
4
+ function hypotenuse(a: number, b: number): number {
5
+ return Math.sqrt(a * a + b * b);
6
+ }
7
+
8
+ /**
9
+ * Евклидово расстояние между двумя точками
10
+ *
11
+ * ```ts
12
+ * import { distancePoint } from './math';
13
+ * import * as assert from 'node:assert/strict';
14
+ *
15
+ * assert.equal(distance(1, 1, 4, 5), 5)
16
+ * ```
17
+ */
18
+ export function distance(x1: number, y1: number, x2: number, y2: number): number {
19
+ return hypotenuse(x1 - x2, y1 - y2);
20
+ }
21
+
22
+ /**
23
+ * Евклидово расстояние между двумя точками
24
+ *
25
+ * ```ts
26
+ * import { distancePoint } from './math';
27
+ * import * as assert from 'node:assert/strict';
28
+ *
29
+ * assert.equal(distancePoint([1, 1], [4, 5]), 5)
30
+ * ```
31
+ */
32
+ export function distancePoint(
33
+ [x1, y1]: readonly [number, number],
34
+ [x2, y2]: readonly [number, number],
35
+ ): number {
36
+ return distance(x1, y1, x2, y2);
37
+ }
@@ -0,0 +1,81 @@
1
+ import { type DeepReadonly } from '../../../types';
2
+ import * as array from '../../array';
3
+ import { cubicBezierTwoDimensional } from '../../curve';
4
+ import { distancePoint } from '../../math';
5
+ import type { SVGPathSupport } from './path';
6
+ import { type Point, type Points } from './point';
7
+
8
+ export interface MaxSegmentLengthOptions {
9
+ maxSegmentLength?: number;
10
+ }
11
+
12
+ /**
13
+ * Аппроксимирует кривую Безье в точки
14
+ */
15
+ function approximateCurves(
16
+ prevPoint: [number, number],
17
+ args: [number, number, number, number, number, number],
18
+ { maxSegmentLength }: Required<MaxSegmentLengthOptions>,
19
+ ): Points {
20
+ const distancePoints = distancePoint([args[4], args[5]], prevPoint);
21
+ const acc: Points = new Array(Math.ceil(Math.max(2, distancePoints / maxSegmentLength)));
22
+
23
+ for (let index = 0; index < acc.length; index++) {
24
+ const progress = Math.min(1, (maxSegmentLength / distancePoints) * index);
25
+
26
+ acc[index] = cubicBezierTwoDimensional(
27
+ prevPoint[0],
28
+ prevPoint[1],
29
+ args[0],
30
+ args[1],
31
+ args[2],
32
+ args[3],
33
+ args[4],
34
+ args[5],
35
+ progress,
36
+ );
37
+ }
38
+
39
+ return acc;
40
+ }
41
+
42
+ /**
43
+ * Аппроксимирует svg путь в точки
44
+ *
45
+ * ```ts
46
+ * import * as approximate from './approximate';
47
+ * import * as assert from 'node:assert/strict';
48
+ *
49
+ * assert.equal(
50
+ * approximate.approximateRing([['M', [20, 40]], ['L', [40, 60]]]),
51
+ * [[20, 40], [40, 60]],
52
+ * );
53
+ * ```
54
+ */
55
+ export function approximateRing(
56
+ path: DeepReadonly<SVGPathSupport>,
57
+ { maxSegmentLength = 1 }: MaxSegmentLengthOptions = {},
58
+ ): Points {
59
+ const prevPoint: Point = [0, 0];
60
+
61
+ return path.reduce<Points>((acc, [command, args]) => {
62
+ switch (command) {
63
+ case 'M':
64
+ case 'L':
65
+ acc.push(array.copy(args));
66
+ prevPoint[0] = args[0];
67
+ prevPoint[1] = args[1];
68
+ break;
69
+ case 'C':
70
+ acc.push(...approximateCurves(prevPoint, array.copy(args), { maxSegmentLength }));
71
+ prevPoint[0] = args[4];
72
+ prevPoint[1] = args[5];
73
+
74
+ break;
75
+ case 'Z':
76
+ break;
77
+ }
78
+
79
+ return acc;
80
+ }, []);
81
+ }