@bifrostui/react 2.0.0-alpha.2 → 2.0.0-alpha.21

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 (484) 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/Button/index.css +2 -3
  35. package/dist/Calendar/Calendar.types.d.ts +1 -1
  36. package/dist/Calendar/__tests__/fixtures/A11yDemos.d.ts +1 -1
  37. package/dist/Calendar/__tests__/fixtures/A11yDemos.js +2 -2
  38. package/dist/Card/Card.d.ts +1 -1
  39. package/dist/Card/Card.js +3 -3
  40. package/dist/Card/Card.types.d.ts +1 -1
  41. package/dist/Card/CardContent.d.ts +1 -1
  42. package/dist/Card/CardContent.js +3 -3
  43. package/dist/Card/CardContent.types.d.ts +1 -1
  44. package/dist/Card/CardFooter.d.ts +1 -1
  45. package/dist/Card/CardFooter.js +3 -3
  46. package/dist/Card/CardFooter.types.d.ts +1 -1
  47. package/dist/Card/CardHeader.d.ts +1 -1
  48. package/dist/Card/CardHeader.js +10 -10
  49. package/dist/Checkbox/CheckboxContext.d.ts +1 -1
  50. package/dist/Checkbox/CheckboxContext.js +2 -2
  51. package/dist/Checkbox/__tests__/fixtures/A11yDemos.d.ts +1 -1
  52. package/dist/Checkbox/__tests__/fixtures/A11yDemos.js +4 -4
  53. package/dist/CitySelector/CitySelector.types.d.ts +1 -0
  54. package/dist/CitySelector/Selector/index.d.ts +1 -1
  55. package/dist/CitySelector/Selector/index.js +2 -2
  56. package/dist/Collapse/Collapse.types.d.ts +1 -1
  57. package/dist/CollapsePanel/CollapsePanel.d.ts +1 -1
  58. package/dist/CollapsePanel/CollapsePanel.js +9 -9
  59. package/dist/CollapsePanel/CollapsePanel.types.d.ts +1 -1
  60. package/dist/CollapsePanel/CollapsePanelItem.d.ts +1 -1
  61. package/dist/CollapsePanel/CollapsePanelItem.js +5 -5
  62. package/dist/Countdown/Countdown.types.d.ts +2 -2
  63. package/dist/Countdown/__tests__/fixtures/A11yDemos.d.ts +1 -1
  64. package/dist/Countdown/__tests__/fixtures/A11yDemos.js +10 -10
  65. package/dist/Countdown/utils.d.ts +2 -2
  66. package/dist/Countdown/utils.js +4 -4
  67. package/dist/DatePicker/DatePicker.types.d.ts +1 -1
  68. package/dist/DesktopPicker/DesktopPicker.types.d.ts +1 -1
  69. package/dist/DesktopTimePicker/DesktopTimePicker.types.d.ts +11 -11
  70. package/dist/DesktopTimePicker/useGetTimePickerContent.js +2 -2
  71. package/dist/DesktopTimePicker/utils/utils.d.ts +1 -1
  72. package/dist/DesktopTimePicker/utils/utils.js +3 -3
  73. package/dist/Dialog/__tests__/fixtures/A11yDemos.d.ts +1 -1
  74. package/dist/Dialog/__tests__/fixtures/A11yDemos.js +4 -4
  75. package/dist/Divider/Divider.types.d.ts +1 -1
  76. package/dist/Drawer/Drawer.d.ts +1 -1
  77. package/dist/Drawer/Drawer.js +5 -5
  78. package/dist/Drawer/Drawer.types.d.ts +1 -1
  79. package/dist/Fade/Fade.d.ts +1 -1
  80. package/dist/Fade/Fade.js +4 -4
  81. package/dist/Fade/Fade.miniapp.js +13 -10
  82. package/dist/Fade/Fade.types.d.ts +1 -1
  83. package/dist/IconButton/IconButton.d.ts +1 -1
  84. package/dist/IconButton/IconButton.js +6 -6
  85. package/dist/IconButton/IconButton.types.d.ts +1 -1
  86. package/dist/Input/Input.types.d.ts +1 -1
  87. package/dist/Input/__tests__/fixtures/A11yDemos.d.ts +1 -1
  88. package/dist/Input/__tests__/fixtures/A11yDemos.js +7 -7
  89. package/dist/ItemSelector/ItemSelector.miniapp.js +7 -5
  90. package/dist/ItemSelector/ItemSelector.types.d.ts +1 -0
  91. package/dist/ItemSelector/Selector/index.d.ts +1 -1
  92. package/dist/ItemSelector/Selector/index.js +2 -2
  93. package/dist/List/List.d.ts +1 -1
  94. package/dist/List/List.js +4 -4
  95. package/dist/List/ListContext.d.ts +1 -1
  96. package/dist/List/ListContext.js +2 -2
  97. package/dist/List/ListItem.d.ts +1 -1
  98. package/dist/List/ListItem.js +8 -8
  99. package/dist/List/ListItem.types.d.ts +1 -1
  100. package/dist/List/ListItemContent.d.ts +1 -1
  101. package/dist/List/ListItemContent.js +3 -3
  102. package/dist/List/ListItemContent.types.d.ts +1 -1
  103. package/dist/List/ListItemExtra.d.ts +1 -1
  104. package/dist/List/ListItemExtra.js +3 -3
  105. package/dist/List/ListItemExtra.types.d.ts +1 -1
  106. package/dist/List/ListItemFooter.d.ts +1 -1
  107. package/dist/List/ListItemFooter.js +3 -3
  108. package/dist/List/ListItemFooter.types.d.ts +1 -1
  109. package/dist/List/ListItemHeader.d.ts +1 -1
  110. package/dist/List/ListItemHeader.js +3 -3
  111. package/dist/List/ListItemHeader.types.d.ts +1 -1
  112. package/dist/Loading/Loading.d.ts +1 -1
  113. package/dist/Loading/Loading.js +5 -5
  114. package/dist/Loading/Loading.types.d.ts +1 -1
  115. package/dist/Modal/Modal.d.ts +1 -1
  116. package/dist/Modal/Modal.js +6 -6
  117. package/dist/Modal/Modal.miniapp.d.ts +1 -1
  118. package/dist/Modal/Modal.miniapp.js +7 -7
  119. package/dist/Modal/__tests__/fixtures/A11yDemos.d.ts +1 -1
  120. package/dist/Modal/__tests__/fixtures/A11yDemos.js +3 -3
  121. package/dist/Modal/useModal.js +26 -29
  122. package/dist/NavBar/NavBar.d.ts +1 -1
  123. package/dist/NavBar/NavBar.js +10 -10
  124. package/dist/Picker/Picker.js +0 -1
  125. package/dist/Picker/Picker.types.d.ts +1 -1
  126. package/dist/Picker/__tests__/fixtures/A11yDemos.d.ts +1 -1
  127. package/dist/Picker/__tests__/fixtures/A11yDemos.js +2 -2
  128. package/dist/Popover/Popover.d.ts +1 -1
  129. package/dist/Popover/Popover.js +8 -8
  130. package/dist/Popover/Popover.types.d.ts +1 -1
  131. package/dist/Popover/__tests__/fixtures/A11yDemos.d.ts +1 -1
  132. package/dist/Popover/__tests__/fixtures/A11yDemos.js +21 -21
  133. package/dist/Portal/Portal.d.ts +1 -1
  134. package/dist/Portal/Portal.js +3 -3
  135. package/dist/Portal/Portal.miniapp.js +14 -8
  136. package/dist/Portal/Portal.types.d.ts +1 -1
  137. package/dist/Progress/Progress.d.ts +1 -1
  138. package/dist/Progress/Progress.js +4 -4
  139. package/dist/Progress/Progress.types.d.ts +1 -1
  140. package/dist/Progress/__tests__/fixtures/A11yDemos.d.ts +1 -1
  141. package/dist/Progress/__tests__/fixtures/A11yDemos.js +9 -9
  142. package/dist/Radio/RadioButtonIcon.d.ts +1 -1
  143. package/dist/Radio/RadioButtonIcon.js +4 -4
  144. package/dist/Radio/RadioContext.d.ts +1 -1
  145. package/dist/Radio/RadioContext.js +2 -2
  146. package/dist/Radio/__tests__/fixtures/A11yDemos.d.ts +1 -1
  147. package/dist/Radio/__tests__/fixtures/A11yDemos.js +4 -4
  148. package/dist/Rating/Rating.types.d.ts +1 -1
  149. package/dist/ScrollView/ScrollView.types.d.ts +210 -1
  150. package/dist/ScrollView/__tests__/fixtures/A11yDemos.d.ts +1 -1
  151. package/dist/ScrollView/__tests__/fixtures/A11yDemos.js +30 -30
  152. package/dist/ScrollView/useScrollView.js +16 -4
  153. package/dist/Skeleton/Skeleton.d.ts +1 -1
  154. package/dist/Skeleton/Skeleton.js +3 -3
  155. package/dist/Skeleton/Skeleton.types.d.ts +1 -1
  156. package/dist/Slide/Slide.d.ts +1 -1
  157. package/dist/Slide/Slide.js +4 -4
  158. package/dist/Slide/Slide.miniapp.js +13 -10
  159. package/dist/Slider/Slider.types.d.ts +1 -1
  160. package/dist/Steps/Step.types.d.ts +1 -1
  161. package/dist/Steps/StepsContext.d.ts +1 -1
  162. package/dist/Steps/StepsContext.js +2 -2
  163. package/dist/SwipeAction/SwipeAction.js +7 -8
  164. package/dist/SwipeAction/SwipeAction.types.d.ts +1 -1
  165. package/dist/Swiper/Swiper.types.d.ts +1 -1
  166. package/dist/Swiper/SwiperItem.d.ts +1 -1
  167. package/dist/Swiper/SwiperItem.js +2 -2
  168. package/dist/Switch/__tests__/fixtures/A11yDemos.d.ts +1 -1
  169. package/dist/Switch/__tests__/fixtures/A11yDemos.js +4 -4
  170. package/dist/TabBar/TabBar.d.ts +1 -1
  171. package/dist/TabBar/TabBar.js +5 -5
  172. package/dist/Tabs/Tab.css +1 -23
  173. package/dist/Tabs/Tab.d.ts +2 -2
  174. package/dist/Tabs/Tab.js +42 -34
  175. package/dist/Tabs/Tab.types.d.ts +1 -1
  176. package/dist/Tabs/TabIndicator.d.ts +11 -0
  177. package/dist/Tabs/TabIndicator.js +185 -0
  178. package/dist/Tabs/TabMask.d.ts +7 -0
  179. package/dist/Tabs/TabMask.js +47 -0
  180. package/dist/Tabs/TabPanel.js +4 -4
  181. package/dist/Tabs/TabPanel.types.d.ts +1 -1
  182. package/dist/Tabs/Tabs.css +14 -6
  183. package/dist/Tabs/Tabs.js +99 -157
  184. package/dist/Tabs/Tabs.types.d.ts +5 -6
  185. package/dist/Tabs/TabsContext.d.ts +15 -6
  186. package/dist/Tabs/TabsContext.js +6 -14
  187. package/dist/Tabs/classes.d.ts +13 -0
  188. package/dist/Tabs/classes.js +63 -0
  189. package/dist/Tabs/index.css +15 -29
  190. package/dist/Tabs/index.d.ts +2 -2
  191. package/dist/Tabs/index.js +4 -4
  192. package/dist/Tabs/index.miniapp.d.ts +5 -0
  193. package/dist/Tabs/index.miniapp.js +50 -0
  194. package/dist/Tabs/miniapp/Tab.d.ts +5 -0
  195. package/dist/Tabs/miniapp/Tab.js +106 -0
  196. package/dist/Tabs/miniapp/TabIndicator.d.ts +15 -0
  197. package/dist/Tabs/miniapp/TabIndicator.js +301 -0
  198. package/dist/Tabs/miniapp/Tabs.d.ts +5 -0
  199. package/dist/Tabs/miniapp/Tabs.js +251 -0
  200. package/dist/Tabs/miniapp/TabsContext.d.ts +17 -0
  201. package/dist/Tabs/miniapp/TabsContext.js +39 -0
  202. package/dist/Tabs/miniapp/index.d.ts +2 -0
  203. package/dist/Tabs/miniapp/index.js +41 -0
  204. package/dist/Tabs/miniapp/scroll.d.ts +21 -0
  205. package/dist/Tabs/miniapp/scroll.js +52 -0
  206. package/dist/Tabs/miniapp/utils/queryBatch.d.ts +68 -0
  207. package/dist/Tabs/miniapp/utils/queryBatch.js +100 -0
  208. package/dist/Tabs/utils/scroll.js +10 -4
  209. package/dist/Tag/Tag.css +0 -1
  210. package/dist/Tag/Tag.d.ts +1 -1
  211. package/dist/Tag/Tag.js +6 -6
  212. package/dist/Tag/Tag.types.d.ts +1 -1
  213. package/dist/Tag/TagGroup.d.ts +1 -1
  214. package/dist/Tag/TagGroup.js +3 -3
  215. package/dist/Tag/TagGroup.types.d.ts +1 -1
  216. package/dist/Tag/__tests__/fixtures/A11yDemos.js +3 -3
  217. package/dist/Tag/index.css +0 -1
  218. package/dist/TextArea/__tests__/fixtures/A11yDemos.d.ts +1 -1
  219. package/dist/TextArea/__tests__/fixtures/A11yDemos.js +6 -6
  220. package/dist/ThemeProvider/hooks/ThemeContext.d.ts +1 -1
  221. package/dist/ThemeProvider/hooks/ThemeContext.js +2 -2
  222. package/dist/ThemeProvider/hooks/useTheme.js +2 -2
  223. package/dist/ThemeProvider/utils/mountTokens.js +2 -2
  224. package/dist/Toast/Toast.d.ts +1 -1
  225. package/dist/Toast/Toast.js +8 -8
  226. package/dist/Toast/__tests__/fixtures/A11yDemos.d.ts +1 -1
  227. package/dist/Toast/__tests__/fixtures/A11yDemos.js +2 -2
  228. package/dist/Tooltip/Tooltip.d.ts +1 -1
  229. package/dist/Tooltip/Tooltip.js +5 -5
  230. package/dist/Tooltip/Tooltip.types.d.ts +1 -1
  231. package/dist/Tooltip/__tests__/fixtures/A11yDemos.d.ts +1 -1
  232. package/dist/Tooltip/__tests__/fixtures/A11yDemos.js +14 -14
  233. package/dist/Transition/Transition.d.ts +1 -1
  234. package/dist/Transition/Transition.js +3 -3
  235. package/dist/Transition/Transition.miniapp.d.ts +1 -1
  236. package/dist/Transition/Transition.miniapp.js +3 -3
  237. package/dist/Transition/TransitionCore.js +8 -2
  238. package/dist/_.._/benchmarks/components/Button.d.js +15 -0
  239. package/dist/_.._/benchmarks/components/Button.js +2 -2
  240. package/dist/_.._/benchmarks/components/Input.d.js +15 -0
  241. package/dist/_.._/benchmarks/components/Tabs.d.js +15 -0
  242. package/es/ActionSheet/ActionSheet.d.ts +1 -1
  243. package/es/ActionSheet/ActionSheet.js +1 -1
  244. package/es/ActionSheet/ActionSheet.types.d.ts +1 -1
  245. package/es/ActionSheet/ActionSheetContext.d.ts +1 -1
  246. package/es/ActionSheet/ActionSheetContext.js +1 -1
  247. package/es/ActionSheet/ActionSheetItem.types.d.ts +1 -1
  248. package/es/Alert/Alert.d.ts +1 -1
  249. package/es/Alert/Alert.js +1 -1
  250. package/es/Alert/__tests__/fixtures/A11yDemos.d.ts +1 -1
  251. package/es/Alert/__tests__/fixtures/A11yDemos.js +1 -1
  252. package/es/Avatar/Avatar.d.ts +1 -1
  253. package/es/Avatar/Avatar.js +1 -1
  254. package/es/Avatar/Avatar.types.d.ts +1 -1
  255. package/es/Avatar/AvatarGroup.types.d.ts +1 -1
  256. package/es/Backdrop/Backdrop.d.ts +1 -1
  257. package/es/Backdrop/Backdrop.js +1 -1
  258. package/es/Backdrop/Backdrop.types.d.ts +1 -1
  259. package/es/Backdrop/__tests__/fixtures/A11yDemos.d.ts +1 -1
  260. package/es/Backdrop/__tests__/fixtures/A11yDemos.js +1 -1
  261. package/es/Badge/Badge.d.ts +1 -1
  262. package/es/Badge/Badge.js +1 -1
  263. package/es/Badge/__tests__/fixtures/A11yDemos.d.ts +1 -1
  264. package/es/Badge/__tests__/fixtures/A11yDemos.js +1 -1
  265. package/es/Breadcrumb/Breadcrumb.d.ts +1 -1
  266. package/es/Breadcrumb/Breadcrumb.js +1 -1
  267. package/es/Breadcrumb/Breadcrumb.types.d.ts +1 -1
  268. package/es/Breadcrumb/BreadcrumbItem.d.ts +1 -1
  269. package/es/Breadcrumb/BreadcrumbItem.js +1 -1
  270. package/es/Button/Button.d.ts +1 -1
  271. package/es/Button/Button.js +1 -1
  272. package/es/Button/Button.types.d.ts +1 -1
  273. package/es/Button/__tests__/fixtures/A11yDemos.d.ts +1 -1
  274. package/es/Button/__tests__/fixtures/A11yDemos.js +1 -1
  275. package/es/Button/index.css +2 -3
  276. package/es/Calendar/Calendar.types.d.ts +1 -1
  277. package/es/Calendar/__tests__/fixtures/A11yDemos.d.ts +1 -1
  278. package/es/Calendar/__tests__/fixtures/A11yDemos.js +1 -1
  279. package/es/Card/Card.d.ts +1 -1
  280. package/es/Card/Card.js +1 -1
  281. package/es/Card/Card.types.d.ts +1 -1
  282. package/es/Card/CardContent.d.ts +1 -1
  283. package/es/Card/CardContent.js +1 -1
  284. package/es/Card/CardContent.types.d.ts +1 -1
  285. package/es/Card/CardFooter.d.ts +1 -1
  286. package/es/Card/CardFooter.js +1 -1
  287. package/es/Card/CardFooter.types.d.ts +1 -1
  288. package/es/Card/CardHeader.d.ts +1 -1
  289. package/es/Card/CardHeader.js +1 -1
  290. package/es/Checkbox/CheckboxContext.d.ts +1 -1
  291. package/es/Checkbox/CheckboxContext.js +1 -1
  292. package/es/Checkbox/__tests__/fixtures/A11yDemos.d.ts +1 -1
  293. package/es/Checkbox/__tests__/fixtures/A11yDemos.js +1 -1
  294. package/es/CitySelector/CitySelector.types.d.ts +1 -0
  295. package/es/CitySelector/Selector/index.d.ts +1 -1
  296. package/es/CitySelector/Selector/index.js +1 -1
  297. package/es/Collapse/Collapse.types.d.ts +1 -1
  298. package/es/CollapsePanel/CollapsePanel.d.ts +1 -1
  299. package/es/CollapsePanel/CollapsePanel.js +1 -1
  300. package/es/CollapsePanel/CollapsePanel.types.d.ts +1 -1
  301. package/es/CollapsePanel/CollapsePanelItem.d.ts +1 -1
  302. package/es/CollapsePanel/CollapsePanelItem.js +1 -1
  303. package/es/Countdown/Countdown.types.d.ts +2 -2
  304. package/es/Countdown/__tests__/fixtures/A11yDemos.d.ts +1 -1
  305. package/es/Countdown/__tests__/fixtures/A11yDemos.js +1 -1
  306. package/es/Countdown/utils.d.ts +2 -2
  307. package/es/Countdown/utils.js +4 -4
  308. package/es/DatePicker/DatePicker.types.d.ts +1 -1
  309. package/es/DesktopPicker/DesktopPicker.types.d.ts +1 -1
  310. package/es/DesktopTimePicker/DesktopTimePicker.types.d.ts +11 -11
  311. package/es/DesktopTimePicker/useGetTimePickerContent.js +3 -3
  312. package/es/DesktopTimePicker/utils/utils.d.ts +1 -1
  313. package/es/DesktopTimePicker/utils/utils.js +2 -2
  314. package/es/Dialog/__tests__/fixtures/A11yDemos.d.ts +1 -1
  315. package/es/Dialog/__tests__/fixtures/A11yDemos.js +1 -1
  316. package/es/Divider/Divider.types.d.ts +1 -1
  317. package/es/Drawer/Drawer.d.ts +1 -1
  318. package/es/Drawer/Drawer.js +1 -1
  319. package/es/Drawer/Drawer.types.d.ts +1 -1
  320. package/es/Fade/Fade.d.ts +1 -1
  321. package/es/Fade/Fade.js +1 -1
  322. package/es/Fade/Fade.miniapp.js +14 -11
  323. package/es/Fade/Fade.types.d.ts +1 -1
  324. package/es/IconButton/IconButton.d.ts +1 -1
  325. package/es/IconButton/IconButton.js +1 -1
  326. package/es/IconButton/IconButton.types.d.ts +1 -1
  327. package/es/Input/Input.types.d.ts +1 -1
  328. package/es/Input/__tests__/fixtures/A11yDemos.d.ts +1 -1
  329. package/es/Input/__tests__/fixtures/A11yDemos.js +1 -1
  330. package/es/ItemSelector/ItemSelector.miniapp.js +7 -5
  331. package/es/ItemSelector/ItemSelector.types.d.ts +1 -0
  332. package/es/ItemSelector/Selector/index.d.ts +1 -1
  333. package/es/ItemSelector/Selector/index.js +1 -1
  334. package/es/List/List.d.ts +1 -1
  335. package/es/List/List.js +1 -1
  336. package/es/List/ListContext.d.ts +1 -1
  337. package/es/List/ListContext.js +1 -1
  338. package/es/List/ListItem.d.ts +1 -1
  339. package/es/List/ListItem.js +1 -1
  340. package/es/List/ListItem.types.d.ts +1 -1
  341. package/es/List/ListItemContent.d.ts +1 -1
  342. package/es/List/ListItemContent.js +1 -1
  343. package/es/List/ListItemContent.types.d.ts +1 -1
  344. package/es/List/ListItemExtra.d.ts +1 -1
  345. package/es/List/ListItemExtra.js +1 -1
  346. package/es/List/ListItemExtra.types.d.ts +1 -1
  347. package/es/List/ListItemFooter.d.ts +1 -1
  348. package/es/List/ListItemFooter.js +1 -1
  349. package/es/List/ListItemFooter.types.d.ts +1 -1
  350. package/es/List/ListItemHeader.d.ts +1 -1
  351. package/es/List/ListItemHeader.js +1 -1
  352. package/es/List/ListItemHeader.types.d.ts +1 -1
  353. package/es/Loading/Loading.d.ts +1 -1
  354. package/es/Loading/Loading.js +1 -1
  355. package/es/Loading/Loading.types.d.ts +1 -1
  356. package/es/Modal/Modal.d.ts +1 -1
  357. package/es/Modal/Modal.js +1 -1
  358. package/es/Modal/Modal.miniapp.d.ts +1 -1
  359. package/es/Modal/Modal.miniapp.js +1 -1
  360. package/es/Modal/__tests__/fixtures/A11yDemos.d.ts +1 -1
  361. package/es/Modal/__tests__/fixtures/A11yDemos.js +1 -1
  362. package/es/Modal/useModal.js +26 -29
  363. package/es/NavBar/NavBar.d.ts +1 -1
  364. package/es/NavBar/NavBar.js +1 -1
  365. package/es/Picker/Picker.js +0 -1
  366. package/es/Picker/Picker.types.d.ts +1 -1
  367. package/es/Picker/__tests__/fixtures/A11yDemos.d.ts +1 -1
  368. package/es/Picker/__tests__/fixtures/A11yDemos.js +1 -1
  369. package/es/Popover/Popover.d.ts +1 -1
  370. package/es/Popover/Popover.js +1 -1
  371. package/es/Popover/Popover.types.d.ts +1 -1
  372. package/es/Popover/__tests__/fixtures/A11yDemos.d.ts +1 -1
  373. package/es/Popover/__tests__/fixtures/A11yDemos.js +1 -1
  374. package/es/Portal/Portal.d.ts +1 -1
  375. package/es/Portal/Portal.js +1 -1
  376. package/es/Portal/Portal.miniapp.js +15 -9
  377. package/es/Portal/Portal.types.d.ts +1 -1
  378. package/es/Progress/Progress.d.ts +1 -1
  379. package/es/Progress/Progress.js +1 -1
  380. package/es/Progress/Progress.types.d.ts +1 -1
  381. package/es/Progress/__tests__/fixtures/A11yDemos.d.ts +1 -1
  382. package/es/Progress/__tests__/fixtures/A11yDemos.js +1 -1
  383. package/es/Radio/RadioButtonIcon.d.ts +1 -1
  384. package/es/Radio/RadioButtonIcon.js +1 -1
  385. package/es/Radio/RadioContext.d.ts +1 -1
  386. package/es/Radio/RadioContext.js +1 -1
  387. package/es/Radio/__tests__/fixtures/A11yDemos.d.ts +1 -1
  388. package/es/Radio/__tests__/fixtures/A11yDemos.js +1 -1
  389. package/es/Rating/Rating.types.d.ts +1 -1
  390. package/es/ScrollView/ScrollView.types.d.ts +210 -1
  391. package/es/ScrollView/__tests__/fixtures/A11yDemos.d.ts +1 -1
  392. package/es/ScrollView/__tests__/fixtures/A11yDemos.js +1 -1
  393. package/es/ScrollView/useScrollView.js +16 -4
  394. package/es/Skeleton/Skeleton.d.ts +1 -1
  395. package/es/Skeleton/Skeleton.js +1 -1
  396. package/es/Skeleton/Skeleton.types.d.ts +1 -1
  397. package/es/Slide/Slide.d.ts +1 -1
  398. package/es/Slide/Slide.js +1 -1
  399. package/es/Slide/Slide.miniapp.js +14 -11
  400. package/es/Slider/Slider.types.d.ts +1 -1
  401. package/es/Steps/Step.types.d.ts +1 -1
  402. package/es/Steps/StepsContext.d.ts +1 -1
  403. package/es/Steps/StepsContext.js +1 -1
  404. package/es/SwipeAction/SwipeAction.js +7 -8
  405. package/es/SwipeAction/SwipeAction.types.d.ts +1 -1
  406. package/es/Swiper/Swiper.js +5 -1
  407. package/es/Swiper/Swiper.types.d.ts +1 -1
  408. package/es/Swiper/SwiperItem.d.ts +1 -1
  409. package/es/Swiper/SwiperItem.js +1 -1
  410. package/es/Switch/__tests__/fixtures/A11yDemos.d.ts +1 -1
  411. package/es/Switch/__tests__/fixtures/A11yDemos.js +1 -1
  412. package/es/TabBar/TabBar.d.ts +1 -1
  413. package/es/TabBar/TabBar.js +1 -1
  414. package/es/Tabs/Tab.css +1 -23
  415. package/es/Tabs/Tab.d.ts +2 -2
  416. package/es/Tabs/Tab.js +44 -36
  417. package/es/Tabs/Tab.types.d.ts +1 -1
  418. package/es/Tabs/TabIndicator.d.ts +11 -0
  419. package/es/Tabs/TabIndicator.js +156 -0
  420. package/es/Tabs/TabMask.d.ts +7 -0
  421. package/es/Tabs/TabMask.js +18 -0
  422. package/es/Tabs/TabPanel.js +8 -4
  423. package/es/Tabs/TabPanel.types.d.ts +1 -1
  424. package/es/Tabs/Tabs.css +14 -6
  425. package/es/Tabs/Tabs.js +100 -158
  426. package/es/Tabs/Tabs.types.d.ts +5 -6
  427. package/es/Tabs/TabsContext.d.ts +15 -6
  428. package/es/Tabs/TabsContext.js +6 -4
  429. package/es/Tabs/classes.d.ts +13 -0
  430. package/es/Tabs/classes.js +28 -0
  431. package/es/Tabs/index.css +15 -29
  432. package/es/Tabs/index.d.ts +2 -2
  433. package/es/Tabs/index.js +2 -2
  434. package/es/Tabs/index.miniapp.d.ts +5 -0
  435. package/es/Tabs/index.miniapp.js +11 -0
  436. package/es/Tabs/miniapp/Tab.d.ts +5 -0
  437. package/es/Tabs/miniapp/Tab.js +77 -0
  438. package/es/Tabs/miniapp/TabIndicator.d.ts +15 -0
  439. package/es/Tabs/miniapp/TabIndicator.js +272 -0
  440. package/es/Tabs/miniapp/Tabs.d.ts +5 -0
  441. package/es/Tabs/miniapp/Tabs.js +229 -0
  442. package/es/Tabs/miniapp/TabsContext.d.ts +17 -0
  443. package/es/Tabs/miniapp/TabsContext.js +16 -0
  444. package/es/Tabs/miniapp/index.d.ts +2 -0
  445. package/es/Tabs/miniapp/index.js +7 -0
  446. package/es/Tabs/miniapp/scroll.d.ts +21 -0
  447. package/es/Tabs/miniapp/scroll.js +29 -0
  448. package/es/Tabs/miniapp/utils/queryBatch.d.ts +68 -0
  449. package/es/Tabs/miniapp/utils/queryBatch.js +65 -0
  450. package/es/Tabs/utils/scroll.js +10 -4
  451. package/es/Tag/Tag.css +0 -1
  452. package/es/Tag/Tag.d.ts +1 -1
  453. package/es/Tag/Tag.js +4 -4
  454. package/es/Tag/Tag.types.d.ts +1 -1
  455. package/es/Tag/TagGroup.d.ts +1 -1
  456. package/es/Tag/TagGroup.js +1 -1
  457. package/es/Tag/TagGroup.types.d.ts +1 -1
  458. package/es/Tag/__tests__/fixtures/A11yDemos.js +3 -3
  459. package/es/Tag/index.css +0 -1
  460. package/es/TextArea/__tests__/fixtures/A11yDemos.d.ts +1 -1
  461. package/es/TextArea/__tests__/fixtures/A11yDemos.js +1 -1
  462. package/es/ThemeProvider/hooks/ThemeContext.d.ts +1 -1
  463. package/es/ThemeProvider/hooks/ThemeContext.js +1 -1
  464. package/es/ThemeProvider/hooks/useTheme.js +1 -1
  465. package/es/ThemeProvider/utils/mountTokens.js +1 -1
  466. package/es/Toast/Toast.d.ts +1 -1
  467. package/es/Toast/Toast.js +1 -1
  468. package/es/Toast/__tests__/fixtures/A11yDemos.d.ts +1 -1
  469. package/es/Toast/__tests__/fixtures/A11yDemos.js +1 -1
  470. package/es/Tooltip/Tooltip.d.ts +1 -1
  471. package/es/Tooltip/Tooltip.js +1 -1
  472. package/es/Tooltip/Tooltip.types.d.ts +1 -1
  473. package/es/Tooltip/__tests__/fixtures/A11yDemos.d.ts +1 -1
  474. package/es/Tooltip/__tests__/fixtures/A11yDemos.js +1 -1
  475. package/es/Transition/Transition.d.ts +1 -1
  476. package/es/Transition/Transition.js +1 -1
  477. package/es/Transition/Transition.miniapp.d.ts +1 -1
  478. package/es/Transition/Transition.miniapp.js +1 -1
  479. package/es/Transition/TransitionCore.js +8 -2
  480. package/es/_.._/benchmarks/components/Button.d.js +0 -0
  481. package/es/_.._/benchmarks/components/Button.js +1 -1
  482. package/es/_.._/benchmarks/components/Input.d.js +0 -0
  483. package/es/_.._/benchmarks/components/Tabs.d.js +0 -0
  484. package/package.json +7 -6
