@bifrostui/react 2.0.0-alpha.11 → 2.0.0-alpha.13

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 (475) hide show
  1. package/dist/ActionSheet/ActionSheet.d.ts +1 -1
  2. package/dist/ActionSheet/ActionSheet.js +8 -8
  3. package/dist/ActionSheet/ActionSheet.types.d.ts +1 -1
  4. package/dist/ActionSheet/ActionSheetContext.d.ts +1 -1
  5. package/dist/ActionSheet/ActionSheetContext.js +2 -2
  6. package/dist/ActionSheet/ActionSheetItem.types.d.ts +1 -1
  7. package/dist/Alert/Alert.d.ts +1 -1
  8. package/dist/Alert/Alert.js +16 -16
  9. package/dist/Alert/__tests__/fixtures/A11yDemos.d.ts +1 -1
  10. package/dist/Alert/__tests__/fixtures/A11yDemos.js +12 -12
  11. package/dist/Avatar/Avatar.d.ts +1 -1
  12. package/dist/Avatar/Avatar.js +5 -5
  13. package/dist/Avatar/Avatar.types.d.ts +1 -1
  14. package/dist/Avatar/AvatarGroup.types.d.ts +1 -1
  15. package/dist/Backdrop/Backdrop.d.ts +1 -1
  16. package/dist/Backdrop/Backdrop.js +3 -3
  17. package/dist/Backdrop/Backdrop.types.d.ts +1 -1
  18. package/dist/Backdrop/__tests__/fixtures/A11yDemos.d.ts +1 -1
  19. package/dist/Backdrop/__tests__/fixtures/A11yDemos.js +3 -3
  20. package/dist/Badge/Badge.d.ts +1 -1
  21. package/dist/Badge/Badge.js +4 -4
  22. package/dist/Badge/__tests__/fixtures/A11yDemos.d.ts +1 -1
  23. package/dist/Badge/__tests__/fixtures/A11yDemos.js +13 -13
  24. package/dist/Breadcrumb/Breadcrumb.d.ts +1 -1
  25. package/dist/Breadcrumb/Breadcrumb.js +9 -9
  26. package/dist/Breadcrumb/Breadcrumb.types.d.ts +1 -1
  27. package/dist/Breadcrumb/BreadcrumbItem.d.ts +1 -1
  28. package/dist/Breadcrumb/BreadcrumbItem.js +4 -4
  29. package/dist/Button/Button.d.ts +1 -1
  30. package/dist/Button/Button.js +6 -6
  31. package/dist/Button/Button.types.d.ts +1 -1
  32. package/dist/Button/__tests__/fixtures/A11yDemos.d.ts +1 -1
  33. package/dist/Button/__tests__/fixtures/A11yDemos.js +8 -8
  34. package/dist/Calendar/Calendar.types.d.ts +1 -1
  35. package/dist/Calendar/__tests__/fixtures/A11yDemos.d.ts +1 -1
  36. package/dist/Calendar/__tests__/fixtures/A11yDemos.js +2 -2
  37. package/dist/Card/Card.d.ts +1 -1
  38. package/dist/Card/Card.js +3 -3
  39. package/dist/Card/Card.types.d.ts +1 -1
  40. package/dist/Card/CardContent.d.ts +1 -1
  41. package/dist/Card/CardContent.js +3 -3
  42. package/dist/Card/CardContent.types.d.ts +1 -1
  43. package/dist/Card/CardFooter.d.ts +1 -1
  44. package/dist/Card/CardFooter.js +3 -3
  45. package/dist/Card/CardFooter.types.d.ts +1 -1
  46. package/dist/Card/CardHeader.d.ts +1 -1
  47. package/dist/Card/CardHeader.js +10 -10
  48. package/dist/Checkbox/CheckboxContext.d.ts +1 -1
  49. package/dist/Checkbox/CheckboxContext.js +2 -2
  50. package/dist/Checkbox/__tests__/fixtures/A11yDemos.d.ts +1 -1
  51. package/dist/Checkbox/__tests__/fixtures/A11yDemos.js +4 -4
  52. package/dist/CitySelector/CitySelector.types.d.ts +1 -0
  53. package/dist/CitySelector/Selector/index.d.ts +1 -1
  54. package/dist/CitySelector/Selector/index.js +2 -2
  55. package/dist/Collapse/Collapse.types.d.ts +1 -1
  56. package/dist/CollapsePanel/CollapsePanel.d.ts +1 -1
  57. package/dist/CollapsePanel/CollapsePanel.js +9 -9
  58. package/dist/CollapsePanel/CollapsePanel.types.d.ts +1 -1
  59. package/dist/CollapsePanel/CollapsePanelItem.d.ts +1 -1
  60. package/dist/CollapsePanel/CollapsePanelItem.js +5 -5
  61. package/dist/Countdown/Countdown.types.d.ts +2 -2
  62. package/dist/Countdown/__tests__/fixtures/A11yDemos.d.ts +1 -1
  63. package/dist/Countdown/__tests__/fixtures/A11yDemos.js +10 -10
  64. package/dist/Countdown/utils.d.ts +2 -2
  65. package/dist/Countdown/utils.js +4 -4
  66. package/dist/DatePicker/DatePicker.types.d.ts +1 -1
  67. package/dist/DesktopPicker/DesktopPicker.types.d.ts +1 -1
  68. package/dist/DesktopTimePicker/DesktopTimePicker.types.d.ts +11 -11
  69. package/dist/DesktopTimePicker/useGetTimePickerContent.js +2 -2
  70. package/dist/DesktopTimePicker/utils/utils.d.ts +1 -1
  71. package/dist/DesktopTimePicker/utils/utils.js +3 -3
  72. package/dist/Dialog/__tests__/fixtures/A11yDemos.d.ts +1 -1
  73. package/dist/Dialog/__tests__/fixtures/A11yDemos.js +4 -4
  74. package/dist/Divider/Divider.types.d.ts +1 -1
  75. package/dist/Drawer/Drawer.d.ts +1 -1
  76. package/dist/Drawer/Drawer.js +5 -5
  77. package/dist/Drawer/Drawer.types.d.ts +1 -1
  78. package/dist/Fade/Fade.d.ts +1 -1
  79. package/dist/Fade/Fade.js +4 -4
  80. package/dist/Fade/Fade.types.d.ts +1 -1
  81. package/dist/IconButton/IconButton.d.ts +1 -1
  82. package/dist/IconButton/IconButton.js +6 -6
  83. package/dist/IconButton/IconButton.types.d.ts +1 -1
  84. package/dist/Input/Input.types.d.ts +1 -1
  85. package/dist/Input/__tests__/fixtures/A11yDemos.d.ts +1 -1
  86. package/dist/Input/__tests__/fixtures/A11yDemos.js +7 -7
  87. package/dist/ItemSelector/ItemSelector.miniapp.js +7 -5
  88. package/dist/ItemSelector/ItemSelector.types.d.ts +1 -0
  89. package/dist/ItemSelector/Selector/index.d.ts +1 -1
  90. package/dist/ItemSelector/Selector/index.js +2 -2
  91. package/dist/List/List.d.ts +1 -1
  92. package/dist/List/List.js +4 -4
  93. package/dist/List/ListContext.d.ts +1 -1
  94. package/dist/List/ListContext.js +2 -2
  95. package/dist/List/ListItem.d.ts +1 -1
  96. package/dist/List/ListItem.js +8 -8
  97. package/dist/List/ListItem.types.d.ts +1 -1
  98. package/dist/List/ListItemContent.d.ts +1 -1
  99. package/dist/List/ListItemContent.js +3 -3
  100. package/dist/List/ListItemContent.types.d.ts +1 -1
  101. package/dist/List/ListItemExtra.d.ts +1 -1
  102. package/dist/List/ListItemExtra.js +3 -3
  103. package/dist/List/ListItemExtra.types.d.ts +1 -1
  104. package/dist/List/ListItemFooter.d.ts +1 -1
  105. package/dist/List/ListItemFooter.js +3 -3
  106. package/dist/List/ListItemFooter.types.d.ts +1 -1
  107. package/dist/List/ListItemHeader.d.ts +1 -1
  108. package/dist/List/ListItemHeader.js +3 -3
  109. package/dist/List/ListItemHeader.types.d.ts +1 -1
  110. package/dist/Loading/Loading.d.ts +1 -1
  111. package/dist/Loading/Loading.js +5 -5
  112. package/dist/Loading/Loading.types.d.ts +1 -1
  113. package/dist/Modal/Modal.d.ts +1 -1
  114. package/dist/Modal/Modal.js +6 -6
  115. package/dist/Modal/Modal.miniapp.d.ts +1 -1
  116. package/dist/Modal/Modal.miniapp.js +7 -7
  117. package/dist/Modal/__tests__/fixtures/A11yDemos.d.ts +1 -1
  118. package/dist/Modal/__tests__/fixtures/A11yDemos.js +3 -3
  119. package/dist/Modal/useModal.js +26 -29
  120. package/dist/NavBar/NavBar.d.ts +1 -1
  121. package/dist/NavBar/NavBar.js +10 -10
  122. package/dist/Picker/Picker.js +0 -1
  123. package/dist/Picker/Picker.types.d.ts +1 -1
  124. package/dist/Picker/__tests__/fixtures/A11yDemos.d.ts +1 -1
  125. package/dist/Picker/__tests__/fixtures/A11yDemos.js +2 -2
  126. package/dist/Popover/Popover.d.ts +1 -1
  127. package/dist/Popover/Popover.js +8 -8
  128. package/dist/Popover/Popover.types.d.ts +1 -1
  129. package/dist/Popover/__tests__/fixtures/A11yDemos.d.ts +1 -1
  130. package/dist/Popover/__tests__/fixtures/A11yDemos.js +21 -21
  131. package/dist/Portal/Portal.d.ts +1 -1
  132. package/dist/Portal/Portal.js +3 -3
  133. package/dist/Portal/Portal.types.d.ts +1 -1
  134. package/dist/Progress/Progress.d.ts +1 -1
  135. package/dist/Progress/Progress.js +4 -4
  136. package/dist/Progress/Progress.types.d.ts +1 -1
  137. package/dist/Progress/__tests__/fixtures/A11yDemos.d.ts +1 -1
  138. package/dist/Progress/__tests__/fixtures/A11yDemos.js +9 -9
  139. package/dist/Radio/RadioButtonIcon.d.ts +1 -1
  140. package/dist/Radio/RadioButtonIcon.js +4 -4
  141. package/dist/Radio/RadioContext.d.ts +1 -1
  142. package/dist/Radio/RadioContext.js +2 -2
  143. package/dist/Radio/__tests__/fixtures/A11yDemos.d.ts +1 -1
  144. package/dist/Radio/__tests__/fixtures/A11yDemos.js +4 -4
  145. package/dist/Rating/Rating.types.d.ts +1 -1
  146. package/dist/ScrollView/ScrollView.types.d.ts +1 -1
  147. package/dist/ScrollView/__tests__/fixtures/A11yDemos.d.ts +1 -1
  148. package/dist/ScrollView/__tests__/fixtures/A11yDemos.js +30 -30
  149. package/dist/ScrollView/useScrollView.js +16 -4
  150. package/dist/Skeleton/Skeleton.d.ts +1 -1
  151. package/dist/Skeleton/Skeleton.js +3 -3
  152. package/dist/Skeleton/Skeleton.types.d.ts +1 -1
  153. package/dist/Slide/Slide.d.ts +1 -1
  154. package/dist/Slide/Slide.js +4 -4
  155. package/dist/Slider/Slider.types.d.ts +1 -1
  156. package/dist/Steps/Step.types.d.ts +1 -1
  157. package/dist/Steps/StepsContext.d.ts +1 -1
  158. package/dist/Steps/StepsContext.js +2 -2
  159. package/dist/SwipeAction/SwipeAction.js +7 -8
  160. package/dist/SwipeAction/SwipeAction.types.d.ts +1 -1
  161. package/dist/Swiper/Swiper.types.d.ts +1 -1
  162. package/dist/Swiper/SwiperItem.d.ts +1 -1
  163. package/dist/Swiper/SwiperItem.js +2 -2
  164. package/dist/Switch/__tests__/fixtures/A11yDemos.d.ts +1 -1
  165. package/dist/Switch/__tests__/fixtures/A11yDemos.js +4 -4
  166. package/dist/TabBar/TabBar.d.ts +1 -1
  167. package/dist/TabBar/TabBar.js +5 -5
  168. package/dist/Tabs/Tab.css +1 -22
  169. package/dist/Tabs/Tab.d.ts +2 -2
  170. package/dist/Tabs/Tab.js +42 -34
  171. package/dist/Tabs/Tab.types.d.ts +1 -1
  172. package/dist/Tabs/TabIndicator.d.ts +13 -0
  173. package/dist/Tabs/TabIndicator.js +115 -0
  174. package/dist/Tabs/TabMask.d.ts +9 -0
  175. package/dist/Tabs/TabMask.js +88 -0
  176. package/dist/Tabs/TabPanel.types.d.ts +1 -1
  177. package/dist/Tabs/Tabs.css +15 -5
  178. package/dist/Tabs/Tabs.js +84 -159
  179. package/dist/Tabs/Tabs.types.d.ts +5 -6
  180. package/dist/Tabs/TabsContext.d.ts +15 -6
  181. package/dist/Tabs/TabsContext.js +6 -14
  182. package/dist/Tabs/classes.d.ts +10 -0
  183. package/dist/Tabs/classes.js +54 -0
  184. package/dist/Tabs/index.css +16 -27
  185. package/dist/Tabs/index.d.ts +2 -2
  186. package/dist/Tabs/index.js +4 -4
  187. package/dist/Tabs/index.miniapp.d.ts +5 -0
  188. package/dist/Tabs/index.miniapp.js +50 -0
  189. package/dist/Tabs/miniapp/Tab.d.ts +5 -0
  190. package/dist/Tabs/miniapp/Tab.js +104 -0
  191. package/dist/Tabs/miniapp/TabIndicator.d.ts +15 -0
  192. package/dist/Tabs/miniapp/TabIndicator.js +207 -0
  193. package/dist/Tabs/miniapp/TabMask.d.ts +13 -0
  194. package/dist/Tabs/miniapp/TabMask.js +67 -0
  195. package/dist/Tabs/miniapp/Tabs.d.ts +5 -0
  196. package/dist/Tabs/miniapp/Tabs.js +261 -0
  197. package/dist/Tabs/miniapp/TabsContext.d.ts +17 -0
  198. package/dist/Tabs/miniapp/TabsContext.js +39 -0
  199. package/dist/Tabs/miniapp/index.d.ts +2 -0
  200. package/dist/Tabs/miniapp/index.js +41 -0
  201. package/dist/Tabs/miniapp/scroll.d.ts +21 -0
  202. package/dist/Tabs/miniapp/scroll.js +52 -0
  203. package/dist/Tabs/miniapp/utils/queryBatch.d.ts +68 -0
  204. package/dist/Tabs/miniapp/utils/queryBatch.js +100 -0
  205. package/dist/Tabs/utils/scroll.js +10 -4
  206. package/dist/Tag/Tag.d.ts +1 -1
  207. package/dist/Tag/Tag.js +6 -6
  208. package/dist/Tag/Tag.types.d.ts +1 -1
  209. package/dist/Tag/TagGroup.d.ts +1 -1
  210. package/dist/Tag/TagGroup.js +3 -3
  211. package/dist/Tag/TagGroup.types.d.ts +1 -1
  212. package/dist/Tag/__tests__/fixtures/A11yDemos.js +3 -3
  213. package/dist/TextArea/__tests__/fixtures/A11yDemos.d.ts +1 -1
  214. package/dist/TextArea/__tests__/fixtures/A11yDemos.js +6 -6
  215. package/dist/ThemeProvider/hooks/ThemeContext.d.ts +1 -1
  216. package/dist/ThemeProvider/hooks/ThemeContext.js +2 -2
  217. package/dist/ThemeProvider/hooks/useTheme.js +2 -2
  218. package/dist/ThemeProvider/utils/mountTokens.js +2 -2
  219. package/dist/Toast/Toast.d.ts +1 -1
  220. package/dist/Toast/Toast.js +8 -8
  221. package/dist/Toast/__tests__/fixtures/A11yDemos.d.ts +1 -1
  222. package/dist/Toast/__tests__/fixtures/A11yDemos.js +2 -2
  223. package/dist/Tooltip/Tooltip.d.ts +1 -1
  224. package/dist/Tooltip/Tooltip.js +5 -5
  225. package/dist/Tooltip/Tooltip.types.d.ts +1 -1
  226. package/dist/Tooltip/__tests__/fixtures/A11yDemos.d.ts +1 -1
  227. package/dist/Tooltip/__tests__/fixtures/A11yDemos.js +14 -14
  228. package/dist/Transition/Transition.d.ts +1 -1
  229. package/dist/Transition/Transition.js +3 -3
  230. package/dist/Transition/Transition.miniapp.d.ts +1 -1
  231. package/dist/Transition/Transition.miniapp.js +3 -3
  232. package/dist/Transition/TransitionCore.js +8 -2
  233. package/dist/_.._/benchmarks/components/Button.d.js +15 -0
  234. package/dist/_.._/benchmarks/components/Button.js +2 -2
  235. package/dist/_.._/benchmarks/components/Input.d.js +15 -0
  236. package/dist/_.._/benchmarks/components/Tabs.d.js +15 -0
  237. package/es/ActionSheet/ActionSheet.d.ts +1 -1
  238. package/es/ActionSheet/ActionSheet.js +1 -1
  239. package/es/ActionSheet/ActionSheet.types.d.ts +1 -1
  240. package/es/ActionSheet/ActionSheetContext.d.ts +1 -1
  241. package/es/ActionSheet/ActionSheetContext.js +1 -1
  242. package/es/ActionSheet/ActionSheetItem.types.d.ts +1 -1
  243. package/es/Alert/Alert.d.ts +1 -1
  244. package/es/Alert/Alert.js +1 -1
  245. package/es/Alert/__tests__/fixtures/A11yDemos.d.ts +1 -1
  246. package/es/Alert/__tests__/fixtures/A11yDemos.js +1 -1
  247. package/es/Avatar/Avatar.d.ts +1 -1
  248. package/es/Avatar/Avatar.js +1 -1
  249. package/es/Avatar/Avatar.types.d.ts +1 -1
  250. package/es/Avatar/AvatarGroup.types.d.ts +1 -1
  251. package/es/Backdrop/Backdrop.d.ts +1 -1
  252. package/es/Backdrop/Backdrop.js +1 -1
  253. package/es/Backdrop/Backdrop.types.d.ts +1 -1
  254. package/es/Backdrop/__tests__/fixtures/A11yDemos.d.ts +1 -1
  255. package/es/Backdrop/__tests__/fixtures/A11yDemos.js +1 -1
  256. package/es/Badge/Badge.d.ts +1 -1
  257. package/es/Badge/Badge.js +1 -1
  258. package/es/Badge/__tests__/fixtures/A11yDemos.d.ts +1 -1
  259. package/es/Badge/__tests__/fixtures/A11yDemos.js +1 -1
  260. package/es/Breadcrumb/Breadcrumb.d.ts +1 -1
  261. package/es/Breadcrumb/Breadcrumb.js +1 -1
  262. package/es/Breadcrumb/Breadcrumb.types.d.ts +1 -1
  263. package/es/Breadcrumb/BreadcrumbItem.d.ts +1 -1
  264. package/es/Breadcrumb/BreadcrumbItem.js +1 -1
  265. package/es/Button/Button.d.ts +1 -1
  266. package/es/Button/Button.js +1 -1
  267. package/es/Button/Button.types.d.ts +1 -1
  268. package/es/Button/__tests__/fixtures/A11yDemos.d.ts +1 -1
  269. package/es/Button/__tests__/fixtures/A11yDemos.js +1 -1
  270. package/es/Calendar/Calendar.types.d.ts +1 -1
  271. package/es/Calendar/__tests__/fixtures/A11yDemos.d.ts +1 -1
  272. package/es/Calendar/__tests__/fixtures/A11yDemos.js +1 -1
  273. package/es/Card/Card.d.ts +1 -1
  274. package/es/Card/Card.js +1 -1
  275. package/es/Card/Card.types.d.ts +1 -1
  276. package/es/Card/CardContent.d.ts +1 -1
  277. package/es/Card/CardContent.js +1 -1
  278. package/es/Card/CardContent.types.d.ts +1 -1
  279. package/es/Card/CardFooter.d.ts +1 -1
  280. package/es/Card/CardFooter.js +1 -1
  281. package/es/Card/CardFooter.types.d.ts +1 -1
  282. package/es/Card/CardHeader.d.ts +1 -1
  283. package/es/Card/CardHeader.js +1 -1
  284. package/es/Checkbox/CheckboxContext.d.ts +1 -1
  285. package/es/Checkbox/CheckboxContext.js +1 -1
  286. package/es/Checkbox/__tests__/fixtures/A11yDemos.d.ts +1 -1
  287. package/es/Checkbox/__tests__/fixtures/A11yDemos.js +1 -1
  288. package/es/CitySelector/CitySelector.types.d.ts +1 -0
  289. package/es/CitySelector/Selector/index.d.ts +1 -1
  290. package/es/CitySelector/Selector/index.js +1 -1
  291. package/es/Collapse/Collapse.types.d.ts +1 -1
  292. package/es/CollapsePanel/CollapsePanel.d.ts +1 -1
  293. package/es/CollapsePanel/CollapsePanel.js +1 -1
  294. package/es/CollapsePanel/CollapsePanel.types.d.ts +1 -1
  295. package/es/CollapsePanel/CollapsePanelItem.d.ts +1 -1
  296. package/es/CollapsePanel/CollapsePanelItem.js +1 -1
  297. package/es/Countdown/Countdown.types.d.ts +2 -2
  298. package/es/Countdown/__tests__/fixtures/A11yDemos.d.ts +1 -1
  299. package/es/Countdown/__tests__/fixtures/A11yDemos.js +1 -1
  300. package/es/Countdown/utils.d.ts +2 -2
  301. package/es/Countdown/utils.js +4 -4
  302. package/es/DatePicker/DatePicker.d.ts +1 -1
  303. package/es/DatePicker/DatePicker.types.d.ts +1 -1
  304. package/es/DesktopPicker/DesktopPicker.types.d.ts +1 -1
  305. package/es/DesktopTimePicker/DesktopTimePicker.types.d.ts +11 -11
  306. package/es/DesktopTimePicker/useGetTimePickerContent.js +3 -3
  307. package/es/DesktopTimePicker/utils/utils.d.ts +1 -1
  308. package/es/DesktopTimePicker/utils/utils.js +2 -2
  309. package/es/Dialog/__tests__/fixtures/A11yDemos.d.ts +1 -1
  310. package/es/Dialog/__tests__/fixtures/A11yDemos.js +1 -1
  311. package/es/Divider/Divider.types.d.ts +1 -1
  312. package/es/Drawer/Drawer.d.ts +1 -1
  313. package/es/Drawer/Drawer.js +1 -1
  314. package/es/Drawer/Drawer.types.d.ts +1 -1
  315. package/es/Fade/Fade.d.ts +1 -1
  316. package/es/Fade/Fade.js +1 -1
  317. package/es/Fade/Fade.types.d.ts +1 -1
  318. package/es/IconButton/IconButton.d.ts +1 -1
  319. package/es/IconButton/IconButton.js +1 -1
  320. package/es/IconButton/IconButton.types.d.ts +1 -1
  321. package/es/Input/Input.types.d.ts +1 -1
  322. package/es/Input/__tests__/fixtures/A11yDemos.d.ts +1 -1
  323. package/es/Input/__tests__/fixtures/A11yDemos.js +1 -1
  324. package/es/ItemSelector/ItemSelector.miniapp.js +7 -5
  325. package/es/ItemSelector/ItemSelector.types.d.ts +1 -0
  326. package/es/ItemSelector/Selector/index.d.ts +1 -1
  327. package/es/ItemSelector/Selector/index.js +1 -1
  328. package/es/List/List.d.ts +1 -1
  329. package/es/List/List.js +1 -1
  330. package/es/List/ListContext.d.ts +1 -1
  331. package/es/List/ListContext.js +1 -1
  332. package/es/List/ListItem.d.ts +1 -1
  333. package/es/List/ListItem.js +1 -1
  334. package/es/List/ListItem.types.d.ts +1 -1
  335. package/es/List/ListItemContent.d.ts +1 -1
  336. package/es/List/ListItemContent.js +1 -1
  337. package/es/List/ListItemContent.types.d.ts +1 -1
  338. package/es/List/ListItemExtra.d.ts +1 -1
  339. package/es/List/ListItemExtra.js +1 -1
  340. package/es/List/ListItemExtra.types.d.ts +1 -1
  341. package/es/List/ListItemFooter.d.ts +1 -1
  342. package/es/List/ListItemFooter.js +1 -1
  343. package/es/List/ListItemFooter.types.d.ts +1 -1
  344. package/es/List/ListItemHeader.d.ts +1 -1
  345. package/es/List/ListItemHeader.js +1 -1
  346. package/es/List/ListItemHeader.types.d.ts +1 -1
  347. package/es/Loading/Loading.d.ts +1 -1
  348. package/es/Loading/Loading.js +1 -1
  349. package/es/Loading/Loading.types.d.ts +1 -1
  350. package/es/Modal/Modal.d.ts +1 -1
  351. package/es/Modal/Modal.js +1 -1
  352. package/es/Modal/Modal.miniapp.d.ts +2 -2
  353. package/es/Modal/Modal.miniapp.js +1 -1
  354. package/es/Modal/__tests__/fixtures/A11yDemos.d.ts +1 -1
  355. package/es/Modal/__tests__/fixtures/A11yDemos.js +1 -1
  356. package/es/Modal/useModal.js +26 -29
  357. package/es/NavBar/NavBar.d.ts +1 -1
  358. package/es/NavBar/NavBar.js +1 -1
  359. package/es/Picker/Picker.js +0 -1
  360. package/es/Picker/Picker.types.d.ts +1 -1
  361. package/es/Picker/__tests__/fixtures/A11yDemos.d.ts +1 -1
  362. package/es/Picker/__tests__/fixtures/A11yDemos.js +1 -1
  363. package/es/Popover/Popover.d.ts +1 -1
  364. package/es/Popover/Popover.js +1 -1
  365. package/es/Popover/Popover.types.d.ts +1 -1
  366. package/es/Popover/__tests__/fixtures/A11yDemos.d.ts +1 -1
  367. package/es/Popover/__tests__/fixtures/A11yDemos.js +1 -1
  368. package/es/Portal/Portal.d.ts +1 -1
  369. package/es/Portal/Portal.js +1 -1
  370. package/es/Portal/Portal.types.d.ts +1 -1
  371. package/es/Progress/Progress.d.ts +1 -1
  372. package/es/Progress/Progress.js +1 -1
  373. package/es/Progress/Progress.types.d.ts +1 -1
  374. package/es/Progress/__tests__/fixtures/A11yDemos.d.ts +1 -1
  375. package/es/Progress/__tests__/fixtures/A11yDemos.js +1 -1
  376. package/es/Radio/RadioButtonIcon.d.ts +1 -1
  377. package/es/Radio/RadioButtonIcon.js +1 -1
  378. package/es/Radio/RadioContext.d.ts +1 -1
  379. package/es/Radio/RadioContext.js +1 -1
  380. package/es/Radio/__tests__/fixtures/A11yDemos.d.ts +1 -1
  381. package/es/Radio/__tests__/fixtures/A11yDemos.js +1 -1
  382. package/es/Rating/Rating.types.d.ts +1 -1
  383. package/es/ScrollView/ScrollView.types.d.ts +1 -1
  384. package/es/ScrollView/__tests__/fixtures/A11yDemos.d.ts +1 -1
  385. package/es/ScrollView/__tests__/fixtures/A11yDemos.js +1 -1
  386. package/es/ScrollView/useScrollView.js +16 -4
  387. package/es/Skeleton/Skeleton.d.ts +1 -1
  388. package/es/Skeleton/Skeleton.js +1 -1
  389. package/es/Skeleton/Skeleton.types.d.ts +1 -1
  390. package/es/Slide/Slide.d.ts +1 -1
  391. package/es/Slide/Slide.js +1 -1
  392. package/es/Slider/Slider.types.d.ts +1 -1
  393. package/es/Steps/Step.types.d.ts +1 -1
  394. package/es/Steps/StepsContext.d.ts +1 -1
  395. package/es/Steps/StepsContext.js +1 -1
  396. package/es/SwipeAction/SwipeAction.js +7 -8
  397. package/es/SwipeAction/SwipeAction.types.d.ts +1 -1
  398. package/es/Swiper/Swiper.js +5 -1
  399. package/es/Swiper/Swiper.types.d.ts +1 -1
  400. package/es/Swiper/SwiperItem.d.ts +1 -1
  401. package/es/Swiper/SwiperItem.js +1 -1
  402. package/es/Switch/__tests__/fixtures/A11yDemos.d.ts +1 -1
  403. package/es/Switch/__tests__/fixtures/A11yDemos.js +1 -1
  404. package/es/TabBar/TabBar.d.ts +1 -1
  405. package/es/TabBar/TabBar.js +1 -1
  406. package/es/Tabs/Tab.css +1 -22
  407. package/es/Tabs/Tab.d.ts +2 -2
  408. package/es/Tabs/Tab.js +44 -36
  409. package/es/Tabs/Tab.types.d.ts +1 -1
  410. package/es/Tabs/TabIndicator.d.ts +13 -0
  411. package/es/Tabs/TabIndicator.js +86 -0
  412. package/es/Tabs/TabMask.d.ts +9 -0
  413. package/es/Tabs/TabMask.js +59 -0
  414. package/es/Tabs/TabPanel.types.d.ts +1 -1
  415. package/es/Tabs/Tabs.css +15 -5
  416. package/es/Tabs/Tabs.js +86 -161
  417. package/es/Tabs/Tabs.types.d.ts +5 -6
  418. package/es/Tabs/TabsContext.d.ts +15 -6
  419. package/es/Tabs/TabsContext.js +6 -4
  420. package/es/Tabs/classes.d.ts +10 -0
  421. package/es/Tabs/classes.js +22 -0
  422. package/es/Tabs/index.css +16 -27
  423. package/es/Tabs/index.d.ts +2 -2
  424. package/es/Tabs/index.js +2 -2
  425. package/es/Tabs/index.miniapp.d.ts +5 -0
  426. package/es/Tabs/index.miniapp.js +11 -0
  427. package/es/Tabs/miniapp/Tab.d.ts +5 -0
  428. package/es/Tabs/miniapp/Tab.js +75 -0
  429. package/es/Tabs/miniapp/TabIndicator.d.ts +15 -0
  430. package/es/Tabs/miniapp/TabIndicator.js +178 -0
  431. package/es/Tabs/miniapp/TabMask.d.ts +13 -0
  432. package/es/Tabs/miniapp/TabMask.js +38 -0
  433. package/es/Tabs/miniapp/Tabs.d.ts +5 -0
  434. package/es/Tabs/miniapp/Tabs.js +239 -0
  435. package/es/Tabs/miniapp/TabsContext.d.ts +17 -0
  436. package/es/Tabs/miniapp/TabsContext.js +16 -0
  437. package/es/Tabs/miniapp/index.d.ts +2 -0
  438. package/es/Tabs/miniapp/index.js +7 -0
  439. package/es/Tabs/miniapp/scroll.d.ts +21 -0
  440. package/es/Tabs/miniapp/scroll.js +29 -0
  441. package/es/Tabs/miniapp/utils/queryBatch.d.ts +68 -0
  442. package/es/Tabs/miniapp/utils/queryBatch.js +65 -0
  443. package/es/Tabs/utils/scroll.js +10 -4
  444. package/es/Tag/Tag.d.ts +1 -1
  445. package/es/Tag/Tag.js +4 -4
  446. package/es/Tag/Tag.types.d.ts +1 -1
  447. package/es/Tag/TagGroup.d.ts +1 -1
  448. package/es/Tag/TagGroup.js +1 -1
  449. package/es/Tag/TagGroup.types.d.ts +1 -1
  450. package/es/Tag/__tests__/fixtures/A11yDemos.js +3 -3
  451. package/es/TextArea/__tests__/fixtures/A11yDemos.d.ts +1 -1
  452. package/es/TextArea/__tests__/fixtures/A11yDemos.js +1 -1
  453. package/es/ThemeProvider/hooks/ThemeContext.d.ts +1 -1
  454. package/es/ThemeProvider/hooks/ThemeContext.js +1 -1
  455. package/es/ThemeProvider/hooks/useTheme.js +1 -1
  456. package/es/ThemeProvider/utils/mountTokens.js +1 -1
  457. package/es/Toast/Toast.d.ts +1 -1
  458. package/es/Toast/Toast.js +1 -1
  459. package/es/Toast/__tests__/fixtures/A11yDemos.d.ts +1 -1
  460. package/es/Toast/__tests__/fixtures/A11yDemos.js +1 -1
  461. package/es/Tooltip/Tooltip.d.ts +1 -1
  462. package/es/Tooltip/Tooltip.js +1 -1
  463. package/es/Tooltip/Tooltip.types.d.ts +1 -1
  464. package/es/Tooltip/__tests__/fixtures/A11yDemos.d.ts +1 -1
  465. package/es/Tooltip/__tests__/fixtures/A11yDemos.js +1 -1
  466. package/es/Transition/Transition.d.ts +1 -1
  467. package/es/Transition/Transition.js +1 -1
  468. package/es/Transition/Transition.miniapp.d.ts +1 -1
  469. package/es/Transition/Transition.miniapp.js +1 -1
  470. package/es/Transition/TransitionCore.js +8 -2
  471. package/es/_.._/benchmarks/components/Button.d.js +0 -0
  472. package/es/_.._/benchmarks/components/Button.js +1 -1
  473. package/es/_.._/benchmarks/components/Input.d.js +0 -0
  474. package/es/_.._/benchmarks/components/Tabs.d.js +0 -0
  475. package/package.json +7 -6
