maxkb/ui/src/stores/modules-shared-system/user.ts
2025-06-12 16:51:49 +08:00

192 lines
5.4 KiB
TypeScript

import {defineStore} from 'pinia'
import {type Ref} from 'vue'
import type {User} from '@/api/type/user'
import UserApi from '@/api/user/user'
import LoginApi from '@/api/user/login'
import {cloneDeep} from 'lodash'
import ThemeApi from '@/api/system-settings/theme'
// import { defaultPlatformSetting } from '@/utils/theme'
import {useLocalStorage} from '@vueuse/core'
import {localeConfigKey, getBrowserLang} from '@/locales/index'
import useThemeStore from './theme'
import {useElementPlusTheme} from "use-element-plus-theme";
import {defaultPlatformSetting} from "@/utils/theme";
export interface userStateTypes {
userType: number // 1 系统操作者 2 对话用户
userInfo: User | null
version?: string
XPACK_LICENSE_IS_VALID: true
isXPack: true
themeInfo: any
token: any
}
const useLoginStore = defineStore('use', {
state: (): userStateTypes => ({
userType: 1, // 1 系统操作者 2 对话用户
userInfo: null,
version: '',
XPACK_LICENSE_IS_VALID: false,
isXPack: false,
themeInfo: null,
token: ''
}),
actions: {
getLanguage() {
return this.userType === 1
? localStorage.getItem('MaxKB-locale') || getBrowserLang()
: sessionStorage.getItem('language') || getBrowserLang()
},
isDefaultTheme() {
return !this.themeInfo?.theme || this.themeInfo?.theme === '#3370FF'
},
setTheme(data: any) {
const {changeTheme} = useElementPlusTheme(this.themeInfo?.theme)
changeTheme(data?.['theme'])
this.themeInfo = cloneDeep(data)
},
async profile(loading?: Ref<boolean>) {
return UserApi.getUserProfile(loading).then((ok) => {
this.userInfo = ok.data
useLocalStorage<string>(localeConfigKey, 'en-US').value =
ok?.data?.language || this.getLanguage()
const theme = useThemeStore()
theme.setTheme()
return this.asyncGetProfile()
})
},
async asyncGetProfile() {
return new Promise((resolve, reject) => {
UserApi.getProfile()
.then(async (ok) => {
// this.version = ok.data?.version || '-'
this.isXPack = true
this.XPACK_LICENSE_IS_VALID = true
if (this.isEnterprise()) {
// await this.theme()
} else {
this.themeInfo = {
...defaultPlatformSetting
}
}
resolve(ok)
})
.catch((error) => {
reject(error)
})
})
},
getPermissions() {
if (this.userInfo) {
return this.isXPack && this.XPACK_LICENSE_IS_VALID
? [...this.userInfo?.permissions, 'x-pack']
: this.userInfo?.permissions
} else {
return this.userInfo?.permissions
}
},
getRole() {
if (this.userInfo) {
return this.userInfo?.role
} else {
return ''
}
},
async theme(loading?: Ref<boolean>) {
return await ThemeApi.getThemeInfo(loading).then((ok) => {
this.setTheme(ok.data)
// window.document.title = this.themeInfo['title'] || 'MaxKB'
// const link = document.querySelector('link[rel="icon"]') as any
// if (link) {
// link['href'] = this.themeInfo['icon'] || '/favicon.ico'
// }
})
},
showXpack() {
return this.isXPack
},
isExpire() {
return this.isXPack && !this.XPACK_LICENSE_IS_VALID
},
isEnterprise() {
return this.isXPack && this.XPACK_LICENSE_IS_VALID
},
// changeUserType(num: number, token?: string) {
// this.userType = num
// this.userAccessToken = token
// },
async dingCallback(code: string) {
return LoginApi.getDingCallback(code).then((ok) => {
this.token = ok.data
localStorage.setItem('token', ok.data)
return this.profile()
})
},
async dingOauth2Callback(code: string) {
return LoginApi.getDingOauth2Callback(code).then((ok) => {
this.token = ok.data
localStorage.setItem('token', ok.data)
return this.profile()
})
},
async wecomCallback(code: string) {
return LoginApi.getWecomCallback(code).then((ok) => {
this.token = ok.data
localStorage.setItem('token', ok.data)
return this.profile()
})
},
async larkCallback(code: string) {
return LoginApi.getLarkCallback(code).then((ok) => {
this.token = ok.data
localStorage.setItem('token', ok.data)
return this.profile()
})
},
async logout() {
return LoginApi.logout().then(() => {
localStorage.removeItem('token')
return true
})
},
async getAuthType() {
return LoginApi.getAuthType().then((ok) => {
return ok.data
})
},
async getQrType() {
return LoginApi.getQrType().then((ok) => {
return ok.data
})
},
async getQrSource() {
return LoginApi.getQrSource().then((ok) => {
return ok.data
})
},
async postUserLanguage(lang: string, loading?: Ref<boolean>) {
return new Promise((resolve, reject) => {
LoginApi.postLanguage({ language: lang }, loading)
.then(async (ok) => {
useLocalStorage(localeConfigKey, 'en-US').value = lang
window.location.reload()
resolve(ok)
})
.catch((error) => {
reject(error)
})
})
}
},
})
export default useLoginStore