Compare commits

..

364 Commits

Author SHA1 Message Date
xiaoxian521
1fcbe4e404 Merge branch 'main' into pages 2026-01-08 11:30:32 +08:00
xiaoming
fcd28837b2 feat: RePureTableBarReVxeTableBar组件实现全量文本国际化 (#1251) 2026-01-08 11:23:51 +08:00
xiaoxian521
53f2f72849 Merge branch 'main' into pages 2026-01-07 10:45:09 +08:00
xiaoming
4c07d84463 perf: 优化主题色选项风格 (#1257) 2026-01-07 10:39:49 +08:00
xiaoxian521
bbd5d45d0e Merge branch 'main' into pages 2026-01-06 12:53:23 +08:00
xiaoming
4f59013b61 feat: layout右上角的操作按钮添加动效 (#1254) 2026-01-06 12:38:52 +08:00
xiaoming
ace4c07590 perf: 优化系统配置面板 (#1255) 2025-12-24 08:10:48 +08:00
xiaoxian521
b20323e627 chore: 升级依赖,相关兼容处理 2025-12-23 06:24:41 +08:00
xiaoxian521
30459741d4 fix: 升级vite-plugin-router-warnv2版本,兼容最新版的vue-router 2025-12-11 08:56:32 +08:00
xiaoxian521
c6690259a6 chore: update 2025-12-08 08:09:34 +08:00
xiaoxian521
4c0f2937c8 chore: update 2025-11-28 13:39:54 +08:00
xiaoxian521
ed0ab495f6 Merge branch 'main' into pages 2025-11-27 12:29:22 +08:00
xiaoxian521
d4cf8167ce Merge branch 'main' into pages 2025-11-26 08:20:46 +08:00
xiaoxian521
6fe45b2539 Merge branch 'main' into pages 2025-11-17 13:43:59 +08:00
xiaoxian521
fbceefa5a7 Merge branch 'main' into pages 2025-11-13 10:10:47 +08:00
xiaoxian521
7d8eeee22b Merge branch 'main' into pages 2025-11-08 10:30:33 +08:00
xiaoxian521
8bb96ef370 Merge branch 'main' into pages 2025-11-05 10:01:55 +08:00
xiaoxian521
91ceb8f397 chore: update 2025-10-17 10:38:56 +08:00
xiaoxian521
401d99b3be Merge branch 'main' into pages 2025-10-17 10:19:32 +08:00
xiaoxian521
37cd77d4dd chore: update 2025-09-25 20:27:14 +08:00
xiaoxian521
728ccd6d9a chore: update 2025-09-22 14:00:52 +08:00
xiaoxian521
07785fe989 Merge branch 'main' into pages 2025-09-19 14:37:16 +08:00
xiaoxian521
cb3672ec1e Merge branch 'main' into pages 2025-09-18 10:10:03 +08:00
xiaoxian521
1ebfc2c0ec Merge branch 'main' into pages 2025-09-15 15:51:48 +08:00
xiaoxian521
d353da6ac5 chore: update 2025-08-14 09:10:49 +08:00
xiaoxian521
2cc688135e Merge branch 'main' into pages 2025-08-14 08:25:23 +08:00
xiaoxian521
51e9dfc717 Merge branch 'main' into pages 2025-07-24 12:28:56 +08:00
xiaoxian521
fe7d67af0d chore: update 2025-05-27 14:30:44 +08:00
xiaoxian521
c2ae49a2e6 chore: update 2025-05-12 16:07:26 +08:00
xiaoxian521
a7f78ff1ec Merge branch 'main' into pages 2025-04-18 15:06:38 +08:00
xiaoxian521
de36c33d3c Merge branch 'main' into pages 2025-04-17 14:45:23 +08:00
xiaoxian521
41daa6a5db Merge branch 'main' into pages 2025-04-14 16:42:23 +08:00
xiaoxian521
9b871c8164 chore: update 2025-04-10 18:39:00 +08:00
xiaoxian521
c3f017434e chore: update 2025-04-10 11:04:23 +08:00
xiaoxian521
c48279ce56 Merge branch 'main' into pages 2025-04-10 10:48:04 +08:00
xiaoxian521
7c61fabebe chore: update 2025-04-09 19:18:32 +08:00
xiaoxian521
440ce053e5 Merge branch 'main' into pages 2025-04-09 19:16:25 +08:00
xiaoxian521
e72ac8ae70 Merge branch 'main' into pages 2025-03-11 09:51:24 +08:00
xiaoxian521
edfbe7de87 chore: update 2024-12-27 12:04:30 +08:00
xiaoxian521
5c73d182b4 Merge branch 'main' into pages 2024-12-27 11:58:04 +08:00
xiaoxian521
dfa3797b27 Merge branch 'main' into pages 2024-12-19 17:38:42 +08:00
xiaoxian521
a84529418c Merge branch 'main' into pages 2024-12-14 17:09:24 +08:00
xiaoxian521
81d8a51d6c chore: update 2024-11-28 13:06:32 +08:00
xiaoxian521
533199656e chore: update 2024-11-24 13:58:31 +08:00
xiaoxian521
5057e0933b chore: update 2024-10-19 09:37:05 +08:00
xiaoxian521
5ce380d7e6 Merge branch 'main' into pages 2024-10-19 08:24:32 +08:00
xiaoxian521
9d351ab600 Merge branch 'main' into pages 2024-09-25 17:00:31 +08:00
xiaoxian521
81111c096a Merge branch 'main' into pages 2024-09-24 12:12:16 +08:00
xiaoxian521
66f099fa99 Merge branch 'main' into pages 2024-09-23 14:52:29 +08:00
xiaoxian521
190c3c6123 Merge branch 'main' into pages 2024-08-13 10:28:40 +08:00
xiaoxian521
c0d683c9b1 Merge branch 'main' into pages 2024-08-03 15:39:24 +08:00
xiaoxian521
c3320d771c chore: update 2024-06-26 17:52:50 +08:00
xiaoxian521
76a173ceb2 chore: update 2024-06-15 17:09:38 +08:00
xiaoxian521
87a89ff85a chore: js 2024-06-11 22:35:05 +08:00
xiaoxian521
bf0d7dd060 Merge branch 'main' into pages 2024-06-11 22:30:41 +08:00
xiaoxian521
f1d1abd661 chore: 通知 2024-06-06 10:51:32 +08:00
xiaoxian521
06977488ef Merge branch 'main' into pages 2024-06-06 10:48:26 +08:00
xiaoxian521
debd439eeb Merge branch 'main' into pages 2024-06-04 13:59:51 +08:00
xiaoxian521
e33eb54d36 chore: update sponsors 2024-06-01 06:26:27 +08:00
xiaoxian521
4315c3122f chore: update 2024-05-30 08:42:27 +08:00
xiaoxian521
7159227ebf Merge branch 'main' into pages 2024-05-30 08:30:18 +08:00
xiaoxian521
134a06d282 Merge branch 'main' into pages 2024-05-28 12:39:16 +08:00
xiaoxian521
bdb32b3b22 chore: update 2024-05-20 22:15:03 +08:00
xiaoxian521
a02b5b7b5c chore: update 2024-05-14 21:15:03 +08:00
xiaoxian521
b80013f458 chore: update 2024-05-14 18:41:19 +08:00
xiaoxian521
097d6cd8bf Merge branch 'main' into pages 2024-05-14 18:02:09 +08:00
xiaoxian521
d9bd2ecca3 Merge branch 'main' into pages 2024-05-08 16:08:03 +08:00
xiaoxian521
2e0fdcad4b chore: update 2024-05-06 16:44:51 +08:00
xiaoxian521
da9467d98a chore: update 2024-05-06 16:41:55 +08:00
xiaoxian521
fb856a158d Merge branch 'main' into gitee 2024-05-06 16:40:05 +08:00
xiaoxian521
b617ce650a Merge branch 'main' into gitee 2024-05-06 16:08:45 +08:00
xiaoxian521
0e68510f4f chore: update 2024-04-26 13:08:33 +08:00
xiaoxian521
b33f8ca05c Merge branch 'main' into gitee 2024-04-26 13:05:42 +08:00
xiaoxian521
192a52a07c chore: update 2024-04-24 11:30:28 +08:00
xiaoxian521
5f768aa3c5 Merge branch 'main' into gitee 2024-04-24 11:26:31 +08:00
xiaoxian521
5d12a6d556 chore: update 2024-04-24 10:52:09 +08:00
xiaoxian521
8b2ca51272 chore: update 2024-04-24 10:48:45 +08:00
xiaoxian521
b3983df384 Merge branch 'main' into gitee 2024-04-24 10:40:12 +08:00
xiaoxian521
a5a527fa54 chore: update 2024-04-18 13:50:05 +08:00
xiaoxian521
c8686999f5 Merge branch 'main' into gitee 2024-04-18 13:48:43 +08:00
xiaoxian521
dabadf98fd chore: update 2024-04-17 15:48:20 +08:00
xiaoxian521
3720c15712 Merge branch 'main' into gitee 2024-04-17 15:47:06 +08:00
xiaoxian521
b4a8384fa9 chore: update 2024-04-15 17:57:56 +08:00
xiaoxian521
ebf6bb23eb Merge branch 'main' into gitee 2024-04-15 17:56:10 +08:00
xiaoxian521
147e8125e8 chore: update 2024-04-13 11:26:55 +08:00
xiaoxian521
0f35e7e0c5 Merge branch 'main' into gitee 2024-04-13 11:24:57 +08:00
xiaoxian521
733cb795fa chore: update 2024-04-12 16:26:23 +08:00
xiaoxian521
07dc4942ba Merge branch 'main' into gitee 2024-04-12 16:24:07 +08:00
xiaoxian521
c1cfe98f3e chore: update 2024-04-04 22:21:40 +08:00
xiaoxian521
5b51aedab4 chore: update 2024-04-04 22:20:14 +08:00
xiaoxian521
0bb0026974 Merge branch 'main' into gitee 2024-04-04 22:18:28 +08:00
xiaoxian521
3db2e53367 chore: update 2024-03-31 20:44:49 +08:00
xiaoxian521
0c1b14a9b5 Merge branch 'main' into gitee 2024-03-31 20:42:04 +08:00
xiaoxian521
3b1af3ec99 chore: update 2024-03-29 10:15:56 +08:00
xiaoxian521
1c5cc42220 chore: update 2024-03-29 10:14:01 +08:00
xiaoxian521
fc40bb3ea3 Merge branch 'main' into gitee 2024-03-29 10:12:02 +08:00
xiaoxian521
a47610fb59 chore: update 2024-03-28 11:34:33 +08:00
xiaoxian521
8d987d247d chore: update 2024-03-28 11:33:09 +08:00
xiaoxian521
2ac8eab760 chore: update 2024-03-27 13:58:47 +08:00
xiaoxian521
a5f2fcca01 chore: update 2024-03-27 13:57:25 +08:00
xiaoxian521
34d5d2d64d chore: update 2024-03-27 10:39:58 +08:00
xiaoxian521
6eb28f13fd chore: update 2024-03-27 10:38:38 +08:00
xiaoxian521
08b902a836 chore: update 2024-03-27 10:30:27 +08:00
xiaoxian521
1a033a784f Merge branch 'main' into gitee 2024-03-27 10:28:52 +08:00
xiaoxian521
b00afc7b82 chore: update 2024-03-24 21:22:32 +08:00
xiaoxian521
1d27d6e83a Merge branch 'main' into gitee 2024-03-24 21:21:00 +08:00
xiaoxian521
14aa977cb7 Merge branch 'main' into gitee 2024-03-24 19:38:40 +08:00
xiaoxian521
518db3d318 chore: update 2024-03-23 16:24:25 +08:00
xiaoxian521
6f4f2276bb Merge branch 'main' into gitee 2024-03-23 16:20:11 +08:00
xiaoxian521
9098546fc4 chore: update 2024-03-23 08:40:42 +08:00
xiaoxian521
a4f32df68d chore: update 2024-03-23 08:39:09 +08:00
xiaoxian521
9a6124c97b Merge branch 'main' into gitee 2024-03-23 08:24:55 +08:00
xiaoxian521
6764da7991 chore: update 2024-03-22 15:43:03 +08:00
xiaoxian521
712aca8ba1 Merge branch 'main' into gitee 2024-03-22 15:41:13 +08:00
xiaoxian521
c23919cc5d chore: update 2024-03-21 23:09:55 +08:00
xiaoxian521
26ee13de8c chore: update 2024-03-21 23:08:37 +08:00
xiaoxian521
3a25022df0 chore: update 2024-03-21 22:48:37 +08:00
xiaoxian521
edd481ad67 chore: update 2024-03-21 22:47:13 +08:00
xiaoxian521
52b59453f3 chore: update 2024-03-21 16:24:24 +08:00
xiaoxian521
c6b96cfe63 Merge branch 'main' into gitee 2024-03-21 16:21:30 +08:00
xiaoxian521
e5d90d9089 chore: update 2024-03-21 00:18:27 +08:00
xiaoxian521
a93850341c Merge branch 'main' into gitee 2024-03-21 00:17:11 +08:00
xiaoxian521
e793a69cb1 chore: update 2024-03-20 19:40:27 +08:00
xiaoxian521
dc5745e502 Merge branch 'main' into gitee 2024-03-20 19:39:14 +08:00
xiaoxian521
dcc4904e32 chore: update 2024-03-20 15:07:39 +08:00
xiaoxian521
4d6bbb2ada Merge branch 'main' into gitee 2024-03-20 15:05:56 +08:00
xiaoxian521
258ba5adaa chore: update 2024-03-19 21:08:43 +08:00
xiaoxian521
caab9c9843 Merge branch 'main' into gitee 2024-03-19 21:07:39 +08:00
xiaoxian521
b3be037a2d chore: update 2024-03-19 16:55:49 +08:00
xiaoxian521
97ff577085 Merge branch 'main' into gitee 2024-03-19 16:54:28 +08:00
xiaoxian521
58f0891141 chore: update 2024-03-19 16:25:05 +08:00
xiaoxian521
c1659c01a4 Merge branch 'main' into gitee 2024-03-19 16:23:56 +08:00
xiaoxian521
4d746a969c chore: update 2024-03-18 16:18:26 +08:00
xiaoxian521
e3b4f0f7f9 Merge branch 'main' into gitee 2024-03-18 16:17:23 +08:00
xiaoxian521
c074e99021 chore: update 2024-03-17 22:58:29 +08:00
xiaoxian521
166f785ce6 Merge branch 'main' into gitee 2024-03-17 22:57:05 +08:00
xiaoxian521
54f3ebbc9b chore: update 2024-03-17 14:19:43 +08:00
xiaoxian521
3f195a33c3 Merge branch 'main' into gitee 2024-03-17 14:18:41 +08:00
xiaoxian521
27b374d9fc chore: update 2024-03-16 23:29:07 +08:00
xiaoxian521
56ec3eda80 Merge branch 'main' into gitee 2024-03-16 23:27:38 +08:00
xiaoxian521
7e976bebbe chore: update 2024-03-16 01:27:17 +08:00
xiaoxian521
8d16627ca9 chore: update 2024-03-16 01:26:24 +08:00
xiaoxian521
b6f2575182 chore: update 2024-03-14 11:25:24 +08:00
xiaoxian521
91a57cbba9 Merge branch 'main' into gitee 2024-03-14 11:24:14 +08:00
xiaoxian521
e153ed3054 chore: update 2024-03-14 10:16:54 +08:00
xiaoxian521
26d564095b Merge branch 'main' into gitee 2024-03-14 10:15:39 +08:00
xiaoxian521
47855a39f2 chore: update 2024-03-13 21:19:45 +08:00
xiaoxian521
be773575bb Merge branch 'main' into gitee 2024-03-13 21:18:39 +08:00
xiaoxian521
4ac6a0b238 chore: update 2024-03-13 20:52:43 +08:00
xiaoxian521
0fb677540a Merge branch 'main' into gitee 2024-03-13 20:50:26 +08:00
xiaoxian521
e642f37317 chore: update 2024-03-12 14:51:49 +08:00
xiaoxian521
017a294112 Merge branch 'main' into gitee 2024-03-12 14:49:40 +08:00
xiaoxian521
0386152b52 chore: update 2024-03-08 14:39:07 +08:00
xiaoxian521
6d47fa628b chore: update 2024-03-08 14:37:58 +08:00
xiaoxian521
3209cf727f chore: update 2024-03-06 16:26:30 +08:00
xiaoxian521
be64390cee Merge branch 'main' into gitee 2024-03-06 16:24:50 +08:00
xiaoxian521
c5863f6e34 chore: update 2024-03-06 12:13:53 +08:00
xiaoxian521
4406b5fa1b Merge branch 'main' into gitee 2024-03-06 12:07:55 +08:00
xiaoxian521
562e31d119 chore: update 2024-03-06 08:53:15 +08:00
xiaoxian521
cf1efcc9f5 Merge branch 'main' into gitee 2024-03-06 08:50:51 +08:00
xiaoxian521
c9655d25d1 chore: update 2024-03-06 01:17:27 +08:00
xiaoxian521
969c0f89ec Merge branch 'main' into gitee 2024-03-06 01:15:52 +08:00
xiaoxian521
5b7c868829 chore: update 2024-03-05 22:26:40 +08:00
xiaoxian521
87a2af7181 Merge branch 'main' into gitee 2024-03-05 22:24:55 +08:00
xiaoxian521
057db33e5a chore: update 2024-03-05 00:13:41 +08:00
xiaoxian521
74197929d5 chore: update 2024-03-05 00:12:06 +08:00
xiaoxian521
43b61aad25 chore: update 2024-03-04 16:51:30 +08:00
xiaoxian521
8742a67d56 Merge branch 'main' into gitee 2024-03-04 16:50:18 +08:00
xiaoxian521
3885cec95b chore: update 2024-03-04 01:14:01 +08:00
xiaoxian521
95f3cf7c0a chore: update 2024-03-04 01:12:38 +08:00
xiaoxian521
0576b1cfeb Merge branch 'main' into gitee 2024-03-04 01:07:55 +08:00
xiaoxian521
a65f90f50a chore: update 2024-03-02 01:33:15 +08:00
xiaoxian521
08110770e0 Merge branch 'main' into gitee 2024-03-02 01:31:19 +08:00
xiaoxian521
cd8d80bfb0 chore: update 2024-03-01 21:13:02 +08:00
xiaoxian521
0316a3de5f Merge branch 'main' into gitee 2024-03-01 21:11:10 +08:00
xiaoxian521
691cec8c94 chore: update 2024-03-01 16:42:37 +08:00
xiaoxian521
10aa2c0718 Merge branch 'main' into gitee 2024-03-01 16:40:24 +08:00
xiaoxian521
bdcdef41df chore: update 2024-03-01 12:10:40 +08:00
xiaoxian521
97cb48e726 Merge branch 'main' into gitee 2024-03-01 12:09:15 +08:00
xiaoxian521
41df77fe95 chore: update 2024-02-29 13:21:03 +08:00
xiaoxian521
7076d2761a Merge branch 'main' into gitee 2024-02-29 13:18:53 +08:00
xiaoxian521
13c1adf03c chore: update 2024-02-26 23:17:32 +08:00
xiaoxian521
bbf64e1ff0 Merge branch 'main' into gitee 2024-02-26 23:13:54 +08:00
xiaoxian521
c32a60a10d chore: update 2024-02-19 13:47:30 +08:00
xiaoxian521
7a32d804b5 Merge branch 'main' into gitee 2024-02-19 13:43:08 +08:00
xiaoxian521
5027e26633 chore: update 2024-01-29 13:32:11 +08:00
xiaoxian521
907f8ffbef Merge remote-tracking branch 'origin/main' into gitee 2024-01-29 13:28:30 +08:00
xiaoxian521
358f7c2c1f chore: update 2024-01-27 16:42:55 +08:00
xiaoxian521
8c2bd1e986 chore: update 2024-01-27 16:39:59 +08:00
xiaoxian521
63f5d47fc7 chore: update 2024-01-27 16:31:53 +08:00
xiaoxian521
f069f45418 Merge remote-tracking branch 'origin/main' into gitee 2024-01-27 16:28:45 +08:00
xiaoxian521
60304dcb33 chore: update 2024-01-24 15:59:56 +08:00
xiaoxian521
07f6145179 Merge remote-tracking branch 'origin/main' into gitee 2024-01-24 15:56:57 +08:00
xiaoxian521
be1504ea83 chore: update 2024-01-23 14:03:17 +08:00
xiaoxian521
9d640eee48 Merge remote-tracking branch 'origin/main' into gitee 2024-01-23 14:00:11 +08:00
xiaoxian521
213ad9d851 chore: update 2024-01-22 11:25:00 +08:00
xiaoxian521
ac36246e19 Merge remote-tracking branch 'origin/main' into gitee 2024-01-22 11:19:06 +08:00
xiaoxian521
64f529a84e chore: update 2024-01-21 23:34:55 +08:00
xiaoxian521
46cec38fe6 Merge remote-tracking branch 'origin/main' into gitee 2024-01-21 23:31:02 +08:00
xiaoxian521
5def64a02d chore: update 2024-01-19 17:24:55 +08:00
xiaoxian521
bce6656926 Merge remote-tracking branch 'origin/main' into gitee 2024-01-19 17:22:01 +08:00
xiaoxian521
e42012a3eb chore: update 2024-01-19 16:25:57 +08:00
xiaoxian521
01a2e49377 Merge remote-tracking branch 'origin/main' into gitee 2024-01-19 16:23:08 +08:00
xiaoxian521
cc59397dc5 chore: update 2024-01-19 13:06:15 +08:00
xiaoxian521
c9bb37339d Merge remote-tracking branch 'origin/main' into gitee 2024-01-19 13:03:16 +08:00
xiaoxian521
1d8ec613ce chore: update 2024-01-18 23:57:34 +08:00
xiaoxian521
a118b701d1 Merge remote-tracking branch 'origin/main' into gitee 2024-01-18 23:53:03 +08:00
xiaoxian521
765bd35b9f chore: update 2024-01-18 17:53:34 +08:00
xiaoxian521
90b4107496 Merge remote-tracking branch 'origin/main' into gitee 2024-01-18 17:50:07 +08:00
xiaoxian521
666dc9bcb0 chore: update 2024-01-17 10:44:25 +08:00
xiaoxian521
8376191b19 chore: update 2024-01-17 10:41:21 +08:00
xiaoxian521
800577c127 chore: update 2024-01-16 13:07:17 +08:00
xiaoxian521
fdf0b9ba7e Merge remote-tracking branch 'origin/main' into gitee 2024-01-16 13:05:40 +08:00
xiaoxian521
03f8a25f75 chore: update 2024-01-16 01:02:30 +08:00
xiaoxian521
827481c909 Merge remote-tracking branch 'origin/main' into gitee 2024-01-16 01:01:22 +08:00
xiaoxian521
947bf62635 chore: update 2024-01-16 00:52:06 +08:00
xiaoxian521
dd647eb3b2 Merge remote-tracking branch 'origin/main' into gitee 2024-01-16 00:50:22 +08:00
xiaoxian521
305da78f75 chore: update 2024-01-16 00:47:18 +08:00
xiaoxian521
9eec96809f chore: update 2024-01-14 23:27:52 +08:00
xiaoxian521
e3f5f3c1a9 Merge remote-tracking branch 'origin/main' into gitee 2024-01-14 23:26:00 +08:00
xiaoxian521
27e4ad9460 chore: update 2024-01-14 12:51:27 +08:00
xiaoxian521
17eaf8161f Merge remote-tracking branch 'origin/main' into gitee 2024-01-14 12:49:39 +08:00
xiaoxian521
78b37d3480 chore: update 2024-01-12 01:04:39 +08:00
xiaoxian521
bad65648a2 Merge remote-tracking branch 'origin/main' into gitee 2024-01-12 01:03:03 +08:00
xiaoxian521
dce3dea7fe chore: update 2024-01-11 19:46:16 +08:00
xiaoxian521
4b3cdbf473 Merge remote-tracking branch 'origin/main' into gitee 2024-01-11 19:43:54 +08:00
xiaoxian521
4bcdc7229a chore: update 2024-01-11 01:58:59 +08:00
xiaoxian521
236f9e1b6a Merge remote-tracking branch 'origin/main' into gitee 2024-01-11 01:57:17 +08:00
xiaoxian521
7d5c7dfeb3 chore: update 2024-01-08 00:03:57 +08:00
xiaoxian521
1a38146587 Merge remote-tracking branch 'origin/main' into gitee 2024-01-08 00:02:10 +08:00
xiaoxian521
796348094d Merge remote-tracking branch 'origin/main' into gitee 2024-01-07 23:31:16 +08:00
xiaoxian521
6126d53bc0 chore: update 2024-01-03 17:34:25 +08:00
xiaoxian521
9a5f1f0d89 Merge remote-tracking branch 'origin/main' into gitee 2024-01-03 17:32:52 +08:00
xiaoxian521
1abdfe683a chore: update 2024-01-03 00:09:15 +08:00
xiaoxian521
f9124c886c Merge remote-tracking branch 'origin/main' into gitee 2024-01-03 00:07:21 +08:00
xiaoxian521
2aaf141178 chore: update 2024-01-02 23:18:01 +08:00
xiaoxian521
4dc7ccda4f Merge remote-tracking branch 'origin/main' into gitee 2024-01-02 23:16:18 +08:00
xiaoxian521
951496c72b chore: update 2024-01-02 19:54:47 +08:00
xiaoxian521
4fb186424c Merge remote-tracking branch 'origin/main' into gitee 2024-01-02 19:52:43 +08:00
xiaoxian521
7c66dcdfe1 chore: update 2023-11-02 10:07:20 +08:00
xiaoxian521
c57b2be2b0 Merge branch 'main' of github.com:pure-admin/vue-pure-admin into gitee 2023-11-02 10:06:18 +08:00
xiaoxian521
d921e54f76 chore: update 2023-10-31 01:00:12 +08:00
xiaoxian521
3be4d87f6a Merge branch 'main' of github.com:pure-admin/vue-pure-admin into gitee 2023-10-31 00:59:05 +08:00
xiaoxian521
18aade8cde chore: update 2023-10-30 23:54:06 +08:00
xiaoxian521
3a488eff38 Merge branch 'main' of github.com:pure-admin/vue-pure-admin into gitee 2023-10-30 23:52:58 +08:00
xiaoxian521
9d6624fe5e chore: update 2023-10-17 11:41:08 +08:00
xiaoxian521
227a7b7a2a Merge branch 'main' of github.com:pure-admin/vue-pure-admin into gitee 2023-10-17 11:39:36 +08:00
xiaoxian521
7336406b02 chore: update 2023-10-09 19:02:53 +08:00
xiaoxian521
ea188be3d7 Merge branch 'main' of github.com:pure-admin/vue-pure-admin into gitee 2023-10-09 19:00:40 +08:00
xiaoxian521
09e24f5e03 chore: update 2023-10-07 15:33:43 +08:00
xiaoxian521
94382e4bcd chore: update 2023-10-07 15:32:03 +08:00
xiaoxian521
0c01fbfa9c Merge branch 'main' into gitee 2023-10-07 15:09:03 +08:00
xiaoxian521
a2e0b9155b chore: update 2023-08-30 21:53:35 +08:00
xiaoxian521
d7a479afc6 Merge branch 'main' of github.com:pure-admin/vue-pure-admin into gitee 2023-08-30 21:52:26 +08:00
xiaoxian521
e38b5ec797 chore: update 2023-08-30 21:51:41 +08:00
xiaoxian521
fd097c5a6a chore: update 2023-08-30 12:39:32 +08:00
xiaoxian521
421fe54bbd chore: update 2023-08-30 12:36:43 +08:00
xiaoxian521
6fa1d28748 chore: update 2023-08-30 12:14:51 +08:00
xiaoxian521
94c5c6e7d0 Merge branch 'main' of github.com:pure-admin/vue-pure-admin into gitee 2023-08-30 12:12:12 +08:00
xiaoxian521
1a61d934bd chore: update 2023-07-18 12:46:39 +08:00
xiaoxian521
29ba70d041 Merge branch 'main' of github.com:pure-admin/vue-pure-admin into gitee 2023-07-18 12:45:22 +08:00
xiaoxian521
bd5e96c6ab chore: update 2023-07-12 18:27:40 +08:00
xiaoxian521
ff272087ee Merge branch 'main' of github.com:pure-admin/vue-pure-admin into gitee 2023-07-12 18:25:35 +08:00
xiaoxian521
c0ec81b669 Merge branch 'main' of github.com:pure-admin/vue-pure-admin into gitee 2023-07-12 18:17:02 +08:00
xiaoxian521
16ff8b60c1 chore: update 2023-06-27 17:57:56 +08:00
xiaoxian521
71a7d3ce1f chore: update 2023-06-27 17:46:30 +08:00
xiaoxian521
a831ea2bb3 chore: update 2023-06-27 17:45:15 +08:00
xiaoxian521
1cd173b66c Merge branch 'main' of github.com:pure-admin/vue-pure-admin into gitee 2023-06-27 17:44:30 +08:00
xiaoxian521
dbff002c00 chore: update 2023-06-26 18:07:18 +08:00
xiaoxian521
43cd5d9321 Merge branch 'main' of github.com:pure-admin/vue-pure-admin into gitee 2023-06-26 18:06:01 +08:00
xiaoxian521
131766bba1 chore: update 2023-06-26 11:33:52 +08:00
xiaoxian521
4d458169ea Merge branch 'main' of github.com:pure-admin/vue-pure-admin into gitee 2023-06-26 11:32:30 +08:00
xiaoxian521
8194f6c98f chore: update 2023-06-25 18:39:46 +08:00
xiaoxian521
cf54809ee8 Merge branch 'main' of github.com:pure-admin/vue-pure-admin into gitee 2023-06-25 18:38:36 +08:00
xiaoxian521
e362927e51 chore: update 2023-06-22 00:38:07 +08:00
xiaoxian521
eed805414d Merge branch 'main' of github.com:pure-admin/vue-pure-admin into gitee 2023-06-22 00:36:58 +08:00
xiaoxian521
e9a1550134 chore: update 2023-06-19 11:57:27 +08:00
xiaoxian521
52a973db34 Merge branch 'main' of github.com:pure-admin/vue-pure-admin into gitee 2023-06-19 11:56:02 +08:00
xiaoxian521
98790df5b8 chore: update 2023-06-14 11:11:18 +08:00
xiaoxian521
433035ac94 Merge branch 'main' of github.com:pure-admin/vue-pure-admin into gitee 2023-06-14 11:10:13 +08:00
xiaoxian521
41e912101a chore: update 2023-06-13 23:14:27 +08:00
xiaoxian521
518fd88362 Merge branch 'main' of github.com:pure-admin/vue-pure-admin into gitee 2023-06-13 23:13:17 +08:00
xiaoxian521
04aa161a1d chore: update 2023-06-12 21:14:45 +08:00
xiaoxian521
4e62edc78e Merge branch 'main' of github.com:pure-admin/vue-pure-admin into gitee 2023-06-12 21:13:23 +08:00
xiaoxian521
19522aa2f0 chore: update 2023-06-09 18:08:38 +08:00
xiaoxian521
2bd7d44119 Merge branch 'main' of github.com:pure-admin/vue-pure-admin into gitee 2023-06-09 18:07:26 +08:00
xiaoxian521
f13b471e9b chore: update 2023-06-07 11:06:35 +08:00
xiaoxian521
793e228be2 Merge branch 'main' of github.com:pure-admin/vue-pure-admin into gitee 2023-06-07 11:05:30 +08:00
xiaoxian521
de628597c0 chore: update 2023-06-05 19:35:34 +08:00
xiaoxian521
f797d9531c Merge branch 'main' of github.com:pure-admin/vue-pure-admin into gitee 2023-06-05 19:34:16 +08:00
xiaoxian521
0e09b8c809 Merge branch 'main' of github.com:pure-admin/vue-pure-admin into gitee 2023-06-04 12:47:03 +08:00
xiaoxian521
55129577c7 Merge branch 'main' of github.com:pure-admin/vue-pure-admin into gitee 2023-06-04 12:44:01 +08:00
xiaoxian521
c95a090649 chore: update 2023-05-29 11:37:34 +08:00
xiaoxian521
d18b2787f4 Merge branch 'main' of github.com:pure-admin/vue-pure-admin into gitee 2023-05-29 11:34:16 +08:00
xiaoxian521
7d4a5cc431 chore: update 2023-05-27 21:59:43 +08:00
xiaoxian521
2a7e35696b Merge branch 'main' of github.com:pure-admin/vue-pure-admin into gitee 2023-05-27 21:58:34 +08:00
xiaoxian521
362bae0e64 chore: update 2023-05-27 13:35:12 +08:00
xiaoxian521
22e7b4b503 Merge branch 'main' of github.com:pure-admin/vue-pure-admin into gitee 2023-05-27 13:33:53 +08:00
xiaoxian521
ad0ca59796 chore: update 2023-05-27 13:33:15 +08:00
xiaoxian521
a33dea3c6d chore: update 2023-05-26 23:30:14 +08:00
xiaoxian521
24b645d462 Merge branch 'main' of github.com:pure-admin/vue-pure-admin into gitee 2023-05-26 23:27:51 +08:00
xiaoxian521
52d0adf4a8 chore: update 2023-05-26 23:11:09 +08:00
xiaoxian521
69841db686 Merge branch 'main' of github.com:pure-admin/vue-pure-admin into gitee 2023-05-26 23:08:39 +08:00
xiaoxian521
76acd82ec5 chore: update 2023-05-26 12:49:16 +08:00
xiaoxian521
9d2878f534 Merge branch 'main' of github.com:pure-admin/vue-pure-admin into gitee 2023-05-26 12:40:49 +08:00
xiaoxian521
08f05fe621 chore: update 2023-05-24 13:01:18 +08:00
xiaoxian521
6294a3ffac Merge branch 'main' of github.com:pure-admin/vue-pure-admin into gitee 2023-05-24 12:58:59 +08:00
xiaoxian521
e59acea894 chore: update 2023-05-18 17:26:20 +08:00
xiaoxian521
b1ada2f1ae Merge branch 'main' of github.com:pure-admin/vue-pure-admin into gitee 2023-05-18 17:25:14 +08:00
xiaoxian521
b9daa90b37 chore: update 2023-05-16 14:36:04 +08:00
xiaoxian521
93498b6643 Merge branch 'main' of github.com:pure-admin/vue-pure-admin into gitee 2023-05-16 14:35:01 +08:00
xiaoxian521
7b067a8801 chore: update 2023-05-15 19:16:46 +08:00
xiaoxian521
88f7aefa16 Merge branch 'main' of github.com:pure-admin/vue-pure-admin into gitee 2023-05-15 19:15:37 +08:00
xiaoxian521
fb72d4afec chore: update 2023-05-15 14:50:02 +08:00
xiaoxian521
45ec532ec6 Merge branch 'main' of github.com:pure-admin/vue-pure-admin into gitee 2023-05-15 14:48:13 +08:00
xiaoxian521
45d225c3d0 chore: update 2023-05-14 16:42:53 +08:00
xiaoxian521
b9c1d8e351 Merge branch 'main' of github.com:pure-admin/vue-pure-admin into gitee 2023-05-14 16:41:23 +08:00
xiaoxian521
21f658489c chore: update 2023-05-11 20:53:36 +08:00
xiaoxian521
ff9d0da464 chore: update 2023-05-11 20:37:21 +08:00
xiaoxian521
d352cfbcde Merge branch 'main' of github.com:pure-admin/vue-pure-admin into gitee 2023-05-11 20:36:00 +08:00
xiaoxian521
1adec2df2a chore: update 2023-05-11 15:25:20 +08:00
xiaoxian521
a51c11865d Merge branch 'main' of github.com:pure-admin/vue-pure-admin into gitee 2023-05-11 15:23:37 +08:00
xiaoxian521
c5f2118a34 chore: update 2023-05-10 01:54:17 +08:00
xiaoxian521
2df0b16320 Merge branch 'main' of github.com:pure-admin/vue-pure-admin into gitee 2023-05-10 01:52:32 +08:00
xiaoxian521
3fa7176a68 chore: update 2023-05-09 15:35:56 +08:00
xiaoxian521
c8356ac05f Merge branch 'main' of github.com:pure-admin/vue-pure-admin into gitee 2023-05-09 15:34:26 +08:00
xiaoxian521
784b6943a0 chore: update 2023-05-08 20:16:48 +08:00
xiaoxian521
c77ec6bda3 Merge branch 'main' of github.com:pure-admin/vue-pure-admin into gitee 2023-05-08 20:14:32 +08:00
xiaoxian521
0c2a430485 chore: update 2023-03-30 12:27:12 +08:00
xiaoxian521
013ae275de Merge branch 'main' into gitee 2023-03-30 12:25:53 +08:00
xiaoxian521
6696a3964e chore: update 2023-02-28 22:58:13 +08:00
xiaoxian521
6b2b5dee78 Merge branch 'main' into gitee 2023-02-28 22:56:58 +08:00
xiaoxian521
e637b37416 chore: update 2023-02-16 12:44:44 +08:00
xiaoxian521
534d125c33 Merge branch 'main' into gitee 2023-02-16 12:43:26 +08:00
xiaoxian521
a873c3977b chore: update 2023-02-13 14:03:46 +08:00
xiaoxian521
d063407e3d Merge branch 'main' into gitee 2023-02-13 14:02:19 +08:00
xiaoxian521
534e889f49 perf: 优化logo图和文字布局 2023-02-13 14:00:37 +08:00
xiaoxian521
cb7bd9e5a8 chore: update 2023-02-12 23:55:06 +08:00
xiaoxian521
0b4a281bad Merge branch 'main' into gitee 2023-02-12 23:53:58 +08:00
xiaoxian521
9243e6e290 chore: update 2023-02-12 14:40:59 +08:00
xiaoxian521
039a194788 Merge branch 'main' into gitee 2023-02-12 14:40:21 +08:00
xiaoxian521
8f12419660 style: update 2023-02-12 14:38:50 +08:00
xiaoxian521
9683a7be9c chore: update 2023-02-12 13:29:47 +08:00
xiaoxian521
94ac2ba400 Merge branch 'main' into gitee 2023-02-12 13:28:41 +08:00
xiaoxian521
eed95cd109 chore: update 2023-02-11 16:18:55 +08:00
xiaoxian521
3fb9c6895e Merge branch 'main' into gitee 2023-02-11 16:17:53 +08:00
xiaoxian521
9c3ac7a888 chore: update 2023-02-09 12:11:18 +08:00
xiaoxian521
d05a4e9990 Merge branch 'main' into gitee 2023-02-09 12:09:47 +08:00
xiaoxian521
585997dbb7 chore: update 2023-02-09 00:25:06 +08:00
xiaoxian521
0c7185cc47 Merge branch 'main' into gitee 2023-02-09 00:23:57 +08:00
xiaoxian521
d0c45b7995 chore: update 2023-02-08 18:11:24 +08:00
xiaoxian521
9ba545ae3b Merge branch 'main' into gitee 2023-02-08 18:10:12 +08:00
xiaoxian521
86f5a040dc chore: update 2023-01-08 16:15:33 +08:00
xiaoxian521
9ff777c8d2 Merge branch 'main' into gitee 2023-01-08 16:11:59 +08:00
xiaoxian521
e0b7922b13 chore: update 2022-12-26 12:57:03 +08:00
xiaoxian521
c951880e3a Merge branch 'main' into gitee 2022-12-26 12:56:01 +08:00
xiaoxian521
0d02cb739e chore: update 2022-12-16 14:54:53 +08:00
xiaoxian521
9c5140d117 Merge branch 'main' into gitee 2022-12-16 14:53:11 +08:00
xiaoxian521
7707607545 chore: update 2022-12-13 15:28:52 +08:00
xiaoxian521
e6775a1b05 Merge branch 'main' into gitee 2022-12-13 15:27:01 +08:00
xiaoxian521
0087f0f27c chore: update 2022-12-09 22:35:31 +08:00
xiaoxian521
5da968f122 Merge branch 'main' into gitee 2022-12-09 22:34:27 +08:00
xiaoxian521
43d0a53ce0 chore: update 2022-12-09 20:23:54 +08:00
xiaoxian521
db64905ab0 chore: update 2022-12-09 20:21:50 +08:00
29 changed files with 1392 additions and 983 deletions

3
.gitignore vendored
View File

@@ -1,10 +1,9 @@
node_modules node_modules
.DS_Store .DS_Store
dist
dist-ssr
*.local *.local
.eslintcache .eslintcache
report.html report.html
dist
vite.config.*.timestamp* vite.config.*.timestamp*
yarn.lock yarn.lock

View File

@@ -1,8 +0,0 @@
#!/bin/sh
# shellcheck source=./_/husky.sh
. "$(dirname "$0")/_/husky.sh"
PATH="/usr/local/bin:$PATH"
npx --no-install commitlint --edit "$1"

View File

@@ -1,9 +0,0 @@
#!/bin/sh
command_exists () {
command -v "$1" >/dev/null 2>&1
}
# Workaround for Windows 10, Git Bash and Pnpm
if command_exists winpty && test -t 1; then
exec < /dev/tty
fi

View File

@@ -1,10 +0,0 @@
#!/bin/sh
. "$(dirname "$0")/_/husky.sh"
. "$(dirname "$0")/common.sh"
[ -n "$CI" ] && exit 0
PATH="/usr/local/bin:$PATH"
# Perform lint check on files in the staging area through .lintstagedrc configuration
pnpm exec lint-staged

2
.nvmrc
View File

@@ -1 +1 @@
v22.20.0 v24.12.0

View File

@@ -1,18 +1,26 @@
<!doctype html> <!doctype html>
<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 http-equiv="X-UA-Compatible" content="IE=edge,chrome=1" />
<meta name="renderer" content="webkit" /> <meta name="renderer" content="webkit" />
<meta <meta name="viewport"
name="viewport" content="width=device-width,initial-scale=1.0,minimum-scale=1.0,maximum-scale=1.0,user-scalable=0" />
content="width=device-width,initial-scale=1.0,minimum-scale=1.0,maximum-scale=1.0,user-scalable=0"
/>
<title>vue-pure-admin</title> <title>vue-pure-admin</title>
<link rel="icon" href="/favicon.ico" /> <link rel="icon" href="/favicon.ico" />
</head> <script>
var _hmt = _hmt || [];
(function () {
var hm = document.createElement("script")
hm.src = "https://hm.baidu.com/hm.js?d3824e75ef2bf6d851035f74ae1aec68"
var s = document.getElementsByTagName("script")[0]
s.parentNode.insertBefore(hm, s)
})();
</script>
</head>
<body> <body>
<div id="app"> <div id="app">
<style> <style>
html, html,
@@ -66,6 +74,7 @@
} }
@keyframes load-animation { @keyframes load-animation {
0%, 0%,
80%, 80%,
100% { 100% {
@@ -80,5 +89,6 @@
<div class="loader"></div> <div class="loader"></div>
</div> </div>
<script type="module" src="/src/main.ts"></script> <script type="module" src="/src/main.ts"></script>
</body> </body>
</html> </html>

View File

@@ -239,3 +239,17 @@ login:
purePassWordSureReg: Please enter confirm password purePassWordSureReg: Please enter confirm password
purePassWordDifferentReg: The two passwords do not match! purePassWordDifferentReg: The two passwords do not match!
purePassWordUpdateReg: Password has been updated purePassWordUpdateReg: Password has been updated
tableBar:
pureList: List
pureLarge: Large
pureDefault: Default
pureSmall: Small
pureColumnSettings: ColumnSettings
pureCollapse: Collapse
pureExpand: Expand
pureRefresh: Refresh
pureDensity: Density
pureColumnDisplay: ColumnDisplay
pureReset: Reset
pureExitFullScreen: ExitFullScreen
pureFullScreen: FullScreen

View File

@@ -239,3 +239,17 @@ login:
purePassWordSureReg: 请输入确认密码 purePassWordSureReg: 请输入确认密码
purePassWordDifferentReg: 两次密码不一致! purePassWordDifferentReg: 两次密码不一致!
purePassWordUpdateReg: 修改密码成功 purePassWordUpdateReg: 修改密码成功
tableBar:
pureList: 列表
pureLarge: 宽松
pureDefault: 默认
pureSmall: 紧凑
pureColumnSettings: 列设置
pureCollapse: 折叠
pureExpand: 展开
pureRefresh: 刷新
pureDensity: 密度
pureColumnDisplay: 列展示
pureReset: 重置
pureExitFullScreen: 退出全屏
pureFullScreen: 全屏

View File

@@ -56,7 +56,7 @@
"@pureadmin/table": "^3.3.0", "@pureadmin/table": "^3.3.0",
"@pureadmin/utils": "^2.6.3", "@pureadmin/utils": "^2.6.3",
"@vue-flow/background": "^1.3.2", "@vue-flow/background": "^1.3.2",
"@vue-flow/core": "^1.48.0", "@vue-flow/core": "^1.48.1",
"@vueuse/core": "^14.1.0", "@vueuse/core": "^14.1.0",
"@vueuse/motion": "^3.0.3", "@vueuse/motion": "^3.0.3",
"@wangeditor/editor": "^5.1.23", "@wangeditor/editor": "^5.1.23",
@@ -72,7 +72,7 @@
"deep-chat": "^2.3.0", "deep-chat": "^2.3.0",
"echarts": "^6.0.0", "echarts": "^6.0.0",
"el-table-infinite-scroll": "^3.0.8", "el-table-infinite-scroll": "^3.0.8",
"element-plus": "^2.12.0", "element-plus": "^2.13.0",
"highlight.js": "^11.11.1", "highlight.js": "^11.11.1",
"intro.js": "^7.2.0", "intro.js": "^7.2.0",
"js-cookie": "^3.0.5", "js-cookie": "^3.0.5",
@@ -96,11 +96,11 @@
"v3-infinite-loading": "^1.3.2", "v3-infinite-loading": "^1.3.2",
"vditor": "^3.11.2", "vditor": "^3.11.2",
"version-rocket": "^1.7.4", "version-rocket": "^1.7.4",
"vue": "^3.5.25", "vue": "^3.5.26",
"vue-i18n": "^11.2.2", "vue-i18n": "^11.2.7",
"vue-json-pretty": "^2.6.0", "vue-json-pretty": "^2.6.0",
"vue-pdf-embed": "^2.1.3", "vue-pdf-embed": "^2.1.3",
"vue-router": "^4.6.3", "vue-router": "^4.6.4",
"vue-tippy": "^6.7.1", "vue-tippy": "^6.7.1",
"vue-types": "^6.0.0", "vue-types": "^6.0.0",
"vue-virtual-scroller": "2.0.0-beta.8", "vue-virtual-scroller": "2.0.0-beta.8",
@@ -117,29 +117,29 @@
"@commitlint/cli": "^20.2.0", "@commitlint/cli": "^20.2.0",
"@commitlint/config-conventional": "^20.2.0", "@commitlint/config-conventional": "^20.2.0",
"@commitlint/types": "^20.2.0", "@commitlint/types": "^20.2.0",
"@eslint/js": "^9.39.1", "@eslint/js": "^9.39.2",
"@faker-js/faker": "^10.1.0", "@faker-js/faker": "^10.1.0",
"@iconify/json": "^2.2.416", "@iconify/json": "^2.2.417",
"@iconify/vue": "4.2.0", "@iconify/vue": "4.2.0",
"@intlify/unplugin-vue-i18n": "^11.0.1", "@intlify/unplugin-vue-i18n": "^11.0.3",
"@tailwindcss/vite": "^4.1.17", "@tailwindcss/vite": "^4.1.18",
"@types/codemirror": "^5.60.17", "@types/codemirror": "^5.60.17",
"@types/dagre": "^0.7.53", "@types/dagre": "^0.7.53",
"@types/intro.js": "^5.1.5", "@types/intro.js": "^5.1.5",
"@types/js-cookie": "^3.0.6", "@types/js-cookie": "^3.0.6",
"@types/node": "^20.19.26", "@types/node": "^20.19.27",
"@types/nprogress": "^0.2.3", "@types/nprogress": "^0.2.3",
"@types/path-browserify": "^1.0.3", "@types/path-browserify": "^1.0.3",
"@types/qrcode": "^1.5.6", "@types/qrcode": "^1.5.6",
"@types/qs": "^6.14.0", "@types/qs": "^6.14.0",
"@types/sortablejs": "^1.15.9", "@types/sortablejs": "^1.15.9",
"@vitejs/plugin-vue": "^6.0.2", "@vitejs/plugin-vue": "^6.0.3",
"@vitejs/plugin-vue-jsx": "^5.1.2", "@vitejs/plugin-vue-jsx": "^5.1.2",
"boxen": "^8.0.1", "boxen": "^8.0.1",
"code-inspector-plugin": "^1.3.0", "code-inspector-plugin": "^1.3.3",
"cssnano": "^7.1.2", "cssnano": "^7.1.2",
"dagre": "^0.8.5", "dagre": "^0.8.5",
"eslint": "^9.39.1", "eslint": "^9.39.2",
"eslint-config-prettier": "^10.1.8", "eslint-config-prettier": "^10.1.8",
"eslint-plugin-prettier": "^5.5.4", "eslint-plugin-prettier": "^5.5.4",
"eslint-plugin-vue": "^10.6.2", "eslint-plugin-vue": "^10.6.2",
@@ -153,26 +153,26 @@
"prettier": "^3.7.4", "prettier": "^3.7.4",
"rimraf": "^6.1.2", "rimraf": "^6.1.2",
"rollup-plugin-visualizer": "^6.0.5", "rollup-plugin-visualizer": "^6.0.5",
"sass": "^1.95.1", "sass": "^1.97.1",
"stylelint": "^16.26.1", "stylelint": "^16.26.1",
"stylelint-config-recess-order": "^7.4.0", "stylelint-config-recess-order": "^7.4.0",
"stylelint-config-recommended-vue": "^1.6.1", "stylelint-config-recommended-vue": "^1.6.1",
"stylelint-config-standard-scss": "^14.0.0", "stylelint-config-standard-scss": "^14.0.0",
"stylelint-prettier": "^5.0.3", "stylelint-prettier": "^5.0.3",
"svgo": "^4.0.0", "svgo": "^4.0.0",
"tailwindcss": "^4.1.17", "tailwindcss": "^4.1.18",
"typescript": "^5.9.3", "typescript": "^5.9.3",
"typescript-eslint": "^8.49.0", "typescript-eslint": "^8.50.0",
"unplugin-icons": "^22.5.0", "unplugin-icons": "^22.5.0",
"vite": "^7.2.7", "vite": "^7.3.0",
"vite-plugin-cdn-import": "^1.0.1", "vite-plugin-cdn-import": "^1.0.1",
"vite-plugin-compression": "^0.5.1", "vite-plugin-compression": "^0.5.1",
"vite-plugin-fake-server": "^2.2.2", "vite-plugin-fake-server": "^2.2.2",
"vite-plugin-remove-console": "^2.2.0", "vite-plugin-remove-console": "^2.2.0",
"vite-plugin-router-warn": "^1.0.0", "vite-plugin-router-warn": "^2.0.0",
"vite-svg-loader": "^5.1.0", "vite-svg-loader": "^5.1.0",
"vue-eslint-parser": "^10.2.0", "vue-eslint-parser": "^10.2.0",
"vue-tsc": "^3.1.8" "vue-tsc": "^3.2.1"
}, },
"engines": { "engines": {
"node": "^20.19.0 || >=22.13.0", "node": "^20.19.0 || >=22.13.0",

1797
pnpm-lock.yaml generated

File diff suppressed because it is too large Load Diff

View File

@@ -16,6 +16,7 @@ import en from "element-plus/es/locale/lang/en";
import zhCn from "element-plus/es/locale/lang/zh-cn"; import zhCn from "element-plus/es/locale/lang/zh-cn";
import plusEn from "plus-pro-components/es/locale/lang/en"; import plusEn from "plus-pro-components/es/locale/lang/en";
import plusZhCn from "plus-pro-components/es/locale/lang/zh-cn"; import plusZhCn from "plus-pro-components/es/locale/lang/zh-cn";
import { ElNotification } from "element-plus";
export default defineComponent({ export default defineComponent({
name: "app", name: "app",
@@ -53,6 +54,32 @@ export default defineComponent({
} }
); );
} }
},
mounted() {
ElNotification({
title: "高级服务",
duration: 0,
customClass: "fullpage-notification",
// @ts-expect-error
style: { width: "260px" },
position: "bottom-right",
dangerouslyUseHTMLString: true,
message: `
<a target='_blank' class='block text-base text-center border mt-4 rounded hover:text-[red]!' href='https://pure-admin.cn/pages/service/'>
新功能更新,点我查看
</a>
`
});
} }
}); });
</script> </script>
<style>
.fullpage-notification > .el-notification__group > .el-notification__closeBtn {
top: 15px;
}
.fullpage-notification > div > h2 {
color: red;
font-size: 18px;
}
</style>

