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

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 (516) 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.d.ts +1 -1
  72. package/dist/DatePicker/DatePicker.types.d.ts +1 -1
  73. package/dist/DesktopPicker/DesktopPicker.types.d.ts +1 -1
  74. package/dist/DesktopTimePicker/DesktopTimePicker.types.d.ts +11 -11
  75. package/dist/DesktopTimePicker/useGetTimePickerContent.js +2 -2
  76. package/dist/DesktopTimePicker/utils/utils.d.ts +1 -1
  77. package/dist/DesktopTimePicker/utils/utils.js +3 -3
  78. package/dist/Dialog/Dialog.js +19 -12
  79. package/dist/Dialog/Dialog.types.d.ts +13 -0
  80. package/dist/Dialog/FunctionalDialog.js +1 -1
  81. package/dist/Dialog/__tests__/fixtures/A11yDemos.d.ts +1 -1
  82. package/dist/Dialog/__tests__/fixtures/A11yDemos.js +4 -4
  83. package/dist/Dialog/index.css +21 -44
  84. package/dist/Divider/Divider.types.d.ts +1 -1
  85. package/dist/Drawer/Drawer.d.ts +1 -1
  86. package/dist/Drawer/Drawer.js +5 -5
  87. package/dist/Drawer/Drawer.types.d.ts +1 -1
  88. package/dist/Fade/Fade.d.ts +1 -1
  89. package/dist/Fade/Fade.js +4 -4
  90. package/dist/Fade/Fade.miniapp.js +13 -10
  91. package/dist/Fade/Fade.types.d.ts +1 -1
  92. package/dist/IconButton/IconButton.d.ts +1 -1
  93. package/dist/IconButton/IconButton.js +6 -6
  94. package/dist/IconButton/IconButton.types.d.ts +1 -1
  95. package/dist/Input/Input.types.d.ts +1 -1
  96. package/dist/Input/__tests__/fixtures/A11yDemos.d.ts +1 -1
  97. package/dist/Input/__tests__/fixtures/A11yDemos.js +7 -7
  98. package/dist/ItemSelector/ItemSelector.miniapp.js +7 -5
  99. package/dist/ItemSelector/ItemSelector.types.d.ts +1 -1
  100. package/dist/ItemSelector/Selector/index.d.ts +1 -1
  101. package/dist/ItemSelector/Selector/index.js +2 -2
  102. package/dist/List/List.d.ts +1 -1
  103. package/dist/List/List.js +4 -4
  104. package/dist/List/ListContext.d.ts +1 -1
  105. package/dist/List/ListContext.js +2 -2
  106. package/dist/List/ListItem.d.ts +1 -1
  107. package/dist/List/ListItem.js +8 -8
  108. package/dist/List/ListItem.types.d.ts +1 -1
  109. package/dist/List/ListItemContent.d.ts +1 -1
  110. package/dist/List/ListItemContent.js +3 -3
  111. package/dist/List/ListItemContent.types.d.ts +1 -1
  112. package/dist/List/ListItemExtra.d.ts +1 -1
  113. package/dist/List/ListItemExtra.js +3 -3
  114. package/dist/List/ListItemExtra.types.d.ts +1 -1
  115. package/dist/List/ListItemFooter.d.ts +1 -1
  116. package/dist/List/ListItemFooter.js +3 -3
  117. package/dist/List/ListItemFooter.types.d.ts +1 -1
  118. package/dist/List/ListItemHeader.d.ts +1 -1
  119. package/dist/List/ListItemHeader.js +3 -3
  120. package/dist/List/ListItemHeader.types.d.ts +1 -1
  121. package/dist/Loading/Loading.d.ts +1 -1
  122. package/dist/Loading/Loading.js +5 -5
  123. package/dist/Loading/Loading.types.d.ts +1 -1
  124. package/dist/Modal/Modal.d.ts +1 -1
  125. package/dist/Modal/Modal.js +6 -6
  126. package/dist/Modal/Modal.miniapp.d.ts +1 -1
  127. package/dist/Modal/Modal.miniapp.js +7 -7
  128. package/dist/Modal/__tests__/fixtures/A11yDemos.d.ts +1 -1
  129. package/dist/Modal/__tests__/fixtures/A11yDemos.js +3 -3
  130. package/dist/Modal/useModal.d.ts +1 -0
  131. package/dist/Modal/useModal.js +26 -29
  132. package/dist/NavBar/NavBar.d.ts +1 -1
  133. package/dist/NavBar/NavBar.js +10 -10
  134. package/dist/Picker/Picker.js +0 -1
  135. package/dist/Picker/Picker.types.d.ts +1 -1
  136. package/dist/Picker/__tests__/fixtures/A11yDemos.d.ts +1 -1
  137. package/dist/Picker/__tests__/fixtures/A11yDemos.js +2 -2
  138. package/dist/Popover/Popover.d.ts +1 -1
  139. package/dist/Popover/Popover.js +8 -8
  140. package/dist/Popover/Popover.types.d.ts +1 -1
  141. package/dist/Popover/__tests__/fixtures/A11yDemos.d.ts +1 -1
  142. package/dist/Popover/__tests__/fixtures/A11yDemos.js +21 -21
  143. package/dist/Portal/Portal.d.ts +1 -1
  144. package/dist/Portal/Portal.js +3 -3
  145. package/dist/Portal/Portal.miniapp.js +14 -8
  146. package/dist/Portal/Portal.types.d.ts +1 -1
  147. package/dist/Progress/Progress.d.ts +1 -1
  148. package/dist/Progress/Progress.js +4 -4
  149. package/dist/Progress/Progress.types.d.ts +1 -1
  150. package/dist/Progress/__tests__/fixtures/A11yDemos.d.ts +1 -1
  151. package/dist/Progress/__tests__/fixtures/A11yDemos.js +9 -9
  152. package/dist/Radio/RadioButtonIcon.d.ts +1 -1
  153. package/dist/Radio/RadioButtonIcon.js +4 -4
  154. package/dist/Radio/RadioContext.d.ts +1 -1
  155. package/dist/Radio/RadioContext.js +2 -2
  156. package/dist/Radio/__tests__/fixtures/A11yDemos.d.ts +1 -1
  157. package/dist/Radio/__tests__/fixtures/A11yDemos.js +4 -4
  158. package/dist/Radio/index.css +1 -0
  159. package/dist/Rating/Rating.types.d.ts +1 -1
  160. package/dist/ScrollView/ScrollView.types.d.ts +210 -1
  161. package/dist/ScrollView/__tests__/fixtures/A11yDemos.d.ts +1 -1
  162. package/dist/ScrollView/__tests__/fixtures/A11yDemos.js +30 -30
  163. package/dist/ScrollView/useScrollView.js +16 -4
  164. package/dist/Select/selectContext.d.ts +0 -1
  165. package/dist/Skeleton/Skeleton.d.ts +1 -1
  166. package/dist/Skeleton/Skeleton.js +3 -3
  167. package/dist/Skeleton/Skeleton.types.d.ts +1 -1
  168. package/dist/Slide/Slide.d.ts +1 -1
  169. package/dist/Slide/Slide.js +4 -4
  170. package/dist/Slide/Slide.miniapp.js +13 -10
  171. package/dist/Slider/Slider.types.d.ts +1 -1
  172. package/dist/Steps/Step.types.d.ts +1 -1
  173. package/dist/Steps/StepsContext.d.ts +1 -1
  174. package/dist/Steps/StepsContext.js +2 -2
  175. package/dist/SwipeAction/SwipeAction.js +7 -8
  176. package/dist/SwipeAction/SwipeAction.types.d.ts +1 -1
  177. package/dist/SwipeAction/SwipeActionContext.d.ts +0 -1
  178. package/dist/Swiper/Swiper.js +2 -0
  179. package/dist/Swiper/Swiper.types.d.ts +1 -1
  180. package/dist/Swiper/SwiperItem.d.ts +1 -1
  181. package/dist/Swiper/SwiperItem.js +2 -2
  182. package/dist/Switch/__tests__/fixtures/A11yDemos.d.ts +1 -1
  183. package/dist/Switch/__tests__/fixtures/A11yDemos.js +4 -4
  184. package/dist/TabBar/TabBar.d.ts +1 -1
  185. package/dist/TabBar/TabBar.js +5 -5
  186. package/dist/Tabs/Tab.css +1 -23
  187. package/dist/Tabs/Tab.d.ts +2 -2
  188. package/dist/Tabs/Tab.js +42 -34
  189. package/dist/Tabs/Tab.types.d.ts +1 -1
  190. package/dist/Tabs/TabIndicator.d.ts +11 -0
  191. package/dist/Tabs/TabIndicator.js +185 -0
  192. package/dist/Tabs/TabMask.d.ts +7 -0
  193. package/dist/Tabs/TabMask.js +47 -0
  194. package/dist/Tabs/TabPanel.js +4 -4
  195. package/dist/Tabs/TabPanel.types.d.ts +1 -1
  196. package/dist/Tabs/Tabs.css +17 -6
  197. package/dist/Tabs/Tabs.js +101 -157
  198. package/dist/Tabs/Tabs.types.d.ts +5 -6
  199. package/dist/Tabs/TabsContext.d.ts +15 -6
  200. package/dist/Tabs/TabsContext.js +6 -14
  201. package/dist/Tabs/classes.d.ts +13 -0
  202. package/dist/Tabs/classes.js +63 -0
  203. package/dist/Tabs/index.css +18 -29
  204. package/dist/Tabs/index.d.ts +2 -2
  205. package/dist/Tabs/index.js +4 -4
  206. package/dist/Tabs/index.miniapp.d.ts +5 -0
  207. package/dist/Tabs/index.miniapp.js +50 -0
  208. package/dist/Tabs/miniapp/Tab.d.ts +5 -0
  209. package/dist/Tabs/miniapp/Tab.js +106 -0
  210. package/dist/Tabs/miniapp/TabIndicator.d.ts +15 -0
  211. package/dist/Tabs/miniapp/TabIndicator.js +301 -0
  212. package/dist/Tabs/miniapp/Tabs.d.ts +5 -0
  213. package/dist/Tabs/miniapp/Tabs.js +250 -0
  214. package/dist/Tabs/miniapp/TabsContext.d.ts +17 -0
  215. package/dist/Tabs/miniapp/TabsContext.js +39 -0
  216. package/dist/Tabs/miniapp/index.d.ts +2 -0
  217. package/dist/Tabs/miniapp/index.js +41 -0
  218. package/dist/Tabs/miniapp/scroll.d.ts +21 -0
  219. package/dist/Tabs/miniapp/scroll.js +52 -0
  220. package/dist/Tabs/miniapp/utils/queryBatch.d.ts +68 -0
  221. package/dist/Tabs/miniapp/utils/queryBatch.js +100 -0
  222. package/dist/Tabs/utils/scroll.js +10 -4
  223. package/dist/Tag/Tag.css +11 -1
  224. package/dist/Tag/Tag.d.ts +1 -1
  225. package/dist/Tag/Tag.js +6 -6
  226. package/dist/Tag/Tag.types.d.ts +2 -2
  227. package/dist/Tag/TagGroup.d.ts +1 -1
  228. package/dist/Tag/TagGroup.js +3 -3
  229. package/dist/Tag/TagGroup.types.d.ts +1 -1
  230. package/dist/Tag/__tests__/fixtures/A11yDemos.js +3 -3
  231. package/dist/Tag/index.css +11 -1
  232. package/dist/TextArea/__tests__/fixtures/A11yDemos.d.ts +1 -1
  233. package/dist/TextArea/__tests__/fixtures/A11yDemos.js +6 -6
  234. package/dist/ThemeProvider/hooks/ThemeContext.d.ts +1 -1
  235. package/dist/ThemeProvider/hooks/ThemeContext.js +2 -2
  236. package/dist/ThemeProvider/hooks/useTheme.js +2 -2
  237. package/dist/ThemeProvider/utils/mountTokens.js +2 -2
  238. package/dist/Toast/FunctionalToast.js +3 -5
  239. package/dist/Toast/Toast.d.ts +1 -1
  240. package/dist/Toast/Toast.js +8 -8
  241. package/dist/Toast/Toast.types.d.ts +1 -1
  242. package/dist/Toast/__tests__/fixtures/A11yDemos.d.ts +1 -1
  243. package/dist/Toast/__tests__/fixtures/A11yDemos.js +2 -2
  244. package/dist/Toast/index.css +7 -5
  245. package/dist/Tooltip/Tooltip.d.ts +1 -1
  246. package/dist/Tooltip/Tooltip.js +5 -5
  247. package/dist/Tooltip/Tooltip.types.d.ts +1 -1
  248. package/dist/Tooltip/__tests__/fixtures/A11yDemos.d.ts +1 -1
  249. package/dist/Tooltip/__tests__/fixtures/A11yDemos.js +14 -14
  250. package/dist/Transition/Transition.d.ts +1 -1
  251. package/dist/Transition/Transition.js +3 -3
  252. package/dist/Transition/Transition.miniapp.d.ts +1 -1
  253. package/dist/Transition/Transition.miniapp.js +3 -3
  254. package/dist/Transition/TransitionCore.js +8 -2
  255. package/dist/_.._/benchmarks/components/Button.d.js +15 -0
  256. package/dist/_.._/benchmarks/components/Button.js +2 -2
  257. package/dist/_.._/benchmarks/components/Input.d.js +15 -0
  258. package/dist/_.._/benchmarks/components/Tabs.d.js +15 -0
  259. package/es/ActionSheet/ActionSheet.d.ts +1 -1
  260. package/es/ActionSheet/ActionSheet.js +1 -1
  261. package/es/ActionSheet/ActionSheet.types.d.ts +1 -1
  262. package/es/ActionSheet/ActionSheetContext.d.ts +1 -1
  263. package/es/ActionSheet/ActionSheetContext.js +1 -1
  264. package/es/ActionSheet/ActionSheetItem.types.d.ts +1 -1
  265. package/es/Alert/Alert.d.ts +1 -1
  266. package/es/Alert/Alert.js +1 -1
  267. package/es/Alert/__tests__/fixtures/A11yDemos.d.ts +1 -1
  268. package/es/Alert/__tests__/fixtures/A11yDemos.js +1 -1
  269. package/es/Avatar/Avatar.d.ts +1 -1
  270. package/es/Avatar/Avatar.js +1 -1
  271. package/es/Avatar/Avatar.types.d.ts +1 -1
  272. package/es/Avatar/AvatarGroup.types.d.ts +1 -1
  273. package/es/Backdrop/Backdrop.d.ts +1 -1
  274. package/es/Backdrop/Backdrop.js +1 -1
  275. package/es/Backdrop/Backdrop.types.d.ts +1 -1
  276. package/es/Backdrop/__tests__/fixtures/A11yDemos.d.ts +1 -1
  277. package/es/Backdrop/__tests__/fixtures/A11yDemos.js +1 -1
  278. package/es/Badge/Badge.d.ts +1 -1
  279. package/es/Badge/Badge.js +1 -1
  280. package/es/Badge/__tests__/fixtures/A11yDemos.d.ts +1 -1
  281. package/es/Badge/__tests__/fixtures/A11yDemos.js +1 -1
  282. package/es/Breadcrumb/Breadcrumb.d.ts +1 -1
  283. package/es/Breadcrumb/Breadcrumb.js +1 -1
  284. package/es/Breadcrumb/Breadcrumb.types.d.ts +1 -1
  285. package/es/Breadcrumb/BreadcrumbItem.d.ts +1 -1
  286. package/es/Breadcrumb/BreadcrumbItem.js +1 -1
  287. package/es/Button/Button.d.ts +1 -1
  288. package/es/Button/Button.js +1 -1
  289. package/es/Button/Button.types.d.ts +1 -1
  290. package/es/Button/__tests__/fixtures/A11yDemos.d.ts +1 -1
  291. package/es/Button/__tests__/fixtures/A11yDemos.js +1 -1
  292. package/es/Button/index.css +2 -3
  293. package/es/CSSTransition/demo/CSSTransitionDemo.js +3 -0
  294. package/es/CSSTransition/demo/index.css +0 -3
  295. package/es/Calendar/Calendar.js +5 -1
  296. package/es/Calendar/Calendar.types.d.ts +1 -1
  297. package/es/Calendar/__tests__/fixtures/A11yDemos.d.ts +1 -1
  298. package/es/Calendar/__tests__/fixtures/A11yDemos.js +1 -1
  299. package/es/Card/Card.d.ts +1 -1
  300. package/es/Card/Card.js +1 -1
  301. package/es/Card/Card.types.d.ts +1 -1
  302. package/es/Card/CardContent.d.ts +1 -1
  303. package/es/Card/CardContent.js +1 -1
  304. package/es/Card/CardContent.types.d.ts +1 -1
  305. package/es/Card/CardFooter.d.ts +1 -1
  306. package/es/Card/CardFooter.js +1 -1
  307. package/es/Card/CardFooter.types.d.ts +1 -1
  308. package/es/Card/CardHeader.d.ts +1 -1
  309. package/es/Card/CardHeader.js +1 -1
  310. package/es/Checkbox/CheckboxContext.d.ts +1 -1
  311. package/es/Checkbox/CheckboxContext.js +1 -1
  312. package/es/Checkbox/__tests__/fixtures/A11yDemos.d.ts +1 -1
  313. package/es/Checkbox/__tests__/fixtures/A11yDemos.js +1 -1
  314. package/es/CitySelector/CitySelector.types.d.ts +1 -1
  315. package/es/CitySelector/Selector/index.d.ts +1 -1
  316. package/es/CitySelector/Selector/index.js +1 -1
  317. package/es/Collapse/Collapse.types.d.ts +1 -1
  318. package/es/CollapsePanel/CollapsePanel.d.ts +1 -1
  319. package/es/CollapsePanel/CollapsePanel.js +1 -1
  320. package/es/CollapsePanel/CollapsePanel.types.d.ts +1 -1
  321. package/es/CollapsePanel/CollapsePanelItem.d.ts +1 -1
  322. package/es/CollapsePanel/CollapsePanelItem.js +1 -1
  323. package/es/Countdown/Countdown.types.d.ts +2 -2
  324. package/es/Countdown/__tests__/fixtures/A11yDemos.d.ts +1 -1
  325. package/es/Countdown/__tests__/fixtures/A11yDemos.js +1 -1
  326. package/es/Countdown/utils.d.ts +2 -2
  327. package/es/Countdown/utils.js +4 -4
  328. package/es/DatePicker/DatePicker.types.d.ts +1 -1
  329. package/es/DesktopPicker/DesktopPicker.types.d.ts +1 -1
  330. package/es/DesktopTimePicker/DesktopTimePicker.types.d.ts +11 -11
  331. package/es/DesktopTimePicker/useGetTimePickerContent.js +3 -3
  332. package/es/DesktopTimePicker/utils/utils.d.ts +1 -1
  333. package/es/DesktopTimePicker/utils/utils.js +2 -2
  334. package/es/Dialog/Dialog.js +19 -12
  335. package/es/Dialog/Dialog.types.d.ts +13 -0
  336. package/es/Dialog/FunctionalDialog.js +1 -1
  337. package/es/Dialog/__tests__/fixtures/A11yDemos.d.ts +1 -1
  338. package/es/Dialog/__tests__/fixtures/A11yDemos.js +1 -1
  339. package/es/Dialog/index.css +21 -44
  340. package/es/Divider/Divider.types.d.ts +1 -1
  341. package/es/Drawer/Drawer.d.ts +1 -1
  342. package/es/Drawer/Drawer.js +1 -1
  343. package/es/Drawer/Drawer.types.d.ts +1 -1
  344. package/es/Fade/Fade.d.ts +1 -1
  345. package/es/Fade/Fade.js +1 -1
  346. package/es/Fade/Fade.miniapp.js +14 -11
  347. package/es/Fade/Fade.types.d.ts +1 -1
  348. package/es/IconButton/IconButton.d.ts +1 -1
  349. package/es/IconButton/IconButton.js +1 -1
  350. package/es/IconButton/IconButton.types.d.ts +1 -1
  351. package/es/Input/Input.types.d.ts +1 -1
  352. package/es/Input/__tests__/fixtures/A11yDemos.d.ts +1 -1
  353. package/es/Input/__tests__/fixtures/A11yDemos.js +1 -1
  354. package/es/ItemSelector/ItemSelector.miniapp.js +7 -5
  355. package/es/ItemSelector/ItemSelector.types.d.ts +1 -1
  356. package/es/ItemSelector/Selector/index.d.ts +1 -1
  357. package/es/ItemSelector/Selector/index.js +1 -1
  358. package/es/List/List.d.ts +1 -1
  359. package/es/List/List.js +1 -1
  360. package/es/List/ListContext.d.ts +1 -1
  361. package/es/List/ListContext.js +1 -1
  362. package/es/List/ListItem.d.ts +1 -1
  363. package/es/List/ListItem.js +1 -1
  364. package/es/List/ListItem.types.d.ts +1 -1
  365. package/es/List/ListItemContent.d.ts +1 -1
  366. package/es/List/ListItemContent.js +1 -1
  367. package/es/List/ListItemContent.types.d.ts +1 -1
  368. package/es/List/ListItemExtra.d.ts +1 -1
  369. package/es/List/ListItemExtra.js +1 -1
  370. package/es/List/ListItemExtra.types.d.ts +1 -1
  371. package/es/List/ListItemFooter.d.ts +1 -1
  372. package/es/List/ListItemFooter.js +1 -1
  373. package/es/List/ListItemFooter.types.d.ts +1 -1
  374. package/es/List/ListItemHeader.d.ts +1 -1
  375. package/es/List/ListItemHeader.js +1 -1
  376. package/es/List/ListItemHeader.types.d.ts +1 -1
  377. package/es/Loading/Loading.d.ts +1 -1
  378. package/es/Loading/Loading.js +1 -1
  379. package/es/Loading/Loading.types.d.ts +1 -1
  380. package/es/Modal/Modal.d.ts +1 -1
  381. package/es/Modal/Modal.js +1 -1
  382. package/es/Modal/Modal.miniapp.d.ts +1 -1
  383. package/es/Modal/Modal.miniapp.js +1 -1
  384. package/es/Modal/__tests__/fixtures/A11yDemos.d.ts +1 -1
  385. package/es/Modal/__tests__/fixtures/A11yDemos.js +1 -1
  386. package/es/Modal/useModal.d.ts +1 -0
  387. package/es/Modal/useModal.js +26 -29
  388. package/es/NavBar/NavBar.d.ts +1 -1
  389. package/es/NavBar/NavBar.js +1 -1
  390. package/es/Picker/Picker.js +0 -1
  391. package/es/Picker/Picker.types.d.ts +1 -1
  392. package/es/Picker/__tests__/fixtures/A11yDemos.d.ts +1 -1
  393. package/es/Picker/__tests__/fixtures/A11yDemos.js +1 -1
  394. package/es/Popover/Popover.d.ts +1 -1
  395. package/es/Popover/Popover.js +1 -1
  396. package/es/Popover/Popover.types.d.ts +1 -1
  397. package/es/Popover/__tests__/fixtures/A11yDemos.d.ts +1 -1
  398. package/es/Popover/__tests__/fixtures/A11yDemos.js +1 -1
  399. package/es/Portal/Portal.d.ts +1 -1
  400. package/es/Portal/Portal.js +1 -1
  401. package/es/Portal/Portal.miniapp.js +15 -9
  402. package/es/Portal/Portal.types.d.ts +1 -1
  403. package/es/Progress/Progress.d.ts +1 -1
  404. package/es/Progress/Progress.js +1 -1
  405. package/es/Progress/Progress.types.d.ts +1 -1
  406. package/es/Progress/__tests__/fixtures/A11yDemos.d.ts +1 -1
  407. package/es/Progress/__tests__/fixtures/A11yDemos.js +1 -1
  408. package/es/Radio/RadioButtonIcon.d.ts +1 -1
  409. package/es/Radio/RadioButtonIcon.js +1 -1
  410. package/es/Radio/RadioContext.d.ts +1 -1
  411. package/es/Radio/RadioContext.js +1 -1
  412. package/es/Radio/__tests__/fixtures/A11yDemos.d.ts +1 -1
  413. package/es/Radio/__tests__/fixtures/A11yDemos.js +1 -1
  414. package/es/Radio/index.css +1 -0
  415. package/es/Rating/Rating.types.d.ts +1 -1
  416. package/es/ScrollView/ScrollView.types.d.ts +210 -1
  417. package/es/ScrollView/__tests__/fixtures/A11yDemos.d.ts +1 -1
  418. package/es/ScrollView/__tests__/fixtures/A11yDemos.js +1 -1
  419. package/es/ScrollView/useScrollView.js +16 -4
  420. package/es/Select/selectContext.d.ts +0 -1
  421. package/es/Skeleton/Skeleton.d.ts +1 -1
  422. package/es/Skeleton/Skeleton.js +1 -1
  423. package/es/Skeleton/Skeleton.types.d.ts +1 -1
  424. package/es/Slide/Slide.d.ts +1 -1
  425. package/es/Slide/Slide.js +1 -1
  426. package/es/Slide/Slide.miniapp.js +14 -11
  427. package/es/Slider/Slider.types.d.ts +1 -1
  428. package/es/Steps/Step.types.d.ts +1 -1
  429. package/es/Steps/StepsContext.d.ts +1 -1
  430. package/es/Steps/StepsContext.js +1 -1
  431. package/es/SwipeAction/SwipeAction.js +7 -8
  432. package/es/SwipeAction/SwipeAction.types.d.ts +1 -1
  433. package/es/SwipeAction/SwipeActionContext.d.ts +0 -1
  434. package/es/Swiper/Swiper.js +7 -1
  435. package/es/Swiper/Swiper.types.d.ts +1 -1
  436. package/es/Swiper/SwiperItem.d.ts +1 -1
  437. package/es/Swiper/SwiperItem.js +1 -1
  438. package/es/Switch/__tests__/fixtures/A11yDemos.d.ts +1 -1
  439. package/es/Switch/__tests__/fixtures/A11yDemos.js +1 -1
  440. package/es/TabBar/TabBar.d.ts +1 -1
  441. package/es/TabBar/TabBar.js +1 -1
  442. package/es/Tabs/Tab.css +1 -23
  443. package/es/Tabs/Tab.d.ts +2 -2
  444. package/es/Tabs/Tab.js +44 -36
  445. package/es/Tabs/Tab.types.d.ts +1 -1
  446. package/es/Tabs/TabIndicator.d.ts +11 -0
  447. package/es/Tabs/TabIndicator.js +156 -0
  448. package/es/Tabs/TabMask.d.ts +7 -0
  449. package/es/Tabs/TabMask.js +18 -0
  450. package/es/Tabs/TabPanel.js +8 -4
  451. package/es/Tabs/TabPanel.types.d.ts +1 -1
  452. package/es/Tabs/Tabs.css +17 -6
  453. package/es/Tabs/Tabs.js +102 -158
  454. package/es/Tabs/Tabs.types.d.ts +5 -6
  455. package/es/Tabs/TabsContext.d.ts +15 -6
  456. package/es/Tabs/TabsContext.js +6 -4
  457. package/es/Tabs/classes.d.ts +13 -0
  458. package/es/Tabs/classes.js +28 -0
  459. package/es/Tabs/index.css +18 -29
  460. package/es/Tabs/index.d.ts +2 -2
  461. package/es/Tabs/index.js +2 -2
  462. package/es/Tabs/index.miniapp.d.ts +5 -0
  463. package/es/Tabs/index.miniapp.js +11 -0
  464. package/es/Tabs/miniapp/Tab.d.ts +5 -0
  465. package/es/Tabs/miniapp/Tab.js +77 -0
  466. package/es/Tabs/miniapp/TabIndicator.d.ts +15 -0
  467. package/es/Tabs/miniapp/TabIndicator.js +272 -0
  468. package/es/Tabs/miniapp/Tabs.d.ts +5 -0
  469. package/es/Tabs/miniapp/Tabs.js +228 -0
  470. package/es/Tabs/miniapp/TabsContext.d.ts +17 -0
  471. package/es/Tabs/miniapp/TabsContext.js +16 -0
  472. package/es/Tabs/miniapp/index.d.ts +2 -0
  473. package/es/Tabs/miniapp/index.js +7 -0
  474. package/es/Tabs/miniapp/scroll.d.ts +21 -0
  475. package/es/Tabs/miniapp/scroll.js +29 -0
  476. package/es/Tabs/miniapp/utils/queryBatch.d.ts +68 -0
  477. package/es/Tabs/miniapp/utils/queryBatch.js +65 -0
  478. package/es/Tabs/utils/scroll.js +10 -4
  479. package/es/Tag/Tag.css +11 -1
  480. package/es/Tag/Tag.d.ts +1 -1
  481. package/es/Tag/Tag.js +4 -4
  482. package/es/Tag/Tag.types.d.ts +2 -2
  483. package/es/Tag/TagGroup.d.ts +1 -1
  484. package/es/Tag/TagGroup.js +1 -1
  485. package/es/Tag/TagGroup.types.d.ts +1 -1
  486. package/es/Tag/__tests__/fixtures/A11yDemos.js +3 -3
  487. package/es/Tag/index.css +11 -1
  488. package/es/TextArea/__tests__/fixtures/A11yDemos.d.ts +1 -1
  489. package/es/TextArea/__tests__/fixtures/A11yDemos.js +1 -1
  490. package/es/ThemeProvider/hooks/ThemeContext.d.ts +1 -1
  491. package/es/ThemeProvider/hooks/ThemeContext.js +1 -1
  492. package/es/ThemeProvider/hooks/useTheme.js +1 -1
  493. package/es/ThemeProvider/utils/mountTokens.js +1 -1
  494. package/es/Toast/FunctionalToast.js +4 -6
  495. package/es/Toast/Toast.d.ts +1 -1
  496. package/es/Toast/Toast.js +1 -1
  497. package/es/Toast/Toast.types.d.ts +1 -1
  498. package/es/Toast/__tests__/fixtures/A11yDemos.d.ts +1 -1
  499. package/es/Toast/__tests__/fixtures/A11yDemos.js +1 -1
  500. package/es/Toast/index.css +7 -5
  501. package/es/Tooltip/Tooltip.d.ts +1 -1
  502. package/es/Tooltip/Tooltip.js +1 -1
  503. package/es/Tooltip/Tooltip.types.d.ts +1 -1
  504. package/es/Tooltip/__tests__/fixtures/A11yDemos.d.ts +1 -1
  505. package/es/Tooltip/__tests__/fixtures/A11yDemos.js +1 -1
  506. package/es/Transition/Transition.d.ts +1 -1
  507. package/es/Transition/Transition.js +1 -1
  508. package/es/Transition/Transition.miniapp.d.ts +1 -1
  509. package/es/Transition/Transition.miniapp.js +1 -1
  510. package/es/Transition/TransitionCore.js +8 -2
  511. package/es/_.._/benchmarks/components/Button.d.js +0 -0
  512. package/es/_.._/benchmarks/components/Button.js +1 -1
  513. package/es/_.._/benchmarks/components/Input.d.js +0 -0
  514. package/es/_.._/benchmarks/components/Tabs.d.js +0 -0
  515. package/package.json +17 -26
  516. package/src/index.ts +0 -58
