@vkontakte/vkui 4.26.0 → 4.27.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 (299) hide show
  1. package/.cache/.eslintcache +1 -1
  2. package/.cache/.stylelintcache +1 -1
  3. package/.cache/.tsbuildinfo +210 -85
  4. package/.cache/ts/src/components/ActionSheetItem/ActionSheetItem.d.ts +1 -2
  5. package/.cache/ts/src/components/Alert/Alert.d.ts +1 -2
  6. package/.cache/ts/src/components/AppearanceProvider/AppearanceProvider.d.ts +1 -0
  7. package/.cache/ts/src/components/Card/Card.d.ts +1 -2
  8. package/.cache/ts/src/components/CardScroll/CardScroll.d.ts +4 -7
  9. package/.cache/ts/src/components/Chip/Chip.d.ts +2 -2
  10. package/.cache/ts/src/components/ConfigProvider/ConfigProvider.d.ts +1 -1
  11. package/.cache/ts/src/components/ConfigProvider/ConfigProviderContext.d.ts +5 -5
  12. package/.cache/ts/src/components/Gradient/Gradient.d.ts +1 -2
  13. package/.cache/ts/src/components/SegmentedControl/SegmentedControl.d.ts +17 -0
  14. package/.cache/ts/src/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.d.ts +4 -0
  15. package/.cache/ts/src/components/SliderSwitch/SliderSwitch.d.ts +6 -2
  16. package/.cache/ts/src/components/SliderSwitch/SliderSwitchButton.d.ts +4 -2
  17. package/.cache/ts/src/components/Switch/Switch.d.ts +3 -2
  18. package/.cache/ts/src/components/Typography/Title/Title.d.ts +4 -1
  19. package/.cache/ts/src/components/VisuallyHiddenInput/VisuallyHiddenInput.d.ts +12 -0
  20. package/.cache/ts/src/hooks/usePlatform.d.ts +1 -1
  21. package/.cache/ts/src/index.d.ts +7 -5
  22. package/.cache/ts/src/lib/utils.d.ts +1 -0
  23. package/.cache/ts/src/tokenized/index.d.ts +6 -0
  24. package/VKUI_TOKENS_MIGRATION_GUIDE.md +2 -1
  25. package/dist/cjs/components/ActionSheetItem/ActionSheetItem.d.ts +1 -2
  26. package/dist/cjs/components/ActionSheetItem/ActionSheetItem.js +16 -10
  27. package/dist/cjs/components/ActionSheetItem/ActionSheetItem.js.map +1 -1
  28. package/dist/cjs/components/Alert/Alert.d.ts +1 -2
  29. package/dist/cjs/components/Alert/Alert.js +12 -12
  30. package/dist/cjs/components/Alert/Alert.js.map +1 -1
  31. package/dist/cjs/components/AppearanceProvider/AppearanceProvider.d.ts +1 -0
  32. package/dist/cjs/components/AppearanceProvider/AppearanceProvider.js +29 -2
  33. package/dist/cjs/components/AppearanceProvider/AppearanceProvider.js.map +1 -1
  34. package/dist/cjs/components/Banner/Banner.js +1 -1
  35. package/dist/cjs/components/Banner/Banner.js.map +1 -1
  36. package/dist/cjs/components/Button/Button.js +9 -1
  37. package/dist/cjs/components/Button/Button.js.map +1 -1
  38. package/dist/cjs/components/Card/Card.d.ts +1 -2
  39. package/dist/cjs/components/Card/Card.js +4 -8
  40. package/dist/cjs/components/Card/Card.js.map +1 -1
  41. package/dist/cjs/components/CardScroll/CardScroll.d.ts +4 -7
  42. package/dist/cjs/components/CardScroll/CardScroll.js +11 -15
  43. package/dist/cjs/components/CardScroll/CardScroll.js.map +1 -1
  44. package/dist/cjs/components/Chip/Chip.d.ts +2 -2
  45. package/dist/cjs/components/Chip/Chip.js +3 -5
  46. package/dist/cjs/components/Chip/Chip.js.map +1 -1
  47. package/dist/cjs/components/ChipsInput/ChipsInput.js +2 -2
  48. package/dist/cjs/components/ChipsInput/ChipsInput.js.map +1 -1
  49. package/dist/cjs/components/ConfigProvider/ConfigProvider.d.ts +1 -1
  50. package/dist/cjs/components/ConfigProvider/ConfigProvider.js +1 -26
  51. package/dist/cjs/components/ConfigProvider/ConfigProvider.js.map +1 -1
  52. package/dist/cjs/components/ConfigProvider/ConfigProviderContext.d.ts +5 -5
  53. package/dist/cjs/components/ConfigProvider/ConfigProviderContext.js.map +1 -1
  54. package/dist/cjs/components/ContentCard/ContentCard.js +4 -4
  55. package/dist/cjs/components/ContentCard/ContentCard.js.map +1 -1
  56. package/dist/cjs/components/Gradient/Gradient.d.ts +1 -2
  57. package/dist/cjs/components/Gradient/Gradient.js +6 -10
  58. package/dist/cjs/components/Gradient/Gradient.js.map +1 -1
  59. package/dist/cjs/components/Header/Header.js +1 -1
  60. package/dist/cjs/components/Header/Header.js.map +1 -1
  61. package/dist/cjs/components/ModalCardBase/ModalCardBase.js +1 -1
  62. package/dist/cjs/components/ModalCardBase/ModalCardBase.js.map +1 -1
  63. package/dist/cjs/components/PanelHeaderButton/PanelHeaderButton.js +1 -1
  64. package/dist/cjs/components/PanelHeaderButton/PanelHeaderButton.js.map +1 -1
  65. package/dist/cjs/components/Placeholder/Placeholder.js +1 -1
  66. package/dist/cjs/components/Placeholder/Placeholder.js.map +1 -1
  67. package/dist/cjs/components/Search/Search.js +47 -23
  68. package/dist/cjs/components/Search/Search.js.map +1 -1
  69. package/dist/cjs/components/SegmentedControl/SegmentedControl.d.ts +17 -0
  70. package/dist/cjs/components/SegmentedControl/SegmentedControl.js +116 -0
  71. package/dist/cjs/components/SegmentedControl/SegmentedControl.js.map +1 -0
  72. package/dist/cjs/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.d.ts +4 -0
  73. package/dist/cjs/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js +61 -0
  74. package/dist/cjs/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js.map +1 -0
  75. package/dist/cjs/components/SimpleCell/SimpleCell.js +21 -8
  76. package/dist/cjs/components/SimpleCell/SimpleCell.js.map +1 -1
  77. package/dist/cjs/components/SliderSwitch/SliderSwitch.d.ts +6 -2
  78. package/dist/cjs/components/SliderSwitch/SliderSwitch.js +18 -6
  79. package/dist/cjs/components/SliderSwitch/SliderSwitch.js.map +1 -1
  80. package/dist/cjs/components/SliderSwitch/SliderSwitchButton.d.ts +4 -2
  81. package/dist/cjs/components/SliderSwitch/SliderSwitchButton.js +6 -5
  82. package/dist/cjs/components/SliderSwitch/SliderSwitchButton.js.map +1 -1
  83. package/dist/cjs/components/Switch/Switch.d.ts +3 -2
  84. package/dist/cjs/components/Switch/Switch.js +3 -6
  85. package/dist/cjs/components/Switch/Switch.js.map +1 -1
  86. package/dist/cjs/components/Typography/Title/Title.d.ts +4 -1
  87. package/dist/cjs/components/Typography/Title/Title.js +9 -19
  88. package/dist/cjs/components/Typography/Title/Title.js.map +1 -1
  89. package/dist/cjs/components/VisuallyHiddenInput/VisuallyHiddenInput.d.ts +12 -0
  90. package/dist/cjs/components/VisuallyHiddenInput/VisuallyHiddenInput.js +37 -0
  91. package/dist/cjs/components/VisuallyHiddenInput/VisuallyHiddenInput.js.map +1 -0
  92. package/dist/cjs/hooks/usePlatform.d.ts +1 -1
  93. package/dist/cjs/hooks/usePlatform.js.map +1 -1
  94. package/dist/cjs/index.d.ts +7 -5
  95. package/dist/cjs/index.js +18 -10
  96. package/dist/cjs/index.js.map +1 -1
  97. package/dist/cjs/lib/utils.d.ts +1 -0
  98. package/dist/cjs/lib/utils.js +7 -0
  99. package/dist/cjs/lib/utils.js.map +1 -1
  100. package/dist/cjs/tokenized/index.d.ts +6 -0
  101. package/dist/cjs/tokenized/index.js +24 -0
  102. package/dist/cjs/tokenized/index.js.map +1 -1
  103. package/dist/components/ActionSheetItem/ActionSheetItem.d.ts +1 -2
  104. package/dist/components/ActionSheetItem/ActionSheetItem.js +14 -10
  105. package/dist/components/ActionSheetItem/ActionSheetItem.js.map +1 -1
  106. package/dist/components/Alert/Alert.d.ts +1 -2
  107. package/dist/components/Alert/Alert.js +11 -12
  108. package/dist/components/Alert/Alert.js.map +1 -1
  109. package/dist/components/AppearanceProvider/AppearanceProvider.d.ts +1 -0
  110. package/dist/components/AppearanceProvider/AppearanceProvider.js +24 -1
  111. package/dist/components/AppearanceProvider/AppearanceProvider.js.map +1 -1
  112. package/dist/components/Banner/Banner.js +1 -1
  113. package/dist/components/Banner/Banner.js.map +1 -1
  114. package/dist/components/Button/Button.js +9 -2
  115. package/dist/components/Button/Button.js.map +1 -1
  116. package/dist/components/Card/Card.d.ts +1 -2
  117. package/dist/components/Card/Card.js +3 -9
  118. package/dist/components/Card/Card.js.map +1 -1
  119. package/dist/components/CardScroll/CardScroll.d.ts +4 -7
  120. package/dist/components/CardScroll/CardScroll.js +9 -14
  121. package/dist/components/CardScroll/CardScroll.js.map +1 -1
  122. package/dist/components/Chip/Chip.d.ts +2 -2
  123. package/dist/components/Chip/Chip.js +2 -6
  124. package/dist/components/Chip/Chip.js.map +1 -1
  125. package/dist/components/ChipsInput/ChipsInput.js +1 -1
  126. package/dist/components/ChipsInput/ChipsInput.js.map +1 -1
  127. package/dist/components/ConfigProvider/ConfigProvider.d.ts +1 -1
  128. package/dist/components/ConfigProvider/ConfigProvider.js +1 -25
  129. package/dist/components/ConfigProvider/ConfigProvider.js.map +1 -1
  130. package/dist/components/ConfigProvider/ConfigProviderContext.d.ts +5 -5
  131. package/dist/components/ConfigProvider/ConfigProviderContext.js.map +1 -1
  132. package/dist/components/ContentCard/ContentCard.js +3 -3
  133. package/dist/components/ContentCard/ContentCard.js.map +1 -1
  134. package/dist/components/Gradient/Gradient.d.ts +1 -2
  135. package/dist/components/Gradient/Gradient.js +5 -11
  136. package/dist/components/Gradient/Gradient.js.map +1 -1
  137. package/dist/components/Header/Header.js +1 -1
  138. package/dist/components/Header/Header.js.map +1 -1
  139. package/dist/components/ModalCardBase/ModalCardBase.js +2 -2
  140. package/dist/components/ModalCardBase/ModalCardBase.js.map +1 -1
  141. package/dist/components/PanelHeaderButton/PanelHeaderButton.js +1 -1
  142. package/dist/components/PanelHeaderButton/PanelHeaderButton.js.map +1 -1
  143. package/dist/components/Placeholder/Placeholder.js +1 -1
  144. package/dist/components/Placeholder/Placeholder.js.map +1 -1
  145. package/dist/components/Search/Search.js +45 -22
  146. package/dist/components/Search/Search.js.map +1 -1
  147. package/dist/components/SegmentedControl/SegmentedControl.d.ts +17 -0
  148. package/dist/components/SegmentedControl/SegmentedControl.js +94 -0
  149. package/dist/components/SegmentedControl/SegmentedControl.js.map +1 -0
  150. package/dist/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.d.ts +4 -0
  151. package/dist/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js +40 -0
  152. package/dist/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js.map +1 -0
  153. package/dist/components/SimpleCell/SimpleCell.js +21 -9
  154. package/dist/components/SimpleCell/SimpleCell.js.map +1 -1
  155. package/dist/components/SliderSwitch/SliderSwitch.d.ts +6 -2
  156. package/dist/components/SliderSwitch/SliderSwitch.js +14 -3
  157. package/dist/components/SliderSwitch/SliderSwitch.js.map +1 -1
  158. package/dist/components/SliderSwitch/SliderSwitchButton.d.ts +4 -2
  159. package/dist/components/SliderSwitch/SliderSwitchButton.js +5 -5
  160. package/dist/components/SliderSwitch/SliderSwitchButton.js.map +1 -1
  161. package/dist/components/Switch/Switch.d.ts +3 -2
  162. package/dist/components/Switch/Switch.js +3 -6
  163. package/dist/components/Switch/Switch.js.map +1 -1
  164. package/dist/components/Typography/Title/Title.d.ts +4 -1
  165. package/dist/components/Typography/Title/Title.js +7 -16
  166. package/dist/components/Typography/Title/Title.js.map +1 -1
  167. package/dist/components/VisuallyHiddenInput/VisuallyHiddenInput.d.ts +12 -0
  168. package/dist/components/VisuallyHiddenInput/VisuallyHiddenInput.js +23 -0
  169. package/dist/components/VisuallyHiddenInput/VisuallyHiddenInput.js.map +1 -0
  170. package/dist/components.css +5 -5
  171. package/dist/components.css.map +1 -1
  172. package/dist/cssm/components/ActionSheetItem/ActionSheetItem.js +14 -10
  173. package/dist/cssm/components/ActionSheetItem/ActionSheetItem.js.map +1 -1
  174. package/dist/cssm/components/Alert/Alert.js +11 -12
  175. package/dist/cssm/components/Alert/Alert.js.map +1 -1
  176. package/dist/cssm/components/AppearanceProvider/AppearanceProvider.js +24 -1
  177. package/dist/cssm/components/AppearanceProvider/AppearanceProvider.js.map +1 -1
  178. package/dist/cssm/components/Banner/Banner.js +1 -1
  179. package/dist/cssm/components/Banner/Banner.js.map +1 -1
  180. package/dist/cssm/components/Button/Button.js +9 -2
  181. package/dist/cssm/components/Button/Button.js.map +1 -1
  182. package/dist/cssm/components/Card/Card.css +2 -2
  183. package/dist/cssm/components/Card/Card.js +3 -9
  184. package/dist/cssm/components/Card/Card.js.map +1 -1
  185. package/dist/cssm/components/CardScroll/CardScroll.css +1 -1
  186. package/dist/cssm/components/CardScroll/CardScroll.js +9 -14
  187. package/dist/cssm/components/CardScroll/CardScroll.js.map +1 -1
  188. package/dist/cssm/components/Chip/Chip.js +2 -6
  189. package/dist/cssm/components/Chip/Chip.js.map +1 -1
  190. package/dist/cssm/components/ChipsInput/ChipsInput.js +1 -1
  191. package/dist/cssm/components/ChipsInput/ChipsInput.js.map +1 -1
  192. package/dist/cssm/components/ConfigProvider/ConfigProvider.js +1 -25
  193. package/dist/cssm/components/ConfigProvider/ConfigProvider.js.map +1 -1
  194. package/dist/cssm/components/ConfigProvider/ConfigProviderContext.js.map +1 -1
  195. package/dist/cssm/components/ContentCard/ContentCard.js +3 -3
  196. package/dist/cssm/components/ContentCard/ContentCard.js.map +1 -1
  197. package/dist/cssm/components/FocusVisible/FocusVisible.css +1 -1
  198. package/dist/cssm/components/Gradient/Gradient.js +5 -11
  199. package/dist/cssm/components/Gradient/Gradient.js.map +1 -1
  200. package/dist/cssm/components/Header/Header.js +1 -1
  201. package/dist/cssm/components/Header/Header.js.map +1 -1
  202. package/dist/cssm/components/ModalCardBase/ModalCardBase.js +2 -2
  203. package/dist/cssm/components/ModalCardBase/ModalCardBase.js.map +1 -1
  204. package/dist/cssm/components/PanelHeaderButton/PanelHeaderButton.js +1 -1
  205. package/dist/cssm/components/PanelHeaderButton/PanelHeaderButton.js.map +1 -1
  206. package/dist/cssm/components/Placeholder/Placeholder.js +1 -1
  207. package/dist/cssm/components/Placeholder/Placeholder.js.map +1 -1
  208. package/dist/cssm/components/Search/Search.js +45 -22
  209. package/dist/cssm/components/Search/Search.js.map +1 -1
  210. package/dist/cssm/components/SegmentedControl/SegmentedControl.css +1 -0
  211. package/dist/cssm/components/SegmentedControl/SegmentedControl.js +95 -0
  212. package/dist/cssm/components/SegmentedControl/SegmentedControl.js.map +1 -0
  213. package/dist/cssm/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.css +1 -0
  214. package/dist/cssm/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js +41 -0
  215. package/dist/cssm/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.js.map +1 -0
  216. package/dist/cssm/components/SimpleCell/SimpleCell.js +21 -9
  217. package/dist/cssm/components/SimpleCell/SimpleCell.js.map +1 -1
  218. package/dist/cssm/components/SliderSwitch/SliderSwitch.js +14 -3
  219. package/dist/cssm/components/SliderSwitch/SliderSwitch.js.map +1 -1
  220. package/dist/cssm/components/SliderSwitch/SliderSwitchButton.js +5 -5
  221. package/dist/cssm/components/SliderSwitch/SliderSwitchButton.js.map +1 -1
  222. package/dist/cssm/components/Switch/Switch.css +1 -1
  223. package/dist/cssm/components/Switch/Switch.js +3 -6
  224. package/dist/cssm/components/Switch/Switch.js.map +1 -1
  225. package/dist/cssm/components/Typography/Title/Title.css +1 -1
  226. package/dist/cssm/components/Typography/Title/Title.js +7 -16
  227. package/dist/cssm/components/Typography/Title/Title.js.map +1 -1
  228. package/dist/cssm/components/VisuallyHiddenInput/VisuallyHiddenInput.css +1 -0
  229. package/dist/cssm/components/VisuallyHiddenInput/VisuallyHiddenInput.js +24 -0
  230. package/dist/cssm/components/VisuallyHiddenInput/VisuallyHiddenInput.js.map +1 -0
  231. package/dist/cssm/hooks/usePlatform.js.map +1 -1
  232. package/dist/cssm/index.js +6 -5
  233. package/dist/cssm/index.js.map +1 -1
  234. package/dist/cssm/lib/utils.js +3 -0
  235. package/dist/cssm/lib/utils.js.map +1 -1
  236. package/dist/cssm/styles/components.css +5 -5
  237. package/dist/cssm/styles/themes.css +1 -1
  238. package/dist/cssm/tokenized/index.js +3 -0
  239. package/dist/cssm/tokenized/index.js.map +1 -1
  240. package/dist/hooks/usePlatform.d.ts +1 -1
  241. package/dist/hooks/usePlatform.js.map +1 -1
  242. package/dist/index.d.ts +7 -5
  243. package/dist/index.js +6 -5
  244. package/dist/index.js.map +1 -1
  245. package/dist/lib/utils.d.ts +1 -0
  246. package/dist/lib/utils.js +3 -0
  247. package/dist/lib/utils.js.map +1 -1
  248. package/dist/tokenized/index.d.ts +6 -0
  249. package/dist/tokenized/index.js +3 -0
  250. package/dist/tokenized/index.js.map +1 -1
  251. package/dist/vkui.css +6 -6
  252. package/dist/vkui.css.map +1 -1
  253. package/package.json +2 -2
  254. package/src/components/ActionSheetItem/ActionSheetItem.tsx +26 -24
  255. package/src/components/Alert/Alert.tsx +5 -7
  256. package/src/components/AppearanceProvider/AppearanceProvider.tsx +25 -1
  257. package/src/components/Banner/Banner.tsx +1 -1
  258. package/src/components/Button/Button.tsx +6 -3
  259. package/src/components/Card/Card.css +41 -0
  260. package/src/components/Card/Card.tsx +2 -9
  261. package/src/components/CardScroll/CardScroll.css +2 -39
  262. package/src/components/CardScroll/CardScroll.tsx +7 -17
  263. package/src/components/CardScroll/Readme.md +3 -2
  264. package/src/components/Chip/Chip.tsx +1 -4
  265. package/src/components/ChipsInput/ChipsInput.tsx +1 -1
  266. package/src/components/ConfigProvider/ConfigProvider.tsx +6 -25
  267. package/src/components/ConfigProvider/ConfigProviderContext.tsx +5 -5
  268. package/src/components/ContentCard/ContentCard.tsx +2 -2
  269. package/src/components/FocusVisible/FocusVisible.css +4 -8
  270. package/src/components/FormItem/Readme.md +14 -2
  271. package/src/components/Gradient/Gradient.tsx +4 -12
  272. package/src/components/Gradient/Readme.md +1 -1
  273. package/src/components/Header/Header.tsx +1 -1
  274. package/src/components/ModalCardBase/ModalCardBase.tsx +2 -2
  275. package/src/components/ModalRoot/Readme.md +1 -1
  276. package/src/components/PanelHeaderButton/PanelHeaderButton.tsx +1 -5
  277. package/src/components/Placeholder/Placeholder.tsx +1 -1
  278. package/src/components/Search/Search.tsx +38 -14
  279. package/src/components/SegmentedControl/Readme.md +94 -0
  280. package/src/components/SegmentedControl/SegmentedControl.css +42 -0
  281. package/src/components/SegmentedControl/SegmentedControl.tsx +105 -0
  282. package/src/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.css +30 -0
  283. package/src/components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.tsx +42 -0
  284. package/src/components/SimpleCell/SimpleCell.tsx +10 -6
  285. package/src/components/SliderSwitch/Readme.md +4 -0
  286. package/src/components/SliderSwitch/SliderSwitch.tsx +17 -3
  287. package/src/components/SliderSwitch/SliderSwitchButton.tsx +4 -4
  288. package/src/components/Switch/Switch.css +0 -12
  289. package/src/components/Switch/Switch.tsx +8 -10
  290. package/src/components/Typography/Title/Readme.md +28 -41
  291. package/src/components/Typography/Title/Title.css +22 -13
  292. package/src/components/Typography/Title/Title.tsx +27 -22
  293. package/src/components/VisuallyHiddenInput/VisuallyHiddenInput.css +9 -0
  294. package/src/components/VisuallyHiddenInput/VisuallyHiddenInput.tsx +25 -0
  295. package/src/hooks/usePlatform.ts +1 -1
  296. package/src/index.ts +11 -5
  297. package/src/lib/utils.ts +6 -0
  298. package/src/styles/components.css +3 -0
  299. package/src/tokenized/index.ts +13 -0
