@tamagui/sheet 2.0.0-rc.4 → 2.0.0-rc.40
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.turbo/turbo-build.log +3 -0
- package/controller/index.cjs +2 -0
- package/controller/index.js +2 -0
- package/controller/index.native.cjs +2 -0
- package/controller/index.native.js +2 -0
- package/dist/cjs/GestureDetectorWrapper.cjs +27 -21
- package/dist/cjs/GestureDetectorWrapper.native.js +33 -28
- package/dist/cjs/GestureDetectorWrapper.native.js.map +1 -1
- package/dist/cjs/GestureSheetContext.cjs +14 -12
- package/dist/cjs/GestureSheetContext.native.js +29 -27
- package/dist/cjs/GestureSheetContext.native.js.map +1 -1
- package/dist/cjs/Sheet.cjs +88 -86
- package/dist/cjs/Sheet.native.js +88 -86
- package/dist/cjs/Sheet.native.js.map +1 -1
- package/dist/cjs/SheetContext.cjs +16 -14
- package/dist/cjs/SheetContext.native.js +16 -14
- package/dist/cjs/SheetContext.native.js.map +1 -1
- package/dist/cjs/SheetController.cjs +40 -32
- package/dist/cjs/SheetController.native.js +62 -54
- package/dist/cjs/SheetController.native.js.map +1 -1
- package/dist/cjs/SheetImplementationCustom.cjs +545 -429
- package/dist/cjs/SheetImplementationCustom.native.js +569 -474
- package/dist/cjs/SheetImplementationCustom.native.js.map +1 -1
- package/dist/cjs/SheetScrollView.cjs +168 -132
- package/dist/cjs/SheetScrollView.native.js +189 -163
- package/dist/cjs/SheetScrollView.native.js.map +1 -1
- package/dist/cjs/constants.cjs +16 -14
- package/dist/cjs/constants.native.js +16 -14
- package/dist/cjs/constants.native.js.map +1 -1
- package/dist/cjs/contexts.cjs +27 -25
- package/dist/cjs/contexts.native.js +29 -27
- package/dist/cjs/contexts.native.js.map +1 -1
- package/dist/cjs/controller.cjs +14 -12
- package/dist/cjs/controller.native.js +14 -12
- package/dist/cjs/controller.native.js.map +1 -1
- package/dist/cjs/createSheet.cjs +159 -160
- package/dist/cjs/createSheet.native.js +172 -180
- package/dist/cjs/createSheet.native.js.map +1 -1
- package/dist/cjs/gestureState.cjs +12 -10
- package/dist/cjs/gestureState.native.js +12 -10
- package/dist/cjs/gestureState.native.js.map +1 -1
- package/dist/cjs/helpers.cjs +17 -13
- package/dist/cjs/helpers.native.js +17 -13
- package/dist/cjs/helpers.native.js.map +1 -1
- package/dist/cjs/index.cjs +7 -5
- package/dist/cjs/index.native.js +7 -5
- package/dist/cjs/index.native.js.map +1 -1
- package/dist/cjs/nativeSheet.cjs +64 -55
- package/dist/cjs/nativeSheet.native.js +73 -68
- package/dist/cjs/nativeSheet.native.js.map +1 -1
- package/dist/cjs/setupGestureHandler.cjs +24 -18
- package/dist/cjs/setupGestureHandler.native.js +24 -19
- package/dist/cjs/setupGestureHandler.native.js.map +1 -1
- package/dist/cjs/types.cjs +7 -5
- package/dist/cjs/types.native.js +7 -5
- package/dist/cjs/types.native.js.map +1 -1
- package/dist/cjs/useGestureHandlerPan.cjs +181 -111
- package/dist/cjs/useGestureHandlerPan.native.js +183 -115
- package/dist/cjs/useGestureHandlerPan.native.js.map +1 -1
- package/dist/cjs/useKeyboardControllerSheet.cjs +15 -13
- package/dist/cjs/useKeyboardControllerSheet.native.js +100 -82
- package/dist/cjs/useKeyboardControllerSheet.native.js.map +1 -1
- package/dist/cjs/useSheet.cjs +12 -10
- package/dist/cjs/useSheet.native.js +16 -14
- package/dist/cjs/useSheet.native.js.map +1 -1
- package/dist/cjs/useSheetController.cjs +35 -33
- package/dist/cjs/useSheetController.native.js +37 -35
- package/dist/cjs/useSheetController.native.js.map +1 -1
- package/dist/cjs/useSheetOffscreenSize.cjs +35 -23
- package/dist/cjs/useSheetOffscreenSize.native.js +36 -27
- package/dist/cjs/useSheetOffscreenSize.native.js.map +1 -1
- package/dist/cjs/useSheetOpenState.cjs +28 -25
- package/dist/cjs/useSheetOpenState.native.js +39 -37
- package/dist/cjs/useSheetOpenState.native.js.map +1 -1
- package/dist/cjs/useSheetProviderProps.cjs +129 -81
- package/dist/cjs/useSheetProviderProps.native.js +165 -122
- package/dist/cjs/useSheetProviderProps.native.js.map +1 -1
- package/dist/cjs/useSheetScrollViewGestures.cjs +124 -81
- package/dist/cjs/useSheetScrollViewGestures.native.js +128 -79
- package/dist/cjs/useSheetScrollViewGestures.native.js.map +1 -1
- package/dist/esm/GestureDetectorWrapper.mjs +12 -8
- package/dist/esm/GestureDetectorWrapper.mjs.map +1 -1
- package/dist/esm/GestureDetectorWrapper.native.js +18 -15
- package/dist/esm/GestureDetectorWrapper.native.js.map +1 -1
- package/dist/esm/GestureSheetContext.native.js +14 -14
- package/dist/esm/GestureSheetContext.native.js.map +1 -1
- package/dist/esm/Sheet.mjs +70 -70
- package/dist/esm/Sheet.mjs.map +1 -1
- package/dist/esm/Sheet.native.js +70 -70
- package/dist/esm/Sheet.native.js.map +1 -1
- package/dist/esm/SheetContext.mjs +2 -2
- package/dist/esm/SheetContext.mjs.map +1 -1
- package/dist/esm/SheetContext.native.js +2 -2
- package/dist/esm/SheetContext.native.js.map +1 -1
- package/dist/esm/SheetController.mjs +12 -6
- package/dist/esm/SheetController.mjs.map +1 -1
- package/dist/esm/SheetController.native.js +18 -12
- package/dist/esm/SheetController.native.js.map +1 -1
- package/dist/esm/SheetImplementationCustom.mjs +503 -389
- package/dist/esm/SheetImplementationCustom.mjs.map +1 -1
- package/dist/esm/SheetImplementationCustom.native.js +523 -434
- package/dist/esm/SheetImplementationCustom.native.js.map +1 -1
- package/dist/esm/SheetScrollView.mjs +133 -99
- package/dist/esm/SheetScrollView.mjs.map +1 -1
- package/dist/esm/SheetScrollView.native.js +155 -131
- package/dist/esm/SheetScrollView.native.js.map +1 -1
- package/dist/esm/constants.mjs +4 -4
- package/dist/esm/constants.mjs.map +1 -1
- package/dist/esm/constants.native.js +4 -4
- package/dist/esm/constants.native.js.map +1 -1
- package/dist/esm/contexts.mjs +3 -3
- package/dist/esm/contexts.mjs.map +1 -1
- package/dist/esm/contexts.native.js +3 -3
- package/dist/esm/contexts.native.js.map +1 -1
- package/dist/esm/createSheet.mjs +130 -133
- package/dist/esm/createSheet.mjs.map +1 -1
- package/dist/esm/createSheet.native.js +142 -152
- package/dist/esm/createSheet.native.js.map +1 -1
- package/dist/esm/helpers.mjs +5 -3
- package/dist/esm/helpers.mjs.map +1 -1
- package/dist/esm/helpers.native.js +5 -3
- package/dist/esm/helpers.native.js.map +1 -1
- package/dist/esm/index.js +11 -11
- package/dist/esm/index.js.map +1 -6
- package/dist/esm/nativeSheet.mjs +45 -38
- package/dist/esm/nativeSheet.mjs.map +1 -1
- package/dist/esm/nativeSheet.native.js +51 -48
- package/dist/esm/nativeSheet.native.js.map +1 -1
- package/dist/esm/setupGestureHandler.mjs +12 -8
- package/dist/esm/setupGestureHandler.mjs.map +1 -1
- package/dist/esm/setupGestureHandler.native.js +12 -9
- package/dist/esm/setupGestureHandler.native.js.map +1 -1
- package/dist/esm/useGestureHandlerPan.mjs +167 -99
- package/dist/esm/useGestureHandlerPan.mjs.map +1 -1
- package/dist/esm/useGestureHandlerPan.native.js +168 -102
- package/dist/esm/useGestureHandlerPan.native.js.map +1 -1
- package/dist/esm/useKeyboardControllerSheet.mjs +3 -3
- package/dist/esm/useKeyboardControllerSheet.mjs.map +1 -1
- package/dist/esm/useKeyboardControllerSheet.native.js +85 -69
- package/dist/esm/useKeyboardControllerSheet.native.js.map +1 -1
- package/dist/esm/useSheetController.mjs +11 -11
- package/dist/esm/useSheetController.mjs.map +1 -1
- package/dist/esm/useSheetController.native.js +11 -11
- package/dist/esm/useSheetController.native.js.map +1 -1
- package/dist/esm/useSheetOffscreenSize.mjs +23 -13
- package/dist/esm/useSheetOffscreenSize.mjs.map +1 -1
- package/dist/esm/useSheetOffscreenSize.native.js +24 -17
- package/dist/esm/useSheetOffscreenSize.native.js.map +1 -1
- package/dist/esm/useSheetOpenState.mjs +14 -13
- package/dist/esm/useSheetOpenState.mjs.map +1 -1
- package/dist/esm/useSheetOpenState.native.js +17 -17
- package/dist/esm/useSheetOpenState.native.js.map +1 -1
- package/dist/esm/useSheetProviderProps.mjs +101 -55
- package/dist/esm/useSheetProviderProps.mjs.map +1 -1
- package/dist/esm/useSheetProviderProps.native.js +137 -96
- package/dist/esm/useSheetProviderProps.native.js.map +1 -1
- package/dist/esm/useSheetScrollViewGestures.mjs +112 -71
- package/dist/esm/useSheetScrollViewGestures.mjs.map +1 -1
- package/dist/esm/useSheetScrollViewGestures.native.js +116 -69
- package/dist/esm/useSheetScrollViewGestures.native.js.map +1 -1
- package/dist/jsx/GestureDetectorWrapper.mjs +12 -8
- package/dist/jsx/GestureDetectorWrapper.mjs.map +1 -1
- package/dist/jsx/GestureDetectorWrapper.native.js +33 -28
- package/dist/jsx/GestureDetectorWrapper.native.js.map +1 -1
- package/dist/jsx/GestureSheetContext.native.js +29 -27
- package/dist/jsx/GestureSheetContext.native.js.map +1 -1
- package/dist/jsx/Sheet.mjs +70 -70
- package/dist/jsx/Sheet.mjs.map +1 -1
- package/dist/jsx/Sheet.native.js +88 -86
- package/dist/jsx/Sheet.native.js.map +1 -1
- package/dist/jsx/SheetContext.mjs +2 -2
- package/dist/jsx/SheetContext.mjs.map +1 -1
- package/dist/jsx/SheetContext.native.js +16 -14
- package/dist/jsx/SheetContext.native.js.map +1 -1
- package/dist/jsx/SheetController.mjs +12 -6
- package/dist/jsx/SheetController.mjs.map +1 -1
- package/dist/jsx/SheetController.native.js +62 -54
- package/dist/jsx/SheetController.native.js.map +1 -1
- package/dist/jsx/SheetImplementationCustom.mjs +503 -389
- package/dist/jsx/SheetImplementationCustom.mjs.map +1 -1
- package/dist/jsx/SheetImplementationCustom.native.js +569 -474
- package/dist/jsx/SheetImplementationCustom.native.js.map +1 -1
- package/dist/jsx/SheetScrollView.mjs +133 -99
- package/dist/jsx/SheetScrollView.mjs.map +1 -1
- package/dist/jsx/SheetScrollView.native.js +189 -163
- package/dist/jsx/SheetScrollView.native.js.map +1 -1
- package/dist/jsx/constants.mjs +4 -4
- package/dist/jsx/constants.mjs.map +1 -1
- package/dist/jsx/constants.native.js +16 -14
- package/dist/jsx/constants.native.js.map +1 -1
- package/dist/jsx/contexts.mjs +3 -3
- package/dist/jsx/contexts.mjs.map +1 -1
- package/dist/jsx/contexts.native.js +29 -27
- package/dist/jsx/contexts.native.js.map +1 -1
- package/dist/jsx/controller.native.js +14 -12
- package/dist/jsx/createSheet.mjs +130 -133
- package/dist/jsx/createSheet.mjs.map +1 -1
- package/dist/jsx/createSheet.native.js +172 -180
- package/dist/jsx/createSheet.native.js.map +1 -1
- package/dist/jsx/gestureState.native.js +12 -10
- package/dist/jsx/gestureState.native.js.map +1 -1
- package/dist/jsx/helpers.mjs +5 -3
- package/dist/jsx/helpers.mjs.map +1 -1
- package/dist/jsx/helpers.native.js +17 -13
- package/dist/jsx/helpers.native.js.map +1 -1
- package/dist/jsx/index.js +11 -11
- package/dist/jsx/index.js.map +1 -6
- package/dist/jsx/index.native.js +7 -5
- package/dist/jsx/index.native.js.map +1 -1
- package/dist/jsx/nativeSheet.mjs +45 -38
- package/dist/jsx/nativeSheet.mjs.map +1 -1
- package/dist/jsx/nativeSheet.native.js +73 -68
- package/dist/jsx/nativeSheet.native.js.map +1 -1
- package/dist/jsx/setupGestureHandler.mjs +12 -8
- package/dist/jsx/setupGestureHandler.mjs.map +1 -1
- package/dist/jsx/setupGestureHandler.native.js +24 -19
- package/dist/jsx/setupGestureHandler.native.js.map +1 -1
- package/dist/jsx/types.native.js +7 -5
- package/dist/jsx/useGestureHandlerPan.mjs +167 -99
- package/dist/jsx/useGestureHandlerPan.mjs.map +1 -1
- package/dist/jsx/useGestureHandlerPan.native.js +183 -115
- package/dist/jsx/useGestureHandlerPan.native.js.map +1 -1
- package/dist/jsx/useKeyboardControllerSheet.mjs +3 -3
- package/dist/jsx/useKeyboardControllerSheet.mjs.map +1 -1
- package/dist/jsx/useKeyboardControllerSheet.native.js +100 -82
- package/dist/jsx/useKeyboardControllerSheet.native.js.map +1 -1
- package/dist/jsx/useSheet.native.js +16 -14
- package/dist/jsx/useSheetController.mjs +11 -11
- package/dist/jsx/useSheetController.mjs.map +1 -1
- package/dist/jsx/useSheetController.native.js +37 -35
- package/dist/jsx/useSheetController.native.js.map +1 -1
- package/dist/jsx/useSheetOffscreenSize.mjs +23 -13
- package/dist/jsx/useSheetOffscreenSize.mjs.map +1 -1
- package/dist/jsx/useSheetOffscreenSize.native.js +36 -27
- package/dist/jsx/useSheetOffscreenSize.native.js.map +1 -1
- package/dist/jsx/useSheetOpenState.mjs +14 -13
- package/dist/jsx/useSheetOpenState.mjs.map +1 -1
- package/dist/jsx/useSheetOpenState.native.js +39 -37
- package/dist/jsx/useSheetOpenState.native.js.map +1 -1
- package/dist/jsx/useSheetProviderProps.mjs +101 -55
- package/dist/jsx/useSheetProviderProps.mjs.map +1 -1
- package/dist/jsx/useSheetProviderProps.native.js +165 -122
- package/dist/jsx/useSheetProviderProps.native.js.map +1 -1
- package/dist/jsx/useSheetScrollViewGestures.mjs +112 -71
- package/dist/jsx/useSheetScrollViewGestures.mjs.map +1 -1
- package/dist/jsx/useSheetScrollViewGestures.native.js +128 -79
- package/dist/jsx/useSheetScrollViewGestures.native.js.map +1 -1
- package/next.md +78 -0
- package/package.json +31 -46
- package/setup-gesture-handler/index.cjs +2 -0
- package/setup-gesture-handler/index.js +2 -0
- package/setup-gesture-handler/index.native.cjs +2 -0
- package/setup-gesture-handler/index.native.js +2 -0
- package/setup-gesture-handler.cjs +1 -0
- package/src/SheetController.tsx +4 -1
- package/src/SheetImplementationCustom.tsx +87 -45
- package/src/types.tsx +5 -0
- package/src/useGestureHandlerPan.tsx +5 -3
- package/src/useSheetController.tsx +4 -0
- package/tsconfig.json +56 -0
- package/types/Sheet.d.ts +3 -0
- package/types/Sheet.d.ts.map +1 -1
- package/types/SheetController.d.ts +1 -1
- package/types/SheetController.d.ts.map +1 -1
- package/types/SheetImplementationCustom.d.ts +3 -0
- package/types/SheetImplementationCustom.d.ts.map +1 -1
- package/types/createSheet.d.ts +3 -0
- package/types/createSheet.d.ts.map +1 -1
- package/types/types.d.ts +6 -0
- package/types/types.d.ts.map +1 -1
- package/types/useGestureHandlerPan.d.ts.map +1 -1
- package/types/useSheetController.d.ts +3 -0
- package/types/useSheetController.d.ts.map +1 -1
- package/dist/cjs/GestureDetectorWrapper.js +0 -29
- package/dist/cjs/GestureDetectorWrapper.js.map +0 -6
- package/dist/cjs/GestureSheetContext.js +0 -43
- package/dist/cjs/GestureSheetContext.js.map +0 -6
- package/dist/cjs/Sheet.js +0 -104
- package/dist/cjs/Sheet.js.map +0 -6
- package/dist/cjs/SheetContext.js +0 -28
- package/dist/cjs/SheetContext.js.map +0 -6
- package/dist/cjs/SheetController.js +0 -52
- package/dist/cjs/SheetController.js.map +0 -6
- package/dist/cjs/SheetImplementationCustom.js +0 -393
- package/dist/cjs/SheetImplementationCustom.js.map +0 -6
- package/dist/cjs/SheetScrollView.js +0 -137
- package/dist/cjs/SheetScrollView.js.map +0 -6
- package/dist/cjs/constants.js +0 -24
- package/dist/cjs/constants.js.map +0 -6
- package/dist/cjs/contexts.js +0 -33
- package/dist/cjs/contexts.js.map +0 -6
- package/dist/cjs/controller.js +0 -23
- package/dist/cjs/controller.js.map +0 -6
- package/dist/cjs/createSheet.js +0 -152
- package/dist/cjs/createSheet.js.map +0 -6
- package/dist/cjs/gestureState.js +0 -34
- package/dist/cjs/gestureState.js.map +0 -6
- package/dist/cjs/helpers.js +0 -26
- package/dist/cjs/helpers.js.map +0 -6
- package/dist/cjs/index.js +0 -25
- package/dist/cjs/index.js.map +0 -6
- package/dist/cjs/nativeSheet.js +0 -56
- package/dist/cjs/nativeSheet.js.map +0 -6
- package/dist/cjs/setupGestureHandler.js +0 -38
- package/dist/cjs/setupGestureHandler.js.map +0 -6
- package/dist/cjs/types.js +0 -14
- package/dist/cjs/types.js.map +0 -6
- package/dist/cjs/useGestureHandlerPan.js +0 -126
- package/dist/cjs/useGestureHandlerPan.js.map +0 -6
- package/dist/cjs/useKeyboardControllerSheet.js +0 -34
- package/dist/cjs/useKeyboardControllerSheet.js.map +0 -6
- package/dist/cjs/useSheet.js +0 -22
- package/dist/cjs/useSheet.js.map +0 -6
- package/dist/cjs/useSheetController.js +0 -39
- package/dist/cjs/useSheetController.js.map +0 -6
- package/dist/cjs/useSheetOffscreenSize.js +0 -43
- package/dist/cjs/useSheetOffscreenSize.js.map +0 -6
- package/dist/cjs/useSheetOpenState.js +0 -37
- package/dist/cjs/useSheetOpenState.js.map +0 -6
- package/dist/cjs/useSheetProviderProps.js +0 -130
- package/dist/cjs/useSheetProviderProps.js.map +0 -6
- package/dist/cjs/useSheetScrollViewGestures.js +0 -102
- package/dist/cjs/useSheetScrollViewGestures.js.map +0 -6
- package/dist/esm/GestureDetectorWrapper.js +0 -15
- package/dist/esm/GestureDetectorWrapper.js.map +0 -6
- package/dist/esm/GestureSheetContext.js +0 -28
- package/dist/esm/GestureSheetContext.js.map +0 -6
- package/dist/esm/Sheet.js +0 -92
- package/dist/esm/Sheet.js.map +0 -6
- package/dist/esm/SheetContext.js +0 -13
- package/dist/esm/SheetContext.js.map +0 -6
- package/dist/esm/SheetController.js +0 -31
- package/dist/esm/SheetController.js.map +0 -6
- package/dist/esm/SheetImplementationCustom.js +0 -395
- package/dist/esm/SheetImplementationCustom.js.map +0 -6
- package/dist/esm/SheetScrollView.js +0 -122
- package/dist/esm/SheetScrollView.js.map +0 -6
- package/dist/esm/constants.js +0 -8
- package/dist/esm/constants.js.map +0 -6
- package/dist/esm/contexts.js +0 -9
- package/dist/esm/contexts.js.map +0 -6
- package/dist/esm/controller.js +0 -11
- package/dist/esm/controller.js.map +0 -6
- package/dist/esm/createSheet.js +0 -153
- package/dist/esm/createSheet.js.map +0 -6
- package/dist/esm/gestureState.js +0 -18
- package/dist/esm/gestureState.js.map +0 -6
- package/dist/esm/helpers.js +0 -10
- package/dist/esm/helpers.js.map +0 -6
- package/dist/esm/nativeSheet.js +0 -46
- package/dist/esm/nativeSheet.js.map +0 -6
- package/dist/esm/setupGestureHandler.js +0 -22
- package/dist/esm/setupGestureHandler.js.map +0 -6
- package/dist/esm/types.js +0 -1
- package/dist/esm/types.js.map +0 -6
- package/dist/esm/useGestureHandlerPan.js +0 -111
- package/dist/esm/useGestureHandlerPan.js.map +0 -6
- package/dist/esm/useKeyboardControllerSheet.js +0 -18
- package/dist/esm/useKeyboardControllerSheet.js.map +0 -6
- package/dist/esm/useSheet.js +0 -6
- package/dist/esm/useSheet.js.map +0 -6
- package/dist/esm/useSheetController.js +0 -15
- package/dist/esm/useSheetController.js.map +0 -6
- package/dist/esm/useSheetOffscreenSize.js +0 -27
- package/dist/esm/useSheetOffscreenSize.js.map +0 -6
- package/dist/esm/useSheetOpenState.js +0 -22
- package/dist/esm/useSheetOpenState.js.map +0 -6
- package/dist/esm/useSheetProviderProps.js +0 -109
- package/dist/esm/useSheetProviderProps.js.map +0 -6
- package/dist/esm/useSheetScrollViewGestures.js +0 -86
- package/dist/esm/useSheetScrollViewGestures.js.map +0 -6
- package/dist/jsx/GestureDetectorWrapper.js +0 -15
- package/dist/jsx/GestureDetectorWrapper.js.map +0 -6
- package/dist/jsx/GestureSheetContext.js +0 -28
- package/dist/jsx/GestureSheetContext.js.map +0 -6
- package/dist/jsx/Sheet.js +0 -92
- package/dist/jsx/Sheet.js.map +0 -6
- package/dist/jsx/SheetContext.js +0 -13
- package/dist/jsx/SheetContext.js.map +0 -6
- package/dist/jsx/SheetController.js +0 -31
- package/dist/jsx/SheetController.js.map +0 -6
- package/dist/jsx/SheetImplementationCustom.js +0 -395
- package/dist/jsx/SheetImplementationCustom.js.map +0 -6
- package/dist/jsx/SheetScrollView.js +0 -122
- package/dist/jsx/SheetScrollView.js.map +0 -6
- package/dist/jsx/constants.js +0 -8
- package/dist/jsx/constants.js.map +0 -6
- package/dist/jsx/contexts.js +0 -9
- package/dist/jsx/contexts.js.map +0 -6
- package/dist/jsx/controller.js +0 -11
- package/dist/jsx/controller.js.map +0 -6
- package/dist/jsx/createSheet.js +0 -153
- package/dist/jsx/createSheet.js.map +0 -6
- package/dist/jsx/gestureState.js +0 -18
- package/dist/jsx/gestureState.js.map +0 -6
- package/dist/jsx/helpers.js +0 -10
- package/dist/jsx/helpers.js.map +0 -6
- package/dist/jsx/nativeSheet.js +0 -46
- package/dist/jsx/nativeSheet.js.map +0 -6
- package/dist/jsx/setupGestureHandler.js +0 -22
- package/dist/jsx/setupGestureHandler.js.map +0 -6
- package/dist/jsx/types.js +0 -1
- package/dist/jsx/types.js.map +0 -6
- package/dist/jsx/useGestureHandlerPan.js +0 -111
- package/dist/jsx/useGestureHandlerPan.js.map +0 -6
- package/dist/jsx/useKeyboardControllerSheet.js +0 -18
- package/dist/jsx/useKeyboardControllerSheet.js.map +0 -6
- package/dist/jsx/useSheet.js +0 -6
- package/dist/jsx/useSheet.js.map +0 -6
- package/dist/jsx/useSheetController.js +0 -15
- package/dist/jsx/useSheetController.js.map +0 -6
- package/dist/jsx/useSheetOffscreenSize.js +0 -27
- package/dist/jsx/useSheetOffscreenSize.js.map +0 -6
- package/dist/jsx/useSheetOpenState.js +0 -22
- package/dist/jsx/useSheetOpenState.js.map +0 -6
- package/dist/jsx/useSheetProviderProps.js +0 -109
- package/dist/jsx/useSheetProviderProps.js.map +0 -6
- package/dist/jsx/useSheetScrollViewGestures.js +0 -86
- package/dist/jsx/useSheetScrollViewGestures.js.map +0 -6
- package/types/GestureDetectorWrapper.native.d.ts +0 -14
- package/types/GestureDetectorWrapper.native.d.ts.map +0 -1
- package/types/gestureState.native.d.ts +0 -12
- package/types/gestureState.native.d.ts.map +0 -1
- package/types/setupGestureHandler.native.d.ts +0 -41
- package/types/setupGestureHandler.native.d.ts.map +0 -1
- package/types/useGestureHandlerPan.native.d.ts +0 -33
- package/types/useGestureHandlerPan.native.d.ts.map +0 -1
- package/types/useSheetScrollViewGestures.web.d.ts +0 -15
- package/types/useSheetScrollViewGestures.web.d.ts.map +0 -1
|
@@ -5,20 +5,22 @@ var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
|
5
5
|
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
6
6
|
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
7
7
|
var __export = (target, all) => {
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
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
|
-
|
|
19
|
-
|
|
19
|
+
}
|
|
20
|
+
return to;
|
|
21
|
+
};
|
|
20
22
|
var __toCommonJS = mod => __copyProps(__defProp({}, "__esModule", {
|
|
21
|
-
value:
|
|
23
|
+
value: true
|
|
22
24
|
}), mod);
|
|
23
25
|
var useSheetScrollViewGestures_native_exports = {};
|
|
24
26
|
__export(useSheetScrollViewGestures_native_exports, {
|
|
@@ -28,78 +30,125 @@ module.exports = __toCommonJS(useSheetScrollViewGestures_native_exports);
|
|
|
28
30
|
var import_react = require("react");
|
|
29
31
|
function useSheetScrollViewGestures(param) {
|
|
30
32
|
var {
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
33
|
+
scrollBridge,
|
|
34
|
+
hasScrollableContent,
|
|
35
|
+
scrollEnabled,
|
|
36
|
+
setScrollEnabled
|
|
37
|
+
} = param;
|
|
38
|
+
var state = (0, import_react.useRef)({
|
|
39
|
+
lastPageY: 0,
|
|
40
|
+
dragAt: 0,
|
|
41
|
+
dys: [],
|
|
42
|
+
isScrolling: false,
|
|
43
|
+
isDraggingScrollArea: false,
|
|
44
|
+
scrollEngaged: false,
|
|
45
|
+
prevScrollY: 0,
|
|
46
|
+
handoffOccurred: false,
|
|
47
|
+
handoffDragOffset: 0
|
|
48
|
+
});
|
|
49
|
+
var release = function () {
|
|
50
|
+
var s = state.current;
|
|
51
|
+
if (!s.isDraggingScrollArea) return;
|
|
52
|
+
s.isDraggingScrollArea = false;
|
|
53
|
+
scrollBridge.scrollStartY = -1;
|
|
54
|
+
scrollBridge.scrollLock = false;
|
|
55
|
+
s.isScrolling = false;
|
|
56
|
+
s.scrollEngaged = false;
|
|
57
|
+
s.prevScrollY = 0;
|
|
58
|
+
s.handoffOccurred = false;
|
|
59
|
+
s.handoffDragOffset = 0;
|
|
60
|
+
setScrollEnabled(true);
|
|
61
|
+
var vy = 0;
|
|
62
|
+
if (s.dys.length) {
|
|
63
|
+
var recentDys = s.dys.slice(-10);
|
|
64
|
+
var dist = recentDys.reduce(function (a, b) {
|
|
65
|
+
return a + b;
|
|
66
|
+
}, 0);
|
|
67
|
+
vy = dist / recentDys.length * 0.04;
|
|
68
|
+
}
|
|
69
|
+
s.dys = [];
|
|
70
|
+
scrollBridge.release({
|
|
71
|
+
dragAt: s.dragAt,
|
|
72
|
+
vy
|
|
73
|
+
});
|
|
74
|
+
};
|
|
75
|
+
var onStartShouldSetResponder = function () {
|
|
76
|
+
var s = state.current;
|
|
77
|
+
scrollBridge.scrollStartY = -1;
|
|
78
|
+
s.isDraggingScrollArea = true;
|
|
79
|
+
s.scrollEngaged = scrollBridge.y > 0;
|
|
80
|
+
s.prevScrollY = scrollBridge.y;
|
|
81
|
+
s.handoffOccurred = false;
|
|
82
|
+
s.handoffDragOffset = 0;
|
|
83
|
+
return false;
|
|
84
|
+
};
|
|
85
|
+
var onMoveShouldSetResponder = function (e) {
|
|
86
|
+
if (!scrollEnabled) return false;
|
|
87
|
+
var s = state.current;
|
|
88
|
+
var {
|
|
89
|
+
pageY
|
|
90
|
+
} = e.nativeEvent;
|
|
91
|
+
if (s.lastPageY === 0) {
|
|
85
92
|
s.lastPageY = pageY;
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
93
|
+
return false;
|
|
94
|
+
}
|
|
95
|
+
return Math.abs(pageY - s.lastPageY) > 10;
|
|
96
|
+
};
|
|
97
|
+
var onResponderMove = function (e) {
|
|
98
|
+
var s = state.current;
|
|
99
|
+
var {
|
|
100
|
+
pageY
|
|
101
|
+
} = e.nativeEvent;
|
|
102
|
+
if (!s.isScrolling && scrollBridge.scrollStartY === -1) {
|
|
103
|
+
scrollBridge.scrollStartY = pageY;
|
|
104
|
+
s.lastPageY = pageY;
|
|
105
|
+
}
|
|
106
|
+
var dragAt = pageY - scrollBridge.scrollStartY;
|
|
107
|
+
var dy = pageY - s.lastPageY;
|
|
108
|
+
s.lastPageY = pageY;
|
|
109
|
+
var isDraggingDown = dy > 0;
|
|
110
|
+
var isPaneAtTop = scrollBridge.paneY <= scrollBridge.paneMinY + 5;
|
|
111
|
+
var currentScrollY = scrollBridge.y;
|
|
112
|
+
if (currentScrollY > 0) s.scrollEngaged = true;
|
|
113
|
+
var wasScrolledNowAtZero = s.scrollEngaged && s.prevScrollY > 0 && currentScrollY <= 0;
|
|
114
|
+
if (wasScrolledNowAtZero && !s.handoffOccurred) {
|
|
115
|
+
s.handoffOccurred = true;
|
|
116
|
+
s.handoffDragOffset = 0;
|
|
117
|
+
}
|
|
118
|
+
s.prevScrollY = currentScrollY;
|
|
119
|
+
var panHandles = false;
|
|
120
|
+
if (!isPaneAtTop) {
|
|
121
|
+
panHandles = isDraggingDown ? currentScrollY <= 0 || !hasScrollableContent : true;
|
|
122
|
+
} else if (isDraggingDown) {
|
|
123
|
+
if (currentScrollY > 0 && hasScrollableContent && !s.handoffOccurred) {
|
|
124
|
+
panHandles = false;
|
|
125
|
+
} else {
|
|
126
|
+
panHandles = s.handoffOccurred || wasScrolledNowAtZero || currentScrollY <= 0;
|
|
127
|
+
}
|
|
128
|
+
} else {
|
|
129
|
+
panHandles = !hasScrollableContent;
|
|
130
|
+
if (!panHandles) {
|
|
131
|
+
s.isScrolling = true;
|
|
132
|
+
scrollBridge.scrollLock = true;
|
|
133
|
+
setScrollEnabled(true);
|
|
95
134
|
return;
|
|
96
135
|
}
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
136
|
+
}
|
|
137
|
+
if (panHandles) {
|
|
138
|
+
setScrollEnabled(false);
|
|
139
|
+
var effectiveDragAt = dragAt;
|
|
140
|
+
if (s.handoffOccurred) {
|
|
141
|
+
s.handoffDragOffset += dy;
|
|
142
|
+
effectiveDragAt = s.handoffDragOffset;
|
|
143
|
+
}
|
|
144
|
+
scrollBridge.drag(effectiveDragAt);
|
|
145
|
+
s.dragAt = effectiveDragAt;
|
|
146
|
+
s.dys.push(dy);
|
|
147
|
+
if (s.dys.length > 100) s.dys = s.dys.slice(-10);
|
|
148
|
+
} else {
|
|
149
|
+
setScrollEnabled(true);
|
|
150
|
+
}
|
|
151
|
+
};
|
|
103
152
|
return {
|
|
104
153
|
onResponderRelease: release,
|
|
105
154
|
onStartShouldSetResponder,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["useSheetScrollViewGestures_native_exports","__export","useSheetScrollViewGestures","module","exports","__toCommonJS","import_react","require","param","scrollBridge","hasScrollableContent","scrollEnabled","setScrollEnabled","state","useRef","lastPageY","dragAt","dys","isScrolling","isDraggingScrollArea","scrollEngaged","prevScrollY","handoffOccurred","handoffDragOffset","release","s","current","scrollStartY","scrollLock","vy","length","recentDys","slice","dist","reduce","a","b","onStartShouldSetResponder","y","onMoveShouldSetResponder","e","pageY","nativeEvent","Math","abs","onResponderMove","dy","isDraggingDown","isPaneAtTop","paneY","paneMinY","currentScrollY","wasScrolledNowAtZero","panHandles","effectiveDragAt","drag","push","onResponderRelease"],"sources":["../../src/useSheetScrollViewGestures.native.ts"],"sourcesContent":[null],"mappings":"
|
|
1
|
+
{"version":3,"names":["useSheetScrollViewGestures_native_exports","__export","useSheetScrollViewGestures","module","exports","__toCommonJS","import_react","require","param","scrollBridge","hasScrollableContent","scrollEnabled","setScrollEnabled","state","useRef","lastPageY","dragAt","dys","isScrolling","isDraggingScrollArea","scrollEngaged","prevScrollY","handoffOccurred","handoffDragOffset","release","s","current","scrollStartY","scrollLock","vy","length","recentDys","slice","dist","reduce","a","b","onStartShouldSetResponder","y","onMoveShouldSetResponder","e","pageY","nativeEvent","Math","abs","onResponderMove","dy","isDraggingDown","isPaneAtTop","paneY","paneMinY","currentScrollY","wasScrolledNowAtZero","panHandles","effectiveDragAt","drag","push","onResponderRelease"],"sources":["../../src/useSheetScrollViewGestures.native.ts"],"sourcesContent":[null],"mappings":"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","ignoreList":[]}
|
package/next.md
ADDED
|
@@ -0,0 +1,78 @@
|
|
|
1
|
+
# Sheet ScrollView Gesture Handoff - Next Steps
|
|
2
|
+
|
|
3
|
+
## Current Limitation
|
|
4
|
+
|
|
5
|
+
The Sheet + ScrollView gesture coordination on native iOS has limitations because Tamagui uses React Native's built-in `PanResponder`, while iOS's `UIScrollView` gesture recognizers fire BEFORE the RN responder system can claim the gesture.
|
|
6
|
+
|
|
7
|
+
This causes:
|
|
8
|
+
|
|
9
|
+
- Minor scroll "flicker" when starting to drag down from scroll top
|
|
10
|
+
- Imperfect handoff between scroll and sheet drag gestures
|
|
11
|
+
|
|
12
|
+
## Ideal Solution: react-native-gesture-handler Integration
|
|
13
|
+
|
|
14
|
+
Both `gorhom/bottom-sheet` and `react-native-actions-sheet` solve this by using `react-native-gesture-handler` which provides:
|
|
15
|
+
|
|
16
|
+
1. **`simultaneousHandlers`** - allows coordinating multiple gesture recognizers
|
|
17
|
+
2. **`GestureDetector`** with worklets - can check conditions and decide who handles gesture before it starts
|
|
18
|
+
3. **Native gesture coordination** - works at the iOS/Android gesture recognizer level, not the JS responder level
|
|
19
|
+
|
|
20
|
+
## Proposed API
|
|
21
|
+
|
|
22
|
+
```tsx
|
|
23
|
+
import { setupGestureHandler } from '@tamagui/sheet'
|
|
24
|
+
import { GestureHandlerRootView } from 'react-native-gesture-handler'
|
|
25
|
+
|
|
26
|
+
// Call once at app startup (optional - falls back to PanResponder)
|
|
27
|
+
setupGestureHandler({
|
|
28
|
+
// Pass the gesture handler module so we don't add it as a hard dependency
|
|
29
|
+
GestureDetector: require('react-native-gesture-handler').GestureDetector,
|
|
30
|
+
Gesture: require('react-native-gesture-handler').Gesture,
|
|
31
|
+
})
|
|
32
|
+
|
|
33
|
+
// Then wrap app
|
|
34
|
+
export default function App() {
|
|
35
|
+
return (
|
|
36
|
+
<GestureHandlerRootView style={{ flex: 1 }}>
|
|
37
|
+
<YourApp />
|
|
38
|
+
</GestureHandlerRootView>
|
|
39
|
+
)
|
|
40
|
+
}
|
|
41
|
+
```
|
|
42
|
+
|
|
43
|
+
## Implementation Notes
|
|
44
|
+
|
|
45
|
+
If `setupGestureHandler()` is called:
|
|
46
|
+
|
|
47
|
+
- Use `GestureDetector` with `Gesture.Pan()` instead of `PanResponder`
|
|
48
|
+
- Use `simultaneousHandlers` to coordinate with ScrollView's gesture
|
|
49
|
+
- Implement `blockPan` flag pattern from actions-sheet for smooth handoff
|
|
50
|
+
|
|
51
|
+
If not called:
|
|
52
|
+
|
|
53
|
+
- Fall back to current `PanResponder` implementation
|
|
54
|
+
- Accept the minor limitations on native
|
|
55
|
+
|
|
56
|
+
## References
|
|
57
|
+
|
|
58
|
+
- gorhom/bottom-sheet: Uses Reanimated worklets + gesture handler
|
|
59
|
+
- react-native-actions-sheet: Uses `blockPan` flag pattern with gesture handler
|
|
60
|
+
- Both are MIT licensed and can be used as reference
|
|
61
|
+
|
|
62
|
+
## Files to Modify
|
|
63
|
+
|
|
64
|
+
- `SheetImplementationCustom.tsx` - Replace PanResponder with GestureDetector
|
|
65
|
+
- `SheetScrollView.tsx` - Use `useScrollHandlers()` pattern from actions-sheet
|
|
66
|
+
- Add `setupGestureHandler.ts` for optional gesture handler registration
|
|
67
|
+
|
|
68
|
+
## Test Case
|
|
69
|
+
|
|
70
|
+
There's a test case at `code/kitchen-sink/src/usecases/SheetScrollableDrag.tsx` that demonstrates the bug and can be used to verify fixes. It's not exported in the main navigation but can be accessed directly for testing.
|
|
71
|
+
|
|
72
|
+
## Attempted Fixes
|
|
73
|
+
|
|
74
|
+
1. **Native scroll enable/disable based on pane position** - Tried disabling scroll when sheet is not at top position, but this completely broke scrolling because the initial pane position values aren't set correctly on mount.
|
|
75
|
+
|
|
76
|
+
2. **PaneY change listeners** - Added `onPaneYChange`/`setPaneY` to ScrollBridge to notify ScrollView of position changes during drag, but the fundamental issue remains that iOS UIScrollView gesture recognizers fire before RN's responder system.
|
|
77
|
+
|
|
78
|
+
The core issue is architectural: React Native's PanResponder cannot coordinate with iOS's native UIScrollView gesture recognizers at the right level. The only real solution is `react-native-gesture-handler` integration.
|
package/package.json
CHANGED
|
@@ -1,14 +1,8 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@tamagui/sheet",
|
|
3
|
-
"version": "2.0.0-rc.
|
|
3
|
+
"version": "2.0.0-rc.40",
|
|
4
4
|
"license": "MIT",
|
|
5
5
|
"source": "src/index.ts",
|
|
6
|
-
"files": [
|
|
7
|
-
"src",
|
|
8
|
-
"types",
|
|
9
|
-
"dist",
|
|
10
|
-
"controller"
|
|
11
|
-
],
|
|
12
6
|
"type": "module",
|
|
13
7
|
"sideEffects": [
|
|
14
8
|
"*.css"
|
|
@@ -27,23 +21,17 @@
|
|
|
27
21
|
"./package.json": "./package.json",
|
|
28
22
|
".": {
|
|
29
23
|
"types": "./types/index.d.ts",
|
|
30
|
-
"react-native":
|
|
31
|
-
|
|
32
|
-
"import": "./dist/esm/index.native.js",
|
|
33
|
-
"require": "./dist/cjs/index.native.js"
|
|
34
|
-
},
|
|
24
|
+
"react-native": "./dist/esm/index.native.js",
|
|
25
|
+
"browser": "./dist/esm/index.mjs",
|
|
35
26
|
"module": "./dist/esm/index.mjs",
|
|
36
27
|
"import": "./dist/esm/index.mjs",
|
|
37
28
|
"require": "./dist/cjs/index.cjs",
|
|
38
|
-
"default": "./dist/
|
|
29
|
+
"default": "./dist/esm/index.mjs"
|
|
39
30
|
},
|
|
40
31
|
"./controller": {
|
|
41
32
|
"types": "./types/controller.d.ts",
|
|
42
|
-
"react-native":
|
|
43
|
-
|
|
44
|
-
"import": "./dist/esm/controller.native.js",
|
|
45
|
-
"require": "./dist/cjs/controller.native.js"
|
|
46
|
-
},
|
|
33
|
+
"react-native": "./dist/esm/controller.native.js",
|
|
34
|
+
"browser": "./dist/esm/controller.mjs",
|
|
47
35
|
"module": "./dist/esm/controller.mjs",
|
|
48
36
|
"import": "./dist/esm/controller.mjs",
|
|
49
37
|
"require": "./dist/cjs/controller.cjs",
|
|
@@ -51,15 +39,12 @@
|
|
|
51
39
|
},
|
|
52
40
|
"./setup-gesture-handler": {
|
|
53
41
|
"types": "./types/setupGestureHandler.d.ts",
|
|
54
|
-
"react-native":
|
|
55
|
-
|
|
56
|
-
"module": "./dist/esm/setupGestureHandler.native.js",
|
|
57
|
-
"import": "./dist/esm/setupGestureHandler.native.js",
|
|
58
|
-
"require": "./dist/cjs/setupGestureHandler.native.js"
|
|
59
|
-
},
|
|
42
|
+
"react-native": "./dist/esm/setupGestureHandler.native.js",
|
|
43
|
+
"browser": "./dist/esm/setupGestureHandler.mjs",
|
|
60
44
|
"module": "./dist/esm/setupGestureHandler.mjs",
|
|
61
45
|
"import": "./dist/esm/setupGestureHandler.mjs",
|
|
62
|
-
"require": "./dist/cjs/setupGestureHandler.cjs"
|
|
46
|
+
"require": "./dist/cjs/setupGestureHandler.cjs",
|
|
47
|
+
"default": "./dist/esm/setupGestureHandler.mjs"
|
|
63
48
|
}
|
|
64
49
|
},
|
|
65
50
|
"publishConfig": {
|
|
@@ -71,30 +56,30 @@
|
|
|
71
56
|
"clean": "tamagui-build clean"
|
|
72
57
|
},
|
|
73
58
|
"dependencies": {
|
|
74
|
-
"@tamagui/adapt": "2.0.0-rc.
|
|
75
|
-
"@tamagui/animate-presence": "2.0.0-rc.
|
|
76
|
-
"@tamagui/animations-react-native": "2.0.0-rc.
|
|
77
|
-
"@tamagui/compose-refs": "2.0.0-rc.
|
|
78
|
-
"@tamagui/constants": "2.0.0-rc.
|
|
79
|
-
"@tamagui/core": "2.0.0-rc.
|
|
80
|
-
"@tamagui/create-context": "2.0.0-rc.
|
|
81
|
-
"@tamagui/helpers": "2.0.0-rc.
|
|
82
|
-
"@tamagui/native": "2.0.0-rc.
|
|
83
|
-
"@tamagui/portal": "2.0.0-rc.
|
|
84
|
-
"@tamagui/remove-scroll": "2.0.0-rc.
|
|
85
|
-
"@tamagui/scroll-view": "2.0.0-rc.
|
|
86
|
-
"@tamagui/stacks": "2.0.0-rc.
|
|
87
|
-
"@tamagui/use-constant": "2.0.0-rc.
|
|
88
|
-
"@tamagui/use-controllable-state": "2.0.0-rc.
|
|
89
|
-
"@tamagui/use-did-finish-ssr": "2.0.0-rc.
|
|
90
|
-
"@tamagui/use-keyboard-visible": "2.0.0-rc.
|
|
91
|
-
"@tamagui/z-index-stack": "2.0.0-rc.
|
|
59
|
+
"@tamagui/adapt": "2.0.0-rc.40",
|
|
60
|
+
"@tamagui/animate-presence": "2.0.0-rc.40",
|
|
61
|
+
"@tamagui/animations-react-native": "2.0.0-rc.40",
|
|
62
|
+
"@tamagui/compose-refs": "2.0.0-rc.40",
|
|
63
|
+
"@tamagui/constants": "2.0.0-rc.40",
|
|
64
|
+
"@tamagui/core": "2.0.0-rc.40",
|
|
65
|
+
"@tamagui/create-context": "2.0.0-rc.40",
|
|
66
|
+
"@tamagui/helpers": "2.0.0-rc.40",
|
|
67
|
+
"@tamagui/native": "2.0.0-rc.40",
|
|
68
|
+
"@tamagui/portal": "2.0.0-rc.40",
|
|
69
|
+
"@tamagui/remove-scroll": "2.0.0-rc.40",
|
|
70
|
+
"@tamagui/scroll-view": "2.0.0-rc.40",
|
|
71
|
+
"@tamagui/stacks": "2.0.0-rc.40",
|
|
72
|
+
"@tamagui/use-constant": "2.0.0-rc.40",
|
|
73
|
+
"@tamagui/use-controllable-state": "2.0.0-rc.40",
|
|
74
|
+
"@tamagui/use-did-finish-ssr": "2.0.0-rc.40",
|
|
75
|
+
"@tamagui/use-keyboard-visible": "2.0.0-rc.40",
|
|
76
|
+
"@tamagui/z-index-stack": "2.0.0-rc.40"
|
|
92
77
|
},
|
|
93
78
|
"devDependencies": {
|
|
94
|
-
"@tamagui/build": "2.0.0-rc.
|
|
79
|
+
"@tamagui/build": "2.0.0-rc.40",
|
|
95
80
|
"react": ">=19",
|
|
96
|
-
"react-native": "0.
|
|
97
|
-
"react-native-gesture-handler": "~2.
|
|
81
|
+
"react-native": "0.83.2",
|
|
82
|
+
"react-native-gesture-handler": "~2.30.0"
|
|
98
83
|
},
|
|
99
84
|
"peerDependencies": {
|
|
100
85
|
"react": ">=19",
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
Object.assign(module.exports, require('./dist/cjs/setupGestureHandler.cjs'))
|
package/src/SheetController.tsx
CHANGED
|
@@ -8,11 +8,13 @@ import { SheetControllerContext } from './useSheetController'
|
|
|
8
8
|
export const SheetController = ({
|
|
9
9
|
children,
|
|
10
10
|
onOpenChange: onOpenChangeProp,
|
|
11
|
+
onAnimationComplete: onAnimationCompleteProp,
|
|
11
12
|
open,
|
|
12
13
|
hidden,
|
|
13
14
|
disableDrag,
|
|
14
15
|
}: Partial<SheetControllerContextValue> & { children?: ReactNode }) => {
|
|
15
16
|
const onOpenChange = useEvent(onOpenChangeProp)
|
|
17
|
+
const onAnimationComplete = useEvent(onAnimationCompleteProp)
|
|
16
18
|
const id = useId()
|
|
17
19
|
|
|
18
20
|
// track hidden transitions to signal adapt handoff
|
|
@@ -31,9 +33,10 @@ export const SheetController = ({
|
|
|
31
33
|
hidden,
|
|
32
34
|
disableDrag,
|
|
33
35
|
onOpenChange,
|
|
36
|
+
onAnimationComplete,
|
|
34
37
|
skipNextAnimation,
|
|
35
38
|
}),
|
|
36
|
-
[id, onOpenChange, open, hidden, disableDrag, skipNextAnimation]
|
|
39
|
+
[id, onOpenChange, onAnimationComplete, open, hidden, disableDrag, skipNextAnimation]
|
|
37
40
|
)
|
|
38
41
|
|
|
39
42
|
return (
|