mirror of
https://github.com/Litlyx/litlyx
synced 2025-12-10 07:48:37 +01:00
implementing snapshots
This commit is contained in:
26
dashboard/composables/useSnapshot.ts
Normal file
26
dashboard/composables/useSnapshot.ts
Normal file
@@ -0,0 +1,26 @@
|
||||
import type { TProjectSnapshot } from "@schema/ProjectSnapshot";
|
||||
|
||||
const snapshots = useFetch<TProjectSnapshot[]>('/api/project/snapshots', {
|
||||
...signHeaders(),
|
||||
immediate: false
|
||||
});
|
||||
|
||||
const snapshot = ref<TProjectSnapshot>();
|
||||
|
||||
watch(snapshots.data, () => {
|
||||
if (!snapshots.data.value) return;
|
||||
snapshot.value = snapshots.data.value[0];
|
||||
});
|
||||
|
||||
const safeSnapshotDates = computed(() => {
|
||||
const from = new Date(snapshot.value?.from || 0).toISOString();
|
||||
const to = new Date(snapshot.value?.to || Date.now()).toISOString();
|
||||
return { from, to }
|
||||
})
|
||||
|
||||
export function useSnapshot() {
|
||||
if (snapshots.status.value === 'idle') {
|
||||
snapshots.execute();
|
||||
}
|
||||
return { snapshot, snapshots, safeSnapshotDates }
|
||||
}
|
||||
Reference in New Issue
Block a user