@tamagui/sheet 2.0.0-rc.9 → 2.0.0

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 (450) hide show
  1. package/.turbo/turbo-build.log +2 -0
  2. package/controller/index.cjs +2 -1
  3. package/controller/index.js +2 -0
  4. package/controller/index.native.cjs +2 -0
  5. package/controller/index.native.js +2 -0
  6. package/dist/cjs/GestureDetectorWrapper.cjs +27 -21
  7. package/dist/cjs/GestureDetectorWrapper.native.js +33 -28
  8. package/dist/cjs/GestureDetectorWrapper.native.js.map +1 -1
  9. package/dist/cjs/GestureSheetContext.cjs +14 -12
  10. package/dist/cjs/GestureSheetContext.native.js +29 -27
  11. package/dist/cjs/GestureSheetContext.native.js.map +1 -1
  12. package/dist/cjs/Sheet.cjs +88 -86
  13. package/dist/cjs/Sheet.native.js +88 -86
  14. package/dist/cjs/Sheet.native.js.map +1 -1
  15. package/dist/cjs/SheetContext.cjs +16 -14
  16. package/dist/cjs/SheetContext.native.js +16 -14
  17. package/dist/cjs/SheetContext.native.js.map +1 -1
  18. package/dist/cjs/SheetController.cjs +40 -32
  19. package/dist/cjs/SheetController.native.js +62 -54
  20. package/dist/cjs/SheetController.native.js.map +1 -1
  21. package/dist/cjs/SheetImplementationCustom.cjs +568 -429
  22. package/dist/cjs/SheetImplementationCustom.native.js +592 -474
  23. package/dist/cjs/SheetImplementationCustom.native.js.map +1 -1
  24. package/dist/cjs/SheetScrollView.cjs +184 -135
  25. package/dist/cjs/SheetScrollView.native.js +202 -163
  26. package/dist/cjs/SheetScrollView.native.js.map +1 -1
  27. package/dist/cjs/constants.cjs +16 -14
  28. package/dist/cjs/constants.native.js +16 -14
  29. package/dist/cjs/constants.native.js.map +1 -1
  30. package/dist/cjs/contexts.cjs +27 -25
  31. package/dist/cjs/contexts.native.js +29 -27
  32. package/dist/cjs/contexts.native.js.map +1 -1
  33. package/dist/cjs/controller.cjs +14 -12
  34. package/dist/cjs/controller.native.js +14 -12
  35. package/dist/cjs/controller.native.js.map +1 -1
  36. package/dist/cjs/createSheet.cjs +159 -160
  37. package/dist/cjs/createSheet.native.js +172 -180
  38. package/dist/cjs/createSheet.native.js.map +1 -1
  39. package/dist/cjs/gestureState.cjs +12 -10
  40. package/dist/cjs/gestureState.native.js +12 -10
  41. package/dist/cjs/gestureState.native.js.map +1 -1
  42. package/dist/cjs/helpers.cjs +17 -13
  43. package/dist/cjs/helpers.native.js +17 -13
  44. package/dist/cjs/helpers.native.js.map +1 -1
  45. package/dist/cjs/index.cjs +7 -5
  46. package/dist/cjs/index.native.js +7 -5
  47. package/dist/cjs/index.native.js.map +1 -1
  48. package/dist/cjs/keyboardAvoidance.cjs +42 -0
  49. package/dist/cjs/keyboardAvoidance.native.js +46 -0
  50. package/dist/cjs/keyboardAvoidance.native.js.map +1 -0
  51. package/dist/cjs/nativeSheet.cjs +65 -55
  52. package/dist/cjs/nativeSheet.native.js +74 -68
  53. package/dist/cjs/nativeSheet.native.js.map +1 -1
  54. package/dist/cjs/setupGestureHandler.cjs +24 -18
  55. package/dist/cjs/setupGestureHandler.native.js +24 -19
  56. package/dist/cjs/setupGestureHandler.native.js.map +1 -1
  57. package/dist/cjs/types.cjs +7 -5
  58. package/dist/cjs/types.native.js +7 -5
  59. package/dist/cjs/types.native.js.map +1 -1
  60. package/dist/cjs/useGestureHandlerPan.cjs +181 -111
  61. package/dist/cjs/useGestureHandlerPan.native.js +183 -115
  62. package/dist/cjs/useGestureHandlerPan.native.js.map +1 -1
  63. package/dist/cjs/useKeyboardControllerSheet.cjs +15 -13
  64. package/dist/cjs/useKeyboardControllerSheet.native.js +100 -82
  65. package/dist/cjs/useKeyboardControllerSheet.native.js.map +1 -1
  66. package/dist/cjs/useSheet.cjs +12 -10
  67. package/dist/cjs/useSheet.native.js +16 -14
  68. package/dist/cjs/useSheet.native.js.map +1 -1
  69. package/dist/cjs/useSheetController.cjs +35 -33
  70. package/dist/cjs/useSheetController.native.js +37 -35
  71. package/dist/cjs/useSheetController.native.js.map +1 -1
  72. package/dist/cjs/useSheetOffscreenSize.cjs +35 -23
  73. package/dist/cjs/useSheetOffscreenSize.native.js +36 -27
  74. package/dist/cjs/useSheetOffscreenSize.native.js.map +1 -1
  75. package/dist/cjs/useSheetOpenState.cjs +28 -25
  76. package/dist/cjs/useSheetOpenState.native.js +39 -37
  77. package/dist/cjs/useSheetOpenState.native.js.map +1 -1
  78. package/dist/cjs/useSheetProviderProps.cjs +129 -81
  79. package/dist/cjs/useSheetProviderProps.native.js +165 -122
  80. package/dist/cjs/useSheetProviderProps.native.js.map +1 -1
  81. package/dist/cjs/useSheetScrollViewGestures.cjs +124 -81
  82. package/dist/cjs/useSheetScrollViewGestures.native.js +128 -79
  83. package/dist/cjs/useSheetScrollViewGestures.native.js.map +1 -1
  84. package/dist/esm/GestureDetectorWrapper.mjs +12 -8
  85. package/dist/esm/GestureDetectorWrapper.mjs.map +1 -1
  86. package/dist/esm/GestureDetectorWrapper.native.js +18 -15
  87. package/dist/esm/GestureDetectorWrapper.native.js.map +1 -1
  88. package/dist/esm/GestureSheetContext.native.js +14 -14
  89. package/dist/esm/GestureSheetContext.native.js.map +1 -1
  90. package/dist/esm/Sheet.mjs +70 -70
  91. package/dist/esm/Sheet.mjs.map +1 -1
  92. package/dist/esm/Sheet.native.js +70 -70
  93. package/dist/esm/Sheet.native.js.map +1 -1
  94. package/dist/esm/SheetContext.mjs +2 -2
  95. package/dist/esm/SheetContext.mjs.map +1 -1
  96. package/dist/esm/SheetContext.native.js +2 -2
  97. package/dist/esm/SheetContext.native.js.map +1 -1
  98. package/dist/esm/SheetController.mjs +12 -6
  99. package/dist/esm/SheetController.mjs.map +1 -1
  100. package/dist/esm/SheetController.native.js +18 -12
  101. package/dist/esm/SheetController.native.js.map +1 -1
  102. package/dist/esm/SheetImplementationCustom.mjs +526 -389
  103. package/dist/esm/SheetImplementationCustom.mjs.map +1 -1
  104. package/dist/esm/SheetImplementationCustom.native.js +546 -434
  105. package/dist/esm/SheetImplementationCustom.native.js.map +1 -1
  106. package/dist/esm/SheetScrollView.mjs +150 -103
  107. package/dist/esm/SheetScrollView.mjs.map +1 -1
  108. package/dist/esm/SheetScrollView.native.js +169 -132
  109. package/dist/esm/SheetScrollView.native.js.map +1 -1
  110. package/dist/esm/constants.mjs +4 -4
  111. package/dist/esm/constants.mjs.map +1 -1
  112. package/dist/esm/constants.native.js +4 -4
  113. package/dist/esm/constants.native.js.map +1 -1
  114. package/dist/esm/contexts.mjs +3 -3
  115. package/dist/esm/contexts.mjs.map +1 -1
  116. package/dist/esm/contexts.native.js +3 -3
  117. package/dist/esm/contexts.native.js.map +1 -1
  118. package/dist/esm/createSheet.mjs +130 -133
  119. package/dist/esm/createSheet.mjs.map +1 -1
  120. package/dist/esm/createSheet.native.js +142 -152
  121. package/dist/esm/createSheet.native.js.map +1 -1
  122. package/dist/esm/helpers.mjs +5 -3
  123. package/dist/esm/helpers.mjs.map +1 -1
  124. package/dist/esm/helpers.native.js +5 -3
  125. package/dist/esm/helpers.native.js.map +1 -1
  126. package/dist/esm/index.js +11 -11
  127. package/dist/esm/index.js.map +1 -6
  128. package/dist/esm/keyboardAvoidance.mjs +17 -0
  129. package/dist/esm/keyboardAvoidance.mjs.map +1 -0
  130. package/dist/esm/keyboardAvoidance.native.js +18 -0
  131. package/dist/esm/keyboardAvoidance.native.js.map +1 -0
  132. package/dist/esm/nativeSheet.mjs +46 -38
  133. package/dist/esm/nativeSheet.mjs.map +1 -1
  134. package/dist/esm/nativeSheet.native.js +52 -48
  135. package/dist/esm/nativeSheet.native.js.map +1 -1
  136. package/dist/esm/setupGestureHandler.mjs +12 -8
  137. package/dist/esm/setupGestureHandler.mjs.map +1 -1
  138. package/dist/esm/setupGestureHandler.native.js +12 -9
  139. package/dist/esm/setupGestureHandler.native.js.map +1 -1
  140. package/dist/esm/useGestureHandlerPan.mjs +167 -99
  141. package/dist/esm/useGestureHandlerPan.mjs.map +1 -1
  142. package/dist/esm/useGestureHandlerPan.native.js +168 -102
  143. package/dist/esm/useGestureHandlerPan.native.js.map +1 -1
  144. package/dist/esm/useKeyboardControllerSheet.mjs +3 -3
  145. package/dist/esm/useKeyboardControllerSheet.mjs.map +1 -1
  146. package/dist/esm/useKeyboardControllerSheet.native.js +85 -69
  147. package/dist/esm/useKeyboardControllerSheet.native.js.map +1 -1
  148. package/dist/esm/useSheetController.mjs +11 -11
  149. package/dist/esm/useSheetController.mjs.map +1 -1
  150. package/dist/esm/useSheetController.native.js +11 -11
  151. package/dist/esm/useSheetController.native.js.map +1 -1
  152. package/dist/esm/useSheetOffscreenSize.mjs +23 -13
  153. package/dist/esm/useSheetOffscreenSize.mjs.map +1 -1
  154. package/dist/esm/useSheetOffscreenSize.native.js +24 -17
  155. package/dist/esm/useSheetOffscreenSize.native.js.map +1 -1
  156. package/dist/esm/useSheetOpenState.mjs +14 -13
  157. package/dist/esm/useSheetOpenState.mjs.map +1 -1
  158. package/dist/esm/useSheetOpenState.native.js +17 -17
  159. package/dist/esm/useSheetOpenState.native.js.map +1 -1
  160. package/dist/esm/useSheetProviderProps.mjs +101 -55
  161. package/dist/esm/useSheetProviderProps.mjs.map +1 -1
  162. package/dist/esm/useSheetProviderProps.native.js +137 -96
  163. package/dist/esm/useSheetProviderProps.native.js.map +1 -1
  164. package/dist/esm/useSheetScrollViewGestures.mjs +112 -71
  165. package/dist/esm/useSheetScrollViewGestures.mjs.map +1 -1
  166. package/dist/esm/useSheetScrollViewGestures.native.js +116 -69
  167. package/dist/esm/useSheetScrollViewGestures.native.js.map +1 -1
  168. package/dist/jsx/GestureDetectorWrapper.mjs +12 -8
  169. package/dist/jsx/GestureDetectorWrapper.mjs.map +1 -1
  170. package/dist/jsx/GestureDetectorWrapper.native.js +33 -28
  171. package/dist/jsx/GestureDetectorWrapper.native.js.map +1 -1
  172. package/dist/jsx/GestureSheetContext.native.js +29 -27
  173. package/dist/jsx/GestureSheetContext.native.js.map +1 -1
  174. package/dist/jsx/Sheet.mjs +70 -70
  175. package/dist/jsx/Sheet.mjs.map +1 -1
  176. package/dist/jsx/Sheet.native.js +88 -86
  177. package/dist/jsx/Sheet.native.js.map +1 -1
  178. package/dist/jsx/SheetContext.mjs +2 -2
  179. package/dist/jsx/SheetContext.mjs.map +1 -1
  180. package/dist/jsx/SheetContext.native.js +16 -14
  181. package/dist/jsx/SheetContext.native.js.map +1 -1
  182. package/dist/jsx/SheetController.mjs +12 -6
  183. package/dist/jsx/SheetController.mjs.map +1 -1
  184. package/dist/jsx/SheetController.native.js +62 -54
  185. package/dist/jsx/SheetController.native.js.map +1 -1
  186. package/dist/jsx/SheetImplementationCustom.mjs +526 -389
  187. package/dist/jsx/SheetImplementationCustom.mjs.map +1 -1
  188. package/dist/jsx/SheetImplementationCustom.native.js +592 -474
  189. package/dist/jsx/SheetImplementationCustom.native.js.map +1 -1
  190. package/dist/jsx/SheetScrollView.mjs +150 -103
  191. package/dist/jsx/SheetScrollView.mjs.map +1 -1
  192. package/dist/jsx/SheetScrollView.native.js +202 -163
  193. package/dist/jsx/SheetScrollView.native.js.map +1 -1
  194. package/dist/jsx/constants.mjs +4 -4
  195. package/dist/jsx/constants.mjs.map +1 -1
  196. package/dist/jsx/constants.native.js +16 -14
  197. package/dist/jsx/constants.native.js.map +1 -1
  198. package/dist/jsx/contexts.mjs +3 -3
  199. package/dist/jsx/contexts.mjs.map +1 -1
  200. package/dist/jsx/contexts.native.js +29 -27
  201. package/dist/jsx/contexts.native.js.map +1 -1
  202. package/dist/jsx/controller.native.js +14 -12
  203. package/dist/jsx/createSheet.mjs +130 -133
  204. package/dist/jsx/createSheet.mjs.map +1 -1
  205. package/dist/jsx/createSheet.native.js +172 -180
  206. package/dist/jsx/createSheet.native.js.map +1 -1
  207. package/dist/jsx/gestureState.native.js +12 -10
  208. package/dist/jsx/gestureState.native.js.map +1 -1
  209. package/dist/jsx/helpers.mjs +5 -3
  210. package/dist/jsx/helpers.mjs.map +1 -1
  211. package/dist/jsx/helpers.native.js +17 -13
  212. package/dist/jsx/helpers.native.js.map +1 -1
  213. package/dist/jsx/index.js +11 -11
  214. package/dist/jsx/index.js.map +1 -6
  215. package/dist/jsx/index.native.js +7 -5
  216. package/dist/jsx/index.native.js.map +1 -1
  217. package/dist/jsx/keyboardAvoidance.mjs +17 -0
  218. package/dist/jsx/keyboardAvoidance.mjs.map +1 -0
  219. package/dist/jsx/keyboardAvoidance.native.js +46 -0
  220. package/dist/jsx/keyboardAvoidance.native.js.map +1 -0
  221. package/dist/jsx/nativeSheet.mjs +46 -38
  222. package/dist/jsx/nativeSheet.mjs.map +1 -1
  223. package/dist/jsx/nativeSheet.native.js +74 -68
  224. package/dist/jsx/nativeSheet.native.js.map +1 -1
  225. package/dist/jsx/setupGestureHandler.mjs +12 -8
  226. package/dist/jsx/setupGestureHandler.mjs.map +1 -1
  227. package/dist/jsx/setupGestureHandler.native.js +24 -19
  228. package/dist/jsx/setupGestureHandler.native.js.map +1 -1
  229. package/dist/jsx/types.native.js +7 -5
  230. package/dist/jsx/useGestureHandlerPan.mjs +167 -99
  231. package/dist/jsx/useGestureHandlerPan.mjs.map +1 -1
  232. package/dist/jsx/useGestureHandlerPan.native.js +183 -115
  233. package/dist/jsx/useGestureHandlerPan.native.js.map +1 -1
  234. package/dist/jsx/useKeyboardControllerSheet.mjs +3 -3
  235. package/dist/jsx/useKeyboardControllerSheet.mjs.map +1 -1
  236. package/dist/jsx/useKeyboardControllerSheet.native.js +100 -82
  237. package/dist/jsx/useKeyboardControllerSheet.native.js.map +1 -1
  238. package/dist/jsx/useSheet.native.js +16 -14
  239. package/dist/jsx/useSheetController.mjs +11 -11
  240. package/dist/jsx/useSheetController.mjs.map +1 -1
  241. package/dist/jsx/useSheetController.native.js +37 -35
  242. package/dist/jsx/useSheetController.native.js.map +1 -1
  243. package/dist/jsx/useSheetOffscreenSize.mjs +23 -13
  244. package/dist/jsx/useSheetOffscreenSize.mjs.map +1 -1
  245. package/dist/jsx/useSheetOffscreenSize.native.js +36 -27
  246. package/dist/jsx/useSheetOffscreenSize.native.js.map +1 -1
  247. package/dist/jsx/useSheetOpenState.mjs +14 -13
  248. package/dist/jsx/useSheetOpenState.mjs.map +1 -1
  249. package/dist/jsx/useSheetOpenState.native.js +39 -37
  250. package/dist/jsx/useSheetOpenState.native.js.map +1 -1
  251. package/dist/jsx/useSheetProviderProps.mjs +101 -55
  252. package/dist/jsx/useSheetProviderProps.mjs.map +1 -1
  253. package/dist/jsx/useSheetProviderProps.native.js +165 -122
  254. package/dist/jsx/useSheetProviderProps.native.js.map +1 -1
  255. package/dist/jsx/useSheetScrollViewGestures.mjs +112 -71
  256. package/dist/jsx/useSheetScrollViewGestures.mjs.map +1 -1
  257. package/dist/jsx/useSheetScrollViewGestures.native.js +128 -79
  258. package/dist/jsx/useSheetScrollViewGestures.native.js.map +1 -1
  259. package/next.md +78 -0
  260. package/package.json +29 -39
  261. package/setup-gesture-handler/index.cjs +2 -0
  262. package/setup-gesture-handler/index.js +2 -0
  263. package/setup-gesture-handler/index.native.cjs +2 -0
  264. package/setup-gesture-handler/index.native.js +2 -0
  265. package/src/GestureDetectorWrapper.tsx +0 -3
  266. package/src/SheetController.tsx +4 -1
  267. package/src/SheetImplementationCustom.tsx +131 -45
  268. package/src/SheetScrollView.tsx +33 -7
  269. package/src/keyboardAvoidance.ts +30 -0
  270. package/src/nativeSheet.tsx +6 -1
  271. package/src/types.tsx +5 -0
  272. package/src/useGestureHandlerPan.tsx +5 -15
  273. package/src/useSheetController.tsx +4 -0
  274. package/src/useSheetProviderProps.tsx +1 -0
  275. package/test/keyboardAvoidance.test.ts +53 -0
  276. package/tsconfig.json +57 -0
  277. package/types/GestureDetectorWrapper.d.ts.map +1 -1
  278. package/types/Sheet.d.ts +3 -0
  279. package/types/Sheet.d.ts.map +1 -1
  280. package/types/SheetContext.d.ts +1 -0
  281. package/types/SheetContext.d.ts.map +1 -1
  282. package/types/SheetController.d.ts +1 -1
  283. package/types/SheetController.d.ts.map +1 -1
  284. package/types/SheetImplementationCustom.d.ts +3 -0
  285. package/types/SheetImplementationCustom.d.ts.map +1 -1
  286. package/types/SheetScrollView.d.ts.map +1 -1
  287. package/types/createSheet.d.ts +3 -0
  288. package/types/createSheet.d.ts.map +1 -1
  289. package/types/keyboardAvoidance.d.ts +8 -0
  290. package/types/keyboardAvoidance.d.ts.map +1 -0
  291. package/types/nativeSheet.d.ts.map +1 -1
  292. package/types/types.d.ts +6 -0
  293. package/types/types.d.ts.map +1 -1
  294. package/types/useGestureHandlerPan.d.ts.map +1 -1
  295. package/types/useSheetController.d.ts +3 -0
  296. package/types/useSheetController.d.ts.map +1 -1
  297. package/types/useSheetProviderProps.d.ts +1 -0
  298. package/types/useSheetProviderProps.d.ts.map +1 -1
  299. package/dist/cjs/GestureDetectorWrapper.js +0 -29
  300. package/dist/cjs/GestureDetectorWrapper.js.map +0 -6
  301. package/dist/cjs/GestureSheetContext.js +0 -43
  302. package/dist/cjs/GestureSheetContext.js.map +0 -6
  303. package/dist/cjs/Sheet.js +0 -104
  304. package/dist/cjs/Sheet.js.map +0 -6
  305. package/dist/cjs/SheetContext.js +0 -28
  306. package/dist/cjs/SheetContext.js.map +0 -6
  307. package/dist/cjs/SheetController.js +0 -52
  308. package/dist/cjs/SheetController.js.map +0 -6
  309. package/dist/cjs/SheetImplementationCustom.js +0 -393
  310. package/dist/cjs/SheetImplementationCustom.js.map +0 -6
  311. package/dist/cjs/SheetScrollView.js +0 -137
  312. package/dist/cjs/SheetScrollView.js.map +0 -6
  313. package/dist/cjs/constants.js +0 -24
  314. package/dist/cjs/constants.js.map +0 -6
  315. package/dist/cjs/contexts.js +0 -33
  316. package/dist/cjs/contexts.js.map +0 -6
  317. package/dist/cjs/controller.js +0 -23
  318. package/dist/cjs/controller.js.map +0 -6
  319. package/dist/cjs/createSheet.js +0 -152
  320. package/dist/cjs/createSheet.js.map +0 -6
  321. package/dist/cjs/gestureState.js +0 -34
  322. package/dist/cjs/gestureState.js.map +0 -6
  323. package/dist/cjs/helpers.js +0 -26
  324. package/dist/cjs/helpers.js.map +0 -6
  325. package/dist/cjs/index.js +0 -25
  326. package/dist/cjs/index.js.map +0 -6
  327. package/dist/cjs/nativeSheet.js +0 -56
  328. package/dist/cjs/nativeSheet.js.map +0 -6
  329. package/dist/cjs/setupGestureHandler.js +0 -38
  330. package/dist/cjs/setupGestureHandler.js.map +0 -6
  331. package/dist/cjs/types.js +0 -14
  332. package/dist/cjs/types.js.map +0 -6
  333. package/dist/cjs/useGestureHandlerPan.js +0 -126
  334. package/dist/cjs/useGestureHandlerPan.js.map +0 -6
  335. package/dist/cjs/useKeyboardControllerSheet.js +0 -34
  336. package/dist/cjs/useKeyboardControllerSheet.js.map +0 -6
  337. package/dist/cjs/useSheet.js +0 -22
  338. package/dist/cjs/useSheet.js.map +0 -6
  339. package/dist/cjs/useSheetController.js +0 -39
  340. package/dist/cjs/useSheetController.js.map +0 -6
  341. package/dist/cjs/useSheetOffscreenSize.js +0 -43
  342. package/dist/cjs/useSheetOffscreenSize.js.map +0 -6
  343. package/dist/cjs/useSheetOpenState.js +0 -37
  344. package/dist/cjs/useSheetOpenState.js.map +0 -6
  345. package/dist/cjs/useSheetProviderProps.js +0 -130
  346. package/dist/cjs/useSheetProviderProps.js.map +0 -6
  347. package/dist/cjs/useSheetScrollViewGestures.js +0 -102
  348. package/dist/cjs/useSheetScrollViewGestures.js.map +0 -6
  349. package/dist/esm/GestureDetectorWrapper.js +0 -15
  350. package/dist/esm/GestureDetectorWrapper.js.map +0 -6
  351. package/dist/esm/GestureSheetContext.js +0 -28
  352. package/dist/esm/GestureSheetContext.js.map +0 -6
  353. package/dist/esm/Sheet.js +0 -92
  354. package/dist/esm/Sheet.js.map +0 -6
  355. package/dist/esm/SheetContext.js +0 -13
  356. package/dist/esm/SheetContext.js.map +0 -6
  357. package/dist/esm/SheetController.js +0 -31
  358. package/dist/esm/SheetController.js.map +0 -6
  359. package/dist/esm/SheetImplementationCustom.js +0 -395
  360. package/dist/esm/SheetImplementationCustom.js.map +0 -6
  361. package/dist/esm/SheetScrollView.js +0 -122
  362. package/dist/esm/SheetScrollView.js.map +0 -6
  363. package/dist/esm/constants.js +0 -8
  364. package/dist/esm/constants.js.map +0 -6
  365. package/dist/esm/contexts.js +0 -9
  366. package/dist/esm/contexts.js.map +0 -6
  367. package/dist/esm/controller.js +0 -11
  368. package/dist/esm/controller.js.map +0 -6
  369. package/dist/esm/createSheet.js +0 -153
  370. package/dist/esm/createSheet.js.map +0 -6
  371. package/dist/esm/gestureState.js +0 -18
  372. package/dist/esm/gestureState.js.map +0 -6
  373. package/dist/esm/helpers.js +0 -10
  374. package/dist/esm/helpers.js.map +0 -6
  375. package/dist/esm/nativeSheet.js +0 -46
  376. package/dist/esm/nativeSheet.js.map +0 -6
  377. package/dist/esm/setupGestureHandler.js +0 -22
  378. package/dist/esm/setupGestureHandler.js.map +0 -6
  379. package/dist/esm/types.js +0 -1
  380. package/dist/esm/types.js.map +0 -6
  381. package/dist/esm/useGestureHandlerPan.js +0 -111
  382. package/dist/esm/useGestureHandlerPan.js.map +0 -6
  383. package/dist/esm/useKeyboardControllerSheet.js +0 -18
  384. package/dist/esm/useKeyboardControllerSheet.js.map +0 -6
  385. package/dist/esm/useSheet.js +0 -6
  386. package/dist/esm/useSheet.js.map +0 -6
  387. package/dist/esm/useSheetController.js +0 -15
  388. package/dist/esm/useSheetController.js.map +0 -6
  389. package/dist/esm/useSheetOffscreenSize.js +0 -27
  390. package/dist/esm/useSheetOffscreenSize.js.map +0 -6
  391. package/dist/esm/useSheetOpenState.js +0 -22
  392. package/dist/esm/useSheetOpenState.js.map +0 -6
  393. package/dist/esm/useSheetProviderProps.js +0 -109
  394. package/dist/esm/useSheetProviderProps.js.map +0 -6
  395. package/dist/esm/useSheetScrollViewGestures.js +0 -86
  396. package/dist/esm/useSheetScrollViewGestures.js.map +0 -6
  397. package/dist/jsx/GestureDetectorWrapper.js +0 -15
  398. package/dist/jsx/GestureDetectorWrapper.js.map +0 -6
  399. package/dist/jsx/GestureSheetContext.js +0 -28
  400. package/dist/jsx/GestureSheetContext.js.map +0 -6
  401. package/dist/jsx/Sheet.js +0 -92
  402. package/dist/jsx/Sheet.js.map +0 -6
  403. package/dist/jsx/SheetContext.js +0 -13
  404. package/dist/jsx/SheetContext.js.map +0 -6
  405. package/dist/jsx/SheetController.js +0 -31
  406. package/dist/jsx/SheetController.js.map +0 -6
  407. package/dist/jsx/SheetImplementationCustom.js +0 -395
  408. package/dist/jsx/SheetImplementationCustom.js.map +0 -6
  409. package/dist/jsx/SheetScrollView.js +0 -122
  410. package/dist/jsx/SheetScrollView.js.map +0 -6
  411. package/dist/jsx/constants.js +0 -8
  412. package/dist/jsx/constants.js.map +0 -6
  413. package/dist/jsx/contexts.js +0 -9
  414. package/dist/jsx/contexts.js.map +0 -6
  415. package/dist/jsx/controller.js +0 -11
  416. package/dist/jsx/controller.js.map +0 -6
  417. package/dist/jsx/createSheet.js +0 -153
  418. package/dist/jsx/createSheet.js.map +0 -6
  419. package/dist/jsx/gestureState.js +0 -18
  420. package/dist/jsx/gestureState.js.map +0 -6
  421. package/dist/jsx/helpers.js +0 -10
  422. package/dist/jsx/helpers.js.map +0 -6
  423. package/dist/jsx/nativeSheet.js +0 -46
  424. package/dist/jsx/nativeSheet.js.map +0 -6
  425. package/dist/jsx/setupGestureHandler.js +0 -22
  426. package/dist/jsx/setupGestureHandler.js.map +0 -6
  427. package/dist/jsx/types.js +0 -1
  428. package/dist/jsx/types.js.map +0 -6
  429. package/dist/jsx/useGestureHandlerPan.js +0 -111
  430. package/dist/jsx/useGestureHandlerPan.js.map +0 -6
  431. package/dist/jsx/useKeyboardControllerSheet.js +0 -18
  432. package/dist/jsx/useKeyboardControllerSheet.js.map +0 -6
  433. package/dist/jsx/useSheet.js +0 -6
  434. package/dist/jsx/useSheet.js.map +0 -6
  435. package/dist/jsx/useSheetController.js +0 -15
  436. package/dist/jsx/useSheetController.js.map +0 -6
  437. package/dist/jsx/useSheetOffscreenSize.js +0 -27
  438. package/dist/jsx/useSheetOffscreenSize.js.map +0 -6
  439. package/dist/jsx/useSheetOpenState.js +0 -22
  440. package/dist/jsx/useSheetOpenState.js.map +0 -6
  441. package/dist/jsx/useSheetProviderProps.js +0 -109
  442. package/dist/jsx/useSheetProviderProps.js.map +0 -6
  443. package/dist/jsx/useSheetScrollViewGestures.js +0 -86
  444. package/dist/jsx/useSheetScrollViewGestures.js.map +0 -6
  445. package/types/GestureDetectorWrapper.native.d.ts +0 -14
  446. package/types/gestureState.native.d.ts +0 -12
  447. package/types/setupGestureHandler.native.d.ts +0 -41
  448. package/types/useGestureHandlerPan.native.d.ts +0 -33
  449. package/types/useSheetScrollViewGestures.web.d.ts +0 -15
  450. package/types/useSheetScrollViewGestures.web.d.ts.map +0 -1
