@bifrostui/react 2.0.0-alpha.3 → 2.0.0-alpha.31

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 (515) hide show
  1. package/LICENSE +21 -0
  2. package/dist/ActionSheet/ActionSheet.d.ts +1 -1
  3. package/dist/ActionSheet/ActionSheet.js +8 -8
  4. package/dist/ActionSheet/ActionSheet.types.d.ts +1 -1
  5. package/dist/ActionSheet/ActionSheetContext.d.ts +1 -1
  6. package/dist/ActionSheet/ActionSheetContext.js +2 -2
  7. package/dist/ActionSheet/ActionSheetItem.types.d.ts +1 -1
  8. package/dist/Alert/Alert.d.ts +1 -1
  9. package/dist/Alert/Alert.js +16 -16
  10. package/dist/Alert/__tests__/fixtures/A11yDemos.d.ts +1 -1
  11. package/dist/Alert/__tests__/fixtures/A11yDemos.js +12 -12
  12. package/dist/Avatar/Avatar.d.ts +1 -1
  13. package/dist/Avatar/Avatar.js +5 -5
  14. package/dist/Avatar/Avatar.types.d.ts +1 -1
  15. package/dist/Avatar/AvatarGroup.types.d.ts +1 -1
  16. package/dist/Backdrop/Backdrop.d.ts +1 -1
  17. package/dist/Backdrop/Backdrop.js +3 -3
  18. package/dist/Backdrop/Backdrop.types.d.ts +1 -1
  19. package/dist/Backdrop/__tests__/fixtures/A11yDemos.d.ts +1 -1
  20. package/dist/Backdrop/__tests__/fixtures/A11yDemos.js +3 -3
  21. package/dist/Badge/Badge.d.ts +1 -1
  22. package/dist/Badge/Badge.js +4 -4
  23. package/dist/Badge/__tests__/fixtures/A11yDemos.d.ts +1 -1
  24. package/dist/Badge/__tests__/fixtures/A11yDemos.js +13 -13
  25. package/dist/Breadcrumb/Breadcrumb.d.ts +1 -1
  26. package/dist/Breadcrumb/Breadcrumb.js +9 -9
  27. package/dist/Breadcrumb/Breadcrumb.types.d.ts +1 -1
  28. package/dist/Breadcrumb/BreadcrumbItem.d.ts +1 -1
  29. package/dist/Breadcrumb/BreadcrumbItem.js +4 -4
  30. package/dist/Button/Button.d.ts +1 -1
  31. package/dist/Button/Button.js +6 -6
  32. package/dist/Button/Button.types.d.ts +1 -1
  33. package/dist/Button/__tests__/fixtures/A11yDemos.d.ts +1 -1
  34. package/dist/Button/__tests__/fixtures/A11yDemos.js +8 -8
  35. package/dist/Button/index.css +2 -3
  36. package/dist/CSSTransition/demo/CSSTransitionDemo.js +3 -0
  37. package/dist/CSSTransition/demo/index.css +0 -3
  38. package/dist/Calendar/Calendar.js +5 -1
  39. package/dist/Calendar/Calendar.types.d.ts +1 -1
  40. package/dist/Calendar/__tests__/fixtures/A11yDemos.d.ts +1 -1
  41. package/dist/Calendar/__tests__/fixtures/A11yDemos.js +2 -2
  42. package/dist/Card/Card.d.ts +1 -1
  43. package/dist/Card/Card.js +3 -3
  44. package/dist/Card/Card.types.d.ts +1 -1
  45. package/dist/Card/CardContent.d.ts +1 -1
  46. package/dist/Card/CardContent.js +3 -3
  47. package/dist/Card/CardContent.types.d.ts +1 -1
  48. package/dist/Card/CardFooter.d.ts +1 -1
  49. package/dist/Card/CardFooter.js +3 -3
  50. package/dist/Card/CardFooter.types.d.ts +1 -1
  51. package/dist/Card/CardHeader.d.ts +1 -1
  52. package/dist/Card/CardHeader.js +10 -10
  53. package/dist/Checkbox/CheckboxContext.d.ts +1 -1
  54. package/dist/Checkbox/CheckboxContext.js +2 -2
  55. package/dist/Checkbox/__tests__/fixtures/A11yDemos.d.ts +1 -1
  56. package/dist/Checkbox/__tests__/fixtures/A11yDemos.js +4 -4
  57. package/dist/CitySelector/CitySelector.types.d.ts +1 -1
  58. package/dist/CitySelector/Selector/index.d.ts +1 -1
  59. package/dist/CitySelector/Selector/index.js +2 -2
  60. package/dist/Collapse/Collapse.types.d.ts +1 -1
  61. package/dist/CollapsePanel/CollapsePanel.d.ts +1 -1
  62. package/dist/CollapsePanel/CollapsePanel.js +9 -9
  63. package/dist/CollapsePanel/CollapsePanel.types.d.ts +1 -1
  64. package/dist/CollapsePanel/CollapsePanelItem.d.ts +1 -1
  65. package/dist/CollapsePanel/CollapsePanelItem.js +5 -5
  66. package/dist/Countdown/Countdown.types.d.ts +2 -2
  67. package/dist/Countdown/__tests__/fixtures/A11yDemos.d.ts +1 -1
  68. package/dist/Countdown/__tests__/fixtures/A11yDemos.js +10 -10
  69. package/dist/Countdown/utils.d.ts +2 -2
  70. package/dist/Countdown/utils.js +4 -4
  71. package/dist/DatePicker/DatePicker.types.d.ts +1 -1
  72. package/dist/DesktopPicker/DesktopPicker.types.d.ts +1 -1
  73. package/dist/DesktopTimePicker/DesktopTimePicker.types.d.ts +11 -11
  74. package/dist/DesktopTimePicker/useGetTimePickerContent.js +2 -2
  75. package/dist/DesktopTimePicker/utils/utils.d.ts +1 -1
  76. package/dist/DesktopTimePicker/utils/utils.js +3 -3
  77. package/dist/Dialog/Dialog.js +19 -12
  78. package/dist/Dialog/Dialog.types.d.ts +13 -0
  79. package/dist/Dialog/FunctionalDialog.js +1 -1
  80. package/dist/Dialog/__tests__/fixtures/A11yDemos.d.ts +1 -1
  81. package/dist/Dialog/__tests__/fixtures/A11yDemos.js +4 -4
  82. package/dist/Dialog/index.css +21 -44
  83. package/dist/Divider/Divider.types.d.ts +1 -1
  84. package/dist/Drawer/Drawer.d.ts +1 -1
  85. package/dist/Drawer/Drawer.js +5 -5
  86. package/dist/Drawer/Drawer.types.d.ts +1 -1
  87. package/dist/Fade/Fade.d.ts +1 -1
  88. package/dist/Fade/Fade.js +4 -4
  89. package/dist/Fade/Fade.miniapp.js +13 -10
  90. package/dist/Fade/Fade.types.d.ts +1 -1
  91. package/dist/IconButton/IconButton.d.ts +1 -1
  92. package/dist/IconButton/IconButton.js +6 -6
  93. package/dist/IconButton/IconButton.types.d.ts +1 -1
  94. package/dist/Input/Input.types.d.ts +1 -1
  95. package/dist/Input/__tests__/fixtures/A11yDemos.d.ts +1 -1
  96. package/dist/Input/__tests__/fixtures/A11yDemos.js +7 -7
  97. package/dist/ItemSelector/ItemSelector.miniapp.js +7 -5
  98. package/dist/ItemSelector/ItemSelector.types.d.ts +1 -1
  99. package/dist/ItemSelector/Selector/index.d.ts +1 -1
  100. package/dist/ItemSelector/Selector/index.js +2 -2
  101. package/dist/List/List.d.ts +1 -1
  102. package/dist/List/List.js +4 -4
  103. package/dist/List/ListContext.d.ts +1 -1
  104. package/dist/List/ListContext.js +2 -2
  105. package/dist/List/ListItem.d.ts +1 -1
  106. package/dist/List/ListItem.js +8 -8
  107. package/dist/List/ListItem.types.d.ts +1 -1
  108. package/dist/List/ListItemContent.d.ts +1 -1
  109. package/dist/List/ListItemContent.js +3 -3
  110. package/dist/List/ListItemContent.types.d.ts +1 -1
  111. package/dist/List/ListItemExtra.d.ts +1 -1
  112. package/dist/List/ListItemExtra.js +3 -3
  113. package/dist/List/ListItemExtra.types.d.ts +1 -1
  114. package/dist/List/ListItemFooter.d.ts +1 -1
  115. package/dist/List/ListItemFooter.js +3 -3
  116. package/dist/List/ListItemFooter.types.d.ts +1 -1
  117. package/dist/List/ListItemHeader.d.ts +1 -1
  118. package/dist/List/ListItemHeader.js +3 -3
  119. package/dist/List/ListItemHeader.types.d.ts +1 -1
  120. package/dist/Loading/Loading.d.ts +1 -1
  121. package/dist/Loading/Loading.js +5 -5
  122. package/dist/Loading/Loading.types.d.ts +1 -1
  123. package/dist/Modal/Modal.d.ts +1 -1
  124. package/dist/Modal/Modal.js +6 -6
  125. package/dist/Modal/Modal.miniapp.d.ts +2 -2
  126. package/dist/Modal/Modal.miniapp.js +7 -7
  127. package/dist/Modal/__tests__/fixtures/A11yDemos.d.ts +1 -1
  128. package/dist/Modal/__tests__/fixtures/A11yDemos.js +3 -3
  129. package/dist/Modal/useModal.d.ts +1 -0
  130. package/dist/Modal/useModal.js +26 -29
  131. package/dist/NavBar/NavBar.d.ts +1 -1
  132. package/dist/NavBar/NavBar.js +10 -10
  133. package/dist/Picker/Picker.js +0 -1
  134. package/dist/Picker/Picker.types.d.ts +1 -1
  135. package/dist/Picker/__tests__/fixtures/A11yDemos.d.ts +1 -1
  136. package/dist/Picker/__tests__/fixtures/A11yDemos.js +2 -2
  137. package/dist/Popover/Popover.d.ts +1 -1
  138. package/dist/Popover/Popover.js +8 -8
  139. package/dist/Popover/Popover.types.d.ts +1 -1
  140. package/dist/Popover/__tests__/fixtures/A11yDemos.d.ts +1 -1
  141. package/dist/Popover/__tests__/fixtures/A11yDemos.js +21 -21
  142. package/dist/Portal/Portal.d.ts +1 -1
  143. package/dist/Portal/Portal.js +3 -3
  144. package/dist/Portal/Portal.miniapp.js +14 -8
  145. package/dist/Portal/Portal.types.d.ts +1 -1
  146. package/dist/Progress/Progress.d.ts +1 -1
  147. package/dist/Progress/Progress.js +4 -4
  148. package/dist/Progress/Progress.types.d.ts +1 -1
  149. package/dist/Progress/__tests__/fixtures/A11yDemos.d.ts +1 -1
  150. package/dist/Progress/__tests__/fixtures/A11yDemos.js +9 -9
  151. package/dist/Radio/RadioButtonIcon.d.ts +1 -1
  152. package/dist/Radio/RadioButtonIcon.js +4 -4
  153. package/dist/Radio/RadioContext.d.ts +1 -1
  154. package/dist/Radio/RadioContext.js +2 -2
  155. package/dist/Radio/__tests__/fixtures/A11yDemos.d.ts +1 -1
  156. package/dist/Radio/__tests__/fixtures/A11yDemos.js +4 -4
  157. package/dist/Radio/index.css +1 -0
  158. package/dist/Rating/Rating.types.d.ts +1 -1
  159. package/dist/ScrollView/ScrollView.types.d.ts +210 -1
  160. package/dist/ScrollView/__tests__/fixtures/A11yDemos.d.ts +1 -1
  161. package/dist/ScrollView/__tests__/fixtures/A11yDemos.js +30 -30
  162. package/dist/ScrollView/useScrollView.js +16 -4
  163. package/dist/Select/selectContext.d.ts +0 -1
  164. package/dist/Skeleton/Skeleton.d.ts +1 -1
  165. package/dist/Skeleton/Skeleton.js +3 -3
  166. package/dist/Skeleton/Skeleton.types.d.ts +1 -1
  167. package/dist/Slide/Slide.d.ts +1 -1
  168. package/dist/Slide/Slide.js +4 -4
  169. package/dist/Slide/Slide.miniapp.js +13 -10
  170. package/dist/Slider/Slider.types.d.ts +1 -1
  171. package/dist/Steps/Step.types.d.ts +1 -1
  172. package/dist/Steps/StepsContext.d.ts +1 -1
  173. package/dist/Steps/StepsContext.js +2 -2
  174. package/dist/SwipeAction/SwipeAction.js +7 -8
  175. package/dist/SwipeAction/SwipeAction.types.d.ts +1 -1
  176. package/dist/SwipeAction/SwipeActionContext.d.ts +0 -1
  177. package/dist/Swiper/Swiper.js +2 -0
  178. package/dist/Swiper/Swiper.types.d.ts +1 -1
  179. package/dist/Swiper/SwiperItem.d.ts +1 -1
  180. package/dist/Swiper/SwiperItem.js +2 -2
  181. package/dist/Switch/__tests__/fixtures/A11yDemos.d.ts +1 -1
  182. package/dist/Switch/__tests__/fixtures/A11yDemos.js +4 -4
  183. package/dist/TabBar/TabBar.d.ts +1 -1
  184. package/dist/TabBar/TabBar.js +5 -5
  185. package/dist/Tabs/Tab.css +1 -23
  186. package/dist/Tabs/Tab.d.ts +2 -2
  187. package/dist/Tabs/Tab.js +42 -34
  188. package/dist/Tabs/Tab.types.d.ts +1 -1
  189. package/dist/Tabs/TabIndicator.d.ts +11 -0
  190. package/dist/Tabs/TabIndicator.js +185 -0
  191. package/dist/Tabs/TabMask.d.ts +7 -0
  192. package/dist/Tabs/TabMask.js +47 -0
  193. package/dist/Tabs/TabPanel.js +4 -4
  194. package/dist/Tabs/TabPanel.types.d.ts +1 -1
  195. package/dist/Tabs/Tabs.css +17 -6
  196. package/dist/Tabs/Tabs.js +101 -157
  197. package/dist/Tabs/Tabs.types.d.ts +5 -6
  198. package/dist/Tabs/TabsContext.d.ts +15 -6
  199. package/dist/Tabs/TabsContext.js +6 -14
  200. package/dist/Tabs/classes.d.ts +13 -0
  201. package/dist/Tabs/classes.js +63 -0
  202. package/dist/Tabs/index.css +18 -29
  203. package/dist/Tabs/index.d.ts +2 -2
  204. package/dist/Tabs/index.js +4 -4
  205. package/dist/Tabs/index.miniapp.d.ts +5 -0
  206. package/dist/Tabs/index.miniapp.js +50 -0
  207. package/dist/Tabs/miniapp/Tab.d.ts +5 -0
  208. package/dist/Tabs/miniapp/Tab.js +106 -0
  209. package/dist/Tabs/miniapp/TabIndicator.d.ts +15 -0
  210. package/dist/Tabs/miniapp/TabIndicator.js +301 -0
  211. package/dist/Tabs/miniapp/Tabs.d.ts +5 -0
  212. package/dist/Tabs/miniapp/Tabs.js +250 -0
  213. package/dist/Tabs/miniapp/TabsContext.d.ts +17 -0
  214. package/dist/Tabs/miniapp/TabsContext.js +39 -0
  215. package/dist/Tabs/miniapp/index.d.ts +2 -0
  216. package/dist/Tabs/miniapp/index.js +41 -0
  217. package/dist/Tabs/miniapp/scroll.d.ts +21 -0
  218. package/dist/Tabs/miniapp/scroll.js +52 -0
  219. package/dist/Tabs/miniapp/utils/queryBatch.d.ts +68 -0
  220. package/dist/Tabs/miniapp/utils/queryBatch.js +100 -0
  221. package/dist/Tabs/utils/scroll.js +10 -4
  222. package/dist/Tag/Tag.css +11 -1
  223. package/dist/Tag/Tag.d.ts +1 -1
  224. package/dist/Tag/Tag.js +6 -6
  225. package/dist/Tag/Tag.types.d.ts +2 -2
  226. package/dist/Tag/TagGroup.d.ts +1 -1
  227. package/dist/Tag/TagGroup.js +3 -3
  228. package/dist/Tag/TagGroup.types.d.ts +1 -1
  229. package/dist/Tag/__tests__/fixtures/A11yDemos.js +3 -3
  230. package/dist/Tag/index.css +11 -1
  231. package/dist/TextArea/__tests__/fixtures/A11yDemos.d.ts +1 -1
  232. package/dist/TextArea/__tests__/fixtures/A11yDemos.js +6 -6
  233. package/dist/ThemeProvider/hooks/ThemeContext.d.ts +1 -1
  234. package/dist/ThemeProvider/hooks/ThemeContext.js +2 -2
  235. package/dist/ThemeProvider/hooks/useTheme.js +2 -2
  236. package/dist/ThemeProvider/utils/mountTokens.js +2 -2
  237. package/dist/Toast/FunctionalToast.js +3 -5
  238. package/dist/Toast/Toast.d.ts +1 -1
  239. package/dist/Toast/Toast.js +8 -8
  240. package/dist/Toast/Toast.types.d.ts +1 -1
  241. package/dist/Toast/__tests__/fixtures/A11yDemos.d.ts +1 -1
  242. package/dist/Toast/__tests__/fixtures/A11yDemos.js +2 -2
  243. package/dist/Toast/index.css +7 -5
  244. package/dist/Tooltip/Tooltip.d.ts +1 -1
  245. package/dist/Tooltip/Tooltip.js +5 -5
  246. package/dist/Tooltip/Tooltip.types.d.ts +1 -1
  247. package/dist/Tooltip/__tests__/fixtures/A11yDemos.d.ts +1 -1
  248. package/dist/Tooltip/__tests__/fixtures/A11yDemos.js +14 -14
  249. package/dist/Transition/Transition.d.ts +1 -1
  250. package/dist/Transition/Transition.js +3 -3
  251. package/dist/Transition/Transition.miniapp.d.ts +1 -1
  252. package/dist/Transition/Transition.miniapp.js +3 -3
  253. package/dist/Transition/TransitionCore.js +8 -2
  254. package/dist/_.._/benchmarks/components/Button.d.js +15 -0
  255. package/dist/_.._/benchmarks/components/Button.js +2 -2
  256. package/dist/_.._/benchmarks/components/Input.d.js +15 -0
  257. package/dist/_.._/benchmarks/components/Tabs.d.js +15 -0
  258. package/es/ActionSheet/ActionSheet.d.ts +1 -1
  259. package/es/ActionSheet/ActionSheet.js +1 -1
  260. package/es/ActionSheet/ActionSheet.types.d.ts +1 -1
  261. package/es/ActionSheet/ActionSheetContext.d.ts +1 -1
  262. package/es/ActionSheet/ActionSheetContext.js +1 -1
  263. package/es/ActionSheet/ActionSheetItem.types.d.ts +1 -1
  264. package/es/Alert/Alert.d.ts +1 -1
  265. package/es/Alert/Alert.js +1 -1
  266. package/es/Alert/__tests__/fixtures/A11yDemos.d.ts +1 -1
  267. package/es/Alert/__tests__/fixtures/A11yDemos.js +1 -1
  268. package/es/Avatar/Avatar.d.ts +1 -1
  269. package/es/Avatar/Avatar.js +1 -1
  270. package/es/Avatar/Avatar.types.d.ts +1 -1
  271. package/es/Avatar/AvatarGroup.types.d.ts +1 -1
  272. package/es/Backdrop/Backdrop.d.ts +1 -1
  273. package/es/Backdrop/Backdrop.js +1 -1
  274. package/es/Backdrop/Backdrop.types.d.ts +1 -1
  275. package/es/Backdrop/__tests__/fixtures/A11yDemos.d.ts +1 -1
  276. package/es/Backdrop/__tests__/fixtures/A11yDemos.js +1 -1
  277. package/es/Badge/Badge.d.ts +1 -1
  278. package/es/Badge/Badge.js +1 -1
  279. package/es/Badge/__tests__/fixtures/A11yDemos.d.ts +1 -1
  280. package/es/Badge/__tests__/fixtures/A11yDemos.js +1 -1
  281. package/es/Breadcrumb/Breadcrumb.d.ts +1 -1
  282. package/es/Breadcrumb/Breadcrumb.js +1 -1
  283. package/es/Breadcrumb/Breadcrumb.types.d.ts +1 -1
  284. package/es/Breadcrumb/BreadcrumbItem.d.ts +1 -1
  285. package/es/Breadcrumb/BreadcrumbItem.js +1 -1
  286. package/es/Button/Button.d.ts +1 -1
  287. package/es/Button/Button.js +1 -1
  288. package/es/Button/Button.types.d.ts +1 -1
  289. package/es/Button/__tests__/fixtures/A11yDemos.d.ts +1 -1
  290. package/es/Button/__tests__/fixtures/A11yDemos.js +1 -1
  291. package/es/Button/index.css +2 -3
  292. package/es/CSSTransition/demo/CSSTransitionDemo.js +3 -0
  293. package/es/CSSTransition/demo/index.css +0 -3
  294. package/es/Calendar/Calendar.js +5 -1
  295. package/es/Calendar/Calendar.types.d.ts +1 -1
  296. package/es/Calendar/__tests__/fixtures/A11yDemos.d.ts +1 -1
  297. package/es/Calendar/__tests__/fixtures/A11yDemos.js +1 -1
  298. package/es/Card/Card.d.ts +1 -1
  299. package/es/Card/Card.js +1 -1
  300. package/es/Card/Card.types.d.ts +1 -1
  301. package/es/Card/CardContent.d.ts +1 -1
  302. package/es/Card/CardContent.js +1 -1
  303. package/es/Card/CardContent.types.d.ts +1 -1
  304. package/es/Card/CardFooter.d.ts +1 -1
  305. package/es/Card/CardFooter.js +1 -1
  306. package/es/Card/CardFooter.types.d.ts +1 -1
  307. package/es/Card/CardHeader.d.ts +1 -1
  308. package/es/Card/CardHeader.js +1 -1
  309. package/es/Checkbox/CheckboxContext.d.ts +1 -1
  310. package/es/Checkbox/CheckboxContext.js +1 -1
  311. package/es/Checkbox/__tests__/fixtures/A11yDemos.d.ts +1 -1
  312. package/es/Checkbox/__tests__/fixtures/A11yDemos.js +1 -1
  313. package/es/CitySelector/CitySelector.types.d.ts +1 -1
  314. package/es/CitySelector/Selector/index.d.ts +1 -1
  315. package/es/CitySelector/Selector/index.js +1 -1
  316. package/es/Collapse/Collapse.types.d.ts +1 -1
  317. package/es/CollapsePanel/CollapsePanel.d.ts +1 -1
  318. package/es/CollapsePanel/CollapsePanel.js +1 -1
  319. package/es/CollapsePanel/CollapsePanel.types.d.ts +1 -1
  320. package/es/CollapsePanel/CollapsePanelItem.d.ts +1 -1
  321. package/es/CollapsePanel/CollapsePanelItem.js +1 -1
  322. package/es/Countdown/Countdown.types.d.ts +2 -2
  323. package/es/Countdown/__tests__/fixtures/A11yDemos.d.ts +1 -1
  324. package/es/Countdown/__tests__/fixtures/A11yDemos.js +1 -1
  325. package/es/Countdown/utils.d.ts +2 -2
  326. package/es/Countdown/utils.js +4 -4
  327. package/es/DatePicker/DatePicker.types.d.ts +1 -1
  328. package/es/DesktopPicker/DesktopPicker.types.d.ts +1 -1
  329. package/es/DesktopTimePicker/DesktopTimePicker.types.d.ts +11 -11
  330. package/es/DesktopTimePicker/useGetTimePickerContent.js +3 -3
  331. package/es/DesktopTimePicker/utils/utils.d.ts +1 -1
  332. package/es/DesktopTimePicker/utils/utils.js +2 -2
  333. package/es/Dialog/Dialog.js +19 -12
  334. package/es/Dialog/Dialog.types.d.ts +13 -0
  335. package/es/Dialog/FunctionalDialog.js +1 -1
  336. package/es/Dialog/__tests__/fixtures/A11yDemos.d.ts +1 -1
  337. package/es/Dialog/__tests__/fixtures/A11yDemos.js +1 -1
  338. package/es/Dialog/index.css +21 -44
  339. package/es/Divider/Divider.types.d.ts +1 -1
  340. package/es/Drawer/Drawer.d.ts +1 -1
  341. package/es/Drawer/Drawer.js +1 -1
  342. package/es/Drawer/Drawer.types.d.ts +1 -1
  343. package/es/Fade/Fade.d.ts +1 -1
  344. package/es/Fade/Fade.js +1 -1
  345. package/es/Fade/Fade.miniapp.js +14 -11
  346. package/es/Fade/Fade.types.d.ts +1 -1
  347. package/es/IconButton/IconButton.d.ts +1 -1
  348. package/es/IconButton/IconButton.js +1 -1
  349. package/es/IconButton/IconButton.types.d.ts +1 -1
  350. package/es/Input/Input.types.d.ts +1 -1
  351. package/es/Input/__tests__/fixtures/A11yDemos.d.ts +1 -1
  352. package/es/Input/__tests__/fixtures/A11yDemos.js +1 -1
  353. package/es/ItemSelector/ItemSelector.miniapp.js +7 -5
  354. package/es/ItemSelector/ItemSelector.types.d.ts +1 -1
  355. package/es/ItemSelector/Selector/index.d.ts +1 -1
  356. package/es/ItemSelector/Selector/index.js +1 -1
  357. package/es/List/List.d.ts +1 -1
  358. package/es/List/List.js +1 -1
  359. package/es/List/ListContext.d.ts +1 -1
  360. package/es/List/ListContext.js +1 -1
  361. package/es/List/ListItem.d.ts +1 -1
  362. package/es/List/ListItem.js +1 -1
  363. package/es/List/ListItem.types.d.ts +1 -1
  364. package/es/List/ListItemContent.d.ts +1 -1
  365. package/es/List/ListItemContent.js +1 -1
  366. package/es/List/ListItemContent.types.d.ts +1 -1
  367. package/es/List/ListItemExtra.d.ts +1 -1
  368. package/es/List/ListItemExtra.js +1 -1
  369. package/es/List/ListItemExtra.types.d.ts +1 -1
  370. package/es/List/ListItemFooter.d.ts +1 -1
  371. package/es/List/ListItemFooter.js +1 -1
  372. package/es/List/ListItemFooter.types.d.ts +1 -1
  373. package/es/List/ListItemHeader.d.ts +1 -1
  374. package/es/List/ListItemHeader.js +1 -1
  375. package/es/List/ListItemHeader.types.d.ts +1 -1
  376. package/es/Loading/Loading.d.ts +1 -1
  377. package/es/Loading/Loading.js +1 -1
  378. package/es/Loading/Loading.types.d.ts +1 -1
  379. package/es/Modal/Modal.d.ts +1 -1
  380. package/es/Modal/Modal.js +1 -1
  381. package/es/Modal/Modal.miniapp.d.ts +2 -2
  382. package/es/Modal/Modal.miniapp.js +1 -1
  383. package/es/Modal/__tests__/fixtures/A11yDemos.d.ts +1 -1
  384. package/es/Modal/__tests__/fixtures/A11yDemos.js +1 -1
  385. package/es/Modal/useModal.d.ts +1 -0
  386. package/es/Modal/useModal.js +26 -29
  387. package/es/NavBar/NavBar.d.ts +1 -1
  388. package/es/NavBar/NavBar.js +1 -1
  389. package/es/Picker/Picker.js +0 -1
  390. package/es/Picker/Picker.types.d.ts +1 -1
  391. package/es/Picker/__tests__/fixtures/A11yDemos.d.ts +1 -1
  392. package/es/Picker/__tests__/fixtures/A11yDemos.js +1 -1
  393. package/es/Popover/Popover.d.ts +1 -1
  394. package/es/Popover/Popover.js +1 -1
  395. package/es/Popover/Popover.types.d.ts +1 -1
  396. package/es/Popover/__tests__/fixtures/A11yDemos.d.ts +1 -1
  397. package/es/Popover/__tests__/fixtures/A11yDemos.js +1 -1
  398. package/es/Portal/Portal.d.ts +1 -1
  399. package/es/Portal/Portal.js +1 -1
  400. package/es/Portal/Portal.miniapp.js +15 -9
  401. package/es/Portal/Portal.types.d.ts +1 -1
  402. package/es/Progress/Progress.d.ts +1 -1
  403. package/es/Progress/Progress.js +1 -1
  404. package/es/Progress/Progress.types.d.ts +1 -1
  405. package/es/Progress/__tests__/fixtures/A11yDemos.d.ts +1 -1
  406. package/es/Progress/__tests__/fixtures/A11yDemos.js +1 -1
  407. package/es/Radio/RadioButtonIcon.d.ts +1 -1
  408. package/es/Radio/RadioButtonIcon.js +1 -1
  409. package/es/Radio/RadioContext.d.ts +1 -1
  410. package/es/Radio/RadioContext.js +1 -1
  411. package/es/Radio/__tests__/fixtures/A11yDemos.d.ts +1 -1
  412. package/es/Radio/__tests__/fixtures/A11yDemos.js +1 -1
  413. package/es/Radio/index.css +1 -0
  414. package/es/Rating/Rating.types.d.ts +1 -1
  415. package/es/ScrollView/ScrollView.types.d.ts +210 -1
  416. package/es/ScrollView/__tests__/fixtures/A11yDemos.d.ts +1 -1
  417. package/es/ScrollView/__tests__/fixtures/A11yDemos.js +1 -1
  418. package/es/ScrollView/useScrollView.js +16 -4
  419. package/es/Select/selectContext.d.ts +0 -1
  420. package/es/Skeleton/Skeleton.d.ts +1 -1
  421. package/es/Skeleton/Skeleton.js +1 -1
  422. package/es/Skeleton/Skeleton.types.d.ts +1 -1
  423. package/es/Slide/Slide.d.ts +1 -1
  424. package/es/Slide/Slide.js +1 -1
  425. package/es/Slide/Slide.miniapp.js +14 -11
  426. package/es/Slider/Slider.types.d.ts +1 -1
  427. package/es/Steps/Step.types.d.ts +1 -1
  428. package/es/Steps/StepsContext.d.ts +1 -1
  429. package/es/Steps/StepsContext.js +1 -1
  430. package/es/SwipeAction/SwipeAction.js +7 -8
  431. package/es/SwipeAction/SwipeAction.types.d.ts +1 -1
  432. package/es/SwipeAction/SwipeActionContext.d.ts +0 -1
  433. package/es/Swiper/Swiper.js +7 -1
  434. package/es/Swiper/Swiper.types.d.ts +1 -1
  435. package/es/Swiper/SwiperItem.d.ts +1 -1
  436. package/es/Swiper/SwiperItem.js +1 -1
  437. package/es/Switch/__tests__/fixtures/A11yDemos.d.ts +1 -1
  438. package/es/Switch/__tests__/fixtures/A11yDemos.js +1 -1
  439. package/es/TabBar/TabBar.d.ts +1 -1
  440. package/es/TabBar/TabBar.js +1 -1
  441. package/es/Tabs/Tab.css +1 -23
  442. package/es/Tabs/Tab.d.ts +2 -2
  443. package/es/Tabs/Tab.js +44 -36
  444. package/es/Tabs/Tab.types.d.ts +1 -1
  445. package/es/Tabs/TabIndicator.d.ts +11 -0
  446. package/es/Tabs/TabIndicator.js +156 -0
  447. package/es/Tabs/TabMask.d.ts +7 -0
  448. package/es/Tabs/TabMask.js +18 -0
  449. package/es/Tabs/TabPanel.js +8 -4
  450. package/es/Tabs/TabPanel.types.d.ts +1 -1
  451. package/es/Tabs/Tabs.css +17 -6
  452. package/es/Tabs/Tabs.js +102 -158
  453. package/es/Tabs/Tabs.types.d.ts +5 -6
  454. package/es/Tabs/TabsContext.d.ts +15 -6
  455. package/es/Tabs/TabsContext.js +6 -4
  456. package/es/Tabs/classes.d.ts +13 -0
  457. package/es/Tabs/classes.js +28 -0
  458. package/es/Tabs/index.css +18 -29
  459. package/es/Tabs/index.d.ts +2 -2
  460. package/es/Tabs/index.js +2 -2
  461. package/es/Tabs/index.miniapp.d.ts +5 -0
  462. package/es/Tabs/index.miniapp.js +11 -0
  463. package/es/Tabs/miniapp/Tab.d.ts +5 -0
  464. package/es/Tabs/miniapp/Tab.js +77 -0
  465. package/es/Tabs/miniapp/TabIndicator.d.ts +15 -0
  466. package/es/Tabs/miniapp/TabIndicator.js +272 -0
  467. package/es/Tabs/miniapp/Tabs.d.ts +5 -0
  468. package/es/Tabs/miniapp/Tabs.js +228 -0
  469. package/es/Tabs/miniapp/TabsContext.d.ts +17 -0
  470. package/es/Tabs/miniapp/TabsContext.js +16 -0
  471. package/es/Tabs/miniapp/index.d.ts +2 -0
  472. package/es/Tabs/miniapp/index.js +7 -0
  473. package/es/Tabs/miniapp/scroll.d.ts +21 -0
  474. package/es/Tabs/miniapp/scroll.js +29 -0
  475. package/es/Tabs/miniapp/utils/queryBatch.d.ts +68 -0
  476. package/es/Tabs/miniapp/utils/queryBatch.js +65 -0
  477. package/es/Tabs/utils/scroll.js +10 -4
  478. package/es/Tag/Tag.css +11 -1
  479. package/es/Tag/Tag.d.ts +1 -1
  480. package/es/Tag/Tag.js +4 -4
  481. package/es/Tag/Tag.types.d.ts +2 -2
  482. package/es/Tag/TagGroup.d.ts +1 -1
  483. package/es/Tag/TagGroup.js +1 -1
  484. package/es/Tag/TagGroup.types.d.ts +1 -1
  485. package/es/Tag/__tests__/fixtures/A11yDemos.js +3 -3
  486. package/es/Tag/index.css +11 -1
  487. package/es/TextArea/__tests__/fixtures/A11yDemos.d.ts +1 -1
  488. package/es/TextArea/__tests__/fixtures/A11yDemos.js +1 -1
  489. package/es/ThemeProvider/hooks/ThemeContext.d.ts +1 -1
  490. package/es/ThemeProvider/hooks/ThemeContext.js +1 -1
  491. package/es/ThemeProvider/hooks/useTheme.js +1 -1
  492. package/es/ThemeProvider/utils/mountTokens.js +1 -1
  493. package/es/Toast/FunctionalToast.js +4 -6
  494. package/es/Toast/Toast.d.ts +1 -1
  495. package/es/Toast/Toast.js +1 -1
  496. package/es/Toast/Toast.types.d.ts +1 -1
  497. package/es/Toast/__tests__/fixtures/A11yDemos.d.ts +1 -1
  498. package/es/Toast/__tests__/fixtures/A11yDemos.js +1 -1
  499. package/es/Toast/index.css +7 -5
  500. package/es/Tooltip/Tooltip.d.ts +1 -1
  501. package/es/Tooltip/Tooltip.js +1 -1
  502. package/es/Tooltip/Tooltip.types.d.ts +1 -1
  503. package/es/Tooltip/__tests__/fixtures/A11yDemos.d.ts +1 -1
  504. package/es/Tooltip/__tests__/fixtures/A11yDemos.js +1 -1
  505. package/es/Transition/Transition.d.ts +1 -1
  506. package/es/Transition/Transition.js +1 -1
  507. package/es/Transition/Transition.miniapp.d.ts +1 -1
  508. package/es/Transition/Transition.miniapp.js +1 -1
  509. package/es/Transition/TransitionCore.js +8 -2
  510. package/es/_.._/benchmarks/components/Button.d.js +0 -0
  511. package/es/_.._/benchmarks/components/Button.js +1 -1
  512. package/es/_.._/benchmarks/components/Input.d.js +0 -0
  513. package/es/_.._/benchmarks/components/Tabs.d.js +0 -0
  514. package/package.json +17 -26
  515. package/src/index.ts +0 -58
