index.ts
1.75 KB
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
import { defineStore } from 'pinia';
import { AppState } from './types';
import { usePermissionApi } from '@/http/role';
import { SystemPermission } from '@/types/system-permission';
const useAppStore = defineStore('app', {
state: (): AppState => ({
theme: 'light',
colorWeak: false,
navbar: true,
menu: true,
hideMenu: false,
menuCollapse: false,
footer: true,
themeColor: '#165DFF',
menuWidth: 210,
globalSettings: false,
device: 'desktop',
tabBar: false,
permissions: [],
}),
getters: {
appCurrentSetting(state: AppState): AppState {
return { ...state };
},
appDevice(state: AppState) {
return state.device;
},
appMenu(state: AppState): SystemPermission[] {
return state.permissions?.filter((item) => item.guard === 'Admin' && item.type === 'Menu') || [];
},
},
actions: {
// Update app settings
updateSettings(partial: Partial<AppState>) {
// @ts-ignore-next-line
this.$patch(partial);
},
// Change theme color
toggleTheme(dark: boolean) {
if (dark) {
this.theme = 'dark';
document.body.setAttribute('arco-theme', 'dark');
} else {
this.theme = 'light';
document.body.removeAttribute('arco-theme');
}
},
toggleDevice(device: string) {
this.device = device;
},
toggleMenu(value: boolean) {
this.hideMenu = value;
},
queryPermissionList() {
usePermissionApi
.get({
setColumn: ['id', 'parent_id', 'guard', 'name', 'label', 'icon', 'weight', 'type'],
fetchType: 'all',
sortBy: 'weight',
sortType: 'desc',
})
.then(({ data }) => (this.permissions = data));
},
},
});
export default useAppStore;