Compare commits

..

327 Commits

Author SHA1 Message Date
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
178 changed files with 2758 additions and 3086 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

View File

@@ -1,32 +1,3 @@
# 6.0.0 (2025-04-10)
### ✔️ Refactor
- Refactor the icon module, use `@iconify/json` to replace the `@iconify-icons/*` dependency that is no longer maintained and updated, optimize the user experience, ensure that the icon library can be continuously updated and support `Tree-shaking`
- Upgrade `tailwindcss` to `v4` version, bringing faster build speed, simpler installation and configuration, and providing a dedicated `vite` plug-in
### 🎫 Feat
- Add `Ai` chat component example
- Add `tagOnClick` tag to switch global public events
- Add code editor example
- Add `Markdown` example
- Add slider example
### 🐞 Bug fixes
- Fix `aria-hidden` error
- Fix the problem that code hints cannot be displayed when using `this` syntax and update `pinia` related syntax
### 🍏 Perf
- Fix broken links in the waterfall infinite scrolling example
- Update `vue-flow`, related compatibility processing
- Delete the deprecated dependency package `eslint-define-config`, upgrade `eslint` to the latest version, related compatibility processing
- Optimize `src/style/dark.scss` syntax
- Optimize login parameter transfer
- Use `keydown` to replace `keypress`, the `keypress` event has been deprecated
# 5.9.0 (2024-12-10) # 5.9.0 (2024-12-10)
### ✔Refactor ### ✔Refactor

View File

@@ -1,32 +1,3 @@
# 6.0.0 (2025-04-10)
### ✔️ Refactor
- Refactor the icon module, use `@iconify/json` to replace the `@iconify-icons/*` dependency that is no longer maintained and updated, optimize the user experience, ensure that the icon library can be continuously updated and support `Tree-shaking`
- Upgrade `tailwindcss` to `v4` version, bringing faster build speed, simpler installation and configuration, and providing a dedicated `vite` plug-in
### 🎫 Feat
- Add `Ai` chat component example
- Add `tagOnClick` tag to switch global public events
- Add code editor example
- Add `Markdown` example
- Add slider example
### 🐞 Bug fixes
- Fix `aria-hidden` error
- Fix the problem that code hints cannot be displayed when using `this` syntax and update `pinia` related syntax
### 🍏 Perf
- Fix broken links in the waterfall infinite scrolling example
- Update `vue-flow`, related compatibility processing
- Delete the deprecated dependency package `eslint-define-config`, upgrade `eslint` to the latest version, related compatibility processing
- Optimize `src/style/dark.scss` syntax
- Optimize login parameter transfer
- Use `keydown` to replace `keypress`, the `keypress` event has been deprecated
# 5.9.0 (2024-12-10) # 5.9.0 (2024-12-10)
### ✔Refactor ### ✔Refactor

View File

@@ -1,32 +1,3 @@
# 6.0.0 (2025-04-10)
### ✔️ Refactor
- 重构图标模块,使用`@iconify/json`替换不再维护更新的`@iconify-icons/*`依赖,优化使用体验,确保图标库可持续更新并支持`Tree-shaking`
- 升级`tailwindcss``v4`版本,带来更快的构建速度、更简化的安装和配置、提供专属`vite`插件
### 🎫 Feat
- 添加`Ai`聊天组件示例
- 添加`tagOnClick`标签切换全局公共事件
- 添加代码编辑器示例
- 添加`Markdown`示例
- 添加滑块示例
### 🐞 Bug fixes
- 修复`aria-hidden`报错
- 修复使用`this`语法时无法显示代码提示的问题并更新`pinia`相关语法
### 🍏 Perf
- 修复组件-瀑布流无限滚动示例中失效的链接
- 更新`vue-flow`,相关兼容处理
- 删除已弃用的依赖包`eslint-define-config`,升级`eslint`至最新版本,相关兼容处理
- 优化`src/style/dark.scss`语法
- 优化登录传参
- 使用`keydown`替换`keypress``keypress`事件已弃用
# 5.9.0 (2024-12-10) # 5.9.0 (2024-12-10)
### ✔️ Refactor ### ✔️ Refactor

View File

