Files
drop-app/app.vue
2024-10-12 17:34:47 +11:00

51 lines
1.0 KiB
Vue

<template>
<NuxtLayout class="select-none w-screen h-screen">
<NuxtPage />
</NuxtLayout>
</template>
<script setup lang="ts">
import { invoke } from "@tauri-apps/api/core";
// @ts-expect-error
import { AppStatus, type AppState } from "./types.d.ts";
import { listen } from "@tauri-apps/api/event";
import { useAppState } from "./composables/app-state.js";
const router = useRouter();
const state = useAppState();
state.value = await invoke("fetch_state");
router.beforeEach(async () => {
state.value = await invoke("fetch_state");
});
switch (state.value.status) {
case AppStatus.NotConfigured:
router.push("/setup");
break;
case AppStatus.SignedOut:
router.push("/auth");
break;
case AppStatus.SignedInNeedsReauth:
router.push("/auth/signedout");
break;
}
listen("auth/processing", () => {
router.push("/auth/processing");
});
listen("auth/failed", () => {
router.push("/auth/failed");
});
listen("auth/finished", () => {
router.push("/");
});
useHead({
title: "Drop"
})
</script>