react-native-turbo-haptics
Version:
Fast, worklet-compatible haptic feedback for React Native
40 lines (38 loc) • 1.25 kB
JavaScript
import { NativeModules } from 'react-native';
import TurboHapticsModule from './NativeTurboHaptics';
const noop = () => {
'worklet';
return;
};
export const initTurboHaptics = () => {
// Check if already initialized
if (globalThis.createHapticFeedback == null) {
try {
let success = false;
const nativeModule = NativeModules.TurboHaptics;
if (TurboHapticsModule && typeof TurboHapticsModule.install === 'function') {
success = TurboHapticsModule.install();
} else if (nativeModule && typeof nativeModule.install === 'function') {
success = nativeModule.install();
}
if (!success) {
console.warn('TurboHaptics: Failed to initialize');
return null;
}
if (globalThis.createHapticFeedback == null) {
console.warn('TurboHaptics: Failed to create haptic feedback');
return null;
}
} catch (e) {
console.warn('TurboHaptics: Initialization failed:', e);
return null;
}
}
return globalThis.createHapticFeedback ? globalThis.createHapticFeedback() : null;
};
// Initialize module
const haptics = initTurboHaptics() || {
trigger: noop
};
export const internalTrigger = haptics.trigger;
//# sourceMappingURL=initModule.js.map