diff --git a/src/components/navbar/components/dropdowns/ProfileDropdown.vue b/src/components/navbar/components/dropdowns/ProfileDropdown.vue index 02dc20d..f83c5cd 100644 --- a/src/components/navbar/components/dropdowns/ProfileDropdown.vue +++ b/src/components/navbar/components/dropdowns/ProfileDropdown.vue @@ -10,7 +10,12 @@ - 😍 + @@ -45,8 +50,10 @@ import { ref, computed } from "vue"; import { useI18n } from "vue-i18n"; import { useColors } from "vuestic-ui"; +import { useUserStore } from "../../../../stores/user-store"; const { colors, setHSLAColor } = useColors(); +const store = useUserStore(); const hoverColor = computed(() => setHSLAColor(colors.focus, { a: 0.1 })); const { t } = useI18n(); diff --git a/src/pages/auth/CheckTheEmail.vue b/src/pages/auth/CheckTheEmail.vue index 3901685..79e3b9a 100644 --- a/src/pages/auth/CheckTheEmail.vue +++ b/src/pages/auth/CheckTheEmail.vue @@ -38,6 +38,7 @@ const submit = () => { localStorage.setItem('token', response.data.token); localStorage.setItem('profile', JSON.stringify(response.data.profile)); localStorage.setItem('user', JSON.stringify(response.data.user)); + localStorage.setItem('attachments', JSON.stringify(response.data.attachments)); router.push({ name: "dashboard" }).catch((error) => { }); }).catch((error) => { diff --git a/src/pages/auth/Login.vue b/src/pages/auth/Login.vue index de9d200..34238e0 100644 --- a/src/pages/auth/Login.vue +++ b/src/pages/auth/Login.vue @@ -89,6 +89,7 @@ const submit = () => { localStorage.setItem('token', response.data.token); localStorage.setItem('profile', JSON.stringify(response.data.profile)); localStorage.setItem('user', JSON.stringify(response.data.user)); + localStorage.setItem('attachments', JSON.stringify(response.data.attachments)); init({ message: "Вы успешно вошли!", color: "success" }); push({ name: "dashboard" }); diff --git a/src/pages/auth/Signup.vue b/src/pages/auth/Signup.vue index b82dbeb..e0c56d3 100644 --- a/src/pages/auth/Signup.vue +++ b/src/pages/auth/Signup.vue @@ -106,6 +106,7 @@ const submit = () => { localStorage.setItem('token', response.data.token); localStorage.setItem('profile', JSON.stringify(response.data.profile)); localStorage.setItem('user', JSON.stringify(response.data.user)); + localStorage.setItem('attachments', JSON.stringify(response.data.attachments)); init({ message: "Вы успешно вошли", color: "success", diff --git a/src/pages/preferences/modals/EditNameModal.vue b/src/pages/preferences/modals/EditNameModal.vue index 7337e34..385a9d2 100644 --- a/src/pages/preferences/modals/EditNameModal.vue +++ b/src/pages/preferences/modals/EditNameModal.vue @@ -62,15 +62,15 @@ const submit = () => { if (Surname.value === store.userSurname && Name.value === store.userName) { return emits("cancel"); } - let dataUser = JSON.parse(localStorage.getItem("profile")!); - dataUser.first_name = Name.value; - dataUser.surname = Surname.value; + let dataProfile = JSON.parse(localStorage.getItem("profile")!); + dataProfile.first_name = Name.value; + dataProfile.surname = Surname.value; const config = { headers: { Authorization: `Bearer ${localStorage.getItem("token")}` } }; axios .patch(`${HOST}/api/v0/profiles/${store.profileID}`, { - "profile": dataUser, + "profile": dataProfile, }, config) .then((response) => { store.changeUserName(Name.value, Surname.value); diff --git a/src/pages/preferences/preferences-header/PreferencesHeader.vue b/src/pages/preferences/preferences-header/PreferencesHeader.vue index 682ef66..9e4fe31 100644 --- a/src/pages/preferences/preferences-header/PreferencesHeader.vue +++ b/src/pages/preferences/preferences-header/PreferencesHeader.vue @@ -1,7 +1,19 @@ - + + \ No newline at end of file diff --git a/src/stores/user-store.ts b/src/stores/user-store.ts index 2093552..6f27248 100644 --- a/src/stores/user-store.ts +++ b/src/stores/user-store.ts @@ -2,11 +2,13 @@ import { defineStore } from "pinia"; export const useUserStore = defineStore("user", { state: () => { + const defaultAvatar = ""; if (!localStorage.getItem("profile")) { return { profileID: "", userName: "", email: "", + avatar: defaultAvatar, memberSince: "", pfp: "", is2FAEnabled: false, @@ -14,6 +16,7 @@ export const useUserStore = defineStore("user", { } const dataProfile = JSON.parse(localStorage.getItem("profile")!); const dataUser = JSON.parse(localStorage.getItem("user")!); + const dataAttachments = JSON.parse(localStorage.getItem("attachments")!); const dateCreate = new Date(Date.parse(dataProfile.created_at)); const yyyy = dateCreate.getFullYear().toString(); const mm = dateCreate.getMonth() + 1; @@ -28,6 +31,7 @@ export const useUserStore = defineStore("user", { } const formattedToday = stringDD + '/' + strinMM + '/' + yyyy; return { + avatar: dataAttachments.avatar.url || defaultAvatar, profileID: dataProfile.id || "", userName: dataProfile.first_name || "", userSurname: dataProfile.surname || "", @@ -47,5 +51,8 @@ export const useUserStore = defineStore("user", { this.userName = userFirst; this.userSurname = userSurname; }, + changeAvatar(avatar: string) { + this.avatar = avatar; + }, }, });