init
This commit is contained in:
63
src/store/app.js
Normal file
63
src/store/app.js
Normal file
@@ -0,0 +1,63 @@
|
||||
import { getBreadCrumbList, getHomeRoute } from '../utils/tools'
|
||||
|
||||
// 注意:这里的 paramSetupServer 需要在使用时注入
|
||||
let paramSetupServerInstance = null
|
||||
|
||||
export const setParamSetupServer = (server) => {
|
||||
paramSetupServerInstance = server
|
||||
}
|
||||
|
||||
export default {
|
||||
namespaced: true,
|
||||
state: {
|
||||
sysFormModel: { title: '', logoUrl: '' },
|
||||
breadCrumbList: [],
|
||||
homeRoute: {}
|
||||
},
|
||||
getters: {
|
||||
sysFormModel: state => state.sysFormModel,
|
||||
breadCrumbList: state => state.breadCrumbList,
|
||||
homeRoute: state => state.homeRoute
|
||||
},
|
||||
mutations: {
|
||||
setBreadCrumb(state, route) {
|
||||
state.breadCrumbList = getBreadCrumbList(route, state.homeRoute)
|
||||
},
|
||||
setHomeRoute(state, routes) {
|
||||
state.homeRoute = getHomeRoute(routes, 'home')
|
||||
},
|
||||
setSysTitle(state, reload) {
|
||||
state.sysFormModel = reload
|
||||
}
|
||||
},
|
||||
actions: {
|
||||
async getSysTitle({ state, commit }, { defaultTitle = '智能代码平台', defaultLogo = '' }) {
|
||||
let formModel = {
|
||||
title: defaultTitle,
|
||||
logoUrl: defaultLogo
|
||||
}
|
||||
|
||||
if (!paramSetupServerInstance) {
|
||||
commit('setSysTitle', formModel)
|
||||
return
|
||||
}
|
||||
|
||||
try {
|
||||
let res1 = await paramSetupServerInstance.getOne('sys_title')
|
||||
if (res1.data) {
|
||||
formModel.title = res1.data.value
|
||||
document.title = res1.data.value
|
||||
}
|
||||
let res2 = await paramSetupServerInstance.getOne('sys_logo')
|
||||
if (res2.data) {
|
||||
formModel.logoUrl = res2.data.value
|
||||
}
|
||||
} catch (error) {
|
||||
console.error('Failed to get sys title:', error)
|
||||
}
|
||||
|
||||
commit('setSysTitle', formModel)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
10
src/store/index.js
Normal file
10
src/store/index.js
Normal file
@@ -0,0 +1,10 @@
|
||||
import userModule from './user'
|
||||
import appModule from './app'
|
||||
|
||||
export { userModule, appModule }
|
||||
|
||||
export default {
|
||||
user: userModule,
|
||||
app: appModule
|
||||
}
|
||||
|
||||
103
src/store/user.js
Normal file
103
src/store/user.js
Normal file
@@ -0,0 +1,103 @@
|
||||
import { setToken, getToken } from '../utils/tools'
|
||||
import uiTool from '../utils/uiTool'
|
||||
|
||||
// 注意:这里的 userServer 需要在使用时注入
|
||||
let userServerInstance = null
|
||||
|
||||
export const setUserServer = (server) => {
|
||||
userServerInstance = server
|
||||
}
|
||||
|
||||
export default {
|
||||
namespaced: true,
|
||||
state: {
|
||||
userName: '',
|
||||
avatorImgPath: '',
|
||||
token: getToken(),
|
||||
authorityMenus: [],
|
||||
menuList: []
|
||||
},
|
||||
mutations: {
|
||||
setAvator(state, avatorPath) {
|
||||
state.avatorImgPath = avatorPath
|
||||
},
|
||||
setUserName(state, userName) {
|
||||
state.userName = userName
|
||||
localStorage.userName = state.userName
|
||||
},
|
||||
setToken(state, token) {
|
||||
state.token = token
|
||||
setToken(token)
|
||||
},
|
||||
setAuthorityMenus(state, menus) {
|
||||
state.authorityMenus = menus
|
||||
localStorage.authorityMenus = menus
|
||||
},
|
||||
setMenuList(state, menus) {
|
||||
state.menuList = menus
|
||||
}
|
||||
},
|
||||
getters: {
|
||||
avatorImgPath: state => state.avatorImgPath,
|
||||
userName(state) {
|
||||
if (!state.userName) {
|
||||
state.userName = localStorage.userName
|
||||
}
|
||||
return state.userName
|
||||
},
|
||||
menuList: state => state.menuList
|
||||
},
|
||||
actions: {
|
||||
async setAuthorityMenus({ state, commit }, { Main, ParentView, Page404 }) {
|
||||
if (!userServerInstance) {
|
||||
console.error('userServer not initialized')
|
||||
return
|
||||
}
|
||||
|
||||
let res = await userServerInstance.authorityMenus()
|
||||
let authorityMenus = res.data
|
||||
commit('setAuthorityMenus', JSON.stringify(authorityMenus))
|
||||
|
||||
let mainMenu = uiTool.getRoutes(Main, ParentView, Page404)
|
||||
commit('setMenuList', mainMenu.children)
|
||||
},
|
||||
async handleLogin({ state, commit, dispatch }, { userFrom, Main, ParentView, Page404 }) {
|
||||
if (!userServerInstance) {
|
||||
throw new Error('userServer not initialized')
|
||||
}
|
||||
|
||||
let promise = new Promise(async (resolve, reject) => {
|
||||
try {
|
||||
let res = await userServerInstance.login(userFrom)
|
||||
|
||||
let token = res.data.token
|
||||
let name = res.data.user.name.trim()
|
||||
|
||||
if (res.data.shop) {
|
||||
let shopId = res.data.shop.id
|
||||
commit('shop/setShopId', shopId, { root: true })
|
||||
}
|
||||
|
||||
commit('setUserName', name)
|
||||
commit('setToken', token)
|
||||
|
||||
await dispatch('setAuthorityMenus', { Main, ParentView, Page404 })
|
||||
resolve(res)
|
||||
} catch (error) {
|
||||
reject(error)
|
||||
}
|
||||
})
|
||||
|
||||
return promise
|
||||
},
|
||||
async handleLogOut({ state, commit }, vue) {
|
||||
commit('setToken', '')
|
||||
commit('setAuthorityMenus', '[]')
|
||||
if (state.shop) {
|
||||
commit('shop/setShopId', '', { root: true })
|
||||
}
|
||||
window.location.reload()
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user