mirror of
https://github.com/CorentinTh/it-tools.git
synced 2025-04-25 17:26:15 -04:00
feat(rsa-key-pair-generator): refresh certs button
This commit is contained in:
parent
161a21f285
commit
165dc93f83
2 changed files with 47 additions and 3 deletions
42
src/composable/computedRefreshable.ts
Normal file
42
src/composable/computedRefreshable.ts
Normal file
|
@ -0,0 +1,42 @@
|
|||
import { computedAsync } from '@vueuse/core';
|
||||
import { computed, ref, watch } from 'vue';
|
||||
|
||||
export { computedRefreshable, computedRefreshableAsync };
|
||||
|
||||
function computedRefreshable<T>(getter: () => T) {
|
||||
const dirty = ref(true);
|
||||
let value: T;
|
||||
|
||||
const update = () => (dirty.value = true);
|
||||
|
||||
watch(getter, update);
|
||||
|
||||
const computedValue = computed(() => {
|
||||
if (dirty.value) {
|
||||
value = getter();
|
||||
dirty.value = false;
|
||||
}
|
||||
return value;
|
||||
});
|
||||
|
||||
return [computedValue, update] as const;
|
||||
}
|
||||
|
||||
function computedRefreshableAsync<T>(getter: () => Promise<T>, defaultValue?: T) {
|
||||
const dirty = ref(true);
|
||||
let value: T;
|
||||
|
||||
const update = () => (dirty.value = true);
|
||||
|
||||
watch(getter, update);
|
||||
|
||||
const computedValue = computedAsync(async () => {
|
||||
if (dirty.value) {
|
||||
value = await getter();
|
||||
dirty.value = false;
|
||||
}
|
||||
return value;
|
||||
}, defaultValue);
|
||||
|
||||
return [computedValue, update] as const;
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue