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