2024-08-21 02:01:29 +02:00
|
|
|
// Copyright 2024, Command Line Inc.
|
|
|
|
// SPDX-License-Identifier: Apache-2.0
|
|
|
|
|
2024-07-09 08:13:12 +02:00
|
|
|
import { useCallback, useEffect, useRef, useState } from "react";
|
|
|
|
|
2024-09-03 20:24:45 +02:00
|
|
|
export const useLongClick = (ref, onClick, onLongClick, disabled = false, ms = 300) => {
|
2024-07-09 08:13:12 +02:00
|
|
|
const timerRef = useRef(null);
|
|
|
|
const [longClickTriggered, setLongClickTriggered] = useState(false);
|
|
|
|
|
|
|
|
const startPress = useCallback(
|
|
|
|
(e: React.MouseEvent<any>) => {
|
|
|
|
if (onLongClick == null) {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
setLongClickTriggered(false);
|
|
|
|
timerRef.current = setTimeout(() => {
|
|
|
|
setLongClickTriggered(true);
|
|
|
|
onLongClick?.(e);
|
|
|
|
}, ms);
|
|
|
|
},
|
|
|
|
[onLongClick, ms]
|
|
|
|
);
|
|
|
|
|
|
|
|
const stopPress = useCallback(() => {
|
|
|
|
clearTimeout(timerRef.current);
|
|
|
|
}, []);
|
|
|
|
|
|
|
|
const handleClick = useCallback(
|
|
|
|
(e: React.MouseEvent<any>) => {
|
|
|
|
if (longClickTriggered) {
|
2024-07-15 18:40:28 +02:00
|
|
|
e.preventDefault();
|
|
|
|
e.stopPropagation();
|
2024-07-09 08:13:12 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
onClick?.(e);
|
|
|
|
},
|
|
|
|
[longClickTriggered, onClick]
|
|
|
|
);
|
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
const element = ref.current;
|
|
|
|
|
2024-09-03 20:24:45 +02:00
|
|
|
if (!element || disabled) return;
|
2024-07-09 08:13:12 +02:00
|
|
|
|
|
|
|
element.addEventListener("mousedown", startPress);
|
|
|
|
element.addEventListener("mouseup", stopPress);
|
|
|
|
element.addEventListener("mouseleave", stopPress);
|
|
|
|
element.addEventListener("click", handleClick);
|
|
|
|
|
|
|
|
return () => {
|
|
|
|
element.removeEventListener("mousedown", startPress);
|
|
|
|
element.removeEventListener("mouseup", stopPress);
|
|
|
|
element.removeEventListener("mouseleave", stopPress);
|
|
|
|
element.removeEventListener("click", handleClick);
|
|
|
|
};
|
|
|
|
}, [ref.current, startPress, stopPress, handleClick]);
|
|
|
|
|
|
|
|
return ref;
|
|
|
|
};
|