added profile page
parent
b04934ea6c
commit
4bdeee0899
@ -0,0 +1,53 @@
|
||||
<template>
|
||||
<div
|
||||
class="panel"
|
||||
:class="props.mode === 'horizontal' ? 'flex-row' : 'flex-col'">
|
||||
<div class="top">
|
||||
<Icon
|
||||
:name="props.icon"
|
||||
size="24" />
|
||||
<div class="title">
|
||||
{{ props.title }}
|
||||
</div>
|
||||
</div>
|
||||
<div class="middle">
|
||||
<div class="data">
|
||||
{{ props.data }}
|
||||
</div>
|
||||
</div>
|
||||
<div class="bottom"> </div>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script setup lang="ts">
|
||||
interface Props {
|
||||
mode: 'horizontal' | 'vertical';
|
||||
icon: string;
|
||||
title: string;
|
||||
description?: string;
|
||||
data: string | number;
|
||||
}
|
||||
|
||||
const props = defineProps<Props>();
|
||||
</script>
|
||||
|
||||
<style scoped>
|
||||
.panel {
|
||||
@apply bg-secondary flex h-fit w-full justify-start gap-8 p-4 text-center;
|
||||
}
|
||||
.top {
|
||||
@apply flex flex-row items-center justify-start gap-4;
|
||||
}
|
||||
.middle {
|
||||
@apply flex flex-row items-center gap-4;
|
||||
}
|
||||
.bottom {
|
||||
@apply flex flex-row items-center gap-4;
|
||||
}
|
||||
.title {
|
||||
@apply text-2xl font-bold;
|
||||
}
|
||||
.data {
|
||||
@apply text-2xl font-bold;
|
||||
}
|
||||
</style>
|
||||
@ -0,0 +1,60 @@
|
||||
<template>
|
||||
<div class="app">
|
||||
<Header />
|
||||
<div class="dashboard">
|
||||
<CardPanel
|
||||
v-for="data in dashboardData"
|
||||
:mode="data.mode"
|
||||
:icon="data.icon"
|
||||
:title="data.title"
|
||||
:description="data.description"
|
||||
:data="data.data" />
|
||||
</div>
|
||||
</div>
|
||||
</template>
|
||||
|
||||
<script setup lang="ts">
|
||||
definePageMeta({
|
||||
middleware: ['auth'],
|
||||
});
|
||||
|
||||
interface DashboardData {
|
||||
noteCount: {
|
||||
title: string;
|
||||
description: string;
|
||||
data: number;
|
||||
mode: 'horizontal' | 'vertical';
|
||||
icon: string;
|
||||
};
|
||||
}
|
||||
|
||||
const isLoading = ref<boolean>(true);
|
||||
|
||||
const dashboardData: DashboardData = reactive({
|
||||
noteCount: {
|
||||
title: 'Note Count',
|
||||
description: 'The number of notes this account is currently having',
|
||||
data: 0,
|
||||
mode: 'horizontal',
|
||||
icon: 'fa6-solid:note-sticky',
|
||||
},
|
||||
});
|
||||
|
||||
const { data: data, refresh } = await useFetch('/api/profile', {
|
||||
onResponse({ response }) {
|
||||
dashboardData.noteCount.data = response._data.count;
|
||||
},
|
||||
});
|
||||
|
||||
onMounted(() => {
|
||||
isLoading.value = true;
|
||||
refresh();
|
||||
isLoading.value = false;
|
||||
});
|
||||
</script>
|
||||
|
||||
<style scoped>
|
||||
.dashboard {
|
||||
@apply w-full max-w-3xl;
|
||||
}
|
||||
</style>
|
||||
@ -0,0 +1,16 @@
|
||||
import { serverSupabaseUser, serverSupabaseClient } from '#supabase/server';
|
||||
import { Database } from 'utils/database.types';
|
||||
|
||||
export default defineEventHandler(async (event) => {
|
||||
const user = await serverSupabaseUser(event);
|
||||
const supabase = serverSupabaseClient<Database>(event);
|
||||
|
||||
const { count, error } = await supabase
|
||||
.from('notes')
|
||||
.select('*', { count: 'exact', head: true });
|
||||
|
||||
if (!user) {
|
||||
throw createError({ statusCode: 401, message: 'Unauthorized' });
|
||||
}
|
||||
return { count: count, message: 'Profile', error: error };
|
||||
});
|
||||
Loading…
Reference in New Issue