@fountain-ui/lab 2.0.0-beta.9 → 3.0.0-alpha.10

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 (480) hide show
  1. package/build/commonjs/BottomSheet/BottomSheetNative.js +97 -30
  2. package/build/commonjs/BottomSheet/BottomSheetNative.js.map +1 -1
  3. package/build/commonjs/BottomSheet/BottomSheetProps.js.map +1 -1
  4. package/build/commonjs/BottomSheet/BottomSheetWeb.js +64 -17
  5. package/build/commonjs/BottomSheet/BottomSheetWeb.js.map +1 -1
  6. package/build/commonjs/BottomSheet/useDynamicSnapPoints.js +79 -0
  7. package/build/commonjs/BottomSheet/useDynamicSnapPoints.js.map +1 -0
  8. package/build/commonjs/BottomSheet/useDynamicSnapPoints.native.js +22 -0
  9. package/build/commonjs/BottomSheet/useDynamicSnapPoints.native.js.map +1 -0
  10. package/build/commonjs/Carousel/Carousel.js +130 -0
  11. package/build/commonjs/Carousel/Carousel.js.map +1 -0
  12. package/build/commonjs/Carousel/CarouselProps.js.map +1 -1
  13. package/build/commonjs/Carousel/animation/animationUtils.js +9 -0
  14. package/build/commonjs/Carousel/animation/animationUtils.js.map +1 -0
  15. package/build/commonjs/Carousel/animation/createDefaultItemStyle.js +15 -0
  16. package/build/commonjs/Carousel/animation/createDefaultItemStyle.js.map +1 -0
  17. package/build/commonjs/Carousel/animation/createDefaultScrollAnimation.js +26 -0
  18. package/build/commonjs/Carousel/animation/createDefaultScrollAnimation.js.map +1 -0
  19. package/build/commonjs/Carousel/animation/index.js +40 -0
  20. package/build/commonjs/Carousel/animation/index.js.map +1 -0
  21. package/build/commonjs/Carousel/animation/normalItemStyleFactory.js +27 -0
  22. package/build/commonjs/Carousel/animation/normalItemStyleFactory.js.map +1 -0
  23. package/build/commonjs/Carousel/animation/parallaxItemStyleFactory.js +65 -0
  24. package/build/commonjs/Carousel/animation/parallaxItemStyleFactory.js.map +1 -0
  25. package/build/commonjs/Carousel/components/InternalContext.js +29 -0
  26. package/build/commonjs/Carousel/components/InternalContext.js.map +1 -0
  27. package/build/commonjs/Carousel/components/ItemView.js +66 -0
  28. package/build/commonjs/Carousel/components/ItemView.js.map +1 -0
  29. package/build/commonjs/Carousel/components/RootView.js +86 -0
  30. package/build/commonjs/Carousel/components/RootView.js.map +1 -0
  31. package/build/commonjs/Carousel/components/ScrollViewGesture.js +84 -0
  32. package/build/commonjs/Carousel/components/ScrollViewGesture.js.map +1 -0
  33. package/build/commonjs/Carousel/components/index.js +40 -0
  34. package/build/commonjs/Carousel/components/index.js.map +1 -0
  35. package/build/commonjs/Carousel/components/useItemInterpolation.js +65 -0
  36. package/build/commonjs/Carousel/components/useItemInterpolation.js.map +1 -0
  37. package/build/commonjs/Carousel/hooks/index.js +48 -0
  38. package/build/commonjs/Carousel/hooks/index.js.map +1 -0
  39. package/build/commonjs/Carousel/hooks/useAutoplayController.js +58 -0
  40. package/build/commonjs/Carousel/hooks/useAutoplayController.js.map +1 -0
  41. package/build/commonjs/Carousel/hooks/useIndexController.js +55 -0
  42. package/build/commonjs/Carousel/hooks/useIndexController.js.map +1 -0
  43. package/build/commonjs/Carousel/hooks/useItemVisibilityStore.js +95 -0
  44. package/build/commonjs/Carousel/hooks/useItemVisibilityStore.js.map +1 -0
  45. package/build/commonjs/Carousel/hooks/useLoopedData.js +33 -0
  46. package/build/commonjs/Carousel/hooks/useLoopedData.js.map +1 -0
  47. package/build/commonjs/Carousel/hooks/usePagingAnimator.js +202 -0
  48. package/build/commonjs/Carousel/hooks/usePagingAnimator.js.map +1 -0
  49. package/build/commonjs/Carousel/index.js +16 -2
  50. package/build/commonjs/Carousel/index.js.map +1 -1
  51. package/build/commonjs/Carousel/tick.js +16 -0
  52. package/build/commonjs/Carousel/tick.js.map +1 -0
  53. package/build/commonjs/Carousel/types.js +8 -0
  54. package/build/commonjs/Carousel/types.js.map +1 -0
  55. package/build/commonjs/ComicViewer/ComicViewer.js +230 -92
  56. package/build/commonjs/ComicViewer/ComicViewer.js.map +1 -1
  57. package/build/commonjs/ComicViewer/ComicViewerProps.js.map +1 -1
  58. package/build/commonjs/ComicViewer/EncodedTile.js +10 -0
  59. package/build/commonjs/ComicViewer/EncodedTile.js.map +1 -0
  60. package/build/commonjs/ComicViewer/FastScroll.js +175 -0
  61. package/build/commonjs/ComicViewer/FastScroll.js.map +1 -0
  62. package/build/commonjs/ComicViewer/{ComicViewerItemProps.js → FastScrollProps.js} +1 -1
  63. package/build/commonjs/ComicViewer/FastScrollProps.js.map +1 -0
  64. package/build/commonjs/ComicViewer/ReloadButton.js +48 -0
  65. package/build/commonjs/ComicViewer/ReloadButton.js.map +1 -0
  66. package/build/commonjs/ComicViewer/ViewerItem.js +53 -59
  67. package/build/commonjs/ComicViewer/ViewerItem.js.map +1 -1
  68. package/build/commonjs/ComicViewer/index.js.map +1 -1
  69. package/build/commonjs/ComicViewer/util.js +27 -0
  70. package/build/commonjs/ComicViewer/util.js.map +1 -0
  71. package/build/commonjs/DateTimePicker/DateTimePicker.js +12 -3
  72. package/build/commonjs/DateTimePicker/DateTimePicker.js.map +1 -1
  73. package/build/commonjs/DateTimePicker/YearPicker.js +2 -2
  74. package/build/commonjs/DateTimePicker/YearPicker.js.map +1 -1
  75. package/build/commonjs/StatusBarProvider/Provider.js.map +1 -1
  76. package/build/commonjs/StatusBarProvider/StatusBarProvider.js +111 -2
  77. package/build/commonjs/StatusBarProvider/StatusBarProvider.js.map +1 -1
  78. package/build/commonjs/ViewPager/FluxContext.js +13 -0
  79. package/build/commonjs/ViewPager/FluxContext.js.map +1 -0
  80. package/build/commonjs/ViewPager/InternalContext.js +17 -0
  81. package/build/commonjs/ViewPager/InternalContext.js.map +1 -0
  82. package/build/commonjs/ViewPager/PageStateContext.js +14 -0
  83. package/build/commonjs/ViewPager/PageStateContext.js.map +1 -0
  84. package/build/commonjs/ViewPager/ViewPager.js +81 -0
  85. package/build/commonjs/ViewPager/ViewPager.js.map +1 -0
  86. package/build/commonjs/ViewPager/ViewPager.native.js +152 -0
  87. package/build/commonjs/ViewPager/ViewPager.native.js.map +1 -0
  88. package/build/commonjs/ViewPager/ViewPagerProps.js.map +1 -1
  89. package/build/commonjs/ViewPager/components/ChildrenMemoizedPage.js +122 -0
  90. package/build/commonjs/ViewPager/components/ChildrenMemoizedPage.js.map +1 -0
  91. package/build/commonjs/ViewPager/components/FluxStoreProvider.js +37 -0
  92. package/build/commonjs/ViewPager/components/FluxStoreProvider.js.map +1 -0
  93. package/build/commonjs/ViewPager/components/index.js +24 -0
  94. package/build/commonjs/ViewPager/components/index.js.map +1 -0
  95. package/build/commonjs/ViewPager/hooks/index.js +64 -0
  96. package/build/commonjs/ViewPager/hooks/index.js.map +1 -0
  97. package/build/commonjs/ViewPager/hooks/useDispatch.js +22 -0
  98. package/build/commonjs/ViewPager/hooks/useDispatch.js.map +1 -0
  99. package/build/commonjs/ViewPager/hooks/useEagerState.js +24 -0
  100. package/build/commonjs/ViewPager/hooks/useEagerState.js.map +1 -0
  101. package/build/commonjs/ViewPager/hooks/useForceRender.js +16 -0
  102. package/build/commonjs/ViewPager/hooks/useForceRender.js.map +1 -0
  103. package/build/commonjs/ViewPager/hooks/useLazyState.js +43 -0
  104. package/build/commonjs/ViewPager/hooks/useLazyState.js.map +1 -0
  105. package/build/commonjs/ViewPager/hooks/usePageStore.js +35 -0
  106. package/build/commonjs/ViewPager/hooks/usePageStore.js.map +1 -0
  107. package/build/commonjs/ViewPager/hooks/useStore.js +26 -0
  108. package/build/commonjs/ViewPager/hooks/useStore.js.map +1 -0
  109. package/build/commonjs/ViewPager/hooks/useViewPagerPageState.js +19 -0
  110. package/build/commonjs/ViewPager/hooks/useViewPagerPageState.js.map +1 -0
  111. package/build/commonjs/ViewPager/index.js +42 -2
  112. package/build/commonjs/ViewPager/index.js.map +1 -1
  113. package/build/commonjs/ViewPager/types.js +2 -0
  114. package/build/commonjs/ViewPager/types.js.map +1 -0
  115. package/build/commonjs/ViewPager/utils.js +12 -45
  116. package/build/commonjs/ViewPager/utils.js.map +1 -1
  117. package/build/commonjs/ViewabilityTrackerView/Viewability.js +2 -0
  118. package/build/commonjs/ViewabilityTrackerView/Viewability.js.map +1 -0
  119. package/build/commonjs/ViewabilityTrackerView/ViewabilityTrackerView.js +45 -0
  120. package/build/commonjs/ViewabilityTrackerView/ViewabilityTrackerView.js.map +1 -0
  121. package/build/commonjs/ViewabilityTrackerView/ViewabilityTrackerViewProps.js +2 -0
  122. package/build/commonjs/ViewabilityTrackerView/ViewabilityTrackerViewProps.js.map +1 -0
  123. package/build/commonjs/{Carousel/index.native.js → ViewabilityTrackerView/index.js} +3 -3
  124. package/build/commonjs/ViewabilityTrackerView/index.js.map +1 -0
  125. package/build/commonjs/ViewabilityTrackerView/measureViewability.js +42 -0
  126. package/build/commonjs/ViewabilityTrackerView/measureViewability.js.map +1 -0
  127. package/build/commonjs/ViewabilityTrackerView/useViewabilityTracker.js +88 -0
  128. package/build/commonjs/ViewabilityTrackerView/useViewabilityTracker.js.map +1 -0
  129. package/build/commonjs/hooks/index.js +16 -0
  130. package/build/commonjs/hooks/index.js.map +1 -1
  131. package/build/commonjs/hooks/useDeferredExecutor.js +45 -0
  132. package/build/commonjs/hooks/useDeferredExecutor.js.map +1 -0
  133. package/build/commonjs/hooks/useHeight.js +4 -4
  134. package/build/commonjs/hooks/useHeight.js.map +1 -1
  135. package/build/commonjs/hooks/useIsMounted.js +22 -0
  136. package/build/commonjs/hooks/useIsMounted.js.map +1 -0
  137. package/build/commonjs/hooks/useUnstableCollapsibleAppBar.js +3 -5
  138. package/build/commonjs/hooks/useUnstableCollapsibleAppBar.js.map +1 -1
  139. package/build/commonjs/index.js +22 -1
  140. package/build/commonjs/index.js.map +1 -1
  141. package/build/module/BottomSheet/BottomSheetNative.js +91 -25
  142. package/build/module/BottomSheet/BottomSheetNative.js.map +1 -1
  143. package/build/module/BottomSheet/BottomSheetProps.js.map +1 -1
  144. package/build/module/BottomSheet/BottomSheetWeb.js +59 -18
  145. package/build/module/BottomSheet/BottomSheetWeb.js.map +1 -1
  146. package/build/module/BottomSheet/useDynamicSnapPoints.js +65 -0
  147. package/build/module/BottomSheet/useDynamicSnapPoints.js.map +1 -0
  148. package/build/module/BottomSheet/useDynamicSnapPoints.native.js +14 -0
  149. package/build/module/BottomSheet/useDynamicSnapPoints.native.js.map +1 -0
  150. package/build/module/Carousel/Carousel.js +109 -0
  151. package/build/module/Carousel/Carousel.js.map +1 -0
  152. package/build/module/Carousel/CarouselProps.js.map +1 -1
  153. package/build/module/Carousel/animation/animationUtils.js +2 -0
  154. package/build/module/Carousel/animation/animationUtils.js.map +1 -0
  155. package/build/module/Carousel/animation/createDefaultItemStyle.js +3 -0
  156. package/build/module/Carousel/animation/createDefaultItemStyle.js.map +1 -0
  157. package/build/module/Carousel/animation/createDefaultScrollAnimation.js +12 -0
  158. package/build/module/Carousel/animation/createDefaultScrollAnimation.js.map +1 -0
  159. package/build/module/Carousel/animation/index.js +5 -0
  160. package/build/module/Carousel/animation/index.js.map +1 -0
  161. package/build/module/Carousel/animation/normalItemStyleFactory.js +18 -0
  162. package/build/module/Carousel/animation/normalItemStyleFactory.js.map +1 -0
  163. package/build/module/Carousel/animation/parallaxItemStyleFactory.js +55 -0
  164. package/build/module/Carousel/animation/parallaxItemStyleFactory.js.map +1 -0
  165. package/build/module/Carousel/components/InternalContext.js +19 -0
  166. package/build/module/Carousel/components/InternalContext.js.map +1 -0
  167. package/build/module/Carousel/components/ItemView.js +46 -0
  168. package/build/module/Carousel/components/ItemView.js.map +1 -0
  169. package/build/module/Carousel/components/RootView.js +65 -0
  170. package/build/module/Carousel/components/RootView.js.map +1 -0
  171. package/build/module/Carousel/components/ScrollViewGesture.js +69 -0
  172. package/build/module/Carousel/components/ScrollViewGesture.js.map +1 -0
  173. package/build/module/Carousel/components/index.js +5 -0
  174. package/build/module/Carousel/components/index.js.map +1 -0
  175. package/build/module/Carousel/components/useItemInterpolation.js +51 -0
  176. package/build/module/Carousel/components/useItemInterpolation.js.map +1 -0
  177. package/build/module/Carousel/hooks/index.js +6 -0
  178. package/build/module/Carousel/hooks/index.js.map +1 -0
  179. package/build/module/Carousel/hooks/useAutoplayController.js +48 -0
  180. package/build/module/Carousel/hooks/useAutoplayController.js.map +1 -0
  181. package/build/module/Carousel/hooks/useIndexController.js +44 -0
  182. package/build/module/Carousel/hooks/useIndexController.js.map +1 -0
  183. package/build/module/Carousel/hooks/useItemVisibilityStore.js +86 -0
  184. package/build/module/Carousel/hooks/useItemVisibilityStore.js.map +1 -0
  185. package/build/module/Carousel/hooks/useLoopedData.js +24 -0
  186. package/build/module/Carousel/hooks/useLoopedData.js.map +1 -0
  187. package/build/module/Carousel/hooks/usePagingAnimator.js +192 -0
  188. package/build/module/Carousel/hooks/usePagingAnimator.js.map +1 -0
  189. package/build/module/Carousel/index.js +2 -1
  190. package/build/module/Carousel/index.js.map +1 -1
  191. package/build/module/Carousel/tick.js +6 -0
  192. package/build/module/Carousel/tick.js.map +1 -0
  193. package/build/module/Carousel/types.js +4 -0
  194. package/build/module/Carousel/types.js.map +1 -0
  195. package/build/module/ComicViewer/ComicViewer.js +229 -93
  196. package/build/module/ComicViewer/ComicViewer.js.map +1 -1
  197. package/build/module/ComicViewer/ComicViewerProps.js.map +1 -1
  198. package/build/module/ComicViewer/EncodedTile.js +3 -0
  199. package/build/module/ComicViewer/EncodedTile.js.map +1 -0
  200. package/build/module/ComicViewer/FastScroll.js +152 -0
  201. package/build/module/ComicViewer/FastScroll.js.map +1 -0
  202. package/build/module/ComicViewer/FastScrollProps.js +2 -0
  203. package/build/module/ComicViewer/FastScrollProps.js.map +1 -0
  204. package/build/module/ComicViewer/ReloadButton.js +33 -0
  205. package/build/module/ComicViewer/ReloadButton.js.map +1 -0
  206. package/build/module/ComicViewer/ViewerItem.js +53 -60
  207. package/build/module/ComicViewer/ViewerItem.js.map +1 -1
  208. package/build/module/ComicViewer/index.js.map +1 -1
  209. package/build/module/ComicViewer/util.js +15 -0
  210. package/build/module/ComicViewer/util.js.map +1 -0
  211. package/build/module/DateTimePicker/DateTimePicker.js +13 -4
  212. package/build/module/DateTimePicker/DateTimePicker.js.map +1 -1
  213. package/build/module/DateTimePicker/YearPicker.js +2 -2
  214. package/build/module/DateTimePicker/YearPicker.js.map +1 -1
  215. package/build/module/StatusBarProvider/Provider.js.map +1 -1
  216. package/build/module/StatusBarProvider/StatusBarProvider.js +105 -2
  217. package/build/module/StatusBarProvider/StatusBarProvider.js.map +1 -1
  218. package/build/module/ViewPager/FluxContext.js +4 -0
  219. package/build/module/ViewPager/FluxContext.js.map +1 -0
  220. package/build/module/ViewPager/InternalContext.js +7 -0
  221. package/build/module/ViewPager/InternalContext.js.map +1 -0
  222. package/build/module/ViewPager/PageStateContext.js +5 -0
  223. package/build/module/ViewPager/PageStateContext.js.map +1 -0
  224. package/build/module/ViewPager/ViewPager.js +57 -0
  225. package/build/module/ViewPager/ViewPager.js.map +1 -0
  226. package/build/module/ViewPager/ViewPager.native.js +129 -0
  227. package/build/module/ViewPager/ViewPager.native.js.map +1 -0
  228. package/build/module/ViewPager/ViewPagerProps.js.map +1 -1
  229. package/build/module/ViewPager/components/ChildrenMemoizedPage.js +101 -0
  230. package/build/module/ViewPager/components/ChildrenMemoizedPage.js.map +1 -0
  231. package/build/module/ViewPager/components/FluxStoreProvider.js +20 -0
  232. package/build/module/ViewPager/components/FluxStoreProvider.js.map +1 -0
  233. package/build/module/ViewPager/components/index.js +3 -0
  234. package/build/module/ViewPager/components/index.js.map +1 -0
  235. package/build/module/ViewPager/hooks/index.js +8 -0
  236. package/build/module/ViewPager/hooks/index.js.map +1 -0
  237. package/build/module/ViewPager/hooks/useDispatch.js +10 -0
  238. package/build/module/ViewPager/hooks/useDispatch.js.map +1 -0
  239. package/build/module/ViewPager/hooks/useEagerState.js +12 -0
  240. package/build/module/ViewPager/hooks/useEagerState.js.map +1 -0
  241. package/build/module/ViewPager/hooks/useForceRender.js +7 -0
  242. package/build/module/ViewPager/hooks/useForceRender.js.map +1 -0
  243. package/build/module/ViewPager/hooks/useLazyState.js +28 -0
  244. package/build/module/ViewPager/hooks/useLazyState.js.map +1 -0
  245. package/build/module/ViewPager/hooks/usePageStore.js +25 -0
  246. package/build/module/ViewPager/hooks/usePageStore.js.map +1 -0
  247. package/build/module/ViewPager/hooks/useStore.js +14 -0
  248. package/build/module/ViewPager/hooks/useStore.js.map +1 -0
  249. package/build/module/ViewPager/hooks/useViewPagerPageState.js +7 -0
  250. package/build/module/ViewPager/hooks/useViewPagerPageState.js.map +1 -0
  251. package/build/module/ViewPager/index.js +3 -1
  252. package/build/module/ViewPager/index.js.map +1 -1
  253. package/build/module/ViewPager/types.js +2 -0
  254. package/build/module/ViewPager/types.js.map +1 -0
  255. package/build/module/ViewPager/utils.js +6 -34
  256. package/build/module/ViewPager/utils.js.map +1 -1
  257. package/build/module/ViewabilityTrackerView/Viewability.js +2 -0
  258. package/build/module/ViewabilityTrackerView/Viewability.js.map +1 -0
  259. package/build/module/ViewabilityTrackerView/ViewabilityTrackerView.js +28 -0
  260. package/build/module/ViewabilityTrackerView/ViewabilityTrackerView.js.map +1 -0
  261. package/build/module/ViewabilityTrackerView/ViewabilityTrackerViewProps.js +2 -0
  262. package/build/module/ViewabilityTrackerView/ViewabilityTrackerViewProps.js.map +1 -0
  263. package/build/module/ViewabilityTrackerView/index.js +2 -0
  264. package/build/module/ViewabilityTrackerView/index.js.map +1 -0
  265. package/build/module/ViewabilityTrackerView/measureViewability.js +34 -0
  266. package/build/module/ViewabilityTrackerView/measureViewability.js.map +1 -0
  267. package/build/module/ViewabilityTrackerView/useViewabilityTracker.js +73 -0
  268. package/build/module/ViewabilityTrackerView/useViewabilityTracker.js.map +1 -0
  269. package/build/module/hooks/index.js +2 -0
  270. package/build/module/hooks/index.js.map +1 -1
  271. package/build/module/hooks/useDeferredExecutor.js +33 -0
  272. package/build/module/hooks/useDeferredExecutor.js.map +1 -0
  273. package/build/module/hooks/useHeight.js +2 -3
  274. package/build/module/hooks/useHeight.js.map +1 -1
  275. package/build/module/hooks/useIsMounted.js +13 -0
  276. package/build/module/hooks/useIsMounted.js.map +1 -0
  277. package/build/module/hooks/useUnstableCollapsibleAppBar.js +4 -6
  278. package/build/module/hooks/useUnstableCollapsibleAppBar.js.map +1 -1
  279. package/build/module/index.js +2 -0
  280. package/build/module/index.js.map +1 -1
  281. package/build/typescript/AnimatedY/AnimatedY.d.ts +1 -0
  282. package/build/typescript/BottomSheet/BottomSheetNative.d.ts +1 -0
  283. package/build/typescript/BottomSheet/BottomSheetProps.d.ts +31 -2
  284. package/build/typescript/BottomSheet/BottomSheetWeb.d.ts +1 -0
  285. package/build/typescript/BottomSheet/TransparentBackdrop.d.ts +1 -0
  286. package/build/typescript/BottomSheet/useDynamicSnapPoints.d.ts +13 -0
  287. package/build/typescript/BottomSheet/useDynamicSnapPoints.native.d.ts +21 -0
  288. package/build/typescript/Carousel/Carousel.d.ts +5 -0
  289. package/build/typescript/Carousel/CarouselProps.d.ts +33 -48
  290. package/build/typescript/Carousel/animation/animationUtils.d.ts +1 -0
  291. package/build/typescript/Carousel/animation/createDefaultItemStyle.d.ts +2 -0
  292. package/build/typescript/Carousel/animation/createDefaultScrollAnimation.d.ts +2 -0
  293. package/build/typescript/Carousel/animation/index.d.ts +4 -0
  294. package/build/typescript/Carousel/animation/normalItemStyleFactory.d.ts +2 -0
  295. package/build/typescript/Carousel/animation/parallaxItemStyleFactory.d.ts +9 -0
  296. package/build/typescript/Carousel/components/InternalContext.d.ts +14 -0
  297. package/build/typescript/Carousel/components/ItemView.d.ts +9 -0
  298. package/build/typescript/Carousel/components/RootView.d.ts +16 -0
  299. package/build/typescript/Carousel/components/ScrollViewGesture.d.ts +12 -0
  300. package/build/typescript/Carousel/components/index.d.ts +4 -0
  301. package/build/typescript/Carousel/components/useItemInterpolation.d.ts +2 -0
  302. package/build/typescript/Carousel/hooks/index.d.ts +5 -0
  303. package/build/typescript/Carousel/hooks/useAutoplayController.d.ts +7 -0
  304. package/build/typescript/Carousel/hooks/useIndexController.d.ts +10 -0
  305. package/build/typescript/Carousel/hooks/useItemVisibilityStore.d.ts +7 -0
  306. package/build/typescript/Carousel/hooks/useLoopedData.d.ts +1 -0
  307. package/build/typescript/Carousel/hooks/usePagingAnimator.d.ts +17 -0
  308. package/build/typescript/Carousel/index.d.ts +3 -1
  309. package/build/typescript/Carousel/tick.d.ts +2 -0
  310. package/build/typescript/Carousel/types.d.ts +91 -0
  311. package/build/typescript/ComicViewer/ComicViewer.d.ts +2 -1
  312. package/build/typescript/ComicViewer/ComicViewerProps.d.ts +61 -43
  313. package/build/typescript/ComicViewer/EncodedTile.d.ts +2 -0
  314. package/build/typescript/ComicViewer/FastScroll.d.ts +4 -0
  315. package/build/typescript/ComicViewer/FastScrollProps.d.ts +74 -0
  316. package/build/typescript/ComicViewer/ReloadButton.d.ts +7 -0
  317. package/build/typescript/ComicViewer/ViewerItem.d.ts +46 -7
  318. package/build/typescript/ComicViewer/index.d.ts +3 -2
  319. package/build/typescript/ComicViewer/util.d.ts +2 -0
  320. package/build/typescript/DateTimePicker/DateTimePicker.d.ts +1 -0
  321. package/build/typescript/DateTimePicker/YearPicker.d.ts +1 -0
  322. package/build/typescript/FlipCard/FlipCard.d.ts +1 -0
  323. package/build/typescript/StatusBarProvider/Provider.d.ts +13 -0
  324. package/build/typescript/StatusBarProvider/StatusBarProvider.d.ts +1 -0
  325. package/build/typescript/ViewPager/FluxContext.d.ts +5 -0
  326. package/build/typescript/ViewPager/InternalContext.d.ts +7 -0
  327. package/build/typescript/ViewPager/PageStateContext.d.ts +6 -0
  328. package/build/typescript/ViewPager/ViewPager.d.ts +5 -0
  329. package/build/typescript/ViewPager/ViewPager.native.d.ts +5 -0
  330. package/build/typescript/ViewPager/ViewPagerProps.d.ts +21 -27
  331. package/build/typescript/ViewPager/components/ChildrenMemoizedPage.d.ts +14 -0
  332. package/build/typescript/ViewPager/components/FluxStoreProvider.d.ts +6 -0
  333. package/build/typescript/ViewPager/components/index.d.ts +2 -0
  334. package/build/typescript/ViewPager/hooks/index.d.ts +7 -0
  335. package/build/typescript/ViewPager/hooks/useDispatch.d.ts +2 -0
  336. package/build/typescript/ViewPager/hooks/useEagerState.d.ts +1 -0
  337. package/build/typescript/ViewPager/hooks/useForceRender.d.ts +2 -0
  338. package/build/typescript/ViewPager/hooks/useLazyState.d.ts +2 -0
  339. package/build/typescript/ViewPager/hooks/usePageStore.d.ts +2 -0
  340. package/build/typescript/ViewPager/hooks/useStore.d.ts +2 -0
  341. package/build/typescript/ViewPager/hooks/useViewPagerPageState.d.ts +1 -0
  342. package/build/typescript/ViewPager/index.d.ts +4 -1
  343. package/build/typescript/ViewPager/types.d.ts +12 -0
  344. package/build/typescript/ViewPager/utils.d.ts +5 -20
  345. package/build/typescript/ViewabilityTrackerView/Viewability.d.ts +3 -0
  346. package/build/typescript/ViewabilityTrackerView/ViewabilityTrackerView.d.ts +3 -0
  347. package/build/typescript/ViewabilityTrackerView/ViewabilityTrackerViewProps.d.ts +22 -0
  348. package/build/typescript/ViewabilityTrackerView/index.d.ts +2 -0
  349. package/build/typescript/ViewabilityTrackerView/measureViewability.d.ts +11 -0
  350. package/build/typescript/ViewabilityTrackerView/useViewabilityTracker.d.ts +11 -0
  351. package/build/typescript/hooks/index.d.ts +2 -0
  352. package/build/typescript/hooks/useDeferredExecutor.d.ts +11 -0
  353. package/build/typescript/hooks/useIsMounted.d.ts +4 -0
  354. package/build/typescript/index.d.ts +2 -0
  355. package/package.json +10 -25
  356. package/src/BottomSheet/BottomSheetNative.tsx +103 -24
  357. package/src/BottomSheet/BottomSheetProps.ts +37 -2
  358. package/src/BottomSheet/BottomSheetWeb.tsx +69 -24
  359. package/src/BottomSheet/useDynamicSnapPoints.native.ts +15 -0
  360. package/src/BottomSheet/useDynamicSnapPoints.ts +87 -0
  361. package/src/Carousel/Carousel.tsx +135 -0
  362. package/src/Carousel/CarouselProps.ts +42 -53
  363. package/src/Carousel/animation/animationUtils.ts +1 -0
  364. package/src/Carousel/animation/createDefaultItemStyle.ts +3 -0
  365. package/src/Carousel/animation/createDefaultScrollAnimation.ts +14 -0
  366. package/src/Carousel/animation/index.ts +4 -0
  367. package/src/Carousel/animation/normalItemStyleFactory.ts +19 -0
  368. package/src/Carousel/animation/parallaxItemStyleFactory.ts +79 -0
  369. package/src/Carousel/components/InternalContext.ts +33 -0
  370. package/src/Carousel/components/ItemView.tsx +66 -0
  371. package/src/Carousel/components/RootView.tsx +79 -0
  372. package/src/Carousel/components/ScrollViewGesture.tsx +93 -0
  373. package/src/Carousel/components/index.ts +4 -0
  374. package/src/Carousel/components/useItemInterpolation.ts +107 -0
  375. package/src/Carousel/hooks/index.ts +5 -0
  376. package/src/Carousel/hooks/useAutoplayController.ts +57 -0
  377. package/src/Carousel/hooks/useIndexController.tsx +57 -0
  378. package/src/Carousel/hooks/useItemVisibilityStore.ts +107 -0
  379. package/src/Carousel/hooks/useLoopedData.ts +26 -0
  380. package/src/Carousel/hooks/usePagingAnimator.ts +255 -0
  381. package/src/Carousel/index.ts +4 -2
  382. package/src/Carousel/tick.ts +6 -0
  383. package/src/Carousel/types.ts +114 -0
  384. package/src/ComicViewer/ComicViewer.tsx +268 -106
  385. package/src/ComicViewer/ComicViewerProps.ts +66 -44
  386. package/src/ComicViewer/EncodedTile.ts +3 -0
  387. package/src/ComicViewer/FastScroll.tsx +176 -0
  388. package/src/ComicViewer/FastScrollProps.ts +88 -0
  389. package/src/ComicViewer/ReloadButton.tsx +36 -0
  390. package/src/ComicViewer/ViewerItem.tsx +104 -62
  391. package/src/ComicViewer/index.ts +8 -2
  392. package/src/ComicViewer/util.ts +15 -0
  393. package/src/DateTimePicker/DateTimePicker.tsx +11 -3
  394. package/src/DateTimePicker/YearPicker.tsx +2 -2
  395. package/src/StatusBarProvider/Provider.ts +14 -0
  396. package/src/StatusBarProvider/StatusBarProvider.tsx +103 -1
  397. package/src/ViewPager/FluxContext.ts +8 -0
  398. package/src/ViewPager/InternalContext.ts +13 -0
  399. package/src/ViewPager/PageStateContext.ts +11 -0
  400. package/src/ViewPager/ViewPager.native.tsx +152 -0
  401. package/src/ViewPager/ViewPager.tsx +69 -0
  402. package/src/ViewPager/ViewPagerProps.ts +25 -34
  403. package/src/ViewPager/components/ChildrenMemoizedPage.tsx +124 -0
  404. package/src/ViewPager/components/FluxStoreProvider.tsx +27 -0
  405. package/src/ViewPager/components/index.ts +2 -0
  406. package/src/ViewPager/hooks/index.ts +7 -0
  407. package/src/ViewPager/hooks/useDispatch.ts +11 -0
  408. package/src/ViewPager/hooks/useEagerState.ts +14 -0
  409. package/src/ViewPager/hooks/useForceRender.ts +7 -0
  410. package/src/ViewPager/hooks/useLazyState.ts +32 -0
  411. package/src/ViewPager/hooks/usePageStore.ts +30 -0
  412. package/src/ViewPager/hooks/useStore.ts +15 -0
  413. package/src/ViewPager/hooks/useViewPagerPageState.ts +6 -0
  414. package/src/ViewPager/index.ts +11 -2
  415. package/src/ViewPager/types.ts +15 -0
  416. package/src/ViewPager/utils.tsx +9 -56
  417. package/src/ViewabilityTrackerView/Viewability.ts +3 -0
  418. package/src/ViewabilityTrackerView/ViewabilityTrackerView.tsx +33 -0
  419. package/src/ViewabilityTrackerView/ViewabilityTrackerViewProps.ts +25 -0
  420. package/src/ViewabilityTrackerView/index.ts +2 -0
  421. package/src/ViewabilityTrackerView/measureViewability.ts +54 -0
  422. package/src/ViewabilityTrackerView/useViewabilityTracker.ts +85 -0
  423. package/src/hooks/index.ts +2 -0
  424. package/src/hooks/useDeferredExecutor.ts +46 -0
  425. package/src/hooks/useHeight.ts +3 -4
  426. package/src/hooks/useIsMounted.ts +19 -0
  427. package/src/hooks/useUnstableCollapsibleAppBar.ts +4 -4
  428. package/src/index.ts +3 -0
  429. package/build/commonjs/Carousel/CarouselNative.js +0 -72
  430. package/build/commonjs/Carousel/CarouselNative.js.map +0 -1
  431. package/build/commonjs/Carousel/CarouselWeb.js +0 -237
  432. package/build/commonjs/Carousel/CarouselWeb.js.map +0 -1
  433. package/build/commonjs/Carousel/index.native.js.map +0 -1
  434. package/build/commonjs/Carousel/utils.js +0 -19
  435. package/build/commonjs/Carousel/utils.js.map +0 -1
  436. package/build/commonjs/ComicViewer/ComicViewerItemProps.js.map +0 -1
  437. package/build/commonjs/ViewPager/ChildrenMemoizedPage.js +0 -49
  438. package/build/commonjs/ViewPager/ChildrenMemoizedPage.js.map +0 -1
  439. package/build/commonjs/ViewPager/ViewPagerNative.js +0 -75
  440. package/build/commonjs/ViewPager/ViewPagerNative.js.map +0 -1
  441. package/build/commonjs/ViewPager/ViewPagerWeb.js +0 -55
  442. package/build/commonjs/ViewPager/ViewPagerWeb.js.map +0 -1
  443. package/build/commonjs/ViewPager/index.native.js +0 -16
  444. package/build/commonjs/ViewPager/index.native.js.map +0 -1
  445. package/build/module/Carousel/CarouselNative.js +0 -54
  446. package/build/module/Carousel/CarouselNative.js.map +0 -1
  447. package/build/module/Carousel/CarouselWeb.js +0 -215
  448. package/build/module/Carousel/CarouselWeb.js.map +0 -1
  449. package/build/module/Carousel/index.native.js +0 -2
  450. package/build/module/Carousel/index.native.js.map +0 -1
  451. package/build/module/Carousel/utils.js +0 -7
  452. package/build/module/Carousel/utils.js.map +0 -1
  453. package/build/module/ComicViewer/ComicViewerItemProps.js +0 -2
  454. package/build/module/ComicViewer/ComicViewerItemProps.js.map +0 -1
  455. package/build/module/ViewPager/ChildrenMemoizedPage.js +0 -37
  456. package/build/module/ViewPager/ChildrenMemoizedPage.js.map +0 -1
  457. package/build/module/ViewPager/ViewPagerNative.js +0 -58
  458. package/build/module/ViewPager/ViewPagerNative.js.map +0 -1
  459. package/build/module/ViewPager/ViewPagerWeb.js +0 -41
  460. package/build/module/ViewPager/ViewPagerWeb.js.map +0 -1
  461. package/build/module/ViewPager/index.native.js +0 -2
  462. package/build/module/ViewPager/index.native.js.map +0 -1
  463. package/build/typescript/Carousel/CarouselNative.d.ts +0 -2
  464. package/build/typescript/Carousel/CarouselWeb.d.ts +0 -4
  465. package/build/typescript/Carousel/index.native.d.ts +0 -1
  466. package/build/typescript/Carousel/utils.d.ts +0 -6
  467. package/build/typescript/ComicViewer/ComicViewerItemProps.d.ts +0 -12
  468. package/build/typescript/ViewPager/ChildrenMemoizedPage.d.ts +0 -4
  469. package/build/typescript/ViewPager/ViewPagerNative.d.ts +0 -2
  470. package/build/typescript/ViewPager/ViewPagerWeb.d.ts +0 -2
  471. package/build/typescript/ViewPager/index.native.d.ts +0 -1
  472. package/src/Carousel/CarouselNative.tsx +0 -67
  473. package/src/Carousel/CarouselWeb.tsx +0 -222
  474. package/src/Carousel/index.native.ts +0 -1
  475. package/src/Carousel/utils.ts +0 -11
  476. package/src/ComicViewer/ComicViewerItemProps.ts +0 -15
  477. package/src/ViewPager/ChildrenMemoizedPage.tsx +0 -36
  478. package/src/ViewPager/ViewPagerNative.tsx +0 -73
  479. package/src/ViewPager/ViewPagerWeb.tsx +0 -52
  480. package/src/ViewPager/index.native.ts +0 -1