@@ -0,0 +1,28 @@
1
+ const tabsRootClass = "bui-tabs";
2
+ const tabRootClass = "bui-tab";
3
+ const tabPanelRootClass = "bui-tabpanel";
4
+ const tabsScrollClass = `${tabsRootClass}-tabs`;
5
+ const tabsScrollWrapperClass = `${tabsRootClass}-scroll-wrapper`;
6
+ const tabActiveClass = `${tabRootClass}-active`;
7
+ const tabDisabledClass = `${tabRootClass}-disabled`;
8
+ const tabIndicatorClass = `${tabsRootClass}-indicator`;
9
+ const tabMaskClass = `${tabsRootClass}-mask`;
10
+ const tabMaskLeftClass = `${tabMaskClass}-left`;
11
+ const tabMaskRightClass = `${tabMaskClass}-right`;
12
+ const tabPanelActiveClass = `${tabPanelRootClass}-active`;
13
+ const tabPanelInactiveClass = `${tabPanelRootClass}-inactive`;
14
+ export {
15
+ tabActiveClass,
16
+ tabDisabledClass,
17
+ tabIndicatorClass,
18
+ tabMaskClass,
19
+ tabMaskLeftClass,
20
+ tabMaskRightClass,
21
+ tabPanelActiveClass,
22
+ tabPanelInactiveClass,
23
+ tabPanelRootClass,
24
+ tabRootClass,
25
+ tabsRootClass,
26
+ tabsScrollClass,
27
+ tabsScrollWrapperClass
28
+ };
package/es/Tabs/index.css CHANGED
@@ -16,7 +16,6 @@ xhs-page {
16
16
  --bui-tab-height: 100%;
17
17
  --bui-tab-padding: var(--bui-spacing-lg) var(--bui-spacing-lg) 10px;
18
18
  --bui-tab-active-color: var(--bui-color-fg-default);
19
- --bui-tab-active-font-family: var(--bui-font-family-accent, inherit);
20
19
  }
