user.js 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140
  1. import pinia from '~src/store/init'
  2. import appConfig from '~src/config/app'
  3. import { useAppStore } from '~src/store'
  4. import { getRoutes } from '~api/menu'
  5. import themeData from '~src/config/theme'
  6. import tokenData from '~src/router/modules/token'
  7. import { setStoreValue } from '~src/utils/storage'
  8. import { logout, refreshToken, userLogin } from '~api/user'
  9. import { userConfigInfo, userConfigSave } from '~api/other'
  10. import { ArrToOneObj, arrIndex, getArrValue, getObjValue, isNullES } from 'js-fast-way'
  11. import { useOsTheme } from 'hc-vue3-ui'
  12. //初始变量
  13. const store = useAppStore(pinia)
  14. //登录
  15. export const useAppLogin = async (form) => {
  16. const { error, status, res } = await userLogin(form)
  17. if (!error && status === 200) {
  18. store.setTokenVal(res['access_token'])
  19. store.setRefreshTokenVal(res['refresh_token'])
  20. store.setTenantId(res['tenant_id'])
  21. store.setUserInfo(res)
  22. //获取路由菜单
  23. const routerRes = await setRouterData()
  24. if (routerRes.length <= 0) {
  25. return { error: true, msg: '路由异常' }
  26. }
  27. //获取路由首页
  28. const isHomeUrl = await getHomeRouter(routerRes)
  29. if (isNullES(isHomeUrl)) {
  30. return { error: true, msg: '菜单权限异常' }
  31. }
  32. //获取配置数据
  33. await initUserConfigInfo()
  34. return { error, status, res }
  35. } else {
  36. return { error, status, res }
  37. }
  38. }
  39. //获取路由菜单的主入口路径
  40. const getHomeRouter = async (arr) => {
  41. //判断 arr 数组中的 children 中是否有数据,没数据的话,取下一个元素
  42. const menus = arr.filter((item) => {
  43. if (item?.children.length > 0) {
  44. const menua = item.children.filter((items) => {
  45. return items?.children.length > 0
  46. })
  47. return menua.length > 0
  48. } else {
  49. return false
  50. }
  51. })
  52. //处理数据
  53. if (menus.length <= 0) return false
  54. const code = menus[0]?.children[0]?.children[0]?.code
  55. if (isNullES(code)) return false
  56. store.setHomeUrl(code)
  57. return true
  58. }
  59. //用户信息初始化
  60. export const initUserConfigInfo = async () => {
  61. const { error, data } = await userConfigInfo()
  62. if (error) return false
  63. const res = getObjValue(data)
  64. if (res?.theme) {
  65. const { theme, color } = res
  66. //设置主题
  67. store.setTheme(theme)
  68. //设置模式
  69. if (theme === 'auto') {
  70. store.setThemeVal(useOsTheme())
  71. } else {
  72. store.setThemeVal(theme)
  73. }
  74. //获取主色调和首页主题数据
  75. let themeColor = themeData.color
  76. let colorIndex = arrIndex(themeColor, 'name', color)
  77. //设置主色调
  78. if (colorIndex !== -1) {
  79. store.setColor(themeColor[colorIndex])
  80. }
  81. return true
  82. } else {
  83. await userConfigSave({
  84. theme: appConfig?.theme || '',
  85. color: appConfig?.color?.name || '',
  86. })
  87. return true
  88. }
  89. }
  90. //设置路由信息
  91. export const setRouterData = async () => {
  92. //请求接口,获取路由数据
  93. const { error, data } = await getRoutes()
  94. if (error) {
  95. return Promise.reject(false)
  96. }
  97. const resData = getArrValue(data)
  98. //数据转换
  99. let routesObj = {}, routesArr = []
  100. await ArrToOneObj(resData, 'code', routesObj, routesArr)
  101. const routes = [...tokenData, ...routesArr] //合并
  102. //数据缓存
  103. store.setMenus(resData)
  104. setStoreValue('route', routesObj)
  105. setStoreValue('routes', routes)
  106. return resData
  107. }
  108. //刷新token
  109. export const RefreshToken = async () => {
  110. try {
  111. window.console.log('刷新 token')
  112. const { dept_id, role_id } = store.getUserInfo
  113. const refresh = store.getRefreshToken
  114. const tenantId = store.getTenantId
  115. const { error, status, res } = await refreshToken(refresh, tenantId, dept_id, role_id)
  116. if (!error && status === 200) {
  117. store.setTokenVal(res['access_token'])
  118. store.setRefreshTokenVal(res['refresh_token'])
  119. store.setTenantId(res['tenant_id'])
  120. store.setUserInfo(res)
  121. return Promise.resolve(res)
  122. } else {
  123. return Promise.reject(res)
  124. }
  125. } catch (e) {
  126. window.console.warn('token 刷新失败: ', e)
  127. return Promise.reject(e)
  128. }
  129. }
  130. //登出
  131. export const LogOut = async () => {
  132. return await logout()
  133. }