33 lines
		
	
	
		
			802 B
		
	
	
	
		
			TypeScript
		
	
	
			
		
		
	
	
			33 lines
		
	
	
		
			802 B
		
	
	
	
		
			TypeScript
		
	
	
| import type { Ref } from 'vue';
 | |
| import { onMounted, shallowRef } from 'vue';
 | |
| 
 | |
| /**
 | |
|  * Similar with `useLock`, but this hook will always execute last value.
 | |
|  * When set to `true`, it will keep `true` for a short time even if `false` is set.
 | |
|  */
 | |
| export default function useDelayReset(
 | |
|   timeout = 10,
 | |
| ): [Ref<Boolean>, (val: boolean, callback?: () => void) => void, () => void] {
 | |
|   const bool = shallowRef(false);
 | |
|   let delay: any;
 | |
| 
 | |
|   const cancelLatest = () => {
 | |
|     clearTimeout(delay);
 | |
|   };
 | |
| 
 | |
|   onMounted(() => {
 | |
|     cancelLatest();
 | |
|   });
 | |
|   const delaySetBool = (value: boolean, callback: () => void) => {
 | |
|     cancelLatest();
 | |
|     delay = setTimeout(() => {
 | |
|       bool.value = value;
 | |
|       if (callback) {
 | |
|         callback();
 | |
|       }
 | |
|     }, timeout);
 | |
|   };
 | |
| 
 | |
|   return [bool, delaySetBool, cancelLatest];
 | |
| }
 |