user.js 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. import pinia from "~src/store/init"
  2. import appConfig from '~src/config/app';
  3. import {useAppStore} from "~src/store";
  4. import {useOsTheme} from 'vooks'
  5. import {getRoutes} from '~api/menu';
  6. import themeData from '~src/config/theme';
  7. import tokenData from "~src/router/modules/token";
  8. import {setStoreData} from "~src/utils/storage";
  9. import {userLogin,refreshToken,logout} from '~api/user';
  10. import {userConfigInfo, userConfigSave} from "~api/other";
  11. import {ArrToOneObj, getArrValue, getIndex, getObjValue} from "vue-utils-plus"
  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. console.log(res['access_token'])
  19. store.setTokenVal(res['access_token'])
  20. store.setRefreshTokenVal(res['refresh_token'])
  21. store.setTenantId(res['tenant_id'])
  22. store.setUserInfo(res)
  23. const routerRes = await setRouterData()
  24. if (!routerRes) {
  25. return Promise.reject({msg:'路由异常'});
  26. }
  27. await initUserConfigInfo()
  28. return Promise.resolve(res);
  29. } else {
  30. return Promise.reject(res);
  31. }
  32. }
  33. //用户信息初始化
  34. export const initUserConfigInfo = async () => {
  35. const {error, data} = await userConfigInfo();
  36. if (error) {
  37. return Promise.reject(false);
  38. }
  39. const res = getObjValue(data)
  40. if (res?.theme) {
  41. const {theme,color,homeTheme,shotWebRtc,fullScreen,opinionView} = res
  42. //设置主题
  43. store.setTheme(theme)
  44. //设置模式
  45. if (theme === 'auto') {
  46. store.setThemeVal(useOsTheme().value)
  47. } else {
  48. store.setThemeVal(theme)
  49. }
  50. //获取主色调和首页主题数据
  51. let themeColor = themeData.color, themeHome = themeData.home;
  52. let colorIndex = getIndex(themeColor,'name',color)
  53. let homeIndex = getIndex(themeHome,'name',homeTheme)
  54. //设置主色调
  55. if (colorIndex !== -1) {
  56. store.setColor(themeColor[colorIndex])
  57. }
  58. //设置首页主题
  59. if (homeIndex !== -1) {
  60. store.setHomeTheme(themeHome[homeIndex])
  61. }
  62. //设置工单服务的弹出框
  63. store.setOrderServiceTipModal(opinionView ?? 1)
  64. store.setShotWebRtc(shotWebRtc)
  65. store.setShotWebRtc(fullScreen)
  66. return Promise.resolve(true);
  67. } else {
  68. await userConfigSave({
  69. theme: appConfig?.theme || '',
  70. color: appConfig?.color?.name || '',
  71. homeTheme: appConfig?.homeTheme?.name || '',
  72. shotWebRtc: '0',
  73. fullScreen: '1',
  74. opinionView: 1
  75. })
  76. return Promise.resolve(true);
  77. }
  78. }
  79. //设置路由信息
  80. export const setRouterData = async () => {
  81. //请求接口,获取路由数据
  82. const {error, data} = await getRoutes()
  83. if (error) {
  84. return Promise.reject(false);
  85. }
  86. const resData = getArrValue(data)
  87. //数据转换
  88. let routesObj = {}, routesArr = []
  89. await ArrToOneObj(resData, 'code', routesObj, routesArr)
  90. const routes = [...tokenData, ...routesArr] //合并
  91. //数据缓存
  92. store.setMenus(resData)
  93. setStoreData('route', routesObj)
  94. setStoreData('routes', routes)
  95. return Promise.resolve(true);
  96. }
  97. //刷新token
  98. export const RefreshToken = async () => {
  99. try {
  100. window.console.log('刷新 token');
  101. const { dept_id, role_id } = store.getUserInfo;
  102. const refresh = store.getRefreshToken;
  103. const tenantId = store.getTenantId;
  104. const { error, status, res } = await refreshToken(refresh, tenantId, dept_id, role_id);
  105. if (!error && status === 200) {
  106. store.setTokenVal(res['access_token'])
  107. store.setRefreshTokenVal(res['refresh_token'])
  108. store.setTenantId(res['tenant_id'])
  109. store.setUserInfo(res)
  110. return Promise.resolve(res);
  111. } else {
  112. return Promise.reject(res);
  113. }
  114. } catch (e) {
  115. window.console.warn('token 刷新失败: ', e);
  116. return Promise.reject(e);
  117. }
  118. }
  119. //登出
  120. export const LogOut = async () => {
  121. return await logout();
  122. }