@@ -0,0 +1,7 @@
1
+ /// <reference types="react" />
2
+ import type { MonoStore } from '@fountain-ui/core';
3
+ export interface InternalContextValue {
4
+ pageStore: MonoStore<number>;
5
+ }
6
+ declare const InternalContext: import("react").Context<InternalContextValue>;
7
+ export default InternalContext;
@@ -0,0 +1,6 @@
1
+ /// <reference types="react" />
2
+ export interface PageState {
3
+ isActive: boolean;
4
+ }
5
+ declare const PageStateContext: import("react").Context<PageState | null>;
6
+ export default PageStateContext;
@@ -0,0 +1,5 @@
1
+ import React from 'react';
2
+ import type ViewPagerProps from './ViewPagerProps';
3
+ import type { ViewPagerInstance } from './types';
4
+ declare const ViewPager: React.ForwardRefExoticComponent<Pick<ViewPagerProps, "style" | "children" | "onChange" | "scrollEnabled" | "keyboardDismissMode" | "initialPage" | "loading" | "offscreenPageRerenderLimit" | "onPageScrollStateChanged" | "pageForceRerenderKey" | "UNSTABLE_sharedPage"> & React.RefAttributes<ViewPagerInstance>>;
5
+ export default ViewPager;
@@ -0,0 +1,5 @@
1
+ import React from 'react';
2
+ import type ViewPagerProps from './ViewPagerProps';
3
+ import type { ViewPagerInstance } from './types';
4
+ declare const ViewPager: React.ForwardRefExoticComponent<Pick<ViewPagerProps, "style" | "children" | "onChange" | "scrollEnabled" | "keyboardDismissMode" | "initialPage" | "loading" | "offscreenPageRerenderLimit" | "onPageScrollStateChanged" | "pageForceRerenderKey" | "UNSTABLE_sharedPage"> & React.RefAttributes<ViewPagerInstance>>;
5
+ export default ViewPager;
@@ -1,47 +1,37 @@
1
- import React from 'react';
2
- import type { ViewProps } from 'react-native';
3
- import type { ComponentProps } from '@fountain-ui/core';
4
- export declare type KeyboardDismissMode = 'none' | 'on-drag';
5
- export declare type PageProps = React.PropsWithChildren<ViewProps> & {
6
- isNeighbor: boolean;
7
- isVisible: boolean;
8
- rerenderKey?: any;
9
- };
10
- export declare type PageComponent = React.ComponentType<PageProps>;
11
- export declare type Loading = 'lazy' | 'eager';
1
+ import type { ReactNode, Ref } from 'react';
2
+ import type { PageScrollStateChangedNativeEvent } from 'react-native-pager-view';
3
+ import type { ComponentProps, SyncAnimatedValue } from '@fountain-ui/core';
4
+ import type { KeyboardDismissMode, Loading, ViewPagerInstance } from './types';
12
5
  export default interface ViewPagerProps extends ComponentProps<{
6
+ ref?: Ref<ViewPagerInstance>;
13
7
  /**
14
8
  * Collection of ViewPager components.
15
9
  */
16
- children?: React.ReactNode;
10
+ children?: ReactNode;
17
11
  /**
18
- * If `true`, enable page visible hint.
19
- * @default false
12
+ * Index of initial page that should be selected.
13
+ * @default 0
20
14
  */
21
- enableVisibleHint?: boolean;
22
- /**
23
- * If `true`, Based on the current index, the pages on the left and right are also rerender.
24
- * @default false
25
- */
26
- enableNeighborPageRerender?: boolean;
27
- /**
28
- * A number representing the index of the active page.
29
- */
30
- index: number;
15
+ initialPage?: number;
31
16
  /**
32
17
  * Whether to load the page immediately (`eager`) or on an as-needed basis (`lazy`).
33
18
  * @default 'lazy'
34
19
  */
35
20
  loading?: Loading;
21
+ /**
22
+ * Mobile only. The number of pages that should be re-rendered to either side of the current page.
23
+ * Changing this value after the component mount has no effect.
24
+ * @default 0
25
+ */
26
+ offscreenPageRerenderLimit?: number;
36
27
  /**
37
28
  * Callback fired when an index is changed.
38
29
  */
39
30
  onChange?: (newIndex: number) => void;
40
31
  /**
41
- * The component used to render the wrapper of the page.
42
- * @default 'ChildrenMemoizedPage'
32
+ * Native only. This handler processes events that occur when the pager is scrolled horizontally.
43
33
  */
44
- pageComponent?: PageComponent;
34
+ onPageScrollStateChanged?: (event: PageScrollStateChangedNativeEvent) => void;
45
35
  /**
46
36
  * When this value is changed, page will be rerender.
47
37
  */
@@ -56,5 +46,9 @@ export default interface ViewPagerProps extends ComponentProps<{
56
46
  * @default 'on-drag'
57
47
  */
58
48
  keyboardDismissMode?: KeyboardDismissMode;
49
+ /**
50
+ * Unstable API.
51
+ */
52
+ UNSTABLE_sharedPage?: SyncAnimatedValue;
59
53
  }> {
60
54
  }
@@ -0,0 +1,14 @@
1
+ import type { PropsWithChildren } from 'react';
2
+ import React from 'react';
3
+ import type { ViewProps } from 'react-native';
4
+ import type { Loading } from '../types';
5
+ export declare type PageProps = PropsWithChildren<ViewProps> & {
6
+ index: number;
7
+ initialPage: number;
8
+ loading: Loading;
9
+ offscreenPageRerenderLimit: number;
10
+ rerenderKey?: any;
11
+ };
12
+ declare function Page(props: PageProps): JSX.Element;
13
+ declare const _default: React.MemoExoticComponent<typeof Page>;
14
+ export default _default;
@@ -0,0 +1,6 @@
1
+ import React from 'react';
2
+ export interface FluxStoreProviderProps<State> {
3
+ children: React.ReactElement;
4
+ initialState: State;
5
+ }
6
+ export default function FluxStoreProvider<State>(props: FluxStoreProviderProps<State>): JSX.Element;
@@ -0,0 +1,2 @@
1
+ export { default as ChildrenMemoizedPage } from './ChildrenMemoizedPage';
2
+ export { default as FluxStoreProvider } from './FluxStoreProvider';
@@ -0,0 +1,7 @@
1
+ export { default as useDispatch } from './useDispatch';
2
+ export { default as useEagerState } from './useEagerState';
3
+ export { default as useForceRender } from './useForceRender';
4
+ export { default as useLazyState } from './useLazyState';
5
+ export { default as usePageStore } from './usePageStore';
6
+ export { default as useStore } from './useStore';
7
+ export { default as useViewPagerPageState } from './useViewPagerPageState';
@@ -0,0 +1,2 @@
1
+ import type { DispatchAction } from '@fountain-ui/core';
2
+ export default function useDispatch<State>(): (action: DispatchAction<State>) => void;
@@ -0,0 +1 @@
1
+ export default function useEagerState<State>(): State;
@@ -0,0 +1,2 @@
1
+ /// <reference types="react" />
2
+ export default function useForceRender(): import("react").DispatchWithoutAction;
@@ -0,0 +1,2 @@
1
+ import type { EqualityFunction } from '../types';
2
+ export default function useLazyState<State>(equalityFn?: EqualityFunction<State>): State;
@@ -0,0 +1,2 @@
1
+ import type { MonoStore, SyncAnimatedValue } from '@fountain-ui/core';
2
+ export default function usePageStore(value: SyncAnimatedValue): MonoStore<number>;
@@ -0,0 +1,2 @@
1
+ import type { FluxStore } from '../FluxContext';
2
+ export default function useStore<State>(): FluxStore<State>;
@@ -0,0 +1 @@
1
+ export default function useViewPagerPageState(): import("../PageStateContext").PageState | null;
@@ -1,2 +1,5 @@
1
- export { default } from './ViewPagerWeb';
1
+ export { default } from './ViewPager';
2
2
  export type { default as ViewPagerProps } from './ViewPagerProps';
3
+ export type { ViewPagerInstance } from './types';
4
+ export { useDispatch as useFluxDispatch, useEagerState, useStore as useFluxStore, useLazyState, useViewPagerPageState, } from './hooks';
5
+ export { FluxStoreProvider } from './components';
@@ -0,0 +1,12 @@
1
+ export declare type KeyboardDismissMode = 'none' | 'on-drag';
2
+ export declare type Loading = 'lazy' | 'eager';
3
+ export interface EqualityFunction<State> {
4
+ (a: State, b: State): boolean;
5
+ }
6
+ export interface ViewPagerInstance {
7
+ /**
8
+ * Function to scroll to a specific page in the ViewPager. Invalid index is ignored.
9
+ * @param index
10
+ */
11
+ setPage: (index: number) => void;
12
+ }
@@ -1,21 +1,6 @@
1
- import React from 'react';
2
- import ViewPagerProps, { Loading, PageComponent } from './ViewPagerProps';
3
- export interface PageState {
4
- visited?: boolean;
5
- }
6
- export interface PageRenderOption {
7
- enableVisibleHint: boolean;
8
- enableNeighborPageRerender: boolean;
9
- index: number;
10
- loading: Loading;
11
- pageComponent: PageComponent;
12
- pageForceRerenderKey?: any;
13
- }
14
- export interface PageRenderer {
15
- (children: ViewPagerProps['children']): React.ReactNode;
16
- }
17
- export declare const defaultEnableVisibleHint: boolean;
18
- export declare const defaultEnableNeighborPageRerender: boolean;
1
+ import type { EqualityFunction, Loading } from './types';
2
+ export declare const defaultInitialPage: number;
19
3
  export declare const defaultLoading: Loading;
20
- export declare const defaultPageComponent: PageComponent;
21
- export declare const usePageRenderer: ({ enableVisibleHint, index: currentIndex, loading, pageComponent: PageComponent, pageForceRerenderKey, enableNeighborPageRerender, }: PageRenderOption) => PageRenderer;
4
+ export declare const defaultOffscreenPageRerenderLimit: number;
5
+ export declare const refEqual: EqualityFunction<any>;
6
+ export declare function isValidPage(maybePage: number, numberOfPages: number): boolean;
@@ -0,0 +1,3 @@
1
+ export default interface Viewability {
2
+ visible: boolean;
3
+ }
@@ -0,0 +1,3 @@
1
+ /// <reference types="react" />
2
+ import type ViewabilityTrackerViewProps from './ViewabilityTrackerViewProps';
3
+ export default function ViewabilityTrackerView(props: ViewabilityTrackerViewProps): JSX.Element;
@@ -0,0 +1,22 @@
1
+ import type { ViewProps } from 'react-native';
2
+ import type { OverridableComponentProps } from '@fountain-ui/core';
3
+ import type Viewability from './Viewability';
4
+ export default interface ViewabilityTrackerViewProps extends OverridableComponentProps<ViewProps, {
5
+ /**
6
+ * @default true
7
+ */
8
+ enabled?: boolean;
9
+ /**
10
+ * @default 1000
11
+ */
12
+ measurementIntervalMillis?: number;
13
+ /**
14
+ *
15
+ */
16
+ onViewabilityChange?: (viewability: Viewability) => void;
17
+ /**
18
+ * @default 50
19
+ */
20
+ visiblePercentThreshold?: number;
21
+ }> {
22
+ }
@@ -0,0 +1,2 @@
1
+ export { default } from './ViewabilityTrackerView';
2
+ export type { default as ViewabilityTrackerViewProps } from './ViewabilityTrackerViewProps';
@@ -0,0 +1,11 @@
1
+ import type { View } from 'react-native';
2
+ export interface ViewabilityDetail {
3
+ visiblePercent: number;
4
+ }
5
+ export interface MeasureViewabilityParameters {
6
+ view: View;
7
+ windowWidth: number;
8
+ windowHeight: number;
9
+ onViewabilityDetailMeasured: (detail: ViewabilityDetail) => void;
10
+ }
11
+ export default function measureViewability({ view, windowWidth, windowHeight, onViewabilityDetailMeasured, }: MeasureViewabilityParameters): void;
@@ -0,0 +1,11 @@
1
+ import type { RefObject } from 'react';
2
+ import type { View } from 'react-native';
3
+ import type Viewability from './Viewability';
4
+ export interface ViewabilityTrackerConfig {
5
+ enabled: boolean;
6
+ measurementIntervalMillis: number;
7
+ onViewabilityChange?: (viewability: Viewability) => void;
8
+ viewRef: RefObject<View>;
9
+ visiblePercentThreshold: number;
10
+ }
11
+ export default function useViewabilityTracker(config: ViewabilityTrackerConfig): void;
@@ -1,2 +1,4 @@
1
+ export { default as useDeferredExecutor } from './useDeferredExecutor';
2
+ export { default as useIsMounted } from './useIsMounted';
1
3
  export { default as useUnstableCollapsibleAppBar } from './useUnstableCollapsibleAppBar';
2
4
  export { default as useUnstableToggleDisplayStyle } from './useUnstableToggleDisplayStyle';
@@ -0,0 +1,11 @@
1
+ export interface Runnable {
2
+ (): void;
3
+ }
4
+ export interface DeferredExecute {
5
+ (runnable: Runnable, delay?: number): void;
6
+ }
7
+ export interface DeferredExecutor {
8
+ cancel: () => void;
9
+ execute: DeferredExecute;
10
+ }
11
+ export default function useDeferredExecutor(): DeferredExecutor;
@@ -0,0 +1,4 @@
1
+ export interface UseIsMounted {
2
+ (): boolean;
3
+ }
4
+ export default function useIsMounted(): UseIsMounted;
@@ -12,4 +12,6 @@ export { default as ComicViewer } from './ComicViewer';
12
12
  export * from './ComicViewer';
13
13
  export { default as StatusBarProvider, useStatusBarContext } from './StatusBarProvider';
14
14
  export * from './StatusBarProvider';
15
+ export { default as ViewabilityTrackerView } from './ViewabilityTrackerView';
16
+ export * from './ViewabilityTrackerView';
15
17
  export * from './hooks';
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@fountain-ui/lab",
3
- "version": "2.0.0-beta.9",
3
+ "version": "3.0.0-alpha.10",
4
4
  "private": false,
5
5
  "author": "Fountain-UI Team",
6
6
  "description": "Incubator for Fountain-UI React components.",
@@ -17,21 +17,19 @@
17
17
  "dependencies": {
18
18
  "@emotion/react": "^11.10.0",
19
19
  "@emotion/styled": "^11.10.0",
20
- "@fountain-ui/icons": "^2.0.0-beta.6",
21
- "@fountain-ui/utils": "^2.0.0-beta.3",
20
+ "@fountain-ui/icons": "3.0.0-alpha.6",
21
+ "@fountain-ui/utils": "^3.0.0-alpha.1",
22
22
  "react-native-calendars": "1.1267.0"
23
23
  },
24
24
  "peerDependencies": {
25
- "@fountain-ui/core": "^2.0.0-beta.3",
26
- "@gorhom/bottom-sheet": "^4.1.3",
25
+ "@fountain-ui/core": "^3.0.0-alpha.1",
26
+ "@gorhom/bottom-sheet": "^4.5.0",
27
27
  "date-fns": "^2.0.0",
28
28
  "react": "^16.8.0 || ^17.0.0",
29
29
  "react-dom": "^16.8.0 || ^17.0.0",
30
30
  "react-native": "^0.63.0",
31
31
  "react-native-gesture-handler": "^2.0.0",
32
- "react-native-pager-view": "^5.0.0",
33
- "react-native-snap-carousel": "^3.9.0",
34
- "react-slick": "^0.25.0"
32
+ "react-native-pager-view": "^4.0.0"
35
33
  },
36
34
  "peerDependenciesMeta": {
37
35
  "@gorhom/bottom-sheet": {
@@ -40,28 +38,15 @@
40
38
  "react-dom": {
41
39
  "optional": true
42
40
  },
43
- "react-native": {
44
- "optional": true
45
- },
46
- "react-slick": {
47
- "optional": true
48
- },
49
41
  "react-native-pager-view": {
50
42
  "optional": true
51
- },
52
- "react-native-snap-carousel": {
53
- "optional": true
54
43
  }
55
44
  },
56
45
  "devDependencies": {
57
- "@gorhom/bottom-sheet": "4.1.3",
58
- "@types/react-native-snap-carousel": "^3.8.4",
59
- "@types/react-slick": "^0.23.5",
46
+ "@gorhom/bottom-sheet": "^4.5.0",
60
47
  "date-fns": "^2.23.0",
61
- "react-native-pager-view": "^5.4.25",
62
- "react-native-safe-area-context": "^3.3.2",
63
- "react-native-snap-carousel": "^3.9.1",
64
- "react-slick": "^0.28.1"
48
+ "react-native-pager-view": "^4.2.4",
49
+ "react-native-safe-area-context": "^4.0.0"
65
50
  },
66
51
  "react-native-builder-bob": {
67
52
  "source": "./src",
@@ -85,5 +70,5 @@
85
70
  "publishConfig": {
86
71
  "access": "public"
87
72
  },
88
- "gitHead": "319e9f913cea57c5570e8b09a9ce410b3914d4f7"
73
+ "gitHead": "a1cc03c803e63c95ee74237ffe7f809428ff0116"
89
74
  }
@@ -1,30 +1,49 @@
1
- import React from 'react';
2
- import { Platform } from 'react-native';
3
- import { useTheme } from '@fountain-ui/styles';
1
+ import React, { useCallback, useEffect, useRef, useState } from 'react';
2
+ import { Animated, LayoutChangeEvent, useWindowDimensions, ViewStyle } from 'react-native';
4
3
  import {
5
4
  BottomSheetBackdrop,
6
5
  BottomSheetBackdropProps,
7
6
  BottomSheetModal,
8
7
  BottomSheetModalProvider,
8
+ BottomSheetView,
9
9
  } from '@gorhom/bottom-sheet';
10
+ import { Column, css, ExtendedStyle, isNotAndroid12, useAnimatedValue } from '@fountain-ui/core';
11
+ import { useTheme } from '@fountain-ui/styles';
10
12
  import type BottomSheetProps from './BottomSheetProps';
11
13
  import TransparentBackdrop from './TransparentBackdrop';
14
+ import useDynamicSnapPoints from './useDynamicSnapPoints.native';
12
15
 
13
16
  const NoHandle = () => null;
14
17
 
15
18
  export default function BottomSheet(props: BottomSheetProps) {
16
19
  const {
17
20
  backdropOpacity = 0.5,
21
+ backgroundStyle: backgroundStyleProp,
22
+ borderRadius: borderRadiusProp,
18
23
  children,
24
+ enableDynamicSizing = true,
25
+ topElement,
19
26
  index,
27
+ maxHeightNormalizedRatio = 0.8,
20
28
  onChange,
21
- snapPoints,
29
+ snapPoints = [],
30
+ style: styleProp,
22
31
  } = props;
23
32
 
24
- const indexRef = React.useRef<number>(-1);
25
- const bottomSheetRef = React.useRef<BottomSheetModal | null>(null);
33
+ const indexRef = useRef<number>(-1);
34
+ const bottomSheetRef = useRef<BottomSheetModal | null>(null);
35
+
36
+ const { height: windowHeight } = useWindowDimensions();
37
+ const [topElementHeight, setTopElementHeight] = useState(0);
26
38
 
27
- const handleChange = React.useCallback((newIndex: number) => {
39
+ const maxDynamicContentSize = Math.round(windowHeight * maxHeightNormalizedRatio) - topElementHeight;
40
+
41
+ const handleTopElementLayout = (event: LayoutChangeEvent) => {
42
+ const { height } = event.nativeEvent.layout;
43
+ setTopElementHeight(height);
44
+ };
45
+
46
+ const handleChange = useCallback((newIndex: number) => {
28
47
  indexRef.current = newIndex;
29
48
 
30
49
  if (onChange) {
@@ -32,11 +51,11 @@ export default function BottomSheet(props: BottomSheetProps) {
32
51
  }
33
52
  }, [onChange]);
34
53
 
35
- const handleDismiss = React.useCallback(() => {
54
+ const handleDismiss = useCallback(() => {
36
55
  handleChange(-1);
37
56
  }, [handleChange]);
38
57
 
39
- React.useEffect(() => {
58
+ useEffect(() => {
40
59
  if (index === indexRef.current) {
41
60
  return;
42
61
  }
@@ -52,18 +71,31 @@ export default function BottomSheet(props: BottomSheetProps) {
52
71
  }, [index]);
53
72
 
54
73
  const theme = useTheme();
55
- const shadow = theme.shadow[12];
56
- const modalStyle = {
57
- backgroundColor: '#ffffff00',
58
- ...Platform.select<object>({
59
- android: shadow?.elevation,
60
- ios: shadow?.shadow,
61
- web: shadow?.boxShadow,
62
- }),
63
- };
64
- const backgroundStyle = {
65
- backgroundColor: theme.palette.paper.default,
66
- };
74
+
75
+ const borderRadius = borderRadiusProp ?? theme.shape.radius.xxl;
76
+ const backgroundStyle = css([
77
+ {
78
+ backgroundColor: theme.palette.surface.base,
79
+ borderTopLeftRadius: borderRadius,
80
+ borderTopRightRadius: borderRadius,
81
+ },
82
+ backgroundStyleProp,
83
+ ]);
84
+
85
+ const contentWrapperStyle: ViewStyle = css([
86
+ {
87
+ backgroundColor: theme.palette.surface.base,
88
+ borderTopLeftRadius: borderRadius,
89
+ borderTopRightRadius: borderRadius,
90
+ flexShrink: 1,
91
+ maxHeight: maxDynamicContentSize,
92
+ minHeight: 325,
93
+ overflow: 'hidden',
94
+ paddingBottom: theme.spacing(6),
95
+ paddingTop: theme.spacing(5.5),
96
+ },
97
+ styleProp,
98
+ ]);
67
99
 
68
100
  const isBackdropTransparent = backdropOpacity <= 0;
69
101
 
@@ -73,9 +105,34 @@ export default function BottomSheet(props: BottomSheetProps) {
73
105
  appearsOnIndex={0}
74
106
  disappearsOnIndex={-1}
75
107
  opacity={backdropOpacity}
108
+ pressBehavior={onChange ? 'close' : 'none'}
76
109
  />
77
110
  );
78
111
 
112
+ const topElementOpacity = useAnimatedValue(0);
113
+ const topElementAnimationStyle: Animated.WithAnimatedValue<ExtendedStyle> = { opacity: topElementOpacity };
114
+ const topElementLocationStyle: ExtendedStyle = {
115
+ position: 'absolute',
116
+ width: '100%',
117
+ bottom: 0,
118
+ };
119
+ const onAnimate = (fromIndex: number, toIndex: number) => {
120
+ const isVisible = toIndex > -1;
121
+
122
+ Animated.timing(topElementOpacity, {
123
+ toValue: isVisible ? 1 : 0,
124
+ duration: 0,
125
+ useNativeDriver: isNotAndroid12,
126
+ }).start();
127
+ };
128
+
129
+ const {
130
+ animatedHandleHeight,
131
+ animatedSnapPoints,
132
+ animatedContentHeight,
133
+ handleContentLayout,
134
+ } = useDynamicSnapPoints(snapPoints);
135
+
79
136
  return (
80
137
  <BottomSheetModalProvider>
81
138
  <BottomSheetModal
@@ -87,10 +144,32 @@ export default function BottomSheet(props: BottomSheetProps) {
87
144
  onChange={handleChange}
88
145
  onDismiss={handleDismiss}
89
146
  ref={bottomSheetRef}
90
- snapPoints={snapPoints}
91
- style={modalStyle}
147
+ enablePanDownToClose={Boolean(onChange)}
148
+ enableDynamicSizing={enableDynamicSizing}
149
+ maxDynamicContentSize={maxDynamicContentSize}
150
+ detached={Boolean(topElement)}
151
+ onAnimate={topElement ? onAnimate : undefined}
152
+ snapPoints={animatedSnapPoints}
153
+ handleHeight={animatedHandleHeight}
154
+ contentHeight={animatedContentHeight}
92
155
  >
93
- {children}
156
+ {topElement ? (
157
+ <Animated.View style={topElementAnimationStyle}>
158
+ <Column
159
+ onLayout={handleTopElementLayout}
160
+ style={topElementLocationStyle}
161
+ >
162
+ {topElement}
163
+ </Column>
164
+ </Animated.View>
165
+ ) : null}
166
+
167
+ <BottomSheetView
168
+ onLayout={handleContentLayout}
169
+ style={contentWrapperStyle}
170
+ >
171
+ {children}
172
+ </BottomSheetView>
94
173
  </BottomSheetModal>
95
174
  </BottomSheetModalProvider>
96
175
  );
@@ -1,5 +1,5 @@
1
1
  import React from 'react';
2
- import type { ComponentProps } from '@fountain-ui/core';
2
+ import type { ComponentProps, ExtendedStyle } from '@fountain-ui/core';
3
3
 
4
4
  export default interface BottomSheetProps extends ComponentProps<{
5
5
  /**
@@ -8,16 +8,44 @@ export default interface BottomSheetProps extends ComponentProps<{
8
8
  */
9
9
  backdropOpacity?: number;
10
10
 
11
+ /**
12
+ * View style to be applied to the background component. (only native)
13
+ */
14
+ backgroundStyle?: ExtendedStyle | ExtendedStyle[];
15
+
16
+ /**
17
+ * Border radius for bottom sheet
18
+ */
19
+ borderRadius?: number;
20
+
11
21
  /**
12
22
  * BottomSheet children, usually the included sub-components.
13
23
  */
14
24
  children?: React.ReactNode;
15
25
 
26
+ /**
27
+ * Enable dynamic sizing for content size.
28
+ * @default true
29
+ */
30
+ enableDynamicSizing?: boolean;
31
+
32
+ /**
33
+ * Top element for displaying additional information on the bottom sheet.
34
+ */
35
+ topElement?: React.ReactNode;
36
+
16
37
  /**
17
38
  * Snap index. You could also provide -1 to bottom sheet in closed state.
18
39
  */
19
40
  index: number;
20
41
 
42
+ /**
43
+ * Maximum height(normalized value) of dialog
44
+ * ex. 30% => 0.3 / 90% => 0.9
45
+ * @default 0.8
46
+ */
47
+ maxHeightNormalizedRatio?: number;
48
+
21
49
  /**
22
50
  * Callback fired when the index is changed.
23
51
  * Important! Use memoized value.
@@ -27,6 +55,13 @@ export default interface BottomSheetProps extends ComponentProps<{
27
55
  /**
28
56
  * Points for the bottom sheet to snap to, points should be sorted from bottom to top.
29
57
  * Important! Use memoized value.
58
+ * Only number type or string type(~% format) can be used.
59
+ * @default []
60
+ */
61
+ snapPoints?: Array<number | string>;
62
+
63
+ /**
64
+ * View style to be applied to the content area.
30
65
  */
31
- snapPoints: Array<number>;
66
+ style?: ExtendedStyle | ExtendedStyle[];
32
67
  }> {}