@fountain-ui/lab 2.0.0-beta.4 → 2.0.0-beta.40

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/build/commonjs/AnimatedY/AnimatedY.js +10 -14
  2. package/build/commonjs/AnimatedY/AnimatedY.js.map +1 -1
  3. package/build/commonjs/AnimatedY/AnimatedYProps.js.map +1 -1
  4. package/build/commonjs/AnimatedY/index.js.map +1 -1
  5. package/build/commonjs/BottomSheet/BottomSheet.js +177 -0
  6. package/build/commonjs/BottomSheet/BottomSheet.js.map +1 -0
  7. package/build/commonjs/BottomSheet/BottomSheetNative.js +5 -3
  8. package/build/commonjs/BottomSheet/BottomSheetNative.js.map +1 -1
  9. package/build/commonjs/BottomSheet/BottomSheetProps.js.map +1 -1
  10. package/build/commonjs/BottomSheet/BottomSheetWeb.js +19 -7
  11. package/build/commonjs/BottomSheet/BottomSheetWeb.js.map +1 -1
  12. package/build/commonjs/BottomSheet/TransparentBackdrop.js +1 -1
  13. package/build/commonjs/BottomSheet/TransparentBackdrop.js.map +1 -1
  14. package/build/commonjs/BottomSheet/index.js.map +1 -1
  15. package/build/commonjs/BottomSheet/index.native.js.map +1 -1
  16. package/build/commonjs/BottomSheet/useDynamicSnapPoints.js +49 -0
  17. package/build/commonjs/BottomSheet/useDynamicSnapPoints.js.map +1 -0
  18. package/build/commonjs/Carousel/Carousel.js +130 -0
  19. package/build/commonjs/Carousel/Carousel.js.map +1 -0
  20. package/build/commonjs/Carousel/CarouselProps.js.map +1 -1
  21. package/build/commonjs/Carousel/animation/animationUtils.js +9 -0
  22. package/build/commonjs/Carousel/animation/animationUtils.js.map +1 -0
  23. package/build/commonjs/Carousel/animation/createDefaultItemStyle.js +15 -0
  24. package/build/commonjs/Carousel/animation/createDefaultItemStyle.js.map +1 -0
  25. package/build/commonjs/Carousel/animation/createDefaultScrollAnimation.js +20 -0
  26. package/build/commonjs/Carousel/animation/createDefaultScrollAnimation.js.map +1 -0
  27. package/build/commonjs/Carousel/animation/index.js +40 -0
  28. package/build/commonjs/Carousel/animation/index.js.map +1 -0
  29. package/build/commonjs/Carousel/animation/normalItemStyleFactory.js +27 -0
  30. package/build/commonjs/Carousel/animation/normalItemStyleFactory.js.map +1 -0
  31. package/build/commonjs/Carousel/animation/parallaxItemStyleFactory.js +65 -0
  32. package/build/commonjs/Carousel/animation/parallaxItemStyleFactory.js.map +1 -0
  33. package/build/commonjs/Carousel/components/InternalContext.js +29 -0
  34. package/build/commonjs/Carousel/components/InternalContext.js.map +1 -0
  35. package/build/commonjs/Carousel/components/ItemView.js +66 -0
  36. package/build/commonjs/Carousel/components/ItemView.js.map +1 -0
  37. package/build/commonjs/Carousel/components/RootView.js +86 -0
  38. package/build/commonjs/Carousel/components/RootView.js.map +1 -0
  39. package/build/commonjs/Carousel/components/ScrollViewGesture.js +82 -0
  40. package/build/commonjs/Carousel/components/ScrollViewGesture.js.map +1 -0
  41. package/build/commonjs/Carousel/components/index.js +40 -0
  42. package/build/commonjs/Carousel/components/index.js.map +1 -0
  43. package/build/commonjs/Carousel/components/useItemInterpolation.js +65 -0
  44. package/build/commonjs/Carousel/components/useItemInterpolation.js.map +1 -0
  45. package/build/commonjs/Carousel/hooks/index.js +48 -0
  46. package/build/commonjs/Carousel/hooks/index.js.map +1 -0
  47. package/build/commonjs/Carousel/hooks/useAutoplayController.js +58 -0
  48. package/build/commonjs/Carousel/hooks/useAutoplayController.js.map +1 -0
  49. package/build/commonjs/Carousel/hooks/useIndexController.js +55 -0
  50. package/build/commonjs/Carousel/hooks/useIndexController.js.map +1 -0
  51. package/build/commonjs/Carousel/hooks/useItemVisibilityStore.js +95 -0
  52. package/build/commonjs/Carousel/hooks/useItemVisibilityStore.js.map +1 -0
  53. package/build/commonjs/Carousel/hooks/useLoopedData.js +33 -0
  54. package/build/commonjs/Carousel/hooks/useLoopedData.js.map +1 -0
  55. package/build/commonjs/Carousel/hooks/usePagingAnimator.js +202 -0
  56. package/build/commonjs/Carousel/hooks/usePagingAnimator.js.map +1 -0
  57. package/build/commonjs/Carousel/index.js +16 -2
  58. package/build/commonjs/Carousel/index.js.map +1 -1
  59. package/build/commonjs/Carousel/tick.js +16 -0
  60. package/build/commonjs/Carousel/tick.js.map +1 -0
  61. package/build/commonjs/Carousel/types.js +8 -0
  62. package/build/commonjs/Carousel/types.js.map +1 -0
  63. package/build/commonjs/ComicViewer/ComicViewer.js +203 -86
  64. package/build/commonjs/ComicViewer/ComicViewer.js.map +1 -1
  65. package/build/commonjs/ComicViewer/ComicViewerProps.js.map +1 -1
  66. package/build/commonjs/ComicViewer/EncodedTile.js +10 -0
  67. package/build/commonjs/ComicViewer/EncodedTile.js.map +1 -0
  68. package/build/commonjs/ComicViewer/ReloadButton.js +48 -0
  69. package/build/commonjs/ComicViewer/ReloadButton.js.map +1 -0
  70. package/build/commonjs/ComicViewer/ViewerItem.js +49 -58
  71. package/build/commonjs/ComicViewer/ViewerItem.js.map +1 -1
  72. package/build/commonjs/ComicViewer/index.js.map +1 -1
  73. package/build/commonjs/DateTimePicker/DateTimePicker.js +2 -2
  74. package/build/commonjs/DateTimePicker/DateTimePicker.js.map +1 -1
  75. package/build/commonjs/DateTimePicker/DateTimePickerProps.js.map +1 -1
  76. package/build/commonjs/DateTimePicker/DateTimePickerProvider.js.map +1 -1
  77. package/build/commonjs/DateTimePicker/YearPicker.js +21 -17
  78. package/build/commonjs/DateTimePicker/YearPicker.js.map +1 -1
  79. package/build/commonjs/DateTimePicker/index.js +4 -4
  80. package/build/commonjs/DateTimePicker/index.js.map +1 -1
  81. package/build/commonjs/DateTimePicker/utils.js +2 -1
  82. package/build/commonjs/DateTimePicker/utils.js.map +1 -1
  83. package/build/commonjs/FlipCard/FlipCard.js +7 -13
  84. package/build/commonjs/FlipCard/FlipCard.js.map +1 -1
  85. package/build/commonjs/FlipCard/FlipCardProps.js.map +1 -1
  86. package/build/commonjs/FlipCard/index.js.map +1 -1
  87. package/build/commonjs/StatusBarProvider/Provider.js +1 -1
  88. package/build/commonjs/StatusBarProvider/Provider.js.map +1 -1
  89. package/build/commonjs/StatusBarProvider/StatusBarProvider.js.map +1 -1
  90. package/build/commonjs/StatusBarProvider/StatusBarProviderProps.js.map +1 -1
  91. package/build/commonjs/StatusBarProvider/index.js.map +1 -1
  92. package/build/commonjs/ViewPager/FluxContext.js +13 -0
  93. package/build/commonjs/ViewPager/FluxContext.js.map +1 -0
  94. package/build/commonjs/ViewPager/InternalContext.js +17 -0
  95. package/build/commonjs/ViewPager/InternalContext.js.map +1 -0
  96. package/build/commonjs/ViewPager/PageStateContext.js +16 -0
  97. package/build/commonjs/ViewPager/PageStateContext.js.map +1 -0
  98. package/build/commonjs/ViewPager/ViewPager.js +81 -0
  99. package/build/commonjs/ViewPager/ViewPager.js.map +1 -0
  100. package/build/commonjs/ViewPager/ViewPager.native.js +150 -0
  101. package/build/commonjs/ViewPager/ViewPager.native.js.map +1 -0
  102. package/build/commonjs/ViewPager/ViewPagerProps.js.map +1 -1
  103. package/build/commonjs/ViewPager/components/ChildrenMemoizedPage.js +122 -0
  104. package/build/commonjs/ViewPager/components/ChildrenMemoizedPage.js.map +1 -0
  105. package/build/commonjs/ViewPager/components/FluxStoreProvider.js +37 -0
  106. package/build/commonjs/ViewPager/components/FluxStoreProvider.js.map +1 -0
  107. package/build/commonjs/ViewPager/components/index.js +24 -0
  108. package/build/commonjs/ViewPager/components/index.js.map +1 -0
  109. package/build/commonjs/ViewPager/hooks/index.js +64 -0
  110. package/build/commonjs/ViewPager/hooks/index.js.map +1 -0
  111. package/build/commonjs/ViewPager/hooks/useDispatch.js +22 -0
  112. package/build/commonjs/ViewPager/hooks/useDispatch.js.map +1 -0
  113. package/build/commonjs/ViewPager/hooks/useEagerState.js +24 -0
  114. package/build/commonjs/ViewPager/hooks/useEagerState.js.map +1 -0
  115. package/build/commonjs/ViewPager/hooks/useForceRender.js +16 -0
  116. package/build/commonjs/ViewPager/hooks/useForceRender.js.map +1 -0
  117. package/build/commonjs/ViewPager/hooks/useLazyState.js +45 -0
  118. package/build/commonjs/ViewPager/hooks/useLazyState.js.map +1 -0
  119. package/build/commonjs/ViewPager/hooks/usePageStore.js +35 -0
  120. package/build/commonjs/ViewPager/hooks/usePageStore.js.map +1 -0
  121. package/build/commonjs/ViewPager/hooks/useStore.js +26 -0
  122. package/build/commonjs/ViewPager/hooks/useStore.js.map +1 -0
  123. package/build/commonjs/ViewPager/hooks/useViewPagerPageState.js +19 -0
  124. package/build/commonjs/ViewPager/hooks/useViewPagerPageState.js.map +1 -0
  125. package/build/commonjs/ViewPager/index.js +42 -2
  126. package/build/commonjs/ViewPager/index.js.map +1 -1
  127. package/build/commonjs/ViewPager/types.js +2 -0
  128. package/build/commonjs/ViewPager/types.js.map +1 -0
  129. package/build/commonjs/ViewPager/utils.js +12 -43
  130. package/build/commonjs/ViewPager/utils.js.map +1 -1
  131. package/build/commonjs/ViewabilityTrackerView/Viewability.js +2 -0
  132. package/build/commonjs/ViewabilityTrackerView/Viewability.js.map +1 -0
  133. package/build/commonjs/ViewabilityTrackerView/ViewabilityTrackerView.js +45 -0
  134. package/build/commonjs/ViewabilityTrackerView/ViewabilityTrackerView.js.map +1 -0
  135. package/build/commonjs/ViewabilityTrackerView/ViewabilityTrackerViewProps.js +2 -0
  136. package/build/commonjs/ViewabilityTrackerView/ViewabilityTrackerViewProps.js.map +1 -0
  137. package/build/commonjs/{Carousel/index.native.js → ViewabilityTrackerView/index.js} +3 -3
  138. package/build/commonjs/ViewabilityTrackerView/index.js.map +1 -0
  139. package/build/commonjs/ViewabilityTrackerView/measureViewability.js +42 -0
  140. package/build/commonjs/ViewabilityTrackerView/measureViewability.js.map +1 -0
  141. package/build/commonjs/ViewabilityTrackerView/useViewabilityTracker.js +88 -0
  142. package/build/commonjs/ViewabilityTrackerView/useViewabilityTracker.js.map +1 -0
  143. package/build/commonjs/hooks/index.js +16 -0
  144. package/build/commonjs/hooks/index.js.map +1 -1
  145. package/build/commonjs/hooks/useAppbarStyles.js.map +1 -1
  146. package/build/commonjs/hooks/useDeferredExecutor.js +45 -0
  147. package/build/commonjs/hooks/useDeferredExecutor.js.map +1 -0
  148. package/build/commonjs/hooks/useElevationStyle.js.map +1 -1
  149. package/build/commonjs/hooks/useHeight.js +5 -4
  150. package/build/commonjs/hooks/useHeight.js.map +1 -1
  151. package/build/commonjs/hooks/useIsMounted.js +22 -0
  152. package/build/commonjs/hooks/useIsMounted.js.map +1 -0
  153. package/build/commonjs/hooks/useUnstableCollapsibleAppBar.js +58 -61
  154. package/build/commonjs/hooks/useUnstableCollapsibleAppBar.js.map +1 -1
  155. package/build/commonjs/hooks/useUnstableToggleDisplayStyle.js +9 -11
  156. package/build/commonjs/hooks/useUnstableToggleDisplayStyle.js.map +1 -1
  157. package/build/commonjs/index.js +28 -7
  158. package/build/commonjs/index.js.map +1 -1
  159. package/build/module/AnimatedY/AnimatedY.js +11 -10
  160. package/build/module/AnimatedY/AnimatedY.js.map +1 -1
  161. package/build/module/AnimatedY/AnimatedYProps.js.map +1 -1
  162. package/build/module/AnimatedY/index.js.map +1 -1
  163. package/build/module/BottomSheet/BottomSheet.js +161 -0
  164. package/build/module/BottomSheet/BottomSheet.js.map +1 -0
  165. package/build/module/BottomSheet/BottomSheetNative.js +5 -3
  166. package/build/module/BottomSheet/BottomSheetNative.js.map +1 -1
  167. package/build/module/BottomSheet/BottomSheetProps.js.map +1 -1
  168. package/build/module/BottomSheet/BottomSheetWeb.js +18 -7
  169. package/build/module/BottomSheet/BottomSheetWeb.js.map +1 -1
  170. package/build/module/BottomSheet/TransparentBackdrop.js +1 -1
  171. package/build/module/BottomSheet/TransparentBackdrop.js.map +1 -1
  172. package/build/module/BottomSheet/index.js.map +1 -1
  173. package/build/module/BottomSheet/index.native.js.map +1 -1
  174. package/build/module/BottomSheet/useDynamicSnapPoints.js +41 -0
  175. package/build/module/BottomSheet/useDynamicSnapPoints.js.map +1 -0
  176. package/build/module/Carousel/Carousel.js +109 -0
  177. package/build/module/Carousel/Carousel.js.map +1 -0
  178. package/build/module/Carousel/CarouselProps.js.map +1 -1
  179. package/build/module/Carousel/animation/animationUtils.js +2 -0
  180. package/build/module/Carousel/animation/animationUtils.js.map +1 -0
  181. package/build/module/Carousel/animation/createDefaultItemStyle.js +3 -0
  182. package/build/module/Carousel/animation/createDefaultItemStyle.js.map +1 -0
  183. package/build/module/Carousel/animation/createDefaultScrollAnimation.js +11 -0
  184. package/build/module/Carousel/animation/createDefaultScrollAnimation.js.map +1 -0
  185. package/build/module/Carousel/animation/index.js +5 -0
  186. package/build/module/Carousel/animation/index.js.map +1 -0
  187. package/build/module/Carousel/animation/normalItemStyleFactory.js +18 -0
  188. package/build/module/Carousel/animation/normalItemStyleFactory.js.map +1 -0
  189. package/build/module/Carousel/animation/parallaxItemStyleFactory.js +55 -0
  190. package/build/module/Carousel/animation/parallaxItemStyleFactory.js.map +1 -0
  191. package/build/module/Carousel/components/InternalContext.js +19 -0
  192. package/build/module/Carousel/components/InternalContext.js.map +1 -0
  193. package/build/module/Carousel/components/ItemView.js +46 -0
  194. package/build/module/Carousel/components/ItemView.js.map +1 -0
  195. package/build/module/Carousel/components/RootView.js +65 -0
  196. package/build/module/Carousel/components/RootView.js.map +1 -0
  197. package/build/module/Carousel/components/ScrollViewGesture.js +68 -0
  198. package/build/module/Carousel/components/ScrollViewGesture.js.map +1 -0
  199. package/build/module/Carousel/components/index.js +5 -0
  200. package/build/module/Carousel/components/index.js.map +1 -0
  201. package/build/module/Carousel/components/useItemInterpolation.js +51 -0
  202. package/build/module/Carousel/components/useItemInterpolation.js.map +1 -0
  203. package/build/module/Carousel/hooks/index.js +6 -0
  204. package/build/module/Carousel/hooks/index.js.map +1 -0
  205. package/build/module/Carousel/hooks/useAutoplayController.js +48 -0
  206. package/build/module/Carousel/hooks/useAutoplayController.js.map +1 -0
  207. package/build/module/Carousel/hooks/useIndexController.js +44 -0
  208. package/build/module/Carousel/hooks/useIndexController.js.map +1 -0
  209. package/build/module/Carousel/hooks/useItemVisibilityStore.js +86 -0
  210. package/build/module/Carousel/hooks/useItemVisibilityStore.js.map +1 -0
  211. package/build/module/Carousel/hooks/useLoopedData.js +24 -0
  212. package/build/module/Carousel/hooks/useLoopedData.js.map +1 -0
  213. package/build/module/Carousel/hooks/usePagingAnimator.js +192 -0
  214. package/build/module/Carousel/hooks/usePagingAnimator.js.map +1 -0
  215. package/build/module/Carousel/index.js +2 -1
  216. package/build/module/Carousel/index.js.map +1 -1
  217. package/build/module/Carousel/tick.js +6 -0
  218. package/build/module/Carousel/tick.js.map +1 -0
  219. package/build/module/Carousel/types.js +4 -0
  220. package/build/module/Carousel/types.js.map +1 -0
  221. package/build/module/ComicViewer/ComicViewer.js +201 -86
  222. package/build/module/ComicViewer/ComicViewer.js.map +1 -1
  223. package/build/module/ComicViewer/ComicViewerProps.js.map +1 -1
  224. package/build/module/ComicViewer/EncodedTile.js +3 -0
  225. package/build/module/ComicViewer/EncodedTile.js.map +1 -0
  226. package/build/module/ComicViewer/ReloadButton.js +33 -0
  227. package/build/module/ComicViewer/ReloadButton.js.map +1 -0
  228. package/build/module/ComicViewer/ViewerItem.js +49 -59
  229. package/build/module/ComicViewer/ViewerItem.js.map +1 -1
  230. package/build/module/ComicViewer/index.js.map +1 -1
  231. package/build/module/DateTimePicker/DateTimePicker.js +2 -2
  232. package/build/module/DateTimePicker/DateTimePicker.js.map +1 -1
  233. package/build/module/DateTimePicker/DateTimePickerProps.js.map +1 -1
  234. package/build/module/DateTimePicker/DateTimePickerProvider.js.map +1 -1
  235. package/build/module/DateTimePicker/YearPicker.js +21 -17
  236. package/build/module/DateTimePicker/YearPicker.js.map +1 -1
  237. package/build/module/DateTimePicker/index.js.map +1 -1
  238. package/build/module/DateTimePicker/utils.js +2 -1
  239. package/build/module/DateTimePicker/utils.js.map +1 -1
  240. package/build/module/FlipCard/FlipCard.js +7 -7
  241. package/build/module/FlipCard/FlipCard.js.map +1 -1
  242. package/build/module/FlipCard/FlipCardProps.js.map +1 -1
  243. package/build/module/FlipCard/index.js.map +1 -1
  244. package/build/module/StatusBarProvider/Provider.js.map +1 -1
  245. package/build/module/StatusBarProvider/StatusBarProvider.js.map +1 -1
  246. package/build/module/StatusBarProvider/StatusBarProviderProps.js.map +1 -1
  247. package/build/module/StatusBarProvider/index.js.map +1 -1
  248. package/build/module/ViewPager/FluxContext.js +4 -0
  249. package/build/module/ViewPager/FluxContext.js.map +1 -0
  250. package/build/module/ViewPager/InternalContext.js +7 -0
  251. package/build/module/ViewPager/InternalContext.js.map +1 -0
  252. package/build/module/ViewPager/PageStateContext.js +7 -0
  253. package/build/module/ViewPager/PageStateContext.js.map +1 -0
  254. package/build/module/ViewPager/ViewPager.js +57 -0
  255. package/build/module/ViewPager/ViewPager.js.map +1 -0
  256. package/build/module/ViewPager/ViewPager.native.js +127 -0
  257. package/build/module/ViewPager/ViewPager.native.js.map +1 -0
  258. package/build/module/ViewPager/ViewPagerProps.js.map +1 -1
  259. package/build/module/ViewPager/components/ChildrenMemoizedPage.js +101 -0
  260. package/build/module/ViewPager/components/ChildrenMemoizedPage.js.map +1 -0
  261. package/build/module/ViewPager/components/FluxStoreProvider.js +20 -0
  262. package/build/module/ViewPager/components/FluxStoreProvider.js.map +1 -0
  263. package/build/module/ViewPager/components/index.js +3 -0
  264. package/build/module/ViewPager/components/index.js.map +1 -0
  265. package/build/module/ViewPager/hooks/index.js +8 -0
  266. package/build/module/ViewPager/hooks/index.js.map +1 -0
  267. package/build/module/ViewPager/hooks/useDispatch.js +10 -0
  268. package/build/module/ViewPager/hooks/useDispatch.js.map +1 -0
  269. package/build/module/ViewPager/hooks/useEagerState.js +12 -0
  270. package/build/module/ViewPager/hooks/useEagerState.js.map +1 -0
  271. package/build/module/ViewPager/hooks/useForceRender.js +7 -0
  272. package/build/module/ViewPager/hooks/useForceRender.js.map +1 -0
  273. package/build/module/ViewPager/hooks/useLazyState.js +30 -0
  274. package/build/module/ViewPager/hooks/useLazyState.js.map +1 -0
  275. package/build/module/ViewPager/hooks/usePageStore.js +25 -0
  276. package/build/module/ViewPager/hooks/usePageStore.js.map +1 -0
  277. package/build/module/ViewPager/hooks/useStore.js +14 -0
  278. package/build/module/ViewPager/hooks/useStore.js.map +1 -0
  279. package/build/module/ViewPager/hooks/useViewPagerPageState.js +7 -0
  280. package/build/module/ViewPager/hooks/useViewPagerPageState.js.map +1 -0
  281. package/build/module/ViewPager/index.js +3 -1
  282. package/build/module/ViewPager/index.js.map +1 -1
  283. package/build/module/ViewPager/types.js +2 -0
  284. package/build/module/ViewPager/types.js.map +1 -0
  285. package/build/module/ViewPager/utils.js +6 -33
  286. package/build/module/ViewPager/utils.js.map +1 -1
  287. package/build/module/ViewabilityTrackerView/Viewability.js +2 -0
  288. package/build/module/ViewabilityTrackerView/Viewability.js.map +1 -0
  289. package/build/module/ViewabilityTrackerView/ViewabilityTrackerView.js +28 -0
  290. package/build/module/ViewabilityTrackerView/ViewabilityTrackerView.js.map +1 -0
  291. package/build/module/ViewabilityTrackerView/ViewabilityTrackerViewProps.js +2 -0
  292. package/build/module/ViewabilityTrackerView/ViewabilityTrackerViewProps.js.map +1 -0
  293. package/build/module/ViewabilityTrackerView/index.js +2 -0
  294. package/build/module/ViewabilityTrackerView/index.js.map +1 -0
  295. package/build/module/ViewabilityTrackerView/measureViewability.js +34 -0
  296. package/build/module/ViewabilityTrackerView/measureViewability.js.map +1 -0
  297. package/build/module/ViewabilityTrackerView/useViewabilityTracker.js +73 -0
  298. package/build/module/ViewabilityTrackerView/useViewabilityTracker.js.map +1 -0
  299. package/build/module/hooks/index.js +2 -0
  300. package/build/module/hooks/index.js.map +1 -1
  301. package/build/module/hooks/useAppbarStyles.js.map +1 -1
  302. package/build/module/hooks/useDeferredExecutor.js +33 -0
  303. package/build/module/hooks/useDeferredExecutor.js.map +1 -0
  304. package/build/module/hooks/useElevationStyle.js.map +1 -1
  305. package/build/module/hooks/useHeight.js +4 -3
  306. package/build/module/hooks/useHeight.js.map +1 -1
  307. package/build/module/hooks/useIsMounted.js +13 -0
  308. package/build/module/hooks/useIsMounted.js.map +1 -0
  309. package/build/module/hooks/useUnstableCollapsibleAppBar.js +58 -45
  310. package/build/module/hooks/useUnstableCollapsibleAppBar.js.map +1 -1
  311. package/build/module/hooks/useUnstableToggleDisplayStyle.js +9 -7
  312. package/build/module/hooks/useUnstableToggleDisplayStyle.js.map +1 -1
  313. package/build/module/index.js +2 -0
  314. package/build/module/index.js.map +1 -1
  315. package/build/typescript/AnimatedY/AnimatedY.d.ts +0 -1
  316. package/build/typescript/BottomSheet/BottomSheet.d.ts +2 -0
  317. package/build/typescript/BottomSheet/BottomSheetNative.d.ts +0 -1
  318. package/build/typescript/BottomSheet/BottomSheetProps.d.ts +6 -1
  319. package/build/typescript/BottomSheet/BottomSheetWeb.d.ts +0 -1
  320. package/build/typescript/BottomSheet/TransparentBackdrop.d.ts +0 -1
  321. package/build/typescript/BottomSheet/useDynamicSnapPoints.d.ts +11 -0
  322. package/build/typescript/Carousel/Carousel.d.ts +5 -0
  323. package/build/typescript/Carousel/CarouselProps.d.ts +33 -48
  324. package/build/typescript/Carousel/animation/animationUtils.d.ts +1 -0
  325. package/build/typescript/Carousel/animation/createDefaultItemStyle.d.ts +2 -0
  326. package/build/typescript/Carousel/animation/createDefaultScrollAnimation.d.ts +2 -0
  327. package/build/typescript/Carousel/animation/index.d.ts +4 -0
  328. package/build/typescript/Carousel/animation/normalItemStyleFactory.d.ts +2 -0
  329. package/build/typescript/Carousel/animation/parallaxItemStyleFactory.d.ts +9 -0
  330. package/build/typescript/Carousel/components/InternalContext.d.ts +14 -0
  331. package/build/typescript/Carousel/components/ItemView.d.ts +9 -0
  332. package/build/typescript/Carousel/components/RootView.d.ts +16 -0
  333. package/build/typescript/Carousel/components/ScrollViewGesture.d.ts +12 -0
  334. package/build/typescript/Carousel/components/index.d.ts +4 -0
  335. package/build/typescript/Carousel/components/useItemInterpolation.d.ts +2 -0
  336. package/build/typescript/Carousel/hooks/index.d.ts +5 -0
  337. package/build/typescript/Carousel/hooks/useAutoplayController.d.ts +7 -0
  338. package/build/typescript/Carousel/hooks/useIndexController.d.ts +10 -0
  339. package/build/typescript/Carousel/hooks/useItemVisibilityStore.d.ts +7 -0
  340. package/build/typescript/Carousel/hooks/useLoopedData.d.ts +1 -0
  341. package/build/typescript/Carousel/hooks/usePagingAnimator.d.ts +17 -0
  342. package/build/typescript/Carousel/index.d.ts +3 -1
  343. package/build/typescript/Carousel/tick.d.ts +2 -0
  344. package/build/typescript/Carousel/types.d.ts +91 -0
  345. package/build/typescript/ComicViewer/ComicViewer.d.ts +1 -2
  346. package/build/typescript/ComicViewer/ComicViewerProps.d.ts +39 -44
  347. package/build/typescript/ComicViewer/EncodedTile.d.ts +2 -0
  348. package/build/typescript/ComicViewer/ReloadButton.d.ts +6 -0
  349. package/build/typescript/ComicViewer/ViewerItem.d.ts +37 -7
  350. package/build/typescript/ComicViewer/index.d.ts +2 -2
  351. package/build/typescript/DateTimePicker/DateTimePicker.d.ts +0 -1
  352. package/build/typescript/DateTimePicker/YearPicker.d.ts +0 -1
  353. package/build/typescript/FlipCard/FlipCard.d.ts +0 -1
  354. package/build/typescript/StatusBarProvider/StatusBarProvider.d.ts +0 -1
  355. package/build/typescript/ViewPager/FluxContext.d.ts +5 -0
  356. package/build/typescript/ViewPager/InternalContext.d.ts +7 -0
  357. package/build/typescript/ViewPager/PageStateContext.d.ts +6 -0
  358. package/build/typescript/ViewPager/ViewPager.d.ts +5 -0
  359. package/build/typescript/ViewPager/ViewPager.native.d.ts +5 -0
  360. package/build/typescript/ViewPager/ViewPagerProps.d.ts +18 -29
  361. package/build/typescript/ViewPager/components/ChildrenMemoizedPage.d.ts +14 -0
  362. package/build/typescript/ViewPager/components/FluxStoreProvider.d.ts +6 -0
  363. package/build/typescript/ViewPager/components/index.d.ts +2 -0
  364. package/build/typescript/ViewPager/hooks/index.d.ts +7 -0
  365. package/build/typescript/ViewPager/hooks/useDispatch.d.ts +2 -0
  366. package/build/typescript/ViewPager/hooks/useEagerState.d.ts +1 -0
  367. package/build/typescript/ViewPager/hooks/useForceRender.d.ts +2 -0
  368. package/build/typescript/ViewPager/hooks/useLazyState.d.ts +2 -0
  369. package/build/typescript/ViewPager/hooks/usePageStore.d.ts +2 -0
  370. package/build/typescript/ViewPager/hooks/useStore.d.ts +2 -0
  371. package/build/typescript/ViewPager/hooks/useViewPagerPageState.d.ts +1 -0
  372. package/build/typescript/ViewPager/index.d.ts +4 -1
  373. package/build/typescript/ViewPager/types.d.ts +12 -0
  374. package/build/typescript/ViewPager/utils.d.ts +5 -20
  375. package/build/typescript/ViewabilityTrackerView/Viewability.d.ts +3 -0
  376. package/build/typescript/ViewabilityTrackerView/ViewabilityTrackerView.d.ts +2 -0
  377. package/build/typescript/ViewabilityTrackerView/ViewabilityTrackerViewProps.d.ts +22 -0
  378. package/build/typescript/ViewabilityTrackerView/index.d.ts +2 -0
  379. package/build/typescript/ViewabilityTrackerView/measureViewability.d.ts +11 -0
  380. package/build/typescript/ViewabilityTrackerView/useViewabilityTracker.d.ts +11 -0
  381. package/build/typescript/hooks/index.d.ts +2 -0
  382. package/build/typescript/hooks/useDeferredExecutor.d.ts +11 -0
  383. package/build/typescript/hooks/useIsMounted.d.ts +4 -0
  384. package/build/typescript/hooks/useUnstableCollapsibleAppBar.d.ts +2 -3
  385. package/build/typescript/hooks/useUnstableToggleDisplayStyle.d.ts +2 -2
  386. package/build/typescript/index.d.ts +2 -0
  387. package/package.json +11 -25
  388. package/src/AnimatedY/AnimatedY.tsx +13 -10
  389. package/src/BottomSheet/BottomSheet.tsx +184 -0
  390. package/src/BottomSheet/BottomSheetNative.tsx +2 -0
  391. package/src/BottomSheet/BottomSheetProps.ts +7 -1
  392. package/src/BottomSheet/BottomSheetWeb.tsx +18 -5
  393. package/src/BottomSheet/useDynamicSnapPoints.ts +52 -0
  394. package/src/Carousel/Carousel.tsx +135 -0
  395. package/src/Carousel/CarouselProps.ts +42 -53
  396. package/src/Carousel/animation/animationUtils.ts +1 -0
  397. package/src/Carousel/animation/createDefaultItemStyle.ts +3 -0
  398. package/src/Carousel/animation/createDefaultScrollAnimation.ts +13 -0
  399. package/src/Carousel/animation/index.ts +4 -0
  400. package/src/Carousel/animation/normalItemStyleFactory.ts +19 -0
  401. package/src/Carousel/animation/parallaxItemStyleFactory.ts +79 -0
  402. package/src/Carousel/components/InternalContext.ts +33 -0
  403. package/src/Carousel/components/ItemView.tsx +66 -0
  404. package/src/Carousel/components/RootView.tsx +79 -0
  405. package/src/Carousel/components/ScrollViewGesture.tsx +92 -0
  406. package/src/Carousel/components/index.ts +4 -0
  407. package/src/Carousel/components/useItemInterpolation.ts +107 -0
  408. package/src/Carousel/hooks/index.ts +5 -0
  409. package/src/Carousel/hooks/useAutoplayController.ts +57 -0
  410. package/src/Carousel/hooks/useIndexController.tsx +57 -0
  411. package/src/Carousel/hooks/useItemVisibilityStore.ts +107 -0
  412. package/src/Carousel/hooks/useLoopedData.ts +26 -0
  413. package/src/Carousel/hooks/usePagingAnimator.ts +255 -0
  414. package/src/Carousel/index.ts +4 -2
  415. package/src/Carousel/tick.ts +6 -0
  416. package/src/Carousel/types.ts +114 -0
  417. package/src/ComicViewer/ComicViewer.tsx +222 -93
  418. package/src/ComicViewer/ComicViewerProps.ts +42 -48
  419. package/src/ComicViewer/EncodedTile.ts +3 -0
  420. package/src/ComicViewer/ReloadButton.tsx +36 -0
  421. package/src/ComicViewer/ViewerItem.tsx +91 -63
  422. package/src/ComicViewer/index.ts +2 -2
  423. package/src/DateTimePicker/DateTimePicker.tsx +2 -2
  424. package/src/FlipCard/FlipCard.tsx +8 -8
  425. package/src/ViewPager/FluxContext.ts +8 -0
  426. package/src/ViewPager/InternalContext.ts +13 -0
  427. package/src/ViewPager/PageStateContext.ts +11 -0
  428. package/src/ViewPager/ViewPager.native.tsx +150 -0
  429. package/src/ViewPager/ViewPager.tsx +69 -0
  430. package/src/ViewPager/ViewPagerProps.ts +20 -35
  431. package/src/ViewPager/components/ChildrenMemoizedPage.tsx +124 -0
  432. package/src/ViewPager/components/FluxStoreProvider.tsx +27 -0
  433. package/src/ViewPager/components/index.ts +2 -0
  434. package/src/ViewPager/hooks/index.ts +7 -0
  435. package/src/ViewPager/hooks/useDispatch.ts +11 -0
  436. package/src/ViewPager/hooks/useEagerState.ts +14 -0
  437. package/src/ViewPager/hooks/useForceRender.ts +7 -0
  438. package/src/ViewPager/hooks/useLazyState.ts +32 -0
  439. package/src/ViewPager/hooks/usePageStore.ts +30 -0
  440. package/src/ViewPager/hooks/useStore.ts +15 -0
  441. package/src/ViewPager/hooks/useViewPagerPageState.ts +6 -0
  442. package/src/ViewPager/index.ts +11 -2
  443. package/src/ViewPager/types.ts +15 -0
  444. package/src/ViewPager/utils.tsx +9 -56
  445. package/src/ViewabilityTrackerView/Viewability.ts +3 -0
  446. package/src/ViewabilityTrackerView/ViewabilityTrackerView.tsx +33 -0
  447. package/src/ViewabilityTrackerView/ViewabilityTrackerViewProps.ts +25 -0
  448. package/src/ViewabilityTrackerView/index.ts +2 -0
  449. package/src/ViewabilityTrackerView/measureViewability.ts +54 -0
  450. package/src/ViewabilityTrackerView/useViewabilityTracker.ts +85 -0
  451. package/src/hooks/index.ts +2 -0
  452. package/src/hooks/useDeferredExecutor.ts +46 -0
  453. package/src/hooks/useHeight.ts +2 -2
  454. package/src/hooks/useIsMounted.ts +19 -0
  455. package/src/hooks/useUnstableCollapsibleAppBar.ts +62 -45
  456. package/src/hooks/useUnstableToggleDisplayStyle.ts +8 -6
  457. package/src/index.ts +3 -0
  458. package/build/commonjs/Carousel/CarouselNative.js +0 -72
  459. package/build/commonjs/Carousel/CarouselNative.js.map +0 -1
  460. package/build/commonjs/Carousel/CarouselWeb.js +0 -237
  461. package/build/commonjs/Carousel/CarouselWeb.js.map +0 -1
  462. package/build/commonjs/Carousel/index.native.js.map +0 -1
  463. package/build/commonjs/Carousel/utils.js +0 -19
  464. package/build/commonjs/Carousel/utils.js.map +0 -1
  465. package/build/commonjs/ComicViewer/ComicViewerItemProps.js +0 -6
  466. package/build/commonjs/ComicViewer/ComicViewerItemProps.js.map +0 -1
  467. package/build/commonjs/ViewPager/ChildrenMemoizedPage.js +0 -49
  468. package/build/commonjs/ViewPager/ChildrenMemoizedPage.js.map +0 -1
  469. package/build/commonjs/ViewPager/ViewPagerNative.js +0 -72
  470. package/build/commonjs/ViewPager/ViewPagerNative.js.map +0 -1
  471. package/build/commonjs/ViewPager/ViewPagerWeb.js +0 -55
  472. package/build/commonjs/ViewPager/ViewPagerWeb.js.map +0 -1
  473. package/build/commonjs/ViewPager/index.native.js +0 -16
  474. package/build/commonjs/ViewPager/index.native.js.map +0 -1
  475. package/build/commonjs/hooks/useWidth.js +0 -29
  476. package/build/commonjs/hooks/useWidth.js.map +0 -1
  477. package/build/module/Carousel/CarouselNative.js +0 -54
  478. package/build/module/Carousel/CarouselNative.js.map +0 -1
  479. package/build/module/Carousel/CarouselWeb.js +0 -215
  480. package/build/module/Carousel/CarouselWeb.js.map +0 -1
  481. package/build/module/Carousel/index.native.js +0 -2
  482. package/build/module/Carousel/index.native.js.map +0 -1
  483. package/build/module/Carousel/utils.js +0 -7
  484. package/build/module/Carousel/utils.js.map +0 -1
  485. package/build/module/ComicViewer/ComicViewerItemProps.js +0 -2
  486. package/build/module/ComicViewer/ComicViewerItemProps.js.map +0 -1
  487. package/build/module/ViewPager/ChildrenMemoizedPage.js +0 -37
  488. package/build/module/ViewPager/ChildrenMemoizedPage.js.map +0 -1
  489. package/build/module/ViewPager/ViewPagerNative.js +0 -53
  490. package/build/module/ViewPager/ViewPagerNative.js.map +0 -1
  491. package/build/module/ViewPager/ViewPagerWeb.js +0 -41
  492. package/build/module/ViewPager/ViewPagerWeb.js.map +0 -1
  493. package/build/module/ViewPager/index.native.js +0 -2
  494. package/build/module/ViewPager/index.native.js.map +0 -1
  495. package/build/module/hooks/useWidth.js +0 -15
  496. package/build/module/hooks/useWidth.js.map +0 -1
  497. package/build/typescript/Carousel/CarouselNative.d.ts +0 -3
  498. package/build/typescript/Carousel/CarouselWeb.d.ts +0 -4
  499. package/build/typescript/Carousel/index.native.d.ts +0 -1
  500. package/build/typescript/Carousel/utils.d.ts +0 -6
  501. package/build/typescript/ComicViewer/ComicViewerItemProps.d.ts +0 -12
  502. package/build/typescript/ViewPager/ChildrenMemoizedPage.d.ts +0 -4
  503. package/build/typescript/ViewPager/ViewPagerNative.d.ts +0 -3
  504. package/build/typescript/ViewPager/ViewPagerWeb.d.ts +0 -3
  505. package/build/typescript/ViewPager/index.native.d.ts +0 -1
  506. package/build/typescript/hooks/useWidth.d.ts +0 -2
  507. package/src/Carousel/CarouselNative.tsx +0 -67
  508. package/src/Carousel/CarouselWeb.tsx +0 -222
  509. package/src/Carousel/index.native.ts +0 -1
  510. package/src/Carousel/utils.ts +0 -11
  511. package/src/ComicViewer/ComicViewerItemProps.ts +0 -15
  512. package/src/ViewPager/ChildrenMemoizedPage.tsx +0 -36
  513. package/src/ViewPager/ViewPagerNative.tsx +0 -66
  514. package/src/ViewPager/ViewPagerWeb.tsx +0 -52
  515. package/src/ViewPager/index.native.ts +0 -1
  516. package/src/hooks/useWidth.ts +0 -17