@@ -3,481 +3,593 @@ import { ProvideAdaptContext, useAdaptContext } from "@tamagui/adapt";
3
3
  import { AnimatePresence } from "@tamagui/animate-presence";
4
4
  import { useComposedRefs } from "@tamagui/compose-refs";
5
5
  import { isWeb, useIsomorphicLayoutEffect } from "@tamagui/constants";
6
- import { LayoutMeasurementController, View as TamaguiView, Theme, useConfiguration, useDidFinishSSR, useEvent, useThemeName } from "@tamagui/core";
6
+ import { LayoutMeasurementController, View as TamaguiView, useConfiguration, useDidFinishSSR, useEvent, useThemeName } from "@tamagui/core";
7
7
  import { getSafeArea } from "@tamagui/native";
8
8
  import { needsPortalRepropagation, Portal } from "@tamagui/portal";
9
9
  import React, { useState } from "react";
10
10
  import { Dimensions, PanResponder, View } from "react-native";
11
11
  import { ParentSheetContext, SheetInsideSheetContext } from "./contexts.native.js";
12
12
  import { GestureDetectorWrapper } from "./GestureDetectorWrapper.native.js";
13
+ import { getGestureHandlerState } from "./gestureState.native.js";
13
14
  import { GestureSheetProvider } from "./GestureSheetContext.native.js";
