mirror of
https://github.com/plankanban/planka.git
synced 2025-07-22 06:39:44 +02:00
Initial commit
This commit is contained in:
commit
36fe34e8e1
583 changed files with 91539 additions and 0 deletions
29
client/src/hooks/use-closable-form.js
Normal file
29
client/src/hooks/use-closable-form.js
Normal file
|
@ -0,0 +1,29 @@
|
|||
import { useCallback, useEffect, useRef } from 'react';
|
||||
|
||||
export default (isOpened, close) => {
|
||||
const isClosable = useRef(null);
|
||||
|
||||
const handleFieldBlur = useCallback(() => {
|
||||
if (isClosable.current) {
|
||||
close();
|
||||
}
|
||||
}, [close]);
|
||||
|
||||
const handleControlMouseOver = useCallback(() => {
|
||||
isClosable.current = false;
|
||||
}, []);
|
||||
|
||||
const handleControlMouseOut = useCallback(() => {
|
||||
isClosable.current = true;
|
||||
}, []);
|
||||
|
||||
useEffect(() => {
|
||||
if (isOpened) {
|
||||
isClosable.current = true;
|
||||
} else {
|
||||
isClosable.current = null;
|
||||
}
|
||||
}, [isOpened]);
|
||||
|
||||
return [handleFieldBlur, handleControlMouseOver, handleControlMouseOut];
|
||||
};
|
Loading…
Add table
Add a link
Reference in a new issue