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