user.js 2.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  1. import { defineStore } from 'pinia';
  2. import { clone, cloneDeep } from 'lodash-es';
  3. import { showAuthModal } from '@/common/hooks/useModal';
  4. import UserApi from '@/common/api/member/user';
  5. // 默认用户信息
  6. const defaultUserInfo = {
  7. avatar: '', // 头像
  8. nickname: '', // 昵称
  9. gender: 0, // 性别
  10. mobile: '', // 手机号
  11. point: 0, // 积分
  12. };
  13. const user = defineStore({
  14. id: 'user',
  15. state: () => ({
  16. userInfo: clone(defaultUserInfo), // 用户信息
  17. isLogin: !!uni.getStorageSync('token'), // 登录状态
  18. lastUpdateTime: 0, // 上次更新时间
  19. }),
  20. actions: {
  21. // 获取用户信息
  22. async getInfo() {
  23. const { code, data } = await UserApi.getUserInfo();
  24. if (code !== 1) {
  25. return;
  26. }
  27. this.userInfo = data;
  28. return Promise.resolve(data);
  29. },
  30. // 设置 token
  31. setToken(token = '', refreshToken = '') {
  32. if (token === '') {
  33. this.isLogin = false;
  34. uni.removeStorageSync('token');
  35. uni.removeStorageSync('refresh-token');
  36. } else {
  37. this.isLogin = true;
  38. uni.setStorageSync('token', token);
  39. uni.setStorageSync('refresh-token', refreshToken);
  40. this.loginAfter();
  41. }
  42. return this.isLogin;
  43. },
  44. // 更新用户相关信息 (手动限流,5 秒之内不刷新)
  45. async updateUserData() {
  46. if (!this.isLogin) {
  47. this.resetUserData();
  48. return;
  49. }
  50. // 防抖,5 秒之内不刷新
  51. const nowTime = new Date().getTime();
  52. if (this.lastUpdateTime + 5000 > nowTime) {
  53. return;
  54. }
  55. this.lastUpdateTime = nowTime;
  56. // 获取最新信息
  57. await this.getInfo();
  58. return this.userInfo;
  59. },
  60. // 重置用户默认数据
  61. resetUserData() {
  62. // 清空 token
  63. this.setToken();
  64. // 清空用户相关的缓存
  65. this.userInfo = clone(defaultUserInfo);
  66. },
  67. // 登录后,加载各种信息
  68. async loginAfter() {
  69. await this.updateUserData();
  70. },
  71. // 登出系统
  72. async logout() {
  73. this.resetUserData();
  74. return !this.isLogin;
  75. },
  76. },
  77. persist: {
  78. enabled: true,
  79. strategies: [
  80. {
  81. key: 'user-store',
  82. },
  83. ],
  84. },
  85. });
  86. export default user;