View File

@@ -1,5 +1,5 @@
import Sortable from "sortablejs"; import Sortable from "sortablejs";
import { transformI18n } from "@/plugins/i18n"; import { $t, transformI18n } from "@/plugins/i18n";
import { useEpThemeStoreHook } from "@/store/modules/epTheme"; import { useEpThemeStoreHook } from "@/store/modules/epTheme";
import { import {
type PropType, type PropType,
@@ -30,7 +30,7 @@ const props = {
/** 头部最左边的标题 */ /** 头部最左边的标题 */
title: { title: {
type: String, type: String,
default: "列表" default: $t("tableBar.pureList")
}, },
/** 对于树形表格如果想启用展开和折叠功能传入当前表格的ref即可 */ /** 对于树形表格如果想启用展开和折叠功能传入当前表格的ref即可 */
tableRef: { tableRef: {
@@ -169,19 +169,19 @@ export default defineComponent({
style={getDropdownItemStyle.value("large")} style={getDropdownItemStyle.value("large")}
onClick={() => (size.value = "large")} onClick={() => (size.value = "large")}
> >
{transformI18n($t("tableBar.pureLarge"))}
</el-dropdown-item> </el-dropdown-item>
<el-dropdown-item <el-dropdown-item
style={getDropdownItemStyle.value("default")} style={getDropdownItemStyle.value("default")}
onClick={() => (size.value = "default")} onClick={() => (size.value = "default")}
> >
{transformI18n($t("tableBar.pureDefault"))}
</el-dropdown-item> </el-dropdown-item>
<el-dropdown-item <el-dropdown-item
style={getDropdownItemStyle.value("small")} style={getDropdownItemStyle.value("small")}
onClick={() => (size.value = "small")} onClick={() => (size.value = "small")}
> >
{transformI18n($t("tableBar.pureSmall"))}
</el-dropdown-item> </el-dropdown-item>
</el-dropdown-menu> </el-dropdown-menu>
) )
@@ -245,7 +245,9 @@ export default defineComponent({
reference: () => ( reference: () => (
<SettingIcon <SettingIcon
class={["w-[16px]", iconClass.value]} class={["w-[16px]", iconClass.value]}
v-tippy={rendTippyProps("列设置")} v-tippy={rendTippyProps(
transformI18n($t("tableBar.pureColumnSettings"))
)}
/> />
) )
}; };
@@ -268,7 +270,7 @@ export default defineComponent({
{slots?.title ? ( {slots?.title ? (
slots.title() slots.title()
) : ( ) : (
<p class="font-bold truncate">{props.title}</p> <p class="font-bold truncate">{transformI18n(props.title)}</p>
)} )}
<div class="flex items-center justify-around"> <div class="flex items-center justify-around">
{slots?.buttons ? ( {slots?.buttons ? (
@@ -282,7 +284,9 @@ export default defineComponent({
transform: isExpandAll.value ? "none" : "rotate(-90deg)" transform: isExpandAll.value ? "none" : "rotate(-90deg)"
}} }}
v-tippy={rendTippyProps( v-tippy={rendTippyProps(
isExpandAll.value ? "折叠" : "展开" isExpandAll.value
? transformI18n($t("tableBar.pureCollapse"))
: transformI18n($t("tableBar.pureExpand"))
)} )}
onClick={() => onExpand()} onClick={() => onExpand()}
/> />
@@ -295,14 +299,18 @@ export default defineComponent({
iconClass.value, iconClass.value,
loading.value ? "animate-spin" : "" loading.value ? "animate-spin" : ""
]} ]}
v-tippy={rendTippyProps("刷新")} v-tippy={rendTippyProps(
transformI18n($t("tableBar.pureRefresh"))
)}
onClick={() => onReFresh()} onClick={() => onReFresh()}
/> />
<el-divider direction="vertical" /> <el-divider direction="vertical" />
<el-dropdown <el-dropdown
v-slots={dropdown} v-slots={dropdown}
trigger="click" trigger="click"
v-tippy={rendTippyProps("密度")} v-tippy={rendTippyProps(
transformI18n($t("tableBar.pureDensity"))
)}
> >
<CollapseIcon class={["w-[16px]", iconClass.value]} /> <CollapseIcon class={["w-[16px]", iconClass.value]} />
</el-dropdown> </el-dropdown>
@@ -318,13 +326,13 @@ export default defineComponent({
<div class={[topClass.value]}> <div class={[topClass.value]}>
<el-checkbox <el-checkbox
class="-mr-1!" class="-mr-1!"
label="列展示" label={transformI18n($t("tableBar.pureColumnDisplay"))}
v-model={checkAll.value} v-model={checkAll.value}
indeterminate={isIndeterminate.value} indeterminate={isIndeterminate.value}
onChange={value => handleCheckAllChange(value)} onChange={value => handleCheckAllChange(value)}
/> />
<el-button type="primary" link onClick={() => onReset()}> <el-button type="primary" link onClick={() => onReset()}>
{transformI18n($t("tableBar.pureReset"))}
</el-button> </el-button>
</div> </div>
@@ -382,7 +390,11 @@ export default defineComponent({
<iconifyIconOffline <iconifyIconOffline
class={["w-[16px]", iconClass.value]} class={["w-[16px]", iconClass.value]}
icon={isFullscreen.value ? ExitFullscreen : Fullscreen} icon={isFullscreen.value ? ExitFullscreen : Fullscreen}
v-tippy={isFullscreen.value ? "退出全屏" : "全屏"} v-tippy={
isFullscreen.value
? transformI18n($t("tableBar.pureExitFullScreen"))
: transformI18n($t("tableBar.pureFullScreen"))
}
onClick={() => onFullscreen()} onClick={() => onFullscreen()}
/> />
</div> </div>

View File

@@ -1,5 +1,5 @@
import Sortable from "sortablejs"; import Sortable from "sortablejs";
import { transformI18n } from "@/plugins/i18n"; import { $t, transformI18n } from "@/plugins/i18n";
import { useEpThemeStoreHook } from "@/store/modules/epTheme"; import { useEpThemeStoreHook } from "@/store/modules/epTheme";
import { delay, cloneDeep, getKeyList } from "@pureadmin/utils"; import { delay, cloneDeep, getKeyList } from "@pureadmin/utils";
import { import {
@@ -24,7 +24,7 @@ const props = {
/** 头部最左边的标题 */ /** 头部最左边的标题 */
title: { title: {
type: String, type: String,
default: "列表" default: $t("tableBar.pureList")
}, },
vxeTableRef: { vxeTableRef: {
type: Object as PropType<any> type: Object as PropType<any>
@@ -161,19 +161,19 @@ export default defineComponent({
style={getDropdownItemStyle.value("medium")} style={getDropdownItemStyle.value("medium")}
onClick={() => changeSize("medium")} onClick={() => changeSize("medium")}
> >
{transformI18n($t("tableBar.pureLarge"))}
</el-dropdown-item> </el-dropdown-item>
<el-dropdown-item <el-dropdown-item
style={getDropdownItemStyle.value("small")} style={getDropdownItemStyle.value("small")}
onClick={() => changeSize("small")} onClick={() => changeSize("small")}
> >
{transformI18n($t("tableBar.pureDefault"))}
</el-dropdown-item> </el-dropdown-item>
<el-dropdown-item <el-dropdown-item
style={getDropdownItemStyle.value("mini")} style={getDropdownItemStyle.value("mini")}
onClick={() => changeSize("mini")} onClick={() => changeSize("mini")}
> >
{transformI18n($t("tableBar.pureSmall"))}
</el-dropdown-item> </el-dropdown-item>
</el-dropdown-menu> </el-dropdown-menu>
) )
@@ -238,7 +238,9 @@ export default defineComponent({
reference: () => ( reference: () => (
<SettingIcon <SettingIcon
class={["w-[16px]", iconClass.value]} class={["w-[16px]", iconClass.value]}
v-tippy={rendTippyProps("列设置")} v-tippy={rendTippyProps(
transformI18n($t("tableBar.pureColumnSettings"))
)}
/> />
) )
}; };
@@ -261,7 +263,7 @@ export default defineComponent({
{slots?.title ? ( {slots?.title ? (
slots.title() slots.title()
) : ( ) : (
<p class="font-bold truncate">{props.title}</p> <p class="font-bold truncate">{transformI18n(props.title)}</p>
)} )}
<div class="flex items-center justify-around"> <div class="flex items-center justify-around">
{slots?.buttons ? ( {slots?.buttons ? (
@@ -275,7 +277,9 @@ export default defineComponent({
transform: isExpandAll.value ? "none" : "rotate(-90deg)" transform: isExpandAll.value ? "none" : "rotate(-90deg)"
}} }}
v-tippy={rendTippyProps( v-tippy={rendTippyProps(
isExpandAll.value ? "折叠" : "展开" isExpandAll.value
? transformI18n($t("tableBar.pureCollapse"))
: transformI18n($t("tableBar.pureExpand"))
)} )}
onClick={() => onExpand()} onClick={() => onExpand()}
/> />
@@ -288,14 +292,18 @@ export default defineComponent({
iconClass.value, iconClass.value,
loading.value ? "animate-spin" : "" loading.value ? "animate-spin" : ""
]} ]}
v-tippy={rendTippyProps("刷新")} v-tippy={rendTippyProps(
transformI18n($t("tableBar.pureRefresh"))
)}
onClick={() => onReFresh()} onClick={() => onReFresh()}
/> />
<el-divider direction="vertical" /> <el-divider direction="vertical" />
<el-dropdown <el-dropdown
v-slots={dropdown} v-slots={dropdown}
trigger="click" trigger="click"
v-tippy={rendTippyProps("密度")} v-tippy={rendTippyProps(
transformI18n($t("tableBar.pureDensity"))
)}
> >
<CollapseIcon class={["w-[16px]", iconClass.value]} /> <CollapseIcon class={["w-[16px]", iconClass.value]} />
</el-dropdown> </el-dropdown>
@@ -311,13 +319,13 @@ export default defineComponent({
<div class={[topClass.value]}> <div class={[topClass.value]}>
<el-checkbox <el-checkbox
class="-mr-1!" class="-mr-1!"
label="列展示" label={transformI18n($t("tableBar.pureColumnDisplay"))}
v-model={checkAll.value} v-model={checkAll.value}
indeterminate={isIndeterminate.value} indeterminate={isIndeterminate.value}
onChange={value => handleCheckAllChange(value)} onChange={value => handleCheckAllChange(value)}
/> />
<el-button type="primary" link onClick={() => onReset()}> <el-button type="primary" link onClick={() => onReset()}>
{transformI18n($t("tableBar.pureReset"))}
</el-button> </el-button>
</div> </div>
@@ -373,7 +381,11 @@ export default defineComponent({
<iconifyIconOffline <iconifyIconOffline
class={["w-[16px]", iconClass.value]} class={["w-[16px]", iconClass.value]}
icon={isFullscreen.value ? ExitFullscreen : Fullscreen} icon={isFullscreen.value ? ExitFullscreen : Fullscreen}
v-tippy={isFullscreen.value ? "退出全屏" : "全屏"} v-tippy={
isFullscreen.value
? transformI18n($t("tableBar.pureExitFullScreen"))
: transformI18n($t("tableBar.pureFullScreen"))
}
onClick={() => onFullscreen()} onClick={() => onFullscreen()}
/> />
</div> </div>

View File

@@ -8,7 +8,7 @@ const TITLE = getConfig("Title");
<footer <footer
class="layout-footer text-[rgba(0,0,0,0.6)] dark:text-[rgba(220,220,242,0.8)]" class="layout-footer text-[rgba(0,0,0,0.6)] dark:text-[rgba(220,220,242,0.8)]"
> >
Copyright © 2020-present Copyright © 2020-2025
<a <a
class="hover:text-primary!" class="hover:text-primary!"
href="https://github.com/pure-admin" href="https://github.com/pure-admin"
@@ -16,12 +16,23 @@ const TITLE = getConfig("Title");
> >
&nbsp;{{ TITLE }} &nbsp;{{ TITLE }}
</a> </a>
<!-- <div class="ml-8">
<span>赞助商</span>
<a
class="hover:text-primary"
href="https://ai-tools.cn/resume/start"
target="_blank"
>
二猫 AI 简历
</a>
</div> -->
</footer> </footer>
</template> </template>
<style lang="scss" scoped> <style lang="scss" scoped>
.layout-footer { .layout-footer {
display: flex; display: flex;
flex-wrap: wrap;
align-items: center; align-items: center;
justify-content: center; justify-content: center;
width: 100%; width: 100%;

View File

@@ -53,9 +53,11 @@ const { t, locale, translationCh, translationEn } = useTranslationLang();
<LaySearch id="header-search" /> <LaySearch id="header-search" />
<!-- 国际化 --> <!-- 国际化 -->
<el-dropdown id="header-translation" trigger="click"> <el-dropdown id="header-translation" trigger="click">
<GlobalizationIcon <div
class="navbar-bg-hover w-[40px] h-[48px] p-[11px] cursor-pointer outline-hidden" class="globalization-icon navbar-bg-hover hover:[&>svg]:animate-scale-bounce"
/> >
<IconifyIconOffline :icon="GlobalizationIcon" />
</div>
<template #dropdown> <template #dropdown>
<el-dropdown-menu class="translation"> <el-dropdown-menu class="translation">
<el-dropdown-item <el-dropdown-item
@@ -113,7 +115,7 @@ const { t, locale, translationCh, translationEn } = useTranslationLang();
</template> </template>
</el-dropdown> </el-dropdown>
<span <span
class="set-icon navbar-bg-hover" class="set-icon navbar-bg-hover hover:[&>svg]:animate-scale-bounce"
:title="t('buttons.pureOpenSystemSet')" :title="t('buttons.pureOpenSystemSet')"
@click="onPanel" @click="onPanel"
> >

View File

@@ -3,15 +3,12 @@ import { useI18n } from "vue-i18n";
import { ref, computed } from "vue"; import { ref, computed } from "vue";
import { noticesData } from "./data"; import { noticesData } from "./data";
import NoticeList from "./components/NoticeList.vue"; import NoticeList from "./components/NoticeList.vue";
import BellIcon from "~icons/ep/bell"; import BellIcon from "~icons/lucide/bell";
const { t } = useI18n(); const { t } = useI18n();
const noticesNum = ref(0);
const notices = ref(noticesData); const notices = ref(noticesData);
const activeKey = ref(noticesData[0]?.key); const activeKey = ref(noticesData[0]?.key);
notices.value.map(v => (noticesNum.value += v.list.length));
const getLabel = computed( const getLabel = computed(
() => item => () => item =>
t(item.name) + (item.list.length > 0 ? `(${item.list.length})` : "") t(item.name) + (item.list.length > 0 ? `(${item.list.length})` : "")
@@ -21,14 +18,9 @@ const getLabel = computed(
<template> <template>
<el-dropdown trigger="click" placement="bottom-end"> <el-dropdown trigger="click" placement="bottom-end">
<span <span
:class="[ :class="['dropdown-badge', 'navbar-bg-hover', 'select-none', 'mr-[7px]']"
'dropdown-badge',
'navbar-bg-hover',
'select-none',
Number(noticesNum) !== 0 && 'mr-[10px]'
]"
> >
<el-badge :value="Number(noticesNum) === 0 ? '' : noticesNum" :max="99"> <el-badge is-dot>
<span class="header-notice-icon"> <span class="header-notice-icon">
<IconifyIconOffline :icon="BellIcon" /> <IconifyIconOffline :icon="BellIcon" />
</span> </span>
@@ -65,6 +57,34 @@ const getLabel = computed(
</template> </template>
<style lang="scss" scoped> <style lang="scss" scoped>
/* ”铃铛“摇晃衰减动画 */
@keyframes pure-bell-ring {
0%,
100% {
transform-origin: top;
}
15% {
transform: rotateZ(10deg);
}
30% {
transform: rotateZ(-10deg);
}
45% {
transform: rotateZ(5deg);
}
60% {
transform: rotateZ(-5deg);
}
75% {
transform: rotateZ(2deg);
}
}
.dropdown-badge { .dropdown-badge {
display: flex; display: flex;
align-items: center; align-items: center;
@@ -74,7 +94,13 @@ const getLabel = computed(
cursor: pointer; cursor: pointer;
.header-notice-icon { .header-notice-icon {
font-size: 18px; font-size: 16px;
}
&:hover {
.header-notice-icon svg {
animation: pure-bell-ring 1s both;
}
} }
} }

View File

@@ -51,7 +51,7 @@ onBeforeUnmount(() => {
<div class="right-panel-background" /> <div class="right-panel-background" />
<div ref="target" class="right-panel bg-bg_color"> <div ref="target" class="right-panel bg-bg_color">
<div <div
class="project-configuration border-0 border-b-[1px] border-solid border-[var(--pure-border-color)]" class="flex-bc py-3 px-5 border-0 border-l border-solid border-(--pure-border-color)"
> >
<h4 class="dark:text-white"> <h4 class="dark:text-white">
{{ t("panel.pureSystemSet") }} {{ t("panel.pureSystemSet") }}
@@ -73,12 +73,14 @@ onBeforeUnmount(() => {
/> />
</span> </span>
</div> </div>
<el-scrollbar> <el-scrollbar
class="border-y border-l border-r-0 border-solid border-(--pure-border-color) h-[calc(100vh-104px)]!"
>
<slot /> <slot />
</el-scrollbar> </el-scrollbar>
<div <div
class="flex justify-end p-3 border-0 border-t-[1px] border-solid border-[var(--pure-border-color)]" class="flex justify-end p-3 border-0 border-l border-solid border-(--pure-border-color)"
> >
<el-button <el-button
v-tippy="{ v-tippy="{
@@ -99,10 +101,6 @@ onBeforeUnmount(() => {
</template> </template>
<style lang="scss" scoped> <style lang="scss" scoped>
:deep(.el-scrollbar) {
height: calc(100vh - 110px);
}
.right-panel-background { .right-panel-background {
position: fixed; position: fixed;
top: 0; top: 0;
@@ -139,11 +137,4 @@ onBeforeUnmount(() => {
transform: translate(0); transform: translate(0);
} }
} }
.project-configuration {
display: flex;
align-items: center;
justify-content: space-between;
padding: 14px 20px;
}
</style> </style>

View File

@@ -11,7 +11,7 @@ function handleSearch() {
<template> <template>
<div> <div>
<div <div
class="search-container w-[40px] h-[48px] flex-c cursor-pointer navbar-bg-hover" class="search-container w-[40px] h-[48px] flex-c cursor-pointer navbar-bg-hover hover:[&>svg]:animate-scale-bounce"
@click="handleSearch" @click="handleSearch"
> >
<IconifyIconOffline icon="ri/search-line" /> <IconifyIconOffline icon="ri/search-line" />

View File

@@ -345,8 +345,8 @@ onUnmounted(() => removeMatchMedia);
@click="setLayoutThemeColor(item.themeColor)" @click="setLayoutThemeColor(item.themeColor)"
> >
<el-icon <el-icon
style="margin: 0.1em 0.1em 0 0" class="mt-px"
:size="17" :size="20"
:color="getThemeColor(item.themeColor)" :color="getThemeColor(item.themeColor)"
> >
<IconifyIconOffline :icon="Check" /> <IconifyIconOffline :icon="Check" />
@@ -538,17 +538,24 @@ onUnmounted(() => removeMatchMedia);
} }
.theme-color { .theme-color {
height: 20px; display: flex;
gap: 8px;
margin-top: 8px;
li { li {
float: left; position: relative;
height: 20px; width: 21px;
margin-right: 8px; height: 21px;
cursor: pointer; cursor: pointer;
border-radius: 4px; border-radius: 4px;
box-shadow: rgb(0 0 0 / 15%) 0 0 0 1px inset;
transition: all 0.2s ease;
&:nth-child(1) { &:hover {
border: 1px solid #ddd; box-shadow:
rgb(0 0 0 / 25%) 0 0 0 1px inset,
0 2px 4px rgb(0 0 0 / 15%);
transform: scale(1.1);
} }
} }
} }

View File

@@ -83,9 +83,11 @@ onMounted(() => {
<LaySearch id="header-search" /> <LaySearch id="header-search" />
<!-- 国际化 --> <!-- 国际化 -->
<el-dropdown id="header-translation" trigger="click"> <el-dropdown id="header-translation" trigger="click">
<GlobalizationIcon <div
class="navbar-bg-hover w-[40px] h-[48px] p-[11px] cursor-pointer outline-hidden" class="globalization-icon navbar-bg-hover hover:[&>svg]:animate-scale-bounce"
/> >
<IconifyIconOffline :icon="GlobalizationIcon" />
</div>
<template #dropdown> <template #dropdown>
<el-dropdown-menu class="translation"> <el-dropdown-menu class="translation">
<el-dropdown-item <el-dropdown-item
@@ -141,7 +143,7 @@ onMounted(() => {
</template> </template>
</el-dropdown> </el-dropdown>
<span <span
class="set-icon navbar-bg-hover" class="set-icon navbar-bg-hover hover:[&>svg]:animate-scale-bounce"
:title="t('buttons.pureOpenSystemSet')" :title="t('buttons.pureOpenSystemSet')"
@click="onPanel" @click="onPanel"
> >

View File

@@ -104,9 +104,11 @@ watch(
<LaySearch id="header-search" /> <LaySearch id="header-search" />
<!-- 国际化 --> <!-- 国际化 -->
<el-dropdown id="header-translation" trigger="click"> <el-dropdown id="header-translation" trigger="click">
<GlobalizationIcon <div
class="navbar-bg-hover w-[40px] h-[48px] p-[11px] cursor-pointer outline-hidden" class="globalization-icon navbar-bg-hover hover:[&>svg]:animate-scale-bounce"
/> >
<IconifyIconOffline :icon="GlobalizationIcon" />
</div>
<template #dropdown> <template #dropdown>
<el-dropdown-menu class="translation"> <el-dropdown-menu class="translation">
<el-dropdown-item <el-dropdown-item
@@ -162,7 +164,7 @@ watch(
</template> </template>
</el-dropdown> </el-dropdown>
<span <span
class="set-icon navbar-bg-hover" class="set-icon navbar-bg-hover hover:[&>svg]:animate-scale-bounce"
:title="t('buttons.pureOpenSystemSet')" :title="t('buttons.pureOpenSystemSet')"
@click="onPanel" @click="onPanel"
> >

View File

@@ -24,7 +24,10 @@ watch(
</script> </script>
<template> <template>
<span class="fullscreen-icon navbar-bg-hover" @click="toggle"> <span
class="fullscreen-icon navbar-bg-hover hover:[&>svg]:animate-scale-bounce"
@click="toggle"
>
<IconifyIconOffline :icon="screenIcon" /> <IconifyIconOffline :icon="screenIcon" />
</span> </span>
</template> </template>

View File

@@ -135,17 +135,6 @@ html.dark {
} }
} }
/* 系统配置面板 */
.right-panel-items {
.el-divider__text {
--el-bg-color: var(--el-bg-color);
}
.el-divider--horizontal {
border-top: none;
}
}
/* 表单设计器 */ /* 表单设计器 */
.design-form { .design-form {
.el-main.config-content, .el-main.config-content,

View File

@@ -35,3 +35,18 @@
.html-weakness { .html-weakness {
filter: invert(80%); filter: invert(80%);
} }
/* 轻微缩小,再恢复原状的平滑缩放动画 */
@keyframes pure-scale-bounce {
0% {
transform: scale(1);
}
50% {
transform: scale(0.9);
}
100% {
transform: scale(1);
}
}

View File

@@ -34,12 +34,14 @@
} }
.set-icon, .set-icon,
.fullscreen-icon { .fullscreen-icon,
.globalization-icon {
display: flex; display: flex;
align-items: center; align-items: center;
justify-content: center; justify-content: center;
width: 40px; width: 40px;
height: 48px; height: 48px;
font-size: 16px;
cursor: pointer; cursor: pointer;
} }
@@ -231,6 +233,7 @@
.is-active.submenu-title-noDropdown.outer-most > * { .is-active.submenu-title-noDropdown.outer-most > * {
z-index: 1; z-index: 1;
color: #fff; color: #fff;
background: transparent !important;
} }
.is-active.submenu-title-noDropdown.outer-most::before { .is-active.submenu-title-noDropdown.outer-most::before {
@@ -449,7 +452,7 @@
/* 搜索 */ /* 搜索 */
.search-container, .search-container,
/* 国际化 */ /* 国际化 */
.globalization, .globalization-icon,
/* 全屏 */ /* 全屏 */
.fullscreen-icon, .fullscreen-icon,
/* 消息通知 */ /* 消息通知 */
@@ -468,15 +471,6 @@
color: var(--pure-theme-sub-menu-active-text); color: var(--pure-theme-sub-menu-active-text);
} }
.globalization {
width: 40px;
height: 48px;
padding: 11px;
color: var(--pure-theme-sub-menu-active-text);
cursor: pointer;
outline: none;
}
.el-dropdown-link { .el-dropdown-link {
display: flex; display: flex;
align-items: center; align-items: center;
@@ -630,7 +624,7 @@ body[layout="vertical"] {
/* 搜索 */ /* 搜索 */
.search-container, .search-container,
/* 国际化 */ /* 国际化 */
.globalization, .globalization-icon,
/* 全屏 */ /* 全屏 */
.fullscreen-icon, .fullscreen-icon,
/* 消息通知 */ /* 消息通知 */

View File

@@ -44,3 +44,7 @@
@utility navbar-bg-hover { @utility navbar-bg-hover {
@apply dark:text-white dark:hover:bg-[#242424]!; @apply dark:text-white dark:hover:bg-[#242424]!;
} }
@utility animate-scale-bounce {
animation: pure-scale-bounce 0.3s ease-in-out;
}

View File

@@ -336,9 +336,9 @@ watch(loginDay, value => {
</div> </div>
</div> </div>
<div <div
class="w-full flex-c absolute bottom-3 text-sm text-[rgba(0,0,0,0.6)] dark:text-[rgba(220,220,242,0.8)]" class="w-full flex-c flex-wrap absolute bottom-3 text-sm text-[rgba(0,0,0,0.6)] dark:text-[rgba(220,220,242,0.8)]"
> >
Copyright © 2020-present Copyright © 2020-2025
<a <a
class="hover:text-primary!" class="hover:text-primary!"
href="https://github.com/pure-admin" href="https://github.com/pure-admin"
@@ -346,6 +346,16 @@ watch(loginDay, value => {
> >
&nbsp;{{ title }} &nbsp;{{ title }}
</a> </a>
<!-- <div class="ml-8">
<span>赞助商:</span>
<a
class="hover:text-primary"
href="https://ai-tools.cn/resume/start"
target="_blank"
>
二猫 AI 简历
</a>
</div> -->
</div> </div>
</div> </div>
</template> </template>

View File

@@ -102,7 +102,6 @@ function onCloseTags() {
default-expand-all default-expand-all
:props="{ :props="{
label: data => transformI18n(data.meta.title), label: data => transformI18n(data.meta.title),
value: 'uniqueId',
children: 'children', children: 'children',
disabled: 'disabled' disabled: 'disabled'
}" }"