2024-04-12 00:20:26 +02:00
|
|
|
import React from 'react'
|
|
|
|
import {impactAsync, ImpactFeedbackStyle} from 'expo-haptics'
|
2024-04-05 06:19:38 +02:00
|
|
|
|
2023-05-24 22:59:53 +02:00
|
|
|
import {isIOS, isWeb} from 'platform/detection'
|
2024-04-12 00:20:26 +02:00
|
|
|
import {useHapticsDisabled} from 'state/preferences/disable-haptics'
|
2023-05-23 03:46:36 +02:00
|
|
|
|
2024-04-05 06:19:38 +02:00
|
|
|
const hapticImpact: ImpactFeedbackStyle = isIOS
|
|
|
|
? ImpactFeedbackStyle.Medium
|
|
|
|
: ImpactFeedbackStyle.Light // Users said the medium impact was too strong on Android; see APP-537s
|
2023-05-23 03:46:36 +02:00
|
|
|
|
2024-04-12 00:20:26 +02:00
|
|
|
export function useHaptics() {
|
|
|
|
const isHapticsDisabled = useHapticsDisabled()
|
|
|
|
|
|
|
|
return React.useCallback(() => {
|
|
|
|
if (isHapticsDisabled || isWeb) {
|
2023-05-24 22:59:53 +02:00
|
|
|
return
|
|
|
|
}
|
2024-04-05 06:19:38 +02:00
|
|
|
impactAsync(hapticImpact)
|
2024-04-12 00:20:26 +02:00
|
|
|
}, [isHapticsDisabled])
|
2023-05-24 22:59:53 +02:00
|
|
|
}
|