blob: 52e56491754c69bf733aae63c6e791bae7ae26d3 (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
|
import { useState } from "react";
// holdDuration (in ms)
const useTouchHold = ({
onHold,
holdDuration = 500,
}: {
holdDuration?: number;
onHold: () => Promise<void> | void;
}) => {
const [touchTimeout, setTouchTimeout] = useState<ReturnType<
typeof setTimeout
> | null>(null);
return {
onTouchStart: () => {
setTouchTimeout(setTimeout(onHold, holdDuration));
},
onTouchEnd: () => {
if (touchTimeout) {
clearTimeout(touchTimeout);
}
},
};
};
export default useTouchHold;
|