ant-design-vue/components/vc-select/hooks/useDelayReset.ts

33 lines
788 B
TypeScript
Raw Normal View History

2021-06-26 01:35:40 +00:00
import type { Ref } from 'vue';
import { onMounted, ref } from 'vue';
2020-10-07 14:49:01 +00:00
/**
* 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 = ref(false);
2021-11-29 09:53:09 +00:00
let delay: any;
2020-10-07 14:49:01 +00:00
const cancelLatest = () => {
2021-11-29 09:53:09 +00:00
clearTimeout(delay);
2020-10-07 14:49:01 +00:00
};
2020-11-04 15:39:05 +00:00
onMounted(() => {
2020-10-07 14:49:01 +00:00
cancelLatest();
});
const delaySetBool = (value: boolean, callback: () => void) => {
cancelLatest();
2021-11-29 09:53:09 +00:00
delay = setTimeout(() => {
2020-10-07 14:49:01 +00:00
bool.value = value;
if (callback) {
callback();
}
}, timeout);
};
return [bool, delaySetBool, cancelLatest];
}