diff --git a/src/components/auth/ProfileDialog.vue b/src/components/auth/ProfileDialog.vue new file mode 100644 index 0000000..fbb5d51 --- /dev/null +++ b/src/components/auth/ProfileDialog.vue @@ -0,0 +1,123 @@ + + + + + + + + + User Profile + + + Your account information and settings + + + + + + + + + + Account Information + + + Your profile details + + + + + + Name: + {{ userDisplay.name }} + + + + Username: + {{ userDisplay.username }} + + + + Email: + {{ userDisplay.email }} + + + + User ID: + {{ userDisplay.shortId }} + + + + + + + + + + + Account Actions + + + Manage your account settings + + + + + + + Account Settings + + + + + Change Password + + + + + Logout + + + + + + + + + No user information available + + + + \ No newline at end of file diff --git a/src/components/layout/Navbar.vue b/src/components/layout/Navbar.vue index 291921a..81b4e34 100644 --- a/src/components/layout/Navbar.vue +++ b/src/components/layout/Navbar.vue @@ -9,6 +9,7 @@ import { DropdownMenu, DropdownMenuContent, DropdownMenuItem, DropdownMenuSepara import { Sun, Moon, Menu, X, User, LogOut } from 'lucide-vue-next' import LanguageSwitcher from '@/components/LanguageSwitcher.vue' import LoginDialog from '@/components/auth/LoginDialog.vue' +import ProfileDialog from '@/components/auth/ProfileDialog.vue' import { auth } from '@/composables/useAuth' interface NavigationItem { @@ -21,6 +22,7 @@ const { t } = useI18n() const { theme, setTheme } = useTheme() const isOpen = ref(false) const showLoginDialog = ref(false) +const showProfileDialog = ref(false) const navigation = computed(() => [ { name: t('nav.home'), href: '/' }, @@ -41,6 +43,11 @@ const openLoginDialog = () => { isOpen.value = false // Close mobile menu } +const openProfileDialog = () => { + showProfileDialog.value = true + isOpen.value = false // Close mobile menu +} + const handleLogout = async () => { try { auth.logout() @@ -87,7 +94,7 @@ const handleLogout = async () => { - + Profile @@ -146,7 +153,7 @@ const handleLogout = async () => { Logged In - + Profile @@ -181,5 +188,8 @@ const handleLogout = async () => { + + +
No user information available