user.ts 3.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127
  1. import { defineStore } from "pinia";
  2. import {
  3. type userType,
  4. store,
  5. router,
  6. resetRouter,
  7. routerArrays,
  8. storageLocal
  9. } from "../utils";
  10. import {
  11. type UserResult,
  12. type RefreshTokenResult,
  13. getLogin,
  14. refreshTokenApi,
  15. verifySmsLogin,
  16. getUserInfo
  17. } from "@/api/user";
  18. import { useMultiTagsStoreHook } from "./multiTags";
  19. import {
  20. type DataInfo,
  21. setToken,
  22. removeToken,
  23. userKey,
  24. setUserInfo
  25. } from "@/utils/auth";
  26. export const useUserStore = defineStore("pure-user", {
  27. state: (): userType => ({
  28. // 头像
  29. avatar: storageLocal().getItem<DataInfo<number>>(userKey)?.avatar ?? "",
  30. // 用户名
  31. username: storageLocal().getItem<DataInfo<number>>(userKey)?.username ?? "",
  32. // 昵称
  33. nickname: storageLocal().getItem<DataInfo<number>>(userKey)?.nickname ?? "",
  34. // 页面级别权限
  35. roles: storageLocal().getItem<DataInfo<number>>(userKey)?.roles ?? [],
  36. // 按钮级别权限
  37. permissions:
  38. storageLocal().getItem<DataInfo<number>>(userKey)?.permissions ?? [],
  39. // 是否勾选了登录页的免登录
  40. isRemembered: false,
  41. // 登录页的免登录存储几天,默认7天
  42. loginDay: 7
  43. }),
  44. actions: {
  45. /** 存储头像 */
  46. SET_AVATAR(avatar: string) {
  47. this.avatar = avatar;
  48. },
  49. /** 存储用户名 */
  50. SET_USERNAME(username: string) {
  51. this.username = username;
  52. },
  53. /** 存储昵称 */
  54. SET_NICKNAME(nickname: string) {
  55. this.nickname = nickname;
  56. },
  57. /** 存储角色 */
  58. SET_ROLES(roles: Array<string>) {
  59. this.roles = roles;
  60. },
  61. /** 存储按钮级别权限 */
  62. SET_PERMS(permissions: Array<string>) {
  63. this.permissions = permissions;
  64. },
  65. /** 存储是否勾选了登录页的免登录 */
  66. SET_ISREMEMBERED(bool: boolean) {
  67. this.isRemembered = bool;
  68. },
  69. /** 设置登录页的免登录存储几天 */
  70. SET_LOGINDAY(value: number) {
  71. this.loginDay = Number(value);
  72. },
  73. /** 登入 */
  74. async loginByUsername(data: object, submitType: number) {
  75. return new Promise<UserResult>((resolve, reject) => {
  76. const loginfn = submitType === 1 ? getLogin : verifySmsLogin;
  77. loginfn(data)
  78. .then(res => {
  79. console.log(321321, res);
  80. if (res?.code === 200) {
  81. setToken(res.data);
  82. getUserInfo().then(response => {
  83. if (response?.code === 200) {
  84. console.log(response);
  85. setUserInfo(response);
  86. }
  87. });
  88. }
  89. resolve(res);
  90. })
  91. .catch(error => {
  92. reject(error);
  93. });
  94. });
  95. },
  96. /** 前端登出(不调用接口) */
  97. logOut() {
  98. this.username = "";
  99. this.roles = [];
  100. this.permissions = [];
  101. removeToken();
  102. useMultiTagsStoreHook().handleTags("equal", [...routerArrays]);
  103. resetRouter();
  104. router.push("/login");
  105. },
  106. /** 刷新`token` */
  107. async handRefreshToken(data) {
  108. return new Promise<RefreshTokenResult>((resolve, reject) => {
  109. refreshTokenApi(data)
  110. .then(data => {
  111. if (data) {
  112. setToken(data.data);
  113. resolve(data);
  114. }
  115. })
  116. .catch(error => {
  117. reject(error);
  118. });
  119. });
  120. }
  121. }
  122. });
  123. export function useUserStoreHook() {
  124. return useUserStore(store);
  125. }