xto-fronted 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (49) hide show
  1. package/README.md +95 -0
  2. package/dist/403-MQkNUulz.js +31 -0
  3. package/dist/404-BOFYLq4X.js +31 -0
  4. package/dist/App.vue.d.ts +2 -0
  5. package/dist/api/auth.d.ts +8 -0
  6. package/dist/api/system.d.ts +16 -0
  7. package/dist/api/user.d.ts +13 -0
  8. package/dist/components/Layout/Footer.vue.d.ts +2 -0
  9. package/dist/components/Layout/Header.vue.d.ts +4 -0
  10. package/dist/components/Layout/Sidebar.vue.d.ts +2 -0
  11. package/dist/components/Layout/Tabs.vue.d.ts +2 -0
  12. package/dist/components/Layout/index.vue.d.ts +2 -0
  13. package/dist/composables/useAuth.d.ts +9 -0
  14. package/dist/composables/useForm.d.ts +20 -0
  15. package/dist/composables/useTable.d.ts +29 -0
  16. package/dist/directives/permission.d.ts +4 -0
  17. package/dist/enums/index.d.ts +32 -0
  18. package/dist/index-BJxYdNPy.js +475 -0
  19. package/dist/index-BvnIIBR1.js +142 -0
  20. package/dist/index-CEvAq6KE.js +372 -0
  21. package/dist/index-DPkqej__.js +345 -0
  22. package/dist/index-pq9Z5K62.js +184 -0
  23. package/dist/index-vVfjShJR.js +1183 -0
  24. package/dist/index.d.ts +24 -0
  25. package/dist/index.es.js +73 -0
  26. package/dist/index.umd.js +1 -0
  27. package/dist/main.d.ts +0 -0
  28. package/dist/router/dynamicRoutes.d.ts +34 -0
  29. package/dist/router/index.d.ts +6 -0
  30. package/dist/router/staticRoutes.d.ts +3 -0
  31. package/dist/stores/app.d.ts +75 -0
  32. package/dist/stores/auth.d.ts +31 -0
  33. package/dist/stores/index.d.ts +9 -0
  34. package/dist/stores/menu.d.ts +108 -0
  35. package/dist/stores/user.d.ts +113 -0
  36. package/dist/style.css +1 -0
  37. package/dist/utils/auth.d.ts +18 -0
  38. package/dist/utils/permission.d.ts +17 -0
  39. package/dist/utils/request.d.ts +25 -0
  40. package/dist/utils/storage.d.ts +24 -0
  41. package/dist/views/dashboard/index.vue.d.ts +2 -0
  42. package/dist/views/error/403.vue.d.ts +2 -0
  43. package/dist/views/error/404.vue.d.ts +2 -0
  44. package/dist/views/login/index.vue.d.ts +4 -0
  45. package/dist/views/system/menu/index.vue.d.ts +4 -0
  46. package/dist/views/system/role/index.vue.d.ts +4 -0
  47. package/dist/views/system/user/index.vue.d.ts +4 -0
  48. package/dist/vite.svg +10 -0
  49. package/package.json +71 -0
