create-expo-cljs-app
Version:
Create a react native application with Expo and Shadow-CLJS!
56 lines (47 loc) • 1.91 kB
JavaScript
import { Direction } from './web/constants';
import FlingGestureHandler from './web/FlingGestureHandler';
import LongPressGestureHandler from './web/LongPressGestureHandler';
import NativeViewGestureHandler from './web/NativeViewGestureHandler';
import * as NodeManager from './web/NodeManager';
import PanGestureHandler from './web/PanGestureHandler';
import PinchGestureHandler from './web/PinchGestureHandler';
import RotationGestureHandler from './web/RotationGestureHandler';
import TapGestureHandler from './web/TapGestureHandler';
export const Gestures = {
PanGestureHandler,
RotationGestureHandler,
PinchGestureHandler,
TapGestureHandler,
NativeViewGestureHandler,
LongPressGestureHandler,
FlingGestureHandler // ForceTouchGestureHandler,
};
export default {
Direction,
handleSetJSResponder(tag, blockNativeResponder) {
console.warn('handleSetJSResponder: ', tag, blockNativeResponder);
},
handleClearJSResponder() {
console.warn('handleClearJSResponder: ');
},
createGestureHandler(handlerName, handlerTag, config) {
//TODO(TS) extends config
if (!(handlerName in Gestures)) throw new Error(`react-native-gesture-handler: ${handlerName} is not supported on web.`);
const GestureClass = Gestures[handlerName];
NodeManager.createGestureHandler(handlerTag, new GestureClass());
this.updateGestureHandler(handlerTag, config);
},
attachGestureHandler(handlerTag, newView, _usingDeviceEvents, propsRef) {
NodeManager.getHandler(handlerTag).setView(newView, propsRef);
},
updateGestureHandler(handlerTag, newConfig) {
NodeManager.getHandler(handlerTag).updateGestureConfig(newConfig);
},
getGestureHandlerNode(handlerTag) {
return NodeManager.getHandler(handlerTag);
},
dropGestureHandler(handlerTag) {
NodeManager.dropGestureHandler(handlerTag);
}
};
//# sourceMappingURL=RNGestureHandlerModule.web.js.map