@@ -0,0 +1,301 @@
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 __async = (__this, __arguments, generator) => {
29
+ return new Promise((resolve, reject) => {
30
+ var fulfilled = (value) => {
31
+ try {
32
+ step(generator.next(value));
33
+ } catch (e) {
34
+ reject(e);
35
+ }
36
+ };
37
+ var rejected = (value) => {
38
+ try {
39
+ step(generator.throw(value));
40
+ } catch (e) {
41
+ reject(e);
42
+ }
43
+ };
44
+ var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
45
+ step((generator = generator.apply(__this, __arguments)).next());
46
+ });
47
+ };
48
+ var TabIndicator_exports = {};
49
+ __export(TabIndicator_exports, {
50
+ default: () => TabIndicator_default
51
+ });
52
+ module.exports = __toCommonJS(TabIndicator_exports);
53
+ var import_react = __toESM(require("react"));
54
+ var import_clsx = __toESM(require("clsx"));
55
+ var import_taro = __toESM(require("@tarojs/taro"));
56
+ var import_utils = require("@bifrostui/utils");
57
+ var import_classes = require("../classes");
58
+ var import_queryBatch = require("./utils/queryBatch");
59
+ const isValidTabValue = (value) => {
60
+ return value !== void 0 && value !== null;
61
+ };
62
+ const TabIndicator = ({
63
+ currentValue,
64
+ registeredTabValues,
65
+ wrapperId,
66
+ scrollViewId,
67
+ registrationVersion
68
+ }) => {
69
+ const indicatorRef = (0, import_react.useRef)(null);
70
+ const animationTimerRef = (0, import_react.useRef)(null);
71
+ const positionCacheRef = (0, import_react.useRef)(/* @__PURE__ */ new Map());
72
+ const containerInfoRef = (0, import_react.useRef)(null);
73
+ const indicatorWidthRef = (0, import_react.useRef)(24);
74
+ const isInitializedRef = (0, import_react.useRef)(false);
75
+ const initRetryCountRef = (0, import_react.useRef)(0);
76
+ const maxInitRetries = 5;
77
+ const isInitializingRef = (0, import_react.useRef)(false);
78
+ const initVersionRef = (0, import_react.useRef)(0);
79
+ const isMountedRef = (0, import_react.useRef)(true);
80
+ const updateIndicatorPosition = (0, import_utils.useEventCallback)(() => {
81
+ const indicator = indicatorRef.current;
82
+ if (!indicator)
83
+ return;
84
+ if (!isValidTabValue(currentValue) || !registeredTabValues.includes(currentValue)) {
85
+ indicator.style.opacity = "0";
86
+ return;
87
+ }
88
+ const cachedPosition = positionCacheRef.current.get(currentValue);
89
+ const containerInfo = containerInfoRef.current;
90
+ if (!cachedPosition || !containerInfo || !isInitializedRef.current) {
91
+ if (!isInitializedRef.current) {
92
+ initializePositions();
93
+ }
94
+ return;
95
+ }
96
+ const activeTabLeft = cachedPosition.left;
97
+ const activeTabWidth = cachedPosition.width;
98
+ const indicatorWidth = indicatorWidthRef.current;
99
+ const x = activeTabLeft + (activeTabWidth - indicatorWidth) / 2;
100
+ indicator.style.transform = `translate(${x}px, 0px)`;
101
+ indicator.style.opacity = "1";
102
+ });
103
+ const initializePositions = (0, import_utils.useEventCallback)(() => __async(void 0, null, function* () {
104
+ if (!isMountedRef.current)
105
+ return;
106
+ if (isInitializingRef.current)
107
+ return;
108
+ isInitializingRef.current = true;
109
+ initVersionRef.current += 1;
110
+ const currentVersion = initVersionRef.current;
111
+ try {
112
+ const result = yield (0, import_queryBatch.batchQueryTabs)({
113
+ scrollViewId,
114
+ wrapperId,
115
+ tabValues: registeredTabValues
116
+ });
117
+ if (!isMountedRef.current)
118
+ return;
119
+ if (currentVersion !== initVersionRef.current)
120
+ return;
121
+ const { scrollView, scrollFields, wrapper, indicator, tabs } = result;
122
+ if (!scrollView || !wrapper || !indicator || !scrollFields) {
123
+ if (initRetryCountRef.current < maxInitRetries) {
124
+ initRetryCountRef.current += 1;
125
+ if (animationTimerRef.current) {
126
+ clearTimeout(animationTimerRef.current);
127
+ }
128
+ animationTimerRef.current = setTimeout(() => {
129
+ if (!isMountedRef.current)
130
+ return;
131
+ isInitializingRef.current = false;
132
+ initializePositions();
133
+ }, 100);
134
+ } else {
135
+ isInitializingRef.current = false;
136
+ }
137
+ return;
138
+ }
139
+ if (!indicator.width || indicator.width <= 0) {
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
+ containerInfoRef.current = {
157
+ width: scrollView.width,
158
+ scrollWidth: scrollFields.scrollWidth || scrollView.width
159
+ };
160
+ indicatorWidthRef.current = indicator.width;
161
+ const newCache = /* @__PURE__ */ new Map();
162
+ registeredTabValues.forEach((value, index) => {
163
+ const tabRect = tabs[index];
164
+ if (tabRect && tabRect.width > 0) {
165
+ newCache.set(value, {
166
+ left: tabRect.left - wrapper.left,
167
+ width: tabRect.width
168
+ });
169
+ }
170
+ });
171
+ if (newCache.size < registeredTabValues.length) {
172
+ if (initRetryCountRef.current < maxInitRetries) {
173
+ initRetryCountRef.current += 1;
174
+ if (animationTimerRef.current) {
175
+ clearTimeout(animationTimerRef.current);
176
+ }
177
+ animationTimerRef.current = setTimeout(() => {
178
+ if (!isMountedRef.current)
179
+ return;
180
+ isInitializingRef.current = false;
181
+ initializePositions();
182
+ }, 100);
183
+ } else {
184
+ isInitializingRef.current = false;
185
+ }
186
+ return;
187
+ }
188
+ if (currentVersion !== initVersionRef.current || !isMountedRef.current) {
189
+ return;
190
+ }
191
+ initRetryCountRef.current = 0;
192
+ positionCacheRef.current = newCache;
193
+ isInitializedRef.current = true;
194
+ isInitializingRef.current = false;
195
+ updateIndicatorPosition();
196
+ } catch (error) {
197
+ console.error("[TabIndicator] \u6279\u91CF\u67E5\u8BE2\u5931\u8D25:", error);
198
+ isInitializingRef.current = false;
199
+ if (isMountedRef.current && initRetryCountRef.current < maxInitRetries) {
200
+ initRetryCountRef.current += 1;
201
+ if (animationTimerRef.current) {
202
+ clearTimeout(animationTimerRef.current);
203
+ }
204
+ animationTimerRef.current = setTimeout(() => {
205
+ if (!isMountedRef.current)
206
+ return;
207
+ initializePositions();
208
+ }, 100);
209
+ }
210
+ }
211
+ }));
212
+ (0, import_react.useEffect)(() => {
213
+ if (registeredTabValues.length === 0) {
214
+ if (indicatorRef.current) {
215
+ indicatorRef.current.style.opacity = "0";
216
+ }
217
+ return void 0;
218
+ }
219
+ initVersionRef.current += 1;
220
+ if (animationTimerRef.current) {
221
+ clearTimeout(animationTimerRef.current);
222
+ animationTimerRef.current = null;
223
+ }
224
+ isInitializedRef.current = false;
225
+ isInitializingRef.current = false;
226
+ initRetryCountRef.current = 0;
227
+ import_taro.default.nextTick(() => {
228
+ if (!isMountedRef.current)
229
+ return;
230
+ initializePositions();
231
+ });
232
+ return () => {
233
+ if (animationTimerRef.current) {
234
+ clearTimeout(animationTimerRef.current);
235
+ animationTimerRef.current = null;
236
+ }
237
+ initVersionRef.current += 1;
238
+ isInitializingRef.current = false;
239
+ };
240
+ }, [registrationVersion, initializePositions]);
241
+ (0, import_react.useEffect)(() => {
242
+ if (!isValidTabValue(currentValue)) {
243
+ if (indicatorRef.current) {
244
+ indicatorRef.current.style.opacity = "0";
245
+ }
246
+ return;
247
+ }
248
+ updateIndicatorPosition();
249
+ }, [currentValue, updateIndicatorPosition]);
250
+ (0, import_react.useEffect)(() => {
251
+ var _a, _b;
252
+ const handleResize = () => {
253
+ if (!isMountedRef.current)
254
+ return;
255
+ initVersionRef.current += 1;
256
+ isInitializedRef.current = false;
257
+ isInitializingRef.current = false;
258
+ initRetryCountRef.current = 0;
259
+ positionCacheRef.current.clear();
260
+ if (animationTimerRef.current) {
261
+ clearTimeout(animationTimerRef.current);
262
+ animationTimerRef.current = null;
263
+ }
264
+ import_taro.default.nextTick(() => {
265
+ if (!isMountedRef.current)
266
+ return;
267
+ initializePositions();
268
+ });
269
+ };
270
+ (_b = (_a = import_taro.default).onWindowResize) == null ? void 0 : _b.call(_a, handleResize);
271
+ return () => {
272
+ var _a2, _b2;
273
+ (_b2 = (_a2 = import_taro.default).offWindowResize) == null ? void 0 : _b2.call(_a2, handleResize);
274
+ };
275
+ }, [initializePositions]);
276
+ (0, import_react.useEffect)(() => {
277
+ isMountedRef.current = true;
278
+ return () => {
279
+ isMountedRef.current = false;
280
+ if (animationTimerRef.current) {
281
+ clearTimeout(animationTimerRef.current);
282
+ animationTimerRef.current = null;
283
+ }
284
+ };
285
+ }, []);
286
+ return /* @__PURE__ */ import_react.default.createElement(
287
+ "div",
288
+ {
289
+ ref: indicatorRef,
290
+ id: `${wrapperId}-indicator`,
291
+ className: (0, import_clsx.default)(import_classes.tabIndicatorClass),
292
+ style: {
293
+ transition: "transform 0.3s ease-in-out, opacity 0.3s ease-in-out",
294
+ transform: "translate(0px, 0px)",
295
+ opacity: 0
296
+ }
297
+ }
298
+ );
299
+ };
300
+ TabIndicator.displayName = "BuiTabsIndicator";
301
+ var TabIndicator_default = TabIndicator;
@@ -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;
@@ -0,0 +1,250 @@
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 __async = (__this, __arguments, generator) => {
29
+ return new Promise((resolve, reject) => {
30
+ var fulfilled = (value) => {
31
+ try {
32
+ step(generator.next(value));
33
+ } catch (e) {
34
+ reject(e);
35
+ }
36
+ };
37
+ var rejected = (value) => {
38
+ try {
39
+ step(generator.throw(value));
40
+ } catch (e) {
41
+ reject(e);
42
+ }
43
+ };
44
+ var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
45
+ step((generator = generator.apply(__this, __arguments)).next());
46
+ });
47
+ };
48
+ var Tabs_exports = {};
49
+ __export(Tabs_exports, {
50
+ default: () => Tabs_default
51
+ });
52
+ module.exports = __toCommonJS(Tabs_exports);
53
+ var import_react = __toESM(require("react"));
54
+ var import_clsx = __toESM(require("clsx"));
55
+ var import_taro = __toESM(require("@tarojs/taro"));
56
+ var import_components = require("@tarojs/components");
57
+ var import_utils = require("@bifrostui/utils");
58
+ var import_Tab = __toESM(require("./Tab"));
59
+ var import_TabIndicator = __toESM(require("./TabIndicator"));
60
+ var import_TabMask = __toESM(require("../TabMask"));
61
+ var import_TabsContext = require("./TabsContext");
62
+ var import_classes = require("../classes");
63
+ var import_queryBatch = require("./utils/queryBatch");
64
+ var import_Tabs2 = require("../Tabs.css");
65
+ const Tabs = /* @__PURE__ */ import_react.default.forwardRef((props, ref) => {
66
+ const {
67
+ children,
68
+ className,
69
+ value,
70
+ defaultValue,
71
+ tabs = [],
72
+ onChange,
73
+ style
74
+ } = props;
75
+ const handleOnChange = (0, import_utils.useEventCallback)(
76
+ (e, data) => {
77
+ onChange == null ? void 0 : onChange(e, { index: data.value });
78
+ }
79
+ );
80
+ const [currentValue, triggerValueChange] = (0, import_utils.useValue)({
81
+ value,
82
+ defaultValue: defaultValue != null ? defaultValue : "",
83
+ onChange: handleOnChange,
84
+ config: {
85
+ name: "Tabs",
86
+ state: "value"
87
+ }
88
+ });
89
+ const tabsContainerId = (0, import_react.useMemo)(
90
+ () => `bui-tabs-${Math.random().toString(36).slice(2, 11)}`,
91
+ []
92
+ );
93
+ const scrollViewId = `${tabsContainerId}-scroll`;
94
+ const wrapperId = `${tabsContainerId}-wrapper`;
95
+ const [registeredTabValues, setRegisteredTabValues] = (0, import_react.useState)([]);
96
+ const [registrationVersion, setRegistrationVersion] = (0, import_react.useState)(0);
97
+ const [scrollLeft, setScrollLeft] = (0, import_react.useState)(0);
98
+ const [containerWidth, setContainerWidth] = (0, import_react.useState)(0);
99
+ const [scrollWidth, setScrollWidth] = (0, import_react.useState)(0);
100
+ const lastScrollLeftRef = import_react.default.useRef(0);
101
+ const isFirstScroll = import_react.default.useRef(true);
102
+ const [scrollWithAnimation, setScrollWithAnimation] = import_react.default.useState(false);
103
+ const isScrollable = scrollWidth - containerWidth > 1;
104
+ if (process.env.NODE_ENV !== "production") {
105
+ if (tabs.length > 0 && import_react.default.Children.count(children) > 0) {
106
+ console.warn(
107
+ "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"
108
+ );
109
+ }
110
+ }
111
+ const onRegister = (0, import_utils.useEventCallback)((data) => {
112
+ if (data.value !== void 0 && data.value !== null) {
113
+ setRegisteredTabValues((prev) => {
114
+ if (prev.includes(data.value))
115
+ return prev;
116
+ const newValues = [...prev, data.value];
117
+ return newValues;
118
+ });
119
+ setRegistrationVersion((v) => v + 1);
120
+ }
121
+ });
122
+ const onUnregister = (0, import_utils.useEventCallback)((data) => {
123
+ setRegisteredTabValues((prev) => {
124
+ const newValues = prev.filter((v) => v !== data.value);
125
+ return newValues;
126
+ });
127
+ setRegistrationVersion((v) => v + 1);
128
+ });
129
+ const handleClick = (0, import_utils.useEventCallback)(
130
+ (e, item) => {
131
+ const { index, disabled = false } = item;
132
+ if (disabled || [void 0, null].includes(index))
133
+ return;
134
+ if (index !== currentValue) {
135
+ triggerValueChange(e, index);
136
+ }
137
+ }
138
+ );
139
+ const handleScroll = (0, import_utils.useEventCallback)(
140
+ (e) => {
141
+ const { scrollLeft: newScrollLeft, scrollWidth: newScrollWidth } = e.detail;
142
+ lastScrollLeftRef.current = newScrollLeft;
143
+ if (newScrollWidth && newScrollWidth !== scrollWidth) {
144
+ setScrollWidth(newScrollWidth);
145
+ }
146
+ }
147
+ );
148
+ import_react.default.useEffect(() => {
149
+ if (!scrollViewId || registeredTabValues.length === 0)
150
+ return;
151
+ import_taro.default.nextTick(() => __async(void 0, null, function* () {
152
+ const { rect, fields } = yield (0, import_queryBatch.batchQueryContainerSize)(scrollViewId);
153
+ if (rect) {
154
+ setContainerWidth(rect.width);
155
+ }
156
+ if (fields) {
157
+ setScrollWidth(fields.scrollWidth || 0);
158
+ }
159
+ }));
160
+ }, [scrollViewId, registrationVersion, registeredTabValues.length]);
161
+ const centerActiveTab = (0, import_utils.useEventCallback)(() => __async(void 0, null, function* () {
162
+ if (!currentValue || registeredTabValues.length === 0) {
163
+ return;
164
+ }
165
+ const { scrollView, scrollFields, wrapper, currentTab } = yield (0, import_queryBatch.batchQueryForScroll)({
166
+ scrollViewId,
167
+ wrapperId,
168
+ currentTabValue: currentValue
169
+ });
170
+ if (!scrollView || !scrollFields || !wrapper || !currentTab || currentTab.width === 0) {
171
+ return;
172
+ }
173
+ const tabLeftRelativeToWrapper = currentTab.left - wrapper.left;
174
+ const tabWidth = currentTab.width;
175
+ const containerViewWidth = scrollView.width;
176
+ const currentScrollWidth = scrollFields.scrollWidth || scrollView.width;
177
+ const targetScrollLeft = tabLeftRelativeToWrapper - (containerViewWidth - tabWidth) / 2;
178
+ const maxScrollDistance = currentScrollWidth - containerViewWidth;
179
+ const finalScrollLeft = Math.max(
180
+ 0,
181
+ Math.min(targetScrollLeft, maxScrollDistance)
182
+ );
183
+ setScrollLeft(finalScrollLeft);
184
+ lastScrollLeftRef.current = finalScrollLeft;
185
+ if (isFirstScroll.current) {
186
+ import_taro.default.nextTick(() => {
187
+ setScrollWithAnimation(true);
188
+ });
189
+ isFirstScroll.current = false;
190
+ }
191
+ }));
192
+ import_react.default.useEffect(() => {
193
+ if (!currentValue || registeredTabValues.length === 0) {
194
+ return;
195
+ }
196
+ import_taro.default.nextTick(() => {
197
+ centerActiveTab();
198
+ });
199
+ }, [currentValue, centerActiveTab]);
200
+ import_react.default.useEffect(() => {
201
+ if (!currentValue || registeredTabValues.length === 0) {
202
+ return;
203
+ }
204
+ import_taro.default.nextTick(() => {
205
+ centerActiveTab();
206
+ });
207
+ }, [registrationVersion, centerActiveTab]);
208
+ const contextValue = (0, import_react.useMemo)(
209
+ () => ({
210
+ value: currentValue,
211
+ triggerChange: handleClick,
212
+ onRegister,
213
+ onUnregister,
214
+ tabsContainerId: wrapperId
215
+ }),
216
+ [currentValue, handleClick, onRegister, onUnregister, wrapperId]
217
+ );
218
+ const renderedTabs = (0, import_react.useMemo)(() => {
219
+ if (tabs.length > 0) {
220
+ return tabs.map((item) => /* @__PURE__ */ import_react.default.createElement(import_Tab.default, { key: item.index, index: item == null ? void 0 : item.index, disabled: item == null ? void 0 : item.disabled }, item.title));
221
+ }
222
+ return children;
223
+ }, [tabs, children]);
224
+ return /* @__PURE__ */ import_react.default.createElement("div", { className: (0, import_clsx.default)(import_classes.tabsRootClass, className), style, ref }, isScrollable && /* @__PURE__ */ import_react.default.createElement(import_react.default.Fragment, null, /* @__PURE__ */ import_react.default.createElement(import_TabMask.default, { position: "left" }), /* @__PURE__ */ import_react.default.createElement(import_TabMask.default, { position: "right" })), /* @__PURE__ */ import_react.default.createElement(
225
+ import_components.ScrollView,
226
+ {
227
+ id: scrollViewId,
228
+ className: import_classes.tabsScrollClass,
229
+ scrollX: true,
230
+ scrollWithAnimation,
231
+ scrollLeft,
232
+ onScroll: handleScroll,
233
+ enhanced: true,
234
+ showScrollbar: false,
235
+ enablePassive: true
236
+ },
237
+ /* @__PURE__ */ import_react.default.createElement("div", { id: wrapperId, className: import_classes.tabsScrollWrapperClass }, /* @__PURE__ */ import_react.default.createElement(
238
+ import_TabIndicator.default,
239
+ {
240
+ currentValue,
241
+ registeredTabValues,
242
+ wrapperId,
243
+ scrollViewId,
244
+ registrationVersion
245
+ }
246
+ ), /* @__PURE__ */ import_react.default.createElement(import_TabsContext.TabsContextProvider, { value: contextValue }, renderedTabs))
247
+ ));
248
+ });
249
+ Tabs.displayName = "BuiTabs";
250
+ var Tabs_default = Tabs;
@@ -0,0 +1,17 @@
1
+ import { TabChangeEvent } from '../Tabs.types';
2
+ export interface TabRegisterData {
3
+ value: string;
4
+ }
5
+ export interface TabsContextValueType {
6
+ value?: string;
7
+ triggerChange?: TabChangeEvent;
8
+ onRegister?: (data: TabRegisterData) => void;
9
+ onUnregister?: (data: {
10
+ value: string;
11
+ }) => void;
12
+ /** 容器的唯一ID,用于生成子元素ID */
13
+ tabsContainerId?: string;
14
+ }
15
+ declare const TabsContext: import("@bifrostui/utils").Context<TabsContextValueType>;
16
+ export declare const TabsContextProvider: import("react").Provider<TabsContextValueType> & import("react").FC<import("react").ProviderProps<TabsContextValueType>>;
17
+ export default TabsContext;
@@ -0,0 +1,39 @@
1
+ var __defProp = Object.defineProperty;
2
+ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
3
+ var __getOwnPropNames = Object.getOwnPropertyNames;
4
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
5
+ var __export = (target, all) => {
6
+ for (var name in all)
7
+ __defProp(target, name, { get: all[name], enumerable: true });
8
+ };
9
+ var __copyProps = (to, from, except, desc) => {
10
+ if (from && typeof from === "object" || typeof from === "function") {
11
+ for (let key of __getOwnPropNames(from))
12
+ if (!__hasOwnProp.call(to, key) && key !== except)
13
+ __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
14
+ }
15
+ return to;
16
+ };
17
+ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
18
+ var TabsContext_exports = {};
19
+ __export(TabsContext_exports, {
20
+ TabsContextProvider: () => TabsContextProvider,
21
+ default: () => TabsContext_default
22
+ });
23
+ module.exports = __toCommonJS(TabsContext_exports);
24
+ var import_utils = require("@bifrostui/utils");
25
+ const TabsContext = (0, import_utils.createContext)({
26
+ triggerChange: void 0,
27
+ onRegister: void 0,
28
+ onUnregister: void 0,
29
+ tabsContainerId: void 0
30
+ });
31
+ if (process.env.NODE_ENV !== "production") {
32
+ TabsContext.displayName = "BuiTabsContext";
33
+ }
34
+ const TabsContextProvider = TabsContext.Provider;
35
+ var TabsContext_default = TabsContext;
36
+ // Annotate the CommonJS export names for ESM import in node:
37
+ 0 && (module.exports = {
38
+ TabsContextProvider
39
+ });
@@ -0,0 +1,2 @@
1
+ export { default as Tab } from './Tab';
2
+ export { default, default as Tabs } from './Tabs';
@@ -0,0 +1,41 @@
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 miniapp_exports = {};
29
+ __export(miniapp_exports, {
30
+ Tab: () => import_Tab.default,
31
+ Tabs: () => import_Tabs.default,
32
+ default: () => import_Tabs.default
33
+ });
34
+ module.exports = __toCommonJS(miniapp_exports);
35
+ var import_Tab = __toESM(require("./Tab"));
36
+ var import_Tabs = __toESM(require("./Tabs"));
37
+ // Annotate the CommonJS export names for ESM import in node:
38
+ 0 && (module.exports = {
39
+ Tab,
40
+ Tabs
41
+ });
@@ -0,0 +1,21 @@
1
+ /**
2
+ * 小程序版scroll-view滚动到指定位置
3
+ * 使用scroll-left属性和scroll-with-animation实现平滑滚动
4
+ */
5
+ interface ScrollToOptions {
6
+ scrollViewId: string;
7
+ scrollLeft: number;
8
+ duration?: number;
9
+ }
10
+ declare const scrollLeftTo: ({ scrollViewId, scrollLeft, duration, }: ScrollToOptions) => Promise<void>;
11
+ /**
12
+ * 计算将目标元素滚动到视图中心所需的 scrollLeft 值
13
+ */
14
+ interface CalcCenterScrollOptions {
15
+ containerWidth: number;
16
+ targetLeft: number;
17
+ targetWidth: number;
18
+ currentScrollLeft?: number;
19
+ }
20
+ export declare const calcCenterScroll: ({ containerWidth, targetLeft, targetWidth, currentScrollLeft, }: CalcCenterScrollOptions) => number;
21
+ export default scrollLeftTo;