Did more stuff than I even wanna write. Notably:
- Auth/account management - Navigation system - Admin views for LOA stuff
This commit is contained in:
@@ -2,24 +2,99 @@
|
||||
import { RouterLink, RouterView } from 'vue-router';
|
||||
import Separator from './components/ui/separator/Separator.vue';
|
||||
import Button from './components/ui/button/Button.vue';
|
||||
import Application from './pages/Application.vue';
|
||||
import AutoForm from './components/form/AutoForm.vue';
|
||||
import ManageApplications from './pages/ManageApplications.vue';
|
||||
import { Popover, PopoverContent, PopoverTrigger } from './components/ui/popover';
|
||||
import {
|
||||
DropdownMenu,
|
||||
DropdownMenuContent,
|
||||
DropdownMenuItem,
|
||||
DropdownMenuTrigger,
|
||||
} from './components/ui/dropdown-menu';
|
||||
import { onMounted } from 'vue';
|
||||
import { useUserStore } from './stores/user';
|
||||
|
||||
const userStore = useUserStore();
|
||||
|
||||
onMounted(async () => {
|
||||
const res = await fetch(`${import.meta.env.VITE_APIHOST}/members/me`, {
|
||||
credentials: 'include',
|
||||
});
|
||||
const data = await res.json();
|
||||
userStore.user = data;
|
||||
});
|
||||
|
||||
</script>
|
||||
|
||||
<template>
|
||||
<div>
|
||||
<div class="h-15 flex items-center justify-center gap-20">
|
||||
<Button variant="link">Link</Button>
|
||||
<Button variant="link">Link</Button>
|
||||
<Button variant="link">Link</Button>
|
||||
<Button variant="link">Link</Button>
|
||||
<div class="flex items-center justify-between px-10">
|
||||
<div></div>
|
||||
<div class="h-15 flex items-center justify-center gap-20">
|
||||
<RouterLink to="/">
|
||||
<Button variant="link">Home</Button>
|
||||
</RouterLink>
|
||||
<!-- <RouterLink to="/">
|
||||
<Button variant="link">Calendar</Button>
|
||||
</RouterLink> -->
|
||||
<RouterLink to="/members">
|
||||
<Button variant="link">Members</Button>
|
||||
</RouterLink>
|
||||
<Popover>
|
||||
<PopoverTrigger as-child>
|
||||
<Button variant="link">Forms</Button>
|
||||
</PopoverTrigger>
|
||||
<PopoverContent class="flex flex-col gap-4 items-center w-min">
|
||||
<RouterLink to="/transfer">
|
||||
<Button variant="link">Transfer Request</Button>
|
||||
</RouterLink>
|
||||
<RouterLink to="/trainingReport">
|
||||
<Button variant="link">Training Report</Button>
|
||||
</RouterLink>
|
||||
</PopoverContent>
|
||||
</Popover>
|
||||
<Popover>
|
||||
<PopoverTrigger as-child>
|
||||
<Button variant="link">Administration</Button>
|
||||
</PopoverTrigger>
|
||||
<PopoverContent class="flex flex-col gap-4 items-center w-min">
|
||||
<RouterLink to="/administration/rankChange">
|
||||
<Button variant="link">Promotions</Button>
|
||||
</RouterLink>
|
||||
<RouterLink to="/administration/loa">
|
||||
<Button variant="link">Leave of Absence</Button>
|
||||
</RouterLink>
|
||||
<RouterLink to="/administration/transfer">
|
||||
<Button variant="link">Transfer Requests</Button>
|
||||
</RouterLink>
|
||||
<RouterLink to="/administration/applications">
|
||||
<Button variant="link">Recruitment</Button>
|
||||
</RouterLink>
|
||||
</PopoverContent>
|
||||
</Popover>
|
||||
|
||||
</div>
|
||||
<div>
|
||||
<DropdownMenu v-if="userStore.isLoggedIn">
|
||||
<DropdownMenuTrigger class="cursor-pointer">
|
||||
<p>Profile</p>
|
||||
</DropdownMenuTrigger>
|
||||
<DropdownMenuContent>
|
||||
<DropdownMenuItem>My Profile</DropdownMenuItem>
|
||||
<DropdownMenuItem>Settings</DropdownMenuItem>
|
||||
<DropdownMenuItem>
|
||||
<RouterLink to="/loa">
|
||||
Submit LOA
|
||||
</RouterLink>
|
||||
</DropdownMenuItem>
|
||||
<DropdownMenuItem :variant="'destructive'">Logout</DropdownMenuItem>
|
||||
</DropdownMenuContent>
|
||||
</DropdownMenu>
|
||||
|
||||
<a v-else href="https://aj17thdevapi.nexuszone.net/login">Login</a>
|
||||
</div>
|
||||
</div>
|
||||
<Separator></Separator>
|
||||
<!-- <Application></Application> -->
|
||||
<!-- <ManageApplications></ManageApplications> -->
|
||||
<!-- <AutoForm class="max-w-3xl mx-auto my-20"></AutoForm> -->
|
||||
<RouterView></RouterView>
|
||||
|
||||
<RouterView></RouterView>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
|
||||
Reference in New Issue
Block a user