Files
contexted-v3/src/components/TopBar.vue
2023-05-20 07:13:06 +02:00

90 lines
2.9 KiB
Vue

<script setup lang="ts">
import { addNote, setActiveNote, rootNote } from '@/composables/useNotes'
import { user, signOut as firebaseSignOut, isPendingRedirect } from '@/composables/useAuth'
const props = defineProps<{
sideBarCollapsed: boolean
}>()
const emit = defineEmits<{
toggleSideBar: []
}>()
const signOut = (close: () => Promise<Boolean>) => {
firebaseSignOut()
close()
}
const signedIn = ref<boolean>(false)
const closeAuthModal = async (close: () => Promise<boolean>) => {
await close()
signedIn.value = true
redirectPending.value = false
}
watch(user, () => {
if (!user.value) signedIn.value = false
})
const redirectPending = ref<boolean>(isPendingRedirect())
</script>
<template>
<div class="fixed left-0 right-0 top-0 z-[500] flex h-[50px] bg-primary">
<div class="mx-auto flex w-full max-w-app items-center py-2.5 text-white">
<div class="flex items-center pl-3" :class="sideBarCollapsed ? 'w-fit' : 'w-sidebar pr-3'">
<Hamburger
:side-bar-collapsed="props.sideBarCollapsed"
@toggle-side-bar="emit('toggleSideBar')"
/>
<Logo
class="ml-auto pl-5 text-2xl hover:drop-shadow"
id="logo"
@click="setActiveNote(rootNote?.id)"
/>
</div>
<div class="flex h-full flex-grow flex-row items-center gap-2 pl-5 pr-3">
<SearchBar />
<button
class="btn-outline btn-sm btn py-1 text-white"
@click="addNote('Untitled new note', '', true)"
>
<i class="fas fa-plus-circle text-[1.1rem]" />
</button>
<Modal v-if="!signedIn" :open="redirectPending">
<template #activator="{ open }">
<button class="btn-outline btn-sm btn py-1 text-white" @click="open">Sign in</button>
</template>
<template #default="{ close }">
<Auth :authenticating="redirectPending" @signedIn="closeAuthModal(close)" />
</template>
<template #actions="{ close }">
<button class="btn-sm btn" @click="close">Close</button>
</template>
</Modal>
<Modal v-else-if="user">
<template #activator="{ open }">
<button class="btn-outline btn-sm btn py-1 text-white" @click="open">
{{ user.displayName || user.email }}
</button>
</template>
<template #default>Are you sure want to signout?</template>
<template #actions="{ close }">
<button class="btn-sm btn" @click="close">Close</button>
<button class="btn-primary btn-sm btn" @click="signOut(close)">Sign out</button>
</template>
</Modal>
</div>
</div>
</div>
</template>
<style lang="css">
#logo {
@apply cursor-pointer transition-all duration-200 hover:text-primary;
}
#logo:hover {
text-shadow: 0 0 5px white, 0 0 10px white, 0 0 15px white;
}
.btn-outline {
@apply hover:border-white hover:bg-white hover:text-primary focus-visible:outline-white;
}
</style>