feat(rsa-key-pair-generator): refresh certs button

This commit is contained in:
Corentin Thomasset 2023-03-29 20:51:48 +02:00 committed by Corentin THOMASSET
parent 161a21f285
commit 165dc93f83
2 changed files with 47 additions and 3 deletions

View 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;
}

View file

@ -2,8 +2,10 @@
<div style="flex: 0 0 100%"> <div style="flex: 0 0 100%">
<n-space item-style="flex: 1 1 0" style="margin: 0 auto; max-width: 600px" justify="center"> <n-space item-style="flex: 1 1 0" style="margin: 0 auto; max-width: 600px" justify="center">
<n-form-item label="Bits :" v-bind="bitsValidationAttrs" label-placement="left" label-width="100"> <n-form-item label="Bits :" v-bind="bitsValidationAttrs" label-placement="left" label-width="100">
<n-input-number v-model:value="bits" min="256" max="16384" step="8" style="width: 150px" /> <n-input-number v-model:value="bits" min="256" max="16384" step="8" />
</n-form-item> </n-form-item>
<n-button tertiary @click="refreshCerts">Refresh key-pair</n-button>
</n-space> </n-space>
</div> </div>
@ -21,9 +23,9 @@
<script setup lang="ts"> <script setup lang="ts">
import TextareaCopyable from '@/components/TextareaCopyable.vue'; import TextareaCopyable from '@/components/TextareaCopyable.vue';
import { ref } from 'vue'; import { ref } from 'vue';
import { computedAsync } from '@vueuse/core';
import { withDefaultOnErrorAsync } from '@/utils/defaults'; import { withDefaultOnErrorAsync } from '@/utils/defaults';
import { useValidation } from '@/composable/validation'; import { useValidation } from '@/composable/validation';
import { computedRefreshableAsync } from '@/composable/computedRefreshable';
import { generateKeyPair } from './rsa-key-pair-generator.service'; import { generateKeyPair } from './rsa-key-pair-generator.service';
const bits = ref(2048); const bits = ref(2048);
@ -39,7 +41,7 @@ const { attrs: bitsValidationAttrs } = useValidation({
], ],
}); });
const certs = computedAsync( const [certs, refreshCerts] = computedRefreshableAsync(
() => withDefaultOnErrorAsync(() => generateKeyPair({ bits: bits.value }), emptyCerts), () => withDefaultOnErrorAsync(() => generateKeyPair({ bits: bits.value }), emptyCerts),
emptyCerts, emptyCerts,
); );