Files
afrobiz/components/AppHeader.vue
2023-03-25 16:03:28 +11:00

48 lines
1.6 KiB
Vue

<script setup lang="ts">
import { MembershipWithAccount } from '~~/lib/services/user.account.service';
import { storeToRefs } from 'pinia';
const supabase = useSupabaseAuthClient();
const user = useSupabaseUser();
const store = useAppStore()
const { activeMembership } = storeToRefs(store);
const { $client } = useNuxtApp();
const { data: dbUser } = await $client.userAccount.getDBUser.useQuery();
onMounted(async () => {
await store.initUser();
});
async function signout() {
await supabase.auth.signOut();
navigateTo('/', {replace: true});
}
</script>
<template>
<div>
<h3>Nuxt 3 Boilerplate - AppHeader</h3>
<!-- logged in & sign out -->
<div v-if="user">logged in as: {{ user.email }}: <button @click="signout()">Sign Out</button></div>
<div v-if="!user">Not Logged in</div>
<div>
<NuxtLink to="/">Boilerplate</NuxtLink>&nbsp;
|&nbsp;<NuxtLink to="/dashboard">Dashboard</NuxtLink>&nbsp;
|&nbsp;<NuxtLink to="/pricing">Pricing</NuxtLink>&nbsp;
|&nbsp;<NuxtLink to="/account">Account</NuxtLink>
</div>
<!-- Account Switching -->
<p v-if="(dbUser?.dbUser?.memberships) && (dbUser.dbUser.memberships.length > 1)">
<span>Switch Account.. </span>
<button v-for="membership in dbUser?.dbUser.memberships" @click="store.changeActiveMembership(((membership as unknown) as MembershipWithAccount))"> <!-- This cast is infuriating -->
{{ membership.account.name }}
<span v-if="membership.account_id === activeMembership?.account_id">*</span>
</button>
</p>
<hr>
</div>
</template>