@@ -5,11 +5,11 @@ Object.defineProperty(exports, "__esModule", {
5
5
  });
6
6
  exports.default = useUnstableCollapsibleAppBar;
7
7
 
8
- var _react = _interopRequireWildcard(require("react"));
8
+ var _react = require("react");
9
9
 
10
10
  var _reactNative = require("react-native");
11
11
 
12
- var _reactNativeReanimated = _interopRequireDefault(require("react-native-reanimated"));
12
+ var _reactNativeReanimated = require("react-native-reanimated");
13
13
 
14
14
  var _reactNativeSafeAreaContext = require("react-native-safe-area-context");
15
15
 
@@ -21,12 +21,7 @@ var _useHeight = _interopRequireDefault(require("./useHeight"));
21
21
 
22
22
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
23
23
 
24
- function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
25
-
26
- function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
27
-
28
24
  const defaultOptions = {
29
- translucent: false,
30
25
  shouldTranslateYReset: false
31
26
  };
32
27
  const ANIMATION_DURATION_MILLIS = 100;
@@ -39,9 +34,9 @@ function useLargerValueOfLastTwoValues(value) {
39
34
  return Math.max(...refLatestTwoValues.current);
40
35
  }
41
36
 
42
- function useUnstableCollapsibleAppBar(userOptions = defaultOptions) {
37
+ function useUnstableCollapsibleAppBar() {
38
+ let userOptions = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : defaultOptions;
43
39
  const {
44
- translucent,
45
40
  shouldTranslateYReset
46
41
  } = { ...defaultOptions,
47
42
  ...userOptions
@@ -51,53 +46,57 @@ function useUnstableCollapsibleAppBar(userOptions = defaultOptions) {
51
46
  const [appBarHeight, onAppBarLayout] = (0, _useHeight.default)();
52
47
  const appBarMaxHeight = useLargerValueOfLastTwoValues(appBarHeight);
53
48
  const [collapsibleToolbarHeight, onCollapsibleToolbarLayout] = (0, _useHeight.default)();
54
-
55
- const maxTranslateY = _reactNativeReanimated.default.useDerivedValue(() => -collapsibleToolbarHeight);
56
-
57
- const translateY = _reactNativeReanimated.default.useSharedValue(0);
58
-
59
- const lastTranslateY = _reactNativeReanimated.default.useSharedValue(0);
60
-
61
- const lastOffsetY = _reactNativeReanimated.default.useSharedValue(0);
62
-
63
- const prevOffsetY = _reactNativeReanimated.default.useSharedValue(0);
64
-
65
- const overlapped = _reactNativeReanimated.default.useSharedValue(false);
66
-
67
- const vectorY = _reactNativeReanimated.default.useSharedValue(0);
68
-
49
+ const maxTranslateY = (0, _reactNativeReanimated.useDerivedValue)(() => -collapsibleToolbarHeight, [collapsibleToolbarHeight]);
50
+ const translateY = (0, _reactNativeReanimated.useSharedValue)(0);
51
+ const lastTranslateY = (0, _reactNativeReanimated.useSharedValue)(0);
52
+ const lastOffsetY = (0, _reactNativeReanimated.useSharedValue)(0);
53
+ const prevOffsetY = (0, _reactNativeReanimated.useSharedValue)(0);
54
+ const overlapped = (0, _reactNativeReanimated.useSharedValue)(false);
55
+ const vectorY = (0, _reactNativeReanimated.useSharedValue)(0);
69
56
  const elevationStyle = (0, _useElevationStyle.default)(4);
57
+ const animatedStyle = (0, _reactNativeReanimated.useAnimatedStyle)(() => {
58
+ const transform = [{
59
+ translateY: translateY.value
60
+ }];
61
+
62
+ if (_reactNative.Platform.OS === 'web') {
63
+ return {
64
+ transform,
65
+ boxShadow: overlapped.value ? elevationStyle === null || elevationStyle === void 0 ? void 0 : elevationStyle.boxShadow : 0
66
+ };
67
+ }
68
+
69
+ if (_reactNative.Platform.OS === 'android') {
70
+ return {
71
+ transform,
72
+ elevation: overlapped.value ? elevationStyle === null || elevationStyle === void 0 ? void 0 : elevationStyle.elevation : 0
73
+ };
74
+ }
70
75
 
71
- const animatedStyle = _reactNativeReanimated.default.useAnimatedStyle(() => {
72
- return _reactNative.Platform.OS === 'web' ? {
73
- transform: [{
74
- translateY: translateY.value
75
- }],
76
- boxShadow: overlapped.value ? elevationStyle === null || elevationStyle === void 0 ? void 0 : elevationStyle.boxShadow : 0
77
- } : {
78
- transform: [{
79
- translateY: translateY.value
80
- }],
81
- elevation: overlapped.value ? elevationStyle === null || elevationStyle === void 0 ? void 0 : elevationStyle.elevation : 0,
82
- shadowColor: elevationStyle === null || elevationStyle === void 0 ? void 0 : elevationStyle.shadowColor,
83
- shadowOffset: elevationStyle === null || elevationStyle === void 0 ? void 0 : elevationStyle.shadowOffset,
84
- shadowRadius: elevationStyle === null || elevationStyle === void 0 ? void 0 : elevationStyle.shadowRadius,
85
- shadowOpacity: overlapped.value ? elevationStyle === null || elevationStyle === void 0 ? void 0 : elevationStyle.shadowOpacity : 0
86
- };
87
- });
88
-
89
- const indexRef = _react.default.useRef(0);
90
-
91
- const offsetsRef = _react.default.useRef([]);
92
-
93
- const onScrollViewChanged = nextIndex => {
94
- var _offsetsRef$current$n;
76
+ if (_reactNative.Platform.OS === 'ios') {
77
+ return {
78
+ transform,
79
+ shadowColor: elevationStyle === null || elevationStyle === void 0 ? void 0 : elevationStyle.shadowColor,
80
+ shadowOffset: elevationStyle === null || elevationStyle === void 0 ? void 0 : elevationStyle.shadowOffset,
81
+ shadowRadius: elevationStyle === null || elevationStyle === void 0 ? void 0 : elevationStyle.shadowRadius,
82
+ shadowOpacity: overlapped.value ? elevationStyle === null || elevationStyle === void 0 ? void 0 : elevationStyle.shadowOpacity : 0
83
+ };
84
+ }
95
85
 
86
+ return {};
87
+ }, [
88
+ /**
89
+ * FIXME: Consider add `elevationStyle` to dependencies.
90
+ */
91
+ ]);
92
+ const indexRef = (0, _react.useRef)(0);
93
+ const offsetsRef = (0, _react.useRef)([]);
94
+ const onScrollViewChanged = (0, _react.useCallback)(nextIndex => {
96
95
  const prevIndex = indexRef.current;
97
96
 
98
97
  if (prevIndex === nextIndex) {
99
98
  if (shouldTranslateYReset) {
100
- translateY.value = _reactNativeReanimated.default.withTiming(0, {
99
+ translateY.value = (0, _reactNativeReanimated.withTiming)(0, {
101
100
  duration: ANIMATION_DURATION_MILLIS
102
101
  });
103
102
  vectorY.value = 0;
@@ -109,21 +108,20 @@ function useUnstableCollapsibleAppBar(userOptions = defaultOptions) {
109
108
  }
110
109
 
111
110
  offsetsRef.current[prevIndex] = lastOffsetY.value;
112
- const savedOffsetY = (_offsetsRef$current$n = offsetsRef.current[nextIndex]) !== null && _offsetsRef$current$n !== void 0 ? _offsetsRef$current$n : 0;
111
+ const savedOffsetY = offsetsRef.current[nextIndex] ?? 0;
113
112
  lastOffsetY.value = savedOffsetY;
114
113
  indexRef.current = nextIndex; // Determine whether to overlap every time index is changed.
115
114
 
116
115
  overlapped.value = savedOffsetY > 0; // If next ScrollView's offset is too short, expand app bar.
117
116
 
118
117
  if (translateY.value < 0 && savedOffsetY < appBarHeight) {
119
- translateY.value = _reactNativeReanimated.default.withTiming(0, {
118
+ translateY.value = (0, _reactNativeReanimated.withTiming)(0, {
120
119
  duration: ANIMATION_DURATION_MILLIS
121
120
  });
122
121
  vectorY.value = 0;
123
122
  }
124
- };
125
-
126
- const scrollHandler = _reactNativeReanimated.default.useAnimatedScrollHandler({
123
+ }, [appBarHeight]);
124
+ const scrollHandler = (0, _reactNativeReanimated.useAnimatedScrollHandler)({
127
125
  onBeginDrag: () => {
128
126
  lastTranslateY.value = translateY.value;
129
127
  },
@@ -145,13 +143,13 @@ function useUnstableCollapsibleAppBar(userOptions = defaultOptions) {
145
143
  } else {
146
144
  if (offsetY > -maxTy) {
147
145
  if (ty === 0) {
148
- translateY.value = _reactNativeReanimated.default.withTiming(Math.min(Math.max(-offsetY, maxTy), 0), {
146
+ translateY.value = (0, _reactNativeReanimated.withTiming)(Math.min(Math.max(-offsetY, maxTy), 0), {
149
147
  duration: ANIMATION_DURATION_MILLIS
150
148
  });
151
149
  }
152
150
  } else {
153
151
  if (ty === maxTy) {
154
- translateY.value = _reactNativeReanimated.default.withTiming(0, {
152
+ translateY.value = (0, _reactNativeReanimated.withTiming)(0, {
155
153
  duration: ANIMATION_DURATION_MILLIS
156
154
  });
157
155
  }
@@ -177,16 +175,15 @@ function useUnstableCollapsibleAppBar(userOptions = defaultOptions) {
177
175
  const threshold = maxTy * 0.5;
178
176
  const nextTranslateY = ty > threshold || offsetY < appBarHeight ? 0 : maxTy;
179
177
  overlapped.value = offsetY + nextTranslateY > 0;
180
- translateY.value = _reactNativeReanimated.default.withTiming(nextTranslateY, {
178
+ translateY.value = (0, _reactNativeReanimated.withTiming)(nextTranslateY, {
181
179
  duration: ANIMATION_DURATION_MILLIS
182
180
  });
183
181
  }
184
- });
185
-
182
+ }, [appBarHeight]);
186
183
  const hasCollapsible = collapsibleToolbarHeight > 0;
187
- const appBarStyle = [animatedStyle, translucent ? {
184
+ const appBarStyle = [animatedStyle, {
188
185
  paddingTop: safeAreaInsets.top
189
- } : undefined, hasCollapsible ? styles.floating : undefined];
186
+ }, hasCollapsible ? styles.floating : undefined];
190
187
  return {
191
188
  appBarStyle,
192
189
  vectorY,
@@ -1 +1 @@
1
- {"version":3,"sources":["useUnstableCollapsibleAppBar.ts"],"names":["defaultOptions","translucent","shouldTranslateYReset","ANIMATION_DURATION_MILLIS","SUPPORTS_DRAG_DETECTION","Platform","OS","useLargerValueOfLastTwoValues","value","refLatestTwoValues","current","shift","push","Math","max","useUnstableCollapsibleAppBar","userOptions","styles","safeAreaInsets","appBarHeight","onAppBarLayout","appBarMaxHeight","collapsibleToolbarHeight","onCollapsibleToolbarLayout","maxTranslateY","Animated","useDerivedValue","translateY","useSharedValue","lastTranslateY","lastOffsetY","prevOffsetY","overlapped","vectorY","elevationStyle","animatedStyle","useAnimatedStyle","transform","boxShadow","elevation","shadowColor","shadowOffset","shadowRadius","shadowOpacity","indexRef","React","useRef","offsetsRef","onScrollViewChanged","nextIndex","prevIndex","withTiming","duration","savedOffsetY","scrollHandler","useAnimatedScrollHandler","onBeginDrag","onMomentumBegin","onScroll","event","offsetY","contentOffset","y","ty","maxTy","deltaY","dy","min","onEndDrag","onMomentumEnd","threshold","nextTranslateY","hasCollapsible","appBarStyle","paddingTop","top","undefined","floating","scrollContentInsets"],"mappings":"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","sourcesContent":["import React, { useRef } from 'react';\nimport { Falsy, Platform, RegisteredStyle, ScrollViewProps, ViewProps, ViewStyle } from 'react-native';\nimport Animated from 'react-native-reanimated';\nimport { useSafeAreaInsets } from 'react-native-safe-area-context';\nimport useAppbarStyles from './useAppbarStyles';\nimport useElevationStyle from './useElevationStyle';\nimport useHeight from './useHeight';\n\ntype WebOnlyStyle = { boxShadow: any };\n\ntype ViewStyleProp = Array<ViewStyle | RegisteredStyle<ViewStyle> | WebOnlyStyle | Falsy>;\n\ntype OnScroll = ScrollViewProps['onScroll'];\n\ntype OnLayoutCallback = ViewProps['onLayout'];\n\nexport interface ContentInsets {\n top?: number;\n bottom?: number;\n left?: number;\n right?: number;\n}\n\nexport interface Options {\n translucent?: boolean;\n shouldTranslateYReset?: boolean;\n}\n\nexport interface CollapsibleAppBar {\n appBarStyle: ViewStyleProp;\n vectorY: Animated.SharedValue<number>;\n onAppBarLayout: OnLayoutCallback;\n onCollapsibleToolbarLayout: OnLayoutCallback;\n onScroll: OnScroll;\n onScrollViewChanged: (index: number) => void;\n scrollContentInsets: ContentInsets;\n}\n\nconst defaultOptions: Required<Options> = {\n translucent: false,\n shouldTranslateYReset: false,\n};\n\nconst ANIMATION_DURATION_MILLIS = 100;\n\nconst SUPPORTS_DRAG_DETECTION = Platform.OS !== 'web';\n\n\nfunction useLargerValueOfLastTwoValues(value: number) {\n const refLatestTwoValues = useRef([0, 0]);\n\n refLatestTwoValues.current.shift();\n refLatestTwoValues.current.push(value);\n\n return Math.max(...refLatestTwoValues.current);\n}\n\n\nexport default function useUnstableCollapsibleAppBar(userOptions: Options = defaultOptions): CollapsibleAppBar {\n const {\n translucent,\n shouldTranslateYReset,\n }: Required<Options> = {\n ...defaultOptions,\n ...userOptions,\n };\n\n const styles = useAppbarStyles();\n\n const safeAreaInsets = useSafeAreaInsets();\n\n const [appBarHeight, onAppBarLayout] = useHeight();\n const appBarMaxHeight = useLargerValueOfLastTwoValues(appBarHeight);\n const [collapsibleToolbarHeight, onCollapsibleToolbarLayout] = useHeight();\n\n const maxTranslateY = Animated.useDerivedValue(() => -collapsibleToolbarHeight);\n\n const translateY = Animated.useSharedValue<number>(0);\n const lastTranslateY = Animated.useSharedValue<number>(0);\n const lastOffsetY = Animated.useSharedValue<number>(0);\n const prevOffsetY = Animated.useSharedValue<number>(0);\n const overlapped = Animated.useSharedValue<boolean>(false);\n const vectorY = Animated.useSharedValue<number>(0);\n\n const elevationStyle = useElevationStyle(4);\n const animatedStyle = Animated.useAnimatedStyle(() => {\n return Platform.OS === 'web' ? ({\n transform: [{ translateY: translateY.value }],\n boxShadow: overlapped.value ? elevationStyle?.boxShadow : 0,\n }) : ({\n transform: [{ translateY: translateY.value }],\n elevation: overlapped.value ? elevationStyle?.elevation : 0,\n shadowColor: elevationStyle?.shadowColor,\n shadowOffset: elevationStyle?.shadowOffset,\n shadowRadius: elevationStyle?.shadowRadius,\n shadowOpacity: overlapped.value ? elevationStyle?.shadowOpacity : 0,\n });\n });\n\n const indexRef = React.useRef<number>(0);\n const offsetsRef = React.useRef<Array<number>>([]);\n\n const onScrollViewChanged = (nextIndex: number) => {\n const prevIndex = indexRef.current;\n if (prevIndex === nextIndex) {\n if (shouldTranslateYReset) {\n translateY.value = Animated.withTiming(0, {\n duration: ANIMATION_DURATION_MILLIS,\n });\n\n vectorY.value = 0;\n offsetsRef.current = [];\n overlapped.value = false;\n }\n\n return;\n }\n\n offsetsRef.current[prevIndex] = lastOffsetY.value;\n\n const savedOffsetY = offsetsRef.current[nextIndex] ?? 0;\n lastOffsetY.value = savedOffsetY;\n\n indexRef.current = nextIndex;\n\n // Determine whether to overlap every time index is changed.\n overlapped.value = savedOffsetY > 0;\n\n // If next ScrollView's offset is too short, expand app bar.\n if (translateY.value < 0 && savedOffsetY < appBarHeight) {\n translateY.value = Animated.withTiming(0, {\n duration: ANIMATION_DURATION_MILLIS,\n });\n\n vectorY.value = 0;\n }\n };\n\n const scrollHandler = Animated.useAnimatedScrollHandler({\n onBeginDrag: () => {\n lastTranslateY.value = translateY.value;\n },\n onMomentumBegin: () => {\n lastTranslateY.value = translateY.value;\n },\n onScroll: (event) => {\n const offsetY = event.contentOffset.y;\n\n const ty = translateY.value;\n const maxTy = maxTranslateY.value;\n\n const deltaY = offsetY - prevOffsetY.value;\n vectorY.value = (vectorY.value * deltaY >= 0 && offsetY > 0) ? vectorY.value + deltaY : deltaY;\n prevOffsetY.value = offsetY;\n\n if (SUPPORTS_DRAG_DETECTION) {\n const dy = offsetY - lastOffsetY.value;\n\n translateY.value = offsetY <= 0 ? 0 : Math.min(Math.max(lastTranslateY.value - dy, maxTy), 0);\n\n overlapped.value = offsetY + translateY.value > 0;\n } else {\n if (offsetY > -maxTy) {\n if (ty === 0) {\n translateY.value = Animated.withTiming(Math.min(Math.max(-offsetY, maxTy), 0), {\n duration: ANIMATION_DURATION_MILLIS,\n });\n }\n } else {\n if (ty === maxTy) {\n translateY.value = Animated.withTiming(0, {\n duration: ANIMATION_DURATION_MILLIS,\n });\n }\n }\n\n overlapped.value = offsetY > 0;\n\n lastOffsetY.value = offsetY;\n }\n },\n onEndDrag: (event) => {\n lastOffsetY.value = event.contentOffset.y;\n },\n onMomentumEnd: (event) => {\n const offsetY = event.contentOffset.y;\n\n lastOffsetY.value = offsetY;\n\n const ty = translateY.value;\n const maxTy = maxTranslateY.value;\n\n // If toolbar is already positioned on edge, do nothing.\n if (ty <= maxTy || ty >= 0) {\n return;\n }\n\n const threshold = maxTy * 0.5;\n\n const nextTranslateY = (ty > threshold || offsetY < appBarHeight) ? 0 : maxTy;\n\n overlapped.value = offsetY + nextTranslateY > 0;\n\n translateY.value = Animated.withTiming(nextTranslateY, {\n duration: ANIMATION_DURATION_MILLIS,\n });\n },\n });\n\n const hasCollapsible = collapsibleToolbarHeight > 0;\n\n const appBarStyle = [\n animatedStyle,\n translucent ? { paddingTop: safeAreaInsets.top } : undefined,\n hasCollapsible ? styles.floating : undefined,\n ];\n\n return {\n appBarStyle,\n vectorY,\n onAppBarLayout,\n onCollapsibleToolbarLayout,\n onScroll: scrollHandler,\n onScrollViewChanged,\n scrollContentInsets: { top: hasCollapsible ? appBarMaxHeight : 0 },\n };\n};\n"]}
1
+ {"version":3,"names":["defaultOptions","shouldTranslateYReset","ANIMATION_DURATION_MILLIS","SUPPORTS_DRAG_DETECTION","Platform","OS","useLargerValueOfLastTwoValues","value","refLatestTwoValues","useRef","current","shift","push","Math","max","useUnstableCollapsibleAppBar","userOptions","styles","useAppbarStyles","safeAreaInsets","useSafeAreaInsets","appBarHeight","onAppBarLayout","useHeight","appBarMaxHeight","collapsibleToolbarHeight","onCollapsibleToolbarLayout","maxTranslateY","useDerivedValue","translateY","useSharedValue","lastTranslateY","lastOffsetY","prevOffsetY","overlapped","vectorY","elevationStyle","useElevationStyle","animatedStyle","useAnimatedStyle","transform","boxShadow","elevation","shadowColor","shadowOffset","shadowRadius","shadowOpacity","indexRef","offsetsRef","onScrollViewChanged","useCallback","nextIndex","prevIndex","withTiming","duration","savedOffsetY","scrollHandler","useAnimatedScrollHandler","onBeginDrag","onMomentumBegin","onScroll","event","offsetY","contentOffset","y","ty","maxTy","deltaY","dy","min","onEndDrag","onMomentumEnd","threshold","nextTranslateY","hasCollapsible","appBarStyle","paddingTop","top","floating","undefined","scrollContentInsets"],"sources":["useUnstableCollapsibleAppBar.ts"],"sourcesContent":["import { useCallback, useRef } from 'react';\nimport { Falsy, Platform, RegisteredStyle, ScrollViewProps, ViewProps, ViewStyle } from 'react-native';\nimport type { SharedValue } from 'react-native-reanimated';\nimport {\n useAnimatedScrollHandler,\n useAnimatedStyle,\n useDerivedValue,\n useSharedValue,\n withTiming,\n} from 'react-native-reanimated';\nimport { useSafeAreaInsets } from 'react-native-safe-area-context';\nimport useAppbarStyles from './useAppbarStyles';\nimport useElevationStyle from './useElevationStyle';\nimport useHeight from './useHeight';\n\ntype WebOnlyStyle = { boxShadow: any };\n\ntype ViewStyleProp = Array<ViewStyle | RegisteredStyle<ViewStyle> | WebOnlyStyle | Falsy>;\n\ntype OnScroll = ScrollViewProps['onScroll'];\n\ntype OnLayoutCallback = ViewProps['onLayout'];\n\nexport interface ContentInsets {\n top?: number;\n bottom?: number;\n left?: number;\n right?: number;\n}\n\nexport interface Options {\n shouldTranslateYReset?: boolean;\n}\n\nexport interface CollapsibleAppBar {\n appBarStyle: ViewStyleProp;\n vectorY: SharedValue<number>;\n onAppBarLayout: OnLayoutCallback;\n onCollapsibleToolbarLayout: OnLayoutCallback;\n onScroll: OnScroll;\n onScrollViewChanged: (index: number) => void;\n scrollContentInsets: ContentInsets;\n}\n\nconst defaultOptions: Required<Options> = {\n shouldTranslateYReset: false,\n};\n\nconst ANIMATION_DURATION_MILLIS = 100;\n\nconst SUPPORTS_DRAG_DETECTION = Platform.OS !== 'web';\n\nfunction useLargerValueOfLastTwoValues(value: number) {\n const refLatestTwoValues = useRef([0, 0]);\n\n refLatestTwoValues.current.shift();\n refLatestTwoValues.current.push(value);\n\n return Math.max(...refLatestTwoValues.current);\n}\n\nexport default function useUnstableCollapsibleAppBar(userOptions: Options = defaultOptions): CollapsibleAppBar {\n const { shouldTranslateYReset }: Required<Options> = {\n ...defaultOptions,\n ...userOptions,\n };\n\n const styles = useAppbarStyles();\n\n const safeAreaInsets = useSafeAreaInsets();\n\n const [appBarHeight, onAppBarLayout] = useHeight();\n const appBarMaxHeight = useLargerValueOfLastTwoValues(appBarHeight);\n const [collapsibleToolbarHeight, onCollapsibleToolbarLayout] = useHeight();\n\n const maxTranslateY = useDerivedValue(() => -collapsibleToolbarHeight, [collapsibleToolbarHeight]);\n\n const translateY = useSharedValue<number>(0);\n const lastTranslateY = useSharedValue<number>(0);\n const lastOffsetY = useSharedValue<number>(0);\n const prevOffsetY = useSharedValue<number>(0);\n const overlapped = useSharedValue<boolean>(false);\n const vectorY = useSharedValue<number>(0);\n\n const elevationStyle = useElevationStyle(4);\n const animatedStyle = useAnimatedStyle(() => {\n const transform = [{ translateY: translateY.value }];\n\n if (Platform.OS === 'web') {\n return {\n transform,\n boxShadow: overlapped.value ? elevationStyle?.boxShadow : 0,\n };\n }\n if (Platform.OS === 'android') {\n return {\n transform,\n elevation: overlapped.value ? elevationStyle?.elevation : 0,\n };\n }\n if (Platform.OS === 'ios') {\n return {\n transform,\n shadowColor: elevationStyle?.shadowColor,\n shadowOffset: elevationStyle?.shadowOffset,\n shadowRadius: elevationStyle?.shadowRadius,\n shadowOpacity: overlapped.value ? elevationStyle?.shadowOpacity : 0,\n };\n }\n return {};\n }, [\n /**\n * FIXME: Consider add `elevationStyle` to dependencies.\n */\n ]);\n\n const indexRef = useRef<number>(0);\n const offsetsRef = useRef<Array<number>>([]);\n\n const onScrollViewChanged = useCallback((nextIndex: number) => {\n const prevIndex = indexRef.current;\n if (prevIndex === nextIndex) {\n if (shouldTranslateYReset) {\n translateY.value = withTiming(0, {\n duration: ANIMATION_DURATION_MILLIS,\n });\n\n vectorY.value = 0;\n offsetsRef.current = [];\n overlapped.value = false;\n }\n\n return;\n }\n\n offsetsRef.current[prevIndex] = lastOffsetY.value;\n\n const savedOffsetY = offsetsRef.current[nextIndex] ?? 0;\n lastOffsetY.value = savedOffsetY;\n\n indexRef.current = nextIndex;\n\n // Determine whether to overlap every time index is changed.\n overlapped.value = savedOffsetY > 0;\n\n // If next ScrollView's offset is too short, expand app bar.\n if (translateY.value < 0 && savedOffsetY < appBarHeight) {\n translateY.value = withTiming(0, {\n duration: ANIMATION_DURATION_MILLIS,\n });\n\n vectorY.value = 0;\n }\n }, [appBarHeight]);\n\n const scrollHandler = useAnimatedScrollHandler({\n onBeginDrag: () => {\n lastTranslateY.value = translateY.value;\n },\n onMomentumBegin: () => {\n lastTranslateY.value = translateY.value;\n },\n onScroll: (event) => {\n const offsetY = event.contentOffset.y;\n\n const ty = translateY.value;\n const maxTy = maxTranslateY.value;\n\n const deltaY = offsetY - prevOffsetY.value;\n vectorY.value = (vectorY.value * deltaY >= 0 && offsetY > 0) ? vectorY.value + deltaY : deltaY;\n prevOffsetY.value = offsetY;\n\n if (SUPPORTS_DRAG_DETECTION) {\n const dy = offsetY - lastOffsetY.value;\n\n translateY.value = offsetY <= 0 ? 0 : Math.min(Math.max(lastTranslateY.value - dy, maxTy), 0);\n\n overlapped.value = offsetY + translateY.value > 0;\n } else {\n if (offsetY > -maxTy) {\n if (ty === 0) {\n translateY.value = withTiming(Math.min(Math.max(-offsetY, maxTy), 0), {\n duration: ANIMATION_DURATION_MILLIS,\n });\n }\n } else {\n if (ty === maxTy) {\n translateY.value = withTiming(0, {\n duration: ANIMATION_DURATION_MILLIS,\n });\n }\n }\n\n overlapped.value = offsetY > 0;\n\n lastOffsetY.value = offsetY;\n }\n },\n onEndDrag: (event) => {\n lastOffsetY.value = event.contentOffset.y;\n },\n onMomentumEnd: (event) => {\n const offsetY = event.contentOffset.y;\n\n lastOffsetY.value = offsetY;\n\n const ty = translateY.value;\n const maxTy = maxTranslateY.value;\n\n // If toolbar is already positioned on edge, do nothing.\n if (ty <= maxTy || ty >= 0) {\n return;\n }\n\n const threshold = maxTy * 0.5;\n\n const nextTranslateY = (ty > threshold || offsetY < appBarHeight) ? 0 : maxTy;\n\n overlapped.value = offsetY + nextTranslateY > 0;\n\n translateY.value = withTiming(nextTranslateY, {\n duration: ANIMATION_DURATION_MILLIS,\n });\n },\n }, [appBarHeight]);\n\n const hasCollapsible = collapsibleToolbarHeight > 0;\n\n const appBarStyle = [\n animatedStyle,\n { paddingTop: safeAreaInsets.top },\n hasCollapsible ? styles.floating : undefined,\n ];\n\n return {\n appBarStyle,\n vectorY,\n onAppBarLayout,\n onCollapsibleToolbarLayout,\n onScroll: scrollHandler,\n onScrollViewChanged,\n scrollContentInsets: { top: hasCollapsible ? appBarMaxHeight : 0 },\n };\n};\n"],"mappings":"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"}
@@ -5,24 +5,22 @@ Object.defineProperty(exports, "__esModule", {
5
5
  });
6
6
  exports.default = useAnimatedDisplayStyle;
7
7
 
8
- var _reactNativeReanimated = _interopRequireDefault(require("react-native-reanimated"));
8
+ var _reactNativeReanimated = require("react-native-reanimated");
9
9
 
10
- function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
11
-
12
- function useAnimatedDisplayStyle(vectorY, threshold = 200, defaultDisplay = 'flex') {
13
- const display = _reactNativeReanimated.default.useSharedValue(defaultDisplay);
14
-
15
- _reactNativeReanimated.default.useAnimatedReaction(() => vectorY.value, vy => {
10
+ function useAnimatedDisplayStyle(vectorY) {
11
+ let threshold = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 200;
12
+ let defaultDisplay = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : 'flex';
13
+ const display = (0, _reactNativeReanimated.useSharedValue)(defaultDisplay);
14
+ (0, _reactNativeReanimated.useAnimatedReaction)(() => vectorY.value, vy => {
16
15
  if (vy >= threshold) {
17
16
  display.value = 'none';
18
17
  } else if (vy < threshold) {
19
18
  display.value = 'flex';
20
19
  }
21
- });
22
-
23
- return _reactNativeReanimated.default.useAnimatedStyle(() => ({
20
+ }, [threshold]);
21
+ return (0, _reactNativeReanimated.useAnimatedStyle)(() => ({
24
22
  display: display.value
25
- }));
23
+ }), []);
26
24
  }
27
25
 
28
26
  ;
@@ -1 +1 @@
1
- {"version":3,"sources":["useUnstableToggleDisplayStyle.ts"],"names":["useAnimatedDisplayStyle","vectorY","threshold","defaultDisplay","display","Animated","useSharedValue","useAnimatedReaction","value","vy","useAnimatedStyle"],"mappings":";;;;;;;AAAA;;;;AAEe,SAASA,uBAAT,CACXC,OADW,EAEXC,SAAiB,GAAG,GAFT,EAGXC,cAA+B,GAAG,MAHvB,EAIb;AACE,QAAMC,OAAO,GAAGC,+BAASC,cAAT,CAAwBH,cAAxB,CAAhB;;AAEAE,iCAASE,mBAAT,CACI,MAAMN,OAAO,CAACO,KADlB,EAEKC,EAAD,IAAQ;AACJ,QAAIA,EAAE,IAAIP,SAAV,EAAqB;AACjBE,MAAAA,OAAO,CAACI,KAAR,GAAgB,MAAhB;AACH,KAFD,MAEO,IAAIC,EAAE,GAAGP,SAAT,EAAoB;AACvBE,MAAAA,OAAO,CAACI,KAAR,GAAgB,MAAhB;AACH;AACJ,GARL;;AAWA,SAAOH,+BAASK,gBAAT,CAA0B,OAAO;AACpCN,IAAAA,OAAO,EAAEA,OAAO,CAACI;AADmB,GAAP,CAA1B,CAAP;AAGH;;AAAA","sourcesContent":["import Animated from 'react-native-reanimated';\n\nexport default function useAnimatedDisplayStyle(\n vectorY: Animated.SharedValue<number>,\n threshold: number = 200,\n defaultDisplay: 'flex' | 'none' = 'flex',\n) {\n const display = Animated.useSharedValue(defaultDisplay);\n\n Animated.useAnimatedReaction(\n () => vectorY.value,\n (vy) => {\n if (vy >= threshold) {\n display.value = 'none';\n } else if (vy < threshold) {\n display.value = 'flex';\n }\n },\n );\n\n return Animated.useAnimatedStyle(() => ({\n display: display.value,\n }));\n};\n"]}
1
+ {"version":3,"names":["useAnimatedDisplayStyle","vectorY","threshold","defaultDisplay","display","useSharedValue","useAnimatedReaction","value","vy","useAnimatedStyle"],"sources":["useUnstableToggleDisplayStyle.ts"],"sourcesContent":["import type { SharedValue } from 'react-native-reanimated';\nimport { useAnimatedReaction, useAnimatedStyle, useSharedValue } from 'react-native-reanimated';\n\nexport default function useAnimatedDisplayStyle(\n vectorY: SharedValue<number>,\n threshold: number = 200,\n defaultDisplay: 'flex' | 'none' = 'flex',\n) {\n const display = useSharedValue(defaultDisplay);\n\n useAnimatedReaction(\n () => vectorY.value,\n (vy) => {\n if (vy >= threshold) {\n display.value = 'none';\n } else if (vy < threshold) {\n display.value = 'flex';\n }\n },\n [threshold],\n );\n\n return useAnimatedStyle(() => ({\n display: display.value,\n }), []);\n};\n"],"mappings":";;;;;;;AACA;;AAEe,SAASA,uBAAT,CACXC,OADW,EAIb;EAAA,IAFEC,SAEF,uEAFsB,GAEtB;EAAA,IADEC,cACF,uEADoC,MACpC;EACE,MAAMC,OAAO,GAAG,IAAAC,qCAAA,EAAeF,cAAf,CAAhB;EAEA,IAAAG,0CAAA,EACI,MAAML,OAAO,CAACM,KADlB,EAEKC,EAAD,IAAQ;IACJ,IAAIA,EAAE,IAAIN,SAAV,EAAqB;MACjBE,OAAO,CAACG,KAAR,GAAgB,MAAhB;IACH,CAFD,MAEO,IAAIC,EAAE,GAAGN,SAAT,EAAoB;MACvBE,OAAO,CAACG,KAAR,GAAgB,MAAhB;IACH;EACJ,CARL,EASI,CAACL,SAAD,CATJ;EAYA,OAAO,IAAAO,uCAAA,EAAiB,OAAO;IAC3BL,OAAO,EAAEA,OAAO,CAACG;EADU,CAAP,CAAjB,EAEH,EAFG,CAAP;AAGH;;AAAA"}
@@ -11,7 +11,8 @@ var _exportNames = {
11
11
  ViewPager: true,
12
12
  ComicViewer: true,
13
13
  StatusBarProvider: true,
14
- useStatusBarContext: true
14
+ useStatusBarContext: true,
15
+ ViewabilityTrackerView: true
15
16
  };
16
17
  Object.defineProperty(exports, "BottomSheet", {
17
18
  enumerable: true,
@@ -25,6 +26,12 @@ Object.defineProperty(exports, "Carousel", {
25
26
  return _Carousel.default;
26
27
  }
27
28
  });
29
+ Object.defineProperty(exports, "ComicViewer", {
30
+ enumerable: true,
31
+ get: function () {
32
+ return _ComicViewer.default;
33
+ }
34
+ });
28
35
  Object.defineProperty(exports, "DateTimePicker", {
29
36
  enumerable: true,
30
37
  get: function () {
@@ -37,22 +44,22 @@ Object.defineProperty(exports, "FlipCard", {
37
44
  return _FlipCard.default;
38
45
  }
39
46
  });
40
- Object.defineProperty(exports, "ViewPager", {
47
+ Object.defineProperty(exports, "StatusBarProvider", {
41
48
  enumerable: true,
42
49
  get: function () {
43
- return _ViewPager.default;
50
+ return _StatusBarProvider.default;
44
51
  }
45
52
  });
46
- Object.defineProperty(exports, "ComicViewer", {
53
+ Object.defineProperty(exports, "ViewPager", {
47
54
  enumerable: true,
48
55
  get: function () {
49
- return _ComicViewer.default;
56
+ return _ViewPager.default;
50
57
  }
51
58
  });
52
- Object.defineProperty(exports, "StatusBarProvider", {
59
+ Object.defineProperty(exports, "ViewabilityTrackerView", {
53
60
  enumerable: true,
54
61
  get: function () {
55
- return _StatusBarProvider.default;
62
+ return _ViewabilityTrackerView.default;
56
63
  }
57
64
  });
58
65
  Object.defineProperty(exports, "useStatusBarContext", {
@@ -160,6 +167,20 @@ Object.keys(_StatusBarProvider).forEach(function (key) {
160
167
  });
161
168
  });
162
169
 
170
+ var _ViewabilityTrackerView = _interopRequireWildcard(require("./ViewabilityTrackerView"));
171
+
172
+ Object.keys(_ViewabilityTrackerView).forEach(function (key) {
173
+ if (key === "default" || key === "__esModule") return;
174
+ if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;
175
+ if (key in exports && exports[key] === _ViewabilityTrackerView[key]) return;
176
+ Object.defineProperty(exports, key, {
177
+ enumerable: true,
178
+ get: function () {
179
+ return _ViewabilityTrackerView[key];
180
+ }
181
+ });
182
+ });
183
+
163
184
  var _hooks = require("./hooks");
164
185
 
165
186
  Object.keys(_hooks).forEach(function (key) {
@@ -1 +1 @@
1
- {"version":3,"sources":["index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;;AACA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;AAEA;;AACA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;AAEA;;AACA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;AAEA;;AACA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;AAEA;;AACA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;AAEA;;AACA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;AAEA;;AACA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;AAEA;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA","sourcesContent":["export { default as BottomSheet } from './BottomSheet';\nexport * from './BottomSheet';\n\nexport { default as Carousel } from './Carousel';\nexport * from './Carousel';\n\nexport { default as DateTimePicker } from './DateTimePicker';\nexport * from './DateTimePicker';\n\nexport { default as FlipCard } from './FlipCard';\nexport * from './FlipCard';\n\nexport { default as ViewPager } from './ViewPager';\nexport * from './ViewPager';\n\nexport { default as ComicViewer } from './ComicViewer';\nexport * from './ComicViewer';\n\nexport { default as StatusBarProvider, useStatusBarContext } from './StatusBarProvider';\nexport * from './StatusBarProvider';\n\nexport * from './hooks';\n"]}
1
+ {"version":3,"names":[],"sources":["index.ts"],"sourcesContent":["export { default as BottomSheet } from './BottomSheet';\nexport * from './BottomSheet';\n\nexport { default as Carousel } from './Carousel';\nexport * from './Carousel';\n\nexport { default as DateTimePicker } from './DateTimePicker';\nexport * from './DateTimePicker';\n\nexport { default as FlipCard } from './FlipCard';\nexport * from './FlipCard';\n\nexport { default as ViewPager } from './ViewPager';\nexport * from './ViewPager';\n\nexport { default as ComicViewer } from './ComicViewer';\nexport * from './ComicViewer';\n\nexport { default as StatusBarProvider, useStatusBarContext } from './StatusBarProvider';\nexport * from './StatusBarProvider';\n\nexport { default as ViewabilityTrackerView } from './ViewabilityTrackerView';\nexport * from './ViewabilityTrackerView';\n\nexport * from './hooks';\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;;AACA;EAAA;EAAA;EAAA;EAAA;IAAA;IAAA;MAAA;IAAA;EAAA;AAAA;;AAEA;;AACA;EAAA;EAAA;EAAA;EAAA;IAAA;IAAA;MAAA;IAAA;EAAA;AAAA;;AAEA;;AACA;EAAA;EAAA;EAAA;EAAA;IAAA;IAAA;MAAA;IAAA;EAAA;AAAA;;AAEA;;AACA;EAAA;EAAA;EAAA;EAAA;IAAA;IAAA;MAAA;IAAA;EAAA;AAAA;;AAEA;;AACA;EAAA;EAAA;EAAA;EAAA;IAAA;IAAA;MAAA;IAAA;EAAA;AAAA;;AAEA;;AACA;EAAA;EAAA;EAAA;EAAA;IAAA;IAAA;MAAA;IAAA;EAAA;AAAA;;AAEA;;AACA;EAAA;EAAA;EAAA;EAAA;IAAA;IAAA;MAAA;IAAA;EAAA;AAAA;;AAEA;;AACA;EAAA;EAAA;EAAA;EAAA;IAAA;IAAA;MAAA;IAAA;EAAA;AAAA;;AAEA;;AAAA;EAAA;EAAA;EAAA;EAAA;IAAA;IAAA;MAAA;IAAA;EAAA;AAAA"}
@@ -1,23 +1,24 @@
1
- import React from 'react';
2
- import Animated, { Easing } from 'react-native-reanimated';
1
+ import React, { useEffect } from 'react';
2
+ import Animated, { Easing, useAnimatedStyle, useSharedValue, withTiming } from 'react-native-reanimated';
3
+ const ANIMATION_CONFIG = {
4
+ duration: 150,
5
+ easing: Easing.out(Easing.exp)
6
+ };
3
7
  export default function AnimatedY(props) {
4
8
  const {
5
9
  children,
6
10
  translateY,
7
11
  style
8
12
  } = props;
9
- const animatedY = Animated.useSharedValue(translateY);
10
- const animatedStyle = Animated.useAnimatedStyle(() => ({
13
+ const animatedY = useSharedValue(translateY);
14
+ const animatedStyle = useAnimatedStyle(() => ({
11
15
  transform: [{
12
16
  translateY: animatedY.value
13
17
  }]
14
- }));
15
- React.useEffect(() => {
18
+ }), []);
19
+ useEffect(() => {
16
20
  if (translateY >= 0) {
17
- animatedY.value = Animated.withTiming(translateY, {
18
- duration: 150,
19
- easing: Easing.out(Easing.exp)
20
- });
21
+ animatedY.value = withTiming(translateY, ANIMATION_CONFIG);
21
22
  }
22
23
  }, [translateY]);
23
24
  return /*#__PURE__*/React.createElement(Animated.View, {
@@ -1 +1 @@
1
- {"version":3,"sources":["AnimatedY.tsx"],"names":["React","Animated","Easing","AnimatedY","props","children","translateY","style","animatedY","useSharedValue","animatedStyle","useAnimatedStyle","transform","value","useEffect","withTiming","duration","easing","out","exp"],"mappings":"AAAA,OAAOA,KAAP,MAAkB,OAAlB;AACA,OAAOC,QAAP,IAAmBC,MAAnB,QAAiC,yBAAjC;AAGA,eAAe,SAASC,SAAT,CAAmBC,KAAnB,EAA0C;AACrD,QAAM;AACFC,IAAAA,QADE;AAEFC,IAAAA,UAFE;AAGFC,IAAAA;AAHE,MAIFH,KAJJ;AAMA,QAAMI,SAAS,GAAGP,QAAQ,CAACQ,cAAT,CAAwBH,UAAxB,CAAlB;AACA,QAAMI,aAAa,GAAGT,QAAQ,CAACU,gBAAT,CAA0B,OAAO;AACnDC,IAAAA,SAAS,EAAE,CAAC;AAAEN,MAAAA,UAAU,EAAEE,SAAS,CAACK;AAAxB,KAAD;AADwC,GAAP,CAA1B,CAAtB;AAIAb,EAAAA,KAAK,CAACc,SAAN,CAAgB,MAAM;AAClB,QAAIR,UAAU,IAAI,CAAlB,EAAqB;AACjBE,MAAAA,SAAS,CAACK,KAAV,GAAkBZ,QAAQ,CAACc,UAAT,CAAoBT,UAApB,EAAgC;AAC9CU,QAAAA,QAAQ,EAAE,GADoC;AAE9CC,QAAAA,MAAM,EAAEf,MAAM,CAACgB,GAAP,CAAWhB,MAAM,CAACiB,GAAlB;AAFsC,OAAhC,CAAlB;AAIH;AACJ,GAPD,EAOG,CAACb,UAAD,CAPH;AASA,sBACI,oBAAC,QAAD,CAAU,IAAV;AACI,IAAA,QAAQ,EAAED,QADd;AAEI,IAAA,KAAK,EAAE,CACHK,aADG,EAEHH,KAFG;AAFX,IADJ;AASH;AAAA","sourcesContent":["import React from 'react';\nimport Animated, { Easing } from 'react-native-reanimated';\nimport type AnimatedYProps from './AnimatedYProps';\n\nexport default function AnimatedY(props: AnimatedYProps) {\n const {\n children,\n translateY,\n style,\n } = props;\n\n const animatedY = Animated.useSharedValue(translateY);\n const animatedStyle = Animated.useAnimatedStyle(() => ({\n transform: [{ translateY: animatedY.value }],\n }));\n\n React.useEffect(() => {\n if (translateY >= 0) {\n animatedY.value = Animated.withTiming(translateY, {\n duration: 150,\n easing: Easing.out(Easing.exp),\n });\n }\n }, [translateY]);\n\n return (\n <Animated.View\n children={children}\n style={[\n animatedStyle,\n style,\n ]}\n />\n );\n};\n"]}
1
+ {"version":3,"names":["React","useEffect","Animated","Easing","useAnimatedStyle","useSharedValue","withTiming","ANIMATION_CONFIG","duration","easing","out","exp","AnimatedY","props","children","translateY","style","animatedY","animatedStyle","transform","value"],"sources":["AnimatedY.tsx"],"sourcesContent":["import React, { useEffect } from 'react';\nimport type { WithTimingConfig } from 'react-native-reanimated';\nimport Animated, { Easing, useAnimatedStyle, useSharedValue, withTiming } from 'react-native-reanimated';\nimport type AnimatedYProps from './AnimatedYProps';\n\nconst ANIMATION_CONFIG: Readonly<WithTimingConfig> = {\n duration: 150,\n easing: Easing.out(Easing.exp),\n};\n\nexport default function AnimatedY(props: AnimatedYProps) {\n const {\n children,\n translateY,\n style,\n } = props;\n\n const animatedY = useSharedValue(translateY);\n const animatedStyle = useAnimatedStyle(() => ({\n transform: [{ translateY: animatedY.value }],\n }), []);\n\n useEffect(() => {\n if (translateY >= 0) {\n animatedY.value = withTiming(translateY, ANIMATION_CONFIG);\n }\n }, [translateY]);\n\n return (\n <Animated.View\n children={children}\n style={[\n animatedStyle,\n style,\n ]}\n />\n );\n};\n"],"mappings":"AAAA,OAAOA,KAAP,IAAgBC,SAAhB,QAAiC,OAAjC;AAEA,OAAOC,QAAP,IAAmBC,MAAnB,EAA2BC,gBAA3B,EAA6CC,cAA7C,EAA6DC,UAA7D,QAA+E,yBAA/E;AAGA,MAAMC,gBAA4C,GAAG;EACjDC,QAAQ,EAAE,GADuC;EAEjDC,MAAM,EAAEN,MAAM,CAACO,GAAP,CAAWP,MAAM,CAACQ,GAAlB;AAFyC,CAArD;AAKA,eAAe,SAASC,SAAT,CAAmBC,KAAnB,EAA0C;EACrD,MAAM;IACFC,QADE;IAEFC,UAFE;IAGFC;EAHE,IAIFH,KAJJ;EAMA,MAAMI,SAAS,GAAGZ,cAAc,CAACU,UAAD,CAAhC;EACA,MAAMG,aAAa,GAAGd,gBAAgB,CAAC,OAAO;IAC1Ce,SAAS,EAAE,CAAC;MAAEJ,UAAU,EAAEE,SAAS,CAACG;IAAxB,CAAD;EAD+B,CAAP,CAAD,EAElC,EAFkC,CAAtC;EAIAnB,SAAS,CAAC,MAAM;IACZ,IAAIc,UAAU,IAAI,CAAlB,EAAqB;MACjBE,SAAS,CAACG,KAAV,GAAkBd,UAAU,CAACS,UAAD,EAAaR,gBAAb,CAA5B;IACH;EACJ,CAJQ,EAIN,CAACQ,UAAD,CAJM,CAAT;EAMA,oBACI,oBAAC,QAAD,CAAU,IAAV;IACI,QAAQ,EAAED,QADd;IAEI,KAAK,EAAE,CACHI,aADG,EAEHF,KAFG;EAFX,EADJ;AASH;AAAA"}
@@ -1 +1 @@
1
- {"version":3,"sources":[],"names":[],"mappings":"","sourcesContent":[]}
1
+ {"version":3,"names":[],"sources":["AnimatedYProps.ts"],"sourcesContent":["import React from 'react';\nimport type { ComponentProps } from '@fountain-ui/core';\n\nexport default interface AnimatedYProps extends ComponentProps<{\n /**\n * The content of the component.\n */\n children?: React.ReactNode;\n\n /**\n * The translate y value of the component.\n */\n translateY: number;\n}> {}\n"],"mappings":""}
@@ -1 +1 @@
1
- {"version":3,"sources":["index.ts"],"names":["default"],"mappings":"AAAA,SAASA,OAAT,QAAwB,aAAxB","sourcesContent":["export { default } from './AnimatedY';\nexport type { default as AnimatedYProps } from './AnimatedYProps';\n"]}
1
+ {"version":3,"names":["default"],"sources":["index.ts"],"sourcesContent":["export { default } from './AnimatedY';\nexport type { default as AnimatedYProps } from './AnimatedYProps';\n"],"mappings":"AAAA,SAASA,OAAT,QAAwB,aAAxB"}
@@ -0,0 +1,161 @@
1
+ function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
2
+
3
+ import React, { useEffect, useMemo, useRef } from 'react';
4
+ import { Animated, PanResponder, ScrollView, View } from 'react-native';
5
+ import { css, Modal, Paper, StyleSheet, useAnimatedValue, useTheme } from '@fountain-ui/core';
6
+ import useDynamicSnapPoints from './useDynamicSnapPoints';
7
+
8
+ const useStyles = function () {
9
+ const theme = useTheme();
10
+ return {
11
+ root: {
12
+ justifyContent: 'flex-end',
13
+ zIndex: theme.zIndex.dialog
14
+ },
15
+ animated: {
16
+ alignSelf: 'center',
17
+ maxWidth: 720,
18
+ width: '100%'
19
+ },
20
+ paper: {
21
+ borderBottomLeftRadius: 0,
22
+ borderBottomRightRadius: 0,
23
+ flexGrow: 1,
24
+ overflow: 'hidden'
25
+ },
26
+ scrollView: {
27
+ flexGrow: 1
28
+ }
29
+ };
30
+ };
31
+
32
+ export default function BottomSheet(props) {
33
+ const {
34
+ backdropOpacity,
35
+ children,
36
+ header,
37
+ index,
38
+ onChange,
39
+ snapPoints: initialSnapPoints
40
+ } = props;
41
+ const styles = useStyles();
42
+ const contentLayout = useRef({
43
+ x: 0,
44
+ y: 0,
45
+ width: 0,
46
+ height: 0
47
+ });
48
+ const currentScrollY = useRef(0);
49
+ const {
50
+ snapPoints,
51
+ handleContentLayout
52
+ } = useDynamicSnapPoints({
53
+ index,
54
+ initialSnapPoints
55
+ });
56
+ const height = snapPoints[snapPoints.length - 1] ?? 0;
57
+ const translateY = height - (snapPoints[index] ?? 0);
58
+ const animatedY = useAnimatedValue(translateY);
59
+
60
+ const isInsideScrollView = (locationX, locationY) => {
61
+ const {
62
+ current: {
63
+ x,
64
+ y,
65
+ width,
66
+ height
67
+ }
68
+ } = contentLayout;
69
+ return locationX >= x && locationX <= x + width && locationY >= y && locationY <= y + height;
70
+ };
71
+
72
+ const panResponder = useMemo(() => PanResponder.create({
73
+ onMoveShouldSetPanResponder: (event, gestureState) => {
74
+ const {
75
+ nativeEvent: {
76
+ locationX,
77
+ locationY
78
+ }
79
+ } = event;
80
+
81
+ if (isInsideScrollView(locationX, locationY)) {
82
+ return gestureState.dy > 0 && currentScrollY.current === 0;
83
+ }
84
+
85
+ return true;
86
+ },
87
+ onPanResponderMove: (_, gestureState) => {
88
+ if (gestureState.dy > 0) {
89
+ animatedY.setValue(translateY + gestureState.dy);
90
+ }
91
+ },
92
+ onPanResponderRelease: (_, gestureState) => {
93
+ if (gestureState.dy > 0 && gestureState.vy > 0.5) {
94
+ handleClose();
95
+ } else {
96
+ Animated.timing(animatedY, {
97
+ toValue: translateY,
98
+ useNativeDriver: false,
99
+ duration: 300
100
+ }).start();
101
+ }
102
+ }
103
+ }), [translateY]);
104
+ useEffect(() => {
105
+ if (translateY >= 0) {
106
+ Animated.timing(animatedY, {
107
+ toValue: translateY,
108
+ useNativeDriver: false,
109
+ duration: 300
110
+ }).start();
111
+ }
112
+ }, [translateY]);
113
+
114
+ const handleClose = () => {
115
+ if (onChange) {
116
+ onChange(-1);
117
+ }
118
+ };
119
+
120
+ const handleScrollViewLayout = event => {
121
+ contentLayout.current = event.nativeEvent.layout;
122
+ };
123
+
124
+ const handleScroll = event => {
125
+ currentScrollY.current = event.nativeEvent.contentOffset.y;
126
+ };
127
+
128
+ const animatedStyles = [styles.animated, {
129
+ transform: [{
130
+ translateY: animatedY
131
+ }]
132
+ }];
133
+ const paperStyles = [styles.paper, { ...(height !== 0 ? {
134
+ height
135
+ } : {})
136
+ }];
137
+ const contentStyle = { ...(snapPoints[index] !== 0 ? {
138
+ height: snapPoints[index]
139
+ } : {})
140
+ };
141
+ return /*#__PURE__*/React.createElement(Modal, {
142
+ backdropOpacity: backdropOpacity,
143
+ onClose: handleClose,
144
+ visible: index >= 0,
145
+ style: css([StyleSheet.absoluteFill, styles.root])
146
+ }, /*#__PURE__*/React.createElement(Animated.View, _extends({
147
+ style: animatedStyles
148
+ }, panResponder.panHandlers), /*#__PURE__*/React.createElement(Paper, {
149
+ elevation: 12,
150
+ style: paperStyles
151
+ }, /*#__PURE__*/React.createElement(View, {
152
+ style: contentStyle,
153
+ onLayout: handleContentLayout
154
+ }, header, /*#__PURE__*/React.createElement(ScrollView, {
155
+ onLayout: handleScrollViewLayout,
156
+ onScroll: handleScroll,
157
+ scrollEventThrottle: 300,
158
+ style: styles.scrollView
159
+ }, children)))));
160
+ }
161
+ //# sourceMappingURL=BottomSheet.js.map