create-pubinfo 2.0.0-rc.3 → 2.0.0-rc.5
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.
- package/dist/index.js +201 -157
- package/package.json +5 -1
- package/templates/{pubinfo-template → pubinfo-app}/.env +0 -3
- package/templates/{pubinfo-template → pubinfo-app}/_gitignore +1 -0
- package/templates/{pubinfo-template/openapi.config.ts → pubinfo-app/openapi.config.ts.hbs} +1 -1
- package/templates/{pubinfo-template/package.json → pubinfo-app/package.json.hbs} +12 -7
- package/templates/pubinfo-app/src/settings.ts.hbs +8 -0
- package/templates/pubinfo-module/.editorconfig +10 -0
- package/templates/pubinfo-module/README.md.hbs +27 -0
- package/templates/pubinfo-module/_gitignore +38 -0
- package/templates/pubinfo-module/_npmrc +5 -0
- package/templates/pubinfo-module/eslint.config.ts +3 -0
- package/templates/pubinfo-module/package.json.hbs +67 -0
- package/templates/pubinfo-module/playground/.env +2 -0
- package/templates/pubinfo-module/playground/.env.development +6 -0
- package/templates/pubinfo-module/playground/.env.production +10 -0
- package/templates/pubinfo-module/playground/index.html +47 -0
- package/templates/pubinfo-module/playground/openapi.config.ts.hbs +33 -0
- package/templates/pubinfo-module/playground/package.json.hbs +22 -0
- package/templates/pubinfo-module/playground/pubinfo.config.ts +9 -0
- package/templates/pubinfo-module/playground/public/browser_upgrade/chrome.png +0 -0
- package/templates/pubinfo-module/playground/public/browser_upgrade/edge.png +0 -0
- package/templates/pubinfo-module/playground/public/browser_upgrade/index.css +49 -0
- package/templates/pubinfo-module/playground/public/loading.css +92 -0
- package/templates/pubinfo-module/playground/src/App.vue +7 -0
- package/templates/pubinfo-module/playground/src/api/modules/auth/index.ts +3 -0
- package/templates/pubinfo-module/playground/src/api/modules/auth/renzhengfuwu.ts +145 -0
- package/templates/pubinfo-module/playground/src/api/modules/auth/typings.d.ts +97 -0
- package/templates/pubinfo-module/playground/src/api/request.ts +125 -0
- package/templates/pubinfo-module/playground/src/assets/icons/logo.svg +1 -0
- package/templates/pubinfo-module/playground/src/assets/icons/process-management.svg +1 -0
- package/templates/pubinfo-module/playground/src/assets/icons/workbench.svg +1 -0
- package/templates/pubinfo-module/playground/src/assets/images/login-bg.webp +0 -0
- package/templates/pubinfo-module/playground/src/assets/images/login-bg_dark.webp +0 -0
- package/templates/pubinfo-module/playground/src/assets/images/login-small.png +0 -0
- package/templates/pubinfo-module/playground/src/assets/images/login-small_dark.webp +0 -0
- package/templates/pubinfo-module/playground/src/components/UIProvider/index.vue +51 -0
- package/templates/pubinfo-module/playground/src/layouts/index.vue +44 -0
- package/templates/pubinfo-module/playground/src/main.ts.hbs +24 -0
- package/templates/pubinfo-module/playground/src/modules/auth.ts +20 -0
- package/templates/pubinfo-module/playground/src/modules/rbac.ts +10 -0
- package/templates/pubinfo-module/playground/src/routes/index.ts +71 -0
- package/templates/pubinfo-module/playground/src/routes/modules/demo/breadcrumb.example.ts +62 -0
- package/templates/pubinfo-module/playground/src/routes/modules/demo/link.ts +15 -0
- package/templates/pubinfo-module/playground/src/routes/modules/demo/multilevel.menu.example.ts +68 -0
- package/templates/pubinfo-module/playground/src/routes/modules/demo/other.page.ts +37 -0
- package/templates/pubinfo-module/playground/src/routes/modules/demo/single.ts +14 -0
- package/templates/{pubinfo-template → pubinfo-module/playground}/src/settings.ts +1 -1
- package/templates/pubinfo-module/playground/src/stores/index.ts +2 -0
- package/templates/pubinfo-module/playground/src/stores/modules/conter.ts +16 -0
- package/templates/pubinfo-module/playground/src/views/demo/breadcrumb_example/detail1.vue +11 -0
- package/templates/pubinfo-module/playground/src/views/demo/breadcrumb_example/detail2.vue +11 -0
- package/templates/pubinfo-module/playground/src/views/demo/breadcrumb_example/list1.vue +11 -0
- package/templates/pubinfo-module/playground/src/views/demo/breadcrumb_example/list2.vue +11 -0
- package/templates/pubinfo-module/playground/src/views/demo/multilevel_menu_example/level2/level3/page1.vue +11 -0
- package/templates/pubinfo-module/playground/src/views/demo/multilevel_menu_example/level2/level3/page2.vue +11 -0
- package/templates/pubinfo-module/playground/src/views/demo/multilevel_menu_example/level2/page.vue +11 -0
- package/templates/pubinfo-module/playground/src/views/demo/multilevel_menu_example/page.vue +11 -0
- package/templates/pubinfo-module/playground/src/views/demo/other_page/des.vue +13 -0
- package/templates/pubinfo-module/playground/src/views/demo/other_page/index.vue +25 -0
- package/templates/pubinfo-module/playground/src/views/demo/preview-empty/index.vue +17 -0
- package/templates/pubinfo-module/playground/src/views/demo/single/index.vue +13 -0
- package/templates/pubinfo-module/playground/src/views/system/index.vue +5 -0
- package/templates/pubinfo-module/playground/src/views/system/login/components/LoginForm.vue +29 -0
- package/templates/pubinfo-module/playground/src/views/system/login/components/LoginWithPhone.vue +213 -0
- package/templates/pubinfo-module/playground/src/views/system/login/components/PasswordLogin.vue +194 -0
- package/templates/pubinfo-module/playground/src/views/system/login/components/Savephone.vue +17 -0
- package/templates/pubinfo-module/playground/src/views/system/login/components/Useragreement.vue +26 -0
- package/templates/pubinfo-module/playground/src/views/system/login/composables.ts +84 -0
- package/templates/pubinfo-module/playground/src/views/system/login/index.vue +142 -0
- package/templates/pubinfo-module/playground/tsconfig.json +3 -0
- package/templates/pubinfo-module/playground/uno.config.ts +17 -0
- package/templates/pubinfo-module/pnpm-workspace.yaml +2 -0
- package/templates/pubinfo-module/pubinfo.config.ts.hbs +36 -0
- package/templates/pubinfo-module/src/index.ts.hbs +9 -0
- package/templates/pubinfo-module/src/pages/demo.vue +11 -0
- package/templates/pubinfo-module/stylelint.config.js +3 -0
- package/templates/pubinfo-module/tsconfig.json +16 -0
- package/templates/pubinfo-module/uno.config.ts +8 -0
- package/templates/{pubinfo-template → pubinfo-app}/.browserslistrc +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/.editorconfig +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/.env.development +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/.env.production +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/_npmrc +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/eslint.config.ts +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/index.html +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/pubinfo.config.ts +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/public/browser_upgrade/chrome.png +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/public/browser_upgrade/edge.png +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/public/browser_upgrade/index.css +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/public/loading.css +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/src/App.vue +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/src/api/modules/auth/index.ts +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/src/api/modules/auth/renzhengfuwu.ts +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/src/api/modules/auth/typings.d.ts +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/src/api/request.ts +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/src/assets/icons/logo.svg +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/src/assets/icons/process-management.svg +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/src/assets/icons/workbench.svg +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/src/assets/images/login-bg.webp +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/src/assets/images/login-bg_dark.webp +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/src/assets/images/login-small.png +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/src/assets/images/login-small_dark.webp +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/src/components/UIProvider/index.vue +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/src/layouts/index.vue +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/src/main.ts +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/src/modules/auth.ts +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/src/modules/rbac.ts +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/src/routes/index.ts +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/src/routes/modules/demo/breadcrumb.example.ts +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/src/routes/modules/demo/link.ts +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/src/routes/modules/demo/multilevel.menu.example.ts +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/src/routes/modules/demo/other.page.ts +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/src/routes/modules/demo/single.ts +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/src/stores/index.ts +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/src/stores/modules/conter.ts +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/src/views/demo/breadcrumb_example/detail1.vue +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/src/views/demo/breadcrumb_example/detail2.vue +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/src/views/demo/breadcrumb_example/list1.vue +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/src/views/demo/breadcrumb_example/list2.vue +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/src/views/demo/multilevel_menu_example/level2/level3/page1.vue +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/src/views/demo/multilevel_menu_example/level2/level3/page2.vue +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/src/views/demo/multilevel_menu_example/level2/page.vue +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/src/views/demo/multilevel_menu_example/page.vue +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/src/views/demo/other_page/des.vue +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/src/views/demo/other_page/index.vue +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/src/views/demo/preview-empty/index.vue +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/src/views/demo/single/index.vue +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/src/views/system/index.vue +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/src/views/system/login/components/LoginForm.vue +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/src/views/system/login/components/LoginWithPhone.vue +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/src/views/system/login/components/PasswordLogin.vue +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/src/views/system/login/components/Savephone.vue +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/src/views/system/login/components/Useragreement.vue +0 -0
- package/templates/{pubinfo-template → pubinfo-app}/src/views/system/login/composables.ts +1 -1
- /package/templates/{pubinfo-template → pubinfo-app}/src/views/system/login/index.vue +0 -0
- /package/templates/{pubinfo-template → pubinfo-app}/stylelint.config.js +0 -0
- /package/templates/{pubinfo-template → pubinfo-app}/tsconfig.json +0 -0
- /package/templates/{pubinfo-template → pubinfo-app}/uno.config.ts +0 -0
|
@@ -0,0 +1,125 @@
|
|
|
1
|
+
import { message } from 'ant-design-vue';
|
|
2
|
+
import { createRequest, RESPONSE_CODE } from 'pubinfo';
|
|
3
|
+
import { useUserStore } from '@/stores';
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* @description
|
|
7
|
+
* 创建 API 请求的基础 URL。
|
|
8
|
+
* 如果环境是开发环境,并且 VITE_OPEN_PROXY 标志设置为 'true',
|
|
9
|
+
* 则返回 '/proxy/'。否则,返回 VITE_APP_API_BASEURL 的值。
|
|
10
|
+
* @returns API 请求的基础 URL。
|
|
11
|
+
*/
|
|
12
|
+
function createBaseURL(baseUrl: string) {
|
|
13
|
+
let requestBaseUrl;
|
|
14
|
+
if (import.meta.env.DEV && import.meta.env.VITE_OPEN_PROXY === 'true') {
|
|
15
|
+
const url = new URL(baseUrl);
|
|
16
|
+
const pathname = url.pathname;
|
|
17
|
+
requestBaseUrl = `${pathname}/proxy/`;
|
|
18
|
+
}
|
|
19
|
+
else {
|
|
20
|
+
requestBaseUrl = baseUrl;
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
return requestBaseUrl;
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
function createErrorMsg(msg: string) {
|
|
27
|
+
message.error(msg);
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
const timeout = 60 * 1000;
|
|
31
|
+
|
|
32
|
+
function createInstance(url: string) {
|
|
33
|
+
return createRequest({
|
|
34
|
+
baseURL: createBaseURL(url),
|
|
35
|
+
timeout: 60 * 1000,
|
|
36
|
+
responded: {
|
|
37
|
+
/**
|
|
38
|
+
* @description
|
|
39
|
+
* 网络成功的响应
|
|
40
|
+
*/
|
|
41
|
+
async onSuccess(response) {
|
|
42
|
+
const isBlob = response.config?.responseType === 'blob';
|
|
43
|
+
if (isBlob) {
|
|
44
|
+
return Promise.resolve(response);
|
|
45
|
+
}
|
|
46
|
+
|
|
47
|
+
const data = response.data;
|
|
48
|
+
// 基于code判断逻辑
|
|
49
|
+
const { code } = data;
|
|
50
|
+
// code 都是number类型
|
|
51
|
+
switch (code) {
|
|
52
|
+
/**
|
|
53
|
+
* @description
|
|
54
|
+
* 成功的code
|
|
55
|
+
*/
|
|
56
|
+
case RESPONSE_CODE.SUCCESS:
|
|
57
|
+
return Promise.resolve(data);
|
|
58
|
+
|
|
59
|
+
/**
|
|
60
|
+
* @description
|
|
61
|
+
* 用于判断refreshToken是否过期
|
|
62
|
+
* 如果refreshToken也过期了,需要重新登录
|
|
63
|
+
* 不需要msg提示信息
|
|
64
|
+
*/
|
|
65
|
+
case RESPONSE_CODE.LOGIN_TOKEN_INVALID:
|
|
66
|
+
useUserStore().logout();
|
|
67
|
+
return Promise.reject(data);
|
|
68
|
+
|
|
69
|
+
/**
|
|
70
|
+
* @description
|
|
71
|
+
* 账户未启用,请联系管理员
|
|
72
|
+
* 账户锁定,请联系管理员
|
|
73
|
+
*/
|
|
74
|
+
case RESPONSE_CODE.ACCOUT_NOT_ENABLE:
|
|
75
|
+
case RESPONSE_CODE.ACCOUNT_LOCKED:
|
|
76
|
+
createErrorMsg(response.data.msg);
|
|
77
|
+
useUserStore().logout();
|
|
78
|
+
return Promise.reject(data);
|
|
79
|
+
|
|
80
|
+
/**
|
|
81
|
+
* @description
|
|
82
|
+
* 密码过期或者首次登录,需要修改密码
|
|
83
|
+
* 需要跳转到修改密码页面
|
|
84
|
+
* 目前貌似不需要单独判读code在此处处理
|
|
85
|
+
*/
|
|
86
|
+
case RESPONSE_CODE.CHANGE_INIT_PASSWORD:
|
|
87
|
+
case RESPONSE_CODE.PASSWORD_EXPIRED:
|
|
88
|
+
return Promise.reject(data);
|
|
89
|
+
|
|
90
|
+
/**
|
|
91
|
+
* @description
|
|
92
|
+
* RESPONSE_CODE 中其他的错误信息
|
|
93
|
+
*/
|
|
94
|
+
default:
|
|
95
|
+
createErrorMsg(response.data.msg);
|
|
96
|
+
return Promise.reject(data);
|
|
97
|
+
}
|
|
98
|
+
},
|
|
99
|
+
/**
|
|
100
|
+
* @description
|
|
101
|
+
* 网络失败的响应
|
|
102
|
+
*/
|
|
103
|
+
onError(error) {
|
|
104
|
+
const message = error.message;
|
|
105
|
+
let msg = '';
|
|
106
|
+
switch (message) {
|
|
107
|
+
case 'Network Error':
|
|
108
|
+
msg = '网络故障';
|
|
109
|
+
break;
|
|
110
|
+
case `timeout of ${timeout}ms exceeded`:
|
|
111
|
+
msg = '接口请求超时';
|
|
112
|
+
break;
|
|
113
|
+
default:
|
|
114
|
+
msg = `接口${message.substr(message.length - 3)}异常`;
|
|
115
|
+
break;
|
|
116
|
+
}
|
|
117
|
+
createErrorMsg(msg);
|
|
118
|
+
return Promise.reject(error);
|
|
119
|
+
},
|
|
120
|
+
},
|
|
121
|
+
});
|
|
122
|
+
}
|
|
123
|
+
|
|
124
|
+
export const basic = createInstance(import.meta.env.VITE_APP_API_BASEURL);
|
|
125
|
+
export const auth = createInstance(import.meta.env.VITE_APP_API_BASEURL);
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" fill="none" viewBox="0 0 144 125" preserveAspectRatio="xMidYMid meet"><path fill="url(#a)" stroke="url(#b)" d="M142.858 58.054c0 1.922-.524 3.845-1.572 5.418l-14.68 23.068-16.078 25.165c-1.398 2.097-3.67 3.496-6.292 3.496h-65.71L55.13 86.54h34.952l14.855-25.515c.699-1.398-.175-2.97-1.748-2.97H71.731l16.602-28.661h34.428c2.272 0 4.369 1.223 5.592 3.145l12.758 20.098c1.223 1.572 1.747 3.495 1.747 5.417Z"/><path fill="url(#c)" stroke="url(#d)" d="M38.702 54.909c-.7 1.398.174 2.97 1.747 2.97h31.457L55.304 86.54H20.876c-2.272 0-4.369-1.223-5.592-3.146L2.352 63.473C1.303 61.724.779 59.977.779 58.054s.524-3.844 1.573-5.417l14.68-23.068 16.077-25.34C34.507 2.13 36.954.732 39.401.732h65.535l-16.603 28.66H53.382z"/><path fill="url(#e)" d="M142.858 57.88v9.087c0 1.922-.524 3.844-1.572 5.417l-30.758 48.409c-1.398 2.097-3.845 3.495-6.292 3.495h-65.71V115.2h65.536c2.621 0 4.893-1.398 6.291-3.495l16.253-25.34 14.68-23.068c1.048-1.748 1.572-3.67 1.572-5.418" opacity=".8"/><path fill="url(#f)" d="m104.935 61.025-3.495 6.117H71.731l-11.36 19.573H55.13l16.602-28.66h31.457c1.573 0 2.621 1.572 1.747 2.97" opacity=".8"/><path fill="url(#g)" d="m101.44 67.142 3.495-6.117c.874-1.398-.174-2.97-1.747-2.97H71.731v9.087z" opacity=".8"/><path fill="url(#h)" d="M104.936.733v9.088l-11.36 19.573h-5.242z" opacity=".8"/><path fill="url(#i)" d="m88.508 29.394-5.243 9.087h-29.71L42.197 58.054H40.45c-1.573 0-2.622-1.748-1.748-2.97l14.855-25.516h34.951z" opacity=".8"/><path fill="url(#j)" d="m55.13 86.54-5.244 9.087h-29.01c-2.272 0-4.369-1.223-5.592-3.145L2.352 72.559C1.303 70.986.779 69.064.779 67.142v-9.088c0 1.923.524 3.845 1.573 5.418l12.757 20.097c1.223 1.922 3.32 3.146 5.592 3.146H55.13z" opacity=".8"/><defs><linearGradient id="a" x1="90.693" x2="90.693" y1="29.394" y2="115.201" gradientUnits="userSpaceOnUse"><stop stop-color="#AEFFD3"/><stop offset="1" stop-color="#13C966"/></linearGradient><linearGradient id="b" x1="132.493" x2="90.803" y1="35.066" y2="115.258" gradientUnits="userSpaceOnUse"><stop stop-color="#fff" stop-opacity="0"/><stop offset="1" stop-color="#fff" stop-opacity=".82"/></linearGradient><linearGradient id="c" x1="52.857" x2="52.857" y1=".733" y2="86.54" gradientUnits="userSpaceOnUse"><stop stop-color="#A3C6FF"/><stop offset="1" stop-color="#2275FF"/></linearGradient><linearGradient id="d" x1="94.587" x2="52.857" y1="6.405" y2="86.54" gradientUnits="userSpaceOnUse"><stop stop-color="#fff" stop-opacity="0"/><stop offset="1" stop-color="#fff" stop-opacity=".55"/></linearGradient><linearGradient id="e" x1="90.693" x2="90.693" y1="57.879" y2="124.288" gradientUnits="userSpaceOnUse"><stop stop-color="#AEFFD3"/><stop offset="1" stop-color="#0FE270"/></linearGradient><linearGradient id="f" x1="80.191" x2="80.191" y1="58.054" y2="86.715" gradientUnits="userSpaceOnUse"><stop stop-color="#A3C6FF"/><stop offset="1" stop-color="#2275FF"/></linearGradient><linearGradient id="g" x1="72.889" x2="100.968" y1="67.142" y2="67.142" gradientUnits="userSpaceOnUse"><stop stop-color="#AEFFD3"/><stop offset="1" stop-color="#0FE270"/></linearGradient><linearGradient id="h" x1="105.825" x2="89.13" y1=".733" y2="27.995" gradientUnits="userSpaceOnUse"><stop stop-color="#A3C6FF"/><stop offset="1" stop-color="#2275FF"/></linearGradient><linearGradient id="i" x1="63.446" x2="63.446" y1="29.394" y2="58.054" gradientUnits="userSpaceOnUse"><stop stop-color="#A3C6FF"/><stop offset="1" stop-color="#2275FF"/></linearGradient><linearGradient id="j" x1="27.954" x2="27.954" y1="58.054" y2="95.627" gradientUnits="userSpaceOnUse"><stop stop-color="#A3C6FF"/><stop offset="1" stop-color="#2275FF"/></linearGradient></defs></svg>
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="24" height="24" viewBox="0 0 24 24" preserveAspectRatio="xMidYMid meet"><defs><linearGradient id="a" x1="0%" x2="85.607%" y1="0%" y2="88.541%"><stop offset="0%" stop-color="#05E0CF"/><stop offset="100%" stop-color="#02BDA1"/></linearGradient><linearGradient id="d" x1="56.555%" x2="56.555%" y1="95.676%" y2="0%"><stop offset="0%" stop-color="#FFF"/><stop offset="100%" stop-color="#FFF" stop-opacity=".8"/></linearGradient><linearGradient id="e" x1="56.555%" x2="56.555%" y1="95.676%" y2="0%"><stop offset="0%" stop-color="#FFF"/><stop offset="100%" stop-color="#FFF" stop-opacity=".8"/></linearGradient><path id="b" d="M0 0h16v16H0z"/></defs><g fill="none" fill-rule="evenodd"><rect width="24" height="24" fill="url(#a)" rx="8"/><g transform="translate(5 4)"><mask id="c" fill="#fff"><use xlink:href="#b"/></mask><g mask="url(#c)"><path fill="url(#d)" d="M8 0a1 1 0 0 1 1 1v3a1 1 0 0 1-1 1H1a1 1 0 0 1-1-1V1a1 1 0 0 1 1-1zm0 8a1 1 0 0 1 1 1v3a1 1 0 0 1-1 1H1a1 1 0 0 1-1-1V9a1 1 0 0 1 1-1z" transform="translate(1 1.5)"/><path fill="url(#e)" d="M10.12 1.872a5.59 5.59 0 0 1 2.413 4.027l.915.001a.6.6 0 1 1 0 1.2h-.916a5.59 5.59 0 0 1-2.426 4.03.6.6 0 0 1-.674-.994 4.39 4.39 0 0 0 1.932-3.64 4.39 4.39 0 0 0-1.92-3.633.6.6 0 1 1 .676-.991" transform="translate(1 1.5)"/></g></g></g></svg>
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="24" height="24" viewBox="0 0 24 24" preserveAspectRatio="xMidYMid meet"><defs><linearGradient id="b" x1="24.065%" x2="100%" y1="0%" y2="100%"><stop offset="0%" stop-color="#FFC758"/><stop offset="100%" stop-color="#FFB92B"/></linearGradient><rect id="a" width="24" height="24" x="0" y="0" rx="8"/></defs><g fill="none" fill-rule="evenodd"><use xlink:href="#a" fill="url(#b)"/><path fill="#FFF" d="M17 6a2 2 0 0 1 2 2v6a2 2 0 0 1-2 2h-4.4v1.801H14a.6.6 0 0 1 .097 1.193L14 19h-4a.6.6 0 0 1-.097-1.192L10 17.8h1.4V16H7a2 2 0 0 1-2-2V8a2 2 0 0 1 2-2zm-5.5 5.65h-2l-.097.008A.6.6 0 0 0 9.5 12.85h2l.097-.008a.6.6 0 0 0-.097-1.192m3-2.5h-5l-.097.008A.6.6 0 0 0 9.5 10.35h5l.097-.008A.6.6 0 0 0 14.5 9.15"/></g></svg>
|
|
Binary file
|
|
@@ -0,0 +1,51 @@
|
|
|
1
|
+
<script setup lang="ts">
|
|
2
|
+
import { legacyLogicalPropertiesTransformer, theme } from 'ant-design-vue';
|
|
3
|
+
import zhCN from 'ant-design-vue/es/locale/zh_CN';
|
|
4
|
+
import dayjs from 'dayjs';
|
|
5
|
+
import { useTheme } from 'pubinfo';
|
|
6
|
+
import 'dayjs/locale/zh-cn';
|
|
7
|
+
|
|
8
|
+
defineOptions({
|
|
9
|
+
name: 'UIProvider',
|
|
10
|
+
});
|
|
11
|
+
|
|
12
|
+
dayjs.locale('zh-cn');
|
|
13
|
+
|
|
14
|
+
function getContainer() {
|
|
15
|
+
return document.body;
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
const { isDark } = useTheme();
|
|
19
|
+
|
|
20
|
+
const UILocales = computed(() => {
|
|
21
|
+
return zhCN;
|
|
22
|
+
});
|
|
23
|
+
|
|
24
|
+
const themeMode = computed(() => {
|
|
25
|
+
return isDark.value
|
|
26
|
+
? { algorithm: [theme.darkAlgorithm] }
|
|
27
|
+
: {};
|
|
28
|
+
});
|
|
29
|
+
|
|
30
|
+
const themeConfig = computed(() => {
|
|
31
|
+
return Object.assign(
|
|
32
|
+
{ token: { wireframe: true } },
|
|
33
|
+
themeMode.value,
|
|
34
|
+
);
|
|
35
|
+
});
|
|
36
|
+
</script>
|
|
37
|
+
|
|
38
|
+
<template>
|
|
39
|
+
<a-config-provider
|
|
40
|
+
:locale="UILocales"
|
|
41
|
+
:theme="themeConfig"
|
|
42
|
+
:get-popup-container="getContainer"
|
|
43
|
+
>
|
|
44
|
+
<a-style-provider hash-priority="high" :transformers="[legacyLogicalPropertiesTransformer]">
|
|
45
|
+
<a-app class="w-full h-full">
|
|
46
|
+
<slot />
|
|
47
|
+
<a-modal />
|
|
48
|
+
</a-app>
|
|
49
|
+
</a-style-provider>
|
|
50
|
+
</a-config-provider>
|
|
51
|
+
</template>
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
<script lang="ts" setup>
|
|
2
|
+
import {
|
|
3
|
+
Copyright,
|
|
4
|
+
Layout,
|
|
5
|
+
Logo,
|
|
6
|
+
Tool,
|
|
7
|
+
Tools,
|
|
8
|
+
} from 'pubinfo';
|
|
9
|
+
|
|
10
|
+
const title = import.meta.env.VITE_APP_TITLE;
|
|
11
|
+
const dev = import.meta.env.DEV;
|
|
12
|
+
</script>
|
|
13
|
+
|
|
14
|
+
<template>
|
|
15
|
+
<Layout.Provider :app-title="title" :is-dev="dev">
|
|
16
|
+
<Layout>
|
|
17
|
+
<template #header>
|
|
18
|
+
<Layout.Header>
|
|
19
|
+
<template #logo>
|
|
20
|
+
<Logo name="logo" />
|
|
21
|
+
</template>
|
|
22
|
+
|
|
23
|
+
<template #tools>
|
|
24
|
+
<Tools>
|
|
25
|
+
<Tool.Fullscreen />
|
|
26
|
+
<Tool.PageReload />
|
|
27
|
+
<Tool.DarkModeToggle />
|
|
28
|
+
</Tools>
|
|
29
|
+
</template>
|
|
30
|
+
</Layout.Header>
|
|
31
|
+
</template>
|
|
32
|
+
|
|
33
|
+
<template #sidebar>
|
|
34
|
+
<Layout.Sidebar />
|
|
35
|
+
</template>
|
|
36
|
+
|
|
37
|
+
<Layout.Content />
|
|
38
|
+
|
|
39
|
+
<template #footer>
|
|
40
|
+
<Copyright />
|
|
41
|
+
</template>
|
|
42
|
+
</Layout>
|
|
43
|
+
</Layout.Provider>
|
|
44
|
+
</template>
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { createPubinfo } from 'pubinfo';
|
|
2
|
+
import { {{camelCase dir}} } from 'pubinfo-module-{{kebabCase dir}}';
|
|
3
|
+
import { auth, basic } from './api/request';
|
|
4
|
+
import App from './App.vue';
|
|
5
|
+
import { setupAuth } from './modules/auth';
|
|
6
|
+
import { setupRbac } from './modules/rbac';
|
|
7
|
+
import { constantRoutes } from './routes';
|
|
8
|
+
import './settings';
|
|
9
|
+
import 'uno.css';
|
|
10
|
+
|
|
11
|
+
createPubinfo({
|
|
12
|
+
app: App,
|
|
13
|
+
router: { routes: constantRoutes },
|
|
14
|
+
setup(ctx) {},
|
|
15
|
+
request: {
|
|
16
|
+
auth,
|
|
17
|
+
basic,
|
|
18
|
+
},
|
|
19
|
+
modules: [
|
|
20
|
+
setupAuth(),
|
|
21
|
+
setupRbac(),
|
|
22
|
+
{{camelCase dir}}(),
|
|
23
|
+
],
|
|
24
|
+
});
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { auth } from '@pubinfo/module-auth';
|
|
2
|
+
import FourA from '@pubinfo/module-auth/providers/4A';
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* 登录相关配置
|
|
6
|
+
*/
|
|
7
|
+
export function setupAuth() {
|
|
8
|
+
return auth({
|
|
9
|
+
baseURL: import.meta.env.VITE_APP_API_BASEURL,
|
|
10
|
+
providers: [
|
|
11
|
+
FourA({
|
|
12
|
+
// 4A client_id
|
|
13
|
+
clientId: '',
|
|
14
|
+
|
|
15
|
+
// 4A redirect_uri 需要配置为 `xxx/#/auth/4A` 的格式
|
|
16
|
+
redirectUri: '',
|
|
17
|
+
}),
|
|
18
|
+
],
|
|
19
|
+
});
|
|
20
|
+
}
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
import { defineAsyncRoutes, defineSystemRoutes } from 'pubinfo';
|
|
2
|
+
import Login from '@/views/system/login/index.vue';
|
|
3
|
+
|
|
4
|
+
import Breadcrumb from './modules/demo/breadcrumb.example';
|
|
5
|
+
import Link from './modules/demo/link';
|
|
6
|
+
import MultilevelMenuExample from './modules/demo/multilevel.menu.example';
|
|
7
|
+
import OtherPage from './modules/demo/other.page';
|
|
8
|
+
import Single from './modules/demo/single';
|
|
9
|
+
|
|
10
|
+
/**
|
|
11
|
+
* ========================================================================
|
|
12
|
+
* 本地路由(资源管理的类型配置成"应用")
|
|
13
|
+
*========================================================================*
|
|
14
|
+
*/
|
|
15
|
+
defineAsyncRoutes([
|
|
16
|
+
{
|
|
17
|
+
meta: {
|
|
18
|
+
title: '演示管理系统',
|
|
19
|
+
icon: 'workbench',
|
|
20
|
+
},
|
|
21
|
+
children: [
|
|
22
|
+
Single,
|
|
23
|
+
MultilevelMenuExample,
|
|
24
|
+
OtherPage,
|
|
25
|
+
Link,
|
|
26
|
+
Breadcrumb,
|
|
27
|
+
],
|
|
28
|
+
},
|
|
29
|
+
{
|
|
30
|
+
meta: {
|
|
31
|
+
title: '演示系统1',
|
|
32
|
+
icon: 'process-management',
|
|
33
|
+
isDev: true,
|
|
34
|
+
},
|
|
35
|
+
},
|
|
36
|
+
]);
|
|
37
|
+
|
|
38
|
+
/**
|
|
39
|
+
* ========================================================================
|
|
40
|
+
* 系统路由(包含布局)
|
|
41
|
+
*========================================================================*
|
|
42
|
+
*/
|
|
43
|
+
defineSystemRoutes([
|
|
44
|
+
{
|
|
45
|
+
path: '/',
|
|
46
|
+
name: 'Home',
|
|
47
|
+
component: () => import('@/views/system/index.vue'),
|
|
48
|
+
meta: {
|
|
49
|
+
title: '首页',
|
|
50
|
+
icon: 'i-ant-design:home-twotone',
|
|
51
|
+
breadcrumb: false,
|
|
52
|
+
},
|
|
53
|
+
},
|
|
54
|
+
]);
|
|
55
|
+
|
|
56
|
+
/**
|
|
57
|
+
* ========================================================================
|
|
58
|
+
* 固定路由(默认路由)
|
|
59
|
+
*========================================================================*
|
|
60
|
+
*/
|
|
61
|
+
export const constantRoutes = [
|
|
62
|
+
{
|
|
63
|
+
path: '/login',
|
|
64
|
+
name: 'Login',
|
|
65
|
+
component: Login,
|
|
66
|
+
meta: {
|
|
67
|
+
whiteList: true,
|
|
68
|
+
title: '登录',
|
|
69
|
+
},
|
|
70
|
+
},
|
|
71
|
+
];
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
import type { RouteRecordRaw } from 'vue-router';
|
|
2
|
+
|
|
3
|
+
const routes: RouteRecordRaw = {
|
|
4
|
+
path: '/breadcrumb_example',
|
|
5
|
+
redirect: '/breadcrumb_example/list1',
|
|
6
|
+
name: 'breadcrumbExample',
|
|
7
|
+
meta: {
|
|
8
|
+
title: '面包屑导航',
|
|
9
|
+
icon: 'i-solar-confetti-minimalistic-bold',
|
|
10
|
+
},
|
|
11
|
+
children: [
|
|
12
|
+
{
|
|
13
|
+
path: 'list1',
|
|
14
|
+
name: 'breadcrumbExampleList1',
|
|
15
|
+
component: () => import('@/views/demo/breadcrumb_example/list1.vue'),
|
|
16
|
+
meta: {
|
|
17
|
+
title: '列表1(平级模式)',
|
|
18
|
+
},
|
|
19
|
+
},
|
|
20
|
+
{
|
|
21
|
+
path: 'detail1',
|
|
22
|
+
name: 'breadcrumbExampleDetail1',
|
|
23
|
+
component: () => import('@/views/demo/breadcrumb_example/detail1.vue'),
|
|
24
|
+
meta: {
|
|
25
|
+
title: '详情1',
|
|
26
|
+
sidebar: false,
|
|
27
|
+
activeMenu: '/breadcrumb_example/list1',
|
|
28
|
+
},
|
|
29
|
+
},
|
|
30
|
+
{
|
|
31
|
+
path: 'list2',
|
|
32
|
+
name: 'breadcrumbExampleList2',
|
|
33
|
+
redirect: '/breadcrumb_example/demo/list2',
|
|
34
|
+
meta: {
|
|
35
|
+
title: '列表2(层级模式)',
|
|
36
|
+
},
|
|
37
|
+
children: [
|
|
38
|
+
{
|
|
39
|
+
path: '',
|
|
40
|
+
component: () => import('@/views/demo/breadcrumb_example/list2.vue'),
|
|
41
|
+
meta: {
|
|
42
|
+
title: '列表2(层级模式)',
|
|
43
|
+
sidebar: false,
|
|
44
|
+
breadcrumb: false,
|
|
45
|
+
},
|
|
46
|
+
},
|
|
47
|
+
{
|
|
48
|
+
path: 'detail2',
|
|
49
|
+
name: 'breadcrumbExampleDetail2',
|
|
50
|
+
component: () => import('@/views/demo/breadcrumb_example/detail2.vue'),
|
|
51
|
+
meta: {
|
|
52
|
+
title: '详情2',
|
|
53
|
+
sidebar: false,
|
|
54
|
+
activeMenu: '/breadcrumb_example/list2',
|
|
55
|
+
},
|
|
56
|
+
},
|
|
57
|
+
],
|
|
58
|
+
},
|
|
59
|
+
],
|
|
60
|
+
};
|
|
61
|
+
|
|
62
|
+
export default routes;
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import type { RouteRecordRaw } from 'vue-router';
|
|
2
|
+
|
|
3
|
+
const routes: RouteRecordRaw = {
|
|
4
|
+
path: '/link',
|
|
5
|
+
name: 'Link',
|
|
6
|
+
redirect: '',
|
|
7
|
+
meta: {
|
|
8
|
+
title: '跳转路由',
|
|
9
|
+
singleMenu: true,
|
|
10
|
+
icon: 'i-solar-confetti-minimalistic-bold',
|
|
11
|
+
link: 'http://124.223.184.245:10000/docs/',
|
|
12
|
+
},
|
|
13
|
+
};
|
|
14
|
+
|
|
15
|
+
export default routes;
|
package/templates/pubinfo-module/playground/src/routes/modules/demo/multilevel.menu.example.ts
ADDED
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
import type { RouteRecordRaw } from 'vue-router';
|
|
2
|
+
|
|
3
|
+
const routes: RouteRecordRaw = {
|
|
4
|
+
path: '/multilevel_menu_example',
|
|
5
|
+
redirect: '/multilevel_menu_example/page',
|
|
6
|
+
name: 'multilevelMenuExample',
|
|
7
|
+
meta: {
|
|
8
|
+
title: '多级导航',
|
|
9
|
+
icon: 'i-heroicons-solid:menu-alt-3',
|
|
10
|
+
},
|
|
11
|
+
children: [
|
|
12
|
+
{
|
|
13
|
+
path: 'page',
|
|
14
|
+
name: 'multilevelMenuExample1',
|
|
15
|
+
component: () => import('@/views/demo/multilevel_menu_example/page.vue'),
|
|
16
|
+
meta: {
|
|
17
|
+
title: '导航1',
|
|
18
|
+
icon: 'i-heroicons-solid:menu-alt-3',
|
|
19
|
+
},
|
|
20
|
+
},
|
|
21
|
+
{
|
|
22
|
+
path: 'level2',
|
|
23
|
+
name: 'multilevelMenuExample2',
|
|
24
|
+
redirect: '/multilevel_menu_example/level2/page',
|
|
25
|
+
meta: {
|
|
26
|
+
title: '导航2',
|
|
27
|
+
},
|
|
28
|
+
children: [
|
|
29
|
+
{
|
|
30
|
+
path: 'page',
|
|
31
|
+
name: 'multilevelMenuExample2-1',
|
|
32
|
+
component: () => import('@/views/demo/multilevel_menu_example/level2/page.vue'),
|
|
33
|
+
meta: {
|
|
34
|
+
title: '导航2-1',
|
|
35
|
+
},
|
|
36
|
+
},
|
|
37
|
+
{
|
|
38
|
+
path: 'level3',
|
|
39
|
+
name: 'multilevelMenuExample2-2',
|
|
40
|
+
redirect: '/multilevel_menu_example/level2/level3/page1',
|
|
41
|
+
meta: {
|
|
42
|
+
title: '导航2-2',
|
|
43
|
+
},
|
|
44
|
+
children: [
|
|
45
|
+
{
|
|
46
|
+
path: 'page1',
|
|
47
|
+
name: 'multilevelMenuExample2-2-1',
|
|
48
|
+
component: () => import('@/views/demo/multilevel_menu_example/level2/level3/page1.vue'),
|
|
49
|
+
meta: {
|
|
50
|
+
title: '导航2-2-1',
|
|
51
|
+
},
|
|
52
|
+
},
|
|
53
|
+
{
|
|
54
|
+
path: 'page2',
|
|
55
|
+
name: 'multilevelMenuExample2-2-2',
|
|
56
|
+
component: () => import('@/views/demo/multilevel_menu_example/level2/level3/page2.vue'),
|
|
57
|
+
meta: {
|
|
58
|
+
title: '导航2-2-2',
|
|
59
|
+
},
|
|
60
|
+
},
|
|
61
|
+
],
|
|
62
|
+
},
|
|
63
|
+
],
|
|
64
|
+
},
|
|
65
|
+
],
|
|
66
|
+
};
|
|
67
|
+
|
|
68
|
+
export default routes;
|
|
@@ -0,0 +1,37 @@
|
|
|
1
|
+
import type { RouteRecordRaw } from 'vue-router';
|
|
2
|
+
|
|
3
|
+
const routes: RouteRecordRaw = {
|
|
4
|
+
path: '/other-page',
|
|
5
|
+
redirect: '/other-page/list',
|
|
6
|
+
name: 'OtherPage',
|
|
7
|
+
meta: {
|
|
8
|
+
title: '下探页面',
|
|
9
|
+
icon: 'i-solar-confetti-minimalistic-bold',
|
|
10
|
+
},
|
|
11
|
+
children: [
|
|
12
|
+
{
|
|
13
|
+
path: 'list',
|
|
14
|
+
name: 'OtherPageList',
|
|
15
|
+
component: () => import('@/views/demo/other_page/index.vue'),
|
|
16
|
+
meta: {
|
|
17
|
+
title: '列表页',
|
|
18
|
+
sidebar: false,
|
|
19
|
+
breadcrumb: false,
|
|
20
|
+
activeMenu: '/other-page',
|
|
21
|
+
},
|
|
22
|
+
},
|
|
23
|
+
{
|
|
24
|
+
path: 'detail',
|
|
25
|
+
name: 'OtherPageDetail',
|
|
26
|
+
component: () => import('@/views/demo/other_page/des.vue'),
|
|
27
|
+
meta: {
|
|
28
|
+
title: '详情页',
|
|
29
|
+
sidebar: false,
|
|
30
|
+
breadcrumb: true,
|
|
31
|
+
activeMenu: '/other-page',
|
|
32
|
+
},
|
|
33
|
+
},
|
|
34
|
+
],
|
|
35
|
+
};
|
|
36
|
+
|
|
37
|
+
export default routes;
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import type { RouteRecordRaw } from 'vue-router';
|
|
2
|
+
|
|
3
|
+
const routes: RouteRecordRaw = {
|
|
4
|
+
path: '/single',
|
|
5
|
+
component: () => import('@/views/demo/single/index.vue'),
|
|
6
|
+
name: 'Single',
|
|
7
|
+
meta: {
|
|
8
|
+
title: '单页面路由',
|
|
9
|
+
singleMenu: true,
|
|
10
|
+
icon: 'i-solar-confetti-minimalistic-bold',
|
|
11
|
+
},
|
|
12
|
+
};
|
|
13
|
+
|
|
14
|
+
export default routes;
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { defineStore } from 'pinia';
|
|
2
|
+
import { computed, ref } from 'vue';
|
|
3
|
+
|
|
4
|
+
export const useCounterStore = defineStore('counter', () => {
|
|
5
|
+
const count = ref(0);
|
|
6
|
+
const doubleCount = computed(() => count.value * 2);
|
|
7
|
+
function increment() {
|
|
8
|
+
count.value++;
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
return {
|
|
12
|
+
count,
|
|
13
|
+
doubleCount,
|
|
14
|
+
increment,
|
|
15
|
+
};
|
|
16
|
+
});
|