21
20
  .bui-tabs {
22
21
  position: relative;
@@ -29,6 +28,7 @@ xhs-page {
29
28
  flex-wrap: nowrap;
30
29
  justify-content: flex-start;
31
30
  align-items: center;
31
+ white-space: nowrap;
32
32
  position: relative;
33
33
  overflow-x: scroll;
34
34
  scrollbar-width: none;
@@ -36,15 +36,27 @@ xhs-page {
36
36
  .bui-tabs-tabs::-webkit-scrollbar {
37
37
  display: none;
38
38
  }
39
+ .bui-tabs-scroll-wrapper {
40
+ height: 100%;
41
+ display: flex;
42
+ flex-wrap: nowrap;
43
+ justify-content: flex-start;
44
+ align-items: center;
45
+ position: relative;
46
+ min-width: 100%;
47
+ }
39
48
  .bui-tabs-indicator {
40
49
  position: absolute;
50
+ top: unset;
51
+ bottom: var(--bui-tabs-indicator-bottom, 0);
41
52
  width: var(--bui-tabs-indicator-width);
42
- bottom: var(--bui-tabs-indicator-bottom);
43
53
  height: var(--bui-tabs-indicator-height);
44
54
  color: var(--bui-color-primary);
45
55
  background: var(--bui-tabs-indicator-bg);
46
56
  border-radius: var(--bui-tabs-indicator-border-radius);
47
57
  box-shadow: var(--bui-tabs-indicator-box-shadow);
58
+ pointer-events: none;
59
+ transition: left 0.3s ease-in-out;
48
60
  }
49
61
  .bui-tabs-content {
50
62
  padding: var(--bui-spacing-lg);
@@ -74,12 +86,8 @@ xhs-page {
74
86
  var(--bui-color-bg-view),
75
87
  rgba(255, 255, 255, 0));
76
88
  }
77
- .bui-indicator-invisible {
78
- visibility: hidden;
79
- background-color: transparent;
80
- }
81
89
  .bui-tab {
82
- display: flex;
90
+ display: inline-flex;
83
91
  align-items: center;
84
92
  justify-content: center;
85
93
  white-space: nowrap;
@@ -97,33 +105,11 @@ xhs-page {
97
105
  .bui-tab-active {
98
106
  color: var(--bui-tab-active-color);
99
107
  font-weight: var(--bui-font-weight-bold);
100
- font-family: var(--bui-tab-active-font-family);
101
- }
102
- .bui-tab-miniapp-active {
103
- color: var(--bui-tab-active-color);
104
- line-height: 1.5;
105
- font-weight: var(--bui-font-weight-bold);
106
- position: relative;
107
- }
108
- .bui-tab-miniapp-active-line {
109
- position: absolute;
110
- bottom: 0;
111
- left: -12px;
112
- right: -12px;
113
- margin: 0 auto !important;
114
- width: 18px;
115
- height: 2px;
116
- transition: all 100ms cubic-bezier(0.4, 0, 0.2, 1) 0ms;
117
- background-color: var(--bui-color-primary);
118
108
  }
119
109
  .bui-tab-disabled {
120
110
  opacity: 0.5;
121
111
  pointer-events: none;
122
112
  }
123
- .bui-indicator-invisible {
124
- visibility: hidden;
125
- background-color: transparent;
126
- }
127
113
  .bui-tabpanel {
128
114
  font-family: var(--bui-font-family);
129
115
  }
@@ -1,6 +1,6 @@
1
1
  export { default as Tab } from './Tab';
2
- export * from './Tab.types';
3
2
  export { default as TabPanel } from './TabPanel';
4
- export * from './TabPanel.types';
5
3
  export { default, default as Tabs } from './Tabs';
6
4
  export * from './Tabs.types';
5
+ export * from './Tab.types';
6
+ export * from './TabPanel.types';
package/es/Tabs/index.js CHANGED
@@ -1,9 +1,9 @@
1
1
  import { default as default2 } from "./Tab";
2
- export * from "./Tab.types";
3
2
  import { default as default3 } from "./TabPanel";
4
- export * from "./TabPanel.types";
5
3
  import { default as default4, default as default5 } from "./Tabs";
6
4
  export * from "./Tabs.types";
5
+ export * from "./Tab.types";
6
+ export * from "./TabPanel.types";
7
7
  export {
8
8
  default2 as Tab,
9
9
  default3 as TabPanel,
@@ -0,0 +1,5 @@
1
+ export { default, Tab, Tabs } from './miniapp';
2
+ export { default as TabPanel } from './TabPanel';
3
+ export * from './Tabs.types';
4
+ export * from './Tab.types';
5
+ export * from './TabPanel.types';
@@ -0,0 +1,11 @@
1
+ import { default as default2, Tab, Tabs } from "./miniapp";
2
+ import { default as default3 } from "./TabPanel";
3
+ export * from "./Tabs.types";
4
+ export * from "./Tab.types";
5
+ export * from "./TabPanel.types";
6
+ export {
7
+ Tab,
8
+ default3 as TabPanel,
9
+ Tabs,
10
+ default2 as default
11
+ };
@@ -0,0 +1,5 @@
1
+ import React from 'react';
2
+ import { TabProps } from '../Tab.types';
3
+ import '../Tab.less';
4
+ declare const _default: React.MemoExoticComponent<React.ForwardRefExoticComponent<Omit<TabProps<"div", {}>, "ref"> & React.RefAttributes<HTMLDivElement>>>;
5
+ export default _default;
@@ -0,0 +1,77 @@
1
+ import React, { useEffect, useRef } from "react";
2
+ import clsx from "clsx";
3
+ import { useContextSelector, useForkRef } from "@bifrostui/utils";
4
+ import TabsContext from "./TabsContext";
5
+ import { tabRootClass, tabActiveClass, tabDisabledClass } from "../classes";
6
+ import "../Tab.css";
7
+ const Tab = /* @__PURE__ */ React.forwardRef((props, ref) => {
8
+ const {
9
+ className,
10
+ children,
11
+ index,
12
+ disabled = false,
13
+ onClick,
14
+ style
15
+ } = props;
16
+ const innerRef = useRef(null);
17
+ const handleRef = useForkRef(ref, innerRef);
18
+ const isActive = useContextSelector(
19
+ TabsContext,
20
+ (ctx) => ctx.value === index
21
+ );
22
+ const triggerChange = useContextSelector(
23
+ TabsContext,
24
+ (ctx) => ctx.triggerChange
25
+ );
26
+ const onRegister = useContextSelector(TabsContext, (ctx) => ctx.onRegister);
27
+ const onUnregister = useContextSelector(
28
+ TabsContext,
29
+ (ctx) => ctx.onUnregister
30
+ );
31
+ const tabsContainerId = useContextSelector(
32
+ TabsContext,
33
+ (ctx) => ctx.tabsContainerId
34
+ );
35
+ useEffect(() => {
36
+ if (index !== void 0 && index !== null) {
37
+ onRegister == null ? void 0 : onRegister({ value: index });
38
+ }
39
+ return () => {
40
+ if (index !== void 0 && index !== null) {
41
+ onUnregister == null ? void 0 : onUnregister({ value: index });
42
+ }
43
+ };
44
+ }, [onRegister, onUnregister, index]);
45
+ const rootCls = clsx(
46
+ tabRootClass,
47
+ {
48
+ [tabActiveClass]: isActive,
49
+ [tabDisabledClass]: disabled
50
+ },
51
+ className
52
+ );
53
+ const tabId = tabsContainerId ? `${tabsContainerId}-tab-${index}` : void 0;
54
+ return /* @__PURE__ */ React.createElement(
55
+ "div",
56
+ {
57
+ id: tabId,
58
+ ref: handleRef,
59
+ className: rootCls,
60
+ style,
61
+ onClick: (e) => {
62
+ if (disabled)
63
+ return;
64
+ triggerChange == null ? void 0 : triggerChange(e, { index });
65
+ onClick == null ? void 0 : onClick(e, { index });
66
+ }
67
+ },
68
+ children
69
+ );
70
+ });
71
+ Tab.displayName = "BuiTab";
72
+ var Tab_default = /* @__PURE__ */ React.memo(Tab, (prevProps, nextProps) => {
73
+ return prevProps.index === nextProps.index && prevProps.disabled === nextProps.disabled && prevProps.className === nextProps.className && prevProps.children === nextProps.children;
74
+ });
75
+ export {
76
+ Tab_default as default
77
+ };
@@ -0,0 +1,15 @@
1
+ import React from 'react';
2
+ export interface TabIndicatorProps {
3
+ /** 当前选中的 tab 值 */
4
+ currentValue: string;
5
+ /** 已注册的 tabs 值数组(用于生成ID) */
6
+ registeredTabValues: string[];
7
+ /** wrapper 容器的 ID(Tab的父容器) */
8
+ wrapperId: string;
9
+ /** ScrollView 的 ID */
10
+ scrollViewId: string;
11
+ /** 注册版本号,每次 tab 注册/取消注册时递增 */
12
+ registrationVersion: number;
13
+ }
14
+ declare const TabIndicator: React.FC<TabIndicatorProps>;
15
+ export default TabIndicator;
@@ -0,0 +1,272 @@
1
+ var __async = (__this, __arguments, generator) => {
2
+ return new Promise((resolve, reject) => {
3
+ var fulfilled = (value) => {
4
+ try {
5
+ step(generator.next(value));
6
+ } catch (e) {
7
+ reject(e);
8
+ }
9
+ };
10
+ var rejected = (value) => {
11
+ try {
12
+ step(generator.throw(value));
13
+ } catch (e) {
14
+ reject(e);
15
+ }
16
+ };
17
+ var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
18
+ step((generator = generator.apply(__this, __arguments)).next());
19
+ });
20
+ };
21
+ import React, { useEffect, useRef } from "react";
22
+ import clsx from "clsx";
23
+ import Taro from "@tarojs/taro";
24
+ import { useEventCallback } from "@bifrostui/utils";
25
+ import { tabIndicatorClass } from "../classes";
26
+ import { batchQueryTabs } from "./utils/queryBatch";
27
+ const isValidTabValue = (value) => {
28
+ return value !== void 0 && value !== null;
29
+ };
30
+ const TabIndicator = ({
31
+ currentValue,
32
+ registeredTabValues,
33
+ wrapperId,
34
+ scrollViewId,
35
+ registrationVersion
36
+ }) => {
37
+ const indicatorRef = useRef(null);
38
+ const animationTimerRef = useRef(null);
39
+ const positionCacheRef = useRef(/* @__PURE__ */ new Map());
40
+ const containerInfoRef = useRef(null);
41
+ const indicatorWidthRef = useRef(24);
42
+ const isInitializedRef = useRef(false);
43
+ const initRetryCountRef = useRef(0);
44
+ const maxInitRetries = 5;
45
+ const isInitializingRef = useRef(false);
46
+ const initVersionRef = useRef(0);
47
+ const isMountedRef = useRef(true);
48
+ const updateIndicatorPosition = useEventCallback(() => {
49
+ const indicator = indicatorRef.current;
50
+ if (!indicator)
51
+ return;
52
+ if (!isValidTabValue(currentValue) || !registeredTabValues.includes(currentValue)) {
53
+ indicator.style.opacity = "0";
54
+ return;
55
+ }
56
+ const cachedPosition = positionCacheRef.current.get(currentValue);
57
+ const containerInfo = containerInfoRef.current;
58
+ if (!cachedPosition || !containerInfo || !isInitializedRef.current) {
59
+ if (!isInitializedRef.current) {
60
+ initializePositions();
61
+ }
62
+ return;
63
+ }
64
+ const activeTabLeft = cachedPosition.left;
65
+ const activeTabWidth = cachedPosition.width;
66
+ const indicatorWidth = indicatorWidthRef.current;
67
+ const x = activeTabLeft + (activeTabWidth - indicatorWidth) / 2;
68
+ indicator.style.transform = `translate(${x}px, 0px)`;
69
+ indicator.style.opacity = "1";
70
+ });
71
+ const initializePositions = useEventCallback(() => __async(void 0, null, function* () {
72
+ if (!isMountedRef.current)
73
+ return;
74
+ if (isInitializingRef.current)
75
+ return;
76
+ isInitializingRef.current = true;
77
+ initVersionRef.current += 1;
78
+ const currentVersion = initVersionRef.current;
79
+ try {
80
+ const result = yield batchQueryTabs({
81
+ scrollViewId,
82
+ wrapperId,
83
+ tabValues: registeredTabValues
84
+ });
85
+ if (!isMountedRef.current)
86
+ return;
87
+ if (currentVersion !== initVersionRef.current)
88
+ return;
89
+ const { scrollView, scrollFields, wrapper, indicator, tabs } = result;
90
+ if (!scrollView || !wrapper || !indicator || !scrollFields) {
91
+ if (initRetryCountRef.current < maxInitRetries) {
92
+ initRetryCountRef.current += 1;
93
+ if (animationTimerRef.current) {
94
+ clearTimeout(animationTimerRef.current);
95
+ }
96
+ animationTimerRef.current = setTimeout(() => {
97
+ if (!isMountedRef.current)
98
+ return;
99
+ isInitializingRef.current = false;
100
+ initializePositions();
101
+ }, 100);
102
+ } else {
103
+ isInitializingRef.current = false;
104
+ }
105
+ return;
106
+ }
107
+ if (!indicator.width || indicator.width <= 0) {
108
+ if (initRetryCountRef.current < maxInitRetries) {
109
+ initRetryCountRef.current += 1;
110
+ if (animationTimerRef.current) {
111
+ clearTimeout(animationTimerRef.current);
112
+ }
113
+ animationTimerRef.current = setTimeout(() => {
114
+ if (!isMountedRef.current)
115
+ return;
116
+ isInitializingRef.current = false;
117
+ initializePositions();
118
+ }, 100);
119
+ } else {
120
+ isInitializingRef.current = false;
121
+ }
122
+ return;
123
+ }
124
+ containerInfoRef.current = {
125
+ width: scrollView.width,
126
+ scrollWidth: scrollFields.scrollWidth || scrollView.width
127
+ };
128
+ indicatorWidthRef.current = indicator.width;
129
+ const newCache = /* @__PURE__ */ new Map();
130
+ registeredTabValues.forEach((value, index) => {
131
+ const tabRect = tabs[index];
132
+ if (tabRect && tabRect.width > 0) {
133
+ newCache.set(value, {
134
+ left: tabRect.left - wrapper.left,
135
+ width: tabRect.width
136
+ });
137
+ }
138
+ });
139
+ if (newCache.size < registeredTabValues.length) {
140
+ if (initRetryCountRef.current < maxInitRetries) {
141
+ initRetryCountRef.current += 1;
142
+ if (animationTimerRef.current) {
143
+ clearTimeout(animationTimerRef.current);
144
+ }
145
+ animationTimerRef.current = setTimeout(() => {
146
+ if (!isMountedRef.current)
147
+ return;
148
+ isInitializingRef.current = false;
149
+ initializePositions();
150
+ }, 100);
151
+ } else {
152
+ isInitializingRef.current = false;
153
+ }
154
+ return;
155
+ }
156
+ if (currentVersion !== initVersionRef.current || !isMountedRef.current) {
157
+ return;
158
+ }
159
+ initRetryCountRef.current = 0;
160
+ positionCacheRef.current = newCache;
161
+ isInitializedRef.current = true;
162
+ isInitializingRef.current = false;
163
+ updateIndicatorPosition();
164
+ } catch (error) {
165
+ console.error("[TabIndicator] \u6279\u91CF\u67E5\u8BE2\u5931\u8D25:", error);
166
+ isInitializingRef.current = false;
167
+ if (isMountedRef.current && initRetryCountRef.current < maxInitRetries) {
168
+ initRetryCountRef.current += 1;
169
+ if (animationTimerRef.current) {
170
+ clearTimeout(animationTimerRef.current);
171
+ }
172
+ animationTimerRef.current = setTimeout(() => {
173
+ if (!isMountedRef.current)
174
+ return;
175
+ initializePositions();
176
+ }, 100);
177
+ }
178
+ }
179
+ }));
180
+ useEffect(() => {
181
+ if (registeredTabValues.length === 0) {
182
+ if (indicatorRef.current) {
183
+ indicatorRef.current.style.opacity = "0";
184
+ }
185
+ return void 0;
186
+ }
187
+ initVersionRef.current += 1;
188
+ if (animationTimerRef.current) {
189
+ clearTimeout(animationTimerRef.current);
190
+ animationTimerRef.current = null;
191
+ }
192
+ isInitializedRef.current = false;
193
+ isInitializingRef.current = false;
194
+ initRetryCountRef.current = 0;
195
+ Taro.nextTick(() => {
196
+ if (!isMountedRef.current)
197
+ return;
198
+ initializePositions();
199
+ });
200
+ return () => {
201
+ if (animationTimerRef.current) {
202
+ clearTimeout(animationTimerRef.current);
203
+ animationTimerRef.current = null;
204
+ }
205
+ initVersionRef.current += 1;
206
+ isInitializingRef.current = false;
207
+ };
208
+ }, [registrationVersion, initializePositions]);
209
+ useEffect(() => {
210
+ if (!isValidTabValue(currentValue)) {
211
+ if (indicatorRef.current) {
212
+ indicatorRef.current.style.opacity = "0";
213
+ }
214
+ return;
215
+ }
216
+ updateIndicatorPosition();
217
+ }, [currentValue, updateIndicatorPosition]);
218
+ useEffect(() => {
219
+ var _a, _b;
220
+ const handleResize = () => {
221
+ if (!isMountedRef.current)
222
+ return;
223
+ initVersionRef.current += 1;
224
+ isInitializedRef.current = false;
225
+ isInitializingRef.current = false;
226
+ initRetryCountRef.current = 0;
227
+ positionCacheRef.current.clear();
228
+ if (animationTimerRef.current) {
229
+ clearTimeout(animationTimerRef.current);
230
+ animationTimerRef.current = null;
231
+ }
232
+ Taro.nextTick(() => {
233
+ if (!isMountedRef.current)
234
+ return;
235
+ initializePositions();
236
+ });
237
+ };
238
+ (_b = (_a = Taro).onWindowResize) == null ? void 0 : _b.call(_a, handleResize);
239
+ return () => {
240
+ var _a2, _b2;
241
+ (_b2 = (_a2 = Taro).offWindowResize) == null ? void 0 : _b2.call(_a2, handleResize);
242
+ };
243
+ }, [initializePositions]);
244
+ useEffect(() => {
245
+ isMountedRef.current = true;
246
+ return () => {
247
+ isMountedRef.current = false;
248
+ if (animationTimerRef.current) {
249
+ clearTimeout(animationTimerRef.current);
250
+ animationTimerRef.current = null;
251
+ }
252
+ };
253
+ }, []);
254
+ return /* @__PURE__ */ React.createElement(
255
+ "div",
256
+ {
257
+ ref: indicatorRef,
258
+ id: `${wrapperId}-indicator`,
259
+ className: clsx(tabIndicatorClass),
260
+ style: {
261
+ transition: "transform 0.3s ease-in-out, opacity 0.3s ease-in-out",
262
+ transform: "translate(0px, 0px)",
263
+ opacity: 0
264
+ }
265
+ }
266
+ );
267
+ };
268
+ TabIndicator.displayName = "BuiTabsIndicator";
269
+ var TabIndicator_default = TabIndicator;
270
+ export {
271
+ TabIndicator_default as default
272
+ };
@@ -0,0 +1,5 @@
1
+ import React from 'react';
2
+ import { TabsProps } from '../Tabs.types';
3
+ import '../Tabs.less';
4
+ declare const Tabs: React.ForwardRefExoticComponent<Omit<TabsProps<"div", {}>, "ref"> & React.RefAttributes<HTMLDivElement>>;
5
+ export default Tabs;