wujingjing
2024-04-22 f106e4dffb8279cb90726e83e7edd631f4c77699
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
import { defineStore } from 'pinia';
import Cookies from 'js-cookie';
import { Local, Session } from '/@/utils/storage';
import { clearAccessTokens, userInfoKey } from '/@/utils/request';
 
/**
 * 用户信息
 * @methods setUserInfos 设置用户信息
 */
export const useUserInfo = defineStore('userInfo', {
    state: (): UserInfosState => ({
        userInfos: {
            SoftWare: '',
            User: '',
            userName: '',
            photo: '',
            time: 0,
            roles: [],
            authBtnList: [],
        },
    }),
    actions: {
        async setUserInfos(UserInfo: any) {
            // userInfo 保存在缓存中,这样刷新时就不会丢失
            if (Local.get(userInfoKey)) {
                this.userInfos = Local.get(userInfoKey);
            } else {
                Local.set(userInfoKey, UserInfo);
            }
        },
        // 模拟接口数据
        // https://gitee.com/lyt-top/vue-next-admin/issues/I5F1HP
        async getUserInfo() {
            return new Promise((resolve) => {
                setTimeout(() => {
                    if (Local.get(userInfoKey)) {
                        this.userInfos = Local.get(userInfoKey);
                        resolve(this.userInfos);
                    } else {
                        clearAccessTokens();
                        window.location.reload();
 
                        return;
                    }
                }, 0);
            });
 
            return new Promise((resolve) => {
                setTimeout(() => {
                    // 模拟数据,请求接口时,记得删除多余代码及对应依赖的引入
                    const userName = Cookies.get('userName');
                    // 模拟数据
                    let defaultRoles: Array<string> = [];
                    let defaultAuthBtnList: Array<string> = [];
                    // admin 页面权限标识,对应路由 meta.roles,用于控制路由的显示/隐藏
                    let adminRoles: Array<string> = ['admin'];
                    // admin 按钮权限标识
                    let adminAuthBtnList: Array<string> = ['btn.add', 'btn.del', 'btn.edit', 'btn.link'];
                    // test 页面权限标识,对应路由 meta.roles,用于控制路由的显示/隐藏
                    let testRoles: Array<string> = ['common'];
                    // test 按钮权限标识
                    let testAuthBtnList: Array<string> = ['btn.add', 'btn.link'];
                    // 不同用户模拟不同的用户权限
                    if (userName === 'admin') {
                        defaultRoles = adminRoles;
                        defaultAuthBtnList = adminAuthBtnList;
                    } else {
                        defaultRoles = testRoles;
                        defaultAuthBtnList = testAuthBtnList;
                    }
                    // 用户信息模拟数据
                    const userInfos = {
                        userName: userName,
                        photo:
                            userName === 'admin'
                                ? 'https://img2.baidu.com/it/u=1978192862,2048448374&fm=253&fmt=auto&app=138&f=JPEG?w=504&h=500'
                                : 'https://img2.baidu.com/it/u=2370931438,70387529&fm=253&fmt=auto&app=138&f=JPEG?w=500&h=500',
                        time: new Date().getTime(),
                        roles: defaultRoles,
                        authBtnList: defaultAuthBtnList,
                    };
                    resolve(userInfos);
                }, 0);
            });
        },
    },
});