Compare commits
483 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
185d779c8d | ||
|
|
241fc618b8 | ||
|
|
3a0b2e04d4 | ||
|
|
cec867297d | ||
|
|
cbe539c727 | ||
|
|
7c84d9eb70 | ||
|
|
5a7187d22f | ||
|
|
a7e8249ae6 | ||
|
|
d81ab81fb0 | ||
|
|
846e7350fb | ||
|
|
102f27fe30 | ||
|
|
0e76bd4aac | ||
|
|
a74a9e2489 | ||
|
|
28e58e4b4e | ||
|
|
a8e830f51c | ||
|
|
0493c402a7 | ||
|
|
ca10d104c0 | ||
|
|
035ac47b39 | ||
|
|
a983575b6d | ||
|
|
d6a329a63c | ||
|
|
5ac646444f | ||
|
|
b36eab2141 | ||
|
|
3c44909f47 | ||
|
|
b827301d0a | ||
|
|
e0c8781bcc | ||
|
|
8314df9faf | ||
|
|
dffe8834a1 | ||
|
|
8d5be25093 | ||
|
|
7878c108e1 | ||
|
|
f27787d560 | ||
|
|
acaeb0cb42 | ||
|
|
9e8907ce21 | ||
|
|
3879b99176 | ||
|
|
bcbc110883 | ||
|
|
243c8f71a7 | ||
|
|
5f1466b574 | ||
|
|
26b85b5c92 | ||
|
|
76f6a9df89 | ||
|
|
0d4fe313b4 | ||
|
|
c7955bcc19 | ||
|
|
fe0f0c4d9e | ||
|
|
114d5427cc | ||
|
|
d824c99489 | ||
|
|
708ce43e00 | ||
|
|
271b953081 | ||
|
|
af71024f42 | ||
|
|
a73610672f | ||
|
|
4c6acc91ab | ||
|
|
b2dd962161 | ||
|
|
b52ab8cb0a | ||
|
|
d87f7e1948 | ||
|
|
60e3519f93 | ||
|
|
ef80912137 | ||
|
|
2e0b574733 | ||
|
|
e1eb658697 | ||
|
|
5a23bd02a4 | ||
|
|
af04611d6c | ||
|
|
384d5e9598 | ||
|
|
1848c43f0c | ||
|
|
d2cd29a838 | ||
|
|
91576bd7dd | ||
|
|
1b2eb2481e | ||
|
|
e3c240f139 | ||
|
|
d0cfc6614e | ||
|
|
007bb0124f | ||
|
|
9fa1d9d2ea | ||
|
|
1dfc67802a | ||
|
|
bae84cd1ba | ||
|
|
3f3301a4c2 | ||
|
|
4af50acf88 | ||
|
|
61880bc07b | ||
|
|
804f1aea9b | ||
|
|
636201df80 | ||
|
|
4157c7bccc | ||
|
|
0d05a2a6e3 | ||
|
|
a53cbc2b87 | ||
|
|
870f064598 | ||
|
|
2a15298cf8 | ||
|
|
bf8a7d98ac | ||
|
|
e9602d23cb | ||
|
|
747e2b9c1c | ||
|
|
dca722cb29 | ||
|
|
1f8e50f482 | ||
|
|
b6ed8b40d1 | ||
|
|
348916e567 | ||
|
|
6ea020c8d2 | ||
|
|
8f5981a313 | ||
|
|
378feceb5f | ||
|
|
c65940f5ef | ||
|
|
6627d4724e | ||
|
|
9ca764b2a6 | ||
|
|
f4c419d44a | ||
|
|
4f165b9391 | ||
|
|
25f70fd51b | ||
|
|
58f6be4d02 | ||
|
|
64326c4fb5 | ||
|
|
16cce26b67 | ||
|
|
6587e6eec0 | ||
|
|
1cf82eb7a4 | ||
|
|
2214ce7911 | ||
|
|
7f10ac7679 | ||
|
|
c8080c58f5 | ||
|
|
9067d88c3b | ||
|
|
f35dea840e | ||
|
|
8cbf1dd568 | ||
|
|
685c955ecf | ||
|
|
bedbf8077b | ||
|
|
3d304457f5 | ||
|
|
016c75c0d4 | ||
|
|
6c6d520dcb | ||
|
|
506bfc8087 | ||
|
|
e0d6002aa8 | ||
|
|
d14b0358ee | ||
|
|
0b8e402375 | ||
|
|
d192d842ed | ||
|
|
afe056649b | ||
|
|
0d4499c187 | ||
|
|
7397c315a7 | ||
|
|
d2104be91a | ||
|
|
c5d9275630 | ||
|
|
bbedcbc96b | ||
|
|
acebbd8958 | ||
|
|
482b41966e | ||
|
|
0d694e9870 | ||
|
|
294e4f6601 | ||
|
|
93a09bef4b | ||
|
|
14619588d4 | ||
|
|
63640a0950 | ||
|
|
db09d1c442 | ||
|
|
a80c6f034a | ||
|
|
db1f26e9da | ||
|
|
42b7e36e0d | ||
|
|
9271997a30 | ||
|
|
b23066c52b | ||
|
|
56f9dc85e7 | ||
|
|
1a565095e9 | ||
|
|
c89620159a | ||
|
|
160db34fa0 | ||
|
|
c4ebacedfe | ||
|
|
f3f9c12edf | ||
|
|
91df7349f4 | ||
|
|
dc219ed11a | ||
|
|
51d08045e8 | ||
|
|
f348a5982b | ||
|
|
7b614716af | ||
|
|
5828ad55a1 | ||
|
|
0becf0b4bc | ||
|
|
bafd9522e0 | ||
|
|
9797534458 | ||
|
|
5efeb28eb3 | ||
|
|
5e8723a031 | ||
|
|
de76497e8a | ||
|
|
9cdfe80143 | ||
|
|
87da024a29 | ||
|
|
a06de54113 | ||
|
|
5b94930463 | ||
|
|
5885706988 | ||
|
|
997711b264 | ||
|
|
7beb3e63fe | ||
|
|
ae57e42612 | ||
|
|
99140bbd1e | ||
|
|
89f4817cfe | ||
|
|
9802a0c51b | ||
|
|
d2d324e3f0 | ||
|
|
bee2315566 | ||
|
|
6d38b7a6aa | ||
|
|
0f6e4ab4e0 | ||
|
|
ee1a6ffeb6 | ||
|
|
b36850f79f | ||
|
|
bef0d9234e | ||
|
|
0bba4b7d64 | ||
|
|
a7576f6971 | ||
|
|
51d08e4b82 | ||
|
|
494ce8f41b | ||
|
|
8b3f642cf2 | ||
|
|
2e5667f652 | ||
|
|
8d539d4c21 | ||
|
|
c9026a45cc | ||
|
|
81c4184cc4 | ||
|
|
244f657be2 | ||
|
|
74a6b3ffdc | ||
|
|
8e7a79cf94 | ||
|
|
849b46533d | ||
|
|
7f5aeed4d1 | ||
|
|
c749149c2f | ||
|
|
0a7d22248f | ||
|
|
a35dc9d7b6 | ||
|
|
a6e819e169 | ||
|
|
3701161022 | ||
|
|
e3898df731 | ||
|
|
32172220f7 | ||
|
|
fcdfe6d0c0 | ||
|
|
67bc933d5c | ||
|
|
feb1532549 | ||
|
|
1722ee7a9b | ||
|
|
710e119397 | ||
|
|
f21d9f38e5 | ||
|
|
727c0fe3c0 | ||
|
|
e3fda52801 | ||
|
|
37762e45fd | ||
|
|
d43316f7c9 | ||
|
|
6971ba6c53 | ||
|
|
a175cf9fe0 | ||
|
|
9927e6f217 | ||
|
|
bc300eab18 | ||
|
|
3ca4729421 | ||
|
|
dfaa76cc29 | ||
|
|
7103b04283 | ||
|
|
d2ddb49314 | ||
|
|
a4a042bfd7 | ||
|
|
a9a8115d46 | ||
|
|
3676014eb6 | ||
|
|
52910602ff | ||
|
|
a2d1cf0e5f | ||
|
|
8e886e83e7 | ||
|
|
3e8dfb2bcb | ||
|
|
6fb0f7ef4d | ||
|
|
08983fdbc1 | ||
|
|
ef05b2b614 | ||
|
|
a2dde02994 | ||
|
|
7544cf058e | ||
|
|
43193fd2b6 | ||
|
|
25c55c5d1d | ||
|
|
217258b972 | ||
|
|
dbe0815ac4 | ||
|
|
fd4cad8d4c | ||
|
|
e33bdb52f3 | ||
|
|
46a48a5650 | ||
|
|
8fa3448af2 | ||
|
|
f236829b0f | ||
|
|
47dea87275 | ||
|
|
5e9198c2e0 | ||
|
|
c9c8f20cc5 | ||
|
|
a19c97f152 | ||
|
|
5e1e9d3c5f | ||
|
|
96153f8a14 | ||
|
|
14adf692ab | ||
|
|
aa845fc3f5 | ||
|
|
079a455181 | ||
|
|
07794d000c | ||
|
|
e787f46414 | ||
|
|
e61d6109d7 | ||
|
|
34eda14473 | ||
|
|
0eb0b7395e | ||
|
|
73705eb0e4 | ||
|
|
d94fb0ef06 | ||
|
|
17470ecce2 | ||
|
|
12db6966fb | ||
|
|
5070568b89 | ||
|
|
ef91f113ee | ||
|
|
c875d20e83 | ||
|
|
c86aae7b8b | ||
|
|
ee30cba471 | ||
|
|
7bcd8a800a | ||
|
|
903e298951 | ||
|
|
955b76f30a | ||
|
|
1b052023b6 | ||
|
|
3af52cf6c4 | ||
|
|
660b6f4be8 | ||
|
|
836c9e7cab | ||
|
|
4ded2a7a0c | ||
|
|
dc1caecf1c | ||
|
|
8de3e8b37f | ||
|
|
ab93216dbe | ||
|
|
86177e430e | ||
|
|
93ac4fa813 | ||
|
|
0903008ced | ||
|
|
10fa0ee8c8 | ||
|
|
eb0771e7ec | ||
|
|
39159d5e7b | ||
|
|
501891a21c | ||
|
|
cbffe31c70 | ||
|
|
3ef9444bcb | ||
|
|
c81227bb4c | ||
|
|
05ed941638 | ||
|
|
77c798eaed | ||
|
|
6ab9997a56 | ||
|
|
b961659c2f | ||
|
|
81bf66eca9 | ||
|
|
b251f8ff79 | ||
|
|
bae16008db | ||
|
|
a0c54a6ac9 | ||
|
|
438aab9bfc | ||
|
|
e97bd9c8c4 | ||
|
|
653bafaa2b | ||
|
|
b82a3d3a2e | ||
|
|
b8c8251c64 | ||
|
|
00cc5a88e0 | ||
|
|
5d6ed8da33 | ||
|
|
d57e0e379e | ||
|
|
7811f6bdeb | ||
|
|
113e5f9db2 | ||
|
|
1758711174 | ||
|
|
12879f9553 | ||
|
|
d6a358e851 | ||
|
|
9e7d78fd80 | ||
|
|
570154a4f1 | ||
|
|
5564250e7d | ||
|
|
8d65f8ee92 | ||
|
|
11bf711838 | ||
|
|
a845d4f237 | ||
|
|
02c3a88ed6 | ||
|
|
a8a3e5b303 | ||
|
|
cec5af55d9 | ||
|
|
d04ba7563a | ||
|
|
0450f004d3 | ||
|
|
24a899bba0 | ||
|
|
6c75296a02 | ||
|
|
6cca0d3ab2 | ||
|
|
3d34663eda | ||
|
|
4bbf4c8548 | ||
|
|
8685092260 | ||
|
|
622464a8a4 | ||
|
|
be3a8a6949 | ||
|
|
3acb65d42c | ||
|
|
6d3a8c5a88 | ||
|
|
b65b972353 | ||
|
|
8c31ca1bad | ||
|
|
8cb21b6321 | ||
|
|
6d6eb98562 | ||
|
|
aca6a667f3 | ||
|
|
d79e63f673 | ||
|
|
e67d2df677 | ||
|
|
d44da67dc4 | ||
|
|
9d45e80856 | ||
|
|
be66c8bfb9 | ||
|
|
e26a0f949d | ||
|
|
3e991e6e43 | ||
|
|
0337a0300c | ||
|
|
ee8e0eb733 | ||
|
|
39cca9ac25 | ||
|
|
95140986b9 | ||
|
|
034f1577c2 | ||
|
|
c3645fd760 | ||
|
|
b1b236f736 | ||
|
|
0b79b65575 | ||
|
|
067ed96de4 | ||
|
|
f25e5d19a4 | ||
|
|
0380d4a17a | ||
|
|
89dc4e5052 | ||
|
|
12492a522f | ||
|
|
5d9638758b | ||
|
|
6b064bdef9 | ||
|
|
7aa895a2b7 | ||
|
|
35f2f9e93f | ||
|
|
f0a5f02588 | ||
|
|
c4a6a337a3 | ||
|
|
44a4c9346b | ||
|
|
bcf533af62 | ||
|
|
aa8005a982 | ||
|
|
2d6ad99f6f | ||
|
|
1e1747a355 | ||
|
|
6ba0bd7739 | ||
|
|
b4088f4612 | ||
|
|
3c4619d071 | ||
|
|
10e8b296e3 | ||
|
|
b702703472 | ||
|
|
7590dc308c | ||
|
|
2f457ac6b2 | ||
|
|
cbc6743b5a | ||
|
|
af01d80db2 | ||
|
|
b45a10b98f | ||
|
|
cd668c11d8 | ||
|
|
753491a7eb | ||
|
|
fd4706f2d3 | ||
|
|
db580366fd | ||
|
|
487920375b | ||
|
|
42eb52bd88 | ||
|
|
3943164ad6 | ||
|
|
e98dee9f0a | ||
|
|
782cea9995 | ||
|
|
41a0fde036 | ||
|
|
7d453fdca7 | ||
|
|
c935fce27b | ||
|
|
ff4b18b73c | ||
|
|
cf78f6aa6a | ||
|
|
0ad3418239 | ||
|
|
d501339274 | ||
|
|
ad2f7358db | ||
|
|
a7ca161271 | ||
|
|
3a1f28667b | ||
|
|
ef1c47bac5 | ||
|
|
aa7a073b4a | ||
|
|
544e474e98 | ||
|
|
4b16bac5dc | ||
|
|
ea7266c04c | ||
|
|
c18dbea3cd | ||
|
|
f19f27510b | ||
|
|
57e32bab16 | ||
|
|
e63fe92cd9 | ||
|
|
c95126adf5 | ||
|
|
54a0e457b4 | ||
|
|
8436f964e4 | ||
|
|
709cb87c2b | ||
|
|
e0551251d3 | ||
|
|
dae0b5dc08 | ||
|
|
077276463f | ||
|
|
43a8baee3d | ||
|
|
91fe227e8c | ||
|
|
3f526873d8 | ||
|
|
def4c60395 | ||
|
|
6c02e97157 | ||
|
|
c25b130b7d | ||
|
|
c266a675a2 | ||
|
|
6b151eae1b | ||
|
|
0615902632 | ||
|
|
b773fb582d | ||
|
|
9ddf449ea7 | ||
|
|
8a14519467 | ||
|
|
321b9da9a8 | ||
|
|
594efc6204 | ||
|
|
c819554e54 | ||
|
|
3e12372d9c | ||
|
|
0fb7b5e983 | ||
|
|
9d061c6406 | ||
|
|
5f349775a8 | ||
|
|
4e04fdd657 | ||
|
|
c418ab03a2 | ||
|
|
8ffd341443 | ||
|
|
72224717f9 | ||
|
|
d4237aa596 | ||
|
|
ae72cccbb9 | ||
|
|
3389f3118a | ||
|
|
15ccd5db5b | ||
|
|
a28eb4b203 | ||
|
|
f921996563 | ||
|
|
71bd7e89d4 | ||
|
|
02f2cd9747 | ||
|
|
af6a1b03cd | ||
|
|
b248d9ea31 | ||
|
|
3851d284bf | ||
|
|
b520e234a1 | ||
|
|
b40cd2db74 | ||
|
|
fc4bfc35d7 | ||
|
|
769e684c61 | ||
|
|
25c37bb2fa | ||
|
|
ab06aa00ed | ||
|
|
1fa5793ec4 | ||
|
|
5a78685ac9 | ||
|
|
ae161e8b48 | ||
|
|
8d2824fe82 | ||
|
|
822261c922 | ||
|
|
3e4b49b4be | ||
|
|
c5d6d2c76e | ||
|
|
2d9c185b4e | ||
|
|
70af35dbf5 | ||
|
|
7dcf98a178 | ||
|
|
089dea8441 | ||
|
|
c7b61febc3 | ||
|
|
8b8cd52f64 | ||
|
|
eb8d3ca96e | ||
|
|
7e6768208d | ||
|
|
3980c9a876 | ||
|
|
ca849c94e2 | ||
|
|
430e5d75b0 | ||
|
|
5f294356a9 | ||
|
|
4a6fcdb8e5 | ||
|
|
52394cc550 | ||
|
|
f7036143a4 | ||
|
|
7d0367dc58 | ||
|
|
f872ea1a23 | ||
|
|
016948d852 | ||
|
|
7724d6443e | ||
|
|
7013e57d1e | ||
|
|
639a69d579 | ||
|
|
b2c05e4397 | ||
|
|
f76f43ca0e | ||
|
|
a322b8497e | ||
|
|
b75eecabd2 | ||
|
|
4aaffc53a8 | ||
|
|
a2a793f84e | ||
|
|
d551f372e4 | ||
|
|
04f4815f04 | ||
|
|
cec2ffd3eb | ||
|
|
1b56c86e07 | ||
|
|
8b1b37b727 | ||
|
|
f45588e811 | ||
|
|
7f34b63569 | ||
|
|
db4855737b | ||
|
|
ee7241da3f | ||
|
|
3cd4f340a1 | ||
|
|
a7c12d93d3 | ||
|
|
e22e19552a |
14
.env
@@ -1,14 +1,2 @@
|
|||||||
# port
|
# 项目本地运行端口号
|
||||||
VITE_PORT = 8848
|
VITE_PORT = 8848
|
||||||
# title
|
|
||||||
VITE_TITLE = vue-pure-admin
|
|
||||||
# version
|
|
||||||
VITE_VERSION = 2.1.0
|
|
||||||
# open
|
|
||||||
VITE_OPEN = false
|
|
||||||
|
|
||||||
# public path
|
|
||||||
VITE_PUBLIC_PATH = /
|
|
||||||
|
|
||||||
# Cross-domain proxy, you can configure multiple
|
|
||||||
VITE_PROXY = [ ["/api", "http://127.0.0.1:3000" ] ]
|
|
||||||
|
|||||||
@@ -1,14 +1,14 @@
|
|||||||
# port
|
# 项目本地运行端口号
|
||||||
VITE_PORT = 8848
|
VITE_PORT = 8848
|
||||||
# title
|
|
||||||
VITE_TITLE = vue-pure-admin
|
|
||||||
# version
|
|
||||||
VITE_VERSION = 2.1.0
|
|
||||||
# open
|
|
||||||
VITE_OPEN = false
|
|
||||||
|
|
||||||
# public path
|
# 开发环境读取配置文件路径
|
||||||
VITE_PUBLIC_PATH = /
|
VITE_PUBLIC_PATH = /
|
||||||
|
|
||||||
# Cross-domain proxy, you can configure multiple
|
# 开发环境代理
|
||||||
VITE_PROXY = [ ["/api", "http://127.0.0.1:3000" ] ]
|
VITE_PROXY_DOMAIN = /api
|
||||||
|
|
||||||
|
# 开发环境路由历史模式
|
||||||
|
VITE_ROUTER_HISTORY = "hash"
|
||||||
|
|
||||||
|
# 开发环境后端地址
|
||||||
|
VITE_PROXY_DOMAIN_REAL = "http://127.0.0.1:3000"
|
||||||
@@ -1,2 +1,11 @@
|
|||||||
# public path
|
# 线上环境项目打包路径
|
||||||
VITE_PUBLIC_PATH = /manages/
|
VITE_PUBLIC_PATH = /
|
||||||
|
|
||||||
|
# 线上环境路由历史模式
|
||||||
|
VITE_ROUTER_HISTORY = "hash"
|
||||||
|
|
||||||
|
# 线上环境后端地址
|
||||||
|
VITE_PROXY_DOMAIN_REAL = ""
|
||||||
|
|
||||||
|
# 是否为打包后的文件提供传统浏览器兼容性支持 支持 true 不支持 false
|
||||||
|
VITE_LEGACY = false
|
||||||
14
.env.staging
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
# 预发布也需要生产环境的行为
|
||||||
|
# https://cn.vitejs.dev/guide/env-and-mode.html#modes
|
||||||
|
NODE_ENV=production
|
||||||
|
|
||||||
|
VITE_PUBLIC_PATH = /
|
||||||
|
|
||||||
|
# 线上环境路由历史模式
|
||||||
|
VITE_ROUTER_HISTORY = "hash"
|
||||||
|
|
||||||
|
# 线上环境后端地址
|
||||||
|
VITE_PROXY_DOMAIN_REAL = ""
|
||||||
|
|
||||||
|
# 是否为打包后的文件提供传统浏览器兼容性支持 支持 true 不支持 false
|
||||||
|
VITE_LEGACY = false
|
||||||
49
.eslintrc.js
@@ -37,7 +37,7 @@ module.exports = {
|
|||||||
"eslint:recommended",
|
"eslint:recommended",
|
||||||
"@vue/typescript/recommended",
|
"@vue/typescript/recommended",
|
||||||
"@vue/prettier",
|
"@vue/prettier",
|
||||||
"@vue/prettier/@typescript-eslint"
|
"@vue/eslint-config-typescript"
|
||||||
],
|
],
|
||||||
parser: "vue-eslint-parser",
|
parser: "vue-eslint-parser",
|
||||||
parserOptions: {
|
parserOptions: {
|
||||||
@@ -49,7 +49,34 @@ module.exports = {
|
|||||||
jsx: true
|
jsx: true
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
overrides: [
|
||||||
|
{
|
||||||
|
files: ["*.ts", "*.vue"],
|
||||||
|
rules: {
|
||||||
|
"no-undef": "off"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
files: ["*.vue"],
|
||||||
|
parser: "vue-eslint-parser",
|
||||||
|
parserOptions: {
|
||||||
|
parser: "@typescript-eslint/parser",
|
||||||
|
extraFileExtensions: [".vue"],
|
||||||
|
ecmaVersion: "latest",
|
||||||
|
ecmaFeatures: {
|
||||||
|
jsx: true
|
||||||
|
}
|
||||||
|
},
|
||||||
|
rules: {
|
||||||
|
"no-undef": "off"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
],
|
||||||
rules: {
|
rules: {
|
||||||
|
"vue/no-v-html": "off",
|
||||||
|
"vue/require-default-prop": "off",
|
||||||
|
"vue/require-explicit-emits": "off",
|
||||||
|
"vue/multi-word-component-names": "off",
|
||||||
"@typescript-eslint/no-explicit-any": "off", // any
|
"@typescript-eslint/no-explicit-any": "off", // any
|
||||||
"no-debugger": "off",
|
"no-debugger": "off",
|
||||||
"@typescript-eslint/explicit-module-boundary-types": "off", // setup()
|
"@typescript-eslint/explicit-module-boundary-types": "off", // setup()
|
||||||
@@ -57,6 +84,18 @@ module.exports = {
|
|||||||
"@typescript-eslint/ban-ts-comment": "off",
|
"@typescript-eslint/ban-ts-comment": "off",
|
||||||
"@typescript-eslint/no-empty-function": "off",
|
"@typescript-eslint/no-empty-function": "off",
|
||||||
"@typescript-eslint/no-non-null-assertion": "off",
|
"@typescript-eslint/no-non-null-assertion": "off",
|
||||||
|
"vue/html-self-closing": [
|
||||||
|
"error",
|
||||||
|
{
|
||||||
|
html: {
|
||||||
|
void: "always",
|
||||||
|
normal: "always",
|
||||||
|
component: "always"
|
||||||
|
},
|
||||||
|
svg: "always",
|
||||||
|
math: "always"
|
||||||
|
}
|
||||||
|
],
|
||||||
"@typescript-eslint/no-unused-vars": [
|
"@typescript-eslint/no-unused-vars": [
|
||||||
"error",
|
"error",
|
||||||
{
|
{
|
||||||
@@ -70,6 +109,12 @@ module.exports = {
|
|||||||
argsIgnorePattern: "^_",
|
argsIgnorePattern: "^_",
|
||||||
varsIgnorePattern: "^_"
|
varsIgnorePattern: "^_"
|
||||||
}
|
}
|
||||||
|
],
|
||||||
|
"prettier/prettier": [
|
||||||
|
"error",
|
||||||
|
{
|
||||||
|
endOfLine: "auto"
|
||||||
|
}
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
};
|
}
|
||||||
|
|||||||
17
.github/workflows/linter.yml
vendored
@@ -45,11 +45,22 @@ jobs:
|
|||||||
# Full git history is needed to get a proper list of changed files within `super-linter`
|
# Full git history is needed to get a proper list of changed files within `super-linter`
|
||||||
fetch-depth: 0
|
fetch-depth: 0
|
||||||
|
|
||||||
|
- name: Setup node
|
||||||
|
uses: actions/setup-node@v2
|
||||||
|
with:
|
||||||
|
node-version: "16"
|
||||||
|
registry-url: https://registry.npmjs.com/
|
||||||
|
|
||||||
|
- name: Setup pnpm
|
||||||
|
uses: pnpm/action-setup@v2
|
||||||
|
with:
|
||||||
|
version: latest
|
||||||
|
|
||||||
- name: Build
|
- name: Build
|
||||||
run: |
|
run: |
|
||||||
yarn install
|
pnpm install
|
||||||
yarn lint
|
pnpm lint
|
||||||
yarn build
|
pnpm typecheck
|
||||||
env:
|
env:
|
||||||
VALIDATE_ALL_CODEBASE: false
|
VALIDATE_ALL_CODEBASE: false
|
||||||
DEFAULT_BRANCH: main
|
DEFAULT_BRANCH: main
|
||||||
|
|||||||
9
.gitignore
vendored
@@ -4,10 +4,12 @@ dist
|
|||||||
dist-ssr
|
dist-ssr
|
||||||
*.local
|
*.local
|
||||||
.eslintcache
|
.eslintcache
|
||||||
|
report.html
|
||||||
|
|
||||||
|
yarn.lock
|
||||||
npm-debug.log*
|
npm-debug.log*
|
||||||
yarn-debug.log*
|
.pnpm-error.log*
|
||||||
yarn-error.log*
|
.pnpm-debug.log
|
||||||
tests/**/coverage/
|
tests/**/coverage/
|
||||||
|
|
||||||
# Editor directories and files
|
# Editor directories and files
|
||||||
@@ -15,4 +17,5 @@ tests/**/coverage/
|
|||||||
*.suo
|
*.suo
|
||||||
*.ntvs*
|
*.ntvs*
|
||||||
*.njsproj
|
*.njsproj
|
||||||
*.sln
|
*.sln
|
||||||
|
tsconfig.tsbuildinfo
|
||||||
@@ -2,4 +2,4 @@ ports:
|
|||||||
- port: 3344
|
- port: 3344
|
||||||
onOpen: open-preview
|
onOpen: open-preview
|
||||||
tasks:
|
tasks:
|
||||||
- init: npm install && npm run serve
|
- init: pnpm install && pnpm serve
|
||||||
|
|||||||
@@ -3,7 +3,7 @@ command_exists () {
|
|||||||
command -v "$1" >/dev/null 2>&1
|
command -v "$1" >/dev/null 2>&1
|
||||||
}
|
}
|
||||||
|
|
||||||
# Workaround for Windows 10, Git Bash and Yarn
|
# Workaround for Windows 10, Git Bash and Pnpm
|
||||||
if command_exists winpty && test -t 1; then
|
if command_exists winpty && test -t 1; then
|
||||||
exec < /dev/tty
|
exec < /dev/tty
|
||||||
fi
|
fi
|
||||||
|
|||||||
@@ -1,8 +1,6 @@
|
|||||||
module.exports = {
|
module.exports = {
|
||||||
"*.{js,jsx,ts,tsx}": ["eslint --fix", "prettier --write"],
|
"*.{js,jsx,ts,tsx}": ["eslint --fix", "prettier --write"],
|
||||||
"{!(package)*.json,*.code-snippets,.!(browserslist)*rc}": [
|
"{!(package)*.json,.!(browserslist)*rc}": ["prettier --write--parser json"],
|
||||||
"prettier --write--parser json"
|
|
||||||
],
|
|
||||||
"package.json": ["prettier --write"],
|
"package.json": ["prettier --write"],
|
||||||
"*.vue": ["eslint --fix", "prettier --write", "stylelint --fix"],
|
"*.vue": ["eslint --fix", "prettier --write", "stylelint --fix"],
|
||||||
"*.{vue,css,scss,postcss,less}": ["stylelint --fix", "prettier --write"],
|
"*.{vue,css,scss,postcss,less}": ["stylelint --fix", "prettier --write"],
|
||||||
|
|||||||
11
.markdownlint.json
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
{
|
||||||
|
"default": true,
|
||||||
|
"MD003": false,
|
||||||
|
"MD033": false,
|
||||||
|
"MD013": false,
|
||||||
|
"MD001": false,
|
||||||
|
"MD025": false,
|
||||||
|
"MD024": false,
|
||||||
|
"MD007": { "indent": 4 },
|
||||||
|
"no-hard-tabs": false
|
||||||
|
}
|
||||||
@@ -1,7 +1,6 @@
|
|||||||
module.exports = {
|
module.exports = {
|
||||||
bracketSpacing: true,
|
bracketSpacing: true,
|
||||||
jsxBracketSameLine: true,
|
|
||||||
singleQuote: false,
|
singleQuote: false,
|
||||||
arrowParens: 'avoid',
|
arrowParens: "avoid",
|
||||||
trailingComma: 'none'
|
trailingComma: "none"
|
||||||
};
|
};
|
||||||
|
|||||||
15
.vscode/extensions.json
vendored
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
{
|
||||||
|
"recommendations": [
|
||||||
|
"vscode-icons-team.vscode-icons",
|
||||||
|
"davidanson.vscode-markdownlint",
|
||||||
|
"stylelint.vscode-stylelint",
|
||||||
|
"dbaeumer.vscode-eslint",
|
||||||
|
"esbenp.prettier-vscode",
|
||||||
|
"lokalise.i18n-ally",
|
||||||
|
"mikestead.dotenv",
|
||||||
|
"eamodio.gitlens",
|
||||||
|
"antfu.iconify",
|
||||||
|
"antfu.unocss",
|
||||||
|
"Vue.volar"
|
||||||
|
]
|
||||||
|
}
|
||||||
29
.vscode/settings.json
vendored
@@ -1,22 +1,9 @@
|
|||||||
{
|
{
|
||||||
// You should install these plugins:
|
|
||||||
// ESLint
|
|
||||||
// Prettier - Code formatter
|
|
||||||
// stylelint
|
|
||||||
// vscode-icons
|
|
||||||
// TypeScript Vue Plugin (Volar)
|
|
||||||
// Vue Language Features (Volar)
|
|
||||||
"terminal.integrated.rendererType": "dom",
|
|
||||||
"editor.formatOnType": true,
|
"editor.formatOnType": true,
|
||||||
"editor.formatOnSave": true,
|
"editor.formatOnSave": true,
|
||||||
"window.zoomLevel": 1,
|
|
||||||
"javascript.updateImportsOnFileMove.enabled": "always",
|
|
||||||
"[vue]": {
|
"[vue]": {
|
||||||
"editor.defaultFormatter": "esbenp.prettier-vscode"
|
"editor.defaultFormatter": "esbenp.prettier-vscode"
|
||||||
},
|
},
|
||||||
"[javascript]": {
|
|
||||||
"editor.defaultFormatter": "vscode.typescript-language-features"
|
|
||||||
},
|
|
||||||
"editor.tabSize": 2,
|
"editor.tabSize": 2,
|
||||||
"editor.formatOnPaste": true,
|
"editor.formatOnPaste": true,
|
||||||
"files.autoSave": "afterDelay",
|
"files.autoSave": "afterDelay",
|
||||||
@@ -25,23 +12,27 @@
|
|||||||
"editor.suggestSelection": "first",
|
"editor.suggestSelection": "first",
|
||||||
"editor.acceptSuggestionOnCommitCharacter": false,
|
"editor.acceptSuggestionOnCommitCharacter": false,
|
||||||
"css.lint.propertyIgnoredDueToDisplay": "ignore",
|
"css.lint.propertyIgnoredDueToDisplay": "ignore",
|
||||||
// Prevent inline styles from being automatically formatted to all lowercase
|
|
||||||
"editor.quickSuggestions": {
|
"editor.quickSuggestions": {
|
||||||
"other": true,
|
"other": true,
|
||||||
"comments": true,
|
"comments": true,
|
||||||
"strings": true
|
"strings": true
|
||||||
},
|
},
|
||||||
// Automatically fix some syntax errors of ts
|
|
||||||
"tslint.autoFixOnSave": true,
|
|
||||||
"files.associations": {
|
"files.associations": {
|
||||||
// Specifies the location of snippets in the suggestion widget
|
|
||||||
"editor.snippetSuggestions": "top"
|
"editor.snippetSuggestions": "top"
|
||||||
},
|
},
|
||||||
"[css]": {
|
"[css]": {
|
||||||
"editor.defaultFormatter": "esbenp.prettier-vscode"
|
"editor.defaultFormatter": "esbenp.prettier-vscode"
|
||||||
},
|
},
|
||||||
"cSpell.userWords": ["sourcemap", "vite"],
|
|
||||||
"editor.codeActionsOnSave": {
|
"editor.codeActionsOnSave": {
|
||||||
"source.fixAll.eslint": true
|
"source.fixAll.eslint": true
|
||||||
}
|
},
|
||||||
|
"i18n-ally.localesPaths": "locales",
|
||||||
|
"i18n-ally.keystyle": "nested",
|
||||||
|
"i18n-ally.sortKeys": true,
|
||||||
|
"i18n-ally.namespace": true,
|
||||||
|
"i18n-ally.enabledParsers": ["yaml", "js"],
|
||||||
|
"i18n-ally.sourceLanguage": "en",
|
||||||
|
"i18n-ally.displayLanguage": "zh-CN",
|
||||||
|
"i18n-ally.enabledFrameworks": ["vue"],
|
||||||
|
"iconify.excludes": ["el"]
|
||||||
}
|
}
|
||||||
|
|||||||
17
.vscode/vue3.2.code-snippets
vendored
Normal file
@@ -0,0 +1,17 @@
|
|||||||
|
{
|
||||||
|
"Vue3.2+快速生成模板": {
|
||||||
|
"prefix": "Vue3.2+",
|
||||||
|
"body": [
|
||||||
|
"<script setup lang='ts'>",
|
||||||
|
"</script>\n",
|
||||||
|
"<template>",
|
||||||
|
"\t<div>\n",
|
||||||
|
"\t</div>",
|
||||||
|
"</template>\n",
|
||||||
|
"<style scoped>\n",
|
||||||
|
"</style>",
|
||||||
|
"$2"
|
||||||
|
],
|
||||||
|
"description": "Vue3.2+"
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1,3 +1,199 @@
|
|||||||
|
# 3.4.5 (2022-8-22)
|
||||||
|
|
||||||
|
### 🐞 Bug fixes
|
||||||
|
|
||||||
|
- Fix local responsive storage object setting issue
|
||||||
|
|
||||||
|
# 3.4.0 (2022-8-22)
|
||||||
|
|
||||||
|
### 🍏 Perf
|
||||||
|
|
||||||
|
- Optimized routing
|
||||||
|
- Optimized for mobile compatibility
|
||||||
|
- Optimized routing parameters (`query`, `params` way to refresh the page does not need to open the tab page cache, the parameters can be retained on the `url` and `tab page`)
|
||||||
|
|
||||||
|
# 3.3.5 (2022-8-19)
|
||||||
|
|
||||||
|
### 🎫 Feat
|
||||||
|
|
||||||
|
- Secondary encapsulation of `Table` of `element-plus` into [@pureadmin/table](https://github.com/xiaoxian521/pure-admin-table), providing flexible configuration items and integrating into the platform
|
||||||
|
- Secondary encapsulation of `Descriptions` of `element-plus` into [@pureadmin/descriptions](https://github.com/xiaoxian521/pure-admin-descriptions), providing flexible configuration items and integrating into the platform
|
||||||
|
- Centralize most of the tools and hooks of the platform to [@pureadmin/utils](https://pure-admin-utils-docs.vercel.app/), and delete the code concentrated in this library to reduce the size of the platform
|
||||||
|
- Add [unplugin-vue-define-options](https://www.npmjs.com/package/unplugin-vue-define-options) plugin, the page can directly write `defineOptions({name: custom name})`
|
||||||
|
- Add project files, language analysis tool [cloc](https://www.npmjs.com/package/cloc)
|
||||||
|
- Added landing page internationalization
|
||||||
|
- Add full routing configuration table type declaration
|
||||||
|
- Add virtual listing page demo
|
||||||
|
- Add `PDF` preview page demo
|
||||||
|
- Added export `execl` page demo
|
||||||
|
- Added blank page demo without `Layout`
|
||||||
|
|
||||||
|
### ✔️ refactor
|
||||||
|
|
||||||
|
- Refactored the theme color to adapt to `element-plus` dark mode (also solved the problem that the same element `css` in `3.3.0` and earlier versions was overwritten many times, resulting in poor style debugging)
|
||||||
|
- Refactored route reset function
|
||||||
|
|
||||||
|
### 🍏 Perf
|
||||||
|
|
||||||
|
- The compatible project storage directory is named in Chinese, but we really do not recommend Chinese naming, because a library may not escape the Chinese path, causing the project to crash
|
||||||
|
- Optimized interface type
|
||||||
|
|
||||||
|
### 🐞 Bug fixes
|
||||||
|
|
||||||
|
- Fixed async routes with `showlink` set to `false`, not showing after refresh
|
||||||
|
- Fixed vertical navigation menu text being hidden after collapse when there is no `icon`
|
||||||
|
|
||||||
|
# 3.3.0 (2022-5-11)
|
||||||
|
|
||||||
|
### 🎫 Feat
|
||||||
|
|
||||||
|
- Add user management page demo
|
||||||
|
- Add role management page demo
|
||||||
|
- Add department management page demo
|
||||||
|
- Add card list page demo
|
||||||
|
- Integrated form designer
|
||||||
|
- Added `PPT` demo
|
||||||
|
- Added anti-shake interception demo in the function menu
|
||||||
|
- Upgrade `wangeditorV5` (and support internationalization and custom themes)
|
||||||
|
- Integrate `tauri` version
|
||||||
|
- Added barcode function
|
||||||
|
- Added QR code function
|
||||||
|
- Use the `Cascader` cascade selector in `element-plus` to write a three-level and two-level linkage demo of Chinese provinces and cities
|
||||||
|
- Integrate `Swiper` plugin
|
||||||
|
- Routing supports passing `component`, representing the component path
|
||||||
|
- Added pre-release packaging mode
|
||||||
|
- Add [hooks] to close a tag (https://github.com/xiaoxian521/vue-pure-admin/commit/5e8723a031923e79f507e5a17151d3bd88a51523)
|
||||||
|
|
||||||
|
### ✔️ refactor
|
||||||
|
|
||||||
|
- Refactored the landing page to be more inclined to the actual business scenario
|
||||||
|
- Use `unocss` instead of `windicss`, `unocss` has better performance in development environment, no memory leaks, and `api` is compatible with `windicss`
|
||||||
|
|
||||||
|
### 🍏 Perf
|
||||||
|
|
||||||
|
- Optimized the style of the `split-pane` component for the platform
|
||||||
|
- Optimize internationalization, no longer pass the `i18n` field in the route, the platform automatically reads the files in the `locales` folder of the root directory for internationalization matching
|
||||||
|
- Optimized icon selector
|
||||||
|
- Optimize `layout` to display user information [commit](https://github.com/xiaoxian521/vue-pure-admin/commit/56f9dc85e7fbe0637605c43577c794de9f8968aa)
|
||||||
|
|
||||||
|
### 🐞 Bug fixes
|
||||||
|
|
||||||
|
- Fix route initialization problem (Cannot access 'constantRoutes' before initialization)
|
||||||
|
|
||||||
|
# 3.2.0 (2022-3-22)
|
||||||
|
|
||||||
|
### 🎫 Feat
|
||||||
|
|
||||||
|
- Icon selection component
|
||||||
|
- Menu search function
|
||||||
|
- Added results page
|
||||||
|
- Extended `element-plus` timeline component
|
||||||
|
- Extended `element-plus` tree component to support connecting lines
|
||||||
|
- Add tree selector, support single and multiple selection
|
||||||
|
|
||||||
|
### 🍏 Perf
|
||||||
|
|
||||||
|
- Optimized the error page UI
|
||||||
|
- Optimize the internationalization function
|
||||||
|
- Optimized routing `rank` sorting, compatible with the case where the value of the `rank` field in the routing `meta` is `null`
|
||||||
|
|
||||||
|
### 🐞 Bug fixes
|
||||||
|
|
||||||
|
- Fixed the situation where the menu expands and folds will freeze on some computers
|
||||||
|
|
||||||
|
# 3.1.0 (2022-3-3)
|
||||||
|
|
||||||
|
### 🎫 Feat
|
||||||
|
|
||||||
|
- iframe supports dynamic loading
|
||||||
|
- Watermark example
|
||||||
|
- Print examples (pictures, tables, echarts)
|
||||||
|
- Add running and packaging information, use `lodash-unified` to replace `lodash-es`, `lodash-unified` supports `ESM` and is compatible with `CJS`
|
||||||
|
|
||||||
|
### 🐞 Bug fixes
|
||||||
|
|
||||||
|
- Fixed jumping to another menu page alone in one menu page, the routing page jumped but the tab page was not displayed
|
||||||
|
- Fixed the route that returns dynamic level 3 and above in the background, and the menu does not correspond to the page
|
||||||
|
|
||||||
|
# 3.0 (2022-2-14)
|
||||||
|
|
||||||
|
### 🎫 Feat
|
||||||
|
|
||||||
|
- Added mix navigation
|
||||||
|
|
||||||
|
### 🐞 Bug fixes
|
||||||
|
|
||||||
|
- Fix tab page bug
|
||||||
|
|
||||||
|
# 2.9.0 (2022-2-5)
|
||||||
|
|
||||||
|
### 🎫 Feat
|
||||||
|
|
||||||
|
- Added package size analysis, command `pnpm report`
|
||||||
|
|
||||||
|
### 🍏 Perf
|
||||||
|
|
||||||
|
- Use `iconify` to introduce icons on demand, optimize icon size, and reduce network requests
|
||||||
|
- Optimize the route, the route can not pass `showLink: true`, it is displayed by default
|
||||||
|
|
||||||
|
# 2.8.5 (2022-1-21)
|
||||||
|
|
||||||
|
### 🎫 Feat
|
||||||
|
|
||||||
|
- Added `WindiCSS` support
|
||||||
|
- Add online environment remove console plugin `vite-plugin-remove-console`
|
||||||
|
|
||||||
|
### ✔️ refactor
|
||||||
|
|
||||||
|
- Replace `@element-plus/icons-vue` with `@iconify-icons/ep`
|
||||||
|
|
||||||
|
# 2.8.0(2022-1-4)
|
||||||
|
|
||||||
|
### 🎫 Feat
|
||||||
|
|
||||||
|
-Added dark theme
|
||||||
|
-Add element-plus custom theme
|
||||||
|
-Add guide page
|
||||||
|
|
||||||
|
### 🍏 Perf
|
||||||
|
|
||||||
|
-Optimize internationalization, compatible with the vscode plug-in i18n Ally smart reminder
|
||||||
|
-Optimize the back-end return routing structure
|
||||||
|
-Optimize local storage, with four built-in buttons `responsive-configure`, `responsive-locale`, `responsive-layout`, `responsive-tags`, which are basic configuration, international configuration, layout configuration, and tab persistent configuration
|
||||||
|
|
||||||
|
# 2.7.0(2021-12-18)
|
||||||
|
|
||||||
|
### 🎫 Feat
|
||||||
|
|
||||||
|
- New tab reuse
|
||||||
|
- New message reminder template
|
||||||
|
- Added front-end menu tree structure example
|
||||||
|
- Refactor routing, optimize permissions modules, and bring a more convenient experience
|
||||||
|
- Refactor the env environment and http request to bring a more convenient experience
|
||||||
|
- Currently, the tabs of the platform are forced to associate with local storage. The next step is to put the tabs in the memory by default and support configurable persistent tabs
|
||||||
|
- Navigation menu icons support fontawesome, iconfont, remixicon, element-plus/icons, custom svg
|
||||||
|
- Update font-awesome to version 5.0, because versions below 5.0 are no longer officially maintained, but the platform will still be compatible with font-awesome4 version
|
||||||
|
|
||||||
|
### 🍏 Perf
|
||||||
|
|
||||||
|
- Optimize the tab page to bring a better interactive experience
|
||||||
|
- Routing title supports direct writing in Chinese, which can be separated from internationalization
|
||||||
|
- Route history mode is read from env and supports base parameter
|
||||||
|
- Packaged files provide traditional browser compatibility support, configure VITE_LEGACY to true
|
||||||
|
|
||||||
|
# 2.6.0(2021-11-10)
|
||||||
|
|
||||||
|
### 🎫 Feat
|
||||||
|
|
||||||
|
- Refactored navigation theme color, supports multiple color schemes
|
||||||
|
- Refactored login page, illustration style
|
||||||
|
|
||||||
|
### 🍏 Perf
|
||||||
|
|
||||||
|
- Optimize the navigation style
|
||||||
|
- Eliminate strong navigation dependence on vxe-table
|
||||||
|
- Synchronously update element-plus, replace Font Icon with SVG Icon
|
||||||
|
|
||||||
# 2.1.0(2021-10-14)
|
# 2.1.0(2021-10-14)
|
||||||
|
|
||||||
### 🎫 Feat
|
### 🎫 Feat
|
||||||
|
|||||||
196
CHANGELOG.md
@@ -1,3 +1,199 @@
|
|||||||
|
# 3.4.5 (2022-8-22)
|
||||||
|
|
||||||
|
### 🐞 Bug fixes
|
||||||
|
|
||||||
|
- Fix local responsive storage object setting issue
|
||||||
|
|
||||||
|
# 3.4.0 (2022-8-22)
|
||||||
|
|
||||||
|
### 🍏 Perf
|
||||||
|
|
||||||
|
- Optimized routing
|
||||||
|
- Optimized for mobile compatibility
|
||||||
|
- Optimized routing parameters (`query`, `params` way to refresh the page does not need to open the tab page cache, the parameters can be retained on the `url` and `tab page`)
|
||||||
|
|
||||||
|
# 3.3.5 (2022-8-19)
|
||||||
|
|
||||||
|
### 🎫 Feat
|
||||||
|
|
||||||
|
- Secondary encapsulation of `Table` of `element-plus` into [@pureadmin/table](https://github.com/xiaoxian521/pure-admin-table), providing flexible configuration items and integrating into the platform
|
||||||
|
- Secondary encapsulation of `Descriptions` of `element-plus` into [@pureadmin/descriptions](https://github.com/xiaoxian521/pure-admin-descriptions), providing flexible configuration items and integrating into the platform
|
||||||
|
- Centralize most of the tools and hooks of the platform to [@pureadmin/utils](https://pure-admin-utils-docs.vercel.app/), and delete the code concentrated in this library to reduce the size of the platform
|
||||||
|
- Add [unplugin-vue-define-options](https://www.npmjs.com/package/unplugin-vue-define-options) plugin, the page can directly write `defineOptions({name: custom name})`
|
||||||
|
- Add project files, language analysis tool [cloc](https://www.npmjs.com/package/cloc)
|
||||||
|
- Added landing page internationalization
|
||||||
|
- Add full routing configuration table type declaration
|
||||||
|
- Add virtual listing page demo
|
||||||
|
- Add `PDF` preview page demo
|
||||||
|
- Added export `execl` page demo
|
||||||
|
- Added blank page demo without `Layout`
|
||||||
|
|
||||||
|
### ✔️ refactor
|
||||||
|
|
||||||
|
- Refactored the theme color to adapt to `element-plus` dark mode (also solved the problem that the same element `css` in `3.3.0` and earlier versions was overwritten many times, resulting in poor style debugging)
|
||||||
|
- Refactored route reset function
|
||||||
|
|
||||||
|
### 🍏 Perf
|
||||||
|
|
||||||
|
- The compatible project storage directory is named in Chinese, but we really do not recommend Chinese naming, because a library may not escape the Chinese path, causing the project to crash
|
||||||
|
- Optimized interface type
|
||||||
|
|
||||||
|
### 🐞 Bug fixes
|
||||||
|
|
||||||
|
- Fixed async routes with `showlink` set to `false`, not showing after refresh
|
||||||
|
- Fixed vertical navigation menu text being hidden after collapse when there is no `icon`
|
||||||
|
|
||||||
|
# 3.3.0 (2022-5-11)
|
||||||
|
|
||||||
|
### 🎫 Feat
|
||||||
|
|
||||||
|
- Add user management page demo
|
||||||
|
- Add role management page demo
|
||||||
|
- Add department management page demo
|
||||||
|
- Add card list page demo
|
||||||
|
- Integrated form designer
|
||||||
|
- Added `PPT` demo
|
||||||
|
- Added anti-shake interception demo in the function menu
|
||||||
|
- Upgrade `wangeditorV5` (and support internationalization and custom themes)
|
||||||
|
- Integrate `tauri` version
|
||||||
|
- Added barcode function
|
||||||
|
- Added QR code function
|
||||||
|
- Use the `Cascader` cascade selector in `element-plus` to write a three-level and two-level linkage demo of Chinese provinces and cities
|
||||||
|
- Integrate `Swiper` plugin
|
||||||
|
- Routing supports passing `component`, representing the component path
|
||||||
|
- Added pre-release packaging mode
|
||||||
|
- Add [hooks] to close a tag (https://github.com/xiaoxian521/vue-pure-admin/commit/5e8723a031923e79f507e5a17151d3bd88a51523)
|
||||||
|
|
||||||
|
### ✔️ refactor
|
||||||
|
|
||||||
|
- Refactored the landing page to be more inclined to the actual business scenario
|
||||||
|
- Use `unocss` instead of `windicss`, `unocss` has better performance in development environment, no memory leaks, and `api` is compatible with `windicss`
|
||||||
|
|
||||||
|
### 🍏 Perf
|
||||||
|
|
||||||
|
- Optimized the style of the `split-pane` component for the platform
|
||||||
|
- Optimize internationalization, no longer pass the `i18n` field in the route, the platform automatically reads the files in the `locales` folder of the root directory for internationalization matching
|
||||||
|
- Optimized icon selector
|
||||||
|
- Optimize `layout` to display user information [commit](https://github.com/xiaoxian521/vue-pure-admin/commit/56f9dc85e7fbe0637605c43577c794de9f8968aa)
|
||||||
|
|
||||||
|
### 🐞 Bug fixes
|
||||||
|
|
||||||
|
- Fix route initialization problem (Cannot access 'constantRoutes' before initialization)
|
||||||
|
|
||||||
|
# 3.2.0 (2022-3-22)
|
||||||
|
|
||||||
|
### 🎫 Feat
|
||||||
|
|
||||||
|
- Icon selection component
|
||||||
|
- Menu search function
|
||||||
|
- Added results page
|
||||||
|
- Extended `element-plus` timeline component
|
||||||
|
- Extended `element-plus` tree component to support connecting lines
|
||||||
|
- Add tree selector, support single and multiple selection
|
||||||
|
|
||||||
|
### 🍏 Perf
|
||||||
|
|
||||||
|
- Optimized the error page UI
|
||||||
|
- Optimize the internationalization function
|
||||||
|
- Optimized routing `rank` sorting, compatible with the case where the value of the `rank` field in the routing `meta` is `null`
|
||||||
|
|
||||||
|
### 🐞 Bug fixes
|
||||||
|
|
||||||
|
- Fixed the situation where the menu expands and folds will freeze on some computers
|
||||||
|
|
||||||
|
# 3.1.0 (2022-3-3)
|
||||||
|
|
||||||
|
### 🎫 Feat
|
||||||
|
|
||||||
|
- iframe supports dynamic loading
|
||||||
|
- Watermark example
|
||||||
|
- Print examples (pictures, tables, echarts)
|
||||||
|
- Add running and packaging information, use `lodash-unified` to replace `lodash-es`, `lodash-unified` supports `ESM` and is compatible with `CJS`
|
||||||
|
|
||||||
|
### 🐞 Bug fixes
|
||||||
|
|
||||||
|
- Fixed jumping to another menu page alone in one menu page, the routing page jumped but the tab page was not displayed
|
||||||
|
- Fixed the route that returns dynamic level 3 and above in the background, and the menu does not correspond to the page
|
||||||
|
|
||||||
|
# 3.0 (2022-2-14)
|
||||||
|
|
||||||
|
### 🎫 Feat
|
||||||
|
|
||||||
|
- Added mix navigation
|
||||||
|
|
||||||
|
### 🐞 Bug fixes
|
||||||
|
|
||||||
|
- Fix tab page bug
|
||||||
|
|
||||||
|
# 2.9.0 (2022-2-5)
|
||||||
|
|
||||||
|
### 🎫 Feat
|
||||||
|
|
||||||
|
- Added package size analysis, command `pnpm report`
|
||||||
|
|
||||||
|
### 🍏 Perf
|
||||||
|
|
||||||
|
- Use `iconify` to introduce icons on demand, optimize icon size, and reduce network requests
|
||||||
|
- Optimize the route, the route can not pass `showLink: true`, it is displayed by default
|
||||||
|
|
||||||
|
# 2.8.5 (2022-1-21)
|
||||||
|
|
||||||
|
### 🎫 Feat
|
||||||
|
|
||||||
|
- Added `WindiCSS` support
|
||||||
|
- Add online environment remove console plugin `vite-plugin-remove-console`
|
||||||
|
|
||||||
|
### ✔️ refactor
|
||||||
|
|
||||||
|
- Replace `@element-plus/icons-vue` with `@iconify-icons/ep`
|
||||||
|
|
||||||
|
# 2.8.0(2022-1-4)
|
||||||
|
|
||||||
|
### 🎫 Feat
|
||||||
|
|
||||||
|
-Added dark theme
|
||||||
|
-Add element-plus custom theme
|
||||||
|
-Add guide page
|
||||||
|
|
||||||
|
### 🍏 Perf
|
||||||
|
|
||||||
|
-Optimize internationalization, compatible with the vscode plug-in i18n Ally smart reminder
|
||||||
|
-Optimize the back-end return routing structure
|
||||||
|
-Optimize local storage, with four built-in buttons `responsive-configure`, `responsive-locale`, `responsive-layout`, `responsive-tags`, which are basic configuration, international configuration, layout configuration, and tab persistent configuration
|
||||||
|
|
||||||
|
# 2.7.0(2021-12-18)
|
||||||
|
|
||||||
|
### 🎫 Feat
|
||||||
|
|
||||||
|
- New tab reuse
|
||||||
|
- New message reminder template
|
||||||
|
- Added front-end menu tree structure example
|
||||||
|
- Refactor routing, optimize permissions modules, and bring a more convenient experience
|
||||||
|
- Refactor the env environment and http request to bring a more convenient experience
|
||||||
|
- Currently, the tabs of the platform are forced to associate with local storage. The next step is to put the tabs in the memory by default and support configurable persistent tabs
|
||||||
|
- Navigation menu icons support fontawesome, iconfont, remixicon, element-plus/icons, custom svg
|
||||||
|
- Update font-awesome to version 5.0, because versions below 5.0 are no longer officially maintained, but the platform will still be compatible with font-awesome4 version
|
||||||
|
|
||||||
|
### 🍏 Perf
|
||||||
|
|
||||||
|
- Optimize the tab page to bring a better interactive experience
|
||||||
|
- Routing title supports direct writing in Chinese, which can be separated from internationalization
|
||||||
|
- Route history mode is read from env and supports base parameter
|
||||||
|
- Packaged files provide traditional browser compatibility support, configure VITE_LEGACY to true
|
||||||
|
|
||||||
|
# 2.6.0(2021-11-10)
|
||||||
|
|
||||||
|
### 🎫 Feat
|
||||||
|
|
||||||
|
- Refactored navigation theme color, supports multiple color schemes
|
||||||
|
- Refactored login page, illustration style
|
||||||
|
|
||||||
|
### 🍏 Perf
|
||||||
|
|
||||||
|
- Optimize the navigation style
|
||||||
|
- Eliminate strong navigation dependence on vxe-table
|
||||||
|
- Synchronously update element-plus, replace Font Icon with SVG Icon
|
||||||
|
|
||||||
# 2.1.0(2021-10-14)
|
# 2.1.0(2021-10-14)
|
||||||
|
|
||||||
### 🎫 Feat
|
### 🎫 Feat
|
||||||
|
|||||||
@@ -1,3 +1,199 @@
|
|||||||
|
# 3.4.5 (2022-8-22)
|
||||||
|
|
||||||
|
### 🐞 Bug fixes
|
||||||
|
|
||||||
|
- 修复本地响应式存储对象设置问题
|
||||||
|
|
||||||
|
# 3.4.0 (2022-8-22)
|
||||||
|
|
||||||
|
### 🍏 Perf
|
||||||
|
|
||||||
|
- 优化路由
|
||||||
|
- 优化移动端兼容性
|
||||||
|
- 优化路由传参(`query`、`params` 方式刷新页面不需要再开启标签页缓存也能保留参数在`url`和`标签页`上)
|
||||||
|
|
||||||
|
# 3.3.5 (2022-8-19)
|
||||||
|
|
||||||
|
### 🎫 Feat
|
||||||
|
|
||||||
|
- 将 `element-plus` 的 `Table` 二次封装到[@pureadmin/table](https://github.com/xiaoxian521/pure-admin-table),提供灵活的配置项并集成到平台里
|
||||||
|
- 将 `element-plus` 的 `Descriptions` 二次封装到[@pureadmin/descriptions](https://github.com/xiaoxian521/pure-admin-descriptions),提供灵活的配置项并集成到平台里
|
||||||
|
- 将平台的大部分工具以及 hooks 都集中到[@pureadmin/utils](https://pure-admin-utils-docs.vercel.app/),并删除集中到这个库里的代码,减少平台体积
|
||||||
|
- 添加[unplugin-vue-define-options](https://www.npmjs.com/package/unplugin-vue-define-options)插件,页面可直接写 `defineOptions({name: 自定义名称})`
|
||||||
|
- 添加项目文件、语言分析工具 [cloc](https://www.npmjs.com/package/cloc)
|
||||||
|
- 添加登陆页国际化
|
||||||
|
- 添加完整路由配置表类型声明
|
||||||
|
- 添加虚拟列表页面 demo
|
||||||
|
- 添加 `PDF` 预览页面 demo
|
||||||
|
- 添加导出 `execl` 页面 demo
|
||||||
|
- 添加无 `Layout` 的空白页面 demo
|
||||||
|
|
||||||
|
### ✔️ refactor
|
||||||
|
|
||||||
|
- 重构主题色,适配 `element-plus` 暗黑模式(同时也解决了 `3.3.0` 及更低版本中同样的元素 `css` 被多次覆盖,导致样式不好调试的问题)
|
||||||
|
- 重构路由重置功能
|
||||||
|
|
||||||
|
### 🍏 Perf
|
||||||
|
|
||||||
|
- 兼容项目存放目录以中文命名,但我们真心不推荐中文命名,因为可能某个库没有对中文路径做转义处理,导致项目奔溃
|
||||||
|
- 优化接口类型
|
||||||
|
|
||||||
|
### 🐞 Bug fixes
|
||||||
|
|
||||||
|
- 修复路由 `showlink` 为 `false` 的异步路由,刷新后不显示
|
||||||
|
- 修复当没有 `icon` 时,垂直导航菜单折叠后文字被隐藏
|
||||||
|
|
||||||
|
# 3.3.0 (2022-5-11)
|
||||||
|
|
||||||
|
### 🎫 Feat
|
||||||
|
|
||||||
|
- 添加用户管理页面 demo
|
||||||
|
- 添加角色管理页面 demo
|
||||||
|
- 添加部门管理页面 demo
|
||||||
|
- 添加卡片列表页面 demo
|
||||||
|
- 集成表单设计器
|
||||||
|
- 新增`PPT`demo
|
||||||
|
- 在功能菜单中新增防抖截流 demo
|
||||||
|
- 升级`wangeditorV5`(并支持国际化和自定义主题)
|
||||||
|
- 集成`tauri`版本
|
||||||
|
- 新增条形码功能
|
||||||
|
- 新增二维码功能
|
||||||
|
- 使用`element-plus`中的`Cascader`级联选择器编写中国省市区三级、二级联动 demo
|
||||||
|
- 集成`Swiper`插件
|
||||||
|
- 路由支持传`component`,代表组件路径
|
||||||
|
- 添加预发布打包模式
|
||||||
|
- 添加关闭某个标签的[hooks](https://github.com/xiaoxian521/vue-pure-admin/commit/5e8723a031923e79f507e5a17151d3bd88a51523)
|
||||||
|
|
||||||
|
### ✔️ refactor
|
||||||
|
|
||||||
|
- 重构登录页,更偏向实际业务场景
|
||||||
|
- 使用`unocss`替换`windicss`,`unocss`开发环境下性能更好,没有内存泄露,而且`api`使用上兼容`windicss`
|
||||||
|
|
||||||
|
### 🍏 Perf
|
||||||
|
|
||||||
|
- 优化平台的`split-pane`组件样式
|
||||||
|
- 优化国际化,路由不再传`i18n`字段,平台自动读取根目录`locales`文件夹下文件进行国际化匹配
|
||||||
|
- 优化图标选择器
|
||||||
|
- 优化`layout`显示用户信息[commit](https://github.com/xiaoxian521/vue-pure-admin/commit/56f9dc85e7fbe0637605c43577c794de9f8968aa)
|
||||||
|
|
||||||
|
### 🐞 Bug fixes
|
||||||
|
|
||||||
|
- 修复路由初始化问题(Cannot access 'constantRoutes' before initialization)
|
||||||
|
|
||||||
|
# 3.2.0 (2022-3-22)
|
||||||
|
|
||||||
|
### 🎫 Feat
|
||||||
|
|
||||||
|
- 图标选择组件
|
||||||
|
- 菜单搜索功能
|
||||||
|
- 添加结果页面
|
||||||
|
- 扩展`element-plus`时间线组件
|
||||||
|
- 扩展`element-plus`树组件,支持连接线
|
||||||
|
- 添加树形选择器,支持单选和多选
|
||||||
|
|
||||||
|
### 🍏 Perf
|
||||||
|
|
||||||
|
- 优化错误页面 UI
|
||||||
|
- 优化国际化功能
|
||||||
|
- 优化路由`rank`排序,兼容路由`meta`中`rank`字段值为`null`的情况
|
||||||
|
|
||||||
|
### 🐞 Bug fixes
|
||||||
|
|
||||||
|
- 修复菜单展开折叠在部分电脑出现卡顿的情况
|
||||||
|
|
||||||
|
# 3.1.0 (2022-3-3)
|
||||||
|
|
||||||
|
### 🎫 Feat
|
||||||
|
|
||||||
|
- iframe 支持动态加载
|
||||||
|
- 水印示例
|
||||||
|
- 打印示例(图片、表格、echarts)
|
||||||
|
- 添加运行、打包信息, 使用`lodash-unified`替换`lodash-es`,`lodash-unified`支持`ESM`同时兼容`CJS`
|
||||||
|
|
||||||
|
### 🐞 Bug fixes
|
||||||
|
|
||||||
|
- 修复在一个菜单页面内单独跳转到另一个菜单页面,路由页面跳转了但是标签页不显示的情况
|
||||||
|
- 修复后台返回动态三级及以上的路由,出现菜单与页面不对应的情况
|
||||||
|
|
||||||
|
# 3.0 (2022-2-14)
|
||||||
|
|
||||||
|
### 🎫 Feat
|
||||||
|
|
||||||
|
- 添加混合导航
|
||||||
|
|
||||||
|
### 🐞 Bug fixes
|
||||||
|
|
||||||
|
- 修复标签页 bug
|
||||||
|
|
||||||
|
# 2.9.0(2022-2-5)
|
||||||
|
|
||||||
|
### 🎫 Feat
|
||||||
|
|
||||||
|
- 添加打包大小分析,命令`pnpm report`
|
||||||
|
|
||||||
|
### 🍏 Perf
|
||||||
|
|
||||||
|
- 采用`iconify`按需引入图标,优化图标大小,减少网络请求
|
||||||
|
- 优化路由,路由可不传`showLink: true`,默认显示
|
||||||
|
|
||||||
|
# 2.8.5(2022-1-21)
|
||||||
|
|
||||||
|
### 🎫 Feat
|
||||||
|
|
||||||
|
- 添加 `WindiCSS` 支持
|
||||||
|
- 添加线上环境删 console 插件`vite-plugin-remove-console`
|
||||||
|
|
||||||
|
### ✔️ refactor
|
||||||
|
|
||||||
|
- 使用`@iconify-icons/ep`替换`@element-plus/icons-vue`
|
||||||
|
|
||||||
|
# 2.8.0(2022-1-4)
|
||||||
|
|
||||||
|
### 🎫 Feat
|
||||||
|
|
||||||
|
- 添加暗黑主题
|
||||||
|
- 添加 element-plus 自定义主题
|
||||||
|
- 添加引导页
|
||||||
|
|
||||||
|
### 🍏 Perf
|
||||||
|
|
||||||
|
- 优化国际化,兼容 vscode 插件 i18n Ally 智能提醒
|
||||||
|
- 优化后端返回路由结构
|
||||||
|
- 优化本地存储,内置四个键`responsive-configure`、`responsive-locale`、`responsive-layout`、`responsive-tags`,分别为基本配置、国际化配置、布局配置、标签页持久化配置
|
||||||
|
|
||||||
|
# 2.7.0(2021-12-18)
|
||||||
|
|
||||||
|
### 🎫 Feat
|
||||||
|
|
||||||
|
- 新增标签页复用
|
||||||
|
- 新增消息提醒模版
|
||||||
|
- 新增前端菜单树结构例子
|
||||||
|
- 重构路由,优化权限模块,带来更方便的体验
|
||||||
|
- 重构 env 环境和 http 请求,带来更方便的体验
|
||||||
|
- 目前平台的标签页强制关联了本地存储,下一步标签页默认放到内存中并支持可配置持久化标签页
|
||||||
|
- 导航菜单图标支持 fontawesome、iconfont、remixicon、element-plus/icons、自定义 svg
|
||||||
|
- 更新 font-awesome 到 5.0 版本,因为 5.0 以下的版本官方不再维护,但平台依旧会兼容 font-awesome4 版本
|
||||||
|
|
||||||
|
### 🍏 Perf
|
||||||
|
|
||||||
|
- 优化标签页,带来更好的交互体验
|
||||||
|
- 路由 title 支持直接写中文,可脱离国际化
|
||||||
|
- 路由历史模式从 env 读取并支持 base 参数
|
||||||
|
- 打包后的文件提供传统浏览器兼容性支持,配置 VITE_LEGACY 为 true
|
||||||
|
|
||||||
|
# 2.6.0(2021-11-10)
|
||||||
|
|
||||||
|
### 🎫 Feat
|
||||||
|
|
||||||
|
- 重构导航主题色,支持多种配色
|
||||||
|
- 重构登录页,插画风格
|
||||||
|
|
||||||
|
### 🍏 Perf
|
||||||
|
|
||||||
|
- 优化导航样式
|
||||||
|
- 剔除导航强依赖 vxe-table
|
||||||
|
- 同步更新 element-plus,使用 SVG Icon 替换 Font Icon
|
||||||
|
|
||||||
# 2.1.0(2021-10-14)
|
# 2.1.0(2021-10-14)
|
||||||
|
|
||||||
### 🎫 Feat
|
### 🎫 Feat
|
||||||
|
|||||||
2
LICENSE
@@ -1,6 +1,6 @@
|
|||||||
MIT License
|
MIT License
|
||||||
|
|
||||||
Copyright (c) 2021 啝裳
|
Copyright (c) 2022 啝裳
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
of this software and associated documentation files (the "Software"), to deal
|
of this software and associated documentation files (the "Software"), to deal
|
||||||
|
|||||||
@@ -1,37 +1,49 @@
|
|||||||
<h1>vue-pure-admin</h1>
|
<h1>vue-pure-admin</h1>
|
||||||
|
|
||||||
[](LICENSE)
|

|
||||||
|

|
||||||
|

|
||||||
|
|
||||||
**English** | [中文](./README.md)
|
**English** | [中文](./README.md)
|
||||||
|
|
||||||
## Introduction
|
## Introduction
|
||||||
|
|
||||||
vue-pure-admin is a free and open source middle and back-end template. Using the latest `vue3`, `vite2`, `TypeScript`, `Element-Plus` and other mainstream technology development, the out-of-the-box middle and back-end front-end solutions can also be used for learning reference.
|
vue-pure-admin is a free and open source middle and back-end template. Using the latest `vue3` `vite2` `Element-Plus` `TypeScript` and other mainstream technology development, the out-of-the-box middle and back-end front-end solutions can also be used for learning reference.
|
||||||
|
|
||||||
|
## Supporting Video
|
||||||
|
|
||||||
|
- [Click Watch Tutorial](https://www.bilibili.com/video/BV1534y1S7HV)
|
||||||
|
- [Click Watch UI Design](https://www.bilibili.com/video/BV17g411T7rq)
|
||||||
|
|
||||||
|
## Docs
|
||||||
|
|
||||||
|
- [Click Watch Docs](https://pure-admin-doc.vercel.app)
|
||||||
|
|
||||||
|
## Thin
|
||||||
|
|
||||||
|
- [Click Watch Thin](https://github.com/xiaoxian521/pure-admin-thin)
|
||||||
|
|
||||||
|
## Tauri
|
||||||
|
|
||||||
|
- [Click Watch Tauri](https://github.com/xiaoxian521/tauri-pure-admin)
|
||||||
|
|
||||||
## Preview
|
## Preview
|
||||||
|
|
||||||
- [vue-pure-admin](http://yiming_chang.gitee.io/manages)
|
- [vue-pure-admin](https://vue-pure-admin.vercel.app)
|
||||||
|
|
||||||
Click to log in without password
|
|
||||||
|
|
||||||
|
- PC
|
||||||
<p align="center">
|
<p align="center">
|
||||||
<img alt="PureAdmin Logo" width="100%" src="https://p9-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/f5ee80eee1014fb4a53c5bb37574a5f5~tplv-k3u1fbpfcp-watermark.image">
|
<img alt="PureAdmin Logo" width="100%" src="https://p6-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/d45c15ccbe674fe291a4faa528d11eda~tplv-k3u1fbpfcp-zoom-in-crop-mark:3024:0:0:0.awebp?">
|
||||||
<img alt="PureAdmin Logo" width="100%" src="https://p3-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/dec0672a62e141f3b7f626c22ff6c7ef~tplv-k3u1fbpfcp-watermark.image">
|
</p>
|
||||||
<img alt="PureAdmin Logo" width="100%" src="https://p1-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/f586f1353de74b1b88cc9f89fce2146e~tplv-k3u1fbpfcp-watermark.image">
|
|
||||||
<img alt="PureAdmin Logo" width="100%" src="https://p3-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/a28fc0af7ac44e3b8f30469cba4a9993~tplv-k3u1fbpfcp-watermark.image">
|
- DarkMode
|
||||||
<img alt="PureAdmin Logo" width="100%" src="https://p6-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/a17e54329cda4d76aa9c1c4f2a4715d3~tplv-k3u1fbpfcp-watermark.image">
|
<p align="center">
|
||||||
<img alt="PureAdmin Logo" width="100%" src="https://p3-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/d884fb611da74ee0bdc17c29014d0260~tplv-k3u1fbpfcp-watermark.image">
|
<img alt="PureAdmin Logo" width="100%" src="https://p1-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/10a351f0d9c94b90ba3b408a786b9ede~tplv-k3u1fbpfcp-zoom-in-crop-mark:3024:0:0:0.awebp?">
|
||||||
<img alt="PureAdmin Logo" width="100%" src="https://p1-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/abed44ac1f2744e897c28d1689bcb517~tplv-k3u1fbpfcp-watermark.image">
|
</p>
|
||||||
<img alt="PureAdmin Logo" width="100%" src="https://p6-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/cf2f068650f44a0787c699f5a20c75a6~tplv-k3u1fbpfcp-watermark.image">
|
|
||||||
<img alt="PureAdmin Logo" width="100%" src="https://p3-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/73c575dd06474731ad8ab9d853f1ddfd~tplv-k3u1fbpfcp-watermark.image">
|
- Mobile
|
||||||
<img alt="PureAdmin Logo" width="100%" src="https://p9-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/99389b90f5ac4db9b0d61d99dd9a1454~tplv-k3u1fbpfcp-watermark.image">
|
<p align="center">
|
||||||
<img alt="PureAdmin Logo" width="100%" src="https://p3-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/f1546f1c6014446db6c9983934aedc86~tplv-k3u1fbpfcp-watermark.image">
|
<img alt="PureAdmin Logo" width="100%" src="https://p3-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/3061c7b92f6d4cb4bcdf227d966ac696~tplv-k3u1fbpfcp-zoom-in-crop-mark:3024:0:0:0.awebp?">
|
||||||
<img alt="PureAdmin Logo" width="100%" src="https://p6-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/cfb0093b77c34e87b094daaa4304bc2d~tplv-k3u1fbpfcp-watermark.image">
|
|
||||||
<img alt="PureAdmin Logo" width="100%" src="https://p3-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/fe133cc6db3245f9b1b37f231d040550~tplv-k3u1fbpfcp-watermark.image">
|
|
||||||
<img alt="PureAdmin Logo" width="100%" src="https://p1-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/d3110a12d63e4f6fb314e60bf18bdb66~tplv-k3u1fbpfcp-watermark.image">
|
|
||||||
<img alt="PureAdmin Logo" width="100%" src="https://p3-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/45b93ec453e3406a939affe65ddcc803~tplv-k3u1fbpfcp-watermark.image">
|
|
||||||
<img alt="PureAdmin Logo" width="100%" src="https://p1-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/cdc2dc88c1ef4aafbaaade820442c986~tplv-k3u1fbpfcp-watermark.image">
|
|
||||||
<img alt="PureAdmin Logo" width="100%" src="https://p1-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/f4c91b162206485b88cc58a72ff54a01~tplv-k3u1fbpfcp-watermark.image">
|
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
### Use Gitpod
|
### Use Gitpod
|
||||||
@@ -47,7 +59,7 @@ Open the project in Gitpod (free online dev environment for GitHub) and start co
|
|||||||
```bash
|
```bash
|
||||||
git clone https://github.com/xiaoxian521/vue-pure-admin.git
|
git clone https://github.com/xiaoxian521/vue-pure-admin.git
|
||||||
or
|
or
|
||||||
git clone https://github.com.cnpmjs.org/xiaoxian521/vue-pure-admin.git
|
git clone https://gitee.com/yiming_chang/vue-pure-admin.git
|
||||||
```
|
```
|
||||||
|
|
||||||
- Installation dependencies
|
- Installation dependencies
|
||||||
@@ -55,20 +67,20 @@ git clone https://github.com.cnpmjs.org/xiaoxian521/vue-pure-admin.git
|
|||||||
```bash
|
```bash
|
||||||
cd vue-pure-admin
|
cd vue-pure-admin
|
||||||
|
|
||||||
yarn install
|
pnpm install
|
||||||
|
|
||||||
```
|
```
|
||||||
|
|
||||||
- run
|
- run
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
yarn serve
|
pnpm serve
|
||||||
```
|
```
|
||||||
|
|
||||||
- build
|
- build
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
yarn build
|
pnpm build
|
||||||
```
|
```
|
||||||
|
|
||||||
## Change Log
|
## Change Log
|
||||||
@@ -117,20 +129,32 @@ Support modern browsers, not IE
|
|||||||
|
|
||||||
## Maintainer
|
## Maintainer
|
||||||
|
|
||||||
[xiaoxian521](https://github.com/xiaoxian521)
|
[xiaoxian521](https://github.com/xiaoxian521)、[Ten-K](https://github.com/Ten-K)
|
||||||
|
|
||||||
## Donate
|
## Donate
|
||||||
|
|
||||||
If you think this project is helpful to you, you can help the author buy a cup of coffee to show your support!
|
If you think this project is helpful to you, you can help the author buy a glass of juice 🍹 Show your support
|
||||||
|
|
||||||

|
<img src="https://p9-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/f69bf13c5b854ed5b699807cafa0e3ce~tplv-k3u1fbpfcp-zoom-in-crop-mark:1304:0:0:0.awebp?" width="150px" height="150px" />
|
||||||
|
|
||||||
## Exchange Group
|
|
||||||
|
|
||||||
Please scan the code to join the WeChat exchange group, if you have any questions, you can communicate in the group!
|
|
||||||
|
|
||||||

|
|
||||||
|
|
||||||
## License
|
## License
|
||||||
|
|
||||||
|
In principle, no fees and copyrights are charged, and you can use it with confidence, but if you need secondary open source, please contact the author for permission!
|
||||||
|
|
||||||
[MIT © xiaoxian521-2020](./LICENSE)
|
[MIT © xiaoxian521-2020](./LICENSE)
|
||||||
|
|
||||||
|
## Backers
|
||||||
|
|
||||||
|
Thank you very much for your support, I believe the project will get better and better :heart:
|
||||||
|
|
||||||
|
| xueyuheng | taolei1990 | hang-kim | madwolfcrazy | limuen | BenLakes |
|
||||||
|
| :--------------------------------------------------------------------------------------------------------------------------------------: | :---------------------------------------------------------------------------------------------------------------------------------------: | :-------------------------------------------------------------------------------------------------------------------------------------: | :---------------------------------------------------------------------------------------------------------------------------------------: | :-----------------------------------------------------------------------------------------------------------------------------------: | :-------------------------------------------------------------------------------------------------------------------------------------: |
|
||||||
|
| <a href="https://github.com/xueyuheng"><img src="https://avatars.githubusercontent.com/u/48202935?v=4" width="60px" height="60px" /></a> | <a href="https://github.com/taolei1990"><img src="https://avatars.githubusercontent.com/u/23173640?v=4" width="60px" height="60px" /></a> | <a href="https://github.com/hang-kim"><img src="https://avatars.githubusercontent.com/u/52914259?v=4" width="60px" height="60px" /></a> | <a href="https://github.com/madwolfcrazy"><img src="https://avatars.githubusercontent.com/u/223671?v=4" width="60px" height="60px" /></a> | <a href="https://github.com/limuen"><img src="https://avatars.githubusercontent.com/u/31790606?v=4" width="60px" height="60px" /></a> | <a href="https://github.com/BenLakes"><img src="https://avatars.githubusercontent.com/u/15206046?v=4" width="60px" height="60px" /></a> |
|
||||||
|
| mollerzhu | TLovers | cnyyk | | | |
|
||||||
|
| <a href="https://github.com/mollerzhu"><img src="https://avatars.githubusercontent.com/u/49627902?v=4" width="60px" height="60px" /></a> | <a href="https://github.com/TLovers"><img src="https://avatars.githubusercontent.com/u/26561694?v=4" width="60px" height="60px" /></a> | <a href="https://github.com/cnyyk"><img src="https://avatars.githubusercontent.com/u/275233?v=4" width="60px" height="60px" /></a> | | | |
|
||||||
|
|
||||||
|
## Contributors
|
||||||
|
|
||||||
|
This project exists thanks to all the people who contribute :heart:
|
||||||
|
|
||||||
|
<a href="https://github.com/xiaoxian521/vue-pure-admin/graphs/contributors"><img src="https://contrib.rocks/image?repo=xiaoxian521/vue-pure-admin" /></a>
|
||||||
|
|||||||
96
README.md
@@ -1,37 +1,49 @@
|
|||||||
<h1>vue-pure-admin</h1>
|
<h1>vue-pure-admin</h1>
|
||||||
|
|
||||||
[](LICENSE)
|

|
||||||
|

|
||||||
|

|
||||||
|
|
||||||
**中文** | [English](./README.en-US.md)
|
**中文** | [English](./README.en-US.md)
|
||||||
|
|
||||||
## 简介
|
## 简介
|
||||||
|
|
||||||
vue-pure-admin 是一个免费开源的中后台模版。使用了最新的`vue3`,`vite2`,`TypeScript`,`Element-Plus`等主流技术开发,开箱即用的中后台前端解决方案,也可用于学习参考。
|
vue-pure-admin 是一个免费开源的中后台模版。使用了最新的`vue3` `vite2` `Element-Plus` `TypeScript`等主流技术开发,开箱即用的中后台前端解决方案,也可用于学习参考。
|
||||||
|
|
||||||
|
## 配套视频
|
||||||
|
|
||||||
|
- [点我查看教程](https://www.bilibili.com/video/BV1534y1S7HV)
|
||||||
|
- [点我查看 UI 设计](https://www.bilibili.com/video/BV17g411T7rq)
|
||||||
|
|
||||||
|
## 配套文档
|
||||||
|
|
||||||
|
- [点我查看文档](https://pure-admin-doc.vercel.app)
|
||||||
|
|
||||||
|
## 精简版
|
||||||
|
|
||||||
|
- [点我查看精简版](https://github.com/xiaoxian521/pure-admin-thin)
|
||||||
|
|
||||||
|
## Tauri 版
|
||||||
|
|
||||||
|
- [点我查看 Tauri 版](https://github.com/xiaoxian521/tauri-pure-admin)
|
||||||
|
|
||||||
## 预览
|
## 预览
|
||||||
|
|
||||||
- [vue-pure-admin](http://yiming_chang.gitee.io/manages)
|
- [vue-pure-admin](https://vue-pure-admin.vercel.app)
|
||||||
|
|
||||||
点击免密登录
|
|
||||||
|
|
||||||
|
- PC 端
|
||||||
<p align="center">
|
<p align="center">
|
||||||
<img alt="PureAdmin Logo" width="100%" src="https://p9-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/f5ee80eee1014fb4a53c5bb37574a5f5~tplv-k3u1fbpfcp-watermark.image">
|
<img alt="PureAdmin Logo" width="100%" src="https://p6-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/d45c15ccbe674fe291a4faa528d11eda~tplv-k3u1fbpfcp-zoom-in-crop-mark:3024:0:0:0.awebp?">
|
||||||
<img alt="PureAdmin Logo" width="100%" src="https://p3-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/dec0672a62e141f3b7f626c22ff6c7ef~tplv-k3u1fbpfcp-watermark.image">
|
</p>
|
||||||
<img alt="PureAdmin Logo" width="100%" src="https://p1-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/f586f1353de74b1b88cc9f89fce2146e~tplv-k3u1fbpfcp-watermark.image">
|
|
||||||
<img alt="PureAdmin Logo" width="100%" src="https://p3-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/a28fc0af7ac44e3b8f30469cba4a9993~tplv-k3u1fbpfcp-watermark.image">
|
- 暗黑模式
|
||||||
<img alt="PureAdmin Logo" width="100%" src="https://p6-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/a17e54329cda4d76aa9c1c4f2a4715d3~tplv-k3u1fbpfcp-watermark.image">
|
<p align="center">
|
||||||
<img alt="PureAdmin Logo" width="100%" src="https://p3-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/d884fb611da74ee0bdc17c29014d0260~tplv-k3u1fbpfcp-watermark.image">
|
<img alt="PureAdmin Logo" width="100%" src="https://p1-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/10a351f0d9c94b90ba3b408a786b9ede~tplv-k3u1fbpfcp-zoom-in-crop-mark:3024:0:0:0.awebp?">
|
||||||
<img alt="PureAdmin Logo" width="100%" src="https://p1-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/abed44ac1f2744e897c28d1689bcb517~tplv-k3u1fbpfcp-watermark.image">
|
</p>
|
||||||
<img alt="PureAdmin Logo" width="100%" src="https://p6-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/cf2f068650f44a0787c699f5a20c75a6~tplv-k3u1fbpfcp-watermark.image">
|
|
||||||
<img alt="PureAdmin Logo" width="100%" src="https://p3-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/73c575dd06474731ad8ab9d853f1ddfd~tplv-k3u1fbpfcp-watermark.image">
|
- 移动端
|
||||||
<img alt="PureAdmin Logo" width="100%" src="https://p9-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/99389b90f5ac4db9b0d61d99dd9a1454~tplv-k3u1fbpfcp-watermark.image">
|
<p align="center">
|
||||||
<img alt="PureAdmin Logo" width="100%" src="https://p3-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/f1546f1c6014446db6c9983934aedc86~tplv-k3u1fbpfcp-watermark.image">
|
<img alt="PureAdmin Logo" width="100%" src="https://p3-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/3061c7b92f6d4cb4bcdf227d966ac696~tplv-k3u1fbpfcp-zoom-in-crop-mark:3024:0:0:0.awebp?">
|
||||||
<img alt="PureAdmin Logo" width="100%" src="https://p6-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/cfb0093b77c34e87b094daaa4304bc2d~tplv-k3u1fbpfcp-watermark.image">
|
|
||||||
<img alt="PureAdmin Logo" width="100%" src="https://p3-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/fe133cc6db3245f9b1b37f231d040550~tplv-k3u1fbpfcp-watermark.image">
|
|
||||||
<img alt="PureAdmin Logo" width="100%" src="https://p1-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/d3110a12d63e4f6fb314e60bf18bdb66~tplv-k3u1fbpfcp-watermark.image">
|
|
||||||
<img alt="PureAdmin Logo" width="100%" src="https://p3-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/45b93ec453e3406a939affe65ddcc803~tplv-k3u1fbpfcp-watermark.image">
|
|
||||||
<img alt="PureAdmin Logo" width="100%" src="https://p1-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/cdc2dc88c1ef4aafbaaade820442c986~tplv-k3u1fbpfcp-watermark.image">
|
|
||||||
<img alt="PureAdmin Logo" width="100%" src="https://p1-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/f4c91b162206485b88cc58a72ff54a01~tplv-k3u1fbpfcp-watermark.image">
|
|
||||||
</p>
|
</p>
|
||||||
|
|
||||||
### 使用 Gitpod
|
### 使用 Gitpod
|
||||||
@@ -47,7 +59,7 @@ vue-pure-admin 是一个免费开源的中后台模版。使用了最新的`vue3
|
|||||||
```bash
|
```bash
|
||||||
git clone https://github.com/xiaoxian521/vue-pure-admin.git
|
git clone https://github.com/xiaoxian521/vue-pure-admin.git
|
||||||
or
|
or
|
||||||
git clone https://github.com.cnpmjs.org/xiaoxian521/vue-pure-admin.git
|
git clone https://gitee.com/yiming_chang/vue-pure-admin.git
|
||||||
```
|
```
|
||||||
|
|
||||||
- 安装依赖
|
- 安装依赖
|
||||||
@@ -55,20 +67,20 @@ git clone https://github.com.cnpmjs.org/xiaoxian521/vue-pure-admin.git
|
|||||||
```bash
|
```bash
|
||||||
cd vue-pure-admin
|
cd vue-pure-admin
|
||||||
|
|
||||||
yarn install
|
pnpm install
|
||||||
|
|
||||||
```
|
```
|
||||||
|
|
||||||
- 运行
|
- 运行
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
yarn serve
|
pnpm serve
|
||||||
```
|
```
|
||||||
|
|
||||||
- 打包
|
- 打包
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
yarn build
|
pnpm build
|
||||||
```
|
```
|
||||||
|
|
||||||
## 更新日志
|
## 更新日志
|
||||||
@@ -117,20 +129,38 @@ yarn build
|
|||||||
|
|
||||||
## 维护者
|
## 维护者
|
||||||
|
|
||||||
[xiaoxian521](https://github.com/xiaoxian521)
|
[xiaoxian521](https://github.com/xiaoxian521)、[Ten-K](https://github.com/Ten-K)
|
||||||
|
|
||||||
## 捐赠
|
## 捐赠
|
||||||
|
|
||||||
如果你觉得这个项目对你有帮助,你可以帮作者买一杯咖啡表示支持!
|
如果你觉得这个项目对您有帮助,可以帮作者买一杯果汁 🍹 表示支持
|
||||||
|
|
||||||

|
<img src="https://p9-juejin.byteimg.com/tos-cn-i-k3u1fbpfcp/f69bf13c5b854ed5b699807cafa0e3ce~tplv-k3u1fbpfcp-zoom-in-crop-mark:1304:0:0:0.awebp?" width="150px" height="150px" />
|
||||||
|
|
||||||
## 交流群
|
## QQ 交流群
|
||||||
|
|
||||||
请扫码加入微信交流群,有问题可以在群里沟通!
|
一群已满,下面是二群,群里严禁`黄`、`赌`、`毒`、`vpn`等违法行为!
|
||||||
|
|
||||||

|
<img src="https://pure-admin-doc.vercel.app/img/support/qq.png" width="150px" height="225px" />
|
||||||
|
|
||||||
## License
|
## 许可证
|
||||||
|
|
||||||
|
原则上不收取任何费用及版权,可以放心使用,不过如需二次开源(比如用此平台二次开发并开源)请联系作者获取许可!
|
||||||
|
|
||||||
[MIT © xiaoxian521-2020](./LICENSE)
|
[MIT © xiaoxian521-2020](./LICENSE)
|
||||||
|
|
||||||
|
## 捐赠者
|
||||||
|
|
||||||
|
非常感谢你们的支持,相信项目会越来越好 :heart:
|
||||||
|
|
||||||
|
| xueyuheng | taolei1990 | hang-kim | madwolfcrazy | limuen | BenLakes |
|
||||||
|
| :--------------------------------------------------------------------------------------------------------------------------------------: | :---------------------------------------------------------------------------------------------------------------------------------------: | :-------------------------------------------------------------------------------------------------------------------------------------: | :---------------------------------------------------------------------------------------------------------------------------------------: | :-----------------------------------------------------------------------------------------------------------------------------------: | :-------------------------------------------------------------------------------------------------------------------------------------: |
|
||||||
|
| <a href="https://github.com/xueyuheng"><img src="https://avatars.githubusercontent.com/u/48202935?v=4" width="60px" height="60px" /></a> | <a href="https://github.com/taolei1990"><img src="https://avatars.githubusercontent.com/u/23173640?v=4" width="60px" height="60px" /></a> | <a href="https://github.com/hang-kim"><img src="https://avatars.githubusercontent.com/u/52914259?v=4" width="60px" height="60px" /></a> | <a href="https://github.com/madwolfcrazy"><img src="https://avatars.githubusercontent.com/u/223671?v=4" width="60px" height="60px" /></a> | <a href="https://github.com/limuen"><img src="https://avatars.githubusercontent.com/u/31790606?v=4" width="60px" height="60px" /></a> | <a href="https://github.com/BenLakes"><img src="https://avatars.githubusercontent.com/u/15206046?v=4" width="60px" height="60px" /></a> |
|
||||||
|
| mollerzhu | TLovers | cnyyk | | | |
|
||||||
|
| <a href="https://github.com/mollerzhu"><img src="https://avatars.githubusercontent.com/u/49627902?v=4" width="60px" height="60px" /></a> | <a href="https://github.com/TLovers"><img src="https://avatars.githubusercontent.com/u/26561694?v=4" width="60px" height="60px" /></a> | <a href="https://github.com/cnyyk"><img src="https://avatars.githubusercontent.com/u/275233?v=4" width="60px" height="60px" /></a> | | | |
|
||||||
|
|
||||||
|
## 贡献者
|
||||||
|
|
||||||
|
这个项目的存在感谢所有做出贡献的人 :heart:
|
||||||
|
|
||||||
|
<a href="https://github.com/xiaoxian521/vue-pure-admin/graphs/contributors"><img src="https://contrib.rocks/image?repo=xiaoxian521/vue-pure-admin" /></a>
|
||||||
|
|||||||
@@ -1,6 +0,0 @@
|
|||||||
const productPlugins = [];
|
|
||||||
process.env.NODE_ENV === "production" &&
|
|
||||||
productPlugins.push("transform-remove-console");
|
|
||||||
module.exports = {
|
|
||||||
plugins: [...productPlugins]
|
|
||||||
};
|
|
||||||
@@ -1,5 +1,14 @@
|
|||||||
|
// 处理环境变量
|
||||||
const warpperEnv = (envConf: Recordable): ViteEnv => {
|
const warpperEnv = (envConf: Recordable): ViteEnv => {
|
||||||
const ret: any = {};
|
// 此处为默认值,无需修改
|
||||||
|
const ret: ViteEnv = {
|
||||||
|
VITE_PORT: 8848,
|
||||||
|
VITE_PUBLIC_PATH: "",
|
||||||
|
VITE_PROXY_DOMAIN: "",
|
||||||
|
VITE_PROXY_DOMAIN_REAL: "",
|
||||||
|
VITE_ROUTER_HISTORY: "",
|
||||||
|
VITE_LEGACY: false
|
||||||
|
};
|
||||||
|
|
||||||
for (const envName of Object.keys(envConf)) {
|
for (const envName of Object.keys(envConf)) {
|
||||||
let realName = envConf[envName].replace(/\\n/g, "\n");
|
let realName = envConf[envName].replace(/\\n/g, "\n");
|
||||||
@@ -9,13 +18,6 @@ const warpperEnv = (envConf: Recordable): ViteEnv => {
|
|||||||
if (envName === "VITE_PORT") {
|
if (envName === "VITE_PORT") {
|
||||||
realName = Number(realName);
|
realName = Number(realName);
|
||||||
}
|
}
|
||||||
if (envName === "VITE_PROXY" && realName) {
|
|
||||||
try {
|
|
||||||
realName = JSON.parse(realName.replace(/'/g, '"'));
|
|
||||||
} catch (error) {
|
|
||||||
realName = "";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
ret[envName] = realName;
|
ret[envName] = realName;
|
||||||
if (typeof realName === "string") {
|
if (typeof realName === "string") {
|
||||||
process.env[envName] = realName;
|
process.env[envName] = realName;
|
||||||
@@ -25,8 +27,15 @@ const warpperEnv = (envConf: Recordable): ViteEnv => {
|
|||||||
}
|
}
|
||||||
return ret;
|
return ret;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// 跨域代理重写
|
||||||
|
const regExps = (value: string, reg: string): string => {
|
||||||
|
return value.replace(new RegExp(`^${reg}`, "g"), "");
|
||||||
|
};
|
||||||
|
|
||||||
|
// 环境变量
|
||||||
const loadEnv = (): ViteEnv => {
|
const loadEnv = (): ViteEnv => {
|
||||||
return import.meta.env;
|
return import.meta.env;
|
||||||
};
|
};
|
||||||
|
|
||||||
export { loadEnv, warpperEnv };
|
export { warpperEnv, regExps, loadEnv };
|
||||||
50
build/info.ts
Normal file
@@ -0,0 +1,50 @@
|
|||||||
|
import type { Plugin } from "vite";
|
||||||
|
import dayjs, { Dayjs } from "dayjs";
|
||||||
|
import duration from "dayjs/plugin/duration";
|
||||||
|
import { green, blue, bold } from "picocolors";
|
||||||
|
import { getPackageSize } from "@pureadmin/utils";
|
||||||
|
dayjs.extend(duration);
|
||||||
|
|
||||||
|
export function viteBuildInfo(): Plugin {
|
||||||
|
let config: { command: string };
|
||||||
|
let startTime: Dayjs;
|
||||||
|
let endTime: Dayjs;
|
||||||
|
return {
|
||||||
|
name: "vite:buildInfo",
|
||||||
|
configResolved(resolvedConfig: { command: string }) {
|
||||||
|
config = resolvedConfig;
|
||||||
|
},
|
||||||
|
buildStart() {
|
||||||
|
console.log(
|
||||||
|
bold(
|
||||||
|
green(
|
||||||
|
`👏欢迎使用${blue(
|
||||||
|
"[vue-pure-admin]"
|
||||||
|
)},如果您感觉不错,记得点击后面链接给个star哦💖 https://github.com/xiaoxian521/vue-pure-admin`
|
||||||
|
)
|
||||||
|
)
|
||||||
|
);
|
||||||
|
if (config.command === "build") {
|
||||||
|
startTime = dayjs(new Date());
|
||||||
|
}
|
||||||
|
},
|
||||||
|
closeBundle() {
|
||||||
|
if (config.command === "build") {
|
||||||
|
endTime = dayjs(new Date());
|
||||||
|
getPackageSize({
|
||||||
|
callback: (size: string) => {
|
||||||
|
console.log(
|
||||||
|
bold(
|
||||||
|
green(
|
||||||
|
`🎉恭喜打包完成(总用时${dayjs
|
||||||
|
.duration(endTime.diff(startTime))
|
||||||
|
.format("mm分ss秒")},打包后的大小为${size})`
|
||||||
|
)
|
||||||
|
)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
73
build/plugins.ts
Normal file
@@ -0,0 +1,73 @@
|
|||||||
|
import { resolve } from "path";
|
||||||
|
import Unocss from "unocss/vite";
|
||||||
|
import vue from "@vitejs/plugin-vue";
|
||||||
|
import { viteBuildInfo } from "./info";
|
||||||
|
import svgLoader from "vite-svg-loader";
|
||||||
|
import legacy from "@vitejs/plugin-legacy";
|
||||||
|
import vueJsx from "@vitejs/plugin-vue-jsx";
|
||||||
|
import { viteMockServe } from "vite-plugin-mock";
|
||||||
|
import VueI18n from "@intlify/vite-plugin-vue-i18n";
|
||||||
|
import { visualizer } from "rollup-plugin-visualizer";
|
||||||
|
import removeConsole from "vite-plugin-remove-console";
|
||||||
|
import themePreprocessorPlugin from "@pureadmin/theme";
|
||||||
|
import { genScssMultipleScopeVars } from "/@/layout/theme";
|
||||||
|
import DefineOptions from "unplugin-vue-define-options/vite";
|
||||||
|
|
||||||
|
export function getPluginsList(command, VITE_LEGACY) {
|
||||||
|
const prodMock = true;
|
||||||
|
const lifecycle = process.env.npm_lifecycle_event;
|
||||||
|
return [
|
||||||
|
vue(),
|
||||||
|
// https://github.com/intlify/bundle-tools/tree/main/packages/vite-plugin-vue-i18n
|
||||||
|
VueI18n({
|
||||||
|
runtimeOnly: true,
|
||||||
|
compositionOnly: true,
|
||||||
|
include: [resolve("locales/**")]
|
||||||
|
}),
|
||||||
|
// jsx、tsx语法支持
|
||||||
|
vueJsx(),
|
||||||
|
Unocss(),
|
||||||
|
DefineOptions(),
|
||||||
|
// 线上环境删除console
|
||||||
|
removeConsole({ external: ["src/assets/iconfont/iconfont.js"] }),
|
||||||
|
viteBuildInfo(),
|
||||||
|
// 自定义主题
|
||||||
|
themePreprocessorPlugin({
|
||||||
|
scss: {
|
||||||
|
multipleScopeVars: genScssMultipleScopeVars(),
|
||||||
|
// 在生产模式是否抽取独立的主题css文件,extract为true以下属性有效
|
||||||
|
extract: true,
|
||||||
|
// 会选取defaultScopeName对应的主题css文件在html添加link
|
||||||
|
themeLinkTagId: "head",
|
||||||
|
// "head"||"head-prepend" || "body" ||"body-prepend"
|
||||||
|
themeLinkTagInjectTo: "head",
|
||||||
|
// 是否对抽取的css文件内对应scopeName的权重类名移除
|
||||||
|
removeCssScopeName: false
|
||||||
|
}
|
||||||
|
}),
|
||||||
|
// svg组件化支持
|
||||||
|
svgLoader(),
|
||||||
|
// mock支持
|
||||||
|
viteMockServe({
|
||||||
|
mockPath: "mock",
|
||||||
|
localEnabled: command === "serve",
|
||||||
|
prodEnabled: command !== "serve" && prodMock,
|
||||||
|
injectCode: `
|
||||||
|
import { setupProdMockServer } from './mockProdServer';
|
||||||
|
setupProdMockServer();
|
||||||
|
`,
|
||||||
|
logger: false
|
||||||
|
}),
|
||||||
|
// 是否为打包后的文件提供传统浏览器兼容性支持
|
||||||
|
VITE_LEGACY
|
||||||
|
? legacy({
|
||||||
|
targets: ["ie >= 11"],
|
||||||
|
additionalLegacyPolyfills: ["regenerator-runtime/runtime"]
|
||||||
|
})
|
||||||
|
: null,
|
||||||
|
// 打包分析
|
||||||
|
lifecycle === "report"
|
||||||
|
? visualizer({ open: true, brotliSize: true, filename: "report.html" })
|
||||||
|
: null
|
||||||
|
];
|
||||||
|
}
|
||||||
@@ -1,19 +0,0 @@
|
|||||||
type ProxyItem = [string, string];
|
|
||||||
|
|
||||||
type ProxyList = ProxyItem[];
|
|
||||||
|
|
||||||
const regExps = (value: string, reg: string): string => {
|
|
||||||
return value.replace(new RegExp(reg, "g"), "");
|
|
||||||
};
|
|
||||||
|
|
||||||
export function createProxy(list: ProxyList = []) {
|
|
||||||
const ret: any = {};
|
|
||||||
for (const [prefix, target] of list) {
|
|
||||||
ret[prefix] = {
|
|
||||||
target: target,
|
|
||||||
changeOrigin: true,
|
|
||||||
rewrite: (path: string) => regExps(path, prefix)
|
|
||||||
};
|
|
||||||
}
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
149
index.html
@@ -2,11 +2,14 @@
|
|||||||
<html lang="en">
|
<html lang="en">
|
||||||
<head>
|
<head>
|
||||||
<meta charset="UTF-8" />
|
<meta charset="UTF-8" />
|
||||||
|
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1" />
|
||||||
|
<meta name="renderer" content="webkit" />
|
||||||
|
<meta
|
||||||
|
name="viewport"
|
||||||
|
content="width=device-width,initial-scale=1.0,minimum-scale=1.0,maximum-scale=1.0,user-scalable=0"
|
||||||
|
/>
|
||||||
|
<title>vue-pure-admin</title>
|
||||||
<link rel="icon" href="/favicon.ico" />
|
<link rel="icon" href="/favicon.ico" />
|
||||||
<link rel="stylesheet" href="/iconfont.css" />
|
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
|
|
||||||
<title>后台管理系统</title>
|
|
||||||
<script src="/sortable.min.js"></script>
|
|
||||||
<script>
|
<script>
|
||||||
window.process = {};
|
window.process = {};
|
||||||
</script>
|
</script>
|
||||||
@@ -15,106 +18,88 @@
|
|||||||
<body>
|
<body>
|
||||||
<div id="app">
|
<div id="app">
|
||||||
<style>
|
<style>
|
||||||
* {
|
|
||||||
margin: 0;
|
|
||||||
padding: 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
html,
|
html,
|
||||||
body {
|
body,
|
||||||
|
#app {
|
||||||
width: 100%;
|
width: 100%;
|
||||||
height: 100%;
|
height: 100%;
|
||||||
display: flex;
|
display: flex;
|
||||||
|
position: relative;
|
||||||
justify-content: center;
|
justify-content: center;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
background: #000;
|
|
||||||
overflow: hidden;
|
overflow: hidden;
|
||||||
font-family: "Reggae One", cursive;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
p {
|
.loader,
|
||||||
font-size: 8vw;
|
.loader:before,
|
||||||
overflow: hidden;
|
.loader:after {
|
||||||
-webkit-text-stroke: 3px #7272a5;
|
border-radius: 50%;
|
||||||
|
width: 2.5em;
|
||||||
|
height: 2.5em;
|
||||||
|
-webkit-animation-fill-mode: both;
|
||||||
|
animation-fill-mode: both;
|
||||||
|
-webkit-animation: loadAnimation 1.8s infinite ease-in-out;
|
||||||
|
animation: loadAnimation 1.8s infinite ease-in-out;
|
||||||
}
|
}
|
||||||
|
|
||||||
span {
|
.loader {
|
||||||
display: block;
|
color: #406eeb;
|
||||||
font-size: 20px;
|
font-size: 10px;
|
||||||
overflow: hidden;
|
margin: 80px auto;
|
||||||
color: green;
|
position: relative;
|
||||||
text-align: center;
|
text-indent: -9999em;
|
||||||
}
|
-webkit-transform: translateZ(0);
|
||||||
|
-ms-transform: translateZ(0);
|
||||||
p::before {
|
transform: translateZ(0);
|
||||||
content: " ";
|
-webkit-animation-delay: -0.16s;
|
||||||
width: 100%;
|
animation-delay: -0.16s;
|
||||||
height: 100%;
|
|
||||||
position: absolute;
|
|
||||||
left: 0;
|
|
||||||
top: 0;
|
top: 0;
|
||||||
background-image: linear-gradient(45deg, #ff269b, #2ab5f5, #ffbf00);
|
transform: translate(-50%, 0);
|
||||||
mix-blend-mode: multiply;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
p::after {
|
.loader:before,
|
||||||
|
.loader:after {
|
||||||
content: "";
|
content: "";
|
||||||
background: radial-gradient(circle, #fff, #000 50%);
|
|
||||||
background-size: 25% 25%;
|
|
||||||
position: absolute;
|
position: absolute;
|
||||||
top: -100%;
|
top: 0;
|
||||||
left: -100%;
|
|
||||||
right: 0;
|
|
||||||
bottom: 0;
|
|
||||||
mix-blend-mode: color-dodge;
|
|
||||||
animation: mix 2s linear infinite;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@keyframes mix {
|
.loader:before {
|
||||||
to {
|
left: -3.5em;
|
||||||
transform: translate(50%, 50%);
|
-webkit-animation-delay: -0.32s;
|
||||||
|
animation-delay: -0.32s;
|
||||||
|
}
|
||||||
|
|
||||||
|
.loader:after {
|
||||||
|
left: 3.5em;
|
||||||
|
}
|
||||||
|
|
||||||
|
@-webkit-keyframes loadAnimation {
|
||||||
|
0%,
|
||||||
|
80%,
|
||||||
|
100% {
|
||||||
|
box-shadow: 0 2.5em 0 -1.3em;
|
||||||
|
}
|
||||||
|
|
||||||
|
40% {
|
||||||
|
box-shadow: 0 2.5em 0 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@keyframes loadAnimation {
|
||||||
|
0%,
|
||||||
|
80%,
|
||||||
|
100% {
|
||||||
|
box-shadow: 0 2.5em 0 -1.3em;
|
||||||
|
}
|
||||||
|
|
||||||
|
40% {
|
||||||
|
box-shadow: 0 2.5em 0 0;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
</style>
|
</style>
|
||||||
<div class="g-container">
|
<div class="loader"></div>
|
||||||
<p>Pure-Admin</p>
|
|
||||||
<span class="_develop"></span>
|
|
||||||
</div>
|
|
||||||
</div>
|
</div>
|
||||||
<script>
|
|
||||||
// 此代码仅用于开发环境的友好提示,项目打包前请去掉这段js代码 This code is only used as a friendly reminder of the development environment, please remove this js code before packaging the project
|
|
||||||
window.onload = function () {
|
|
||||||
(function () {
|
|
||||||
const ua = navigator.userAgent.toLowerCase();
|
|
||||||
const re = /(msie|firefox|chrome|opera|version).*?([\d.]+)/;
|
|
||||||
const m = ua.match(re);
|
|
||||||
const Sys = {
|
|
||||||
browser: m[1].replace(/version/, "'safari"),
|
|
||||||
version: m[2]
|
|
||||||
};
|
|
||||||
|
|
||||||
const browser = Array.of("chrome", "firefox").includes(Sys.browser);
|
|
||||||
const version = parseFloat(Sys.version);
|
|
||||||
|
|
||||||
const el = document.querySelector("._develop");
|
|
||||||
|
|
||||||
if (el) {
|
|
||||||
if (browser && version >= 90) {
|
|
||||||
let success =
|
|
||||||
document.createTextNode("当前浏览器版本很适合开发!!! 😃");
|
|
||||||
el.appendChild(success);
|
|
||||||
} else {
|
|
||||||
let warn = document.createTextNode(
|
|
||||||
"当前浏览器版本不适合开发,建议使用最新版本的谷歌或者火狐浏览器!!!😯"
|
|
||||||
);
|
|
||||||
el.appendChild(warn);
|
|
||||||
el.style.color = "red";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return Sys;
|
|
||||||
})();
|
|
||||||
};
|
|
||||||
</script>
|
|
||||||
<script type="module" src="/src/main.ts"></script>
|
<script type="module" src="/src/main.ts"></script>
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
|||||||
130
locales/en.yaml
Normal file
@@ -0,0 +1,130 @@
|
|||||||
|
buttons:
|
||||||
|
hsLoginOut: LoginOut
|
||||||
|
hsfullscreen: FullScreen
|
||||||
|
hsexitfullscreen: ExitFullscreen
|
||||||
|
hsrefreshRoute: RefreshRoute
|
||||||
|
hslogin: Login
|
||||||
|
hsadd: Add
|
||||||
|
hsmark: Mark/Cancel
|
||||||
|
hssave: Save
|
||||||
|
hssearch: Search
|
||||||
|
hsexpendAll: Expand All
|
||||||
|
hscollapseAll: Collapse All
|
||||||
|
hssystemSet: Open ProjectConfig
|
||||||
|
hsdelete: Delete
|
||||||
|
hsreload: Reload
|
||||||
|
hscloseCurrentTab: Close CurrentTab
|
||||||
|
hscloseLeftTabs: Close LeftTabs
|
||||||
|
hscloseRightTabs: Close RightTabs
|
||||||
|
hscloseOtherTabs: Close OtherTabs
|
||||||
|
hscloseAllTabs: Close AllTabs
|
||||||
|
menus:
|
||||||
|
hshome: Home
|
||||||
|
hslogin: Login
|
||||||
|
hsempty: Empty Page
|
||||||
|
hssysManagement: System Manage
|
||||||
|
hsUser: User Manage
|
||||||
|
hsDict: Dict Manage
|
||||||
|
hsRole: Role Manage
|
||||||
|
hsDept: Dept Manage
|
||||||
|
hseditor: Editor
|
||||||
|
hserror: Error Page
|
||||||
|
hsfourZeroFour: "404"
|
||||||
|
hsfourZeroOne: "403"
|
||||||
|
hsFive: "500"
|
||||||
|
hscomponents: Components
|
||||||
|
hsvideo: Video Components
|
||||||
|
hsmap: Map Components
|
||||||
|
hsdraggable: Draggable Components
|
||||||
|
hssplitPane: Split Pane
|
||||||
|
hsbutton: Button Components
|
||||||
|
hscropping: Picture Cropping
|
||||||
|
hscountTo: Digital Animation
|
||||||
|
hsselector: Selector Components
|
||||||
|
hsflowChart: Flow Chart
|
||||||
|
hsseamless: Seamless Scroll
|
||||||
|
hscontextmenu: Context Menu
|
||||||
|
hsmenus: MultiLevel Menu
|
||||||
|
hsmenu1: Menu1
|
||||||
|
hsmenu1-1: Menu1-1
|
||||||
|
hsmenu1-2: Menu1-2
|
||||||
|
hsmenu1-2-1: Menu1-2-1
|
||||||
|
hsmenu1-2-2: Menu1-2-2
|
||||||
|
hsmenu1-3: Menu1-3
|
||||||
|
hsmenu2: Menu2
|
||||||
|
permission: Permission Manage
|
||||||
|
permissionPage: Page Permission
|
||||||
|
permissionButton: Button Permission
|
||||||
|
hstabs: Tabs Operate
|
||||||
|
hsguide: Guide
|
||||||
|
hsAble: Able
|
||||||
|
hsMenuTree: Menu Tree
|
||||||
|
hsWatermark: Water Mark
|
||||||
|
hsPrint: Print
|
||||||
|
hsExternalPage: External Page
|
||||||
|
hsPureDocument: Pure Doc(Embedded)
|
||||||
|
externalLink: Pure Doc(External)
|
||||||
|
hsEpDocument: Element Plus Doc(Embedded)
|
||||||
|
hsAbout: About
|
||||||
|
hsResult: Result Page
|
||||||
|
hsSuccess: Success Page
|
||||||
|
hsFail: Fail Page
|
||||||
|
hsIconSelect: Icon Select
|
||||||
|
hsTimeline: Time Line
|
||||||
|
hsLineTree: LineTree
|
||||||
|
hsAntTabs: Imitate Antdv Tabs
|
||||||
|
hsAntAnchor: Imitate Antdv Anchor
|
||||||
|
hsAntTreeSelect: Imitate Antdv TreeSelector
|
||||||
|
hsList: List Page
|
||||||
|
hsListCard: Card List Page
|
||||||
|
hsDebounce: Debounce & Throttle
|
||||||
|
hsFormDesign: Form Design
|
||||||
|
hsBarcode: Barcode
|
||||||
|
hsQrcode: Qrcode
|
||||||
|
hsCascader: Area Cascader
|
||||||
|
hsSwiper: Swiper Plugin
|
||||||
|
hsVirtualList: Virtual List
|
||||||
|
hsPdf: PDF Preview
|
||||||
|
hsExecl: Export Excel
|
||||||
|
status:
|
||||||
|
hsLoad: Loading...
|
||||||
|
login:
|
||||||
|
username: Username
|
||||||
|
password: Password
|
||||||
|
verifyCode: VerifyCode
|
||||||
|
remember: Remember Password
|
||||||
|
sure: Sure Password
|
||||||
|
forget: Forget Password?
|
||||||
|
login: Login
|
||||||
|
thirdLogin: Third Login
|
||||||
|
phoneLogin: Phone Login
|
||||||
|
qRCodeLogin: QRCode Login
|
||||||
|
register: Register
|
||||||
|
weChatLogin: WeChat Login
|
||||||
|
alipayLogin: Alipay Login
|
||||||
|
qqLogin: QQ Login
|
||||||
|
weiboLogin: Weibo Login
|
||||||
|
phone: Phone
|
||||||
|
smsVerifyCode: SMS VerifyCode
|
||||||
|
back: Back
|
||||||
|
test: Mock Test
|
||||||
|
tip: After scanning the code, click "Confirm" to complete the login
|
||||||
|
definite: Definite
|
||||||
|
loginSuccess: Login Success
|
||||||
|
registerSuccess: Regist Success
|
||||||
|
tickPrivacy: Please tick Privacy Policy
|
||||||
|
readAccept: I have read it carefully and accept
|
||||||
|
privacyPolicy: Privacy Policy
|
||||||
|
getVerifyCode: Get VerifyCode
|
||||||
|
info: Seconds
|
||||||
|
usernameReg: Please enter username
|
||||||
|
passwordReg: Please enter password
|
||||||
|
verifyCodeReg: Please enter verify code
|
||||||
|
verifyCodeCorrectReg: Please enter correct verify code
|
||||||
|
verifyCodeSixReg: Please enter a 6-digit verify code
|
||||||
|
phoneReg: Please enter the phone
|
||||||
|
phoneCorrectReg: Please enter the correct phone number format
|
||||||
|
passwordRuleReg: The password format should be any combination of 8-18 digits
|
||||||
|
passwordSureReg: Please enter confirm password
|
||||||
|
passwordDifferentReg: The two passwords do not match!
|
||||||
|
passwordUpdateReg: Password has been updated
|
||||||
130
locales/zh-CN.yaml
Normal file
@@ -0,0 +1,130 @@
|
|||||||
|
buttons:
|
||||||
|
hsLoginOut: 退出系统
|
||||||
|
hsfullscreen: 全屏
|
||||||
|
hsexitfullscreen: 退出全屏
|
||||||
|
hsrefreshRoute: 刷新路由
|
||||||
|
hslogin: 登录
|
||||||
|
hsadd: 新增
|
||||||
|
hsmark: 标记/取消
|
||||||
|
hssave: 保存
|
||||||
|
hssearch: 搜索
|
||||||
|
hsexpendAll: 全部展开
|
||||||
|
hscollapseAll: 全部折叠
|
||||||
|
hssystemSet: 打开项目配置
|
||||||
|
hsdelete: 删除
|
||||||
|
hsreload: 重新加载
|
||||||
|
hscloseCurrentTab: 关闭当前标签页
|
||||||
|
hscloseLeftTabs: 关闭左侧标签页
|
||||||
|
hscloseRightTabs: 关闭右侧标签页
|
||||||
|
hscloseOtherTabs: 关闭其他标签页
|
||||||
|
hscloseAllTabs: 关闭全部标签页
|
||||||
|
menus:
|
||||||
|
hshome: 首页
|
||||||
|
hslogin: 登录
|
||||||
|
hsempty: 无Layout页
|
||||||
|
hssysManagement: 系统管理
|
||||||
|
hsUser: 用户管理
|
||||||
|
hsDict: 字典管理
|
||||||
|
hsRole: 角色管理
|
||||||
|
hsDept: 部门管理
|
||||||
|
hseditor: 编辑器
|
||||||
|
hserror: 错误页面
|
||||||
|
hsfourZeroFour: "404"
|
||||||
|
hsfourZeroOne: "403"
|
||||||
|
hsFive: "500"
|
||||||
|
hscomponents: 组件
|
||||||
|
hsvideo: 视频组件
|
||||||
|
hsmap: 地图组件
|
||||||
|
hsdraggable: 拖拽组件
|
||||||
|
hssplitPane: 切割面板
|
||||||
|
hsbutton: 按钮组件
|
||||||
|
hscropping: 图片裁剪
|
||||||
|
hscountTo: 数字动画
|
||||||
|
hsselector: 选择器组件
|
||||||
|
hsflowChart: 流程图
|
||||||
|
hsseamless: 无缝滚动
|
||||||
|
hscontextmenu: 右键菜单
|
||||||
|
hsmenus: 多级菜单
|
||||||
|
hsmenu1: 菜单1
|
||||||
|
hsmenu1-1: 菜单1-1
|
||||||
|
hsmenu1-2: 菜单1-2
|
||||||
|
hsmenu1-2-1: 菜单1-2-1
|
||||||
|
hsmenu1-2-2: 菜单1-2-2
|
||||||
|
hsmenu1-3: 菜单1-3
|
||||||
|
hsmenu2: 菜单2
|
||||||
|
permission: 权限管理
|
||||||
|
permissionPage: 页面权限
|
||||||
|
permissionButton: 按钮权限
|
||||||
|
hstabs: 标签页操作
|
||||||
|
hsguide: 引导页
|
||||||
|
hsAble: 功能
|
||||||
|
hsMenuTree: 菜单树结构
|
||||||
|
hsWatermark: 水印
|
||||||
|
hsPrint: 打印
|
||||||
|
hsExternalPage: 外部页面
|
||||||
|
hsPureDocument: 平台文档(内嵌)
|
||||||
|
externalLink: 平台文档(外链)
|
||||||
|
hsEpDocument: Element Plus文档(内嵌)
|
||||||
|
hsAbout: 关于
|
||||||
|
hsResult: 结果页面
|
||||||
|
hsSuccess: 成功页面
|
||||||
|
hsFail: 失败页面
|
||||||
|
hsIconSelect: 图标选择器
|
||||||
|
hsTimeline: 时间线
|
||||||
|
hsLineTree: 树形连接线
|
||||||
|
hsAntTabs: 仿antdv标签页
|
||||||
|
hsAntAnchor: 仿antdv锚点
|
||||||
|
hsAntTreeSelect: 仿antdv树型选择器
|
||||||
|
hsList: 列表页
|
||||||
|
hsListCard: 卡片列表页
|
||||||
|
hsDebounce: 防抖节流
|
||||||
|
hsFormDesign: 表单设计器
|
||||||
|
hsBarcode: 条形码
|
||||||
|
hsQrcode: 二维码
|
||||||
|
hsCascader: 区域级联选择器
|
||||||
|
hsSwiper: Swiper插件
|
||||||
|
hsVirtualList: 虚拟列表
|
||||||
|
hsPdf: PDF预览
|
||||||
|
hsExecl: 导出Excel
|
||||||
|
status:
|
||||||
|
hsLoad: 加载中...
|
||||||
|
login:
|
||||||
|
username: 账号
|
||||||
|
password: 密码
|
||||||
|
verifyCode: 验证码
|
||||||
|
remember: 记住密码
|
||||||
|
sure: 确认密码
|
||||||
|
forget: 忘记密码?
|
||||||
|
login: 登录
|
||||||
|
thirdLogin: 第三方登录
|
||||||
|
phoneLogin: 手机登录
|
||||||
|
qRCodeLogin: 二维码登录
|
||||||
|
register: 注册
|
||||||
|
weChatLogin: 微信登录
|
||||||
|
alipayLogin: 支付宝登录
|
||||||
|
qqLogin: QQ登录
|
||||||
|
weiboLogin: 微博登录
|
||||||
|
phone: 手机号码
|
||||||
|
smsVerifyCode: 短信验证码
|
||||||
|
back: 返回
|
||||||
|
test: 模拟测试
|
||||||
|
tip: 扫码后点击"确认",即可完成登录
|
||||||
|
definite: 确定
|
||||||
|
loginSuccess: 登录成功
|
||||||
|
registerSuccess: 注册成功
|
||||||
|
tickPrivacy: 请勾选隐私政策
|
||||||
|
readAccept: 我已仔细阅读并接受
|
||||||
|
privacyPolicy: 《隐私政策》
|
||||||
|
getVerifyCode: 获取验证码
|
||||||
|
info: 秒后重新获取
|
||||||
|
usernameReg: 请输入账号
|
||||||
|
passwordReg: 请输入密码
|
||||||
|
verifyCodeReg: 请输入验证码
|
||||||
|
verifyCodeCorrectReg: 请输入正确的验证码
|
||||||
|
verifyCodeSixReg: 请输入6位数字验证码
|
||||||
|
phoneReg: 请输入手机号码
|
||||||
|
phoneCorrectReg: 请输入正确的手机号码格式
|
||||||
|
passwordRuleReg: 密码格式应为8-18位数字、字母、符号的任意两种组合
|
||||||
|
passwordSureReg: 请输入确认密码
|
||||||
|
passwordDifferentReg: 两次密码不一致!
|
||||||
|
passwordUpdateReg: 修改密码成功
|
||||||
@@ -4,29 +4,44 @@ import { MockMethod } from "vite-plugin-mock";
|
|||||||
// http://mockjs.com/examples.html#Object
|
// http://mockjs.com/examples.html#Object
|
||||||
const systemRouter = {
|
const systemRouter = {
|
||||||
path: "/system",
|
path: "/system",
|
||||||
name: "system",
|
|
||||||
redirect: "/system/user",
|
|
||||||
meta: {
|
meta: {
|
||||||
icon: "el-icon-setting",
|
icon: "setting",
|
||||||
title: "message.hssysManagement",
|
title: "menus.hssysManagement",
|
||||||
showLink: true,
|
rank: 11
|
||||||
rank: 6
|
|
||||||
},
|
},
|
||||||
children: [
|
children: [
|
||||||
{
|
{
|
||||||
path: "/system/user",
|
path: "/system/user/index",
|
||||||
name: "user",
|
name: "User",
|
||||||
meta: {
|
meta: {
|
||||||
title: "message.hsBaseinfo",
|
icon: "flUser",
|
||||||
showLink: true
|
title: "menus.hsUser"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
path: "/system/role/index",
|
||||||
|
name: "Role",
|
||||||
|
meta: {
|
||||||
|
icon: "role",
|
||||||
|
title: "menus.hsRole"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
path: "/system/dept/index",
|
||||||
|
name: "Dept",
|
||||||
|
meta: {
|
||||||
|
icon: "dept",
|
||||||
|
title: "menus.hsDept"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
path: "/system/dict",
|
path: "/system/dict",
|
||||||
name: "dict",
|
component: "/system/dict/index",
|
||||||
|
name: "Dict",
|
||||||
meta: {
|
meta: {
|
||||||
title: "message.hsDict",
|
icon: "dict",
|
||||||
showLink: true
|
title: "menus.hsDict",
|
||||||
|
keepAlive: true
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
@@ -34,35 +49,98 @@ const systemRouter = {
|
|||||||
|
|
||||||
const permissionRouter = {
|
const permissionRouter = {
|
||||||
path: "/permission",
|
path: "/permission",
|
||||||
name: "permission",
|
|
||||||
redirect: "/permission/page",
|
|
||||||
meta: {
|
meta: {
|
||||||
title: "message.permission",
|
title: "menus.permission",
|
||||||
icon: "el-icon-lollipop",
|
icon: "lollipop",
|
||||||
showLink: true,
|
rank: 7
|
||||||
rank: 3
|
|
||||||
},
|
},
|
||||||
children: [
|
children: [
|
||||||
{
|
{
|
||||||
path: "/permission/page",
|
path: "/permission/page/index",
|
||||||
name: "permissionPage",
|
name: "PermissionPage",
|
||||||
meta: {
|
meta: {
|
||||||
title: "message.permissionPage",
|
title: "menus.permissionPage"
|
||||||
showLink: true
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
path: "/permission/button",
|
path: "/permission/button/index",
|
||||||
name: "permissionButton",
|
name: "PermissionButton",
|
||||||
meta: {
|
meta: {
|
||||||
title: "message.permissionButton",
|
title: "menus.permissionButton",
|
||||||
showLink: true,
|
|
||||||
authority: []
|
authority: []
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
};
|
};
|
||||||
|
|
||||||
|
const frameRouter = {
|
||||||
|
path: "/iframe",
|
||||||
|
meta: {
|
||||||
|
icon: "monitor",
|
||||||
|
title: "menus.hsExternalPage",
|
||||||
|
rank: 10
|
||||||
|
},
|
||||||
|
children: [
|
||||||
|
{
|
||||||
|
path: "/iframe/pure",
|
||||||
|
name: "FramePure",
|
||||||
|
meta: {
|
||||||
|
title: "menus.hsPureDocument",
|
||||||
|
frameSrc: "https://pure-admin-doc.vercel.app"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
path: "/external",
|
||||||
|
name: "https://pure-admin-doc.vercel.app",
|
||||||
|
meta: {
|
||||||
|
title: "menus.externalLink"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
path: "/iframe/ep",
|
||||||
|
name: "FrameEp",
|
||||||
|
meta: {
|
||||||
|
title: "menus.hsEpDocument",
|
||||||
|
frameSrc: "https://element-plus.org/zh-CN/"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
};
|
||||||
|
|
||||||
|
const tabsRouter = {
|
||||||
|
path: "/tabs",
|
||||||
|
meta: {
|
||||||
|
icon: "IF-team-icontabs",
|
||||||
|
title: "menus.hstabs",
|
||||||
|
rank: 13
|
||||||
|
},
|
||||||
|
children: [
|
||||||
|
{
|
||||||
|
path: "/tabs/index",
|
||||||
|
name: "Tabs",
|
||||||
|
meta: {
|
||||||
|
title: "menus.hstabs"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
path: "/tabs/query-detail",
|
||||||
|
name: "TabQueryDetail",
|
||||||
|
meta: {
|
||||||
|
// 不在menu菜单中显示
|
||||||
|
showLink: false
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
path: "/tabs/params-detail/:id",
|
||||||
|
component: "params-detail",
|
||||||
|
name: "TabParamsDetail",
|
||||||
|
meta: {
|
||||||
|
showLink: false
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
};
|
||||||
|
|
||||||
// 添加不同按钮权限到/permission/button页面中
|
// 添加不同按钮权限到/permission/button页面中
|
||||||
function setDifAuthority(authority, routes) {
|
function setDifAuthority(authority, routes) {
|
||||||
routes.children[1].meta.authority = [authority];
|
routes.children[1].meta.authority = [authority];
|
||||||
@@ -77,12 +155,17 @@ export default [
|
|||||||
if (query.name === "admin") {
|
if (query.name === "admin") {
|
||||||
return {
|
return {
|
||||||
code: 0,
|
code: 0,
|
||||||
info: [systemRouter, setDifAuthority("v-admin", permissionRouter)]
|
info: [
|
||||||
|
tabsRouter,
|
||||||
|
frameRouter,
|
||||||
|
systemRouter,
|
||||||
|
setDifAuthority("v-admin", permissionRouter)
|
||||||
|
]
|
||||||
};
|
};
|
||||||
} else {
|
} else {
|
||||||
return {
|
return {
|
||||||
code: 0,
|
code: 0,
|
||||||
info: [setDifAuthority("v-test", permissionRouter)]
|
info: [tabsRouter, setDifAuthority("v-test", permissionRouter)]
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,23 +0,0 @@
|
|||||||
import { MockMethod } from "vite-plugin-mock";
|
|
||||||
|
|
||||||
// http://mockjs.com/examples.html#Object
|
|
||||||
const echartsList = (): any => {
|
|
||||||
const result: any[] = [];
|
|
||||||
for (let index = 0; index < 200; index++) {
|
|
||||||
result.push(["@date", Math.floor(Math.random() * 300)]);
|
|
||||||
}
|
|
||||||
return result;
|
|
||||||
};
|
|
||||||
|
|
||||||
export default [
|
|
||||||
{
|
|
||||||
url: "/getEchartsInfo",
|
|
||||||
method: "get",
|
|
||||||
response: () => {
|
|
||||||
return {
|
|
||||||
code: 0,
|
|
||||||
info: echartsList()
|
|
||||||
};
|
|
||||||
}
|
|
||||||
}
|
|
||||||
] as MockMethod[];
|
|
||||||
455
mock/list.ts
Normal file
@@ -0,0 +1,455 @@
|
|||||||
|
import { MockMethod } from "vite-plugin-mock";
|
||||||
|
|
||||||
|
export default [
|
||||||
|
{
|
||||||
|
url: "/getCardList",
|
||||||
|
method: "post",
|
||||||
|
response: () => {
|
||||||
|
return {
|
||||||
|
code: 0,
|
||||||
|
data: {
|
||||||
|
list: [
|
||||||
|
{
|
||||||
|
index: 1,
|
||||||
|
isSetup: true,
|
||||||
|
type: 4,
|
||||||
|
banner: "https://tdesign.gtimg.com/tdesign-pro/cloud-server.jpg",
|
||||||
|
name: "SSL证书",
|
||||||
|
description:
|
||||||
|
"SSL证书又叫服务器证书,腾讯云为您提供证书的一站式服务,包括免费、付费证书的申请、管理及部"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
index: 2,
|
||||||
|
isSetup: false,
|
||||||
|
type: 4,
|
||||||
|
banner: "https://tdesign.gtimg.com/tdesign-pro/t-sec.jpg",
|
||||||
|
name: "人脸识别",
|
||||||
|
description:
|
||||||
|
"SSL证书又叫服务器证书,腾讯云为您提供证书的一站式服务,包括免费、付费证书的申请、管理及部"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
index: 3,
|
||||||
|
isSetup: false,
|
||||||
|
type: 5,
|
||||||
|
banner: "https://tdesign.gtimg.com/tdesign-pro/ssl.jpg",
|
||||||
|
name: "CVM",
|
||||||
|
description:
|
||||||
|
"云硬盘为您提供用于CVM的持久性数据块级存储服务。云硬盘中的数据自动地可用区内以多副本冗"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
index: 4,
|
||||||
|
isSetup: false,
|
||||||
|
type: 2,
|
||||||
|
banner: "https://tdesign.gtimg.com/tdesign-pro/ssl.jpg",
|
||||||
|
name: "SSL证书",
|
||||||
|
description:
|
||||||
|
"云数据库MySQL为用户提供安全可靠,性能卓越、易于维护的企业级云数据库服务。"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
index: 5,
|
||||||
|
isSetup: true,
|
||||||
|
type: 3,
|
||||||
|
banner:
|
||||||
|
"https://tdesign.gtimg.com/tdesign-pro/face-recognition.jpg",
|
||||||
|
name: "SSL证书",
|
||||||
|
description:
|
||||||
|
"云数据库MySQL为用户提供安全可靠,性能卓越、易于维护的企业级云数据库服务。"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
index: 6,
|
||||||
|
isSetup: true,
|
||||||
|
type: 3,
|
||||||
|
banner: "https://tdesign.gtimg.com/tdesign-pro/ssl.jpg",
|
||||||
|
name: "T-Sec 云防火墙",
|
||||||
|
description:
|
||||||
|
"腾讯安全云防火墙产品,是腾讯云安全团队结合云原生的优势,自主研发的SaaS化防火墙产品,无需客无需客无需客无需客无需客无需客无需客"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
index: 7,
|
||||||
|
isSetup: false,
|
||||||
|
type: 1,
|
||||||
|
banner: "https://tdesign.gtimg.com/tdesign-pro/t-sec.jpg",
|
||||||
|
name: "CVM",
|
||||||
|
description:
|
||||||
|
"腾讯安全云防火墙产品,是腾讯云安全团队结合云原生的优势,自主研发的SaaS化防火墙产品,无需客无需客无需客无需客无需客无需客无需客"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
index: 8,
|
||||||
|
isSetup: true,
|
||||||
|
type: 3,
|
||||||
|
banner: "https://tdesign.gtimg.com/tdesign-pro/t-sec.jpg",
|
||||||
|
name: "SSL证书",
|
||||||
|
description:
|
||||||
|
"云硬盘为您提供用于CVM的持久性数据块级存储服务。云硬盘中的数据自动地可用区内以多副本冗"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
index: 9,
|
||||||
|
isSetup: false,
|
||||||
|
type: 1,
|
||||||
|
banner: "https://tdesign.gtimg.com/tdesign-pro/cloud-server.jpg",
|
||||||
|
name: "SSL证书",
|
||||||
|
description:
|
||||||
|
"腾讯安全云防火墙产品,是腾讯云安全团队结合云原生的优势,自主研发的SaaS化防火墙产品,无需客无需客无需客无需客无需客无需客无需客"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
index: 10,
|
||||||
|
isSetup: true,
|
||||||
|
type: 4,
|
||||||
|
banner: "https://tdesign.gtimg.com/tdesign-pro/ssl.jpg",
|
||||||
|
name: "CVM",
|
||||||
|
description:
|
||||||
|
"云数据库MySQL为用户提供安全可靠,性能卓越、易于维护的企业级云数据库服务。"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
index: 11,
|
||||||
|
isSetup: true,
|
||||||
|
type: 5,
|
||||||
|
banner: "https://tdesign.gtimg.com/tdesign-pro/t-sec.jpg",
|
||||||
|
name: "云数据库",
|
||||||
|
description:
|
||||||
|
"SSL证书又叫服务器证书,腾讯云为您提供证书的一站式服务,包括免费、付费证书的申请、管理及部"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
index: 12,
|
||||||
|
isSetup: true,
|
||||||
|
type: 2,
|
||||||
|
banner: "https://tdesign.gtimg.com/tdesign-pro/t-sec.jpg",
|
||||||
|
name: "SSL证书",
|
||||||
|
description:
|
||||||
|
"SSL证书又叫服务器证书,腾讯云为您提供证书的一站式服务,包括免费、付费证书的申请、管理及部"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
index: 13,
|
||||||
|
isSetup: true,
|
||||||
|
type: 3,
|
||||||
|
banner: "https://tdesign.gtimg.com/tdesign-pro/cloud-db.jpg",
|
||||||
|
name: "云数据库",
|
||||||
|
description:
|
||||||
|
"腾讯安全云防火墙产品,是腾讯云安全团队结合云原生的优势,自主研发的SaaS化防火墙产品,无需客无需客无需客无需客无需客无需客无需客"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
index: 14,
|
||||||
|
isSetup: false,
|
||||||
|
type: 5,
|
||||||
|
banner: "https://tdesign.gtimg.com/tdesign-pro/t-sec.jpg",
|
||||||
|
name: "SSL证书",
|
||||||
|
description:
|
||||||
|
"基于腾讯优图强大的面部分析技术,提供包括人脸检测与分析、五官定位、人脸搜索、人脸比对、人脸"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
index: 15,
|
||||||
|
isSetup: true,
|
||||||
|
type: 2,
|
||||||
|
banner: "https://tdesign.gtimg.com/tdesign-pro/t-sec.jpg",
|
||||||
|
name: "云数据库",
|
||||||
|
description:
|
||||||
|
"SSL证书又叫服务器证书,腾讯云为您提供证书的一站式服务,包括免费、付费证书的申请、管理及部"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
index: 16,
|
||||||
|
isSetup: false,
|
||||||
|
type: 3,
|
||||||
|
banner: "https://tdesign.gtimg.com/tdesign-pro/cloud-server.jpg",
|
||||||
|
name: "CVM",
|
||||||
|
description:
|
||||||
|
"基于腾讯优图强大的面部分析技术,提供包括人脸检测与分析、五官定位、人脸搜索、人脸比对、人脸"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
index: 17,
|
||||||
|
isSetup: false,
|
||||||
|
type: 5,
|
||||||
|
banner:
|
||||||
|
"https://tdesign.gtimg.com/tdesign-pro/face-recognition.jpg",
|
||||||
|
name: "云数据库",
|
||||||
|
description:
|
||||||
|
"SSL证书又叫服务器证书,腾讯云为您提供证书的一站式服务,包括免费、付费证书的申请、管理及部"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
index: 18,
|
||||||
|
isSetup: false,
|
||||||
|
type: 4,
|
||||||
|
banner:
|
||||||
|
"https://tdesign.gtimg.com/tdesign-pro/face-recognition.jpg",
|
||||||
|
name: "云数据库",
|
||||||
|
description:
|
||||||
|
"腾讯安全云防火墙产品,是腾讯云安全团队结合云原生的优势,自主研发的SaaS化防火墙产品,无需客无需客无需客无需客无需客无需客无需客"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
index: 19,
|
||||||
|
isSetup: true,
|
||||||
|
type: 2,
|
||||||
|
banner: "https://tdesign.gtimg.com/tdesign-pro/ssl.jpg",
|
||||||
|
name: "CVM",
|
||||||
|
description:
|
||||||
|
"SSL证书又叫服务器证书,腾讯云为您提供证书的一站式服务,包括免费、付费证书的申请、管理及部"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
index: 20,
|
||||||
|
isSetup: true,
|
||||||
|
type: 4,
|
||||||
|
banner:
|
||||||
|
"https://tdesign.gtimg.com/tdesign-pro/face-recognition.jpg",
|
||||||
|
name: "SSL证书",
|
||||||
|
description:
|
||||||
|
"SSL证书又叫服务器证书,腾讯云为您提供证书的一站式服务,包括免费、付费证书的申请、管理及部"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
index: 21,
|
||||||
|
isSetup: false,
|
||||||
|
type: 4,
|
||||||
|
banner: "https://tdesign.gtimg.com/tdesign-pro/t-sec.jpg",
|
||||||
|
name: "云数据库",
|
||||||
|
description:
|
||||||
|
"云硬盘为您提供用于CVM的持久性数据块级存储服务。云硬盘中的数据自动地可用区内以多副本冗"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
index: 22,
|
||||||
|
isSetup: false,
|
||||||
|
type: 3,
|
||||||
|
banner: "https://tdesign.gtimg.com/tdesign-pro/cloud-db.jpg",
|
||||||
|
name: "CVM",
|
||||||
|
description:
|
||||||
|
"SSL证书又叫服务器证书,腾讯云为您提供证书的一站式服务,包括免费、付费证书的申请、管理及部"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
index: 23,
|
||||||
|
isSetup: true,
|
||||||
|
type: 1,
|
||||||
|
banner: "https://tdesign.gtimg.com/tdesign-pro/ssl.jpg",
|
||||||
|
name: "人脸识别",
|
||||||
|
description:
|
||||||
|
"基于腾讯优图强大的面部分析技术,提供包括人脸检测与分析、五官定位、人脸搜索、人脸比对、人脸"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
index: 24,
|
||||||
|
isSetup: true,
|
||||||
|
type: 4,
|
||||||
|
banner: "https://tdesign.gtimg.com/tdesign-pro/ssl.jpg",
|
||||||
|
name: "人脸识别",
|
||||||
|
description:
|
||||||
|
"基于腾讯优图强大的面部分析技术,提供包括人脸检测与分析、五官定位、人脸搜索、人脸比对、人脸"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
index: 25,
|
||||||
|
isSetup: false,
|
||||||
|
type: 5,
|
||||||
|
banner:
|
||||||
|
"https://tdesign.gtimg.com/tdesign-pro/face-recognition.jpg",
|
||||||
|
name: "CVM",
|
||||||
|
description:
|
||||||
|
"云硬盘为您提供用于CVM的持久性数据块级存储服务。云硬盘中的数据自动地可用区内以多副本冗"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
index: 26,
|
||||||
|
isSetup: true,
|
||||||
|
type: 4,
|
||||||
|
banner: "https://tdesign.gtimg.com/tdesign-pro/cloud-server.jpg",
|
||||||
|
name: "SSL证书",
|
||||||
|
description:
|
||||||
|
"云硬盘为您提供用于CVM的持久性数据块级存储服务。云硬盘中的数据自动地可用区内以多副本冗"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
index: 27,
|
||||||
|
isSetup: true,
|
||||||
|
type: 5,
|
||||||
|
banner: "https://tdesign.gtimg.com/tdesign-pro/ssl.jpg",
|
||||||
|
name: "CVM",
|
||||||
|
description:
|
||||||
|
"SSL证书又叫服务器证书,腾讯云为您提供证书的一站式服务,包括免费、付费证书的申请、管理及部"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
index: 28,
|
||||||
|
isSetup: false,
|
||||||
|
type: 4,
|
||||||
|
banner: "https://tdesign.gtimg.com/tdesign-pro/ssl.jpg",
|
||||||
|
name: "云数据库",
|
||||||
|
description:
|
||||||
|
"基于腾讯优图强大的面部分析技术,提供包括人脸检测与分析、五官定位、人脸搜索、人脸比对、人脸"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
index: 29,
|
||||||
|
isSetup: false,
|
||||||
|
type: 5,
|
||||||
|
banner: "https://tdesign.gtimg.com/tdesign-pro/cloud-db.jpg",
|
||||||
|
name: "CVM",
|
||||||
|
description:
|
||||||
|
"SSL证书又叫服务器证书,腾讯云为您提供证书的一站式服务,包括免费、付费证书的申请、管理及部"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
index: 30,
|
||||||
|
isSetup: true,
|
||||||
|
type: 1,
|
||||||
|
banner: "https://tdesign.gtimg.com/tdesign-pro/ssl.jpg",
|
||||||
|
name: "CVM",
|
||||||
|
description:
|
||||||
|
"云硬盘为您提供用于CVM的持久性数据块级存储服务。云硬盘中的数据自动地可用区内以多副本冗"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
index: 31,
|
||||||
|
isSetup: true,
|
||||||
|
type: 4,
|
||||||
|
banner: "https://tdesign.gtimg.com/tdesign-pro/cloud-server.jpg",
|
||||||
|
name: "CVM",
|
||||||
|
description:
|
||||||
|
"基于腾讯优图强大的面部分析技术,提供包括人脸检测与分析、五官定位、人脸搜索、人脸比对、人脸"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
index: 32,
|
||||||
|
isSetup: false,
|
||||||
|
type: 3,
|
||||||
|
banner: "https://tdesign.gtimg.com/tdesign-pro/cloud-server.jpg",
|
||||||
|
name: "T-Sec 云防火墙",
|
||||||
|
description:
|
||||||
|
"腾讯安全云防火墙产品,是腾讯云安全团队结合云原生的优势,自主研发的SaaS化防火墙产品,无需客无需客无需客无需客无需客无需客无需客"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
index: 33,
|
||||||
|
isSetup: true,
|
||||||
|
type: 3,
|
||||||
|
banner: "https://tdesign.gtimg.com/tdesign-pro/t-sec.jpg",
|
||||||
|
name: "CVM",
|
||||||
|
description:
|
||||||
|
"云数据库MySQL为用户提供安全可靠,性能卓越、易于维护的企业级云数据库服务。"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
index: 34,
|
||||||
|
isSetup: false,
|
||||||
|
type: 2,
|
||||||
|
banner: "https://tdesign.gtimg.com/tdesign-pro/ssl.jpg",
|
||||||
|
name: "SSL证书",
|
||||||
|
description:
|
||||||
|
"腾讯安全云防火墙产品,是腾讯云安全团队结合云原生的优势,自主研发的SaaS化防火墙产品,无需客无需客无需客无需客无需客无需客无需客"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
index: 35,
|
||||||
|
isSetup: false,
|
||||||
|
type: 1,
|
||||||
|
banner: "https://tdesign.gtimg.com/tdesign-pro/cloud-server.jpg",
|
||||||
|
name: "云数据库",
|
||||||
|
description:
|
||||||
|
"基于腾讯优图强大的面部分析技术,提供包括人脸检测与分析、五官定位、人脸搜索、人脸比对、人脸"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
index: 36,
|
||||||
|
isSetup: false,
|
||||||
|
type: 4,
|
||||||
|
banner:
|
||||||
|
"https://tdesign.gtimg.com/tdesign-pro/face-recognition.jpg",
|
||||||
|
name: "SSL证书",
|
||||||
|
description:
|
||||||
|
"腾讯安全云防火墙产品,是腾讯云安全团队结合云原生的优势,自主研发的SaaS化防火墙产品,无需客无需客无需客无需客无需客无需客无需客"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
index: 37,
|
||||||
|
isSetup: true,
|
||||||
|
type: 5,
|
||||||
|
banner: "https://tdesign.gtimg.com/tdesign-pro/cloud-server.jpg",
|
||||||
|
name: "CVM",
|
||||||
|
description:
|
||||||
|
"云数据库MySQL为用户提供安全可靠,性能卓越、易于维护的企业级云数据库服务。"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
index: 38,
|
||||||
|
isSetup: false,
|
||||||
|
type: 4,
|
||||||
|
banner: "https://tdesign.gtimg.com/tdesign-pro/ssl.jpg",
|
||||||
|
name: "云数据库",
|
||||||
|
description:
|
||||||
|
"云硬盘为您提供用于CVM的持久性数据块级存储服务。云硬盘中的数据自动地可用区内以多副本冗"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
index: 39,
|
||||||
|
isSetup: false,
|
||||||
|
type: 3,
|
||||||
|
banner: "https://tdesign.gtimg.com/tdesign-pro/t-sec.jpg",
|
||||||
|
name: "人脸识别",
|
||||||
|
description:
|
||||||
|
"云硬盘为您提供用于CVM的持久性数据块级存储服务。云硬盘中的数据自动地可用区内以多副本冗"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
index: 40,
|
||||||
|
isSetup: true,
|
||||||
|
type: 4,
|
||||||
|
banner: "https://tdesign.gtimg.com/tdesign-pro/ssl.jpg",
|
||||||
|
name: "CVM",
|
||||||
|
description:
|
||||||
|
"SSL证书又叫服务器证书,腾讯云为您提供证书的一站式服务,包括免费、付费证书的申请、管理及部"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
index: 41,
|
||||||
|
isSetup: true,
|
||||||
|
type: 4,
|
||||||
|
banner: "https://tdesign.gtimg.com/tdesign-pro/ssl.jpg",
|
||||||
|
name: "T-Sec 云防火墙",
|
||||||
|
description:
|
||||||
|
"云硬盘为您提供用于CVM的持久性数据块级存储服务。云硬盘中的数据自动地可用区内以多副本冗"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
index: 42,
|
||||||
|
isSetup: true,
|
||||||
|
type: 3,
|
||||||
|
banner: "https://tdesign.gtimg.com/tdesign-pro/cloud-server.jpg",
|
||||||
|
name: "T-Sec 云防火墙",
|
||||||
|
description:
|
||||||
|
"云硬盘为您提供用于CVM的持久性数据块级存储服务。云硬盘中的数据自动地可用区内以多副本冗"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
index: 43,
|
||||||
|
isSetup: false,
|
||||||
|
type: 3,
|
||||||
|
banner: "https://tdesign.gtimg.com/tdesign-pro/cloud-db.jpg",
|
||||||
|
name: "SSL证书",
|
||||||
|
description:
|
||||||
|
"云硬盘为您提供用于CVM的持久性数据块级存储服务。云硬盘中的数据自动地可用区内以多副本冗"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
index: 44,
|
||||||
|
isSetup: true,
|
||||||
|
type: 4,
|
||||||
|
banner: "https://tdesign.gtimg.com/tdesign-pro/t-sec.jpg",
|
||||||
|
name: "SSL证书",
|
||||||
|
description:
|
||||||
|
"云硬盘为您提供用于CVM的持久性数据块级存储服务。云硬盘中的数据自动地可用区内以多副本冗"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
index: 45,
|
||||||
|
isSetup: false,
|
||||||
|
type: 3,
|
||||||
|
banner: "https://tdesign.gtimg.com/tdesign-pro/ssl.jpg",
|
||||||
|
name: "T-Sec 云防火墙",
|
||||||
|
description:
|
||||||
|
"SSL证书又叫服务器证书,腾讯云为您提供证书的一站式服务,包括免费、付费证书的申请、管理及部"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
index: 46,
|
||||||
|
isSetup: true,
|
||||||
|
type: 2,
|
||||||
|
banner: "https://tdesign.gtimg.com/tdesign-pro/cloud-server.jpg",
|
||||||
|
name: "SSL证书",
|
||||||
|
description:
|
||||||
|
"SSL证书又叫服务器证书,腾讯云为您提供证书的一站式服务,包括免费、付费证书的申请、管理及部"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
index: 47,
|
||||||
|
isSetup: false,
|
||||||
|
type: 4,
|
||||||
|
banner: "https://tdesign.gtimg.com/tdesign-pro/cloud-server.jpg",
|
||||||
|
name: "SSL证书",
|
||||||
|
description:
|
||||||
|
"腾讯安全云防火墙产品,是腾讯云安全团队结合云原生的优势,自主研发的SaaS化防火墙产品,无需客无需客无需客无需客无需客无需客无需客"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
index: 48,
|
||||||
|
isSetup: false,
|
||||||
|
type: 3,
|
||||||
|
banner: "https://tdesign.gtimg.com/tdesign-pro/ssl.jpg",
|
||||||
|
name: "T-Sec 云防火墙",
|
||||||
|
description:
|
||||||
|
"SSL证书又叫服务器证书,腾讯云为您提供证书的一站式服务,包括免费、付费证书的申请、管理及部"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
||||||
|
] as MockMethod[];
|
||||||
12
mock/map.ts
@@ -1,8 +1,16 @@
|
|||||||
import { MockMethod } from "vite-plugin-mock";
|
import { MockMethod } from "vite-plugin-mock";
|
||||||
|
|
||||||
|
type mapType = {
|
||||||
|
plateNumber: string;
|
||||||
|
driver: string;
|
||||||
|
"orientation|1-360": number;
|
||||||
|
"lng|113-114.1-10": number;
|
||||||
|
"lat|34-35.1-10": number;
|
||||||
|
};
|
||||||
|
|
||||||
// http://mockjs.com/examples.html#Object
|
// http://mockjs.com/examples.html#Object
|
||||||
const mapList = (): any => {
|
const mapList = (): Array<mapType> => {
|
||||||
const result: any[] = [];
|
const result: Array<mapType> = [];
|
||||||
for (let index = 0; index < 200; index++) {
|
for (let index = 0; index < 200; index++) {
|
||||||
result.push({
|
result.push({
|
||||||
plateNumber: "豫A@natural(11111, 99999)@character('upper')",
|
plateNumber: "豫A@natural(11111, 99999)@character('upper')",
|
||||||
|
|||||||
288
mock/system.ts
Normal file
@@ -0,0 +1,288 @@
|
|||||||
|
import { MockMethod } from "vite-plugin-mock";
|
||||||
|
|
||||||
|
export default [
|
||||||
|
{
|
||||||
|
url: "/role",
|
||||||
|
method: "post",
|
||||||
|
response: () => {
|
||||||
|
return {
|
||||||
|
code: 0,
|
||||||
|
data: {
|
||||||
|
list: [
|
||||||
|
{
|
||||||
|
createTime: 1609837428000,
|
||||||
|
updateTime: 1645477701000,
|
||||||
|
creator: "admin",
|
||||||
|
updater: "",
|
||||||
|
deleted: false,
|
||||||
|
tenantId: 1,
|
||||||
|
id: 1,
|
||||||
|
name: "超级管理员",
|
||||||
|
code: "super_admin",
|
||||||
|
sort: 1,
|
||||||
|
status: 0,
|
||||||
|
type: 1,
|
||||||
|
remark: "超级管理员",
|
||||||
|
dataScope: 1,
|
||||||
|
dataScopeDeptIds: null
|
||||||
|
},
|
||||||
|
{
|
||||||
|
createTime: 1609837428000,
|
||||||
|
updateTime: 1645477700000,
|
||||||
|
creator: "admin",
|
||||||
|
updater: "",
|
||||||
|
deleted: false,
|
||||||
|
tenantId: 1,
|
||||||
|
id: 2,
|
||||||
|
name: "普通角色",
|
||||||
|
code: "common",
|
||||||
|
sort: 2,
|
||||||
|
status: 0,
|
||||||
|
type: 1,
|
||||||
|
remark: "普通角色",
|
||||||
|
dataScope: 2,
|
||||||
|
dataScopeDeptIds: null
|
||||||
|
},
|
||||||
|
{
|
||||||
|
createTime: 1609912175000,
|
||||||
|
updateTime: 1647698441000,
|
||||||
|
creator: "",
|
||||||
|
updater: "1",
|
||||||
|
deleted: false,
|
||||||
|
tenantId: 1,
|
||||||
|
id: 101,
|
||||||
|
name: "测试账号",
|
||||||
|
code: "test",
|
||||||
|
sort: 0,
|
||||||
|
status: 0,
|
||||||
|
type: 2,
|
||||||
|
remark: "132",
|
||||||
|
dataScope: 1,
|
||||||
|
dataScopeDeptIds: []
|
||||||
|
}
|
||||||
|
],
|
||||||
|
total: 3
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
url: "/dept",
|
||||||
|
method: "post",
|
||||||
|
response: () => {
|
||||||
|
return {
|
||||||
|
code: 0,
|
||||||
|
data: [
|
||||||
|
{
|
||||||
|
name: "杭州总公司",
|
||||||
|
type: 1, // 1 公司 2 分公司 3 部门
|
||||||
|
parentId: 0,
|
||||||
|
sort: 0,
|
||||||
|
leaderUserId: 1,
|
||||||
|
phone: "15888888888",
|
||||||
|
email: "ry@qq.com",
|
||||||
|
status: 0,
|
||||||
|
id: 100,
|
||||||
|
createTime: 1609837427000,
|
||||||
|
remark: "备注、备注、备注、备注、备注、备注、备注"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "郑州分公司",
|
||||||
|
type: 2,
|
||||||
|
parentId: 100,
|
||||||
|
sort: 1,
|
||||||
|
leaderUserId: 104,
|
||||||
|
phone: "15888888888",
|
||||||
|
email: "ry@qq.com",
|
||||||
|
status: 0,
|
||||||
|
id: 101,
|
||||||
|
createTime: 1609837427000,
|
||||||
|
remark: "备注、备注、备注、备注、备注、备注、备注"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "研发部门",
|
||||||
|
type: 3,
|
||||||
|
parentId: 101,
|
||||||
|
sort: 1,
|
||||||
|
leaderUserId: 104,
|
||||||
|
phone: "15888888888",
|
||||||
|
email: "ry@qq.com",
|
||||||
|
status: 0,
|
||||||
|
id: 103,
|
||||||
|
createTime: 1609837427000,
|
||||||
|
remark: "备注、备注、备注、备注、备注、备注、备注"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "市场部门",
|
||||||
|
type: 3,
|
||||||
|
parentId: 102,
|
||||||
|
sort: 1,
|
||||||
|
leaderUserId: null,
|
||||||
|
phone: "15888888888",
|
||||||
|
email: "ry@qq.com",
|
||||||
|
status: 0,
|
||||||
|
id: 108,
|
||||||
|
createTime: 1609837427000,
|
||||||
|
remark: "备注、备注、备注、备注、备注、备注、备注"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "深圳分公司",
|
||||||
|
type: 2,
|
||||||
|
parentId: 100,
|
||||||
|
sort: 2,
|
||||||
|
leaderUserId: null,
|
||||||
|
phone: "15888888888",
|
||||||
|
email: "ry@qq.com",
|
||||||
|
status: 0,
|
||||||
|
id: 102,
|
||||||
|
createTime: 1609837427000,
|
||||||
|
remark: "备注、备注、备注、备注、备注、备注、备注"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "市场部门",
|
||||||
|
type: 3,
|
||||||
|
parentId: 101,
|
||||||
|
sort: 2,
|
||||||
|
leaderUserId: null,
|
||||||
|
phone: "15888888888",
|
||||||
|
email: "ry@qq.com",
|
||||||
|
status: 1,
|
||||||
|
id: 104,
|
||||||
|
createTime: 1609837427000,
|
||||||
|
remark: "备注、备注、备注、备注、备注、备注、备注"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "财务部门",
|
||||||
|
type: 3,
|
||||||
|
parentId: 102,
|
||||||
|
sort: 2,
|
||||||
|
leaderUserId: null,
|
||||||
|
phone: "15888888888",
|
||||||
|
email: "ry@qq.com",
|
||||||
|
status: 0,
|
||||||
|
id: 109,
|
||||||
|
createTime: 1609837427000,
|
||||||
|
remark: "备注、备注、备注、备注、备注、备注、备注"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "测试部门",
|
||||||
|
type: 3,
|
||||||
|
parentId: 101,
|
||||||
|
sort: 3,
|
||||||
|
leaderUserId: null,
|
||||||
|
phone: "15888888888",
|
||||||
|
email: "ry@qq.com",
|
||||||
|
status: 0,
|
||||||
|
id: 105,
|
||||||
|
createTime: 1609837427000,
|
||||||
|
remark: "备注、备注、备注、备注、备注、备注、备注"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "财务部门",
|
||||||
|
type: 3,
|
||||||
|
parentId: 101,
|
||||||
|
sort: 4,
|
||||||
|
leaderUserId: 103,
|
||||||
|
phone: "15888888888",
|
||||||
|
email: "ry@qq.com",
|
||||||
|
status: 1,
|
||||||
|
id: 106,
|
||||||
|
createTime: 1609837427000,
|
||||||
|
remark: "备注、备注、备注、备注、备注、备注、备注"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
name: "运维部门",
|
||||||
|
type: 3,
|
||||||
|
parentId: 101,
|
||||||
|
sort: 5,
|
||||||
|
leaderUserId: null,
|
||||||
|
phone: "15888888888",
|
||||||
|
email: "ry@qq.com",
|
||||||
|
status: 0,
|
||||||
|
id: 107,
|
||||||
|
createTime: 1609837427000,
|
||||||
|
remark: "备注、备注、备注、备注、备注、备注、备注"
|
||||||
|
}
|
||||||
|
]
|
||||||
|
};
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
url: "/user",
|
||||||
|
method: "post",
|
||||||
|
response: () => {
|
||||||
|
return {
|
||||||
|
code: 0,
|
||||||
|
data: {
|
||||||
|
list: [
|
||||||
|
{
|
||||||
|
username: "admin",
|
||||||
|
nickname: "admin",
|
||||||
|
remark: "管理员",
|
||||||
|
deptId: 103,
|
||||||
|
postIds: [1],
|
||||||
|
mobile: "15888888888",
|
||||||
|
sex: 0,
|
||||||
|
id: 1,
|
||||||
|
status: 0,
|
||||||
|
createTime: 1609837427000,
|
||||||
|
dept: {
|
||||||
|
id: 103,
|
||||||
|
name: "研发部门"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
username: "pure",
|
||||||
|
nickname: "pure",
|
||||||
|
remark: "不要吓我",
|
||||||
|
deptId: 104,
|
||||||
|
postIds: [1],
|
||||||
|
mobile: "15888888888",
|
||||||
|
sex: 0,
|
||||||
|
id: 100,
|
||||||
|
status: 1,
|
||||||
|
createTime: 1609981637000,
|
||||||
|
dept: {
|
||||||
|
id: 104,
|
||||||
|
name: "市场部门"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
username: "小姐姐",
|
||||||
|
nickname: "girl",
|
||||||
|
remark: null,
|
||||||
|
deptId: 106,
|
||||||
|
postIds: null,
|
||||||
|
mobile: "15888888888",
|
||||||
|
sex: 1,
|
||||||
|
id: 103,
|
||||||
|
status: 1,
|
||||||
|
createTime: 1610553035000,
|
||||||
|
dept: {
|
||||||
|
id: 106,
|
||||||
|
name: "财务部门"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
username: "小哥哥",
|
||||||
|
nickname: "boy",
|
||||||
|
remark: null,
|
||||||
|
deptId: 107,
|
||||||
|
postIds: [],
|
||||||
|
mobile: "15888888888",
|
||||||
|
sex: 0,
|
||||||
|
id: 104,
|
||||||
|
status: 0,
|
||||||
|
createTime: 1611166433000,
|
||||||
|
dept: {
|
||||||
|
id: 107,
|
||||||
|
name: "运维部门"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
],
|
||||||
|
total: 4
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
}
|
||||||
|
] as MockMethod[];
|
||||||
209
package.json
@@ -1,102 +1,165 @@
|
|||||||
{
|
{
|
||||||
"name": "vue-pure-admin",
|
"name": "vue-pure-admin",
|
||||||
"version": "2.1.0",
|
"version": "3.4.5",
|
||||||
"private": true,
|
"private": true,
|
||||||
"scripts": {
|
"scripts": {
|
||||||
"dev": "cross-env --max_old_space_size=4096 vite",
|
"dev": "cross-env --max_old_space_size=4096 vite",
|
||||||
"serve": "yarn dev",
|
"serve": "pnpm dev",
|
||||||
"build": "rimraf dist && cross-env vite build",
|
"build": "rimraf dist && cross-env NODE_OPTIONS=--max-old-space-size=8192 vite build",
|
||||||
|
"build:staging": "rimraf dist && cross-env vite build --mode staging",
|
||||||
|
"report": "rimraf dist && cross-env vite build",
|
||||||
"preview": "vite preview",
|
"preview": "vite preview",
|
||||||
"preview:build": "yarn build && vite preview",
|
"preview:build": "pnpm build && vite preview",
|
||||||
"clean:cache": "rm -rf node_modules && rm -rf .eslintcache && yarn cache clean && yarn",
|
"typecheck": "tsc --noEmit && vue-tsc --noEmit --skipLibCheck",
|
||||||
|
"cloc": "cross-env --max_old_space_size=4096 cloc . --exclude-dir=node_modules --exclude-lang=YAML",
|
||||||
|
"clean:cache": "rm -rf node_modules && rm -rf .eslintcache && pnpm install",
|
||||||
"lint:eslint": "eslint --cache --max-warnings 0 \"{src,mock}/**/*.{vue,ts,tsx}\" --fix",
|
"lint:eslint": "eslint --cache --max-warnings 0 \"{src,mock}/**/*.{vue,ts,tsx}\" --fix",
|
||||||
"lint:prettier": "prettier --write \"src/**/*.{js,json,tsx,css,less,scss,vue,html,md}\"",
|
"lint:prettier": "prettier --write \"src/**/*.{js,json,tsx,css,less,scss,vue,html,md}\"",
|
||||||
"lint:stylelint": "stylelint --cache --fix \"**/*.{vue,css,scss,postcss,less}\" --cache --cache-location node_modules/.cache/stylelint/",
|
"lint:stylelint": "stylelint --cache --fix \"**/*.{vue,css,scss,postcss,less}\" --cache --cache-location node_modules/.cache/stylelint/",
|
||||||
"lint:lint-staged": "lint-staged -c ./.husky/lintstagedrc.js",
|
"lint:lint-staged": "lint-staged -c ./.husky/lintstagedrc.js",
|
||||||
"lint:pretty": "pretty-quick --staged",
|
"lint:pretty": "pretty-quick --staged",
|
||||||
"lint": "yarn lint:eslint && yarn lint:prettier && yarn lint:stylelint && yarn lint:pretty",
|
"lint": "pnpm lint:eslint && pnpm lint:prettier && pnpm lint:stylelint",
|
||||||
"prepare": "husky install"
|
"prepare": "husky install",
|
||||||
|
"preinstall": "npx only-allow pnpm"
|
||||||
},
|
},
|
||||||
|
"browserslist": [
|
||||||
|
"> 1%",
|
||||||
|
"not ie 11",
|
||||||
|
"not op_mini all"
|
||||||
|
],
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@amap/amap-jsapi-loader": "^1.0.1",
|
"@amap/amap-jsapi-loader": "^1.0.1",
|
||||||
"@logicflow/core": "^0.4.6",
|
"@ctrl/tinycolor": "^3.4.1",
|
||||||
"@logicflow/extension": "^0.4.6",
|
"@logicflow/core": "^1.1.24",
|
||||||
"@vueuse/core": "^6.5.3",
|
"@logicflow/extension": "^1.1.24",
|
||||||
|
"@pureadmin/components": "^1.1.0",
|
||||||
|
"@pureadmin/descriptions": "^1.1.0",
|
||||||
|
"@pureadmin/table": "^1.2.0",
|
||||||
|
"@pureadmin/utils": "^0.1.1",
|
||||||
|
"@vueuse/core": "^9.1.0",
|
||||||
|
"@vueuse/motion": "^2.0.0-beta.12",
|
||||||
|
"@vueuse/shared": "^9.1.0",
|
||||||
|
"@wangeditor/editor": "^5.1.14",
|
||||||
|
"@wangeditor/editor-for-vue": "^5.1.12",
|
||||||
"animate.css": "^4.1.1",
|
"animate.css": "^4.1.1",
|
||||||
"await-to-js": "^3.0.0",
|
"axios": "^0.27.2",
|
||||||
"axios": "^0.21.1",
|
"china-area-data": "^5.0.1",
|
||||||
"cropperjs": "^1.5.11",
|
"cropperjs": "^1.5.12",
|
||||||
"dayjs": "^1.10.7",
|
"css-color-function": "^1.3.3",
|
||||||
"echarts": "^5.2.1",
|
"dayjs": "^1.11.4",
|
||||||
"element-plus": "1.1.0-beta.20",
|
"driver.js": "^0.9.8",
|
||||||
|
"echarts": "^5.3.3",
|
||||||
|
"element-plus": "^2.2.14",
|
||||||
"element-resize-detector": "^1.2.3",
|
"element-resize-detector": "^1.2.3",
|
||||||
"font-awesome": "^4.7.0",
|
"js-cookie": "^3.0.1",
|
||||||
|
"jsbarcode": "^3.11.5",
|
||||||
|
"lodash": "^4.17.21",
|
||||||
"lodash-es": "^4.17.21",
|
"lodash-es": "^4.17.21",
|
||||||
"lowdb": "^3.0.0",
|
"lodash-unified": "^1.0.2",
|
||||||
"mitt": "^3.0.0",
|
"mitt": "^3.0.0",
|
||||||
"mockjs": "^1.1.0",
|
"mockjs": "^1.1.0",
|
||||||
"nprogress": "^0.2.0",
|
"nprogress": "^0.2.0",
|
||||||
"path": "^0.12.7",
|
"path": "^0.12.7",
|
||||||
"path-to-regexp": "^6.2.0",
|
"pinia": "^2.0.19",
|
||||||
"pinia": "2.0.0-rc.10",
|
"qrcode": "^1.5.1",
|
||||||
|
"qs": "^6.11.0",
|
||||||
"resize-observer-polyfill": "^1.5.1",
|
"resize-observer-polyfill": "^1.5.1",
|
||||||
"responsive-storage": "^1.0.11",
|
"responsive-storage": "^2.1.0",
|
||||||
"sortablejs": "1.13.0",
|
"rgb-hex": "^4.0.0",
|
||||||
"typescript-cookie": "^1.0.0",
|
"sortablejs": "^1.15.0",
|
||||||
"v-contextmenu": "^3.0.0",
|
"swiper": "^8.3.2",
|
||||||
"vue": "^3.2.20",
|
"v-contextmenu": "3.0.0",
|
||||||
"vue-i18n": "^9.2.0-beta.3",
|
"vue": "^3.2.37",
|
||||||
"vue-json-pretty": "^2.0.2",
|
"vue-form-create2": "^1.2.8",
|
||||||
"vue-router": "^4.0.11",
|
"vue-i18n": "^9.2.2",
|
||||||
"vue-types": "^4.1.0",
|
"vue-json-pretty": "^2.1.1",
|
||||||
|
"vue-pdf-embed": "^1.1.4",
|
||||||
|
"vue-router": "^4.1.3",
|
||||||
|
"vue-types": "^4.2.1",
|
||||||
|
"vue-virtual-scroller": "^2.0.0-alpha.1",
|
||||||
"vuedraggable": "^4.1.0",
|
"vuedraggable": "^4.1.0",
|
||||||
"vxe-table": "^4.0.27",
|
"vxe-table": "^4.3.0-beta.5",
|
||||||
"wangeditor": "^4.7.7",
|
"xe-utils": "^3.5.6",
|
||||||
"xe-ajax": "^4.0.5",
|
"xgplayer": "^2.31.7",
|
||||||
"xe-utils": "^3.3.1",
|
"xlsx": "^0.18.5"
|
||||||
"xgplayer": "^2.28.0"
|
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@commitlint/cli": "^13.1.0",
|
"@commitlint/cli": "13.1.0",
|
||||||
"@commitlint/config-conventional": "^13.1.0",
|
"@commitlint/config-conventional": "13.1.0",
|
||||||
"@types/element-resize-detector": "^1.1.3",
|
"@faker-js/faker": "^7.4.0",
|
||||||
"@types/mockjs": "^1.0.3",
|
"@iconify-icons/carbon": "^1.2.8",
|
||||||
"@types/node": "^14.14.14",
|
"@iconify-icons/ep": "^1.2.7",
|
||||||
"@types/nprogress": "^0.2.0",
|
"@iconify-icons/fa": "^1.2.3",
|
||||||
"@typescript-eslint/eslint-plugin": "^4.31.0",
|
"@iconify-icons/fa-solid": "^1.2.3",
|
||||||
"@typescript-eslint/parser": "^4.31.0",
|
"@iconify-icons/fluent": "^1.2.16",
|
||||||
"@vitejs/plugin-vue": "^1.6.0",
|
"@iconify-icons/mdi": "^1.2.8",
|
||||||
"@vitejs/plugin-vue-jsx": "^1.1.7",
|
"@iconify-icons/ri": "^1.2.3",
|
||||||
"@vue/compiler-sfc": "^3.2.20",
|
"@iconify-icons/uil": "^1.2.2",
|
||||||
"@vue/eslint-config-prettier": "^6.0.0",
|
"@iconify/vue": "^3.2.1",
|
||||||
"@vue/eslint-config-typescript": "^7.0.0",
|
"@intlify/vite-plugin-vue-i18n": "^6.0.1",
|
||||||
"autoprefixer": "^10.2.4",
|
"@pureadmin/theme": "^2.4.0",
|
||||||
"babel-plugin-transform-remove-console": "^6.9.4",
|
"@types/element-resize-detector": "1.1.3",
|
||||||
"chalk": "^2.4.2",
|
"@types/js-cookie": "^3.0.1",
|
||||||
"cross-env": "^7.0.3",
|
"@types/lodash": "^4.14.180",
|
||||||
"eslint": "^7.30.0",
|
"@types/lodash-es": "^4.17.6",
|
||||||
"eslint-plugin-prettier": "^3.4.0",
|
"@types/mockjs": "1.0.3",
|
||||||
"eslint-plugin-vue": "^7.17.0",
|
"@types/node": "14.14.14",
|
||||||
"husky": "^7.0.2",
|
"@types/nprogress": "0.2.0",
|
||||||
"lint-staged": "^11.1.2",
|
"@types/qrcode": "^1.4.2",
|
||||||
"postcss": "^8.2.6",
|
"@types/qs": "^6.9.7",
|
||||||
"postcss-import": "^14.0.0",
|
"@types/sortablejs": "^1.13.0",
|
||||||
"prettier": "^2.3.2",
|
"@typescript-eslint/eslint-plugin": "^5.10.2",
|
||||||
"pretty-quick": "^3.1.1",
|
"@typescript-eslint/parser": "^5.10.2",
|
||||||
"rimraf": "^3.0.2",
|
"@vitejs/plugin-legacy": "^2.0.0",
|
||||||
"sass": "^1.38.0",
|
"@vitejs/plugin-vue": "^3.0.1",
|
||||||
"sass-loader": "^12.1.0",
|
"@vitejs/plugin-vue-jsx": "^2.0.0",
|
||||||
"stylelint": "^13.13.1",
|
"@vue/eslint-config-prettier": "^7.0.0",
|
||||||
"stylelint-config-prettier": "^8.0.2",
|
"@vue/eslint-config-typescript": "^10.0.0",
|
||||||
"stylelint-config-standard": "^22.0.0",
|
"@vue/runtime-core": "^3.2.37",
|
||||||
"stylelint-order": "^4.1.0",
|
"autoprefixer": "^10.4.8",
|
||||||
"typescript": "^4.4.2",
|
"cloc": "^2.10.0",
|
||||||
"unplugin-element-plus": "^0.1.0",
|
"cross-env": "7.0.3",
|
||||||
"vite": "^2.6.7",
|
"eslint": "^8.8.0",
|
||||||
|
"eslint-plugin-prettier": "^4.0.0",
|
||||||
|
"eslint-plugin-vue": "^8.4.1",
|
||||||
|
"font-awesome": "^4.7.0",
|
||||||
|
"husky": "^7.0.4",
|
||||||
|
"lint-staged": "11.1.2",
|
||||||
|
"picocolors": "^1.0.0",
|
||||||
|
"postcss": "^8.4.16",
|
||||||
|
"postcss-html": "^1.5.0",
|
||||||
|
"postcss-import": "^14.1.0",
|
||||||
|
"postcss-scss": "^4.0.4",
|
||||||
|
"prettier": "^2.5.1",
|
||||||
|
"pretty-quick": "3.1.1",
|
||||||
|
"rimraf": "3.0.2",
|
||||||
|
"rollup-plugin-visualizer": "^5.7.1",
|
||||||
|
"sass": "^1.53.0",
|
||||||
|
"sass-loader": "^13.0.2",
|
||||||
|
"stylelint": "^14.3.0",
|
||||||
|
"stylelint-config-html": "^1.0.0",
|
||||||
|
"stylelint-config-prettier": "^9.0.3",
|
||||||
|
"stylelint-config-recommended": "^6.0.0",
|
||||||
|
"stylelint-config-standard": "^24.0.0",
|
||||||
|
"stylelint-order": "^5.0.0",
|
||||||
|
"typescript": "^4.7.4",
|
||||||
|
"unocss": "^0.45.9",
|
||||||
|
"unplugin-vue-define-options": "^0.7.3",
|
||||||
|
"vite": "^3.0.9",
|
||||||
"vite-plugin-mock": "^2.9.6",
|
"vite-plugin-mock": "^2.9.6",
|
||||||
"vite-plugin-style-import": "^1.2.1",
|
"vite-plugin-remove-console": "^1.1.0",
|
||||||
"vite-svg-loader": "^2.2.0",
|
"vite-svg-loader": "^3.4.0",
|
||||||
"vue-eslint-parser": "^7.10.0"
|
"vue-eslint-parser": "^8.2.0",
|
||||||
|
"vue-tsc": "^0.40.1"
|
||||||
|
},
|
||||||
|
"pnpm": {
|
||||||
|
"peerDependencyRules": {
|
||||||
|
"ignoreMissing": [
|
||||||
|
"rollup",
|
||||||
|
"terser",
|
||||||
|
"webpack"
|
||||||
|
]
|
||||||
|
}
|
||||||
},
|
},
|
||||||
"repository": "git@github.com:xiaoxian521/vue-pure-admin.git",
|
"repository": "git@github.com:xiaoxian521/vue-pure-admin.git",
|
||||||
"author": "xiaoxian521",
|
"author": "xiaoxian521",
|
||||||
|
|||||||
9567
pnpm-lock.yaml
generated
Normal file
|
Before Width: | Height: | Size: 66 KiB After Width: | Height: | Size: 1.2 KiB |
@@ -1,18 +0,0 @@
|
|||||||
@font-face {
|
|
||||||
font-family: "iconfont"; /* project id 1098500 */
|
|
||||||
src: url("//at.alicdn.com/t/font_1098500_3d6un9zwltz.eot");
|
|
||||||
src: url("//at.alicdn.com/t/font_1098500_3d6un9zwltz.eot?#iefix")
|
|
||||||
format("embedded-opentype"),
|
|
||||||
url("//at.alicdn.com/t/font_1098500_3d6un9zwltz.woff2") format("woff2"),
|
|
||||||
url("//at.alicdn.com/t/font_1098500_3d6un9zwltz.woff") format("woff"),
|
|
||||||
url("//at.alicdn.com/t/font_1098500_3d6un9zwltz.ttf") format("truetype"),
|
|
||||||
url("//at.alicdn.com/t/font_1098500_3d6un9zwltz.svg#iconfont") format("svg");
|
|
||||||
}
|
|
||||||
|
|
||||||
.iconfont {
|
|
||||||
font-family: "iconfont" !important;
|
|
||||||
font-size: 16px;
|
|
||||||
font-style: normal;
|
|
||||||
-webkit-font-smoothing: antialiased;
|
|
||||||
-moz-osx-font-smoothing: grayscale;
|
|
||||||
}
|
|
||||||
@@ -1,11 +1,23 @@
|
|||||||
{
|
{
|
||||||
"Version": "2.0.0",
|
"Version": "3.4.5",
|
||||||
|
"Title": "PureAdmin",
|
||||||
|
"FixedHeader": true,
|
||||||
|
"HiddenSideBar": false,
|
||||||
|
"MultiTagsCache": false,
|
||||||
"KeepAlive": true,
|
"KeepAlive": true,
|
||||||
"Locale": "zh",
|
"Locale": "zh",
|
||||||
"Layout": "vertical-dark",
|
"Layout": "vertical",
|
||||||
|
"Theme": "default",
|
||||||
|
"DarkMode": false,
|
||||||
|
"Grey": false,
|
||||||
|
"Weak": false,
|
||||||
|
"HideTabs": false,
|
||||||
|
"SidebarStatus": true,
|
||||||
|
"EpThemeColor": "#409EFF",
|
||||||
|
"ShowLogo": true,
|
||||||
|
"ShowModel": "smart",
|
||||||
"MapConfigure": {
|
"MapConfigure": {
|
||||||
"amapKey": "97b3248d1553172e81f168cf94ea667e",
|
"amapKey": "97b3248d1553172e81f168cf94ea667e",
|
||||||
"baiduKey": "wTHbkkEweiFqZLKunMIjcrb2RcqNXkhc",
|
|
||||||
"options": {
|
"options": {
|
||||||
"resizeEnable": true,
|
"resizeEnable": true,
|
||||||
"center": [113.6401, 34.72468],
|
"center": [113.6401, 34.72468],
|
||||||
|
|||||||
2607
public/sortable.min.js
vendored
13
src/App.vue
@@ -5,24 +5,19 @@
|
|||||||
</template>
|
</template>
|
||||||
|
|
||||||
<script lang="ts">
|
<script lang="ts">
|
||||||
|
import { defineComponent } from "vue";
|
||||||
import { ElConfigProvider } from "element-plus";
|
import { ElConfigProvider } from "element-plus";
|
||||||
import zhCn from "element-plus/lib/locale/lang/zh-cn";
|
import zhCn from "element-plus/lib/locale/lang/zh-cn";
|
||||||
import en from "element-plus/lib/locale/lang/en";
|
import en from "element-plus/lib/locale/lang/en";
|
||||||
export default {
|
export default defineComponent({
|
||||||
name: "app",
|
name: "app",
|
||||||
components: {
|
components: {
|
||||||
[ElConfigProvider.name]: ElConfigProvider
|
[ElConfigProvider.name]: ElConfigProvider
|
||||||
},
|
},
|
||||||
computed: {
|
computed: {
|
||||||
// eslint-disable-next-line vue/return-in-computed-property
|
|
||||||
currentLocale() {
|
currentLocale() {
|
||||||
switch (this.$storage.locale?.locale) {
|
return this.$storage.locale?.locale === "zh" ? zhCn : en;
|
||||||
case "zh":
|
|
||||||
return zhCn;
|
|
||||||
case "en":
|
|
||||||
return en;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
});
|
||||||
</script>
|
</script>
|
||||||
|
|||||||
15
src/api/list.ts
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
import { http } from "../utils/http";
|
||||||
|
|
||||||
|
type Result = {
|
||||||
|
data?: {
|
||||||
|
/** 列表数据 */
|
||||||
|
list: Array<any>;
|
||||||
|
};
|
||||||
|
code?: number;
|
||||||
|
msg?: string;
|
||||||
|
};
|
||||||
|
|
||||||
|
// 卡片列表
|
||||||
|
export const getCardList = (data?: object) => {
|
||||||
|
return http.request<Result>("post", "/getCardList", { data });
|
||||||
|
};
|
||||||
@@ -1,11 +1,11 @@
|
|||||||
import { http } from "../utils/http";
|
import { http } from "../utils/http";
|
||||||
|
|
||||||
// 地图数据
|
type Result = {
|
||||||
export const mapJson = (data?: object) => {
|
code: number;
|
||||||
return http.request("get", "/getMapInfo", data);
|
info: Array<any>;
|
||||||
};
|
};
|
||||||
|
|
||||||
// echarts数据
|
// 地图数据
|
||||||
export const echartsJson = (data?: object) => {
|
export const mapJson = (params?: object) => {
|
||||||
return http.request("get", "/getEchartsInfo", data);
|
return http.request<Result>("get", "/getMapInfo", { params });
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -1,5 +1,10 @@
|
|||||||
import { http } from "../utils/http";
|
import { http } from "../utils/http";
|
||||||
|
|
||||||
export const getAsyncRoutes = (data?: object) => {
|
type Result = {
|
||||||
return http.request("get", "/getAsyncRoutes", data);
|
code: number;
|
||||||
|
info: Array<any>;
|
||||||
|
};
|
||||||
|
|
||||||
|
export const getAsyncRoutes = (params?: object) => {
|
||||||
|
return http.request<Result>("get", "/getAsyncRoutes", { params });
|
||||||
};
|
};
|
||||||
|
|||||||
27
src/api/system.ts
Normal file
@@ -0,0 +1,27 @@
|
|||||||
|
import { http } from "../utils/http";
|
||||||
|
|
||||||
|
type Result = {
|
||||||
|
data?: {
|
||||||
|
/** 列表数据 */
|
||||||
|
list: Array<any>;
|
||||||
|
/** 总数 */
|
||||||
|
total: number;
|
||||||
|
};
|
||||||
|
code?: number;
|
||||||
|
msg?: string;
|
||||||
|
};
|
||||||
|
|
||||||
|
// 获取用户管理列表
|
||||||
|
export const getUserList = (data?: object) => {
|
||||||
|
return http.request<Result>("post", "/user", { data });
|
||||||
|
};
|
||||||
|
|
||||||
|
// 获取角色管理列表
|
||||||
|
export const getRoleList = (data?: object) => {
|
||||||
|
return http.request<Result>("post", "/role", { data });
|
||||||
|
};
|
||||||
|
|
||||||
|
// 获取部门管理列表
|
||||||
|
export const getDeptList = (data?: object) => {
|
||||||
|
return http.request<Result>("post", "/dept", { data });
|
||||||
|
};
|
||||||
@@ -1,16 +1,26 @@
|
|||||||
import { http } from "../utils/http";
|
import { http } from "../utils/http";
|
||||||
|
|
||||||
|
type Result = {
|
||||||
|
svg?: string;
|
||||||
|
code?: number;
|
||||||
|
info?: object;
|
||||||
|
};
|
||||||
|
|
||||||
// 获取验证码
|
// 获取验证码
|
||||||
export const getVerify = () => {
|
export const getVerify = () => {
|
||||||
return http.request("get", "/captcha");
|
return http.request<Result>("get", "/captcha");
|
||||||
};
|
};
|
||||||
|
|
||||||
// 登录
|
// 登录
|
||||||
export const getLogin = (data: object) => {
|
export const getLogin = (data: object) => {
|
||||||
return http.request("post", "/login", data);
|
return http.request("post", "/login", { data });
|
||||||
};
|
};
|
||||||
|
|
||||||
// 注册
|
// 刷新token
|
||||||
export const getRegist = (data: object) => {
|
export const refreshToken = (data: object) => {
|
||||||
return http.request("post", "/register", data);
|
return http.request("post", "/refreshToken", { data });
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// export const searchVague = (data: object) => {
|
||||||
|
// return http.request("post", "/searchVague", { data });
|
||||||
|
// };
|
||||||
|
|||||||
|
Before Width: | Height: | Size: 160 KiB |
|
Before Width: | Height: | Size: 96 KiB |
|
Before Width: | Height: | Size: 4.7 KiB |
BIN
src/assets/avatars.jpg
Normal file
|
After Width: | Height: | Size: 23 KiB |
|
Before Width: | Height: | Size: 1.1 MiB |
|
Before Width: | Height: | Size: 1.4 KiB After Width: | Height: | Size: 1.4 KiB |
@@ -1,8 +1,8 @@
|
|||||||
@font-face {
|
@font-face {
|
||||||
font-family: "iconfont"; /* Project id 2208059 */
|
font-family: "iconfont"; /* Project id 2208059 */
|
||||||
src: url("iconfont.woff2?t=1634092870259") format("woff2"),
|
src: url("iconfont.woff2?t=1638023560828") format("woff2"),
|
||||||
url("iconfont.woff?t=1634092870259") format("woff"),
|
url("iconfont.woff?t=1638023560828") format("woff"),
|
||||||
url("iconfont.ttf?t=1634092870259") format("truetype");
|
url("iconfont.ttf?t=1638023560828") format("truetype");
|
||||||
}
|
}
|
||||||
|
|
||||||
.iconfont {
|
.iconfont {
|
||||||
@@ -13,8 +13,12 @@
|
|||||||
-moz-osx-font-smoothing: grayscale;
|
-moz-osx-font-smoothing: grayscale;
|
||||||
}
|
}
|
||||||
|
|
||||||
.team-iconzuixinlianzai::before {
|
.team-icontabs::before {
|
||||||
content: "\e6da";
|
content: "\e63e";
|
||||||
|
}
|
||||||
|
|
||||||
|
.team-iconlogo::before {
|
||||||
|
content: "\e620";
|
||||||
}
|
}
|
||||||
|
|
||||||
.team-iconxinpin::before {
|
.team-iconxinpin::before {
|
||||||
@@ -25,22 +29,6 @@
|
|||||||
content: "\e615";
|
content: "\e615";
|
||||||
}
|
}
|
||||||
|
|
||||||
.team-iconinternationality::before {
|
|
||||||
content: "\e67a";
|
|
||||||
}
|
|
||||||
|
|
||||||
.team-iconshanchu::before {
|
|
||||||
content: "\e617";
|
|
||||||
}
|
|
||||||
|
|
||||||
.team-iconshow-main-container::before {
|
|
||||||
content: "\e878";
|
|
||||||
}
|
|
||||||
|
|
||||||
.team-iconhidden-main-container::before {
|
|
||||||
content: "\e881";
|
|
||||||
}
|
|
||||||
|
|
||||||
.team-iconexit-fullscreen::before {
|
.team-iconexit-fullscreen::before {
|
||||||
content: "\e62a";
|
content: "\e62a";
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -6,11 +6,18 @@
|
|||||||
"description": "pure-admin",
|
"description": "pure-admin",
|
||||||
"glyphs": [
|
"glyphs": [
|
||||||
{
|
{
|
||||||
"icon_id": "2508809",
|
"icon_id": "20594647",
|
||||||
"name": "最新连载",
|
"name": "标签页",
|
||||||
"font_class": "zuixinlianzai",
|
"font_class": "tabs",
|
||||||
"unicode": "e6da",
|
"unicode": "e63e",
|
||||||
"unicode_decimal": 59098
|
"unicode_decimal": 58942
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"icon_id": "22129506",
|
||||||
|
"name": "水能",
|
||||||
|
"font_class": "logo",
|
||||||
|
"unicode": "e620",
|
||||||
|
"unicode_decimal": 58912
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"icon_id": "7795613",
|
"icon_id": "7795613",
|
||||||
@@ -26,34 +33,6 @@
|
|||||||
"unicode": "e615",
|
"unicode": "e615",
|
||||||
"unicode_decimal": 58901
|
"unicode_decimal": 58901
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"icon_id": "18367956",
|
|
||||||
"name": "中英文2 中文",
|
|
||||||
"font_class": "internationality",
|
|
||||||
"unicode": "e67a",
|
|
||||||
"unicode_decimal": 59002
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"icon_id": "6184565",
|
|
||||||
"name": "删除",
|
|
||||||
"font_class": "shanchu",
|
|
||||||
"unicode": "e617",
|
|
||||||
"unicode_decimal": 58903
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"icon_id": "9626913",
|
|
||||||
"name": "全屏",
|
|
||||||
"font_class": "show-main-container",
|
|
||||||
"unicode": "e878",
|
|
||||||
"unicode_decimal": 59512
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"icon_id": "9626952",
|
|
||||||
"name": "退出全屏",
|
|
||||||
"font_class": "hidden-main-container",
|
|
||||||
"unicode": "e881",
|
|
||||||
"unicode_decimal": 59521
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"icon_id": "5698509",
|
"icon_id": "5698509",
|
||||||
"name": "全屏缩小",
|
"name": "全屏缩小",
|
||||||
|
|||||||
|
Before Width: | Height: | Size: 9.9 KiB |
1
src/assets/login/avatar.svg
Normal file
@@ -0,0 +1 @@
|
|||||||
|
<svg t="1636193306629" class="icon" viewBox="0 0 1024 1024" version="1.1" xmlns="http://www.w3.org/2000/svg" p-id="1847" width="32" height="32"><path d="M410.558481 0.10861C410.558481 211.083075 109.682285 361.860579 109.682285 633.656511c0 174.943176 134.703259 316.787527 300.876196 316.787527s300.876197-141.817198 300.876197-316.787527C711.407525 361.751969 410.558481 210.974465 410.558481 0.10861z" fill="#386BF3" p-id="1848"></path><path d="M613.468671 73.664572c0 211.055922-300.876197 361.914883-300.876196 633.547901 0 174.943176 134.703259 316.787527 300.876196 316.787527s300.876197-141.817198 300.876197-316.787527c-0.054305-271.633018-300.876197-422.491979-300.876197-633.547901z" fill="#C3D2FB" p-id="1849"></path><path d="M312.592475 707.212473c0-183.713414 137.635722-312.171612 226.72288-441.390078 81.701694 106.111739 172.119322 218.740063 172.119323 367.725506a309.755045 309.755045 0 0 1-291.074166 316.516003 323.114046 323.114046 0 0 1-107.768037-242.851431z" fill="#303F5B" p-id="1850"></path></svg>
|
||||||
|
After Width: | Height: | Size: 1.0 KiB |
BIN
src/assets/login/bg.png
Normal file
|
After Width: | Height: | Size: 17 KiB |
1
src/assets/login/illustration0.svg
Normal file
|
After Width: | Height: | Size: 20 KiB |
1
src/assets/login/illustration1.svg
Normal file
|
After Width: | Height: | Size: 17 KiB |
1
src/assets/login/illustration2.svg
Normal file
@@ -0,0 +1 @@
|
|||||||
|
<svg xmlns="http://www.w3.org/2000/svg" data-name="Layer 1" width="500" height="380" viewBox="0 0 896 529.1129" xmlns:xlink="http://www.w3.org/1999/xlink"><path d="M832.06729,623.22778s-26.37759,9.89441-38.806,32.94348S787.06,706.69574,787.06,706.69574s26.37759-9.89447,38.806-32.94348S832.06729,623.22778,832.06729,623.22778Z" transform="translate(-158 -185.8871)" fill="#3f3d56"/><path d="M867.5,657.59637s-8.64182,26.814-31.0802,40.31373-50.17651,8.57293-50.17651,8.57293,8.64175-26.81408,31.08017-40.31378S867.5,657.59637,867.5,657.59637Z" transform="translate(-158 -185.8871)" fill="#5392f0"/><rect y="527.1129" width="896" height="2" fill="#2f2e41"/><path d="M519.87238,620.97461a95.44448,95.44448,0,0,1-35.748-14.44629L485.306,604.915a93.36283,93.36283,0,0,0,34.999,14.10547c18.93164,3.40137,47.26075,1.73144,74.707-25.52735,53.41358-53.04785,104.39307-58.39062,104.90186-58.43847l.18652,1.99219c-.50146.04687-50.76806,5.31738-103.67822,57.86621-21.61328,21.46386-43.792,27.40234-61.71777,27.40234A83.49962,83.49962,0,0,1,519.87238,620.97461Z" transform="translate(-158 -185.8871)" fill="#2f2e41"/><circle cx="515.15271" cy="381.1129" r="12" fill="#2f2e41"/><circle cx="430.15271" cy="437.1129" r="12" fill="#2f2e41"/><path d="M841.5,714s-17.46191-5.41315-52.26129-10.84192L790,692.5c6-60-34-150-34-150a401.561,401.561,0,0,1,21.4693,139.0246C772.13214,672.2124,761.82056,662.16638,742,656c0,0,25.77765,22.106,33.15918,45.10175a997.84042,997.84042,0,0,0-102.02258-8.21589L682,672.5l-17,17s-7-51-22-53l11,50s-13-10-16-9l7.39746,14.79486c-49.819-.51654-109.08453,1.7356-177.76581,8.95227L476,682l-17,17s-7-51-22-53l11,50s-13-10-16-9l8.64288,17.28583Q406.9763,708.2897,370.5,714Z" transform="translate(-158 -185.8871)" fill="#3f3d56"/><path d="M565.64813,230.37817c-10.89964,11.74783,17.59745,40.25959,17.59745,40.25959s-57.70662,9.73051-53.12783,9.14083,2.20622-49.13151,2.20622-49.13151S576.54777,218.63035,565.64813,230.37817Z" transform="translate(-158 -185.8871)" fill="#a0616a"/><path d="M605.81236,356.10945l-50.139,25.6141-27.22969,15.6059s-32.09862,40.43116-38.08709,64.39234,25.92963,68.247,29.54371,72.82286a54.36088,54.36088,0,0,1,4.98908,7.42355c1.24727,1.85589,12.02944-.541,23.80342-3.06554S547.13,518.93875,547.13,518.93875s-15.02732-38.39505-16.14686-39.25912c-1.04554-.807-4.60093-7.44631-2.04309-10.35234a25.94993,25.94993,0,0,0,5.44489-8.89825,30.09064,30.09064,0,0,1,4.18709-7.94151s45.361-36.83645,59.52776-49.37835,51.82952-4.65839,51.82952-4.65839-17.78167,68.20027-22.22979,72.80616-4.929,8.70085-2.91535,16.50759,28.28157.39078,28.28157.39078L662.766,461.6996s15.74879-34.2925,24.29946-69.67451c4.27533-17.691-3.88828-28.23462-13.12073-34.35549a41.39094,41.39094,0,0,0-30.02983-5.97766l-46.34848,8.1308,32.14706-13.84923Z" transform="translate(-158 -185.8871)" fill="#2f2e41"/><path d="M420.87777,290.19133,361.02366,271.685s-24.179-31.16689-12.78824-36.6669,25.65172,26.94419,25.65172,26.94419l41.686,2.69751Z" transform="translate(-158 -185.8871)" fill="#a0616a"/><path d="M672.49431,257.78673l53.2121-33.06768s15.49333-36.27612,3.0807-38.71059-17.98787,32.56435-17.98787,32.56435l-39.64232,13.17143Z" transform="translate(-158 -185.8871)" fill="#a0616a"/><path d="M682.45318,220.40023l1.01427,39.19147-89.68779,16.025c13.19231,28.22441,9.84118,60.34675,43.04725,74.4259L524.9027,404.78717c4.9871-43.03806-15.81748-75.456-35.263-115.75876-23.68547-8.58589-51.19594-2.29078-80.33649,10.34619l-5.237-40.66416,123.87841-8.896,20.34848,7.77932,21.81842-9.17677C602.17891,238.88953,648.22076,220.77584,682.45318,220.40023Z" transform="translate(-158 -185.8871)" fill="#5392f0"/><path d="M626.64006,486.51727c-2.72,2.36681-5.25213,21.84984-5.34982,28.92023s9.21178,8.89624,14.29855,9.2494,4.47816,3.45631,7.83678,6.04854,14.39625,2.179,28.89019-2.71238-9.75274-20.92568-11.86409-21.662-11-22.78156-11-22.78156S629.36,484.15046,626.64006,486.51727Z" transform="translate(-158 -185.8871)" fill="#2f2e41"/><path d="M547.368,531.00717c3.23089,1.60043,10.61681,19.80614,12.50274,26.62107s-6.65716,10.93994-11.48848,12.5704-3.45631,4.47816-6.04855,7.83678-13.3744,5.75546-28.63472,4.696,4.13258-22.71391,5.98847-23.96118,4.86893-24.82526,4.86893-24.82526S544.13715,529.40674,547.368,531.00717Z" transform="translate(-158 -185.8871)" fill="#2f2e41"/><circle cx="389.47074" cy="35.42904" r="23.99585" fill="#a0616a"/><path d="M519.73448,218.90923a22.82668,22.82668,0,0,1-.83378-18.59281c2.35891-5.8153,7.59174-11.65569,18.87309-13.4,24.61387-3.80572,37.71267,13.43543,37.02452,19.07449s-3.99294,19.27051-3.99294,19.27051,1.47587-12.90619-4.85883-13.362-30.90178-2.37835-37.12217,4.145a14.23268,14.23268,0,0,0-3.71042,13.82977Z" transform="translate(-158 -185.8871)" fill="#2f2e41"/></svg>
|
||||||
|
After Width: | Height: | Size: 4.6 KiB |
1
src/assets/login/illustration3.svg
Normal file
|
After Width: | Height: | Size: 11 KiB |
1
src/assets/login/illustration4.svg
Normal file
|
After Width: | Height: | Size: 12 KiB |
1
src/assets/login/illustration5.svg
Normal file
|
After Width: | Height: | Size: 29 KiB |
1
src/assets/login/illustration6.svg
Normal file
|
After Width: | Height: | Size: 11 KiB |
1
src/assets/status/403.svg
Normal file
|
After Width: | Height: | Size: 12 KiB |
1
src/assets/status/404.svg
Normal file
|
After Width: | Height: | Size: 13 KiB |
1
src/assets/status/500.svg
Normal file
|
After Width: | Height: | Size: 15 KiB |
1
src/assets/svg/back.svg
Normal file
@@ -0,0 +1 @@
|
|||||||
|
<svg width="32" height="32" viewBox="0 0 48 48"><path fill="#2F88FF" fill-rule="evenodd" stroke="#000" stroke-linejoin="round" stroke-width="4" d="M44 40.8361C39.1069 34.8632 34.7617 31.4739 30.9644 30.6682C27.1671 29.8625 23.5517 29.7408 20.1182 30.303V41L4 23.5453L20.1182 7V17.167C26.4667 17.2172 31.8638 19.4948 36.3095 24C40.7553 28.5052 43.3187 34.1172 44 40.8361Z" clip-rule="evenodd"/></svg>
|
||||||
|
After Width: | Height: | Size: 399 B |
1
src/assets/svg/back_top.svg
Normal file
@@ -0,0 +1 @@
|
|||||||
|
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" width="24" height="24"><path fill="none" d="M0 0h24v24H0z"/><path d="M2.88 18.054a35.897 35.897 0 0 1 8.531-16.32.8.8 0 0 1 1.178 0c.166.18.304.332.413.455a35.897 35.897 0 0 1 8.118 15.865c-2.141.451-4.34.747-6.584.874l-2.089 4.178a.5.5 0 0 1-.894 0l-2.089-4.178a44.019 44.019 0 0 1-6.584-.874zm6.698-1.123l1.157.066L12 19.527l1.265-2.53 1.157-.066a42.137 42.137 0 0 0 4.227-.454A33.913 33.913 0 0 0 12 4.09a33.913 33.913 0 0 0-6.649 12.387c1.395.222 2.805.374 4.227.454zM12 15a3 3 0 1 1 0-6 3 3 0 0 1 0 6zm0-2a1 1 0 1 0 0-2 1 1 0 0 0 0 2z"/></svg>
|
||||||
|
After Width: | Height: | Size: 608 B |
1
src/assets/svg/calendar.svg
Normal file
@@ -0,0 +1 @@
|
|||||||
|
<svg fill="none" viewBox="0 0 16 16" width="1em" height="1em" class="t-icon t-icon-calendar" data-v-7be81122=""><path fill="currentColor" d="M10 3H6V1.5H5V3H3a1 1 0 00-1 1v9a1 1 0 001 1h10a1 1 0 001-1V4a1 1 0 00-1-1h-2V1.5h-1V3zM5 5h1V4h4v1h1V4h2v2H3V4h2v1zM3 7h10v6H3V7z" fillOpacity="0.9"></path></svg>
|
||||||
|
After Width: | Height: | Size: 304 B |
1
src/assets/svg/dark.svg
Normal file
@@ -0,0 +1 @@
|
|||||||
|
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" width="16" height="16"><path fill="none" d="M0 0h24v24H0z"/><path d="M11.38 2.019a7.5 7.5 0 1 0 10.6 10.6C21.662 17.854 17.316 22 12.001 22 6.477 22 2 17.523 2 12c0-5.315 4.146-9.661 9.38-9.981z"/></svg>
|
||||||
|
After Width: | Height: | Size: 263 B |
1
src/assets/svg/day.svg
Normal file
@@ -0,0 +1 @@
|
|||||||
|
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" width="16" height="16"><path fill="none" d="M0 0h24v24H0z"/><path d="M12 18a6 6 0 1 1 0-12 6 6 0 0 1 0 12zM11 1h2v3h-2V1zm0 19h2v3h-2v-3zM3.515 4.929l1.414-1.414L7.05 5.636 5.636 7.05 3.515 4.93zM16.95 18.364l1.414-1.414 2.121 2.121-1.414 1.414-2.121-2.121zm2.121-14.85l1.414 1.415-2.121 2.121-1.414-1.414 2.121-2.121zM5.636 16.95l1.414 1.414-2.121 2.121-1.414-1.414 2.121-2.121zM23 11v2h-3v-2h3zM4 11v2H1v-2h3z"/></svg>
|
||||||
|
After Width: | Height: | Size: 480 B |
1
src/assets/svg/enter_outlined.svg
Normal file
@@ -0,0 +1 @@
|
|||||||
|
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" aria-hidden="true" role="img" class="iconify iconify--ant-design" width="20" height="20" preserveAspectRatio="xMidYMid meet" viewBox="0 0 1024 1024"><path fill="currentColor" d="M864 170h-60c-4.4 0-8 3.6-8 8v518H310v-73c0-6.7-7.8-10.5-13-6.3l-141.9 112a8 8 0 0 0 0 12.6l141.9 112c5.3 4.2 13 .4 13-6.3v-75h498c35.3 0 64-28.7 64-64V178c0-4.4-3.6-8-8-8z"></path></svg>
|
||||||
|
After Width: | Height: | Size: 448 B |
@@ -1 +1 @@
|
|||||||
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" aria-hidden="true" role="img" width="1em" height="1em" class="re-screen" preserveAspectRatio="xMidYMid meet" viewBox="0 0 16 16"><g fill="currentColor"><path d="M3.5 4H1V3h2V1h1v2.5l-.5.5zM13 3V1h-1v2.5l.5.5H15V3h-2zm-1 9.5V15h1v-2h2v-1h-2.5l-.5.5zM1 12v1h2v2h1v-2.5l-.5-.5H1zm11-1.5l-.5.5h-7l-.5-.5v-5l.5-.5h7l.5.5v5zM10 7H6v2h4V7z"></path></g></svg>
|
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" aria-hidden="true" role="img" width="1em" height="1em" class="re-screen" color="#00000073" preserveAspectRatio="xMidYMid meet" viewBox="0 0 16 16"><g fill="currentColor"><path d="M3.5 4H1V3h2V1h1v2.5l-.5.5zM13 3V1h-1v2.5l.5.5H15V3h-2zm-1 9.5V15h1v-2h2v-1h-2.5l-.5.5zM1 12v1h2v2h1v-2.5l-.5-.5H1zm11-1.5l-.5.5h-7l-.5-.5v-5l.5-.5h7l.5.5v5zM10 7H6v2h4V7z"></path></g></svg>
|
||||||
|
Before Width: | Height: | Size: 434 B After Width: | Height: | Size: 452 B |
@@ -1 +1 @@
|
|||||||
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" aria-hidden="true" role="img" width="1em" height="1em" class="re-screen" preserveAspectRatio="xMidYMid meet" viewBox="0 0 16 16"><g fill="currentColor"><path d="M3 12h10V4H3v8zm2-6h6v4H5V6zM2 6H1V2.5l.5-.5H5v1H2v3zm13-3.5V6h-1V3h-3V2h3.5l.5.5zM14 10h1v3.5l-.5.5H11v-1h3v-3zM2 13h3v1H1.5l-.5-.5V10h1v3z"></path></g></svg>
|
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" aria-hidden="true" role="img" width="1em" height="1em" class="re-screen" color="#00000073" preserveAspectRatio="xMidYMid meet" viewBox="0 0 16 16"><g fill="currentColor"><path d="M3 12h10V4H3v8zm2-6h6v4H5V6zM2 6H1V2.5l.5-.5H5v1H2v3zm13-3.5V6h-1V3h-3V2h3.5l.5.5zM14 10h1v3.5l-.5.5H11v-1h3v-3zM2 13h3v1H1.5l-.5-.5V10h1v3z"></path></g></svg>
|
||||||
|
Before Width: | Height: | Size: 403 B After Width: | Height: | Size: 421 B |
1
src/assets/svg/laptop.svg
Normal file
@@ -0,0 +1 @@
|
|||||||
|
<svg fill="none" viewBox="0 0 16 16" width="1em" height="1em" class="t-icon t-icon-laptop" data-v-7be81122=""><path fill="currentColor" d="M2.5 12a1 1 0 01-1-1V4a1 1 0 011-1h11a1 1 0 011 1v7a1 1 0 01-1 1h-11zm0-1h11V4h-11v7zM15 13H1v1h14v-1z" fillOpacity="0.9"></path></svg>
|
||||||
|
After Width: | Height: | Size: 274 B |
1
src/assets/svg/mdi_keyboard_esc.svg
Normal file
@@ -0,0 +1 @@
|
|||||||
|
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" aria-hidden="true" role="img" class="iconify iconify--mdi" width="20" height="20" preserveAspectRatio="xMidYMid meet" viewBox="0 0 24 24"><path fill="currentColor" d="M1 7h6v2H3v2h4v2H3v2h4v2H1V7m10 0h4v2h-4v2h2a2 2 0 0 1 2 2v2c0 1.11-.89 2-2 2H9v-2h4v-2h-2a2 2 0 0 1-2-2V9c0-1.1.9-2 2-2m8 0h2a2 2 0 0 1 2 2v1h-2V9h-2v6h2v-1h2v1c0 1.11-.89 2-2 2h-2a2 2 0 0 1-2-2V9c0-1.1.9-2 2-2Z"></path></svg>
|
||||||
|
After Width: | Height: | Size: 477 B |
1
src/assets/svg/service.svg
Normal file
@@ -0,0 +1 @@
|
|||||||
|
<svg fill="none" viewBox="0 0 16 16" width="1em" height="1em" class="t-icon t-icon-service" data-v-7be81122=""><path fill="currentColor" d="M2.52 6.37a5.5 5.5 0 0110.98.13v4c0 .05 0 .1-.02.15A4.5 4.5 0 019 14.7H8v-1h1a3.5 3.5 0 003.4-2.7h-1.9a.5.5 0 01-.5-.5v-4c0-.28.22-.5.5-.5h1.93a4.5 4.5 0 00-8.86 0H5.5c.28 0 .5.22.5.5v4a.5.5 0 01-.5.5H3a.5.5 0 01-.5-.5v-4c0-.04 0-.09.02-.13zM12.5 7H11v3h1.5V7zm-9 0v3H5V7H3.5z" fillOpacity="0.9"></path></svg>
|
||||||
|
After Width: | Height: | Size: 449 B |
1
src/assets/svg/shop.svg
Normal file
@@ -0,0 +1 @@
|
|||||||
|
<svg fill="none" viewBox="0 0 16 16" width="1em" height="1em" class="t-icon t-icon-shop" data-v-7be81122=""><path fill="currentColor" d="M8 1a2.5 2.5 0 00-2.5 2.5V5h-2a.5.5 0 00-.5.5v9c0 .28.22.5.5.5h9a.5.5 0 00.5-.5v-9a.5.5 0 00-.5-.5h-2V3.5A2.5 2.5 0 008 1zm1.5 5v2h1V6H12v8H4V6h1.5v2h1V6h3zm0-1h-3V3.5a1.5 1.5 0 113 0V5z" fillOpacity="0.9"></path></svg>
|
||||||
|
After Width: | Height: | Size: 356 B |
1
src/assets/svg/user_avatar.svg
Normal file
@@ -0,0 +1 @@
|
|||||||
|
<svg fill="none" viewBox="0 0 16 16" width="1em" height="1em" class="t-icon t-icon-user-avatar" data-v-7be81122=""><path fill="currentColor" d="M8 10.5c1.24 0 2.42.31 3.5.88v1.12h1v-1.14a.94.94 0 00-.49-.84 8.48 8.48 0 00-8.02 0 .94.94 0 00-.49.84v1.14h1v-1.12A7.47 7.47 0 018 10.5zM10.5 6a2.5 2.5 0 11-5 0 2.5 2.5 0 015 0zm-1 0a1.5 1.5 0 10-3 0 1.5 1.5 0 003 0z"></path><path fill="currentColor" d="M2.5 1.5a1 1 0 00-1 1v11a1 1 0 001 1h11a1 1 0 001-1v-11a1 1 0 00-1-1h-11zm11 1v11h-11v-11h11z"></path></svg>
|
||||||
|
After Width: | Height: | Size: 508 B |
7
src/components/ReBarcode/index.ts
Normal file
@@ -0,0 +1,7 @@
|
|||||||
|
import reBarcode from "./src/index.vue";
|
||||||
|
import { withInstall } from "@pureadmin/utils";
|
||||||
|
|
||||||
|
/** 条形码组件 */
|
||||||
|
export const ReBarcode = withInstall(reBarcode);
|
||||||
|
|
||||||
|
export default ReBarcode;
|
||||||
42
src/components/ReBarcode/src/index.vue
Normal file
@@ -0,0 +1,42 @@
|
|||||||
|
<script setup lang="ts">
|
||||||
|
import JsBarcode from "jsbarcode";
|
||||||
|
import { ref, onMounted } from "vue";
|
||||||
|
|
||||||
|
defineOptions({
|
||||||
|
name: "ReBarcode"
|
||||||
|
});
|
||||||
|
|
||||||
|
const props = defineProps({
|
||||||
|
tag: {
|
||||||
|
type: String,
|
||||||
|
default: "canvas"
|
||||||
|
},
|
||||||
|
text: {
|
||||||
|
type: String,
|
||||||
|
default: null
|
||||||
|
},
|
||||||
|
// 完整配置 https://github.com/lindell/JsBarcode/wiki/Options
|
||||||
|
options: {
|
||||||
|
type: Object,
|
||||||
|
default() {
|
||||||
|
return {};
|
||||||
|
}
|
||||||
|
},
|
||||||
|
// type 相当于 options.format,如果 type 和 options.format 同时存在,type 值优先;
|
||||||
|
type: {
|
||||||
|
type: String,
|
||||||
|
default: "CODE128"
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
const wrapEl = ref(null);
|
||||||
|
|
||||||
|
onMounted(() => {
|
||||||
|
const opt = { ...props.options, format: props.type };
|
||||||
|
JsBarcode(wrapEl.value, props.text, opt);
|
||||||
|
});
|
||||||
|
</script>
|
||||||
|
|
||||||
|
<template>
|
||||||
|
<component :is="tag" ref="wrapEl" />
|
||||||
|
</template>
|
||||||
@@ -1,36 +0,0 @@
|
|||||||
import { App } from "vue";
|
|
||||||
import reBar from "./src/Bar.vue";
|
|
||||||
import reGithub from "./src/Github.vue";
|
|
||||||
import reInfinite from "./src/Infinite.vue";
|
|
||||||
import reLine from "./src/Line.vue";
|
|
||||||
import rePie from "./src/Pie.vue";
|
|
||||||
|
|
||||||
export const ReBar = Object.assign(reBar, {
|
|
||||||
install(app: App) {
|
|
||||||
app.component(reBar.name, reBar);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
export const ReGithub = Object.assign(reGithub, {
|
|
||||||
install(app: App) {
|
|
||||||
app.component(reGithub.name, reGithub);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
export const ReInfinite = Object.assign(reInfinite, {
|
|
||||||
install(app: App) {
|
|
||||||
app.component(reInfinite.name, reInfinite);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
export const ReLine = Object.assign(reLine, {
|
|
||||||
install(app: App) {
|
|
||||||
app.component(reLine.name, reLine);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
export const RePie = Object.assign(rePie, {
|
|
||||||
install(app: App) {
|
|
||||||
app.component(rePie.name, rePie);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
@@ -1,96 +0,0 @@
|
|||||||
<script lang="ts">
|
|
||||||
export default {
|
|
||||||
name: "Bar"
|
|
||||||
};
|
|
||||||
</script>
|
|
||||||
|
|
||||||
<script setup lang="ts">
|
|
||||||
import { ECharts } from "echarts";
|
|
||||||
import echarts from "/@/plugins/echarts";
|
|
||||||
import { onBeforeMount, onMounted, nextTick } from "vue";
|
|
||||||
import { useEventListener, tryOnUnmounted, useTimeoutFn } from "@vueuse/core";
|
|
||||||
|
|
||||||
let echartInstance: ECharts;
|
|
||||||
|
|
||||||
function initechartInstance() {
|
|
||||||
const echartDom = document.querySelector(".bar");
|
|
||||||
if (!echartDom) return;
|
|
||||||
// @ts-ignore
|
|
||||||
echartInstance = echarts.init(echartDom);
|
|
||||||
echartInstance.clear(); //清除旧画布 重新渲染
|
|
||||||
|
|
||||||
echartInstance.setOption({
|
|
||||||
tooltip: {
|
|
||||||
trigger: "axis",
|
|
||||||
axisPointer: {
|
|
||||||
type: "shadow"
|
|
||||||
}
|
|
||||||
},
|
|
||||||
grid: {
|
|
||||||
bottom: "20%",
|
|
||||||
height: "68%",
|
|
||||||
containLabel: true
|
|
||||||
},
|
|
||||||
xAxis: [
|
|
||||||
{
|
|
||||||
type: "category",
|
|
||||||
axisTick: {
|
|
||||||
alignWithLabel: true
|
|
||||||
},
|
|
||||||
axisLabel: {
|
|
||||||
interval: 0
|
|
||||||
// width: "70",
|
|
||||||
// overflow: "truncate"
|
|
||||||
},
|
|
||||||
data: ["open_issues", "forks", "watchers", "star"]
|
|
||||||
}
|
|
||||||
],
|
|
||||||
yAxis: [
|
|
||||||
{
|
|
||||||
type: "value"
|
|
||||||
}
|
|
||||||
],
|
|
||||||
series: [
|
|
||||||
{
|
|
||||||
name: "GitHub信息",
|
|
||||||
type: "bar",
|
|
||||||
data: [3, 204, 1079, 1079]
|
|
||||||
}
|
|
||||||
]
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
onBeforeMount(() => {
|
|
||||||
nextTick(() => {
|
|
||||||
initechartInstance();
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
onMounted(() => {
|
|
||||||
nextTick(() => {
|
|
||||||
useEventListener("resize", () => {
|
|
||||||
if (!echartInstance) return;
|
|
||||||
useTimeoutFn(() => {
|
|
||||||
echartInstance.resize();
|
|
||||||
}, 180);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
tryOnUnmounted(() => {
|
|
||||||
if (!echartInstance) return;
|
|
||||||
echartInstance.dispose();
|
|
||||||
echartInstance = null;
|
|
||||||
});
|
|
||||||
</script>
|
|
||||||
|
|
||||||
<template>
|
|
||||||
<div class="bar"></div>
|
|
||||||
</template>
|
|
||||||
|
|
||||||
<style scoped>
|
|
||||||
.bar {
|
|
||||||
width: 100%;
|
|
||||||
height: 35vh;
|
|
||||||
}
|
|
||||||
</style>
|
|
||||||
@@ -1,93 +0,0 @@
|
|||||||
<script setup lang="ts">
|
|
||||||
import { ref } from "vue";
|
|
||||||
const lists = ref([
|
|
||||||
{ type: "", label: "善良" },
|
|
||||||
{ type: "success", label: "好学" },
|
|
||||||
{ type: "info", label: "幽默" },
|
|
||||||
{ type: "danger", label: "旅游" },
|
|
||||||
{ type: "warning", label: "追剧" }
|
|
||||||
]);
|
|
||||||
</script>
|
|
||||||
|
|
||||||
<template>
|
|
||||||
<el-descriptions
|
|
||||||
class="margin-top"
|
|
||||||
direction="vertical"
|
|
||||||
:column="3"
|
|
||||||
size="medium"
|
|
||||||
border
|
|
||||||
>
|
|
||||||
<el-descriptions-item>
|
|
||||||
<template #label>
|
|
||||||
<i class="el-icon-user"></i>
|
|
||||||
用户名
|
|
||||||
</template>
|
|
||||||
xiaoxian
|
|
||||||
</el-descriptions-item>
|
|
||||||
<el-descriptions-item>
|
|
||||||
<template #label>
|
|
||||||
<i class="el-icon-mobile-phone"></i>
|
|
||||||
手机号
|
|
||||||
</template>
|
|
||||||
123456789
|
|
||||||
</el-descriptions-item>
|
|
||||||
<el-descriptions-item>
|
|
||||||
<template #label>
|
|
||||||
<i class="el-icon-location-outline"></i>
|
|
||||||
居住地
|
|
||||||
</template>
|
|
||||||
上海
|
|
||||||
</el-descriptions-item>
|
|
||||||
</el-descriptions>
|
|
||||||
<el-descriptions
|
|
||||||
class="margin-top"
|
|
||||||
direction="vertical"
|
|
||||||
:column="2"
|
|
||||||
size="medium"
|
|
||||||
border
|
|
||||||
>
|
|
||||||
<el-descriptions-item>
|
|
||||||
<template #label>
|
|
||||||
<i class="el-icon-tickets"></i>
|
|
||||||
标签
|
|
||||||
</template>
|
|
||||||
<el-tag
|
|
||||||
v-for="item in lists"
|
|
||||||
:key="item.label"
|
|
||||||
:type="item.type"
|
|
||||||
size="mini"
|
|
||||||
effect="dark"
|
|
||||||
>
|
|
||||||
{{ item.label }}
|
|
||||||
</el-tag>
|
|
||||||
</el-descriptions-item>
|
|
||||||
<el-descriptions-item>
|
|
||||||
<template #label>
|
|
||||||
<i class="el-icon-office-building"></i>
|
|
||||||
联系地址
|
|
||||||
</template>
|
|
||||||
上海市徐汇区
|
|
||||||
</el-descriptions-item>
|
|
||||||
</el-descriptions>
|
|
||||||
<el-descriptions
|
|
||||||
class="margin-top"
|
|
||||||
direction="vertical"
|
|
||||||
:column="1"
|
|
||||||
size="medium"
|
|
||||||
border
|
|
||||||
>
|
|
||||||
<el-descriptions-item>
|
|
||||||
<template #label>
|
|
||||||
<i class="el-icon-notebook-1"></i>
|
|
||||||
留言
|
|
||||||
</template>
|
|
||||||
好好学习,天天向上
|
|
||||||
</el-descriptions-item>
|
|
||||||
</el-descriptions>
|
|
||||||
</template>
|
|
||||||
|
|
||||||
<style scoped>
|
|
||||||
.el-tag--mini {
|
|
||||||
margin-right: 10px !important;
|
|
||||||
}
|
|
||||||
</style>
|
|
||||||
@@ -1,84 +0,0 @@
|
|||||||
<script lang="ts">
|
|
||||||
export default {
|
|
||||||
name: "Line"
|
|
||||||
};
|
|
||||||
</script>
|
|
||||||
|
|
||||||
<script setup lang="ts">
|
|
||||||
import { ECharts } from "echarts";
|
|
||||||
import echarts from "/@/plugins/echarts";
|
|
||||||
import { onBeforeMount, onMounted, nextTick } from "vue";
|
|
||||||
import { useEventListener, tryOnUnmounted, useTimeoutFn } from "@vueuse/core";
|
|
||||||
|
|
||||||
let echartInstance: ECharts;
|
|
||||||
|
|
||||||
function initechartInstance() {
|
|
||||||
const echartDom = document.querySelector(".line");
|
|
||||||
if (!echartDom) return;
|
|
||||||
// @ts-ignore
|
|
||||||
echartInstance = echarts.init(echartDom);
|
|
||||||
echartInstance.clear(); //清除旧画布 重新渲染
|
|
||||||
|
|
||||||
echartInstance.setOption({
|
|
||||||
grid: {
|
|
||||||
bottom: "20%",
|
|
||||||
height: "68%",
|
|
||||||
containLabel: true
|
|
||||||
},
|
|
||||||
tooltip: {
|
|
||||||
trigger: "item"
|
|
||||||
},
|
|
||||||
xAxis: {
|
|
||||||
type: "category",
|
|
||||||
axisLabel: {
|
|
||||||
interval: 0
|
|
||||||
},
|
|
||||||
data: ["open_issues", "forks", "watchers", "star"]
|
|
||||||
},
|
|
||||||
yAxis: {
|
|
||||||
type: "value"
|
|
||||||
},
|
|
||||||
series: [
|
|
||||||
{
|
|
||||||
data: [3, 204, 1079, 1079],
|
|
||||||
type: "line",
|
|
||||||
areaStyle: {}
|
|
||||||
}
|
|
||||||
]
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
onBeforeMount(() => {
|
|
||||||
nextTick(() => {
|
|
||||||
initechartInstance();
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
onMounted(() => {
|
|
||||||
nextTick(() => {
|
|
||||||
useEventListener("resize", () => {
|
|
||||||
if (!echartInstance) return;
|
|
||||||
useTimeoutFn(() => {
|
|
||||||
echartInstance.resize();
|
|
||||||
}, 180);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
tryOnUnmounted(() => {
|
|
||||||
if (!echartInstance) return;
|
|
||||||
echartInstance.dispose();
|
|
||||||
echartInstance = null;
|
|
||||||
});
|
|
||||||
</script>
|
|
||||||
|
|
||||||
<template>
|
|
||||||
<div class="line"></div>
|
|
||||||
</template>
|
|
||||||
|
|
||||||
<style scoped>
|
|
||||||
.line {
|
|
||||||
width: 100%;
|
|
||||||
height: 35vh;
|
|
||||||
}
|
|
||||||
</style>
|
|
||||||
@@ -1,87 +0,0 @@
|
|||||||
<script lang="ts">
|
|
||||||
export default {
|
|
||||||
name: "Pie"
|
|
||||||
};
|
|
||||||
</script>
|
|
||||||
|
|
||||||
<script setup lang="ts">
|
|
||||||
import { ECharts } from "echarts";
|
|
||||||
import echarts from "/@/plugins/echarts";
|
|
||||||
import { onBeforeMount, onMounted, nextTick } from "vue";
|
|
||||||
import { useEventListener, tryOnUnmounted, useTimeoutFn } from "@vueuse/core";
|
|
||||||
|
|
||||||
let echartInstance: ECharts;
|
|
||||||
|
|
||||||
function initechartInstance() {
|
|
||||||
const echartDom = document.querySelector(".pie");
|
|
||||||
if (!echartDom) return;
|
|
||||||
// @ts-ignore
|
|
||||||
echartInstance = echarts.init(echartDom);
|
|
||||||
echartInstance.clear(); //清除旧画布 重新渲染
|
|
||||||
|
|
||||||
echartInstance.setOption({
|
|
||||||
tooltip: {
|
|
||||||
trigger: "item"
|
|
||||||
},
|
|
||||||
legend: {
|
|
||||||
orient: "vertical",
|
|
||||||
right: true
|
|
||||||
},
|
|
||||||
series: [
|
|
||||||
{
|
|
||||||
name: "Github信息",
|
|
||||||
type: "pie",
|
|
||||||
radius: "60%",
|
|
||||||
center: ["40%", "50%"],
|
|
||||||
data: [
|
|
||||||
{ value: 1079, name: "watchers" },
|
|
||||||
{ value: 1079, name: "star" },
|
|
||||||
{ value: 204, name: "forks" },
|
|
||||||
{ value: 3, name: "open_issues" }
|
|
||||||
],
|
|
||||||
emphasis: {
|
|
||||||
itemStyle: {
|
|
||||||
shadowBlur: 10,
|
|
||||||
shadowOffsetX: 0,
|
|
||||||
shadowColor: "rgba(0, 0, 0, 0.5)"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
]
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
onBeforeMount(() => {
|
|
||||||
nextTick(() => {
|
|
||||||
initechartInstance();
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
onMounted(() => {
|
|
||||||
nextTick(() => {
|
|
||||||
useEventListener("resize", () => {
|
|
||||||
if (!echartInstance) return;
|
|
||||||
useTimeoutFn(() => {
|
|
||||||
echartInstance.resize();
|
|
||||||
}, 180);
|
|
||||||
});
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
tryOnUnmounted(() => {
|
|
||||||
if (!echartInstance) return;
|
|
||||||
echartInstance.dispose();
|
|
||||||
echartInstance = null;
|
|
||||||
});
|
|
||||||
</script>
|
|
||||||
|
|
||||||
<template>
|
|
||||||
<div class="pie"></div>
|
|
||||||
</template>
|
|
||||||
|
|
||||||
<style scoped>
|
|
||||||
.pie {
|
|
||||||
width: 100%;
|
|
||||||
height: 35vh;
|
|
||||||
}
|
|
||||||
</style>
|
|
||||||
@@ -1,15 +1,11 @@
|
|||||||
import { App } from "vue";
|
|
||||||
import reNormalCountTo from "./src/normal";
|
import reNormalCountTo from "./src/normal";
|
||||||
import reboundCountTo from "./src/rebound";
|
import reboundCountTo from "./src/rebound";
|
||||||
|
import { withInstall } from "@pureadmin/utils";
|
||||||
|
|
||||||
export const ReNormalCountTo = Object.assign(reNormalCountTo, {
|
/** 普通数字动画组件 */
|
||||||
install(app: App) {
|
const ReNormalCountTo = withInstall(reNormalCountTo);
|
||||||
app.component(reNormalCountTo.name, reNormalCountTo);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
export const ReboundCountTo = Object.assign(reboundCountTo, {
|
/** 回弹式数字动画组件 */
|
||||||
install(app: App) {
|
const ReboundCountTo = withInstall(reboundCountTo);
|
||||||
app.component(reboundCountTo.name, reboundCountTo);
|
|
||||||
}
|
export { ReNormalCountTo, ReboundCountTo };
|
||||||
});
|
|
||||||
|
|||||||
@@ -7,10 +7,10 @@ import {
|
|||||||
unref
|
unref
|
||||||
} from "vue";
|
} from "vue";
|
||||||
import { countToProps } from "./props";
|
import { countToProps } from "./props";
|
||||||
import { isNumber } from "/@/utils/is";
|
import { isNumber } from "@pureadmin/utils";
|
||||||
|
|
||||||
export default defineComponent({
|
export default defineComponent({
|
||||||
name: "Normal",
|
name: "ReNormalCountTo",
|
||||||
props: countToProps,
|
props: countToProps,
|
||||||
emits: ["mounted", "callback"],
|
emits: ["mounted", "callback"],
|
||||||
setup(props, { emit }) {
|
setup(props, { emit }) {
|
||||||
@@ -169,7 +169,8 @@ export default defineComponent({
|
|||||||
style={{
|
style={{
|
||||||
color: props.color,
|
color: props.color,
|
||||||
fontSize: props.fontSize
|
fontSize: props.fontSize
|
||||||
}}>
|
}}
|
||||||
|
>
|
||||||
{state.displayValue}
|
{state.displayValue}
|
||||||
</span>
|
</span>
|
||||||
</>
|
</>
|
||||||
|
|||||||
@@ -4,15 +4,15 @@ import {
|
|||||||
ref,
|
ref,
|
||||||
unref,
|
unref,
|
||||||
onBeforeMount,
|
onBeforeMount,
|
||||||
onBeforeUnmount,
|
onBeforeUnmount
|
||||||
getCurrentInstance
|
|
||||||
} from "vue";
|
} from "vue";
|
||||||
import { reboundProps } from "./props";
|
import { reboundProps } from "./props";
|
||||||
|
|
||||||
export default defineComponent({
|
export default defineComponent({
|
||||||
name: "Rebound",
|
name: "ReboundCountTo",
|
||||||
props: reboundProps,
|
props: reboundProps,
|
||||||
setup(props) {
|
setup(props) {
|
||||||
|
const ulRef = ref();
|
||||||
const timer = ref(null);
|
const timer = ref(null);
|
||||||
|
|
||||||
onBeforeMount(() => {
|
onBeforeMount(() => {
|
||||||
@@ -23,8 +23,7 @@ export default defineComponent({
|
|||||||
// Safari浏览器的兼容代码
|
// Safari浏览器的兼容代码
|
||||||
isSafari &&
|
isSafari &&
|
||||||
(timer.value = setTimeout(() => {
|
(timer.value = setTimeout(() => {
|
||||||
// @ts-ignore
|
ulRef.value.setAttribute(
|
||||||
getCurrentInstance().refs["ul"].setAttribute(
|
|
||||||
"style",
|
"style",
|
||||||
`
|
`
|
||||||
animation: none;
|
animation: none;
|
||||||
@@ -42,9 +41,9 @@ export default defineComponent({
|
|||||||
<>
|
<>
|
||||||
<div
|
<div
|
||||||
class="scroll-num"
|
class="scroll-num"
|
||||||
// @ts-ignore
|
style={{ "--i": props.i, "--delay": props.delay }}
|
||||||
style={{ "--i": props.i, "--delay": props.delay }}>
|
>
|
||||||
<ul ref="ul" style={{ fontSize: "32px" }}>
|
<ul ref="ulRef" style={{ fontSize: "32px" }}>
|
||||||
<li>0</li>
|
<li>0</li>
|
||||||
<li>1</li>
|
<li>1</li>
|
||||||
<li>2</li>
|
<li>2</li>
|
||||||
|
|||||||
@@ -1,10 +1,7 @@
|
|||||||
import { App } from "vue";
|
|
||||||
import reCropper from "./src";
|
import reCropper from "./src";
|
||||||
|
import { withInstall } from "@pureadmin/utils";
|
||||||
|
|
||||||
export const ReCropper = Object.assign(reCropper, {
|
/** 图片裁剪组件 */
|
||||||
install(app: App) {
|
export const ReCropper = withInstall(reCropper);
|
||||||
app.component(reCropper.name, reCropper);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
export default ReCropper;
|
export default ReCropper;
|
||||||
|
|||||||
@@ -9,7 +9,7 @@ import {
|
|||||||
PropType
|
PropType
|
||||||
} from "vue";
|
} from "vue";
|
||||||
import { templateRef } from "@vueuse/core";
|
import { templateRef } from "@vueuse/core";
|
||||||
import { useAttrs } from "/@/utils/useAttrs";
|
import { useAttrs } from "@pureadmin/utils";
|
||||||
|
|
||||||
import Cropper from "cropperjs";
|
import Cropper from "cropperjs";
|
||||||
import "cropperjs/dist/cropper.css";
|
import "cropperjs/dist/cropper.css";
|
||||||
@@ -74,7 +74,7 @@ const props = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
export default defineComponent({
|
export default defineComponent({
|
||||||
name: "Cropper",
|
name: "ReCropper",
|
||||||
props,
|
props,
|
||||||
setup(props) {
|
setup(props) {
|
||||||
const cropper: any = ref<Nullable<Cropper>>(null);
|
const cropper: any = ref<Nullable<Cropper>>(null);
|
||||||
@@ -133,7 +133,8 @@ export default defineComponent({
|
|||||||
<>
|
<>
|
||||||
<div
|
<div
|
||||||
class={useAttrs({ excludeListeners: true, excludeKeys: ["class"] })}
|
class={useAttrs({ excludeListeners: true, excludeKeys: ["class"] })}
|
||||||
style={this.getWrapperStyle}>
|
style={this.getWrapperStyle}
|
||||||
|
>
|
||||||
<img
|
<img
|
||||||
ref="imgElRef"
|
ref="imgElRef"
|
||||||
src={this.props.src}
|
src={this.props.src}
|
||||||
|
|||||||
39
src/components/ReFlicker/index.css
Normal file
@@ -0,0 +1,39 @@
|
|||||||
|
.point {
|
||||||
|
width: var(--point-width);
|
||||||
|
height: var(--point-height);
|
||||||
|
background: var(--point-background);
|
||||||
|
position: relative;
|
||||||
|
border-radius: var(--point-border-radius);
|
||||||
|
}
|
||||||
|
|
||||||
|
.point-flicker:after {
|
||||||
|
background: var(--point-background);
|
||||||
|
}
|
||||||
|
|
||||||
|
.point-flicker:before,
|
||||||
|
.point-flicker:after {
|
||||||
|
content: "";
|
||||||
|
width: 100%;
|
||||||
|
height: 100%;
|
||||||
|
top: 0;
|
||||||
|
left: 0;
|
||||||
|
position: absolute;
|
||||||
|
border-radius: var(--point-border-radius);
|
||||||
|
animation: flicker 1.2s ease-out infinite;
|
||||||
|
}
|
||||||
|
|
||||||
|
@keyframes flicker {
|
||||||
|
0% {
|
||||||
|
transform: scale(0.5);
|
||||||
|
opacity: 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
30% {
|
||||||
|
opacity: 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
100% {
|
||||||
|
transform: scale(var(--point-scale));
|
||||||
|
opacity: 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
44
src/components/ReFlicker/index.ts
Normal file
@@ -0,0 +1,44 @@
|
|||||||
|
import "./index.css";
|
||||||
|
import { h, defineComponent, Component } from "vue";
|
||||||
|
|
||||||
|
export interface attrsType {
|
||||||
|
width?: string;
|
||||||
|
height?: string;
|
||||||
|
borderRadius?: number | string;
|
||||||
|
background?: string;
|
||||||
|
scale?: number | string;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* 圆点、方形闪烁动画组件
|
||||||
|
* @param width 可选 string 宽
|
||||||
|
* @param height 可选 string 高
|
||||||
|
* @param borderRadius 可选 number | string 传0为方形、传50%或者不传为圆形
|
||||||
|
* @param background 可选 string 闪烁颜色
|
||||||
|
* @param scale 可选 number | string 闪烁范围,默认2,值越大闪烁范围越大
|
||||||
|
* @returns Component
|
||||||
|
*/
|
||||||
|
export function useRenderFlicker(attrs?: attrsType): Component {
|
||||||
|
return defineComponent({
|
||||||
|
name: "ReFlicker",
|
||||||
|
render() {
|
||||||
|
return h(
|
||||||
|
"div",
|
||||||
|
{
|
||||||
|
class: "point point-flicker",
|
||||||
|
style: {
|
||||||
|
"--point-width": attrs?.width ?? "12px",
|
||||||
|
"--point-height": attrs?.height ?? "12px",
|
||||||
|
"--point-background":
|
||||||
|
attrs?.background ?? "var(--el-color-primary)",
|
||||||
|
"--point-border-radius": attrs?.borderRadius ?? "50%",
|
||||||
|
"--point-scale": attrs?.scale ?? "2"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
default: () => []
|
||||||
|
}
|
||||||
|
);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
@@ -1,10 +1,7 @@
|
|||||||
import { App } from "vue";
|
|
||||||
import reFlop from "./src/index.vue";
|
import reFlop from "./src/index.vue";
|
||||||
|
import { withInstall } from "@pureadmin/utils";
|
||||||
|
|
||||||
export const ReFlop = Object.assign(reFlop, {
|
/** 时间翻牌组件 */
|
||||||
install(app: App) {
|
export const ReFlop = withInstall(reFlop);
|
||||||
app.component(reFlop.name, reFlop);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
|
|
||||||
export default ReFlop;
|
export default ReFlop;
|
||||||
|
|||||||
@@ -9,7 +9,7 @@
|
|||||||
background: #fff;
|
background: #fff;
|
||||||
font-size: 66px;
|
font-size: 66px;
|
||||||
color: #fff;
|
color: #fff;
|
||||||
box-shadow: 0 0 6px rgba(0, 0, 0, 0.5);
|
box-shadow: 0 0 6px rgb(0 0 0 / 50%);
|
||||||
text-align: center;
|
text-align: center;
|
||||||
font-family: "Helvetica Neue";
|
font-family: "Helvetica Neue";
|
||||||
}
|
}
|
||||||
@@ -58,7 +58,7 @@
|
|||||||
.m-flipper.down.go .front::before {
|
.m-flipper.down.go .front::before {
|
||||||
transform-origin: 50% 100%;
|
transform-origin: 50% 100%;
|
||||||
animation: frontFlipDown 0.6s ease-in-out both;
|
animation: frontFlipDown 0.6s ease-in-out both;
|
||||||
box-shadow: 0 -2px 6px rgba(255, 255, 255, 0.3);
|
box-shadow: 0 -2px 6px rgb(255 255 255 / 30%);
|
||||||
backface-visibility: hidden;
|
backface-visibility: hidden;
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -85,7 +85,7 @@
|
|||||||
.m-flipper.up.go .front::after {
|
.m-flipper.up.go .front::after {
|
||||||
transform-origin: 50% 0;
|
transform-origin: 50% 0;
|
||||||
animation: frontFlipUp 0.6s ease-in-out both;
|
animation: frontFlipUp 0.6s ease-in-out both;
|
||||||
box-shadow: 0 2px 6px rgba(255, 255, 255, 0.3);
|
box-shadow: 0 2px 6px rgb(255 255 255 / 30%);
|
||||||
backface-visibility: hidden;
|
backface-visibility: hidden;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||