package/es/Tabs/Tab.js CHANGED
@@ -29,43 +29,56 @@ var __objRest = (source, exclude) => {
29
29
  }
30
30
  return target;
31
31
  };
32
- import React from "react";
32
+ import React, { useEffect, useRef } from "react";
33
33
  import clsx from "clsx";
34
- import { isMini } from "@bifrostui/utils";
34
+ import { isMini, useContextSelector, useForkRef } from "@bifrostui/utils";
35
35
  import TabsContext from "./TabsContext";
36
36
  import "./Tab.css";
37
- const prefixCls = "bui-tab";
37
+ const rootClass = "bui-tab";
38
38
  const Tab = /* @__PURE__ */ React.forwardRef((props, ref) => {
39
39
  const _a = props, {
40
40
  className,
41
41
  children,
42
42
  index,
43
43
  disabled = false,
44
- onClick,
45
- role = "tab",
46
- tabIndex,
47
- "aria-selected": ariaSelected,
48
- "aria-disabled": ariaDisabled
44
+ onClick
49
45
  } = _a, others = __objRest(_a, [
50
46
  "className",
51
47
  "children",
52
48
  "index",
53
49
  "disabled",
54
- "onClick",
55
- "role",
56
- "tabIndex",
57
- "aria-selected",
58
- "aria-disabled"
50
+ "onClick"
59
51
  ]);
60
- const tabsContext = React.useContext(TabsContext);
61
- const { value, triggerChange } = tabsContext;
62
- const isActive = index === value;
52
+ const innerRef = useRef(null);
53
+ const handleRef = useForkRef(ref, innerRef);
54
+ const isActive = useContextSelector(
55
+ TabsContext,
56
+ (ctx) => ctx.value === index
57
+ );
58
+ const triggerChange = useContextSelector(
59
+ TabsContext,
60
+ (ctx) => ctx.triggerChange
61
+ );
62
+ const onRegister = useContextSelector(TabsContext, (ctx) => ctx.onRegister);
63
+ const onUnregister = useContextSelector(
64
+ TabsContext,
65
+ (ctx) => ctx.onUnregister
66
+ );
67
+ useEffect(() => {
68
+ if (index !== void 0 && index !== null) {
69
+ onRegister == null ? void 0 : onRegister({ value: index, ref: innerRef });
70
+ }
71
+ return () => {
72
+ if (index !== void 0 && index !== null) {
73
+ onUnregister == null ? void 0 : onUnregister({ value: index });
74
+ }
75
+ };
76
+ }, [onRegister, onUnregister, index]);
63
77
  const rootCls = clsx(
64
- prefixCls,
78
+ rootClass,
65
79
  {
66
- [`${prefixCls}-active`]: !isMini && isActive,
67
- [`${prefixCls}-miniapp-active`]: isMini && isActive,
68
- [`${prefixCls}-disabled`]: disabled
80
+ [`${rootClass}-active`]: !isMini && isActive,
81
+ [`${rootClass}-disabled`]: disabled
69
82
  },
70
83
  className
71
84
  );
@@ -73,34 +86,29 @@ const Tab = /* @__PURE__ */ React.forwardRef((props, ref) => {
73
86
  if (disabled)
74
87
  return;
75
88
  e.preventDefault();
76
- triggerChange(e, { index });
89
+ triggerChange == null ? void 0 : triggerChange(e, { index });
77
90
  onClick == null ? void 0 : onClick(e, { index });
78
91
  };
92
+ if (process.env.NODE_ENV !== "production") {
93
+ console.count("Tab render");
94
+ }
79
95
  return /* @__PURE__ */ React.createElement(
80
96
  "div",
81
97
  __spreadProps(__spreadValues({
82
- role,
83
- "aria-selected": ariaSelected != null ? ariaSelected : isActive,
84
- "aria-disabled": ariaDisabled != null ? ariaDisabled : disabled,
85
- tabIndex: tabIndex != null ? tabIndex : disabled ? -1 : 0,
86
- ref,
98
+ role: "tab",
99
+ "aria-selected": isActive,
100
+ "aria-disabled": disabled,
101
+ tabIndex: disabled ? -1 : 0,
102
+ ref: handleRef,
87
103
  className: rootCls
88
104
  }, others), {
89
105
  onClick: handleClick
90
106
  }),
91
- children,
92
- isMini && /* @__PURE__ */ React.createElement(
93
- "div",
94
- {
95
- className: clsx(`${prefixCls}-miniapp-active-line`, {
96
- "bui-indicator-invisible": !isActive
97
- })
98
- }
99
- )
107
+ children
100
108
  );
101
109
  });
102
110
  Tab.displayName = "BuiTab";
103
- var Tab_default = Tab;
111
+ var Tab_default = /* @__PURE__ */ React.memo(Tab);
104
112
  export {
105
113
  Tab_default as default
106
114
  };
@@ -1,4 +1,4 @@
1
- import React from 'react';
1
+ import * as React from 'react';
2
2
  import { OverrideProps } from '@bifrostui/types';
3
3
  import { ITabItem, TabChangeEvent } from './Tabs.types';
4
4
  export type TabProps<D extends React.ElementType = 'div', P = {}> = OverrideProps<{
@@ -0,0 +1,13 @@
1
+ import React from 'react';
2
+ export interface TabIndicatorProps {
3
+ /** 当前选中的 tab 值 */
4
+ currentValue: string;
5
+ /** 已注册的 tabs 引用映射表 */
6
+ registeredTabs: React.MutableRefObject<Record<string, React.RefObject<HTMLElement>>>;
7
+ /** tabs 容器的引用 */
8
+ tabsContainerRef: React.RefObject<HTMLDivElement>;
9
+ /** 注册版本号,每次 tab 注册/取消注册时递增 */
10
+ registrationVersion: number;
11
+ }
12
+ declare const TabIndicator: React.FC<TabIndicatorProps>;
13
+ export default TabIndicator;
@@ -0,0 +1,86 @@
1
+ import React, { useEffect, useRef } from "react";
2
+ import clsx from "clsx";
3
+ import { debounce, isMini, useEventCallback } from "@bifrostui/utils";
4
+ import scrollLeftTo from "./utils/scroll";
5
+ const rootClass = "bui-tabs";
6
+ const duration = 300;
7
+ const TabIndicator = ({
8
+ currentValue,
9
+ registeredTabs,
10
+ tabsContainerRef,
11
+ registrationVersion
12
+ }) => {
13
+ const indicatorRef = useRef(null);
14
+ const getActiveTabElement = useEventCallback(
15
+ (activeValue) => {
16
+ const tabRef = registeredTabs.current[activeValue];
17
+ return tabRef == null ? void 0 : tabRef.current;
18
+ }
19
+ );
20
+ const scrollIntoView = useEventCallback((activeTab) => {
21
+ const tabsEl = tabsContainerRef.current;
22
+ if (!tabsEl || !activeTab) {
23
+ return;
24
+ }
25
+ scrollLeftTo(
26
+ tabsEl,
27
+ activeTab.offsetLeft - (tabsEl.offsetWidth - activeTab.offsetWidth) / 2,
28
+ duration
29
+ );
30
+ });
31
+ const animate = useEventCallback(() => {
32
+ const tabsEl = tabsContainerRef.current;
33
+ if (!tabsEl)
34
+ return;
35
+ const indicator = indicatorRef.current;
36
+ if (!indicator)
37
+ return;
38
+ const activeTab = getActiveTabElement(currentValue);
39
+ if (activeTab) {
40
+ const activeTabLeft = activeTab.offsetLeft;
41
+ const activeTabWidth = activeTab.offsetWidth;
42
+ const containerWidth = tabsEl.offsetWidth;
43
+ const containerScrollWidth = tabsEl.scrollWidth;
44
+ const activeLineWidth = indicator.offsetWidth;
45
+ const x = activeTabLeft + (activeTabWidth - activeLineWidth) / 2;
46
+ indicator.style.transform = `translate(${x}px, 0px)`;
47
+ indicator.style.visibility = "visible";
48
+ const maxScrollDistance = containerScrollWidth - containerWidth;
49
+ if (maxScrollDistance > 0 && !isMini) {
50
+ scrollIntoView(activeTab);
51
+ }
52
+ } else {
53
+ indicator.style.visibility = "hidden";
54
+ }
55
+ });
56
+ useEffect(() => {
57
+ animate();
58
+ }, [animate, currentValue, registrationVersion]);
59
+ useEffect(() => {
60
+ const handleResize = debounce(() => {
61
+ animate();
62
+ }, 100);
63
+ window.addEventListener("resize", handleResize);
64
+ return () => {
65
+ window.removeEventListener("resize", handleResize);
66
+ };
67
+ }, [animate]);
68
+ return /* @__PURE__ */ React.createElement(
69
+ "div",
70
+ {
71
+ ref: indicatorRef,
72
+ className: clsx(`${rootClass}-indicator`),
73
+ style: {
74
+ transition: "transform 0.3s ease-in-out",
75
+ transform: "translate(0px, 0px)",
76
+ visibility: "hidden"
77
+ },
78
+ "aria-hidden": "true"
79
+ }
80
+ );
81
+ };
82
+ TabIndicator.displayName = "BuiTabsIndicator";
83
+ var TabIndicator_default = TabIndicator;
84
+ export {
85
+ TabIndicator_default as default
86
+ };
@@ -0,0 +1,9 @@
1
+ import React from 'react';
2
+ export interface TabMaskProps {
3
+ /** Tabs 容器的引用,用于监听滚动 */
4
+ tabsContainerRef: React.RefObject<HTMLDivElement>;
5
+ /** 位置:左侧或右侧 */
6
+ position: 'left' | 'right';
7
+ }
8
+ declare const TabMask: React.FC<TabMaskProps>;
9
+ export default TabMask;
@@ -0,0 +1,59 @@
1
+ import React, { useEffect, useMemo, useRef } from "react";
2
+ import clsx from "clsx";
3
+ import { throttle } from "@bifrostui/utils";
4
+ const rootClass = "bui-tabs";
5
+ const TabMask = ({ tabsContainerRef, position }) => {
6
+ const maskRef = useRef(null);
7
+ const updateMaskOpacity = useMemo(
8
+ () => throttle(
9
+ () => {
10
+ const tabsEl = tabsContainerRef.current;
11
+ const mask = maskRef.current;
12
+ if (!tabsEl || !mask)
13
+ return;
14
+ const { scrollLeft, scrollWidth, offsetWidth } = tabsEl;
15
+ let shouldShow = false;
16
+ if (position === "left") {
17
+ shouldShow = scrollLeft > 0;
18
+ } else {
19
+ const rightRange = Math.abs(
20
+ scrollWidth - (scrollLeft + offsetWidth)
21
+ );
22
+ shouldShow = rightRange > 1;
23
+ }
24
+ mask.style.opacity = shouldShow ? "1" : "0";
25
+ },
26
+ 100,
27
+ {
28
+ trailing: true,
29
+ leading: true
30
+ }
31
+ ),
32
+ [tabsContainerRef, position]
33
+ );
34
+ useEffect(() => {
35
+ const tabsEl = tabsContainerRef.current;
36
+ if (!tabsEl)
37
+ return void 0;
38
+ updateMaskOpacity();
39
+ tabsEl.addEventListener("scroll", updateMaskOpacity);
40
+ return () => {
41
+ tabsEl.removeEventListener("scroll", updateMaskOpacity);
42
+ };
43
+ }, [tabsContainerRef, updateMaskOpacity]);
44
+ return /* @__PURE__ */ React.createElement(
45
+ "div",
46
+ {
47
+ ref: maskRef,
48
+ className: clsx(`${rootClass}-mask`, `${rootClass}-mask-${position}`),
49
+ style: {
50
+ opacity: 0
51
+ },
52
+ "aria-hidden": "true"
53
+ }
54
+ );
55
+ };
56
+ var TabMask_default = TabMask;
57
+ export {
58
+ TabMask_default as default
59
+ };
@@ -1,5 +1,5 @@
1
1
  import { OverrideProps } from '@bifrostui/types';
2
- import React from 'react';
2
+ import * as React from 'react';
3
3
  export type TabPanelProps<D extends React.ElementType = 'div', P = {}> = OverrideProps<{
4
4
  props: P & {
5
5
  /**
package/es/Tabs/Tabs.css CHANGED
@@ -29,6 +29,7 @@ xhs-page {
29
29
  flex-wrap: nowrap;
30
30
  justify-content: flex-start;
31
31
  align-items: center;
32
+ white-space: nowrap;
32
33
  position: relative;
33
34
  overflow-x: scroll;
34
35
  scrollbar-width: none;
@@ -36,15 +37,28 @@ xhs-page {
36
37
  .bui-tabs-tabs::-webkit-scrollbar {
37
38
  display: none;
38
39
  }
40
+ .bui-tabs-scroll-wrapper {
41
+ height: 100%;
42
+ display: flex;
43
+ flex-wrap: nowrap;
44
+ justify-content: flex-start;
45
+ align-items: center;
46
+ position: relative;
47
+ min-width: 100%;
48
+ }
39
49
  .bui-tabs-indicator {
40
50
  position: absolute;
51
+ top: unset;
52
+ bottom: var(--bui-tabs-indicator-bottom, 0);
53
+ left: 0;
41
54
  width: var(--bui-tabs-indicator-width);
42
- bottom: var(--bui-tabs-indicator-bottom);
43
55
  height: var(--bui-tabs-indicator-height);
44
56
  color: var(--bui-color-primary);
45
57
  background: var(--bui-tabs-indicator-bg);
46
58
  border-radius: var(--bui-tabs-indicator-border-radius);
47
59
  box-shadow: var(--bui-tabs-indicator-box-shadow);
60
+ z-index: 1;
61
+ pointer-events: none;
48
62
  }
49
63
  .bui-tabs-content {
50
64
  padding: var(--bui-spacing-lg);
@@ -74,7 +88,3 @@ xhs-page {
74
88
  var(--bui-color-bg-view),
75
89
  rgba(255, 255, 255, 0));
76
90
  }
77
- .bui-indicator-invisible {
78
- visibility: hidden;
79
- background-color: transparent;
80
- }
package/es/Tabs/Tabs.js CHANGED
@@ -26,190 +26,115 @@ var __objRest = (source, exclude) => {
26
26
  }
27
27
  return target;
28
28
  };
29
- import React, { useEffect, useMemo, useRef, useState } from "react";
29
+ import React, { useMemo, useRef, useState } from "react";
30
30
  import clsx from "clsx";
31
- import { debounce, isMini, throttle, useEventCallback } from "@bifrostui/utils";
32
- import scrollLeftTo from "./utils/scroll";
31
+ import { useValue, useEventCallback } from "@bifrostui/utils";
33
32
  import Tab from "./Tab";
33
+ import TabIndicator from "./TabIndicator";
34
+ import TabMask from "./TabMask";
34
35
  import { TabsContextProvider } from "./TabsContext";
36
+ import { tabsRootClass } from "./classes";
35
37
  import "./Tabs.css";
36
- const prefixCls = "bui-tabs";
37
- const duration = 300;
38
38
  const Tabs = /* @__PURE__ */ React.forwardRef((props, ref) => {
39
- const _a = props, { children, className, value, tabs = [], onChange } = _a, others = __objRest(_a, ["children", "className", "value", "tabs", "onChange"]);
40
- const tabsRef = useRef(null);
41
- const activeLineRef = useRef(null);
42
- const [indicatorData, setIndicatorData] = useState({
43
- x: 0,
44
- hasActiveTab: false
45
- });
46
- const [maskData, setMaskData] = useState({
47
- leftMaskOpacity: 0,
48
- rightMaskOpacity: 0
49
- });
50
- const getActiveTabElement = () => {
51
- const tabsEl = tabsRef.current;
52
- if (!tabsEl)
53
- return;
54
- const activeIndex = tabs.findIndex((item) => item.index === value);
55
- if (tabs.length) {
56
- return activeIndex > -1 ? tabsEl.childNodes[activeIndex + 1] : void 0;
39
+ const _a = props, {
40
+ children,
41
+ className,
42
+ value,
43
+ defaultValue,
44
+ tabs = [],
45
+ onChange
46
+ } = _a, others = __objRest(_a, [
47
+ "children",
48
+ "className",
49
+ "value",
50
+ "defaultValue",
51
+ "tabs",
52
+ "onChange"
53
+ ]);
54
+ const handleOnChange = useEventCallback(
55
+ (e, data) => {
56
+ onChange == null ? void 0 : onChange(e, { index: data.value });
57
57
  }
58
- return [...tabsEl.childNodes].find((child) => {
59
- var _a2, _b;
60
- if (isMini) {
61
- return [...(_b = (_a2 = child == null ? void 0 : child.classList) == null ? void 0 : _a2.tokenList) != null ? _b : []].includes(
62
- "bui-tab-miniapp-active"
63
- );
64
- }
65
- return [...child.classList].includes("bui-tab-active");
66
- });
67
- };
68
- const scrollIntoView = () => {
69
- const tabsEl = tabsRef.current;
70
- const activeTab = getActiveTabElement();
71
- if (!tabsEl || !activeTab) {
72
- return;
58
+ );
59
+ const [currentValue, triggerValueChange] = useValue({
60
+ value,
61
+ defaultValue: defaultValue != null ? defaultValue : "",
62
+ onChange: handleOnChange,
63
+ config: {
64
+ name: "Tabs",
65
+ state: "value"
73
66
  }
74
- const to = activeTab.offsetLeft - (tabsEl.offsetWidth - activeTab.offsetWidth) / 2;
75
- scrollLeftTo(tabsEl, to, duration);
76
- };
77
- const animate = useEventCallback(() => {
78
- const tabsEl = tabsRef.current;
79
- if (!tabsEl)
80
- return;
81
- const activeLine = activeLineRef.current;
82
- if (!activeLine)
83
- return;
84
- const activeTab = getActiveTabElement();
85
- let activeTabLeft = 0;
86
- let activeTabWidth = 0;
87
- let containerWidth = 0;
88
- let containerScrollWidth = 0;
89
- let activeLineWidth = 0;
90
- let x = 0;
91
- if (activeTab) {
92
- activeTabLeft = activeTab.offsetLeft;
93
- activeTabWidth = activeTab.offsetWidth;
94
- containerWidth = tabsEl.offsetWidth;
95
- containerScrollWidth = tabsEl.scrollWidth;
96
- activeLineWidth = activeLine.offsetWidth;
97
- x = activeTabLeft + (activeTabWidth - activeLineWidth) / 2;
67
+ });
68
+ const tabsRef = useRef(null);
69
+ const registeredTabs = useRef(
70
+ {}
71
+ );
72
+ const [registrationVersion, setRegistrationVersion] = useState(0);
73
+ if (process.env.NODE_ENV !== "production") {
74
+ if (tabs.length > 0 && React.Children.count(children) > 0) {
75
+ console.warn(
76
+ "BUI Warning: Tabs \u7EC4\u4EF6\u4E0D\u5E94\u8BE5\u540C\u65F6\u4F7F\u7528 tabs \u5C5E\u6027\u548C children\u3002\u8BF7\u53EA\u4F7F\u7528\u5176\u4E2D\u4E00\u79CD\u65B9\u5F0F\u3002\u5F53\u524D\u5C06\u4F18\u5148\u4F7F\u7528 tabs \u5C5E\u6027\uFF0Cchildren \u5C06\u88AB\u5FFD\u7565\u3002"
77
+ );
98
78
  }
99
- setIndicatorData({
100
- x,
101
- hasActiveTab: !!activeTab
102
- });
103
- const maxScrollDistance = containerScrollWidth - containerWidth;
104
- if (maxScrollDistance <= 0 || !activeTab)
105
- return;
106
- if (!isMini) {
107
- scrollIntoView();
79
+ }
80
+ const onRegister = useEventCallback(
81
+ (data) => {
82
+ if (data.value !== void 0 && data.value !== null) {
83
+ registeredTabs.current[data.value] = data.ref;
84
+ setRegistrationVersion((v) => v + 1);
85
+ }
108
86
  }
87
+ );
88
+ const onUnregister = useEventCallback((data) => {
89
+ delete registeredTabs.current[data.value];
90
+ setRegistrationVersion((v) => v + 1);
109
91
  });
110
- const updateMask = useMemo(
111
- () => throttle(
112
- () => {
113
- const tabsEl = tabsRef.current;
114
- if (!tabsEl)
115
- return;
116
- const scrollLeft = tabsEl == null ? void 0 : tabsEl.scrollLeft;
117
- const showLeftMask = scrollLeft > 0;
118
- const rightRange = Math.abs(
119
- tabsEl.scrollWidth - (scrollLeft + tabsEl.offsetWidth)
120
- );
121
- const showRightMask = rightRange > 1;
122
- setMaskData({
123
- leftMaskOpacity: showLeftMask ? 1 : 0,
124
- rightMaskOpacity: showRightMask ? 1 : 0
125
- });
126
- },
127
- 100,
128
- {
129
- trailing: true,
130
- leading: true
92
+ const handleClick = useEventCallback(
93
+ (e, item) => {
94
+ const { index, disabled = false } = item;
95
+ if (disabled || [void 0, null].includes(index))
96
+ return;
97
+ if (index !== currentValue) {
98
+ triggerValueChange(e, index);
131
99
  }
132
- ),
133
- []
134
- );
135
- useEffect(() => {
136
- animate();
137
- }, [value, tabs.length, React.Children.toArray(children).length]);
138
- useEffect(() => {
139
- updateMask();
140
- const handleResize = debounce(() => {
141
- animate();
142
- updateMask();
143
- }, 100);
144
- window.addEventListener("resize", handleResize);
145
- return () => {
146
- window.removeEventListener("resize", handleResize);
147
- };
148
- }, []);
149
- const handleClick = (e, item) => {
150
- const { index, disabled = false } = item;
151
- if (disabled || [void 0, null].includes(index))
152
- return;
153
- if (index !== value) {
154
- onChange == null ? void 0 : onChange(e, { index });
155
- }
156
- };
157
- return /* @__PURE__ */ React.createElement("div", __spreadValues({ ref, className: clsx(prefixCls, className) }, others), /* @__PURE__ */ React.createElement(
158
- "div",
159
- {
160
- className: clsx(`${prefixCls}-mask`, `${prefixCls}-mask-left`),
161
- style: {
162
- opacity: maskData.leftMaskOpacity
163
- },
164
- "aria-hidden": "true"
165
100
  }
166
- ), /* @__PURE__ */ React.createElement(
167
- "div",
168
- {
169
- className: clsx(`${prefixCls}-mask`, `${prefixCls}-mask-right`),
170
- style: {
171
- opacity: maskData.rightMaskOpacity
172
- },
173
- "aria-hidden": "true"
101
+ );
102
+ const contextValue = useMemo(
103
+ () => ({
104
+ value: currentValue,
105
+ triggerChange: handleClick,
106
+ onRegister,
107
+ onUnregister
108
+ }),
109
+ [currentValue, handleClick, onRegister, onUnregister]
110
+ );
111
+ const renderedTabs = useMemo(() => {
112
+ if (tabs.length > 0) {
113
+ return tabs.map((item) => /* @__PURE__ */ React.createElement(Tab, { key: item.index, index: item == null ? void 0 : item.index, disabled: item == null ? void 0 : item.disabled }, item.title));
174
114
  }
175
- ), /* @__PURE__ */ React.createElement(
115
+ return children;
116
+ }, [tabs, children]);
117
+ if (process.env.NODE_ENV !== "production") {
118
+ console.count("Tabs render......");
119
+ }
120
+ return /* @__PURE__ */ React.createElement("div", __spreadValues({ ref, className: clsx(tabsRootClass, className) }, others), /* @__PURE__ */ React.createElement(TabMask, { tabsContainerRef: tabsRef, position: "left" }), /* @__PURE__ */ React.createElement(TabMask, { tabsContainerRef: tabsRef, position: "right" }), /* @__PURE__ */ React.createElement(
176
121
  "div",
177
122
  {
178
- className: `${prefixCls}-tabs`,
123
+ className: `${tabsRootClass}-tabs`,
179
124
  ref: tabsRef,
180
- onScroll: updateMask,
181
125
  role: "tablist",
182
126
  "aria-orientation": "horizontal"
183
127
  },
184
128
  /* @__PURE__ */ React.createElement(
185
- "div",
129
+ TabIndicator,
186
130
  {
187
- ref: activeLineRef,
188
- className: clsx(`${prefixCls}-indicator`, {
189
- "bui-indicator-invisible": isMini || !indicatorData.hasActiveTab
190
- }),
191
- style: {
192
- transition: "transform 0.3s ease-in-out",
193
- transform: `translate(${indicatorData.x}px, 0px)`
194
- },
195
- "aria-hidden": "true"
131
+ currentValue,
132
+ registeredTabs,
133
+ tabsContainerRef: tabsRef,
134
+ registrationVersion
196
135
  }
197
136
  ),
198
- /* @__PURE__ */ React.createElement(TabsContextProvider, { value: { value, triggerChange: handleClick } }, !!tabs.length && tabs.map((item) => {
199
- return /* @__PURE__ */ React.createElement(
200
- Tab,
201
- {
202
- key: item.index,
203
- index: item == null ? void 0 : item.index,
204
- disabled: item == null ? void 0 : item.disabled,
205
- role: "tab",
206
- "aria-selected": value === item.index,
207
- "aria-disabled": item == null ? void 0 : item.disabled,
208
- tabIndex: (item == null ? void 0 : item.disabled) ? -1 : 0
209
- },
210
- item.title
211
- );
212
- }), children)
137
+ /* @__PURE__ */ React.createElement(TabsContextProvider, { value: contextValue }, renderedTabs)
213
138
  ));
214
139
  });
215
140
  Tabs.displayName = "BuiTabs";
@@ -1,10 +1,5 @@
1
1
  import React, { SyntheticEvent } from 'react';
2
2
  import { OverrideProps } from '@bifrostui/types';
3
- export interface TabHeaderItem {
4
- title: React.ReactNode;
5
- index: string;
6
- disabled?: boolean;
7
- }
8
3
  export interface ITabsChangeData {
9
4
  /** 切换后的tab索引 */
10
5
  index: string;
@@ -19,9 +14,13 @@ export type ITabAlign = 'start' | 'center';
19
14
  export type TabsProps<D extends React.ElementType = 'div', P = {}> = OverrideProps<{
20
15
  props: P & {
21
16
  /**
22
- * 当前选中面板的索引值,与tabs.index对应
17
+ * 当前选中面板的索引值,与 ITabItem.index 对应
23
18
  */
24
19
  value?: string;
20
+ /**
21
+ * 默认选中面板的索引值(非受控模式)
22
+ */
23
+ defaultValue?: string;
25
24
  /**
26
25
  * 切换面板的数据
27
26
  */