14
15
  import { resisted } from "./helpers.native.js";
16
+ import { getKeyboardOccludedHeight } from "./keyboardAvoidance.native.js";
15
17
  import { SheetProvider } from "./SheetContext.native.js";
16
18
  import { useGestureHandlerPan } from "./useGestureHandlerPan.native.js";
17
19
  import { useKeyboardControllerSheet } from "./useKeyboardControllerSheet.native.js";
18
20
  import { useSheetOpenState } from "./useSheetOpenState.native.js";
19
21
  import { useSheetProviderProps } from "./useSheetProviderProps.native.js";
20
- var hiddenSize = 10000.1,
21
- _cachedSafeAreaTop;
22
+ var hiddenSize = 10000.1;
23
+ var rnghRootStyleOpen = {
24
+ width: "100%",
25
+ height: "100%"
26
+ };
27
+ var rnghRootStyleClosed = {
28
+ width: "100%",
29
+ height: 0
30
+ };
31
+ var _cachedSafeAreaTop;
22
32
  function getSafeAreaTopInset() {
23
- return _cachedSafeAreaTop !== void 0 || (_cachedSafeAreaTop = getSafeArea().getInsets().top), _cachedSafeAreaTop;
33
+ if (_cachedSafeAreaTop !== void 0) return _cachedSafeAreaTop;
34
+ _cachedSafeAreaTop = getSafeArea().getInsets().top;
35
+ return _cachedSafeAreaTop;
24
36
  }
