2024-12-31 10:05:55 +08:00
|
|
|
|
import { defineStore } from 'pinia'
|
|
|
|
|
|
import { ref } from 'vue'
|
|
|
|
|
|
|
|
|
|
|
|
const initState = { nickname: '', avatar: '' }
|
|
|
|
|
|
|
|
|
|
|
|
export const useUserStore = defineStore(
|
|
|
|
|
|
'user',
|
|
|
|
|
|
() => {
|
|
|
|
|
|
const userInfo = ref<IUserInfo>({ ...initState })
|
|
|
|
|
|
|
|
|
|
|
|
const setUserInfo = (val: IUserInfo) => {
|
|
|
|
|
|
userInfo.value = val
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
const clearUserInfo = () => {
|
|
|
|
|
|
userInfo.value = { ...initState }
|
|
|
|
|
|
}
|
|
|
|
|
|
// 一般没有reset需求,不需要的可以删除
|
|
|
|
|
|
const reset = () => {
|
|
|
|
|
|
userInfo.value = { ...initState }
|
|
|
|
|
|
}
|
|
|
|
|
|
const isLogined = computed(() => !!userInfo.value.token)
|
|
|
|
|
|
|
|
|
|
|
|
return {
|
|
|
|
|
|
userInfo,
|
|
|
|
|
|
setUserInfo,
|
|
|
|
|
|
clearUserInfo,
|
|
|
|
|
|
isLogined,
|
2024-12-31 10:19:20 +08:00
|
|
|
|
reset
|
2024-12-31 10:05:55 +08:00
|
|
|
|
}
|
|
|
|
|
|
},
|
|
|
|
|
|
{
|
2024-12-31 10:19:20 +08:00
|
|
|
|
persist: true
|
|
|
|
|
|
}
|
2024-12-31 10:05:55 +08:00
|
|
|
|
)
|