@@ -57,8 +57,8 @@ const include = [
/** /**
* 在预构建中强制排除的依赖项 * 在预构建中强制排除的依赖项
* 温馨提示:平台推荐的使用方式是哪里需要哪里引入而且都是单个的引入,不需要预构建,直接让浏览器加载就好 * 温馨提示:所有以 `@iconify-icons/` 开头引入的的本地图标模块,都应该加入到下面的 `exclude` 里,因为平台推荐的使用方式是哪里需要哪里引入而且都是单个的引入,不需要预构建,直接让浏览器加载就好
*/ */
const exclude = ["@iconify/json"]; const exclude = ["@iconify-icons/ep", "@iconify-icons/ri"];
export { include, exclude }; export { include, exclude };

View File

@@ -3,10 +3,8 @@ import vue from "@vitejs/plugin-vue";
import { pathResolve } from "./utils"; import { pathResolve } from "./utils";
import { viteBuildInfo } from "./info"; import { viteBuildInfo } from "./info";
import svgLoader from "vite-svg-loader"; import svgLoader from "vite-svg-loader";
import Icons from "unplugin-icons/vite";
import type { PluginOption } from "vite"; import type { PluginOption } from "vite";
import vueJsx from "@vitejs/plugin-vue-jsx"; import vueJsx from "@vitejs/plugin-vue-jsx";
import tailwindcss from "@tailwindcss/vite";
import { configCompressPlugin } from "./compress"; import { configCompressPlugin } from "./compress";
import removeNoMatch from "vite-plugin-router-warn"; import removeNoMatch from "vite-plugin-router-warn";
import { visualizer } from "rollup-plugin-visualizer"; import { visualizer } from "rollup-plugin-visualizer";
@@ -21,7 +19,6 @@ export function getPluginsList(
): PluginOption[] { ): PluginOption[] {
const lifecycle = process.env.npm_lifecycle_event; const lifecycle = process.env.npm_lifecycle_event;
return [ return [
tailwindcss(),
vue({ vue({
template: { template: {
compilerOptions: { compilerOptions: {
@@ -60,11 +57,6 @@ export function getPluginsList(
}), }),
// svg组件化支持 // svg组件化支持
svgLoader(), svgLoader(),
// 自动按需加载图标
Icons({
compiler: "vue3",
scale: 1
}),
VITE_CDN ? cdn : null, VITE_CDN ? cdn : null,
configCompressPlugin(VITE_COMPRESSION), configCompressPlugin(VITE_COMPRESSION),
// 线上环境删除console // 线上环境删除console

View File

@@ -1,25 +1,26 @@
import js from "@eslint/js"; import js from "@eslint/js";
import tseslint from "typescript-eslint";
import pluginVue from "eslint-plugin-vue"; import pluginVue from "eslint-plugin-vue";
import * as parserVue from "vue-eslint-parser"; import * as parserVue from "vue-eslint-parser";
import configPrettier from "eslint-config-prettier"; import configPrettier from "eslint-config-prettier";
import pluginPrettier from "eslint-plugin-prettier"; import pluginPrettier from "eslint-plugin-prettier";
import { defineConfig, globalIgnores } from "eslint/config"; import { defineFlatConfig } from "eslint-define-config";
import * as parserTypeScript from "@typescript-eslint/parser";
import pluginTypeScript from "@typescript-eslint/eslint-plugin";
export default defineConfig([ export default defineFlatConfig([
globalIgnores([ {
...js.configs.recommended,
ignores: [
"**/.*", "**/.*",
"dist/*", "dist/*",
"*.d.ts", "*.d.ts",
"public/*", "public/*",
"src/assets/**", "src/assets/**",
"src/**/iconfont/**" "src/**/iconfont/**"
]), ],
{
...js.configs.recommended,
languageOptions: { languageOptions: {
globals: { globals: {
// types/index.d.ts // index.d.ts
RefType: "readonly", RefType: "readonly",
EmitType: "readonly", EmitType: "readonly",
TargetContext: "readonly", TargetContext: "readonly",
@@ -72,10 +73,21 @@ export default defineConfig([
] ]
} }
}, },
...tseslint.config({ {
extends: [...tseslint.configs.recommended],
files: ["**/*.?([cm])ts", "**/*.?([cm])tsx"], files: ["**/*.?([cm])ts", "**/*.?([cm])tsx"],
languageOptions: {
parser: parserTypeScript,
parserOptions: {
sourceType: "module",
warnOnUnsupportedTypeScriptVersion: false
}
},
plugins: {
"@typescript-eslint": pluginTypeScript
},
rules: { rules: {
...pluginTypeScript.configs.strict.rules,
"@typescript-eslint/ban-types": "off",
"@typescript-eslint/no-redeclare": "error", "@typescript-eslint/no-redeclare": "error",
"@typescript-eslint/ban-ts-comment": "off", "@typescript-eslint/ban-ts-comment": "off",
"@typescript-eslint/no-explicit-any": "off", "@typescript-eslint/no-explicit-any": "off",
@@ -102,20 +114,20 @@ export default defineConfig([
} }
] ]
} }
}), },
{ {
files: ["**/*.d.ts"], files: ["**/*.d.ts"],
rules: { rules: {
"eslint-comments/no-unlimited-disable": "off", "eslint-comments/no-unlimited-disable": "off",
"import/no-duplicates": "off", "import/no-duplicates": "off",
"no-restricted-syntax": "off",
"unused-imports/no-unused-vars": "off" "unused-imports/no-unused-vars": "off"
} }
}, },
{ {
files: ["**/*.?([cm])js"], files: ["**/*.?([cm])js"],
rules: { rules: {
"@typescript-eslint/no-require-imports": "off" "@typescript-eslint/no-require-imports": "off",
"@typescript-eslint/no-var-requires": "off"
} }
}, },
{ {
@@ -136,19 +148,18 @@ export default defineConfig([
jsx: true jsx: true
}, },
extraFileExtensions: [".vue"], extraFileExtensions: [".vue"],
parser: tseslint.parser, parser: "@typescript-eslint/parser",
sourceType: "module" sourceType: "module"
} }
}, },
plugins: { plugins: {
"@typescript-eslint": tseslint.plugin,
vue: pluginVue vue: pluginVue
}, },
processor: pluginVue.processors[".vue"], processor: pluginVue.processors[".vue"],
rules: { rules: {
...pluginVue.configs.base.rules, ...pluginVue.configs.base.rules,
...pluginVue.configs.essential.rules, ...pluginVue.configs["vue3-essential"].rules,
...pluginVue.configs.recommended.rules, ...pluginVue.configs["vue3-recommended"].rules,
"no-undef": "off", "no-undef": "off",
"no-unused-vars": "off", "no-unused-vars": "off",
"vue/no-v-html": "off", "vue/no-v-html": "off",

View File

@@ -1,15 +1,23 @@
<!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" />
<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> </head>
<body> <body>
@@ -66,6 +74,7 @@
} }
@keyframes load-animation { @keyframes load-animation {
0%, 0%,
80%, 80%,
100% { 100% {
@@ -81,4 +90,5 @@
</div> </div>
<script type="module" src="/src/main.ts"></script> <script type="module" src="/src/main.ts"></script>
</body> </body>
</html> </html>

View File

@@ -25,7 +25,7 @@ export default defineFakeRoute([
url: "/mine-logs", url: "/mine-logs",
method: "get", method: "get",
response: () => { response: () => {
const list = [ let list = [
{ {
id: 1, id: 1,
ip: faker.internet.ipv4(), ip: faker.internet.ipv4(),

View File

@@ -1,6 +1,6 @@
{ {
"name": "vue-pure-admin", "name": "vue-pure-admin",
"version": "6.0.0", "version": "5.9.0",
"private": true, "private": true,
"type": "module", "type": "module",
"scripts": { "scripts": {
@@ -54,25 +54,25 @@
"@logicflow/extension": "^1.2.28", "@logicflow/extension": "^1.2.28",
"@pureadmin/descriptions": "^1.2.1", "@pureadmin/descriptions": "^1.2.1",
"@pureadmin/table": "^3.2.1", "@pureadmin/table": "^3.2.1",
"@pureadmin/utils": "^2.6.0", "@pureadmin/utils": "^2.5.0",
"@vue-flow/background": "^1.3.2", "@vue-flow/background": "^1.3.2",
"@vue-flow/core": "^1.42.5", "@vue-flow/core": "^1.42.1",
"@vueuse/core": "^13.1.0", "@vueuse/core": "^12.5.0",
"@vueuse/motion": "^3.0.3", "@vueuse/motion": "^2.2.6",
"@wangeditor/editor": "^5.1.23", "@wangeditor/editor": "^5.1.23",
"@wangeditor/editor-for-vue": "^5.1.12", "@wangeditor/editor-for-vue": "^5.1.12",
"@zxcvbn-ts/core": "^3.0.4", "@zxcvbn-ts/core": "^3.0.4",
"animate.css": "^4.1.1", "animate.css": "^4.1.1",
"axios": "^1.8.4", "axios": "^1.7.9",
"china-area-data": "^5.0.1", "china-area-data": "^5.0.1",
"codemirror": "^5.65.19", "codemirror": "^5.65.18",
"codemirror-editor-vue3": "^2.8.0", "codemirror-editor-vue3": "^2.8.0",
"cropperjs": "^1.6.2", "cropperjs": "^1.6.2",
"dayjs": "^1.11.13", "dayjs": "^1.11.13",
"deep-chat": "^2.1.1", "deep-chat": "^2.1.1",
"echarts": "^5.6.0", "echarts": "^5.6.0",
"el-table-infinite-scroll": "^3.0.6", "el-table-infinite-scroll": "^3.0.6",
"element-plus": "^2.9.7", "element-plus": "^2.9.4",
"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",
@@ -85,94 +85,96 @@
"path-browserify": "^1.0.1", "path-browserify": "^1.0.1",
"pinia": "^3.0.1", "pinia": "^3.0.1",
"pinyin-pro": "^3.26.0", "pinyin-pro": "^3.26.0",
"plus-pro-components": "^0.1.22", "plus-pro-components": "^0.1.20",
"qrcode": "^1.5.4", "qrcode": "^1.5.4",
"qs": "^6.14.0", "qs": "^6.14.0",
"responsive-storage": "^2.2.0", "responsive-storage": "^2.2.0",
"sortablejs": "^1.15.6", "sortablejs": "^1.15.6",
"swiper": "^11.2.6", "swiper": "^11.2.3",
"typeit": "^8.8.7", "typeit": "^8.8.7",
"v-contextmenu": "^3.2.0", "v-contextmenu": "^3.2.0",
"v3-infinite-loading": "^1.3.2", "v3-infinite-loading": "^1.3.2",
"vditor": "^3.10.9", "vditor": "^3.10.9",
"version-rocket": "^1.7.4", "version-rocket": "^1.7.4",
"vue": "^3.5.13", "vue": "^3.5.13",
"vue-i18n": "^11.1.3", "vue-i18n": "^11.1.1",
"vue-json-pretty": "^2.4.0", "vue-json-pretty": "^2.4.0",
"vue-pdf-embed": "^2.1.2", "vue-pdf-embed": "^2.1.2",
"vue-router": "^4.5.0", "vue-router": "^4.5.0",
"vue-tippy": "^6.7.0", "vue-tippy": "^6.6.0",
"vue-types": "^6.0.0", "vue-types": "^5.1.3",
"vue-virtual-scroller": "2.0.0-beta.8", "vue-virtual-scroller": "2.0.0-beta.8",
"vue-waterfall-plugin-next": "^2.6.5", "vue-waterfall-plugin-next": "^2.6.5",
"vue3-danmaku": "^1.6.1", "vue3-danmaku": "^1.6.1",
"vue3-puzzle-vcode": "^1.1.7", "vue3-puzzle-vcode": "^1.1.7",
"vuedraggable": "^4.1.0", "vuedraggable": "^4.1.0",
"vxe-table": "4.6.25", "vxe-table": "4.6.25",
"wavesurfer.js": "^7.9.4", "wavesurfer.js": "^7.9.1",
"xgplayer": "^3.0.21", "xgplayer": "^3.0.20",
"xlsx": "^0.18.5" "xlsx": "^0.18.5"
}, },
"devDependencies": { "devDependencies": {
"@commitlint/cli": "^19.8.0", "@commitlint/cli": "^19.7.1",
"@commitlint/config-conventional": "^19.8.0", "@commitlint/config-conventional": "^19.7.1",
"@commitlint/types": "^19.8.0", "@commitlint/types": "^19.5.0",
"@eslint/js": "^9.24.0", "@eslint/js": "^9.20.0",
"@faker-js/faker": "^9.6.0", "@faker-js/faker": "^9.5.0",
"@iconify/json": "^2.2.324", "@iconify-icons/ep": "^1.2.12",
"@iconify-icons/ri": "^1.2.10",
"@iconify/vue": "4.2.0", "@iconify/vue": "4.2.0",
"@intlify/unplugin-vue-i18n": "^6.0.5", "@intlify/unplugin-vue-i18n": "^6.0.3",
"@tailwindcss/vite": "^4.1.3",
"@types/codemirror": "^5.60.15", "@types/codemirror": "^5.60.15",
"@types/dagre": "^0.7.52", "@types/dagre": "^0.7.52",
"@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.17.30", "@types/node": "^20.17.19",
"@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.5", "@types/qrcode": "^1.5.5",
"@types/qs": "^6.9.18", "@types/qs": "^6.9.18",
"@types/sortablejs": "^1.15.8", "@types/sortablejs": "^1.15.8",
"@vitejs/plugin-vue": "^5.2.3", "@typescript-eslint/eslint-plugin": "^8.24.0",
"@vitejs/plugin-vue-jsx": "^4.1.2", "@typescript-eslint/parser": "^8.24.0",
"@vitejs/plugin-vue": "^5.2.1",
"@vitejs/plugin-vue-jsx": "^4.1.1",
"autoprefixer": "^10.4.20",
"boxen": "^8.0.1", "boxen": "^8.0.1",
"code-inspector-plugin": "^0.20.7", "code-inspector-plugin": "^0.20.0",
"cssnano": "^7.0.6", "cssnano": "^7.0.6",
"dagre": "^0.8.5", "dagre": "^0.8.5",
"eslint": "^9.24.0", "eslint": "^9.20.1",
"eslint-config-prettier": "^10.1.1", "eslint-config-prettier": "^10.0.1",
"eslint-plugin-prettier": "^5.2.6", "eslint-define-config": "^2.1.0",
"eslint-plugin-vue": "^10.0.0", "eslint-plugin-prettier": "^5.2.3",
"eslint-plugin-vue": "^9.32.0",
"gradient-string": "^3.0.0", "gradient-string": "^3.0.0",
"husky": "^9.1.7", "husky": "^9.1.7",
"lint-staged": "^15.5.0", "lint-staged": "^15.4.3",
"postcss": "^8.5.3", "postcss": "^8.5.2",
"postcss-html": "^1.8.0", "postcss-html": "^1.8.0",
"postcss-load-config": "^6.0.1", "postcss-import": "^16.1.0",
"postcss-scss": "^4.0.9", "postcss-scss": "^4.0.9",
"prettier": "^3.5.3", "prettier": "^3.5.1",
"rimraf": "^6.0.1", "rimraf": "^6.0.1",
"rollup-plugin-visualizer": "^5.14.0", "rollup-plugin-visualizer": "^5.14.0",
"sass": "^1.86.3", "sass": "^1.85.0",
"stylelint": "^16.18.0", "stylelint": "^16.14.1",
"stylelint-config-recess-order": "^6.0.0", "stylelint-config-recess-order": "^6.0.0",
"stylelint-config-recommended-vue": "^1.6.0", "stylelint-config-recommended-vue": "^1.6.0",
"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": "^3.3.2", "svgo": "^3.3.2",
"tailwindcss": "^4.1.3", "tailwindcss": "3.4.17",
"typescript": "^5.8.3", "typescript": "^5.7.3",
"typescript-eslint": "^8.29.1", "vite": "^6.1.0",
"unplugin-icons": "^22.1.0",
"vite": "^6.2.5",
"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.0", "vite-plugin-fake-server": "^2.2.0",
"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": "^1.0.0",
"vite-svg-loader": "^5.1.0", "vite-svg-loader": "^5.1.0",
"vue-eslint-parser": "^10.1.3", "vue-eslint-parser": "^9.4.3",
"vue-tsc": "^2.2.8" "vue-tsc": "^2.2.0"
}, },
"engines": { "engines": {
"node": "^18.18.0 || ^20.9.0 || >=22.0.0", "node": "^18.18.0 || ^20.9.0 || >=22.0.0",
@@ -182,7 +184,6 @@
"allowedDeprecatedVersions": { "allowedDeprecatedVersions": {
"are-we-there-yet": "*", "are-we-there-yet": "*",
"sourcemap-codec": "*", "sourcemap-codec": "*",
"lodash.isequal": "*",
"domexception": "*", "domexception": "*",
"w3c-hr-time": "*", "w3c-hr-time": "*",
"inflight": "*", "inflight": "*",
@@ -193,6 +194,11 @@
"abab": "*", "abab": "*",
"glob": "*" "glob": "*"
}, },
"peerDependencyRules": {
"allowedVersions": {
"eslint": "9"
}
},
"onlyBuiltDependencies": [ "onlyBuiltDependencies": [
"@parcel/watcher", "@parcel/watcher",
"core-js", "core-js",

4049
pnpm-lock.yaml generated

File diff suppressed because it is too large Load Diff

View File

@@ -3,6 +3,10 @@
/** @type {import('postcss-load-config').Config} */ /** @type {import('postcss-load-config').Config} */
export default { export default {
plugins: { plugins: {
"postcss-import": {},
"tailwindcss/nesting": {},
tailwindcss: {},
autoprefixer: {},
...(process.env.NODE_ENV === "production" ? { cssnano: {} } : {}) ...(process.env.NODE_ENV === "production" ? { cssnano: {} } : {})
} }
}; };

View File

@@ -1,5 +1,5 @@
{ {
"Version": "6.0.0", "Version": "5.9.0",
"Title": "PureAdmin", "Title": "PureAdmin",
"FixedHeader": true, "FixedHeader": true,
"HiddenSideBar": false, "HiddenSideBar": false,

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",
@@ -54,5 +55,23 @@ export default defineComponent({
); );
} }
} }
// mounted() {
// ElNotification({
// title: "优惠活动即将结束",
// duration: 0,
// //@ts-expect-error
// style: { width: "200px" },
// position: "bottom-right",
// dangerouslyUseHTMLString: true,
// message: `
// <a target='_blank' style='font-size: 16px' class='block text-center border mb-2 rounded hover:text-[red]' href='https://pure-admin.github.io/pure-admin-doc/pages/js/'>
// JS版本
// </a>
// <a target='_blank' style='font-size: 16px' class='block text-center border mb-2 rounded hover:text-[red]' href='https://pure-admin.github.io/pure-admin-doc/pages/max/'>
// Max版本
// </a>
// `
// });
// }
}); });
</script> </script>

View File

@@ -95,7 +95,7 @@ function onMouseleave() {
:view-style="{ overflow: 'hidden' }" :view-style="{ overflow: 'hidden' }"
class="border-t border-[#e5e7eb]" class="border-t border-[#e5e7eb]"
> >
<ul class="flex flex-wrap justify-around mb-1!"> <ul class="flex flex-wrap justify-around mb-1">
<li <li
v-for="(animate, index) in animatesList" v-for="(animate, index) in animatesList"
:key="index" :key="index"

View File

@@ -119,7 +119,7 @@ export default defineComponent({
"p-[6px]", "p-[6px]",
"h-[30px]", "h-[30px]",
"w-[30px]", "w-[30px]",
"outline-hidden", "outline-none",
"rounded-[4px]", "rounded-[4px]",
"cursor-pointer", "cursor-pointer",
"hover:bg-[rgba(0,0,0,0.06)]" "hover:bg-[rgba(0,0,0,0.06)]"

View File

@@ -8,8 +8,8 @@ import {
} from "./index"; } from "./index";
import { ref, computed } from "vue"; import { ref, computed } from "vue";
import { isFunction } from "@pureadmin/utils"; import { isFunction } from "@pureadmin/utils";
import Fullscreen from "~icons/ri/fullscreen-fill"; import Fullscreen from "@iconify-icons/ri/fullscreen-fill";
import ExitFullscreen from "~icons/ri/fullscreen-exit-fill"; import ExitFullscreen from "@iconify-icons/ri/fullscreen-exit-fill";
defineOptions({ defineOptions({
name: "ReDialog" name: "ReDialog"
@@ -79,7 +79,7 @@ const fullscreenClass = computed(() => {
"el-dialog__close", "el-dialog__close",
"-translate-x-2", "-translate-x-2",
"cursor-pointer", "cursor-pointer",
"hover:text-[red]!" "hover:!text-[red]"
]; ];
}); });

View File

@@ -3,7 +3,7 @@ import { ref, unref, onMounted } from "vue";
import { LogicFlow } from "@logicflow/core"; import { LogicFlow } from "@logicflow/core";
interface Props { interface Props {
lf?: LogicFlow; lf: LogicFlow;
catTurboData?: boolean; catTurboData?: boolean;
} }
@@ -114,8 +114,7 @@ onMounted(() => {
:style="{ :style="{
cursor: item.disabled === false ? 'pointer' : 'not-allowed', cursor: item.disabled === false ? 'pointer' : 'not-allowed',
color: item.disabled === false ? '' : '#00000040', color: item.disabled === false ? '' : '#00000040',
background: 'transparent', background: 'transparent'
border: 'none'
}" }"
@click="onControl(item, key)" @click="onControl(item, key)"
> >

View File

@@ -9,8 +9,8 @@ type nodeListType = {
}; };
interface Props { interface Props {
lf?: LogicFlow; lf: LogicFlow;
nodeList?: Array<nodeListType>; nodeList: Array<nodeListType>;
} }
const props = withDefaults(defineProps<Props>(), { const props = withDefaults(defineProps<Props>(), {

View File

@@ -2,7 +2,7 @@
import { IconJson } from "@/components/ReIcon/data"; import { IconJson } from "@/components/ReIcon/data";
import { cloneDeep, isAllEmpty } from "@pureadmin/utils"; import { cloneDeep, isAllEmpty } from "@pureadmin/utils";
import { ref, computed, CSSProperties, watch } from "vue"; import { ref, computed, CSSProperties, watch } from "vue";
import Search from "~icons/ri/search-eye-line"; import Search from "@iconify-icons/ri/search-eye-line";
type ParameterCSSProperties = (item?: string) => CSSProperties | undefined; type ParameterCSSProperties = (item?: string) => CSSProperties | undefined;
@@ -158,7 +158,7 @@ watch(
:name="pane.name" :name="pane.name"
> >
<el-scrollbar height="220px"> <el-scrollbar height="220px">
<ul class="flex flex-wrap px-2! ml-2!"> <ul class="flex flex-wrap px-2 ml-2">
<li <li
v-for="(item, key) in pageList" v-for="(item, key) in pageList"
:key="key" :key="key"
@@ -198,7 +198,7 @@ watch(
@current-change="onCurrentChange" @current-change="onCurrentChange"
/> />
<el-button <el-button
class="justify-end mx-2!" class="justify-end mr-2 ml-2"
type="danger" type="danger"
size="small" size="small"
text text

View File

@@ -1,6 +1,6 @@
import type { iconType } from "./types"; import type { iconType } from "./types";
import { h, defineComponent, type Component } from "vue"; import { h, defineComponent, type Component } from "vue";
import { FontIcon, IconifyIconOnline, IconifyIconOffline } from "../index"; import { IconifyIconOnline, IconifyIconOffline, FontIcon } from "../index";
/** /**
* 支持 `iconfont`、自定义 `svg` 以及 `iconify` 中所有的图标 * 支持 `iconfont`、自定义 `svg` 以及 `iconify` 中所有的图标
@@ -49,12 +49,10 @@ export function useRenderIcon(icon: any, attrs?: iconType): Component {
return defineComponent({ return defineComponent({
name: "Icon", name: "Icon",
render() { render() {
if (!icon) return; const IconifyIcon =
const IconifyIcon = icon.includes(":") icon && icon.includes(":") ? IconifyIconOnline : IconifyIconOffline;
? IconifyIconOnline
: IconifyIconOffline;
return h(IconifyIcon, { return h(IconifyIcon, {
icon, icon: icon,
...attrs ...attrs
}); });
} }

View File

@@ -13,7 +13,6 @@ export default defineComponent({
render() { render() {
if (typeof this.icon === "object") addIcon(this.icon, this.icon); if (typeof this.icon === "object") addIcon(this.icon, this.icon);
const attrs = this.$attrs; const attrs = this.$attrs;
if (typeof this.icon === "string") {
return h( return h(
IconifyIcon, IconifyIcon,
{ {
@@ -28,20 +27,5 @@ export default defineComponent({
default: () => [] default: () => []
} }
); );
} else {
return h(
this.icon,
{
"aria-hidden": false,
style: attrs?.style
? Object.assign(attrs.style, { outline: "none" })
: { outline: "none" },
...attrs
},
{
default: () => []
}
);
}
} }
}); });

View File

@@ -1,87 +1,70 @@
// 这里存放本地图标,在 src/layout/index.vue 文件中加载,避免在首启动加载 // 这里存放本地图标,在 src/layout/index.vue 文件中加载,避免在首启动加载
import { getSvgInfo } from "@pureadmin/utils";
import { addIcon } from "@iconify/vue/dist/offline"; import { addIcon } from "@iconify/vue/dist/offline";
// https://icon-sets.iconify.design/ep/?keyword=ep
import EpMenu from "~icons/ep/menu?raw";
import EpEdit from "~icons/ep/edit?raw";
import EpGuide from "~icons/ep/guide?raw";
import EpSetUp from "~icons/ep/set-up?raw";
import EpMonitor from "~icons/ep/monitor?raw";
import EpLollipop from "~icons/ep/lollipop?raw";
import EpHistogram from "~icons/ep/histogram?raw";
import EpHomeFilled from "~icons/ep/home-filled?raw";
// https://icon-sets.iconify.design/ri/?keyword=ri
import RiMindMap from "~icons/ri/mind-map?raw";
import RiAdminFill from "~icons/ri/admin-fill?raw";
import RiTableLine from "~icons/ri/table-line?raw";
import RiLinksFill from "~icons/ri/links-fill?raw";
import RiAdminLine from "~icons/ri/admin-line?raw";
import RiListCheck from "~icons/ri/list-check?raw";
import RiSearchLine from "~icons/ri/search-line?raw";
import RiWindowLine from "~icons/ri/window-line?raw";
import RiUbuntuFill from "~icons/ri/ubuntu-fill?raw";
import RiHistoryFill from "~icons/ri/history-fill?raw";
import RiEditBoxLine from "~icons/ri/edit-box-line?raw";
import RiCodeBoxLine from "~icons/ri/code-box-line?raw";
import RiArtboardLine from "~icons/ri/artboard-line?raw";
import RiMarkdownLine from "~icons/ri/markdown-line?raw";
import RiFileInfoLine from "~icons/ri/file-info-line?raw";
import RiBankCardLine from "~icons/ri/bank-card-line?raw";
import RiFilePpt2Line from "~icons/ri/file-ppt-2-line?raw";
import RiGitBranchLine from "~icons/ri/git-branch-line?raw";
import RiSettings3Line from "~icons/ri/settings-3-line?raw";
import RiUserVoiceLine from "~icons/ri/user-voice-line?raw";
import RiBookmark2Line from "~icons/ri/bookmark-2-line?raw";
import RiFileSearchLine from "~icons/ri/file-search-line?raw";
import RiChatSearchLine from "~icons/ri/chat-search-line?raw";
import RiInformationLine from "~icons/ri/information-line?raw";
import RiTerminalWindowLine from "~icons/ri/terminal-window-line?raw";
import RiCheckboxCircleLine from "~icons/ri/checkbox-circle-line?raw";
import RiBarChartHorizontalLine from "~icons/ri/bar-chart-horizontal-line?raw";
const icons = [
// Element Plus Icon: https://github.com/element-plus/element-plus-icons
["ep/menu", EpMenu],
["ep/edit", EpEdit],
["ep/guide", EpGuide],
["ep/set-up", EpSetUp],
["ep/monitor", EpMonitor],
["ep/lollipop", EpLollipop],
["ep/histogram", EpHistogram],
["ep/home-filled", EpHomeFilled],
// Remix Icon: https://github.com/Remix-Design/RemixIcon
["ri/mind-map", RiMindMap],
["ri/admin-fill", RiAdminFill],
["ri/table-line", RiTableLine],
["ri/links-fill", RiLinksFill],
["ri/admin-line", RiAdminLine],
["ri/list-check", RiListCheck],
["ri/search-line", RiSearchLine],
["ri/window-line", RiWindowLine],
["ri/ubuntu-fill", RiUbuntuFill],
["ri/history-fill", RiHistoryFill],
["ri/edit-box-line", RiEditBoxLine],
["ri/code-box-line", RiCodeBoxLine],
["ri/artboard-line", RiArtboardLine],
["ri/markdown-line", RiMarkdownLine],
["ri/file-info-line", RiFileInfoLine],
["ri/bank-card-line", RiBankCardLine],
["ri/file-ppt-2-line", RiFilePpt2Line],
["ri/git-branch-line", RiGitBranchLine],
["ri/settings-3-line", RiSettings3Line],
["ri/user-voice-line", RiUserVoiceLine],
["ri/bookmark-2-line", RiBookmark2Line],
["ri/file-search-line", RiFileSearchLine],
["ri/chat-search-line", RiChatSearchLine],
["ri/information-line", RiInformationLine],
["ri/terminal-window-line", RiTerminalWindowLine],
["ri/checkbox-circle-line", RiCheckboxCircleLine],
["ri/bar-chart-horizontal-line", RiBarChartHorizontalLine]
];
// 本地菜单图标,后端在路由的 icon 中返回对应的图标字符串并且前端在此处使用 addIcon 添加即可渲染菜单图标 // 本地菜单图标,后端在路由的 icon 中返回对应的图标字符串并且前端在此处使用 addIcon 添加即可渲染菜单图标
icons.forEach(([name, icon]) => { // @iconify-icons/ep
addIcon(name as string, getSvgInfo(icon as string)); import Menu from "@iconify-icons/ep/menu";
}); import Edit from "@iconify-icons/ep/edit";
import SetUp from "@iconify-icons/ep/set-up";
import Guide from "@iconify-icons/ep/guide";
import Monitor from "@iconify-icons/ep/monitor";
import Lollipop from "@iconify-icons/ep/lollipop";
import Histogram from "@iconify-icons/ep/histogram";
import HomeFilled from "@iconify-icons/ep/home-filled";
addIcon("ep:menu", Menu);
addIcon("ep:edit", Edit);
addIcon("ep:set-up", SetUp);
addIcon("ep:guide", Guide);
addIcon("ep:monitor", Monitor);
addIcon("ep:lollipop", Lollipop);
addIcon("ep:histogram", Histogram);
addIcon("ep:home-filled", HomeFilled);
// @iconify-icons/ri
import Tag from "@iconify-icons/ri/bookmark-2-line";
import Ppt from "@iconify-icons/ri/file-ppt-2-line";
import Card from "@iconify-icons/ri/bank-card-line";
import Role from "@iconify-icons/ri/admin-fill";
import Info from "@iconify-icons/ri/file-info-line";
import Dept from "@iconify-icons/ri/git-branch-line";
import Table from "@iconify-icons/ri/table-line";
import Links from "@iconify-icons/ri/links-fill";
import Search from "@iconify-icons/ri/search-line";
import FlUser from "@iconify-icons/ri/admin-line";
import Setting from "@iconify-icons/ri/settings-3-line";
import MindMap from "@iconify-icons/ri/mind-map";
import BarChart from "@iconify-icons/ri/bar-chart-horizontal-line";
import LoginLog from "@iconify-icons/ri/window-line";
import Artboard from "@iconify-icons/ri/artboard-line";
import SystemLog from "@iconify-icons/ri/file-search-line";
import ListCheck from "@iconify-icons/ri/list-check";
import UbuntuFill from "@iconify-icons/ri/ubuntu-fill";
import OnlineUser from "@iconify-icons/ri/user-voice-line";
import EditBoxLine from "@iconify-icons/ri/edit-box-line";
import OperationLog from "@iconify-icons/ri/history-fill";
import InformationLine from "@iconify-icons/ri/information-line";
import TerminalWindowLine from "@iconify-icons/ri/terminal-window-line";
import CheckboxCircleLine from "@iconify-icons/ri/checkbox-circle-line";
addIcon("ri:bookmark-2-line", Tag);
addIcon("ri:file-ppt-2-line", Ppt);
addIcon("ri:bank-card-line", Card);
addIcon("ri:admin-fill", Role);
addIcon("ri:file-info-line", Info);
addIcon("ri:git-branch-line", Dept);
addIcon("ri:links-fill", Links);
addIcon("ri:table-line", Table);
addIcon("ri:search-line", Search);
addIcon("ri:admin-line", FlUser);
addIcon("ri:settings-3-line", Setting);
addIcon("ri:mind-map", MindMap);
addIcon("ri:bar-chart-horizontal-line", BarChart);
addIcon("ri:window-line", LoginLog);
addIcon("ri:file-search-line", SystemLog);
addIcon("ri:artboard-line", Artboard);
addIcon("ri:list-check", ListCheck);
addIcon("ri:ubuntu-fill", UbuntuFill);
addIcon("ri:user-voice-line", OnlineUser);
addIcon("ri:edit-box-line", EditBoxLine);
addIcon("ri:history-fill", OperationLog);
addIcon("ri:information-line", InformationLine);
addIcon("ri:terminal-window-line", TerminalWindowLine);
addIcon("ri:checkbox-circle-line", CheckboxCircleLine);

View File

@@ -18,8 +18,8 @@ import {
getKeyList getKeyList
} from "@pureadmin/utils"; } from "@pureadmin/utils";
import Fullscreen from "~icons/ri/fullscreen-fill"; import Fullscreen from "@iconify-icons/ri/fullscreen-fill";
import ExitFullscreen from "~icons/ri/fullscreen-exit-fill"; import ExitFullscreen from "@iconify-icons/ri/fullscreen-exit-fill";
import DragIcon from "@/assets/table-bar/drag.svg?component"; import DragIcon from "@/assets/table-bar/drag.svg?component";
import ExpandIcon from "@/assets/table-bar/expand.svg?component"; import ExpandIcon from "@/assets/table-bar/expand.svg?component";
import RefreshIcon from "@/assets/table-bar/refresh.svg?component"; import RefreshIcon from "@/assets/table-bar/refresh.svg?component";
@@ -87,9 +87,9 @@ export default defineComponent({
"text-black", "text-black",
"dark:text-white", "dark:text-white",
"duration-100", "duration-100",
"hover:text-primary!", "hover:!text-primary",
"cursor-pointer", "cursor-pointer",
"outline-hidden" "outline-none"
]; ];
}); });
@@ -255,12 +255,12 @@ export default defineComponent({
<div <div
{...attrs} {...attrs}
class={[ class={[
"w-full", "w-[99/100]",
"px-2", "px-2",
"pb-2", "pb-2",
"bg-bg_color", "bg-bg_color",
isFullscreen.value isFullscreen.value
? ["h-full!", "z-2002", "fixed", "inset-0"] ? ["!w-full", "!h-full", "z-[2002]", "fixed", "inset-0"]
: "mt-2" : "mt-2"
]} ]}
> >
@@ -317,7 +317,7 @@ export default defineComponent({
> >
<div class={[topClass.value]}> <div class={[topClass.value]}>
<el-checkbox <el-checkbox
class="-mr-1!" class="!-mr-1"
label="列展示" label="列展示"
v-model={checkAll.value} v-model={checkAll.value}
indeterminate={isIndeterminate.value} indeterminate={isIndeterminate.value}
@@ -347,8 +347,8 @@ export default defineComponent({
class={[ class={[
"drag-btn w-[16px] mr-2", "drag-btn w-[16px] mr-2",
isFixedColumn(item) isFixedColumn(item)
? "cursor-no-drop!" ? "!cursor-no-drop"
: "cursor-grab!" : "!cursor-grab"
]} ]}
onMouseenter={(event: { onMouseenter={(event: {
preventDefault: () => void; preventDefault: () => void;

View File

@@ -11,7 +11,7 @@ import "./index.scss";
import propTypes from "@/utils/propTypes"; import propTypes from "@/utils/propTypes";
import { isString, cloneDeep } from "@pureadmin/utils"; import { isString, cloneDeep } from "@pureadmin/utils";
import QRCode, { type QRCodeRenderersOptions } from "qrcode"; import QRCode, { type QRCodeRenderersOptions } from "qrcode";
import RefreshRight from "~icons/ep/refresh-right"; import RefreshRight from "@iconify-icons/ep/refresh-right";
interface QrcodeLogo { interface QrcodeLogo {
src?: string; src?: string;

View File

@@ -60,15 +60,12 @@ export function copyObj() {
copyIsArray, copyIsArray,
clone, clone,
i = 1, i = 1,
// eslint-disable-next-line prefer-rest-params
target = arguments[0] || {}, // 使用||运算符排除隐式强制类型转换为false的数据类型 target = arguments[0] || {}, // 使用||运算符排除隐式强制类型转换为false的数据类型
deep = false, deep = false,
// eslint-disable-next-line prefer-const
len = arguments.length; len = arguments.length;
if (typeof target === "boolean") { if (typeof target === "boolean") {
deep = target; deep = target;
// eslint-disable-next-line prefer-rest-params
target = arguments[1] || {}; target = arguments[1] || {};
i++; i++;
} }
@@ -82,7 +79,6 @@ export function copyObj() {
for (; i < len; i++) { for (; i < len; i++) {
//所以如果源对象中数据类型为Undefined或Null那么就会跳过本次循环接着循环下一个源对象 //所以如果源对象中数据类型为Undefined或Null那么就会跳过本次循环接着循环下一个源对象
// eslint-disable-next-line prefer-rest-params
if ((options = arguments[i]) != null) { if ((options = arguments[i]) != null) {
// 如果遇到源对象的数据类型为Boolean, Number for in循环会被跳过不执行for in循环// src用于判断target对象是否存在name属性 // 如果遇到源对象的数据类型为Boolean, Number for in循环会被跳过不执行for in循环// src用于判断target对象是否存在name属性
for (name in options) { for (name in options) {

View File

@@ -12,8 +12,8 @@ import {
getCurrentInstance getCurrentInstance
} from "vue"; } from "vue";
import Fullscreen from "~icons/ri/fullscreen-fill"; import Fullscreen from "@iconify-icons/ri/fullscreen-fill";
import ExitFullscreen from "~icons/ri/fullscreen-exit-fill"; import ExitFullscreen from "@iconify-icons/ri/fullscreen-exit-fill";
import DragIcon from "@/assets/table-bar/drag.svg?component"; import DragIcon from "@/assets/table-bar/drag.svg?component";
import ExpandIcon from "@/assets/table-bar/expand.svg?component"; import ExpandIcon from "@/assets/table-bar/expand.svg?component";
import RefreshIcon from "@/assets/table-bar/refresh.svg?component"; import RefreshIcon from "@/assets/table-bar/refresh.svg?component";
@@ -80,9 +80,9 @@ export default defineComponent({
"text-black", "text-black",
"dark:text-white", "dark:text-white",
"duration-100", "duration-100",
"hover:text-primary!", "hover:!text-primary",
"cursor-pointer", "cursor-pointer",
"outline-hidden" "outline-none"
]; ];
}); });
@@ -248,12 +248,12 @@ export default defineComponent({
<div <div
{...attrs} {...attrs}
class={[ class={[
"w-full", "w-[99/100]",
"px-2", "px-2",
"pb-2", "pb-2",
"bg-bg_color", "bg-bg_color",
isFullscreen.value isFullscreen.value
? ["h-full!", "z-2002", "fixed", "inset-0"] ? ["!w-full", "!h-full", "z-[2002]", "fixed", "inset-0"]
: "mt-2" : "mt-2"
]} ]}
> >
@@ -310,7 +310,7 @@ export default defineComponent({
> >
<div class={[topClass.value]}> <div class={[topClass.value]}>
<el-checkbox <el-checkbox
class="-mr-1!" class="!-mr-1"
label="列展示" label="列展示"
v-model={checkAll.value} v-model={checkAll.value}
indeterminate={isIndeterminate.value} indeterminate={isIndeterminate.value}
@@ -340,8 +340,8 @@ export default defineComponent({
class={[ class={[
"drag-btn w-[16px] mr-2", "drag-btn w-[16px] mr-2",
isFixedColumn(item) isFixedColumn(item)
? "cursor-no-drop!" ? "!cursor-no-drop"
: "cursor-grab!" : "!cursor-grab"
]} ]}
onMouseenter={(event: { onMouseenter={(event: {
preventDefault: () => void; preventDefault: () => void;

View File

@@ -32,8 +32,8 @@ const calculate = (
const offset = el.getBoundingClientRect(); const offset = el.getBoundingClientRect();
// 获取点击位置距离 el 的垂直和水平距离 // 获取点击位置距离 el 的垂直和水平距离
const localX = e.clientX - offset.left; let localX = e.clientX - offset.left;
const localY = e.clientY - offset.top; let localY = e.clientY - offset.top;
let radius = 0; let radius = 0;
let scale = 0.3; let scale = 0.3;

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-2024
<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

@@ -9,10 +9,10 @@ import LaySidebarBreadCrumb from "../lay-sidebar/components/SidebarBreadCrumb.vu
import LaySidebarTopCollapse from "../lay-sidebar/components/SidebarTopCollapse.vue"; import LaySidebarTopCollapse from "../lay-sidebar/components/SidebarTopCollapse.vue";
import GlobalizationIcon from "@/assets/svg/globalization.svg?component"; import GlobalizationIcon from "@/assets/svg/globalization.svg?component";
import AccountSettingsIcon from "~icons/ri/user-settings-line"; import AccountSettingsIcon from "@iconify-icons/ri/user-settings-line";
import LogoutCircleRLine from "~icons/ri/logout-circle-r-line"; import LogoutCircleRLine from "@iconify-icons/ri/logout-circle-r-line";
import Setting from "~icons/ri/settings-3-line"; import Setting from "@iconify-icons/ri/settings-3-line";
import Check from "~icons/ep/check"; import Check from "@iconify-icons/ep/check";
const { const {
layout, layout,
@@ -33,7 +33,7 @@ const { t, locale, translationCh, translationEn } = useTranslationLang();
</script> </script>
<template> <template>
<div class="navbar bg-[#fff] shadow-xs shadow-[rgba(0,21,41,0.08)]"> <div class="navbar bg-[#fff] shadow-sm shadow-[rgba(0,21,41,0.08)]">
<LaySidebarTopCollapse <LaySidebarTopCollapse
v-if="device === 'mobile'" v-if="device === 'mobile'"
class="hamburger-container" class="hamburger-container"
@@ -54,13 +54,13 @@ const { t, locale, translationCh, translationEn } = useTranslationLang();
<!-- 国际化 --> <!-- 国际化 -->
<el-dropdown id="header-translation" trigger="click"> <el-dropdown id="header-translation" trigger="click">
<GlobalizationIcon <GlobalizationIcon
class="navbar-bg-hover w-[40px] h-[48px] p-[11px] cursor-pointer outline-hidden" class="navbar-bg-hover w-[40px] h-[48px] p-[11px] cursor-pointer outline-none"
/> />
<template #dropdown> <template #dropdown>
<el-dropdown-menu class="translation"> <el-dropdown-menu class="translation">
<el-dropdown-item <el-dropdown-item
:style="getDropdownItemStyle(locale, 'zh')" :style="getDropdownItemStyle(locale, 'zh')"
:class="['dark:text-white!', getDropdownItemClass(locale, 'zh')]" :class="['dark:!text-white', getDropdownItemClass(locale, 'zh')]"
@click="translationCh" @click="translationCh"
> >
<IconifyIconOffline <IconifyIconOffline
@@ -72,7 +72,7 @@ const { t, locale, translationCh, translationEn } = useTranslationLang();
</el-dropdown-item> </el-dropdown-item>
<el-dropdown-item <el-dropdown-item
:style="getDropdownItemStyle(locale, 'en')" :style="getDropdownItemStyle(locale, 'en')"
:class="['dark:text-white!', getDropdownItemClass(locale, 'en')]" :class="['dark:!text-white', getDropdownItemClass(locale, 'en')]"
@click="translationEn" @click="translationEn"
> >
<span v-show="locale === 'en'" class="check-en"> <span v-show="locale === 'en'" class="check-en">

View File

@@ -49,7 +49,7 @@ function hoverDescription(event, description) {
<template> <template>
<div <div
class="notice-container border-0 border-b-[1px] border-solid border-[#f0f0f0] dark:border-[#303030]" class="notice-container border-b-[1px] border-solid border-[#f0f0f0] dark:border-[#303030]"
> >
<el-avatar <el-avatar
v-if="noticeItem.avatar" v-if="noticeItem.avatar"

View File

@@ -3,7 +3,7 @@ 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 "@iconify-icons/ep/bell";
const { t } = useI18n(); const { t } = useI18n();
const noticesNum = ref(0); const noticesNum = ref(0);

View File

@@ -4,7 +4,7 @@ import { emitter } from "@/utils/mitt";
import { onClickOutside } from "@vueuse/core"; import { onClickOutside } from "@vueuse/core";
import { ref, computed, onMounted, onBeforeUnmount } from "vue"; import { ref, computed, onMounted, onBeforeUnmount } from "vue";
import { useDataThemeChange } from "@/layout/hooks/useDataThemeChange"; import { useDataThemeChange } from "@/layout/hooks/useDataThemeChange";
import CloseIcon from "~icons/ep/close"; import CloseIcon from "@iconify-icons/ep/close";
const target = ref(null); const target = ref(null);
const show = ref<Boolean>(false); const show = ref<Boolean>(false);
@@ -16,7 +16,7 @@ const iconClass = computed(() => {
"flex", "flex",
"justify-center", "justify-center",
"items-center", "items-center",
"outline-hidden", "outline-none",
"rounded-[4px]", "rounded-[4px]",
"cursor-pointer", "cursor-pointer",
"transition-colors", "transition-colors",
@@ -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="project-configuration border-b-[1px] border-solid border-[var(--pure-border-color)]"
> >
<h4 class="dark:text-white"> <h4 class="dark:text-white">
{{ t("panel.pureSystemSet") }} {{ t("panel.pureSystemSet") }}
@@ -78,7 +78,7 @@ onBeforeUnmount(() => {
</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-t-[1px] border-solid border-[var(--pure-border-color)]"
> >
<el-button <el-button
v-tippy="{ v-tippy="{

View File

@@ -3,10 +3,10 @@ import { useI18n } from "vue-i18n";
import { useNav } from "@/layout/hooks/useNav"; import { useNav } from "@/layout/hooks/useNav";
import MdiKeyboardEsc from "@/assets/svg/keyboard_esc.svg?component"; import MdiKeyboardEsc from "@/assets/svg/keyboard_esc.svg?component";
import EnterOutlined from "@/assets/svg/enter_outlined.svg?component"; import EnterOutlined from "@/assets/svg/enter_outlined.svg?component";
import ArrowUpLine from "~icons/ri/arrow-up-line"; import ArrowUpLine from "@iconify-icons/ri/arrow-up-line";
import ArrowDownLine from "~icons/ri/arrow-down-line"; import ArrowDownLine from "@iconify-icons/ri/arrow-down-line";
withDefaults(defineProps<{ total?: number }>(), { withDefaults(defineProps<{ total: number }>(), {
total: 0 total: 0
}); });

View File

@@ -2,8 +2,8 @@
import type { optionsItem } from "../types"; import type { optionsItem } from "../types";
import { transformI18n } from "@/plugins/i18n"; import { transformI18n } from "@/plugins/i18n";
import { useRenderIcon } from "@/components/ReIcon/src/hooks"; import { useRenderIcon } from "@/components/ReIcon/src/hooks";
import StarIcon from "~icons/ep/star"; import StarIcon from "@iconify-icons/ep/star";
import CloseIcon from "~icons/ep/close"; import CloseIcon from "@iconify-icons/ep/close";
interface Props { interface Props {
item: optionsItem; item: optionsItem;

View File

@@ -13,7 +13,7 @@ import { ref, computed, shallowRef, watch } from "vue";
import { useDebounceFn, onKeyStroke } from "@vueuse/core"; import { useDebounceFn, onKeyStroke } from "@vueuse/core";
import { usePermissionStoreHook } from "@/store/modules/permission"; import { usePermissionStoreHook } from "@/store/modules/permission";
import { cloneDeep, isAllEmpty, storageLocal } from "@pureadmin/utils"; import { cloneDeep, isAllEmpty, storageLocal } from "@pureadmin/utils";
import SearchIcon from "~icons/ri/search-line"; import SearchIcon from "@iconify-icons/ri/search-line";
interface Props { interface Props {
/** 弹窗显隐 */ /** 弹窗显隐 */

View File

@@ -14,7 +14,7 @@ function handleSearch() {
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"
@click="handleSearch" @click="handleSearch"
> >
<IconifyIconOffline icon="ri/search-line" /> <IconifyIconOffline icon="ri:search-line" />
</div> </div>
<SearchModal v-model:value="show" /> <SearchModal v-model:value="show" />
</div> </div>

View File

@@ -19,9 +19,9 @@ import Segmented, { type OptionsType } from "@/components/ReSegmented";
import { useDataThemeChange } from "@/layout/hooks/useDataThemeChange"; import { useDataThemeChange } from "@/layout/hooks/useDataThemeChange";
import { useDark, useGlobal, debounce, isNumber } from "@pureadmin/utils"; import { useDark, useGlobal, debounce, isNumber } from "@pureadmin/utils";
import Check from "~icons/ep/check"; import Check from "@iconify-icons/ep/check";
import LeftArrow from "~icons/ri/arrow-left-s-line?width=20&height=20"; import LeftArrow from "@iconify-icons/ri/arrow-left-s-line";
import RightArrow from "~icons/ri/arrow-right-s-line?width=20&height=20"; import RightArrow from "@iconify-icons/ri/arrow-right-s-line";
import DayIcon from "@/assets/svg/day.svg?component"; import DayIcon from "@/assets/svg/day.svg?component";
import DarkIcon from "@/assets/svg/dark.svg?component"; import DarkIcon from "@/assets/svg/dark.svg?component";
import SystemIcon from "@/assets/svg/system.svg?component"; import SystemIcon from "@/assets/svg/system.svg?component";
@@ -189,7 +189,7 @@ const getThemeColor = computed(() => {
}); });
const pClass = computed(() => { const pClass = computed(() => {
return ["mb-[12px]!", "font-medium", "text-sm", "dark:text-white"]; return ["mb-[12px]", "font-medium", "text-sm", "dark:text-white"];
}); });
const themeOptions = computed<Array<OptionsType>>(() => { const themeOptions = computed<Array<OptionsType>>(() => {
@@ -335,7 +335,7 @@ onUnmounted(() => removeMatchMedia);
" "
/> />
<p :class="['mt-5!', pClass]">{{ t("panel.pureThemeColor") }}</p> <p :class="['mt-5', pClass]">{{ t("panel.pureThemeColor") }}</p>
<ul class="theme-color"> <ul class="theme-color">
<li <li
v-for="(item, index) in themeColors" v-for="(item, index) in themeColors"
@@ -354,7 +354,7 @@ onUnmounted(() => removeMatchMedia);
</li> </li>
</ul> </ul>
<p :class="['mt-5!', pClass]">{{ t("panel.pureLayoutModel") }}</p> <p :class="['mt-5', pClass]">{{ t("panel.pureLayoutModel") }}</p>
<ul class="pure-theme"> <ul class="pure-theme">
<li <li
ref="verticalRef" ref="verticalRef"
@@ -397,7 +397,7 @@ onUnmounted(() => removeMatchMedia);
</ul> </ul>
<span v-if="useAppStoreHook().getViewportWidth > 1280"> <span v-if="useAppStoreHook().getViewportWidth > 1280">
<p :class="['mt-5!', pClass]">{{ t("panel.pureStretch") }}</p> <p :class="['mt-5', pClass]">{{ t("panel.pureStretch") }}</p>
<Segmented <Segmented
resize resize
class="mb-2 select-none" class="mb-2 select-none"
@@ -426,19 +426,21 @@ onUnmounted(() => removeMatchMedia);
> >
<IconifyIconOffline <IconifyIconOffline
:icon="settings.stretch ? RightArrow : LeftArrow" :icon="settings.stretch ? RightArrow : LeftArrow"
height="20"
/> />
<div <div
class="grow border-0 border-b border-dashed" class="flex-grow border-b border-dashed"
style="border-color: var(--el-color-primary)" style="border-color: var(--el-color-primary)"
/> />
<IconifyIconOffline <IconifyIconOffline
:icon="settings.stretch ? LeftArrow : RightArrow" :icon="settings.stretch ? LeftArrow : RightArrow"
height="20"
/> />
</div> </div>
</button> </button>
</span> </span>
<p :class="['mt-4!', pClass]">{{ t("panel.pureTagsStyle") }}</p> <p :class="['mt-4', pClass]">{{ t("panel.pureTagsStyle") }}</p>
<Segmented <Segmented
resize resize
class="select-none" class="select-none"
@@ -447,7 +449,7 @@ onUnmounted(() => removeMatchMedia);
@change="onChange" @change="onChange"
/> />
<p class="mt-5! font-medium text-sm dark:text-white"> <p class="mt-5 font-medium text-sm dark:text-white">
{{ t("panel.pureInterfaceDisplay") }} {{ t("panel.pureInterfaceDisplay") }}
</p> </p>
<ul class="setting"> <ul class="setting">

View File

@@ -12,10 +12,10 @@ import LaySidebarItem from "../lay-sidebar/components/SidebarItem.vue";
import LaySidebarFullScreen from "../lay-sidebar/components/SidebarFullScreen.vue"; import LaySidebarFullScreen from "../lay-sidebar/components/SidebarFullScreen.vue";
import GlobalizationIcon from "@/assets/svg/globalization.svg?component"; import GlobalizationIcon from "@/assets/svg/globalization.svg?component";
import AccountSettingsIcon from "~icons/ri/user-settings-line"; import AccountSettingsIcon from "@iconify-icons/ri/user-settings-line";
import LogoutCircleRLine from "~icons/ri/logout-circle-r-line"; import LogoutCircleRLine from "@iconify-icons/ri/logout-circle-r-line";
import Setting from "~icons/ri/settings-3-line"; import Setting from "@iconify-icons/ri/settings-3-line";
import Check from "~icons/ep/check"; import Check from "@iconify-icons/ep/check";
const menuRef = ref(); const menuRef = ref();
const showLogo = ref( const showLogo = ref(
@@ -84,13 +84,13 @@ onMounted(() => {
<!-- 国际化 --> <!-- 国际化 -->
<el-dropdown id="header-translation" trigger="click"> <el-dropdown id="header-translation" trigger="click">
<GlobalizationIcon <GlobalizationIcon
class="navbar-bg-hover w-[40px] h-[48px] p-[11px] cursor-pointer outline-hidden" class="navbar-bg-hover w-[40px] h-[48px] p-[11px] cursor-pointer outline-none"
/> />
<template #dropdown> <template #dropdown>
<el-dropdown-menu class="translation"> <el-dropdown-menu class="translation">
<el-dropdown-item <el-dropdown-item
:style="getDropdownItemStyle(locale, 'zh')" :style="getDropdownItemStyle(locale, 'zh')"
:class="['dark:text-white!', getDropdownItemClass(locale, 'zh')]" :class="['dark:!text-white', getDropdownItemClass(locale, 'zh')]"
@click="translationCh" @click="translationCh"
> >
<span v-show="locale === 'zh'" class="check-zh"> <span v-show="locale === 'zh'" class="check-zh">
@@ -100,7 +100,7 @@ onMounted(() => {
</el-dropdown-item> </el-dropdown-item>
<el-dropdown-item <el-dropdown-item
:style="getDropdownItemStyle(locale, 'en')" :style="getDropdownItemStyle(locale, 'en')"
:class="['dark:text-white!', getDropdownItemClass(locale, 'en')]" :class="['dark:!text-white', getDropdownItemClass(locale, 'en')]"
@click="translationEn" @click="translationEn"
> >
<span v-show="locale === 'en'" class="check-en"> <span v-show="locale === 'en'" class="check-en">

View File

@@ -13,10 +13,10 @@ import LaySidebarExtraIcon from "../lay-sidebar/components/SidebarExtraIcon.vue"
import LaySidebarFullScreen from "../lay-sidebar/components/SidebarFullScreen.vue"; import LaySidebarFullScreen from "../lay-sidebar/components/SidebarFullScreen.vue";
import GlobalizationIcon from "@/assets/svg/globalization.svg?component"; import GlobalizationIcon from "@/assets/svg/globalization.svg?component";
import AccountSettingsIcon from "~icons/ri/user-settings-line"; import AccountSettingsIcon from "@iconify-icons/ri/user-settings-line";
import LogoutCircleRLine from "~icons/ri/logout-circle-r-line"; import LogoutCircleRLine from "@iconify-icons/ri/logout-circle-r-line";
import Setting from "~icons/ri/settings-3-line"; import Setting from "@iconify-icons/ri/settings-3-line";
import Check from "~icons/ep/check"; import Check from "@iconify-icons/ep/check";
const menuRef = ref(); const menuRef = ref();
const defaultActive = ref(null); const defaultActive = ref(null);
@@ -105,13 +105,13 @@ watch(
<!-- 国际化 --> <!-- 国际化 -->
<el-dropdown id="header-translation" trigger="click"> <el-dropdown id="header-translation" trigger="click">
<GlobalizationIcon <GlobalizationIcon
class="navbar-bg-hover w-[40px] h-[48px] p-[11px] cursor-pointer outline-hidden" class="navbar-bg-hover w-[40px] h-[48px] p-[11px] cursor-pointer outline-none"
/> />
<template #dropdown> <template #dropdown>
<el-dropdown-menu class="translation"> <el-dropdown-menu class="translation">
<el-dropdown-item <el-dropdown-item
:style="getDropdownItemStyle(locale, 'zh')" :style="getDropdownItemStyle(locale, 'zh')"
:class="['dark:text-white!', getDropdownItemClass(locale, 'zh')]" :class="['dark:!text-white', getDropdownItemClass(locale, 'zh')]"
@click="translationCh" @click="translationCh"
> >
<span v-show="locale === 'zh'" class="check-zh"> <span v-show="locale === 'zh'" class="check-zh">
@@ -121,7 +121,7 @@ watch(
</el-dropdown-item> </el-dropdown-item>
<el-dropdown-item <el-dropdown-item
:style="getDropdownItemStyle(locale, 'en')" :style="getDropdownItemStyle(locale, 'en')"
:class="['dark:text-white!', getDropdownItemClass(locale, 'en')]" :class="['dark:!text-white', getDropdownItemClass(locale, 'en')]"
@click="translationEn" @click="translationEn"
> >
<span v-show="locale === 'en'" class="check-en"> <span v-show="locale === 'en'" class="check-en">

View File

@@ -105,12 +105,12 @@ watch(
</script> </script>
<template> <template>
<el-breadcrumb class="leading-[50px]! select-none" separator="/"> <el-breadcrumb class="!leading-[50px] select-none" separator="/">
<transition-group name="breadcrumb"> <transition-group name="breadcrumb">
<el-breadcrumb-item <el-breadcrumb-item
v-for="item in levelList" v-for="item in levelList"
:key="item.path" :key="item.path"
class="inline! items-stretch!" class="!inline !items-stretch"
> >
<a @click.prevent="handleLink(item)"> <a @click.prevent="handleLink(item)">
{{ transformI18n(item.meta.title) }} {{ transformI18n(item.meta.title) }}

View File

@@ -4,10 +4,10 @@ import { useI18n } from "vue-i18n";
import { useGlobal } from "@pureadmin/utils"; import { useGlobal } from "@pureadmin/utils";
import { useNav } from "@/layout/hooks/useNav"; import { useNav } from "@/layout/hooks/useNav";
import ArrowLeft from "~icons/ri/arrow-left-double-fill"; import ArrowLeft from "@iconify-icons/ri/arrow-left-double-fill";
interface Props { interface Props {
isActive?: boolean; isActive: boolean;
} }
withDefaults(defineProps<Props>(), { withDefaults(defineProps<Props>(), {

View File

@@ -17,10 +17,10 @@ import {
useAttrs useAttrs
} from "vue"; } from "vue";
import ArrowUp from "~icons/ep/arrow-up-bold"; import ArrowUp from "@iconify-icons/ep/arrow-up-bold";
import EpArrowDown from "~icons/ep/arrow-down-bold"; import EpArrowDown from "@iconify-icons/ep/arrow-down-bold";
import ArrowLeft from "~icons/ep/arrow-left-bold"; import ArrowLeft from "@iconify-icons/ep/arrow-left-bold";
import ArrowRight from "~icons/ep/arrow-right-bold"; import ArrowRight from "@iconify-icons/ep/arrow-right-bold";
const attrs = useAttrs(); const attrs = useAttrs();
const { layout, isCollapse, tooltipEffect, getDivStyle } = useNav(); const { layout, isCollapse, tooltipEffect, getDivStyle } = useNav();
@@ -144,7 +144,7 @@ function resolvePath(routePath) {
item?.pathList?.length === 2) item?.pathList?.length === 2)
" "
truncated truncated
class="w-full! pl-4! text-inherit!" class="!w-full !pl-4 !text-inherit"
> >
{{ transformI18n(onlyOneChild.meta.title) }} {{ transformI18n(onlyOneChild.meta.title) }}
</el-text> </el-text>
@@ -156,7 +156,7 @@ function resolvePath(routePath) {
offset: [0, -10], offset: [0, -10],
theme: tooltipEffect theme: tooltipEffect
}" }"
class="w-full! text-inherit!" class="!w-full !text-inherit"
> >
{{ transformI18n(onlyOneChild.meta.title) }} {{ transformI18n(onlyOneChild.meta.title) }}
</ReText> </ReText>
@@ -196,9 +196,9 @@ function resolvePath(routePath) {
theme: tooltipEffect theme: tooltipEffect
}" }"
:class="{ :class="{
'w-full!': true, '!w-full': true,
'text-inherit!': true, '!text-inherit': true,
'pl-4!': '!pl-4':
layout !== 'horizontal' && layout !== 'horizontal' &&
isCollapse && isCollapse &&
!toRaw(item.meta.icon) && !toRaw(item.meta.icon) &&

View File

@@ -4,10 +4,10 @@ import { useI18n } from "vue-i18n";
import { useGlobal } from "@pureadmin/utils"; import { useGlobal } from "@pureadmin/utils";
import { useNav } from "@/layout/hooks/useNav"; import { useNav } from "@/layout/hooks/useNav";
import MenuFold from "~icons/ri/menu-fold-fill"; import MenuFold from "@iconify-icons/ri/menu-fold-fill";
interface Props { interface Props {
isActive?: boolean; isActive: boolean;
} }
withDefaults(defineProps<Props>(), { withDefaults(defineProps<Props>(), {
@@ -23,7 +23,7 @@ const iconClass = computed(() => {
"mb-1", "mb-1",
"w-[16px]", "w-[16px]",
"h-[16px]", "h-[16px]",
"inline-block!", "inline-block",
"align-middle", "align-middle",
"cursor-pointer", "cursor-pointer",
"duration-[100ms]" "duration-[100ms]"

View File

@@ -1,10 +1,10 @@
<script setup lang="ts"> <script setup lang="ts">
import { useI18n } from "vue-i18n"; import { useI18n } from "vue-i18n";
import MenuFold from "~icons/ri/menu-fold-fill"; import MenuFold from "@iconify-icons/ri/menu-fold-fill";
import MenuUnfold from "~icons/ri/menu-unfold-fill"; import MenuUnfold from "@iconify-icons/ri/menu-unfold-fill";
interface Props { interface Props {
isActive?: boolean; isActive: boolean;
} }
withDefaults(defineProps<Props>(), { withDefaults(defineProps<Props>(), {
@@ -32,7 +32,7 @@ const toggleClick = () => {
> >
<IconifyIconOffline <IconifyIconOffline
:icon="isActive ? MenuFold : MenuUnfold" :icon="isActive ? MenuFold : MenuUnfold"
class="inline-block align-middle hover:text-primary dark:hover:text-white!" class="inline-block align-middle hover:text-primary dark:hover:!text-white"
/> />
</div> </div>
</template> </template>

View File

@@ -18,11 +18,11 @@ import {
useResizeObserver useResizeObserver
} from "@pureadmin/utils"; } from "@pureadmin/utils";
import ExitFullscreen from "~icons/ri/fullscreen-exit-fill"; import ExitFullscreen from "@iconify-icons/ri/fullscreen-exit-fill";
import Fullscreen from "~icons/ri/fullscreen-fill"; import Fullscreen from "@iconify-icons/ri/fullscreen-fill";
import ArrowDown from "~icons/ri/arrow-down-s-line"; import ArrowDown from "@iconify-icons/ri/arrow-down-s-line";
import ArrowRightSLine from "~icons/ri/arrow-right-s-line"; import ArrowRightSLine from "@iconify-icons/ri/arrow-right-s-line";
import ArrowLeftSLine from "~icons/ri/arrow-left-s-line"; import ArrowLeftSLine from "@iconify-icons/ri/arrow-left-s-line";
const { const {
Close, Close,
@@ -589,7 +589,7 @@ onBeforeUnmount(() => {
> >
<template v-if="showModel !== 'chrome'"> <template v-if="showModel !== 'chrome'">
<span <span
class="tag-title dark:text-text_color_primary! dark:hover:text-primary!" class="tag-title dark:!text-text_color_primary dark:hover:!text-primary"
> >
{{ transformI18n(item.meta.title) }} {{ transformI18n(item.meta.title) }}
</span> </span>

View File

@@ -14,8 +14,8 @@ import { useUserStoreHook } from "@/store/modules/user";
import { useGlobal, isAllEmpty } from "@pureadmin/utils"; import { useGlobal, isAllEmpty } from "@pureadmin/utils";
import { useEpThemeStoreHook } from "@/store/modules/epTheme"; import { useEpThemeStoreHook } from "@/store/modules/epTheme";
import { usePermissionStoreHook } from "@/store/modules/permission"; import { usePermissionStoreHook } from "@/store/modules/permission";
import ExitFullscreen from "~icons/ri/fullscreen-exit-fill"; import ExitFullscreen from "@iconify-icons/ri/fullscreen-exit-fill";
import Fullscreen from "~icons/ri/fullscreen-fill"; import Fullscreen from "@iconify-icons/ri/fullscreen-fill";
const errorInfo = const errorInfo =
"The current routing configuration is incorrect, please check the configuration"; "The current routing configuration is incorrect, please check the configuration";
@@ -64,7 +64,7 @@ export function useNav() {
const getDropdownItemClass = computed(() => { const getDropdownItemClass = computed(() => {
return (locale, t) => { return (locale, t) => {
return locale === t ? "" : "dark:hover:text-primary!"; return locale === t ? "" : "dark:hover:!text-primary";
}; };
}); });

View File

@@ -21,13 +21,13 @@ import {
hasClass hasClass
} from "@pureadmin/utils"; } from "@pureadmin/utils";
import Fullscreen from "~icons/ri/fullscreen-fill"; import Fullscreen from "@iconify-icons/ri/fullscreen-fill";
import CloseAllTags from "~icons/ri/subtract-line"; import CloseAllTags from "@iconify-icons/ri/subtract-line";
import CloseOtherTags from "~icons/ri/text-spacing"; import CloseOtherTags from "@iconify-icons/ri/text-spacing";
import CloseRightTags from "~icons/ri/text-direction-l"; import CloseRightTags from "@iconify-icons/ri/text-direction-l";
import CloseLeftTags from "~icons/ri/text-direction-r"; import CloseLeftTags from "@iconify-icons/ri/text-direction-r";
import RefreshRight from "~icons/ep/refresh-right"; import RefreshRight from "@iconify-icons/ep/refresh-right";
import Close from "~icons/ep/close"; import Close from "@iconify-icons/ep/close";
export function useTags() { export function useTags() {
const route = useRoute(); const route = useRoute();

View File

@@ -1,4 +1,4 @@
import type { FunctionalComponent } from "vue"; import type { IconifyIcon } from "@iconify/vue";
const { VITE_HIDE_HOME } = import.meta.env; const { VITE_HIDE_HOME } = import.meta.env;
export const routerArrays: Array<RouteConfigs> = export const routerArrays: Array<RouteConfigs> =
@@ -8,7 +8,7 @@ export const routerArrays: Array<RouteConfigs> =
path: "/welcome", path: "/welcome",
meta: { meta: {
title: "menus.pureHome", title: "menus.pureHome",
icon: "ep/home-filled" icon: "ep:home-filled"
} }
} }
] ]
@@ -16,7 +16,7 @@ export const routerArrays: Array<RouteConfigs> =
export type routeMetaType = { export type routeMetaType = {
title?: string; title?: string;
icon?: string | FunctionalComponent; icon?: string | IconifyIcon;
showLink?: boolean; showLink?: boolean;
savedPosition?: boolean; savedPosition?: boolean;
auths?: Array<string>; auths?: Array<string>;
@@ -36,7 +36,7 @@ export type multiTagsType = {
}; };
export type tagsViewsType = { export type tagsViewsType = {
icon: string | FunctionalComponent; icon: string | IconifyIcon;
text: string; text: string;
divided: boolean; divided: boolean;
disabled: boolean; disabled: boolean;

View File

@@ -10,7 +10,7 @@ import zhLocale from "element-plus/es/locale/lang/zh-cn";
const siphonI18n = (function () { const siphonI18n = (function () {
// 仅初始化一次国际化配置 // 仅初始化一次国际化配置
const cache = Object.fromEntries( let cache = Object.fromEntries(
Object.entries( Object.entries(
import.meta.glob("../../locales/*.y(a)?ml", { eager: true }) import.meta.glob("../../locales/*.y(a)?ml", { eager: true })
).map(([key, value]: any) => { ).map(([key, value]: any) => {

View File

@@ -5,7 +5,7 @@ export default {
path: "/able", path: "/able",
redirect: "/able/watermark", redirect: "/able/watermark",
meta: { meta: {
icon: "ri/ubuntu-fill", icon: "ri:ubuntu-fill",
title: $t("menus.pureAble"), title: $t("menus.pureAble"),
rank: able rank: able
}, },

View File

@@ -5,7 +5,7 @@ export default {
path: "/about", path: "/about",
redirect: "/about/index", redirect: "/about/index",
meta: { meta: {
icon: "ri/file-info-line", icon: "ri:file-info-line",
title: $t("menus.pureAbout"), title: $t("menus.pureAbout"),
rank: about rank: about
}, },

View File

@@ -6,7 +6,7 @@ export default {
path: "/board", path: "/board",
redirect: "/board/index", redirect: "/board/index",
meta: { meta: {
icon: "ri/artboard-line", icon: "ri:artboard-line",
title: $t("menus.pureBoard"), title: $t("menus.pureBoard"),
rank: board rank: board
}, },

View File

@@ -4,7 +4,7 @@ export default {
path: "/chatai", path: "/chatai",
redirect: "/chatai/index", redirect: "/chatai/index",
meta: { meta: {
icon: "ri/chat-search-line", icon: "ri:chat-search-line",
title: "chat-ai", title: "chat-ai",
rank: chatai rank: chatai
}, },

View File

@@ -5,7 +5,7 @@ export default {
path: "/codemirror", path: "/codemirror",
redirect: "/codemirror/index", redirect: "/codemirror/index",
meta: { meta: {
icon: "ri/code-box-line", icon: "ri:code-box-line",
title: $t("menus.pureCodeMirror"), title: $t("menus.pureCodeMirror"),
rank: codemirror rank: codemirror
}, },

View File

@@ -5,7 +5,7 @@ export default {
path: "/components", path: "/components",
redirect: "/components/dialog", redirect: "/components/dialog",
meta: { meta: {
icon: "ep/menu", icon: "ep:menu",
title: $t("menus.pureComponents"), title: $t("menus.pureComponents"),
rank: components rank: components
}, },

View File

@@ -5,7 +5,7 @@ export default {
path: "/editor", path: "/editor",
redirect: "/editor/index", redirect: "/editor/index",
meta: { meta: {
icon: "ep/edit", icon: "ep:edit",
title: $t("menus.pureEditor"), title: $t("menus.pureEditor"),
rank: editor rank: editor
}, },

View File

@@ -5,7 +5,7 @@ export default {
path: "/error", path: "/error",
redirect: "/error/403", redirect: "/error/403",
meta: { meta: {
icon: "ri/information-line", icon: "ri:information-line",
// showLink: false, // showLink: false,
title: $t("menus.pureAbnormal"), title: $t("menus.pureAbnormal"),
rank: error rank: error

View File

@@ -5,7 +5,7 @@ export default {
path: "/flow-chart", path: "/flow-chart",
redirect: "/flow-chart/index", redirect: "/flow-chart/index",
meta: { meta: {
icon: "ep/set-up", icon: "ep:set-up",
title: $t("menus.pureFlowChart"), title: $t("menus.pureFlowChart"),
rank: flowchart rank: flowchart
}, },

View File

@@ -5,7 +5,7 @@ export default {
path: "/form", path: "/form",
redirect: "/form/index", redirect: "/form/index",
meta: { meta: {
icon: "ri/edit-box-line", icon: "ri:edit-box-line",
title: $t("menus.pureSchemaForm"), title: $t("menus.pureSchemaForm"),
rank: form rank: form
}, },

View File

@@ -6,7 +6,7 @@ export default {
path: "/form-design", path: "/form-design",
redirect: "/form-design/index", redirect: "/form-design/index",
meta: { meta: {
icon: "ri/terminal-window-line", icon: "ri:terminal-window-line",
title: $t("menus.pureFormDesign"), title: $t("menus.pureFormDesign"),
rank: formdesign rank: formdesign
}, },

View File

@@ -5,7 +5,7 @@ export default {
path: "/ganttastic", path: "/ganttastic",
redirect: "/ganttastic/index", redirect: "/ganttastic/index",
meta: { meta: {
icon: "ri/bar-chart-horizontal-line", icon: "ri:bar-chart-horizontal-line",
title: $t("menus.pureGanttastic"), title: $t("menus.pureGanttastic"),
rank: ganttastic rank: ganttastic
}, },

View File

@@ -5,7 +5,7 @@ export default {
path: "/guide", path: "/guide",
redirect: "/guide/index", redirect: "/guide/index",
meta: { meta: {
icon: "ep/guide", icon: "ep:guide",
title: $t("menus.pureGuide"), title: $t("menus.pureGuide"),
rank: guide rank: guide
}, },

View File

@@ -9,7 +9,7 @@ export default {
component: Layout, component: Layout,
redirect: "/welcome", redirect: "/welcome",
meta: { meta: {
icon: "ep/home-filled", icon: "ep:home-filled",
title: $t("menus.pureHome"), title: $t("menus.pureHome"),
rank: home rank: home
}, },

View File

@@ -5,7 +5,7 @@ export default {
path: "/list", path: "/list",
redirect: "/list/card", redirect: "/list/card",
meta: { meta: {
icon: "ri/list-check", icon: "ri:list-check",
title: $t("menus.pureList"), title: $t("menus.pureList"),
rank: list rank: list
}, },
@@ -15,7 +15,7 @@ export default {
name: "CardList", name: "CardList",
component: () => import("@/views/list/card/index.vue"), component: () => import("@/views/list/card/index.vue"),
meta: { meta: {
icon: "ri/bank-card-line", icon: "ri:bank-card-line",
title: $t("menus.pureCardList"), title: $t("menus.pureCardList"),
showParent: true showParent: true
} }

View File

@@ -5,7 +5,7 @@ export default {
path: "/markdown", path: "/markdown",
redirect: "/markdown/index", redirect: "/markdown/index",
meta: { meta: {
icon: "ri/markdown-line", icon: "ri:markdown-line",
title: $t("menus.pureMarkdown"), title: $t("menus.pureMarkdown"),
rank: markdown rank: markdown
}, },

View File

@@ -6,7 +6,7 @@ export default {
path: "/mind-map", path: "/mind-map",
redirect: "/mind-map/index", redirect: "/mind-map/index",
meta: { meta: {
icon: "ri/mind-map", icon: "ri:mind-map",
title: $t("menus.pureMindMap"), title: $t("menus.pureMindMap"),
rank: mind rank: mind
}, },

View File

@@ -6,7 +6,7 @@ export default {
redirect: "/nested/menu1/menu1-1", redirect: "/nested/menu1/menu1-1",
meta: { meta: {
title: $t("menus.pureMenus"), title: $t("menus.pureMenus"),
icon: "ep/histogram", icon: "ep:histogram",
rank: nested rank: nested
}, },
children: [ children: [

View File

@@ -5,7 +5,7 @@ export default {
path: "/ppt", path: "/ppt",
redirect: "/ppt/index", redirect: "/ppt/index",
meta: { meta: {
icon: "ri/file-ppt-2-line", icon: "ri:file-ppt-2-line",
title: "PPT", title: "PPT",
rank: ppt rank: ppt
}, },

View File

@@ -5,7 +5,7 @@ export default {
path: "/result", path: "/result",
redirect: "/result/success", redirect: "/result/success",
meta: { meta: {
icon: "ri/checkbox-circle-line", icon: "ri:checkbox-circle-line",
title: $t("menus.pureResult"), title: $t("menus.pureResult"),
rank: result rank: result
}, },

View File

@@ -5,7 +5,7 @@ export default {
path: "/table", path: "/table",
redirect: "/table/index", redirect: "/table/index",
meta: { meta: {
icon: "ri/table-line", icon: "ri:table-line",
title: $t("menus.pureTable"), title: $t("menus.pureTable"),
rank: table rank: table
}, },

View File

@@ -4,7 +4,7 @@ export default {
path: "/vue-flow", path: "/vue-flow",
redirect: "/vue-flow/index", redirect: "/vue-flow/index",
meta: { meta: {
icon: "ep/set-up", icon: "ep:set-up",
title: "vue-flow", title: "vue-flow",
rank: vueflow rank: vueflow
}, },

View File

@@ -1,3 +1,12 @@
*,
::before,
::after {
box-sizing: border-box;
border-color: currentColor;
border-style: solid;
border-width: 0;
}
#app { #app {
width: 100%; width: 100%;
height: 100%; height: 100%;

View File

@@ -235,6 +235,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 {

View File

@@ -1,46 +1,21 @@
@layer theme, base, components, utilities; @tailwind base;
@import "tailwindcss/theme.css" layer(theme); @tailwind components;
@import "tailwindcss/utilities.css" layer(utilities); @tailwind utilities;
@custom-variant dark (&:is(.dark *)); @layer components {
.flex-c {
@theme {
--color-bg_color: var(--el-bg-color);
--color-primary: var(--el-color-primary);
--color-text_color_primary: var(--el-text-color-primary);
--color-text_color_regular: var(--el-text-color-regular);
}
/*
The default border color has changed to `currentColor` in Tailwind CSS v4,
so we've added these compatibility styles to make sure everything still
looks the same as it did with Tailwind CSS v3.
If we ever want to remove these styles, we need to add an explicit border
color utility to any element that depends on these defaults.
*/
@layer base {
*,
::after,
::before,
::backdrop,
::file-selector-button {
border-color: var(--color-gray-200, currentColor);
}
}
@utility flex-c {
@apply flex justify-center items-center; @apply flex justify-center items-center;
} }
@utility flex-ac { .flex-ac {
@apply flex justify-around items-center; @apply flex justify-around items-center;
} }
@utility flex-bc { .flex-bc {
@apply flex justify-between items-center; @apply flex justify-between items-center;
} }
@utility navbar-bg-hover { .navbar-bg-hover {
@apply dark:text-white dark:hover:bg-[#242424]!; @apply dark:text-white dark:hover:!bg-[#242424];
}
} }

View File

@@ -140,10 +140,8 @@ Print.prototype = {
"position:absolute;width:0;height:0;top:-10px;left:-10px;" "position:absolute;width:0;height:0;top:-10px;left:-10px;"
); );
// eslint-disable-next-line prefer-const
w = f.contentWindow || f.contentDocument; w = f.contentWindow || f.contentDocument;
// eslint-disable-next-line prefer-const
doc = f.contentDocument || f.contentWindow.document; doc = f.contentDocument || f.contentWindow.document;
doc.open(); doc.open();
doc.write(content); doc.write(content);

View File

@@ -76,7 +76,7 @@ function onReset() {
immediate: true, immediate: true,
timeout: 1000 timeout: 1000
}" }"
class="w-[200px]!" class="!w-[200px]"
clearable clearable
@clear="onInput" @clear="onInput"
/> />
@@ -86,7 +86,7 @@ function onReset() {
<el-input <el-input
v-model="searchTwo" v-model="searchTwo"
v-optimize="{ event: 'input', fn: onInputTwo, timeout: 400 }" v-optimize="{ event: 'input', fn: onInputTwo, timeout: 400 }"
class="w-[200px]!" class="!w-[200px]"
clearable clearable
/> />
</div> </div>
@@ -100,7 +100,7 @@ function onReset() {
timeout: 400, timeout: 400,
params: { name: '小明', sex: '男' } params: { name: '小明', sex: '男' }
}" }"
class="w-[200px]!" class="!w-[200px]"
clearable clearable
/> />
</div> </div>
@@ -112,7 +112,7 @@ function onReset() {
<el-input <el-input
v-model="searchFour" v-model="searchFour"
v-optimize:throttle="{ event: 'input', fn: onInputFour, timeout: 1000 }" v-optimize:throttle="{ event: 'input', fn: onInputFour, timeout: 1000 }"
class="w-[200px]!" class="!w-[200px]"
clearable clearable
/> />
</div> </div>
@@ -125,7 +125,7 @@ function onReset() {
fn: onInputFive, fn: onInputFive,
params: { name: '小明', sex: '男' } params: { name: '小明', sex: '男' }
}" }"
class="w-[200px]!" class="!w-[200px]"
clearable clearable
/> />
</div> </div>
@@ -134,7 +134,7 @@ function onReset() {
<div class="mb-2"> <div class="mb-2">
文本复制指令(双击输入框内容即可复制) 文本复制指令(双击输入框内容即可复制)
<el-input v-model="searchSix" v-copy="searchSix" class="w-[200px]!" /> <el-input v-model="searchSix" v-copy="searchSix" class="!w-[200px]" />
</div> </div>
<div> <div>
文本复制指令(自定义触发事件,单击复制) 文本复制指令(自定义触发事件,单击复制)

View File

@@ -51,9 +51,7 @@ const load = () => {
代码位置 src/views/able/infinite-scroll.vue 代码位置 src/views/able/infinite-scroll.vue
</el-link> </el-link>
</template> </template>
<div class="mb-2"> <p class="mb-2">{{ isBottom ? "已加载全部页" : `加载到第 ${page}` }}</p>
{{ isBottom ? "已加载全部页" : `加载到第 ${page}` }}
</div>
<el-table <el-table
v-el-table-infinite-scroll="load" v-el-table-infinite-scroll="load"
border border

View File

@@ -7,7 +7,7 @@ import { useRenderIcon } from "@/components/ReIcon/src/hooks";
import { extractPathList, deleteChildren } from "@/utils/tree"; import { extractPathList, deleteChildren } from "@/utils/tree";
import { usePermissionStoreHook } from "@/store/modules/permission"; import { usePermissionStoreHook } from "@/store/modules/permission";
import type { TreeNode } from "element-plus/es/components/tree-v2/src/types"; import type { TreeNode } from "element-plus/es/components/tree-v2/src/types";
import NodeTree from "~icons/ri/node-tree"; import NodeTree from "@iconify-icons/ri/node-tree";
defineOptions({ defineOptions({
name: "MenuTree" name: "MenuTree"

View File

@@ -21,8 +21,8 @@ defineOptions({
</div> </div>
</template> </template>
<p v-html="html('带 音 调')" /> <p v-html="html('带 音 调')" />
<p class="mt-2!" v-html="html('不 带 音 调', { toneType: 'none' })" /> <p class="mt-2" v-html="html('不 带 音 调', { toneType: 'none' })" />
<p class="mt-2! custom" v-html="html('自 定 义 样 式')" /> <p class="mt-2 custom" v-html="html('自 定 义 样 式')" />
</el-card> </el-card>
</template> </template>

View File

@@ -83,7 +83,7 @@ const tableData: User[] = [
<span class="font-medium">打印功能报表图表图片</span> <span class="font-medium">打印功能报表图表图片</span>
<el-select <el-select
v-model="value" v-model="value"
class="w-[100px]! mr-2" class="!w-[100px] mr-2"
placeholder="Select" placeholder="Select"
size="small" size="small"
> >

View File

@@ -45,6 +45,6 @@ function onInput() {
</el-tag> </el-tag>
</div> </div>
<el-input v-model="modelValue" @input="onInput" /> <el-input v-model="modelValue" @input="onInput" />
<p class="mt-2!">{{ modelValue }}</p> <p class="mt-2">{{ modelValue }}</p>
</el-card> </el-card>
</template> </template>

View File

@@ -2,7 +2,7 @@
import { onMounted } from "vue"; import { onMounted } from "vue";
import { deviceDetection } from "@pureadmin/utils"; import { deviceDetection } from "@pureadmin/utils";
import { useRenderIcon } from "@/components/ReIcon/src/hooks"; import { useRenderIcon } from "@/components/ReIcon/src/hooks";
import VideoPlay from "~icons/ep/video-play"; import VideoPlay from "@iconify-icons/ep/video-play";
import Player from "xgplayer"; import Player from "xgplayer";
import "xgplayer/dist/index.min.css"; import "xgplayer/dist/index.min.css";

View File

@@ -53,7 +53,7 @@ onBeforeUnmount(() => {
代码位置 src/views/able/watermark.vue 代码位置 src/views/able/watermark.vue
</el-link> </el-link>
</template> </template>
<el-space wrap class="mb-2!"> <el-space wrap class="!mb-2">
<span> 请输入要创建水印的值</span> <span> 请输入要创建水印的值</span>
<el-input v-model="value" class="mr-4" style="width: 200px" clearable /> <el-input v-model="value" class="mr-4" style="width: 200px" clearable />
<span>请选择要创建水印的颜色</span> <span>请选择要创建水印的颜色</span>

View File

@@ -103,13 +103,13 @@ onBeforeUnmount(() => {
</template> </template>
<div <div
v-loading="loading" v-loading="loading"
class="w-8/12 m-auto! mt-[20px]!" class="w-8/12 !m-auto !mt-[20px]"
element-loading-background="transparent" element-loading-background="transparent"
> >
<div ref="wavesurferRef" /> <div ref="wavesurferRef" />
<div v-show="totalTime" class="flex justify-between"> <div v-show="totalTime" class="flex justify-between">
<span class="text-[#81888f]">00:00</span> <span class="text-[#81888f]">00:00</span>
<h1 class="text-4xl mt-2!">{{ curTime }}</h1> <h1 class="text-4xl mt-2">{{ curTime }}</h1>
<span class="text-[#81888f]">{{ totalTime }}</span> <span class="text-[#81888f]">{{ totalTime }}</span>
</div> </div>
<div v-show="totalTime" class="flex mt-2 w-[180px] justify-around m-auto"> <div v-show="totalTime" class="flex mt-2 w-[180px] justify-around m-auto">

View File

@@ -7,7 +7,7 @@ export function useColumns() {
minWidth: 100, minWidth: 100,
cellRenderer: () => { cellRenderer: () => {
return ( return (
<el-tag size="large" class="text-base!"> <el-tag size="large" class="!text-base">
{version} {version}
</el-tag> </el-tag>
); );
@@ -18,7 +18,7 @@ export function useColumns() {
minWidth: 120, minWidth: 120,
cellRenderer: () => { cellRenderer: () => {
return ( return (
<el-tag size="large" class="text-base!"> <el-tag size="large" class="!text-base">
{lastBuildTime} {lastBuildTime}
</el-tag> </el-tag>
); );
@@ -29,7 +29,7 @@ export function useColumns() {
minWidth: 140, minWidth: 140,
cellRenderer: () => { cellRenderer: () => {
return ( return (
<el-tag size="large" class="text-base!"> <el-tag size="large" class="!text-base">
{engines.node} {engines.node}
</el-tag> </el-tag>
); );
@@ -40,7 +40,7 @@ export function useColumns() {
minWidth: 140, minWidth: 140,
cellRenderer: () => { cellRenderer: () => {
return ( return (
<el-tag size="large" class="text-base!"> <el-tag size="large" class="!text-base">
{engines.pnpm} {engines.pnpm}
</el-tag> </el-tag>
); );

View File

@@ -43,7 +43,7 @@ function onClick(item) {
deviceDetection() ? 'max-w-[100%]' : 'max-w-[70%]' deviceDetection() ? 'max-w-[100%]' : 'max-w-[70%]'
]" ]"
> >
<h3 class="my-8!">账户管理</h3> <h3 class="my-8">账户管理</h3>
<div v-for="(item, index) in list" :key="index"> <div v-for="(item, index) in list" :key="index">
<div class="flex items-center"> <div class="flex items-center">
<div class="flex-1"> <div class="flex-1">

View File

@@ -38,7 +38,7 @@ function onChange(val, item) {
deviceDetection() ? 'max-w-[100%]' : 'max-w-[70%]' deviceDetection() ? 'max-w-[100%]' : 'max-w-[70%]'
]" ]"
> >
<h3 class="my-8!">偏好设置</h3> <h3 class="my-8">偏好设置</h3>
<div v-for="(item, index) in list" :key="index"> <div v-for="(item, index) in list" :key="index">
<div class="flex items-center"> <div class="flex items-center">
<div class="flex-1"> <div class="flex-1">

View File

@@ -6,7 +6,7 @@ import { type UserInfo, getMine } from "@/api/user";
import type { FormInstance, FormRules } from "element-plus"; import type { FormInstance, FormRules } from "element-plus";
import ReCropperPreview from "@/components/ReCropperPreview"; import ReCropperPreview from "@/components/ReCropperPreview";
import { createFormData, deviceDetection } from "@pureadmin/utils"; import { createFormData, deviceDetection } from "@pureadmin/utils";
import uploadLine from "~icons/ri/upload-line"; import uploadLine from "@iconify-icons/ri/upload-line";
defineOptions({ defineOptions({
name: "Profile" name: "Profile"
@@ -110,7 +110,7 @@ getMine().then(res => {
deviceDetection() ? 'max-w-[100%]' : 'max-w-[70%]' deviceDetection() ? 'max-w-[100%]' : 'max-w-[70%]'
]" ]"
> >
<h3 class="my-8!">个人信息</h3> <h3 class="my-8">个人信息</h3>
<el-form <el-form
ref="userInfoFormRef" ref="userInfoFormRef"
label-position="top" label-position="top"
@@ -128,7 +128,7 @@ getMine().then(res => {
:show-file-list="false" :show-file-list="false"
:on-change="onChange" :on-change="onChange"
> >
<el-button plain class="ml-4!"> <el-button plain class="ml-4">
<IconifyIconOffline :icon="uploadLine" /> <IconifyIconOffline :icon="uploadLine" />
<span class="ml-2">更新头像</span> <span class="ml-2">更新头像</span>
</el-button> </el-button>

View File

@@ -78,7 +78,7 @@ onMounted(() => {
deviceDetection() ? 'max-w-[100%]' : 'max-w-[70%]' deviceDetection() ? 'max-w-[100%]' : 'max-w-[70%]'
]" ]"
> >
<h3 class="my-8!">安全日志</h3> <h3 class="my-8">安全日志</h3>
<pure-table <pure-table
row-key="id" row-key="id"
table-layout="auto" table-layout="auto"

View File

@@ -11,11 +11,11 @@ import AccountManagement from "./components/AccountManagement.vue";
import { useDataThemeChange } from "@/layout/hooks/useDataThemeChange"; import { useDataThemeChange } from "@/layout/hooks/useDataThemeChange";
import LaySidebarTopCollapse from "@/layout/components/lay-sidebar/components/SidebarTopCollapse.vue"; import LaySidebarTopCollapse from "@/layout/components/lay-sidebar/components/SidebarTopCollapse.vue";
import leftLine from "~icons/ri/arrow-left-s-line"; import leftLine from "@iconify-icons/ri/arrow-left-s-line";
import ProfileIcon from "~icons/ri/user-3-line"; import ProfileIcon from "@iconify-icons/ri/user-3-line";
import PreferencesIcon from "~icons/ri/settings-3-line"; import PreferencesIcon from "@iconify-icons/ri/settings-3-line";
import SecurityLogIcon from "~icons/ri/window-line"; import SecurityLogIcon from "@iconify-icons/ri/window-line";
import AccountManagementIcon from "~icons/ri/profile-line"; import AccountManagementIcon from "@iconify-icons/ri/profile-line";
defineOptions({ defineOptions({
name: "AccountSettings" name: "AccountSettings"
@@ -70,12 +70,12 @@ getMine().then(res => {
<el-container class="h-full"> <el-container class="h-full">
<el-aside <el-aside
v-if="isOpen" v-if="isOpen"
class="pure-account-settings overflow-hidden px-2 dark:bg-(--el-bg-color)! border-r-[1px] border-[var(--pure-border-color)]" class="pure-account-settings overflow-hidden px-2 dark:!bg-[var(--el-bg-color)] border-r-[1px] border-[var(--pure-border-color)]"
:width="deviceDetection() ? '180px' : '240px'" :width="deviceDetection() ? '180px' : '240px'"
> >
<el-menu :default-active="witchPane" class="pure-account-settings-menu"> <el-menu :default-active="witchPane" class="pure-account-settings-menu">
<el-menu-item <el-menu-item
class="hover:transition-all! hover:duration-200! hover:text-base! h-[50px]!" class="hover:!transition-all hover:!duration-200 hover:!text-base !h-[50px]"
@click="router.go(-1)" @click="router.go(-1)"
> >
<div class="flex items-center"> <div class="flex items-center">
@@ -86,10 +86,10 @@ getMine().then(res => {
<div class="flex items-center ml-8 mt-4 mb-4"> <div class="flex items-center ml-8 mt-4 mb-4">
<el-avatar :size="48" :src="userInfo.avatar" /> <el-avatar :size="48" :src="userInfo.avatar" />
<div class="ml-4 flex flex-col max-w-[130px]"> <div class="ml-4 flex flex-col max-w-[130px]">
<ReText class="font-bold self-baseline!"> <ReText class="font-bold !self-baseline">
{{ userInfo.nickname }} {{ userInfo.nickname }}
</ReText> </ReText>
<ReText class="self-baseline!" type="info"> <ReText class="!self-baseline" type="info">
{{ userInfo.username }} {{ userInfo.username }}
</ReText> </ReText>
</div> </div>

View File

@@ -36,6 +36,6 @@ watch(animate, () => {
代码位置 src/views/components/animatecss.vue 代码位置 src/views/components/animatecss.vue
</el-link> </el-link>
</template> </template>
<ReAnimateSelector v-model="animate" class="w-[200px]!" /> <ReAnimateSelector v-model="animate" class="!w-[200px]" />
</el-card> </el-card>
</template> </template>

View File

@@ -109,7 +109,7 @@ watch(size, val =>
代码位置 src/views/components/check-button.vue 代码位置 src/views/components/check-button.vue
</el-link> </el-link>
</template> </template>
<div class="mb-2">单选紧凑风格的按钮样式</div> <p class="mb-2">单选紧凑风格的按钮样式</p>
<el-radio-group <el-radio-group
v-model="radio" v-model="radio"
:size="dynamicSize" :size="dynamicSize"
@@ -121,7 +121,7 @@ watch(size, val =>
</el-radio-group> </el-radio-group>
<el-divider /> <el-divider />
<div class="mb-2">单选带有边框</div> <p class="mb-2">单选带有边框</p>
<el-radio-group <el-radio-group
v-model="radioBox" v-model="radioBox"
:size="dynamicSize" :size="dynamicSize"
@@ -133,7 +133,7 @@ watch(size, val =>
</el-radio-group> </el-radio-group>
<el-divider /> <el-divider />
<div class="mb-2">单选自定义内容</div> <p class="mb-2">单选自定义内容</p>
<el-radio-group <el-radio-group
v-model="radioCustom" v-model="radioCustom"
:size="dynamicSize" :size="dynamicSize"
@@ -160,7 +160,7 @@ watch(size, val =>
</el-radio-group> </el-radio-group>
<el-divider /> <el-divider />
<div class="mb-2">多选紧凑风格的按钮样式</div> <p class="mb-2">多选紧凑风格的按钮样式</p>
<el-checkbox-group <el-checkbox-group
v-model="checkboxGroup" v-model="checkboxGroup"
:size="dynamicSize" :size="dynamicSize"
@@ -172,7 +172,7 @@ watch(size, val =>
</el-checkbox-group> </el-checkbox-group>
<el-divider /> <el-divider />
<div class="mb-2">多选带有边框</div> <p class="mb-2">多选带有边框</p>
<el-checkbox-group <el-checkbox-group
v-model="checkboxGroupBox" v-model="checkboxGroupBox"
:size="dynamicSize" :size="dynamicSize"
@@ -184,7 +184,7 @@ watch(size, val =>
</el-checkbox-group> </el-checkbox-group>
<el-divider /> <el-divider />
<div class="mb-2">多选来点不一样的体验</div> <p class="mb-2">多选来点不一样的体验</p>
<el-checkbox-group <el-checkbox-group
v-model="checkboxGroupCustom" v-model="checkboxGroupCustom"
class="pure-checkbox" class="pure-checkbox"
@@ -218,14 +218,14 @@ watch(size, val =>
</el-checkbox-group> </el-checkbox-group>
<el-divider /> <el-divider />
<div>可控制间距的按钮样式</div> <p>可控制间距的按钮样式</p>
<el-slider <el-slider
v-model="spaceSize" v-model="spaceSize"
class="mb-2 w-[300px]!" class="mb-2 !w-[300px]"
:show-tooltip="false" :show-tooltip="false"
:disabled="size === 'disabled'" :disabled="size === 'disabled'"
/> />
<div class="mb-2">单选</div> <p class="mb-2">单选</p>
<el-space wrap :size="spaceSize"> <el-space wrap :size="spaceSize">
<el-check-tag <el-check-tag
v-for="(tag, index) in checkTag" v-for="(tag, index) in checkTag"
@@ -241,7 +241,7 @@ watch(size, val =>
{{ tag.title }} {{ tag.title }}
</el-check-tag> </el-check-tag>
</el-space> </el-space>
<div class="mb-2 mt-4"> <p class="mb-2 mt-4">
多选 多选
{{ {{
getKeyList( getKeyList(
@@ -249,7 +249,7 @@ watch(size, val =>
"title" "title"
) )
}} }}
</div> </p>
<el-space wrap :size="spaceSize"> <el-space wrap :size="spaceSize">
<el-check-tag <el-check-tag
v-for="(tag, index) in checkGroupTag" v-for="(tag, index) in checkGroupTag"
@@ -267,7 +267,7 @@ watch(size, val =>
</el-space> </el-space>
<el-divider /> <el-divider />
<div class="mb-2">单个可选按钮</div> <p class="mb-2">单个可选按钮</p>
<el-check-tag <el-check-tag
:class="[ :class="[
'select-none', 'select-none',

View File

@@ -69,7 +69,7 @@ watch(size, val =>
</el-link> </el-link>
</template> </template>
<div class="mb-2 mt-4">单选</div> <p class="mb-2 mt-4">单选</p>
<PlusCheckCardGroup <PlusCheckCardGroup
v-model="list" v-model="list"
:options="options" :options="options"
@@ -77,7 +77,7 @@ watch(size, val =>
:disabled="size === 'disabled'" :disabled="size === 'disabled'"
/> />
<div class="mb-2 mt-4">多选</div> <p class="mb-2 mt-4">多选</p>
<PlusCheckCardGroup <PlusCheckCardGroup
v-model="list1" v-model="list1"
:options="options" :options="options"

View File

@@ -50,12 +50,12 @@ const handleChange = (val: string[]) => {
</el-link> </el-link>
</template> </template>
<div class="mb-2">基础用法</div> <p class="mb-2">基础用法</p>
<el-radio-group v-model="radio" class="mb-3"> <el-radio-group v-model="radio" class="mb-3">
<el-radio value="">可同时展开多个面板</el-radio> <el-radio value="">可同时展开多个面板</el-radio>
<el-radio value="accordion">每次只能展开一个面板</el-radio> <el-radio value="accordion">每次只能展开一个面板</el-radio>
</el-radio-group> </el-radio-group>
<el-button size="small" text bg class="ml-8! mb-1!" @click="onClick"> <el-button size="small" text bg class="ml-8 mb-1" @click="onClick">
外部触发打开、关闭 外部触发打开、关闭
</el-button> </el-button>
<el-collapse <el-collapse

View File

@@ -73,7 +73,7 @@ function onClick() {
</el-link> </el-link>
</template> </template>
<div class="mb-2">不同尺寸、选择透明度、预定义颜色</div> <p class="mb-2">不同尺寸、选择透明度、预定义颜色</p>
<el-color-picker <el-color-picker
v-model="color" v-model="color"
show-alpha show-alpha
@@ -83,7 +83,7 @@ function onClick() {
/> />
<el-divider /> <el-divider />
<div class="mb-2">外部触发器</div> <p class="mb-2">外部触发器</p>
<el-space wrap> <el-space wrap>
<el-color-picker <el-color-picker
ref="colorPickerRef" ref="colorPickerRef"

View File

@@ -1,6 +1,6 @@
<template> <template>
<div> <div>
<div class="mb-2">基础用法</div> <p class="mb-2">基础用法</p>
<div v-contextmenu:contextmenu class="wrapper"> <div v-contextmenu:contextmenu class="wrapper">
<code>右键点击此区域</code> <code>右键点击此区域</code>
</div> </div>

Some files were not shown because too many files have changed in this diff Show More