@@ -0,0 +1,113 @@
1
+ import { UserInfo } from '../types/api';
2
+ export declare const useUserStore: import('pinia').StoreDefinition<"user", Pick<{
3
+ userInfo: import('vue').Ref<{
4
+ id: number | string;
5
+ username: string;
6
+ nickname: string;
7
+ avatar?: string | undefined;
8
+ email?: string | undefined;
9
+ phone?: string | undefined;
10
+ status: number;
11
+ roles: string[];
12
+ permissions: string[];
13
+ createTime?: string | undefined;
14
+ updateTime?: string | undefined;
15
+ } | null, UserInfo | {
16
+ id: number | string;
17
+ username: string;
18
+ nickname: string;
19
+ avatar?: string | undefined;
20
+ email?: string | undefined;
21
+ phone?: string | undefined;
22
+ status: number;
23
+ roles: string[];
24
+ permissions: string[];
25
+ createTime?: string | undefined;
26
+ updateTime?: string | undefined;
27
+ } | null>;
28
+ roles: import('vue').Ref<string[], string[]>;
29
+ permissions: import('vue').Ref<string[], string[]>;
30
+ isLoggedIn: import('vue').ComputedRef<boolean>;
31
+ username: import('vue').ComputedRef<string>;
32
+ nickname: import('vue').ComputedRef<string>;
33
+ avatar: import('vue').ComputedRef<string>;
34
+ userId: import('vue').ComputedRef<string | number | undefined>;
35
+ setUserInfo: (info: UserInfo) => void;
36
+ clearUserInfo: () => void;
37
+ hasPermission: (permission: string | string[]) => boolean;
38
+ hasRole: (role: string | string[]) => boolean;
39
+ }, "userInfo" | "roles" | "permissions">, Pick<{
40
+ userInfo: import('vue').Ref<{
41
+ id: number | string;
42
+ username: string;
43
+ nickname: string;
44
+ avatar?: string | undefined;
45
+ email?: string | undefined;
46
+ phone?: string | undefined;
47
+ status: number;
48
+ roles: string[];
49
+ permissions: string[];
50
+ createTime?: string | undefined;
51
+ updateTime?: string | undefined;
52
+ } | null, UserInfo | {
53
+ id: number | string;
54
+ username: string;
55
+ nickname: string;
56
+ avatar?: string | undefined;
57
+ email?: string | undefined;
58
+ phone?: string | undefined;
59
+ status: number;
60
+ roles: string[];
61
+ permissions: string[];
62
+ createTime?: string | undefined;
63
+ updateTime?: string | undefined;
64
+ } | null>;
65
+ roles: import('vue').Ref<string[], string[]>;
66
+ permissions: import('vue').Ref<string[], string[]>;
67
+ isLoggedIn: import('vue').ComputedRef<boolean>;
68
+ username: import('vue').ComputedRef<string>;
69
+ nickname: import('vue').ComputedRef<string>;
70
+ avatar: import('vue').ComputedRef<string>;
71
+ userId: import('vue').ComputedRef<string | number | undefined>;
72
+ setUserInfo: (info: UserInfo) => void;
73
+ clearUserInfo: () => void;
74
+ hasPermission: (permission: string | string[]) => boolean;
75
+ hasRole: (role: string | string[]) => boolean;
76
+ }, "isLoggedIn" | "username" | "nickname" | "avatar" | "userId">, Pick<{
77
+ userInfo: import('vue').Ref<{
78
+ id: number | string;
79
+ username: string;
80
+ nickname: string;
81
+ avatar?: string | undefined;
82
+ email?: string | undefined;
83
+ phone?: string | undefined;
84
+ status: number;
85
+ roles: string[];
86
+ permissions: string[];
87
+ createTime?: string | undefined;
88
+ updateTime?: string | undefined;
89
+ } | null, UserInfo | {
90
+ id: number | string;
91
+ username: string;
92
+ nickname: string;
93
+ avatar?: string | undefined;
94
+ email?: string | undefined;
95
+ phone?: string | undefined;
96
+ status: number;
97
+ roles: string[];
98
+ permissions: string[];
99
+ createTime?: string | undefined;
100
+ updateTime?: string | undefined;
101
+ } | null>;
102
+ roles: import('vue').Ref<string[], string[]>;
103
+ permissions: import('vue').Ref<string[], string[]>;
104
+ isLoggedIn: import('vue').ComputedRef<boolean>;
105
+ username: import('vue').ComputedRef<string>;
106
+ nickname: import('vue').ComputedRef<string>;
107
+ avatar: import('vue').ComputedRef<string>;
108
+ userId: import('vue').ComputedRef<string | number | undefined>;
109
+ setUserInfo: (info: UserInfo) => void;
110
+ clearUserInfo: () => void;
111
+ hasPermission: (permission: string | string[]) => boolean;
112
+ hasRole: (role: string | string[]) => boolean;
113
+ }, "setUserInfo" | "clearUserInfo" | "hasPermission" | "hasRole">>;
package/dist/style.css ADDED
@@ -0,0 +1 @@
1
+ .sidebar[data-v-69e6558d]{height:100%;display:flex;flex-direction:column;background-color:var(--bg-color)}.sidebar__logo[data-v-69e6558d]{height:50px;display:flex;align-items:center;justify-content:center;gap:10px;border-bottom:1px solid var(--color-border-lighter)}.sidebar__logo-img[data-v-69e6558d]{width:32px;height:32px}.sidebar__logo-text[data-v-69e6558d]{font-size:16px;font-weight:600;color:var(--color-primary)}.sidebar__search[data-v-69e6558d]{padding:10px;border-bottom:1px solid var(--color-border-lighter);position:relative}.sidebar__search-results[data-v-69e6558d]{position:absolute;top:100%;left:0;right:0;background-color:var(--bg-color);border:1px solid var(--color-border-lighter);border-radius:var(--border-radius-base);box-shadow:var(--box-shadow);max-height:300px;overflow-y:auto;z-index:100}.sidebar__search-item[data-v-69e6558d]{display:flex;align-items:center;gap:10px;padding:10px 12px;cursor:pointer;transition:background-color .2s}.sidebar__search-item[data-v-69e6558d]:hover{background-color:var(--color-fill)}.sidebar__search-item-info[data-v-69e6558d]{display:flex;flex-direction:column;gap:2px}.sidebar__search-item-title[data-v-69e6558d]{font-size:14px;color:var(--color-text-primary)}.sidebar__search-item-parent[data-v-69e6558d]{font-size:12px;color:var(--color-text-secondary)}.sidebar__menu[data-v-69e6558d]{flex:1;border-right:none;overflow-y:auto}.sidebar__user[data-v-69e6558d]{padding:10px;border-top:1px solid var(--color-border-lighter);display:flex;align-items:center;justify-content:space-between}.sidebar__user-info[data-v-69e6558d]{display:flex;flex-direction:column;gap:2px}.sidebar__user-name[data-v-69e6558d]{font-size:14px;font-weight:500}.sidebar__user-role[data-v-69e6558d]{font-size:12px;color:var(--color-text-secondary)}.menu-icon[data-v-69e6558d]{margin-right:8px}.header[data-v-a8667482]{display:flex;align-items:center;justify-content:space-between;padding:0 20px;height:100%}.header__left[data-v-a8667482]{display:flex;align-items:center;gap:15px}.header__collapse[data-v-a8667482]{width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:18px;color:var(--color-text-regular)}.header__collapse[data-v-a8667482]:hover{color:var(--color-primary)}.header__breadcrumb[data-v-a8667482]{font-size:14px;color:var(--color-text-secondary)}.header__breadcrumb .is-current[data-v-a8667482]{color:var(--color-text-primary);font-weight:500}.header__right[data-v-a8667482]{display:flex;align-items:center;gap:15px}.header__action[data-v-a8667482]{width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;border-radius:var(--border-radius-base);font-size:16px}.header__action[data-v-a8667482]:hover{background-color:var(--color-fill)}.header__user[data-v-a8667482]{position:relative}.header__user-trigger[data-v-a8667482]{display:flex;align-items:center;gap:8px;cursor:pointer;padding:4px 8px;border-radius:var(--border-radius-base);transition:background-color .2s}.header__user-trigger[data-v-a8667482]:hover{background-color:var(--color-fill)}.header__user-name[data-v-a8667482]{font-size:14px;color:var(--color-text-primary)}.header__user-arrow[data-v-a8667482]{font-size:10px;color:var(--color-text-secondary);transition:transform .2s}.header__user-arrow.is-active[data-v-a8667482]{transform:rotate(180deg)}.header__avatar[data-v-a8667482]{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light-3));display:flex;align-items:center;justify-content:center;color:#fff;font-size:14px;font-weight:500}.header__dropdown[data-v-a8667482]{position:absolute;top:calc(100% + 8px);right:0;min-width:200px;background-color:var(--bg-color);border-radius:var(--border-radius-base);box-shadow:var(--box-shadow);overflow:hidden;z-index:100}.header__dropdown-header[data-v-a8667482]{display:flex;align-items:center;gap:12px;padding:16px}.header__dropdown-avatar[data-v-a8667482]{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light-3));display:flex;align-items:center;justify-content:center;color:#fff;font-size:16px;font-weight:500}.header__dropdown-info[data-v-a8667482]{flex:1}.header__dropdown-name[data-v-a8667482]{font-size:14px;font-weight:500;color:var(--color-text-primary)}.header__dropdown-role[data-v-a8667482]{font-size:12px;color:var(--color-text-secondary);margin-top:2px}.header__dropdown-divider[data-v-a8667482]{height:1px;background-color:var(--color-border-lighter)}.header__dropdown-menu[data-v-a8667482]{padding:8px 0}.header__dropdown-item[data-v-a8667482]{display:flex;align-items:center;gap:10px;padding:10px 16px;cursor:pointer;font-size:14px;color:var(--color-text-regular);transition:all .2s}.header__dropdown-item[data-v-a8667482]:hover{background-color:var(--color-fill);color:var(--color-text-primary)}.header__dropdown-item--danger[data-v-a8667482]{color:var(--color-danger)}.header__dropdown-item--danger[data-v-a8667482]:hover{background-color:var(--color-danger-light);color:var(--color-danger)}.header__dropdown-icon[data-v-a8667482]{font-size:16px}.dropdown-enter-active[data-v-a8667482],.dropdown-leave-active[data-v-a8667482]{transition:all .2s ease}.dropdown-enter-from[data-v-a8667482],.dropdown-leave-to[data-v-a8667482]{opacity:0;transform:translateY(-10px)}.layout[data-v-1a24e6d0]{display:flex;width:100%;height:100%}.layout__aside[data-v-1a24e6d0]{transition:width .3s;overflow:hidden;flex-shrink:0;height:100%}.layout__main[data-v-1a24e6d0]{flex:1;display:flex;flex-direction:column;overflow:hidden;height:100%}.layout__header[data-v-1a24e6d0]{height:50px;background-color:var(--bg-color);border-bottom:1px solid var(--color-border-lighter);flex-shrink:0}.layout__content[data-v-1a24e6d0]{flex:1;overflow:auto;background-color:var(--bg-color-page)}.tabs-wrapper[data-v-bd3be691]{width:100%;height:100%;padding:0 10px}.tabs-wrapper[data-v-bd3be691] .t-tabs{height:100%}.tabs-wrapper[data-v-bd3be691] .t-tabs__header{margin:0;border-bottom:none}.tabs-wrapper[data-v-bd3be691] .t-tabs__nav{border:none}.tabs-wrapper[data-v-bd3be691] .t-tabs__item{height:32px;line-height:32px;border:1px solid var(--color-border-lighter);margin-right:5px;border-radius:var(--border-radius-base);padding:0 15px}.tabs-wrapper[data-v-bd3be691] .t-tabs__item.is-active{background-color:var(--color-primary-light-9);border-color:var(--color-primary)}.tab-label[data-v-bd3be691]{display:flex;align-items:center;gap:5px}.tab-close[data-v-bd3be691]{width:14px;height:14px;display:flex;align-items:center;justify-content:center;font-size:10px;border-radius:50%}.tab-close[data-v-bd3be691]:hover{background-color:var(--color-danger-light);color:var(--color-danger)}.footer[data-v-317ae311]{width:100%;text-align:center;font-size:12px;color:var(--color-text-secondary)}.login[data-v-eb51a732]{width:100%;min-height:100vh;display:flex;align-items:center;justify-content:flex-end;padding-right:15%;background:linear-gradient(135deg,var(--color-primary-light-9) 0%,var(--color-primary-light-7) 100%)}.login__container[data-v-eb51a732]{width:400px;padding:40px;background-color:var(--bg-color);border-radius:var(--border-radius-large);box-shadow:var(--box-shadow-dark)}.login__header[data-v-eb51a732]{text-align:center;margin-bottom:30px}.login__logo[data-v-eb51a732]{width:60px;height:60px}.login__title[data-v-eb51a732]{font-size:28px;font-weight:600;color:var(--color-primary);margin:15px 0 5px}.login__subtitle[data-v-eb51a732]{font-size:14px;color:var(--color-text-secondary)}.login__form[data-v-eb51a732] .t-form-item{margin-bottom:20px}.login__form[data-v-eb51a732] .x-input__prefix{margin-right:8px}.login__submit[data-v-eb51a732]{width:100%}.login__footer[data-v-eb51a732]{text-align:center;margin-top:20px;font-size:12px;color:var(--color-text-placeholder)}.error-page[data-v-f1a1acb0]{width:100%;height:100vh;display:flex;align-items:center;justify-content:center;background-color:var(--bg-color-page)}.error-page__content[data-v-f1a1acb0]{text-align:center}.error-page__code[data-v-f1a1acb0]{font-size:120px;font-weight:600;color:var(--color-primary);line-height:1;margin-bottom:20px}.error-page__title[data-v-f1a1acb0]{font-size:24px;font-weight:500;color:var(--color-text-primary);margin-bottom:10px}.error-page__desc[data-v-f1a1acb0]{font-size:14px;color:var(--color-text-secondary);margin-bottom:30px}.error-page[data-v-f6105e3d]{width:100%;height:100vh;display:flex;align-items:center;justify-content:center;background-color:var(--bg-color-page)}.error-page__content[data-v-f6105e3d]{text-align:center}.error-page__code[data-v-f6105e3d]{font-size:120px;font-weight:600;color:var(--color-warning);line-height:1;margin-bottom:20px}.error-page__title[data-v-f6105e3d]{font-size:24px;font-weight:500;color:var(--color-text-primary);margin-bottom:10px}.error-page__desc[data-v-f6105e3d]{font-size:14px;color:var(--color-text-secondary);margin-bottom:30px}.dashboard[data-v-4bb1b10a]{padding:20px}.dashboard__stats[data-v-4bb1b10a]{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:20px}@media (max-width: 1200px){.dashboard__stats[data-v-4bb1b10a]{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.dashboard__stats[data-v-4bb1b10a]{grid-template-columns:1fr}}.dashboard__main[data-v-4bb1b10a]{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;margin-bottom:20px}@media (max-width: 992px){.dashboard__main[data-v-4bb1b10a]{grid-template-columns:1fr}}.dashboard__quick[data-v-4bb1b10a],.dashboard__activity[data-v-4bb1b10a]{min-height:300px}.card-title[data-v-4bb1b10a]{font-size:16px;font-weight:500}.stat-card__content[data-v-4bb1b10a]{display:flex;align-items:center;gap:15px}.stat-card__icon[data-v-4bb1b10a]{width:50px;height:50px;display:flex;align-items:center;justify-content:center;font-size:24px;border-radius:var(--border-radius-base)}.stat-card__info[data-v-4bb1b10a]{flex:1}.stat-card__title[data-v-4bb1b10a]{font-size:14px;color:var(--color-text-secondary);margin-bottom:5px}.stat-card__value[data-v-4bb1b10a]{font-size:24px;font-weight:600}.quick-links[data-v-4bb1b10a]{display:grid;grid-template-columns:repeat(4,1fr);gap:15px}@media (max-width: 768px){.quick-links[data-v-4bb1b10a]{grid-template-columns:repeat(2,1fr)}}.quick-link[data-v-4bb1b10a]{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:20px;border-radius:var(--border-radius-base);background-color:var(--color-fill);text-decoration:none;transition:all var(--transition-duration-fast)}.quick-link[data-v-4bb1b10a]:hover{background-color:var(--color-primary-light-9);transform:translateY(-2px)}.quick-link__icon[data-v-4bb1b10a]{font-size:28px;margin-bottom:10px}.quick-link__title[data-v-4bb1b10a]{font-size:14px;color:var(--color-text-primary)}.activity-list[data-v-4bb1b10a]{display:flex;flex-direction:column;gap:15px}.activity-item[data-v-4bb1b10a]{display:flex;align-items:center;gap:10px;padding-bottom:15px;border-bottom:1px solid var(--color-border-lighter)}.activity-item[data-v-4bb1b10a]:last-child{border-bottom:none;padding-bottom:0}.activity-item__action[data-v-4bb1b10a]{flex:1;font-size:14px;color:var(--color-text-regular)}.activity-item__time[data-v-4bb1b10a]{font-size:12px;color:var(--color-text-placeholder)}.system-info[data-v-4bb1b10a]{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}@media (max-width: 768px){.system-info[data-v-4bb1b10a]{grid-template-columns:1fr}}.system-info__item[data-v-4bb1b10a]{display:flex;align-items:center;gap:10px}.system-info__label[data-v-4bb1b10a]{font-size:14px;color:var(--color-text-secondary);min-width:80px}.system-info__value[data-v-4bb1b10a]{font-size:14px;color:var(--color-text-primary)}.user-page[data-v-4ebcfe66]{padding:20px}.user-page .search-card[data-v-4ebcfe66]{margin-bottom:20px}.user-page .toolbar[data-v-4ebcfe66]{margin-bottom:15px}.data-table[data-v-4ebcfe66]{width:100%;border-collapse:collapse}.data-table th[data-v-4ebcfe66],.data-table td[data-v-4ebcfe66]{padding:12px;text-align:left;border-bottom:1px solid var(--color-border-lighter)}.data-table th[data-v-4ebcfe66]{font-weight:500;color:var(--color-text-regular);background-color:var(--color-fill-light)}.data-table .loading-cell[data-v-4ebcfe66],.data-table .empty-cell[data-v-4ebcfe66]{text-align:center;color:var(--color-text-secondary);padding:40px}.pagination-wrapper[data-v-4ebcfe66]{display:flex;justify-content:flex-end;margin-top:20px}.role-page[data-v-b714caf1]{padding:20px}.role-page .search-card[data-v-b714caf1]{margin-bottom:20px}.role-page .toolbar[data-v-b714caf1]{margin-bottom:15px}.data-table[data-v-b714caf1]{width:100%;border-collapse:collapse}.data-table th[data-v-b714caf1],.data-table td[data-v-b714caf1]{padding:12px;text-align:left;border-bottom:1px solid var(--color-border-lighter)}.data-table th[data-v-b714caf1]{font-weight:500;color:var(--color-text-regular);background-color:var(--color-fill-light)}.data-table .loading-cell[data-v-b714caf1],.data-table .empty-cell[data-v-b714caf1]{text-align:center;color:var(--color-text-secondary);padding:40px}.pagination-wrapper[data-v-b714caf1]{display:flex;justify-content:flex-end;margin-top:20px}.menu-page[data-v-14a9dcbc]{padding:20px}.menu-page .toolbar[data-v-14a9dcbc]{margin-bottom:15px}.tree-table[data-v-14a9dcbc]{width:100%;border-collapse:collapse}.tree-table th[data-v-14a9dcbc],.tree-table td[data-v-14a9dcbc]{padding:12px;text-align:left;border-bottom:1px solid var(--color-border-lighter)}.tree-table th[data-v-14a9dcbc]{font-weight:500;color:var(--color-text-regular);background-color:var(--color-fill-light)}.tree-table .tree-row--level-1 td[data-v-14a9dcbc]:first-child{padding-left:30px}.tree-indent[data-v-14a9dcbc]{display:inline-block;width:20px}.menu-name[data-v-14a9dcbc]{cursor:pointer;color:var(--color-primary)}.menu-name[data-v-14a9dcbc]:hover{text-decoration:underline}
@@ -0,0 +1,18 @@
1
+ /**
2
+ * Token 管理
3
+ */
4
+ export interface TokenInfo {
5
+ token: string;
6
+ refreshToken: string;
7
+ expireTime: number;
8
+ }
9
+ export declare const getToken: () => string | null;
10
+ export declare const setToken: (token: string) => void;
11
+ export declare const getRefreshToken: () => string | null;
12
+ export declare const setRefreshToken: (refreshToken: string) => void;
13
+ export declare const getTokenExpire: () => number | null;
14
+ export declare const setTokenExpire: (expireTime: number) => void;
15
+ export declare const setTokenInfo: (info: TokenInfo) => void;
16
+ export declare const clearToken: () => void;
17
+ export declare const isTokenExpired: () => boolean;
18
+ export declare const hasToken: () => boolean;
@@ -0,0 +1,17 @@
1
+ /**
2
+ * 权限工具函数
3
+ */
4
+ /**
5
+ * 检查是否有权限
6
+ * @param permission 权限标识
7
+ */
8
+ export declare function hasPermission(permission: string | string[]): boolean;
9
+ /**
10
+ * 检查是否有角色
11
+ * @param role 角色标识
12
+ */
13
+ export declare function hasRole(role: string | string[]): boolean;
14
+ /**
15
+ * 检查是否是管理员
16
+ */
17
+ export declare function isAdmin(): boolean;
@@ -0,0 +1,25 @@
1
+ import { AxiosInstance, AxiosRequestConfig } from 'axios';
2
+ export interface ApiResponse<T = unknown> {
3
+ code: number;
4
+ data: T;
5
+ message: string;
6
+ }
7
+ export interface PageParams {
8
+ page: number;
9
+ pageSize: number;
10
+ }
11
+ export interface PageResponse<T> {
12
+ list: T[];
13
+ total: number;
14
+ page: number;
15
+ pageSize: number;
16
+ }
17
+ declare const request: AxiosInstance;
18
+ export declare const http: {
19
+ get<T = unknown>(url: string, config?: AxiosRequestConfig): Promise<ApiResponse<T>>;
20
+ post<T = unknown>(url: string, data?: unknown, config?: AxiosRequestConfig): Promise<ApiResponse<T>>;
21
+ put<T = unknown>(url: string, data?: unknown, config?: AxiosRequestConfig): Promise<ApiResponse<T>>;
22
+ patch<T = unknown>(url: string, data?: unknown, config?: AxiosRequestConfig): Promise<ApiResponse<T>>;
23
+ delete<T = unknown>(url: string, config?: AxiosRequestConfig): Promise<ApiResponse<T>>;
24
+ };
25
+ export default request;
@@ -0,0 +1,24 @@
1
+ /**
2
+ * 本地存储封装
3
+ */
4
+ interface StorageWrapper {
5
+ get<T>(key: string): T | null;
6
+ set(key: string, value: unknown): void;
7
+ remove(key: string): void;
8
+ clear(): void;
9
+ }
10
+ export declare const localStorageUtil: StorageWrapper;
11
+ export declare const sessionStorageUtil: StorageWrapper;
12
+ export declare const local: {
13
+ get: <T>(key: string) => T | null;
14
+ set: (key: string, value: unknown) => void;
15
+ remove: (key: string) => void;
16
+ clear: () => void;
17
+ };
18
+ export declare const session: {
19
+ get: <T>(key: string) => T | null;
20
+ set: (key: string, value: unknown) => void;
21
+ remove: (key: string) => void;
22
+ clear: () => void;
23
+ };
24
+ export {};
@@ -0,0 +1,2 @@
1
+ declare const _default: import('vue').DefineComponent<{}, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<{}> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, true, {}, HTMLDivElement>;
2
+ export default _default;
@@ -0,0 +1,2 @@
1
+ declare const _default: import('vue').DefineComponent<{}, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<{}> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, true, {}, HTMLDivElement>;
2
+ export default _default;
@@ -0,0 +1,2 @@
1
+ declare const _default: import('vue').DefineComponent<{}, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<{}> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, true, {}, HTMLDivElement>;
2
+ export default _default;
@@ -0,0 +1,4 @@
1
+ declare const _default: import('vue').DefineComponent<{}, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<{}> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, true, {
2
+ formRef: any;
3
+ }, HTMLDivElement>;
4
+ export default _default;
@@ -0,0 +1,4 @@
1
+ declare const _default: import('vue').DefineComponent<{}, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<{}> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, true, {
2
+ formRef: any;
3
+ }, HTMLDivElement>;
4
+ export default _default;
@@ -0,0 +1,4 @@
1
+ declare const _default: import('vue').DefineComponent<{}, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<{}> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, true, {
2
+ formRef: any;
3
+ }, HTMLDivElement>;
4
+ export default _default;
@@ -0,0 +1,4 @@
1
+ declare const _default: import('vue').DefineComponent<{}, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<{}> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, true, {
2
+ formRef: any;
3
+ }, HTMLDivElement>;
4
+ export default _default;
package/dist/vite.svg ADDED
@@ -0,0 +1,10 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" viewBox="0 0 256 256">
2
+ <defs>
3
+ <linearGradient id="gradient" x1="0%" y1="0%" x2="100%" y2="100%">
4
+ <stop offset="0%" style="stop-color:#409eff;stop-opacity:1" />
5
+ <stop offset="100%" style="stop-color:#67c23a;stop-opacity:1" />
6
+ </linearGradient>
7
+ </defs>
8
+ <rect width="256" height="256" rx="32" fill="url(#gradient)"/>
9
+ <text x="128" y="160" text-anchor="middle" fill="white" font-size="120" font-weight="bold" font-family="Arial">X</text>
10
+ </svg>
package/package.json ADDED
@@ -0,0 +1,71 @@
1
+ {
2
+ "name": "xto-fronted",
3
+ "version": "0.1.0",
4
+ "private": false,
5
+ "type": "module",
6
+ "description": "XTO 前端应用框架",
7
+ "main": "dist/index.umd.js",
8
+ "module": "dist/index.es.js",
9
+ "types": "dist/index.d.ts",
10
+ "exports": {
11
+ ".": {
12
+ "import": "./dist/index.es.js",
13
+ "require": "./dist/index.umd.js",
14
+ "types": "./dist/index.d.ts"
15
+ },
16
+ "./style.css": "./dist/style.css"
17
+ },
18
+ "files": [
19
+ "dist"
20
+ ],
21
+ "peerDependencies": {
22
+ "axios": "^1.6.0",
23
+ "pinia": "^2.1.0",
24
+ "vue": "^3.4.0",
25
+ "vue-router": "^4.3.0"
26
+ },
27
+ "dependencies": {
28
+ "@xto/base": "^0.1.0",
29
+ "@xto/business": "^0.1.0",
30
+ "@xto/core": "^0.1.0",
31
+ "@xto/data": "^0.1.0",
32
+ "@xto/feedback": "^0.1.0",
33
+ "@xto/form": "^0.1.0",
34
+ "@xto/layout": "^0.1.0",
35
+ "@xto/navigation": "^0.1.0"
36
+ },
37
+ "devDependencies": {
38
+ "@types/node": "^20.11.30",
39
+ "@vitejs/plugin-vue": "^5.0.4",
40
+ "axios": "^1.6.8",
41
+ "pinia": "^2.1.7",
42
+ "sass": "^1.72.0",
43
+ "sass-embedded": "^1.72.0",
44
+ "typescript": "^5.4.2",
45
+ "vite": "^5.2.0",
46
+ "vite-plugin-dts": "^4.5.4",
47
+ "vue": "^3.4.21",
48
+ "vue-router": "^4.3.0",
49
+ "vue-tsc": "^2.0.6"
50
+ },
51
+ "keywords": [
52
+ "vue",
53
+ "vue3",
54
+ "admin",
55
+ "template",
56
+ "xto"
57
+ ],
58
+ "author": "",
59
+ "license": "MIT",
60
+ "repository": {
61
+ "type": "git",
62
+ "url": ""
63
+ },
64
+ "scripts": {
65
+ "dev": "vite",
66
+ "build": "vue-tsc && vite build",
67
+ "build:lib": "vue-tsc && vite build --mode lib",
68
+ "preview": "vite preview",
69
+ "lint": "eslint . --ext .vue,.js,.jsx,.cjs,.mjs,.ts,.tsx,.cts,.mts --fix"
70
+ }
71
+ }