@@ -1,44 +1,31 @@
1
- Упрощения в Android-версии (происходят автоматически):
1
+ Семейство заголовков.
2
2
 
3
- - `semibold` превращается в `medium`
4
- - `heavy` превращается в `bold`
5
- - `<Title level="3" />` превращается в `<Headline />`
3
+ ```jsx { "props": { "layout": false, "iframe": false } }
4
+ <div style={{ padding: 20 }}>
5
+ <Title level="1" style={{ marginBottom: 16 }}>
6
+ Title 1
7
+ </Title>
8
+ <Title level="2" style={{ marginBottom: 16 }}>
9
+ Title 2
10
+ </Title>
11
+ <Title level="3">Title 3</Title>
12
+ </div>
13
+ ```
14
+
15
+ ## Кастомизация
16
+
17
+ Есть возможность переопределить жирность.
6
18
 
7
- ```jsx
8
- <View activePanel="test">
9
- <Panel id="test">
10
- <PanelHeader>Title</PanelHeader>
11
- <Group>
12
- <Div>
13
- <Title level="1" weight="semibold" style={{ marginBottom: 16 }}>
14
- Title 1 semibold
15
- </Title>
16
- <Title level="1" weight="bold" style={{ marginBottom: 16 }}>
17
- Title 1 bold
18
- </Title>
19
- <Title level="1" weight="heavy" style={{ marginBottom: 16 }}>
20
- Title 1 heavy
21
- </Title>
22
- <Title level="2" weight="regular" style={{ marginBottom: 16 }}>
23
- Title 2 regular
24
- </Title>
25
- <Title level="2" weight="semibold" style={{ marginBottom: 16 }}>
26
- Title 2 semibold
27
- </Title>
28
- <Title level="2" weight="heavy" style={{ marginBottom: 16 }}>
29
- Title 2 heavy
30
- </Title>
31
- <Title level="3" weight="regular" style={{ marginBottom: 16 }}>
32
- Title 3 regular
33
- </Title>
34
- <Title level="3" weight="medium" style={{ marginBottom: 16 }}>
35
- Title 3 medium
36
- </Title>
37
- <Title level="3" weight="semibold">
38
- Title 3 semibold
39
- </Title>
40
- </Div>
41
- </Group>
42
- </Panel>
43
- </View>
19
+ ```jsx { "props": { "layout": false, "iframe": false } }
20
+ <div style={{ padding: 20 }}>
21
+ <Title level="3" weight="1" style={{ marginBottom: 16 }}>
22
+ Title 3 weight 1
23
+ </Title>
24
+ <Title level="3" weight="2" style={{ marginBottom: 16 }}>
25
+ Title 3 weight 2
26
+ </Title>
27
+ <Title level="3" weight="3">
28
+ Title 3 weight 3
29
+ </Title>
30
+ </div>
44
31
  ```
@@ -4,47 +4,56 @@
4
4
  }
5
5
 
6
6
  .Title--l-1 {
7
- font-size: 24px;
8
- line-height: 28px;
7
+ font-size: var(--vkui--font_title1--font_size--regular);
8
+ line-height: var(--vkui--font_title1--line_height--regular);
9
+ font-weight: var(--vkui--font_title1--font_weight--regular);
9
10
  }
10
11
 
11
12
  .Title--l-2 {
12
- font-size: 20px;
13
- line-height: 24px;
13
+ font-size: var(--vkui--font_title2--font_size--regular);
14
+ line-height: var(--vkui--font_title2--line_height--regular);
15
+ font-weight: var(--vkui--font_title2--font_weight--regular);
14
16
  }
15
17
 
16
18
  .Title--l-3 {
17
- font-size: 17px;
18
- line-height: 22px;
19
+ font-size: var(--vkui--font_title3--font_size--regular);
20
+ line-height: var(--vkui--font_title3--line_height--regular);
21
+ font-weight: var(--vkui--font_title3--font_weight--regular);
19
22
  }
20
23
 
24
+ /* TODO удалить перед релизом 5.0.0 */
21
25
  .Title--w-regular {
22
26
  font-weight: 400;
23
27
  }
24
28
 
29
+ /* TODO удалить перед релизом 5.0.0 */
25
30
  .Title--w-medium {
26
31
  font-weight: 500;
27
32
  }
28
33
 
34
+ /* TODO удалить перед релизом 5.0.0 */
29
35
  .Title--w-semibold {
30
36
  font-weight: 600;
31
37
  }
32
38
 
39
+ /* TODO удалить перед релизом 5.0.0 */
33
40
  .Title--w-bold {
34
41
  font-weight: 700;
35
42
  }
36
43
 
44
+ /* TODO удалить перед релизом 5.0.0 */
37
45
  .Title--w-heavy {
38
46
  font-weight: 800;
39
47
  }
40
48
 
41
- /**
42
- * ANDROID
43
- */
44
- .Title--android.Title--w-semibold {
45
- font-weight: 500;
49
+ .Title--w-1 {
50
+ font-weight: var(--vkui--font_weight_accent1);
46
51
  }
47
52
 
48
- .Title--android.Title--w-heavy {
49
- font-weight: 700;
53
+ .Title--w-2 {
54
+ font-weight: var(--vkui--font_weight_accent2);
55
+ }
56
+
57
+ .Title--w-3 {
58
+ font-weight: var(--vkui--font_weight_accent3);
50
59
  }
@@ -1,51 +1,56 @@
1
1
  import * as React from "react";
2
2
  import { HasComponent } from "../../../types";
3
- import { usePlatform } from "../../../hooks/usePlatform";
4
3
  import { classNames } from "../../../lib/classNames";
5
- import { getClassName } from "../../../helpers/getClassName";
6
- import { ANDROID } from "../../../lib/platform";
7
- import Headline, { HeadlineProps } from "../Headline/Headline";
4
+ import { warnOnce } from "../../../lib/warnOnce";
8
5
  import "./Title.css";
9
6
 
10
7
  export interface TitleProps
11
8
  extends React.AllHTMLAttributes<HTMLElement>,
12
9
  HasComponent {
13
- weight: "heavy" | "bold" | "semibold" | "medium" | "regular";
10
+ /**
11
+ * Начертания "heavy", "bold", "semibold", "medium" и "regular" устарели и будут удалены в 5.0.0.
12
+ */
13
+ weight?:
14
+ | "heavy"
15
+ | "bold"
16
+ | "semibold"
17
+ | "medium"
18
+ | "regular"
19
+ | "1"
20
+ | "2"
21
+ | "3";
14
22
  level: "1" | "2" | "3";
15
23
  }
16
24
 
25
+ const warn = warnOnce("Title");
26
+
17
27
  const Title: React.FC<TitleProps> = ({
18
28
  children,
19
- weight = "regular",
29
+ weight,
20
30
  level = "1",
21
31
  Component,
22
32
  ...restProps
23
33
  }: TitleProps) => {
24
- const platform = usePlatform();
25
-
26
34
  if (!Component) {
27
35
  Component = ("h" + level) as React.ElementType;
28
36
  }
29
37
 
30
- if (platform === ANDROID && level === "3") {
31
- const headlineWeight: HeadlineProps["weight"] =
32
- weight === "regular" ? weight : "medium";
33
-
34
- return (
35
- <Headline Component={Component} {...restProps} weight={headlineWeight}>
36
- {children}
37
- </Headline>
38
- );
38
+ if (process.env.NODE_ENV === "development") {
39
+ if (
40
+ weight &&
41
+ ["heavy", "bold", "semibold", "medium", "regular"].includes(weight)
42
+ )
43
+ warn(
44
+ `Начертание "${weight}" устарело и будет удалено в 5.0.0. Используйте значения "1", "2" и "3"`
45
+ );
39
46
  }
40
47
 
41
48
  return (
42
49
  <Component
43
50
  {...restProps}
44
- vkuiClass={classNames(
45
- getClassName("Title", platform),
46
- `Title--w-${weight}`,
47
- `Title--l-${level}`
48
- )}
51
+ vkuiClass={classNames("Title", `Title--l-${level}`, {
52
+ [`Title--w-${weight}`]: !!weight,
53
+ })}
49
54
  >
50
55
  {children}
51
56
  </Component>
@@ -0,0 +1,9 @@
1
+ .VisuallyHiddenInput {
2
+ position: absolute;
3
+ height: 1px;
4
+ white-space: nowrap;
5
+ clip: rect(0 0 0 0);
6
+ clip-path: inset(50%);
7
+ overflow: hidden;
8
+ opacity: 0;
9
+ }
@@ -0,0 +1,25 @@
1
+ import * as React from "react";
2
+ import { useExternRef } from "../../hooks/useExternRef";
3
+ import { HasRef } from "../../types";
4
+ import "./VisuallyHiddenInput.css";
5
+
6
+ export interface VisuallyHiddenInputProps
7
+ extends React.InputHTMLAttributes<HTMLInputElement>,
8
+ HasRef<HTMLInputElement> {}
9
+
10
+ /**
11
+ * @description
12
+ * Обертка над обычным `<input/>`; дает
13
+ * скрыть его визуально и оставить
14
+ * доступным для ассистивных технологий.
15
+ */
16
+ export const VisuallyHiddenInput: React.FC<VisuallyHiddenInputProps> = ({
17
+ getRef,
18
+ ...restProps
19
+ }) => {
20
+ const inputRef = useExternRef(getRef);
21
+
22
+ return (
23
+ <input {...restProps} vkuiClass="VisuallyHiddenInput" ref={inputRef} />
24
+ );
25
+ };
@@ -3,7 +3,7 @@ import { PlatformType } from "../lib/platform";
3
3
  import { SSRContext } from "../lib/SSR";
4
4
  import { ConfigProviderContext } from "../components/ConfigProvider/ConfigProviderContext";
5
5
 
6
- export function usePlatform(): PlatformType | undefined {
6
+ export function usePlatform(): PlatformType {
7
7
  const ssrContext = React.useContext(SSRContext);
8
8
  const { platform } = React.useContext(ConfigProviderContext);
9
9
  return ssrContext.platform || platform;
package/src/index.ts CHANGED
@@ -80,11 +80,11 @@ export { default as Button } from "./components/Button/Button";
80
80
  export type { ButtonProps } from "./components/Button/Button";
81
81
  export { default as IconButton } from "./components/IconButton/IconButton";
82
82
  export type { IconButtonProps } from "./components/IconButton/IconButton";
83
- export { default as Card } from "./components/Card/Card";
83
+ export { Card } from "./components/Card/Card";
84
84
  export type { CardProps } from "./components/Card/Card";
85
85
  export { default as CardGrid } from "./components/CardGrid/CardGrid";
86
86
  export type { CardGridProps } from "./components/CardGrid/CardGrid";
87
- export { default as CardScroll } from "./components/CardScroll/CardScroll";
87
+ export { CardScroll } from "./components/CardScroll/CardScroll";
88
88
  export type { CardScrollProps } from "./components/CardScroll/CardScroll";
89
89
  export { default as ContentCard } from "./components/ContentCard/ContentCard";
90
90
  export type { ContentCardProps } from "./components/ContentCard/ContentCard";
@@ -94,7 +94,7 @@ export { default as Header } from "./components/Header/Header";
94
94
  export type { HeaderProps } from "./components/Header/Header";
95
95
  export { default as Group } from "./components/Group/Group";
96
96
  export type { GroupProps } from "./components/Group/Group";
97
- export { default as Gradient } from "./components/Gradient/Gradient";
97
+ export { Gradient } from "./components/Gradient/Gradient";
98
98
  export type { GradientProps } from "./components/Gradient/Gradient";
99
99
  export { default as List } from "./components/List/List";
100
100
  export { Cell } from "./components/Cell/Cell";
@@ -176,7 +176,7 @@ export { default as File } from "./components/File/File";
176
176
  export type { FileProps } from "./components/File/File";
177
177
  export { default as Input } from "./components/Input/Input";
178
178
  export type { InputProps } from "./components/Input/Input";
179
- export { default as Chip } from "./components/Chip/Chip";
179
+ export { Chip } from "./components/Chip/Chip";
180
180
  export type { ChipProps } from "./components/Chip/Chip";
181
181
  export { default as ChipsInput } from "./components/ChipsInput/ChipsInput";
182
182
  export type { ChipsInputProps } from "./components/ChipsInput/ChipsInput";
@@ -210,11 +210,17 @@ export type {
210
210
  DatePickerProps,
211
211
  DatePickerDateFormat,
212
212
  } from "./components/DatePicker/DatePicker";
213
- export { default as SliderSwitch } from "./components/SliderSwitch/SliderSwitch";
213
+ export { SliderSwitch } from "./components/SliderSwitch/SliderSwitch";
214
214
  export type {
215
215
  SliderSwitchProps,
216
216
  SliderSwitchOptionInterface,
217
217
  } from "./components/SliderSwitch/SliderSwitch";
218
+ export { SegmentedControl } from "./components/SegmentedControl/SegmentedControl";
219
+ export type {
220
+ SegmentedControlProps,
221
+ SegmentedControlOptionInterface,
222
+ SegmentedControlValue,
223
+ } from "./components/SegmentedControl/SegmentedControl";
218
224
 
219
225
  /**
220
226
  * Helpers
package/src/lib/utils.ts CHANGED
@@ -88,3 +88,9 @@ export function getTitleFromChildren(children: React.ReactNode): string {
88
88
 
89
89
  return label;
90
90
  }
91
+
92
+ export const generateRandomId = () => {
93
+ return Math.random()
94
+ .toString(36)
95
+ .replace(/[^a-z]+/g, "");
96
+ };
@@ -126,6 +126,9 @@
126
126
  @import "../components/SliderSwitch/SliderSwitch.css";
127
127
  @import "../components/Popper/Popper.css";
128
128
  @import "../components/CustomSelectDropdown/CustomSelectDropdown.css";
129
+ @import "../components/SegmentedControl/SegmentedControl.css";
130
+ @import "../components/SegmentedControl/SegmentedControlOption/SegmentedControlOption.css";
131
+ @import "../components/VisuallyHiddenInput/VisuallyHiddenInput.css";
129
132
 
130
133
  /* Advertisement */
131
134
  @import "../components/PromoBanner/PromoBanner.css";
@@ -1,2 +1,15 @@
1
1
  export { default as Button } from "../components/Button/Button";
2
2
  export type { ButtonProps } from "../components/Button/Button";
3
+
4
+ export { Card } from "../components/Card/Card";
5
+ export type { CardProps } from "../components/Card/Card";
6
+
7
+ export { CardScroll } from "../components/CardScroll/CardScroll";
8
+ export type { CardScrollProps } from "../components/CardScroll/CardScroll";
9
+
10
+ export { SegmentedControl } from "../components/SegmentedControl/SegmentedControl";
11
+ export type {
12
+ SegmentedControlProps,
13
+ SegmentedControlOptionInterface,
14
+ SegmentedControlValue,
15
+ } from "../components/SegmentedControl/SegmentedControl";