package/dist/Tabs/Tab.css CHANGED
@@ -1,5 +1,5 @@
1
1
  .bui-tab {
2
- display: flex;
2
+ display: inline-flex;
3
3
  align-items: center;
4
4
  justify-content: center;
5
5
  white-space: nowrap;
@@ -17,30 +17,8 @@
17
17
  .bui-tab-active {
18
18
  color: var(--bui-tab-active-color);
19
19
  font-weight: var(--bui-font-weight-bold);
20
- font-family: var(--bui-tab-active-font-family);
21
- }
22
- .bui-tab-miniapp-active {
23
- color: var(--bui-tab-active-color);
24
- line-height: 1.5;
25
- font-weight: var(--bui-font-weight-bold);
26
- position: relative;
27
- }
28
- .bui-tab-miniapp-active-line {
29
- position: absolute;
30
- bottom: 0;
31
- left: -12px;
32
- right: -12px;
33
- margin: 0 auto !important;
34
- width: 18px;
35
- height: 2px;
36
- transition: all 100ms cubic-bezier(0.4, 0, 0.2, 1) 0ms;
37
- background-color: var(--bui-color-primary);
38
20
  }
39
21
  .bui-tab-disabled {
40
22
  opacity: 0.5;
41
23
  pointer-events: none;
42
24
  }
43
- .bui-indicator-invisible {
44
- visibility: hidden;
45
- background-color: transparent;
46
- }
@@ -1,5 +1,5 @@
1
1
  import React from 'react';
2
2
  import { TabProps } from './Tab.types';
3
3
  import './Tab.less';
4
- declare const Tab: React.ForwardRefExoticComponent<Omit<TabProps<"div", {}>, "ref"> & React.RefAttributes<HTMLDivElement>>;
5
- export default Tab;
4
+ declare const _default: React.MemoExoticComponent<React.ForwardRefExoticComponent<Omit<TabProps<"div", {}>, "ref"> & React.RefAttributes<HTMLDivElement>>>;
5
+ export default _default;
package/dist/Tabs/Tab.js CHANGED
@@ -63,39 +63,52 @@ var import_react = __toESM(require("react"));
63
63
  var import_clsx = __toESM(require("clsx"));
64
64
  var import_utils = require("@bifrostui/utils");
65
65
  var import_TabsContext = __toESM(require("./TabsContext"));
66
+ var import_classes = require("./classes");
66
67
  var import_Tab2 = require("./Tab.css");
67
- const prefixCls = "bui-tab";
68
68
  const Tab = /* @__PURE__ */ import_react.default.forwardRef((props, ref) => {
69
69
  const _a = props, {
70
70
  className,
71
71
  children,
72
72
  index,
73
73
  disabled = false,
74
- onClick,
75
- role = "tab",
76
- tabIndex,
77
- "aria-selected": ariaSelected,
78
- "aria-disabled": ariaDisabled
74
+ onClick
79
75
  } = _a, others = __objRest(_a, [
80
76
  "className",
81
77
  "children",
82
78
  "index",
83
79
  "disabled",
84
- "onClick",
85
- "role",
86
- "tabIndex",
87
- "aria-selected",
88
- "aria-disabled"
80
+ "onClick"
89
81
  ]);
90
- const tabsContext = import_react.default.useContext(import_TabsContext.default);
91
- const { value, triggerChange } = tabsContext;
92
- const isActive = index === value;
82
+ const innerRef = (0, import_react.useRef)(null);
83
+ const handleRef = (0, import_utils.useForkRef)(ref, innerRef);
84
+ const isActive = (0, import_utils.useContextSelector)(
85
+ import_TabsContext.default,
86
+ (ctx) => ctx.value === index
87
+ );
88
+ const triggerChange = (0, import_utils.useContextSelector)(
89
+ import_TabsContext.default,
90
+ (ctx) => ctx.triggerChange
91
+ );
92
+ const onRegister = (0, import_utils.useContextSelector)(import_TabsContext.default, (ctx) => ctx.onRegister);
93
+ const onUnregister = (0, import_utils.useContextSelector)(
94
+ import_TabsContext.default,
95
+ (ctx) => ctx.onUnregister
96
+ );
97
+ (0, import_react.useEffect)(() => {
98
+ if (index !== void 0 && index !== null) {
99
+ onRegister == null ? void 0 : onRegister({ value: index, ref: innerRef });
100
+ }
101
+ return () => {
102
+ if (index !== void 0 && index !== null) {
103
+ onUnregister == null ? void 0 : onUnregister({ value: index });
104
+ }
105
+ };
106
+ }, [onRegister, onUnregister, index]);
93
107
  const rootCls = (0, import_clsx.default)(
94
- prefixCls,
108
+ import_classes.tabRootClass,
95
109
  {
96
- [`${prefixCls}-active`]: !import_utils.isMini && isActive,
97
- [`${prefixCls}-miniapp-active`]: import_utils.isMini && isActive,
98
- [`${prefixCls}-disabled`]: disabled
110
+ [import_classes.tabActiveClass]: !import_utils.isMini && isActive,
111
+ [import_classes.tabDisabledClass]: disabled
99
112
  },
100
113
  className
101
114
  );
@@ -103,31 +116,26 @@ const Tab = /* @__PURE__ */ import_react.default.forwardRef((props, ref) => {
103
116
  if (disabled)
104
117
  return;
105
118
  e.preventDefault();
106
- triggerChange(e, { index });
119
+ triggerChange == null ? void 0 : triggerChange(e, { index });
107
120
  onClick == null ? void 0 : onClick(e, { index });
108
121
  };
122
+ if (process.env.NODE_ENV !== "production") {
123
+ console.count("Tab render");
124
+ }
109
125
  return /* @__PURE__ */ import_react.default.createElement(
110
126
  "div",
111
127
  __spreadProps(__spreadValues({
112
- role,
113
- "aria-selected": ariaSelected != null ? ariaSelected : isActive,
114
- "aria-disabled": ariaDisabled != null ? ariaDisabled : disabled,
115
- tabIndex: tabIndex != null ? tabIndex : disabled ? -1 : 0,
116
- ref,
128
+ role: "tab",
129
+ "aria-selected": isActive,
130
+ "aria-disabled": disabled,
131
+ tabIndex: disabled ? -1 : 0,
132
+ ref: handleRef,
117
133
  className: rootCls
118
134
  }, others), {
119
135
  onClick: handleClick
120
136
  }),
121
- children,
122
- import_utils.isMini && /* @__PURE__ */ import_react.default.createElement(
123
- "div",
124
- {
125
- className: (0, import_clsx.default)(`${prefixCls}-miniapp-active-line`, {
126
- "bui-indicator-invisible": !isActive
127
- })
128
- }
129
- )
137
+ children
130
138
  );
131
139
  });
132
140
  Tab.displayName = "BuiTab";
133
- var Tab_default = Tab;
141
+ var Tab_default = /* @__PURE__ */ import_react.default.memo(Tab);
@@ -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,11 @@
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
+ }
10
+ declare const TabIndicator: React.FC<TabIndicatorProps>;
11
+ export default TabIndicator;
@@ -0,0 +1,185 @@
1
+ var __create = Object.create;
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __getProtoOf = Object.getPrototypeOf;
6
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
7
+ var __export = (target, all) => {
8
+ for (var name in all)
9
+ __defProp(target, name, { get: all[name], enumerable: true });
10
+ };
11
+ var __copyProps = (to, from, except, desc) => {
12
+ if (from && typeof from === "object" || typeof from === "function") {
13
+ for (let key of __getOwnPropNames(from))
14
+ if (!__hasOwnProp.call(to, key) && key !== except)
15
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
16
+ }
17
+ return to;
18
+ };
19
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
20
+ // If the importer is in node compatibility mode or this is not an ESM
21
+ // file that has been converted to a CommonJS file using a Babel-
22
+ // compatible transform (i.e. "__esModule" has not been set), then set
23
+ // "default" to the CommonJS "module.exports" for node compatibility.
24
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
25
+ mod
26
+ ));
27
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
28
+ var TabIndicator_exports = {};
29
+ __export(TabIndicator_exports, {
30
+ default: () => TabIndicator_default
31
+ });
32
+ module.exports = __toCommonJS(TabIndicator_exports);
33
+ var import_react = __toESM(require("react"));
34
+ var import_clsx = __toESM(require("clsx"));
35
+ var import_utils = require("@bifrostui/utils");
36
+ var import_scroll = __toESM(require("./utils/scroll"));
37
+ var import_classes = require("./classes");
38
+ const duration = 300;
39
+ const DEFAULT_INDICATOR_WIDTH = 24;
40
+ const TabIndicator = ({
41
+ currentValue,
42
+ registeredTabs,
43
+ tabsContainerRef
44
+ }) => {
45
+ const indicatorRef = (0, import_react.useRef)(null);
46
+ const hasRenderedOnce = (0, import_react.useRef)(false);
47
+ const [indicatorStyle, setIndicatorStyle] = (0, import_react.useState)(
48
+ null
49
+ );
50
+ const getActiveTabElement = (0, import_utils.useEventCallback)(
51
+ (activeValue) => {
52
+ const tabRef = registeredTabs.current[activeValue];
53
+ return tabRef == null ? void 0 : tabRef.current;
54
+ }
55
+ );
56
+ const scrollIntoView = (0, import_utils.useEventCallback)(
57
+ (activeTab, animate = true) => {
58
+ const tabsEl = tabsContainerRef.current;
59
+ if (!tabsEl || !activeTab) {
60
+ return;
61
+ }
62
+ (0, import_scroll.default)(
63
+ tabsEl,
64
+ activeTab.offsetLeft - (tabsEl.offsetWidth - activeTab.offsetWidth) / 2,
65
+ animate ? duration : 0
66
+ );
67
+ }
68
+ );
69
+ const getIndicatorWidth = (0, import_utils.useEventCallback)(() => {
70
+ const indicator = indicatorRef.current;
71
+ if (!indicator)
72
+ return DEFAULT_INDICATOR_WIDTH;
73
+ const rect = indicator.getBoundingClientRect();
74
+ return rect.width > 0 ? rect.width : DEFAULT_INDICATOR_WIDTH;
75
+ });
76
+ const getTabsMeta = (0, import_utils.useEventCallback)(() => {
77
+ const tabsNode = tabsContainerRef.current;
78
+ let tabsMeta = null;
79
+ if (tabsNode) {
80
+ const rect = tabsNode.getBoundingClientRect();
81
+ tabsMeta = {
82
+ clientWidth: tabsNode.clientWidth,
83
+ scrollLeft: tabsNode.scrollLeft,
84
+ scrollWidth: tabsNode.scrollWidth,
85
+ left: rect.left
86
+ };
87
+ }
88
+ let tabMeta = null;
89
+ const activeTab = getActiveTabElement(currentValue);
90
+ if (activeTab) {
91
+ tabMeta = activeTab.getBoundingClientRect();
92
+ }
93
+ return { tabsMeta, tabMeta };
94
+ });
95
+ const updateIndicatorState = (0, import_utils.useEventCallback)(() => {
96
+ const { tabsMeta, tabMeta } = getTabsMeta();
97
+ if (!tabMeta || !tabsMeta) {
98
+ setIndicatorStyle(null);
99
+ return;
100
+ }
101
+ const tabLeft = tabMeta.left - tabsMeta.left + tabsMeta.scrollLeft;
102
+ const tabWidth = tabMeta.width;
103
+ const indicatorWidth = getIndicatorWidth();
104
+ const leftPosition = tabLeft + (tabWidth - indicatorWidth) / 2;
105
+ const newIndicatorStyle = {
106
+ left: leftPosition
107
+ };
108
+ if (indicatorStyle === null) {
109
+ setIndicatorStyle(newIndicatorStyle);
110
+ } else {
111
+ const dLeft = Math.abs(indicatorStyle.left - newIndicatorStyle.left);
112
+ if (dLeft >= 1) {
113
+ setIndicatorStyle(newIndicatorStyle);
114
+ }
115
+ }
116
+ const activeTab = getActiveTabElement(currentValue);
117
+ if (activeTab) {
118
+ const maxScrollDistance = tabsMeta.scrollWidth - tabsMeta.clientWidth;
119
+ if (maxScrollDistance > 0 && !import_utils.isMini) {
120
+ scrollIntoView(activeTab, hasRenderedOnce.current);
121
+ }
122
+ hasRenderedOnce.current = true;
123
+ }
124
+ });
125
+ (0, import_react.useEffect)(() => {
126
+ updateIndicatorState();
127
+ });
128
+ (0, import_react.useEffect)(() => {
129
+ const tabsContainer = tabsContainerRef.current;
130
+ if (!tabsContainer)
131
+ return void 0;
132
+ const handleResize = (0, import_utils.debounce)(() => {
133
+ if (tabsContainerRef.current) {
134
+ updateIndicatorState();
135
+ }
136
+ }, 100);
137
+ window.addEventListener("resize", handleResize);
138
+ let resizeObserver;
139
+ let mutationObserver;
140
+ if (typeof ResizeObserver !== "undefined") {
141
+ resizeObserver = new ResizeObserver(handleResize);
142
+ Array.from(tabsContainer.children).forEach((child) => {
143
+ resizeObserver == null ? void 0 : resizeObserver.observe(child);
144
+ });
145
+ }
146
+ if (typeof MutationObserver !== "undefined") {
147
+ const handleMutation = (records) => {
148
+ records.forEach((record) => {
149
+ record.removedNodes.forEach((item) => {
150
+ if (item instanceof Element) {
151
+ resizeObserver == null ? void 0 : resizeObserver.unobserve(item);
152
+ }
153
+ });
154
+ record.addedNodes.forEach((item) => {
155
+ if (item instanceof Element) {
156
+ resizeObserver == null ? void 0 : resizeObserver.observe(item);
157
+ }
158
+ });
159
+ });
160
+ handleResize();
161
+ };
162
+ mutationObserver = new MutationObserver(handleMutation);
163
+ mutationObserver.observe(tabsContainer, { childList: true });
164
+ }
165
+ return () => {
166
+ window.removeEventListener("resize", handleResize);
167
+ mutationObserver == null ? void 0 : mutationObserver.disconnect();
168
+ resizeObserver == null ? void 0 : resizeObserver.disconnect();
169
+ };
170
+ }, [updateIndicatorState, tabsContainerRef]);
171
+ if (!indicatorStyle) {
172
+ return null;
173
+ }
174
+ return /* @__PURE__ */ import_react.default.createElement(
175
+ "div",
176
+ {
177
+ ref: indicatorRef,
178
+ className: (0, import_clsx.default)(import_classes.tabIndicatorClass),
179
+ style: indicatorStyle,
180
+ "aria-hidden": "true"
181
+ }
182
+ );
183
+ };
184
+ TabIndicator.displayName = "BuiTabsIndicator";
185
+ var TabIndicator_default = TabIndicator;
@@ -0,0 +1,7 @@
1
+ import React from 'react';
2
+ export interface TabMaskProps {
3
+ /** 位置:左侧或右侧 */
4
+ position: 'left' | 'right';
5
+ }
6
+ declare const _default: React.NamedExoticComponent<TabMaskProps>;
7
+ export default _default;
@@ -0,0 +1,47 @@
1
+ var __create = Object.create;
2
+ var __defProp = Object.defineProperty;
3
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
+ var __getOwnPropNames = Object.getOwnPropertyNames;
5
+ var __getProtoOf = Object.getPrototypeOf;
6
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
7
+ var __export = (target, all) => {
8
+ for (var name in all)
9
+ __defProp(target, name, { get: all[name], enumerable: true });
10
+ };
11
+ var __copyProps = (to, from, except, desc) => {
12
+ if (from && typeof from === "object" || typeof from === "function") {
13
+ for (let key of __getOwnPropNames(from))
14
+ if (!__hasOwnProp.call(to, key) && key !== except)
15
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
16
+ }
17
+ return to;
18
+ };
19
+ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
20
+ // If the importer is in node compatibility mode or this is not an ESM
21
+ // file that has been converted to a CommonJS file using a Babel-
22
+ // compatible transform (i.e. "__esModule" has not been set), then set
23
+ // "default" to the CommonJS "module.exports" for node compatibility.
24
+ isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
25
+ mod
26
+ ));
27
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
28
+ var TabMask_exports = {};
29
+ __export(TabMask_exports, {
30
+ default: () => TabMask_default
31
+ });
32
+ module.exports = __toCommonJS(TabMask_exports);
33
+ var import_react = __toESM(require("react"));
34
+ var import_clsx = __toESM(require("clsx"));
35
+ var import_classes = require("./classes");
36
+ const TabMask = ({ position }) => /* @__PURE__ */ import_react.default.createElement(
37
+ "div",
38
+ {
39
+ className: (0, import_clsx.default)(
40
+ import_classes.tabMaskClass,
41
+ position === "left" ? import_classes.tabMaskLeftClass : import_classes.tabMaskRightClass
42
+ ),
43
+ "aria-hidden": "true"
44
+ }
45
+ );
46
+ TabMask.displayName = "BuiTabsMask";
47
+ var TabMask_default = /* @__PURE__ */ import_react.default.memo(TabMask);
@@ -58,8 +58,8 @@ __export(TabPanel_exports, {
58
58
  module.exports = __toCommonJS(TabPanel_exports);
59
59
  var import_react = __toESM(require("react"));
60
60
  var import_clsx = __toESM(require("clsx"));
61
+ var import_classes = require("./classes");
61
62
  var import_TabPanel2 = require("./TabPanel.css");
62
- const prefixCls = "bui-tabpanel";
63
63
  const TabPanel = (0, import_react.forwardRef)((props, ref) => {
64
64
  const _a = props, {
65
65
  className,
@@ -83,9 +83,9 @@ const TabPanel = (0, import_react.forwardRef)((props, ref) => {
83
83
  "aria-hidden": !isActive,
84
84
  tabIndex: 0,
85
85
  ref,
86
- className: (0, import_clsx.default)(prefixCls, className, {
87
- [`${prefixCls}-active`]: isActive,
88
- [`${prefixCls}-inactive`]: !isActive
86
+ className: (0, import_clsx.default)(import_classes.tabPanelRootClass, className, {
87
+ [import_classes.tabPanelActiveClass]: isActive,
88
+ [import_classes.tabPanelInactiveClass]: !isActive
89
89
  })
90
90
  }, others),
91
91
  isActive ? children : keepActiveDom
@@ -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
  /**
@@ -2,6 +2,7 @@
2
2
  page,
3
3
  xhs-page {
4
4
  --bui-tabs-height: 39px;
5
+ --bui-tabs-padding: 0;
5
6
  --bui-tabs-font-weight: var(--bui-font-weight-medium);
6
7
  --bui-tabs-indicator-bg: var(--bui-color-primary);
7
8
  --bui-tabs-indicator-height: 3PX;
@@ -16,10 +17,10 @@ xhs-page {
16
17
  --bui-tab-height: 100%;
17
18
  --bui-tab-padding: var(--bui-spacing-lg) var(--bui-spacing-lg) 10px;
18
19
  --bui-tab-active-color: var(--bui-color-fg-default);
19
- --bui-tab-active-font-family: var(--bui-font-family-accent, inherit);
20
20
  }
21
21
  .bui-tabs {
22
22
  position: relative;
23
+ padding: var(--bui-tabs-padding);
23
24
  font-family: var(--bui-font-family);
24
25
  font-weight: var(--bui-tabs-font-weight);
25
26
  }
@@ -29,6 +30,7 @@ xhs-page {
29
30
  flex-wrap: nowrap;
30
31
  justify-content: flex-start;
31
32
  align-items: center;
33
+ white-space: nowrap;
32
34
  position: relative;
33
35
  overflow-x: scroll;
34
36
  scrollbar-width: none;
@@ -36,15 +38,28 @@ xhs-page {
36
38
  .bui-tabs-tabs::-webkit-scrollbar {
37
39
  display: none;
38
40
  }
41
+ .bui-tabs-scroll-wrapper {
42
+ height: 100%;
43
+ display: flex;
44
+ flex-direction: row;
45
+ flex-wrap: nowrap;
46
+ justify-content: flex-start;
47
+ align-items: center;
48
+ position: relative;
49
+ min-width: 100%;
50
+ }
39
51
  .bui-tabs-indicator {
40
52
  position: absolute;
53
+ top: unset;
54
+ bottom: var(--bui-tabs-indicator-bottom, 0);
41
55
  width: var(--bui-tabs-indicator-width);
42
- bottom: var(--bui-tabs-indicator-bottom);
43
56
  height: var(--bui-tabs-indicator-height);
44
57
  color: var(--bui-color-primary);
45
58
  background: var(--bui-tabs-indicator-bg);
46
59
  border-radius: var(--bui-tabs-indicator-border-radius);
47
60
  box-shadow: var(--bui-tabs-indicator-box-shadow);
61
+ pointer-events: none;
62
+ transition: left 0.3s ease-in-out;
48
63
  }
49
64
  .bui-tabs-content {
50
65
  padding: var(--bui-spacing-lg);
@@ -74,7 +89,3 @@ xhs-page {
74
89
  var(--bui-color-bg-view),
75
90
  rgba(255, 255, 255, 0));
76
91
  }
77
- .bui-indicator-invisible {
78
- visibility: hidden;
79
- background-color: transparent;
80
- }