mirror of
https://github.com/streamich/react-use.git
synced 2026-01-25 14:17:16 +00:00
38 lines
902 B
TypeScript
38 lines
902 B
TypeScript
import { useEffect } from 'react';
|
|
|
|
export type VibrationPattern = number | number[];
|
|
|
|
const isVibrationApiSupported = typeof navigator === 'object' && 'vibrate' in navigator;
|
|
|
|
const useVibrateMock = () => {};
|
|
|
|
function useVibrate(enabled: boolean = true, pattern: VibrationPattern = [1000, 1000], loop: boolean = true): void {
|
|
useEffect(() => {
|
|
let interval;
|
|
|
|
if (enabled) {
|
|
navigator.vibrate(pattern);
|
|
|
|
if (loop) {
|
|
const duration = pattern instanceof Array ? pattern.reduce((a, b) => a + b) : (pattern as number);
|
|
|
|
interval = setInterval(() => {
|
|
navigator.vibrate(pattern);
|
|
}, duration);
|
|
}
|
|
}
|
|
|
|
return () => {
|
|
if (enabled) {
|
|
navigator.vibrate(0);
|
|
|
|
if (loop) {
|
|
clearInterval(interval);
|
|
}
|
|
}
|
|
};
|
|
}, [enabled]);
|
|
}
|
|
|
|
export default isVibrationApiSupported ? useVibrate : useVibrateMock;
|