25
- var relativeDimensionTo = isWeb ? "window" : "screen",
26
- SheetImplementationCustom = /* @__PURE__ */React.forwardRef(function (props, forwardedRef) {
27
- var parentSheet = React.useContext(ParentSheetContext),
28
- {
29
- transition,
30
- transitionConfig: transitionConfigProp,
31
- modal = !1,
32
- zIndex = parentSheet.zIndex + 1,
33
- moveOnKeyboardChange = !1,
34
- unmountChildrenWhenHidden = !1,
35
- portalProps,
36
- containerComponent: ContainerComponent = React.Fragment
37
- } = props,
38
- state = useSheetOpenState(props),
39
- [overlayComponent, setOverlayComponent] = React.useState(null),
40
- providerProps = useSheetProviderProps(props, state, {
41
- onOverlayComponent: setOverlayComponent
42
- }),
43
- {
44
- frameSize,
45
- setFrameSize,
46
- snapPoints,
47
- snapPointsMode,
48
- hasFit,
49
- position,
50
- setPosition,
51
- scrollBridge,
52
- screenSize,
53
- setMaxContentSize,
54
- maxSnapPoint
55
- } = providerProps,
56
- {
57
- open,
58
- controller,
59
- isHidden
60
- } = state,
61
- sheetRef = React.useRef(void 0),
62
- ref = useComposedRefs(forwardedRef, sheetRef, providerProps.contentRef),
63
- {
64
- animationDriver
65
- } = useConfiguration();
66
- if (!animationDriver) throw new Error("Sheet requires an animation driver to be set");
67
- var transitionConfig = function () {
68
- var _animationDriver_animations;
69
- if (transitionConfigProp) return transitionConfigProp;
70
- var [animationProp, animationPropConfig] = transition ? Array.isArray(transition) ? transition : [transition] : [];
71
- return animationProp && !((_animationDriver_animations = animationDriver.animations) === null || _animationDriver_animations === void 0) && _animationDriver_animations[animationProp] ? {
72
- ...animationDriver.animations[animationProp],
73
- ...animationPropConfig
74
- } : null;
75
- }(),
76
- [isShowingInnerSheet, setIsShowingInnerSheet] = React.useState(!1),
77
- shouldHideParentSheet = !isWeb && modal && isShowingInnerSheet && needsPortalRepropagation(),
78
- sheetInsideSheet = React.useContext(SheetInsideSheetContext),
79
- onInnerSheet = React.useCallback(function (hasChild) {
80
- setIsShowingInnerSheet(hasChild);
81
- }, []),
82
- stableFrameSize = React.useRef(frameSize);
83
- React.useEffect(function () {
84
- open && frameSize && (stableFrameSize.current = frameSize);
85
- }, [open, frameSize]);
86
- var effectiveFrameSize = open ? frameSize : stableFrameSize.current || frameSize,
87
- positions = React.useMemo(function () {
88
- return snapPoints.map(function (point) {
89
- return getYPositions(snapPointsMode, point, screenSize, effectiveFrameSize);
90
- });
91
- }, [screenSize, effectiveFrameSize, snapPoints, snapPointsMode]),
92
- {
93
- keyboardHeight,
94
- isKeyboardVisible,
95
- dismissKeyboard,
96
- pauseKeyboardHandler,
97
- flushPendingHide
98
- } = useKeyboardControllerSheet({
99
- enabled: !isWeb && !!moveOnKeyboardChange
100
- }),
101
- [isDragging, setIsDragging_] = React.useState(!1),
102
- isDraggingRef = React.useRef(!1),
103
- setIsDragging = React.useCallback(function (val) {
104
- isDraggingRef.current = val, pauseKeyboardHandler.current = val, setIsDragging_(val), val || flushPendingHide();
105
- }, [pauseKeyboardHandler, flushPendingHide]),
106
- activePositionsRef = React.useRef(positions),
107
- activePositions = React.useMemo(function () {
108
- if (isDragging || isDraggingRef.current) return activePositionsRef.current;
109
- var result;
110
- if (!isKeyboardVisible || keyboardHeight <= 0) result = positions;else {
111
- var safeAreaTop = isWeb ? 0 : getSafeAreaTopInset();
112
- result = positions.map(function (p) {
113
- return screenSize && p >= screenSize ? p : Math.max(safeAreaTop, p - keyboardHeight);
114
- });
115
- }
116
- return activePositionsRef.current = result, result;
117
- }, [positions, isKeyboardVisible, keyboardHeight, screenSize, isDragging]),
118
- {
119
- useAnimatedNumber,
120
- useAnimatedNumberStyle,
121
- useAnimatedNumberReaction
122
- } = animationDriver,
123
- _animationDriver_View,
124
- AnimatedView = (_animationDriver_View = animationDriver.View) !== null && _animationDriver_View !== void 0 ? _animationDriver_View : TamaguiView;
125
- useIsomorphicLayoutEffect(function () {
126
- if (sheetInsideSheet && open) return sheetInsideSheet(!0), function () {
127
- sheetInsideSheet(!1);
128
- };
129
- }, [sheetInsideSheet, open]);
130
- var nextParentContext = React.useMemo(function () {
131
- return {
132
- zIndex
133
- };
134
- }, [zIndex]),
135
- isMounted = useDidFinishSSR(),
136
- startPosition = isMounted && screenSize ? screenSize : hiddenSize,
137
- animatedNumber = useAnimatedNumber(startPosition),
138
- at = React.useRef(startPosition),
139
- hasntMeasured = at.current === hiddenSize,
140
- [disableAnimation, setDisableAnimation] = useState(hasntMeasured),
141
- skipAdaptAnimation = React.useRef(!1);
142
- controller?.skipNextAnimation && (skipAdaptAnimation.current = !0);
143
- var hasScrollView = React.useRef(!1);
144
- useAnimatedNumberReaction({
145
- value: animatedNumber,
146
- hostRef: sheetRef
147
- }, React.useCallback(function (value) {
148
- at.current = value, scrollBridge.paneY = value;
149
- var minY = activePositions[0],
150
- wasAtTop = scrollBridge.isAtTop,
151
- nowAtTop = value <= minY + 5;
152
- if (wasAtTop !== nowAtTop) if (scrollBridge.isAtTop = nowAtTop, nowAtTop) {
37
+ var relativeDimensionTo = isWeb ? "window" : "screen";
38
+ var SheetImplementationCustom = /* @__PURE__ */React.forwardRef(function SheetImplementationCustom2(props, forwardedRef) {
39
+ var parentSheet = React.useContext(ParentSheetContext);
40
+ var {
41
+ transition,
42
+ transitionConfig: transitionConfigProp,
43
+ modal = false,
44
+ zIndex = parentSheet.zIndex + 1,
45
+ moveOnKeyboardChange = false,
46
+ unmountChildrenWhenHidden = false,
47
+ portalProps,
48
+ containerComponent: ContainerComponent = React.Fragment,
49
+ onAnimationComplete
50
+ } = props;
51
+ var state = useSheetOpenState(props);
52
+ var [overlayComponent, setOverlayComponent] = React.useState(null);
53
+ var providerProps = useSheetProviderProps(props, state, {
54
+ onOverlayComponent: setOverlayComponent
55
+ });
56
+ var {
57
+ frameSize,
58
+ setFrameSize,
59
+ snapPoints,
60
+ snapPointsMode,
61
+ hasFit,
62
+ position,
63
+ setPosition,
64
+ scrollBridge,
65
+ screenSize,
66
+ setMaxContentSize,
67
+ maxSnapPoint
68
+ } = providerProps;
69
+ var {
70
+ open,
71
+ controller,
72
+ isHidden
73
+ } = state;
74
+ var openRef = React.useRef(open);
75
+ openRef.current = open;
76
+ var sheetRef = React.useRef(void 0);
77
+ var ref = useComposedRefs(forwardedRef, sheetRef, providerProps.contentRef);
78
+ var {
79
+ animationDriver
80
+ } = useConfiguration();
81
+ if (!animationDriver) throw new Error(`Sheet requires an animation driver to be set`);
82
+ var transitionConfig = function () {
83
+ var _animationDriver_animations;
84
+ if (transitionConfigProp) return transitionConfigProp;
85
+ var [animationProp, animationPropConfig] = !transition ? [] : Array.isArray(transition) ? transition : [transition];
86
+ if (animationProp && ((_animationDriver_animations = animationDriver.animations) === null || _animationDriver_animations === void 0 ? void 0 : _animationDriver_animations[animationProp])) return {
87
+ ...animationDriver.animations[animationProp],
88
+ ...animationPropConfig
89
+ };
90
+ return null;
91
+ }();
92
+ var [isShowingInnerSheet, setIsShowingInnerSheet] = React.useState(false);
93
+ var shouldHideParentSheet = !isWeb && modal && isShowingInnerSheet && needsPortalRepropagation();
94
+ var sheetInsideSheet = React.useContext(SheetInsideSheetContext);
95
+ var onInnerSheet = React.useCallback(function (hasChild) {
96
+ setIsShowingInnerSheet(hasChild);
97
+ }, []);
98
+ var stableFrameSize = React.useRef(frameSize);
99
+ React.useEffect(function () {
100
+ if (open && frameSize) stableFrameSize.current = frameSize;
101
+ }, [open, frameSize]);
102
+ var effectiveFrameSize = open ? frameSize : stableFrameSize.current || frameSize;
103
+ var positions = React.useMemo(function () {
104
+ return snapPoints.map(function (point) {
105
+ return getYPositions(snapPointsMode, point, screenSize, effectiveFrameSize);
106
+ });
107
+ }, [screenSize, effectiveFrameSize, snapPoints, snapPointsMode]);
108
+ var {
109
+ keyboardHeight,
110
+ isKeyboardVisible,
111
+ dismissKeyboard,
112
+ pauseKeyboardHandler,
113
+ flushPendingHide
114
+ } = useKeyboardControllerSheet({
115
+ enabled: !isWeb && Boolean(moveOnKeyboardChange)
116
+ });
117
+ var [isDragging, setIsDragging_] = React.useState(false);
118
+ var isDraggingRef = React.useRef(false);
119
+ var setIsDragging = React.useCallback(function (val) {
120
+ isDraggingRef.current = val;
121
+ pauseKeyboardHandler.current = val;
122
+ setIsDragging_(val);
123
+ if (!val) flushPendingHide();
124
+ }, [pauseKeyboardHandler, flushPendingHide]);
125
+ var activePositionsRef = React.useRef(positions);
126
+ var activePositions = React.useMemo(function () {
127
+ if (isDragging || isDraggingRef.current) return activePositionsRef.current;
128
+ var result;
129
+ if (!isKeyboardVisible || keyboardHeight <= 0) result = positions;else {
130
+ var safeAreaTop = isWeb ? 0 : getSafeAreaTopInset();
131
+ result = positions.map(function (p) {
132
+ if (screenSize && p >= screenSize) return p;
133
+ return Math.max(safeAreaTop, p - keyboardHeight);
134
+ });
135
+ }
136
+ activePositionsRef.current = result;
137
+ return result;
138
+ }, [positions, isKeyboardVisible, keyboardHeight, screenSize, isDragging]);
139
+ var keyboardOccludedHeight = getKeyboardOccludedHeight({
140
+ frameSize,
141
+ isKeyboardVisible: !isWeb && isKeyboardVisible,
142
+ keyboardHeight,
143
+ screenSize,
144
+ sheetY: position >= 0 ? activePositions[position] : void 0
145
+ });
146
+ var {
147
+ useAnimatedNumber,
148
+ useAnimatedNumberStyle,
149
+ useAnimatedNumberReaction
150
+ } = animationDriver;
151
+ var _animationDriver_View;
152
+ var AnimatedView = (_animationDriver_View = animationDriver.View) !== null && _animationDriver_View !== void 0 ? _animationDriver_View : TamaguiView;
153
+ useIsomorphicLayoutEffect(function () {
154
+ if (!(sheetInsideSheet && open)) return;
155
+ sheetInsideSheet(true);
156
+ return function () {
157
+ sheetInsideSheet(false);
158
+ };
159
+ }, [sheetInsideSheet, open]);
160
+ var nextParentContext = React.useMemo(function () {
161
+ return {
162
+ zIndex
163
+ };
164
+ }, [zIndex]);
165
+ var startPosition = useDidFinishSSR() && screenSize ? screenSize : hiddenSize;
166
+ var animatedNumber = useAnimatedNumber(startPosition);
167
+ var at = React.useRef(startPosition);
168
+ var hasntMeasured = at.current === hiddenSize;
169
+ var [disableAnimation, setDisableAnimation] = useState(hasntMeasured);
170
+ var skipAdaptAnimation = React.useRef(false);
171
+ if (controller === null || controller === void 0 ? void 0 : controller.skipNextAnimation) skipAdaptAnimation.current = true;
172
+ var hasScrollView = React.useRef(false);
173
+ var opacityFallbackTimer = React.useRef(null);
174
+ useAnimatedNumberReaction({
175
+ value: animatedNumber,
176
+ hostRef: sheetRef
177
+ }, React.useCallback(function (value) {
178
+ at.current = value;
179
+ scrollBridge.paneY = value;
180
+ var minY = activePositions[0];
181
+ var wasAtTop = scrollBridge.isAtTop;
182
+ var nowAtTop = value <= minY + 5;
183
+ if (wasAtTop !== nowAtTop) {
184
+ scrollBridge.isAtTop = nowAtTop;
185
+ if (nowAtTop) {
153
186
  var _scrollBridge_setScrollEnabled;
154
- scrollBridge.scrollLockY = void 0, (_scrollBridge_setScrollEnabled = scrollBridge.setScrollEnabled) === null || _scrollBridge_setScrollEnabled === void 0 || _scrollBridge_setScrollEnabled.call(scrollBridge, !0);
187
+ if (scrollBridge.y > 0) {
188
+ var _scrollBridge_forceScrollTo;
189
+ (_scrollBridge_forceScrollTo = scrollBridge.forceScrollTo) === null || _scrollBridge_forceScrollTo === void 0 || _scrollBridge_forceScrollTo.call(scrollBridge, 0);
190
+ scrollBridge.y = 0;
191
+ }
192
+ scrollBridge.scrollLockY = void 0;
193
+ (_scrollBridge_setScrollEnabled = scrollBridge.setScrollEnabled) === null || _scrollBridge_setScrollEnabled === void 0 || _scrollBridge_setScrollEnabled.call(scrollBridge, true);
155
194
  } else {
156
195
  var _scrollBridge_setScrollEnabled1;
157
- scrollBridge.scrollLockY = 0, (_scrollBridge_setScrollEnabled1 = scrollBridge.setScrollEnabled) === null || _scrollBridge_setScrollEnabled1 === void 0 || _scrollBridge_setScrollEnabled1.call(scrollBridge, !1);
196
+ scrollBridge.scrollLockY = 0;
197
+ (_scrollBridge_setScrollEnabled1 = scrollBridge.setScrollEnabled) === null || _scrollBridge_setScrollEnabled1 === void 0 || _scrollBridge_setScrollEnabled1.call(scrollBridge, false);
158
198
  }
159
- }, [animationDriver, activePositions]));
160
- function stopSpring() {
161
- animatedNumber.stop(), scrollBridge.onFinishAnimate && (scrollBridge.onFinishAnimate(), scrollBridge.onFinishAnimate = void 0);
162
199
  }
163
- var animateTo = useEvent(function (position2, animationOverride) {
164
- if (frameSize !== 0) {
165
- var toValue = isHidden || position2 === -1 ? screenSize : activePositions[position2];
166
- if (at.current !== toValue) {
167
- if (at.current = toValue, stopSpring(), skipAdaptAnimation.current) {
168
- skipAdaptAnimation.current = !1, animatedNumber.setValue(toValue, {
169
- type: "timing",
170
- duration: 0
171
- });
172
- return;
173
- }
174
- animatedNumber.setValue(toValue, animationOverride || {
175
- type: "spring",
176
- ...transitionConfig
177
- });
178
- }
179
- }
180
- });
181
- useIsomorphicLayoutEffect(function () {
182
- if (hasntMeasured && screenSize && frameSize) {
183
- at.current = screenSize, animatedNumber.setValue(screenSize, {
184
- type: "timing",
185
- duration: 0
186
- }, function () {
187
- setTimeout(function () {
188
- setDisableAnimation(!1);
189
- }, 10);
190
- });
191
- return;
192
- }
193
- if (!disableAnimation && !(!frameSize || !screenSize || isHidden || hasntMeasured && !open) && (animateTo(position), position === -1 && (scrollBridge.scrollLock = !1, scrollBridge.scrollStartY = -1), open && position >= 0)) {
194
- var isTopPosition = position === 0;
195
- if (scrollBridge.isAtTop = isTopPosition, isTopPosition) {
196
- var _scrollBridge_setScrollEnabled;
197
- scrollBridge.scrollLockY = void 0, (_scrollBridge_setScrollEnabled = scrollBridge.setScrollEnabled) === null || _scrollBridge_setScrollEnabled === void 0 || _scrollBridge_setScrollEnabled.call(scrollBridge, !0);
198
- } else {
199
- var _scrollBridge_setScrollEnabled1;
200
- scrollBridge.scrollLockY = 0, (_scrollBridge_setScrollEnabled1 = scrollBridge.setScrollEnabled) === null || _scrollBridge_setScrollEnabled1 === void 0 || _scrollBridge_setScrollEnabled1.call(scrollBridge, !1);
201
- }
200
+ }, [animationDriver, activePositions]));
201
+ function stopSpring() {
202
+ animatedNumber.stop();
203
+ if (scrollBridge.onFinishAnimate) {
204
+ scrollBridge.onFinishAnimate();
205
+ scrollBridge.onFinishAnimate = void 0;
206
+ }
207
+ }
208
+ var animateTo = useEvent(function (position2, animationOverride) {
209
+ if (frameSize === 0) return;
210
+ var toValue = isHidden || position2 === -1 ? screenSize : activePositions[position2];
211
+ if (at.current === toValue) return;
212
+ at.current = toValue;
213
+ stopSpring();
214
+ var isOpenAnimation = position2 !== -1 && !isHidden;
215
+ if (opacityFallbackTimer.current) {
216
+ clearTimeout(opacityFallbackTimer.current);
217
+ opacityFallbackTimer.current = null;
218
+ }
219
+ var animationCompleteCallback = function () {
220
+ var _controller_onAnimationComplete;
221
+ if (opacityFallbackTimer.current) {
222
+ clearTimeout(opacityFallbackTimer.current);
223
+ opacityFallbackTimer.current = null;
202
224
  }
203
- }, [hasntMeasured, disableAnimation, isHidden, frameSize, screenSize, open, position]);
204
- var _props_disableDrag,
205
- disableDrag = (_props_disableDrag = props.disableDrag) !== null && _props_disableDrag !== void 0 ? _props_disableDrag : controller?.disableDrag,
206
- themeName = useThemeName(),
207
- [blockPan, setBlockPan] = React.useState(!1),
208
- panResponder = React.useMemo(function () {
209
- if (disableDrag || !frameSize || isShowingInnerSheet) return;
210
- var minY = positions[0];
211
- scrollBridge.paneMinY = minY;
212
- var startY = at.current;
213
- function setPanning(val) {
214
- setIsDragging(val);
215
- }
216
- var release = function (param) {
217
- var {
218
- vy
219
- } = param;
220
- if (scrollBridge.setParentDragging(!1), !scrollBridge.scrollLock) {
221
- isExternalDrag = !1, previouslyScrolling = !1, setPanning(!1);
222
- for (var currentPos = at.current, end = currentPos + frameSize * vy * 0.2, closestPoint = 0, dist = Number.POSITIVE_INFINITY, i = 0; i < positions.length; i++) {
223
- var position2 = positions[i],
224
- curDist = end > position2 ? end - position2 : position2 - end;
225
- curDist < dist && (dist = curDist, closestPoint = i);
226
- }
227
- setPosition(closestPoint), animateTo(closestPoint);
228
- }
229
- },
230
- finish = function (_e, state2) {
231
- release({
232
- vy: state2.vy,
233
- dragAt: state2.dy
234
- });
235
- },
236
- previouslyScrolling = !1,
237
- onMoveShouldSet = function (e, param) {
238
- var {
239
- dy
240
- } = param;
241
- function getShouldSet() {
242
- if (e.target === providerProps.handleRef.current) return !0;
243
- if (scrollBridge.hasScrollableContent === !0) {
244
- if (scrollBridge.scrollLock) return !1;
245
- var isScrolled = scrollBridge.y !== 0,
246
- isDraggingUp = dy < 0,
247
- isNearTop = scrollBridge.paneY - 5 <= scrollBridge.paneMinY;
248
- if (isScrolled) return previouslyScrolling = !0, !1;
249
- if (isNearTop && hasScrollView.current && isDraggingUp) return !1;
250
- }
251
- return Math.abs(dy) > 10;
252
- }
253
- var granted = getShouldSet();
254
- return granted && scrollBridge.setParentDragging(!0), granted;
255
- },
256
- grant = function () {
257
- setPanning(!0), stopSpring(), startY = at.current;
258
- },
259
- isExternalDrag = !1;
260
- return scrollBridge.drag = function (dy) {
261
- isExternalDrag || (isExternalDrag = !0, grant());
262
- var to = dy + startY;
263
- animatedNumber.setValue(resisted(to, minY), {
264
- type: "direct"
265
- });
266
- }, scrollBridge.release = release, scrollBridge.snapToPosition = function (positionIndex) {
267
- isExternalDrag = !1, previouslyScrolling = !1, setPanning(!1), setPosition(positionIndex), animateTo(positionIndex);
268
- }, PanResponder.create({
269
- onMoveShouldSetPanResponder: onMoveShouldSet,
270
- onPanResponderGrant: grant,
271
- onPanResponderMove: function (_e, param) {
272
- var {
273
- dy
274
- } = param,
275
- toFull = dy + startY,
276
- to = resisted(toFull, minY),
277
- isAtTop = to <= minY;
278
- isAtTop ? scrollBridge.setParentDragging(!1) : scrollBridge.setParentDragging(!0), animatedNumber.setValue(to, {
279
- type: "direct"
280
- });
281
- },
282
- onPanResponderEnd: finish,
283
- onPanResponderTerminate: finish,
284
- onPanResponderRelease: finish
285
- });
286
- }, [disableDrag, isShowingInnerSheet, animateTo, frameSize, positions, setPosition]);
287
- React.useEffect(function () {
288
- isDragging || isHidden || !open || disableAnimation || !frameSize || !screenSize || animateTo(position, {
225
+ if (!isOpenAnimation && !openRef.current) setOpacity(0);
226
+ onAnimationComplete === null || onAnimationComplete === void 0 || onAnimationComplete({
227
+ open: isOpenAnimation
228
+ });
229
+ controller === null || controller === void 0 || (_controller_onAnimationComplete = controller.onAnimationComplete) == null || _controller_onAnimationComplete.call(controller, {
230
+ open: isOpenAnimation
231
+ });
232
+ };
233
+ if (!isOpenAnimation) opacityFallbackTimer.current = setTimeout(function () {
234
+ opacityFallbackTimer.current = null;
235
+ if (!openRef.current) setOpacity(0);
236
+ }, 1e3);
237
+ if (skipAdaptAnimation.current) {
238
+ skipAdaptAnimation.current = false;
239
+ animatedNumber.setValue(toValue, {
240
+ type: "timing",
241
+ duration: 0
242
+ }, animationCompleteCallback);
243
+ return;
244
+ }
245
+ animatedNumber.setValue(toValue, animationOverride || {
246
+ type: "spring",
247
+ ...transitionConfig
248
+ }, animationCompleteCallback);
249
+ });
250
+ useIsomorphicLayoutEffect(function () {
251
+ if (hasntMeasured && screenSize && frameSize) {
252
+ at.current = screenSize;
253
+ animatedNumber.setValue(screenSize, {
289
254
  type: "timing",
290
- duration: 250
255
+ duration: 0
256
+ }, function () {
257
+ setTimeout(function () {
258
+ setDisableAnimation(false);
259
+ }, 10);
291
260
  });
292
- }, [isKeyboardVisible, keyboardHeight]);
293
- var wasDragging = React.useRef(!1);
294
- React.useEffect(function () {
295
- if (isDragging) {
296
- wasDragging.current = !0;
297
- return;
261
+ return;
262
+ }
263
+ if (disableAnimation) return;
264
+ if (!frameSize || !screenSize || isHidden || hasntMeasured && !open) return;
265
+ animateTo(position);
266
+ if (position === -1) {
267
+ scrollBridge.scrollLock = false;
268
+ scrollBridge.scrollStartY = -1;
269
+ }
270
+ if (open && position >= 0) {
271
+ var isTopPosition = position === 0;
272
+ scrollBridge.isAtTop = isTopPosition;
273
+ if (isTopPosition) {
274
+ var _scrollBridge_setScrollEnabled;
275
+ scrollBridge.scrollLockY = void 0;
276
+ (_scrollBridge_setScrollEnabled = scrollBridge.setScrollEnabled) === null || _scrollBridge_setScrollEnabled === void 0 || _scrollBridge_setScrollEnabled.call(scrollBridge, true);
277
+ } else {
278
+ var _scrollBridge_setScrollEnabled1;
279
+ scrollBridge.scrollLockY = 0;
280
+ (_scrollBridge_setScrollEnabled1 = scrollBridge.setScrollEnabled) === null || _scrollBridge_setScrollEnabled1 === void 0 || _scrollBridge_setScrollEnabled1.call(scrollBridge, false);
298
281
  }
299
- wasDragging.current && (wasDragging.current = !1, !(!frameSize || !screenSize || isHidden || !open) && animateTo(position));
300
- }, [isDragging]), React.useEffect(function () {
301
- !open && isKeyboardVisible && dismissKeyboard();
302
- }, [open]);
303
- var {
304
- panGesture,
305
- panGestureRef,
306
- gestureHandlerEnabled
307
- } = useGestureHandlerPan({
308
- positions: activePositions,
309
- frameSize,
310
- setPosition,
311
- animateTo,
312
- stopSpring,
313
- scrollBridge,
314
- setIsDragging,
315
- getCurrentPosition: function () {
316
- return at.current;
317
- },
318
- resisted,
319
- disableDrag,
320
- isShowingInnerSheet,
321
- setAnimatedPosition: function (val) {
322
- at.current = val, animatedNumber.setValue(val, {
323
- type: "direct"
324
- });
325
- },
326
- pauseKeyboardHandler
327
- }),
328
- handleAnimationViewLayout = React.useCallback(function (e) {
329
- var _e_nativeEvent;
330
- if (!(!open && stableFrameSize.current !== 0)) {
331
- var layoutHeight = (_e_nativeEvent = e.nativeEvent) === null || _e_nativeEvent === void 0 ? void 0 : _e_nativeEvent.layout.height,
332
- next = modal ? Math.min(layoutHeight, Dimensions.get(relativeDimensionTo).height) : layoutHeight;
333
- next && setFrameSize(next);
282
+ }
283
+ }, [hasntMeasured, disableAnimation, isHidden, frameSize, screenSize, open, position]);
284
+ var _props_disableDrag;
285
+ var disableDrag = (_props_disableDrag = props.disableDrag) !== null && _props_disableDrag !== void 0 ? _props_disableDrag : controller === null || controller === void 0 ? void 0 : controller.disableDrag;
286
+ useThemeName();
287
+ var [blockPan, setBlockPan] = React.useState(false);
288
+ var panResponder = React.useMemo(function () {
289
+ if (disableDrag) return;
290
+ if (!frameSize) return;
291
+ if (isShowingInnerSheet) return;
292
+ var minY = positions[0];
293
+ scrollBridge.paneMinY = minY;
294
+ var startY = at.current;
295
+ function setPanning(val) {
296
+ setIsDragging(val);
297
+ }
298
+ var release = function (param) {
299
+ var {
300
+ vy
301
+ } = param;
302
+ scrollBridge.setParentDragging(false);
303
+ if (scrollBridge.scrollLock) return;
304
+ isExternalDrag = false;
305
+ previouslyScrolling = false;
306
+ setPanning(false);
307
+ var end = at.current + frameSize * vy * .2;
308
+ var closestPoint = 0;
309
+ var dist = Number.POSITIVE_INFINITY;
310
+ for (var i = 0; i < positions.length; i++) {
311
+ var position2 = positions[i];
312
+ var curDist = end > position2 ? end - position2 : position2 - end;
313
+ if (curDist < dist) {
314
+ dist = curDist;
315
+ closestPoint = i;
334
316
  }
335
- }, [open, modal]),
336
- handleMaxContentViewLayout = React.useCallback(function (e) {
337
- var _e_nativeEvent,
338
- next = Math.min((_e_nativeEvent = e.nativeEvent) === null || _e_nativeEvent === void 0 ? void 0 : _e_nativeEvent.layout.height, Dimensions.get(relativeDimensionTo).height);
339
- next && setMaxContentSize(next);
340
- }, []),
341
- animatedStyle = useAnimatedNumberStyle(animatedNumber, function (val) {
342
- "worklet";
343
-
344
- var translateY = frameSize === 0 ? hiddenSize : val;
345
- return {
346
- transform: [{
347
- translateY
348
- }]
349
- };
350
- }),
351
- [opacity, setOpacity] = React.useState(open ? 1 : 0);
352
- open && opacity === 0 && setOpacity(1), React.useEffect(function () {
353
- if (!open) {
354
- var tm = setTimeout(function () {
355
- setOpacity(0);
356
- }, 400);
357
- return function () {
358
- clearTimeout(tm);
359
- };
360
317
  }
361
- }, [open]);
362
- var forcedContentHeight = hasFit ? void 0 : snapPointsMode === "percent" ?
363
- // Use dvh for modal (viewport-relative), % for inline (container-relative)
364
- `${maxSnapPoint}${isWeb && modal ? "dvh" : "%"}` : maxSnapPoint,
365
- setHasScrollView = React.useCallback(function (val) {
366
- hasScrollView.current = val;
367
- }, []),
368
- contents = /* @__PURE__ */_jsx(LayoutMeasurementController, {
369
- disable: !open,
370
- children: /* @__PURE__ */_jsx(ParentSheetContext.Provider, {
371
- value: nextParentContext,
372
- children: /* @__PURE__ */_jsx(SheetProvider, {
373
- ...providerProps,
374
- setHasScrollView,
375
- children: /* @__PURE__ */_jsxs(GestureSheetProvider, {
376
- isDragging,
377
- blockPan,
378
- setBlockPan,
379
- panGesture,
380
- panGestureRef,
381
- children: [/* @__PURE__ */_jsx(AnimatePresence, {
382
- custom: {
383
- open
384
- },
385
- children: shouldHideParentSheet || !open ? null : overlayComponent
386
- }), snapPointsMode !== "percent" && /* @__PURE__ */_jsx(View, {
387
- style: {
388
- opacity: 0,
389
- position: "absolute",
390
- top: 0,
391
- left: 0,
392
- right: 0,
393
- bottom: 0,
394
- pointerEvents: "none"
395
- },
396
- onLayout: handleMaxContentViewLayout
397
- }), /* @__PURE__ */_jsx(AnimatedView, {
398
- ref,
399
- onLayout: handleAnimationViewLayout,
400
- // @ts-ignore for CSS driver this is necessary to attach the transition
401
- // also motion driver at least though i suspect all drivers?
402
- transition: isDragging || disableAnimation ? null : transition,
403
- // @ts-ignore
404
- disableClassName: !0,
405
- style: [{
406
- position: "absolute",
407
- zIndex,
408
- width: "100%",
409
- height: forcedContentHeight,
410
- minHeight: forcedContentHeight,
411
- opacity: shouldHideParentSheet ? 0 : opacity,
412
- ...((shouldHideParentSheet || !open) && {
413
- pointerEvents: "none"
414
- })
415
- }, animatedStyle],
416
- children: (/* wrap children with plain RN View for panResponder - tamagui views no longer handle responder events on web */
417
- gestureHandlerEnabled && panGesture ? /* @__PURE__ */_jsx(GestureDetectorWrapper, {
418
- gesture: panGesture,
419
- style: {
420
- flex: 1
421
- },
422
- children: props.children
423
- }) : /* @__PURE__ */_jsx(View, {
424
- ...panResponder?.panHandlers,
425
- style: {
426
- flex: 1,
427
- width: "100%",
428
- height: "100%"
429
- },
430
- children: props.children
431
- }))
432
- })]
433
- })
434
- })
435
- })
318
+ setPosition(closestPoint);
319
+ animateTo(closestPoint);
320
+ };
321
+ var finish = function (_e, state2) {
322
+ release({
323
+ vy: state2.vy,
324
+ dragAt: state2.dy
436
325
  });
437
- if (needsPortalRepropagation()) {
438
- var adaptContext = useAdaptContext();
439
- contents = /* @__PURE__ */_jsx(ProvideAdaptContext, {
440
- ...adaptContext,
441
- children: (/* @ts-ignore */
442
- contents)
326
+ };
327
+ var previouslyScrolling = false;
328
+ var onMoveShouldSet = function (e, param) {
329
+ var {
330
+ dy
331
+ } = param;
332
+ function getShouldSet() {
333
+ if (e.target === providerProps.handleRef.current) return true;
334
+ if (scrollBridge.hasScrollableContent === true) {
335
+ if (scrollBridge.scrollLock) return false;
336
+ var isScrolled = scrollBridge.y !== 0;
337
+ var isDraggingUp = dy < 0;
338
+ var isNearTop = scrollBridge.paneY - 5 <= scrollBridge.paneMinY;
339
+ if (isScrolled) return false;
340
+ if (isNearTop) {
341
+ if (hasScrollView.current && isDraggingUp) return false;
342
+ }
343
+ }
344
+ return Math.abs(dy) > 10;
345
+ }
346
+ var granted = getShouldSet();
347
+ if (granted) scrollBridge.setParentDragging(true);
348
+ return granted;
349
+ };
350
+ var grant = function () {
351
+ setPanning(true);
352
+ stopSpring();
353
+ startY = at.current;
354
+ };
355
+ var isExternalDrag = false;
356
+ scrollBridge.drag = function (dy) {
357
+ if (!isExternalDrag) {
358
+ isExternalDrag = true;
359
+ grant();
360
+ }
361
+ var to = dy + startY;
362
+ animatedNumber.setValue(resisted(to, minY), {
363
+ type: "direct"
443
364
  });
365
+ };
366
+ scrollBridge.release = release;
367
+ scrollBridge.snapToPosition = function (positionIndex) {
368
+ isExternalDrag = false;
369
+ setPanning(false);
370
+ setPosition(positionIndex);
371
+ animateTo(positionIndex);
372
+ };
373
+ return PanResponder.create({
374
+ onMoveShouldSetPanResponder: onMoveShouldSet,
375
+ onPanResponderGrant: grant,
376
+ onPanResponderMove: function (_e, param) {
377
+ var {
378
+ dy
379
+ } = param;
380
+ var to = resisted(dy + startY, minY);
381
+ if (to <= minY) scrollBridge.setParentDragging(false);else scrollBridge.setParentDragging(true);
382
+ animatedNumber.setValue(to, {
383
+ type: "direct"
384
+ });
385
+ },
386
+ onPanResponderEnd: finish,
387
+ onPanResponderTerminate: finish,
388
+ onPanResponderRelease: finish
389
+ });
390
+ }, [disableDrag, isShowingInnerSheet, animateTo, frameSize, positions, setPosition]);
391
+ React.useEffect(function () {
392
+ if (isDragging || isHidden || !open || disableAnimation) return;
393
+ if (!frameSize || !screenSize) return;
394
+ animateTo(position, {
395
+ type: "timing",
396
+ duration: 250
397
+ });
398
+ }, [isKeyboardVisible, keyboardHeight]);
399
+ var wasDragging = React.useRef(false);
400
+ React.useEffect(function () {
401
+ if (isDragging) {
402
+ wasDragging.current = true;
403
+ return;
444
404
  }
445
- var shouldMountChildren = unmountChildrenWhenHidden ? !!opacity : !0;
446
- if (modal) {
447
- var modalContents = /* @__PURE__ */_jsx(Portal, {
448
- stackZIndex: zIndex,
449
- ...portalProps,
450
- children: shouldMountChildren && /* @__PURE__ */_jsx(ContainerComponent, {
451
- children: /* @__PURE__ */_jsx(Theme, {
452
- contain: !0,
453
- forceClassName: !0,
454
- name: themeName,
455
- children: contents
456
- })
457
- })
458
- });
459
- return isWeb ? modalContents : /* @__PURE__ */_jsx(SheetInsideSheetContext.Provider, {
460
- value: onInnerSheet,
461
- children: modalContents
405
+ if (!wasDragging.current) return;
406
+ wasDragging.current = false;
407
+ if (!frameSize || !screenSize || isHidden || !open) return;
408
+ animateTo(position);
409
+ }, [isDragging]);
410
+ React.useEffect(function () {
411
+ if (!open && isKeyboardVisible) dismissKeyboard();
412
+ }, [open]);
413
+ var {
414
+ panGesture,
415
+ panGestureRef,
416
+ gestureHandlerEnabled
417
+ } = useGestureHandlerPan({
418
+ positions: activePositions,
419
+ frameSize,
420
+ setPosition,
421
+ animateTo,
422
+ stopSpring,
423
+ scrollBridge,
424
+ setIsDragging,
425
+ getCurrentPosition: function () {
426
+ return at.current;
427
+ },
428
+ resisted,
429
+ disableDrag,
430
+ isShowingInnerSheet,
431
+ setAnimatedPosition: function (val) {
432
+ at.current = val;
433
+ animatedNumber.setValue(val, {
434
+ type: "direct"
462
435
  });
436
+ },
437
+ pauseKeyboardHandler
438
+ });
439
+ var handleAnimationViewLayout = useEvent(function (e) {
440
+ var _e_nativeEvent;
441
+ if (!open && stableFrameSize.current !== 0) return;
442
+ var layoutHeight = (_e_nativeEvent = e.nativeEvent) === null || _e_nativeEvent === void 0 ? void 0 : _e_nativeEvent.layout.height;
443
+ var next = modal ? Math.min(layoutHeight, Dimensions.get(relativeDimensionTo).height) : layoutHeight;
444
+ if (!next) return;
445
+ setFrameSize(next);
446
+ });
447
+ var handleMaxContentViewLayout = React.useCallback(function (e) {
448
+ var _e_nativeEvent;
449
+ var next = Math.min((_e_nativeEvent = e.nativeEvent) === null || _e_nativeEvent === void 0 ? void 0 : _e_nativeEvent.layout.height, Dimensions.get(relativeDimensionTo).height);
450
+ if (!next) return;
451
+ setMaxContentSize(next);
452
+ }, []);
453
+ var animatedStyle = useAnimatedNumberStyle(animatedNumber, React.useCallback(function (val) {
454
+ "worklet";
455
+
456
+ return {
457
+ transform: [{
458
+ translateY: frameSize === 0 ? hiddenSize : val
459
+ }]
460
+ };
461
+ }, [frameSize]));
462
+ var [opacity, setOpacity] = React.useState(open ? 1 : 0);
463
+ if (open && opacity === 0) {
464
+ setOpacity(1);
465
+ if (opacityFallbackTimer.current) {
466
+ clearTimeout(opacityFallbackTimer.current);
467
+ opacityFallbackTimer.current = null;
463
468
  }
464
- return contents;
469
+ }
470
+ var forcedContentHeight = hasFit ? void 0 : snapPointsMode === "percent" ? `${maxSnapPoint}${isWeb ? modal ? "dvh" : "%" : "%"}` : maxSnapPoint;
471
+ var setHasScrollView = React.useCallback(function (val) {
472
+ hasScrollView.current = val;
473
+ }, []);
474
+ var contents = /* @__PURE__ */_jsx(LayoutMeasurementController, {
475
+ disable: !open,
476
+ children: /* @__PURE__ */_jsx(ParentSheetContext.Provider, {
477
+ value: nextParentContext,
478
+ children: /* @__PURE__ */_jsx(SheetProvider, {
479
+ ...providerProps,
480
+ keyboardOccludedHeight,
481
+ setHasScrollView,
482
+ children: /* @__PURE__ */_jsxs(GestureSheetProvider, {
483
+ isDragging,
484
+ blockPan,
485
+ setBlockPan,
486
+ panGesture,
487
+ panGestureRef,
488
+ children: [/* @__PURE__ */_jsx(AnimatePresence, {
489
+ custom: {
490
+ open
491
+ },
492
+ children: shouldHideParentSheet || !open ? null : overlayComponent
493
+ }), snapPointsMode !== "percent" && /* @__PURE__ */_jsx(View, {
494
+ style: {
495
+ opacity: 0,
496
+ position: "absolute",
497
+ top: 0,
498
+ left: 0,
499
+ right: 0,
500
+ bottom: 0,
501
+ pointerEvents: "none"
502
+ },
503
+ onLayout: handleMaxContentViewLayout
504
+ }), /* @__PURE__ */_jsx(AnimatedView, {
505
+ ref,
506
+ onLayout: handleAnimationViewLayout,
507
+ transition: isDragging || disableAnimation ? null : transition,
508
+ disableClassName: true,
509
+ style: [{
510
+ position: "absolute",
511
+ zIndex,
512
+ width: "100%",
513
+ height: forcedContentHeight,
514
+ minHeight: forcedContentHeight,
515
+ opacity: !shouldHideParentSheet ? opacity : 0,
516
+ ...((shouldHideParentSheet || !open) && {
517
+ pointerEvents: "none"
518
+ })
519
+ }, animatedStyle],
520
+ children: gestureHandlerEnabled && panGesture ? /* @__PURE__ */_jsx(GestureDetectorWrapper, {
521
+ gesture: panGesture,
522
+ style: {
523
+ flex: 1
524
+ },
525
+ children: props.children
526
+ }) : /* @__PURE__ */_jsx(View, {
527
+ ...(panResponder === null || panResponder === void 0 ? void 0 : panResponder.panHandlers),
528
+ style: {
529
+ flex: 1,
530
+ width: "100%",
531
+ height: "100%"
532
+ },
533
+ children: props.children
534
+ })
535
+ })]
536
+ })
537
+ })
538
+ })
465
539
  });
540
+ if (needsPortalRepropagation()) contents = /* @__PURE__ */_jsx(ProvideAdaptContext, {
541
+ ...useAdaptContext(),
542
+ children: contents
543
+ });
544
+ var shouldMountChildren = unmountChildrenWhenHidden ? !!opacity : true;
545
+ if (modal) {
546
+ var RNGHRoot = getGestureHandlerState().RootView;
547
+ var mountedContents = shouldMountChildren ? /* @__PURE__ */_jsx(ContainerComponent, {
548
+ children: contents
549
+ }) : null;
550
+ var modalContents = /* @__PURE__ */_jsx(Portal, {
551
+ stackZIndex: zIndex,
552
+ ...portalProps,
553
+ children: mountedContents && RNGHRoot ? /* @__PURE__ */_jsx(RNGHRoot, {
554
+ style: open ? rnghRootStyleOpen : rnghRootStyleClosed,
555
+ children: mountedContents
556
+ }) : mountedContents
557
+ });
558
+ if (isWeb) return modalContents;
559
+ return /* @__PURE__ */_jsx(SheetInsideSheetContext.Provider, {
560
+ value: onInnerSheet,
561
+ children: modalContents
562
+ });
563
+ }
564
+ return contents;
565
+ });
466
566
  function getYPositions(mode, point, screenSize, frameSize) {
467
567
  if (!screenSize || !frameSize) return 0;
468
568
  if (mode === "mixed") {
469
- if (typeof point == "number") return screenSize - Math.min(screenSize, Math.max(0, point));
569
+ if (typeof point === "number") return screenSize - Math.min(screenSize, Math.max(0, point));
470
570
  if (point === "fit") return screenSize - Math.min(screenSize, frameSize);
471
571
  if (point.endsWith("%")) {
472
572
  var pct = Math.min(100, Math.max(0, Number(point.slice(0, -1)))) / 100;
473
- return Number.isNaN(pct) ? (console.warn("Invalid snapPoint percentage string"), 0) : Math.round(screenSize - pct * screenSize);
573
+ if (Number.isNaN(pct)) {
574
+ console.warn("Invalid snapPoint percentage string");
575
+ return 0;
576
+ }
577
+ return Math.round(screenSize - pct * screenSize);
474
578
  }
475
- return console.warn("Invalid snapPoint unknown value"), 0;
579
+ console.warn("Invalid snapPoint unknown value");
580
+ return 0;
581
+ }
582
+ if (mode === "fit") {
583
+ if (point === 0) return screenSize;
584
+ return screenSize - Math.min(screenSize, frameSize);
476
585
  }
477
- if (mode === "fit") return point === 0 ? screenSize : screenSize - Math.min(screenSize, frameSize);
478
- if (mode === "constant" && typeof point == "number") return screenSize - Math.min(screenSize, Math.max(0, point));
586
+ if (mode === "constant" && typeof point === "number") return screenSize - Math.min(screenSize, Math.max(0, point));
479
587
  var pct1 = Math.min(100, Math.max(0, Number(point))) / 100;
480
- return Number.isNaN(pct1) ? (console.warn("Invalid snapPoint percentage"), 0) : Math.round(screenSize - pct1 * screenSize);
588
+ if (Number.isNaN(pct1)) {
589
+ console.warn("Invalid snapPoint percentage");
590
+ return 0;
591
+ }
592
+ return Math.round(screenSize - pct1 * screenSize);
481
593
  }
482
594
  export { SheetImplementationCustom };
483
595
  //# sourceMappingURL=SheetImplementationCustom.native.js.map