create-web-kit 25.728.1412 → 25.728.1502
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/dist/assets/html/ie.html +256 -0
- package/dist/config/frameworks.js +2 -7
- package/dist/generators/nextjs-csr.js +20 -12
- package/dist/templates/electron-react/eslint.config.js +7 -0
- package/dist/templates/electron-vue/eslint.config.js +7 -0
- package/dist/templates/nextjs-csr/.devcontainer/devcontainer.json +32 -0
- package/dist/templates/nextjs-csr/eslint.config.mjs +16 -0
- package/dist/templates/nextjs-csr/next.config.ts +28 -0
- package/dist/templates/nextjs-csr/prettier.config.json +21 -0
- package/dist/templates/nextjs-csr/src/app/error.tsx +326 -0
- package/dist/templates/nextjs-csr/src/app/layout.tsx +47 -0
- package/dist/templates/nextjs-csr/src/app/not-found.tsx +16 -0
- package/dist/templates/nextjs-csr/src/components/build-info.tsx +20 -0
- package/dist/templates/nextjs-csr/src/components/providers/index.tsx +15 -0
- package/dist/templates/nextjs-csr/src/components/providers/query.tsx +45 -0
- package/dist/templates/nextjs-csr/src/components/providers/theme.tsx +17 -0
- package/dist/templates/nextjs-csr/src/components/show.tsx +12 -0
- package/dist/templates/nextjs-csr/src/lib/request.ts +204 -0
- package/dist/templates/vue3/vite.config.ts +12 -0
- package/package.json +2 -2
package/README.md
CHANGED
|
@@ -0,0 +1,256 @@
|
|
|
1
|
+
<!DOCTYPE html>
|
|
2
|
+
<html lang="zh-CN">
|
|
3
|
+
|
|
4
|
+
<head>
|
|
5
|
+
<meta charset="UTF-8" />
|
|
6
|
+
<title>请升级您的浏览器</title>
|
|
7
|
+
<meta http-equiv="X-UA-Compatible" content="IE=Edge,chrome=1">
|
|
8
|
+
<meta name="renderer" content="webkit">
|
|
9
|
+
<base target="_blank" />
|
|
10
|
+
<style type="text/css">
|
|
11
|
+
html,
|
|
12
|
+
body,
|
|
13
|
+
div,
|
|
14
|
+
span,
|
|
15
|
+
applet,
|
|
16
|
+
object,
|
|
17
|
+
iframe,
|
|
18
|
+
h1,
|
|
19
|
+
h2,
|
|
20
|
+
h3,
|
|
21
|
+
h4,
|
|
22
|
+
h5,
|
|
23
|
+
h6,
|
|
24
|
+
p,
|
|
25
|
+
blockquote,
|
|
26
|
+
pre,
|
|
27
|
+
a,
|
|
28
|
+
abbr,
|
|
29
|
+
acronym,
|
|
30
|
+
address,
|
|
31
|
+
big,
|
|
32
|
+
cite,
|
|
33
|
+
code,
|
|
34
|
+
del,
|
|
35
|
+
dfn,
|
|
36
|
+
em,
|
|
37
|
+
img,
|
|
38
|
+
ins,
|
|
39
|
+
kbd,
|
|
40
|
+
q,
|
|
41
|
+
s,
|
|
42
|
+
samp,
|
|
43
|
+
small,
|
|
44
|
+
strike,
|
|
45
|
+
strong,
|
|
46
|
+
sub,
|
|
47
|
+
sup,
|
|
48
|
+
tt,
|
|
49
|
+
var,
|
|
50
|
+
b,
|
|
51
|
+
u,
|
|
52
|
+
i,
|
|
53
|
+
center,
|
|
54
|
+
dl,
|
|
55
|
+
dt,
|
|
56
|
+
dd,
|
|
57
|
+
ol,
|
|
58
|
+
ul,
|
|
59
|
+
li,
|
|
60
|
+
fieldset,
|
|
61
|
+
form,
|
|
62
|
+
label,
|
|
63
|
+
legend,
|
|
64
|
+
table,
|
|
65
|
+
caption,
|
|
66
|
+
tbody,
|
|
67
|
+
tfoot,
|
|
68
|
+
thead,
|
|
69
|
+
tr,
|
|
70
|
+
th,
|
|
71
|
+
td,
|
|
72
|
+
article,
|
|
73
|
+
aside,
|
|
74
|
+
canvas,
|
|
75
|
+
details,
|
|
76
|
+
embed,
|
|
77
|
+
figure,
|
|
78
|
+
figcaption,
|
|
79
|
+
footer,
|
|
80
|
+
header,
|
|
81
|
+
hgroup,
|
|
82
|
+
menu,
|
|
83
|
+
nav,
|
|
84
|
+
output,
|
|
85
|
+
ruby,
|
|
86
|
+
section,
|
|
87
|
+
summary,
|
|
88
|
+
time,
|
|
89
|
+
mark,
|
|
90
|
+
audio,
|
|
91
|
+
video {
|
|
92
|
+
border: 0;
|
|
93
|
+
font-size: 100%;
|
|
94
|
+
font: inherit;
|
|
95
|
+
vertical-align: baseline;
|
|
96
|
+
margin: 0;
|
|
97
|
+
padding: 0
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
article,
|
|
101
|
+
aside,
|
|
102
|
+
details,
|
|
103
|
+
figcaption,
|
|
104
|
+
figure,
|
|
105
|
+
footer,
|
|
106
|
+
header,
|
|
107
|
+
hgroup,
|
|
108
|
+
menu,
|
|
109
|
+
nav,
|
|
110
|
+
section {
|
|
111
|
+
display: block
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
body {
|
|
115
|
+
line-height: 1
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
ol,
|
|
119
|
+
ul {
|
|
120
|
+
list-style: none
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
blockquote,
|
|
124
|
+
q {
|
|
125
|
+
quotes: none
|
|
126
|
+
}
|
|
127
|
+
|
|
128
|
+
blockquote:before,
|
|
129
|
+
blockquote:after,
|
|
130
|
+
q:before,
|
|
131
|
+
q:after {
|
|
132
|
+
content: none
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
table {
|
|
136
|
+
border-collapse: collapse;
|
|
137
|
+
border-spacing: 0
|
|
138
|
+
}
|
|
139
|
+
|
|
140
|
+
a {
|
|
141
|
+
text-decoration: none;
|
|
142
|
+
color: #0072c6;
|
|
143
|
+
}
|
|
144
|
+
|
|
145
|
+
a:hover {
|
|
146
|
+
text-decoration: none;
|
|
147
|
+
color: #004d8c;
|
|
148
|
+
}
|
|
149
|
+
|
|
150
|
+
body {
|
|
151
|
+
width: 960px;
|
|
152
|
+
margin: 0 auto;
|
|
153
|
+
padding: 10px;
|
|
154
|
+
font-size: 14px;
|
|
155
|
+
line-height: 24px;
|
|
156
|
+
color: #454545;
|
|
157
|
+
font-family: 'Microsoft YaHei UI', 'Microsoft YaHei', DengXian, SimSun, 'Segoe UI', Tahoma, Helvetica, sans-serif;
|
|
158
|
+
overflow-y: scroll
|
|
159
|
+
}
|
|
160
|
+
|
|
161
|
+
h1 {
|
|
162
|
+
font-size: 40px;
|
|
163
|
+
line-height: 80px;
|
|
164
|
+
font-weight: 100;
|
|
165
|
+
margin-bottom: 10px;
|
|
166
|
+
}
|
|
167
|
+
|
|
168
|
+
h2 {
|
|
169
|
+
font-size: 20px;
|
|
170
|
+
line-height: 25px;
|
|
171
|
+
font-weight: 100;
|
|
172
|
+
margin: 10px 0;
|
|
173
|
+
}
|
|
174
|
+
|
|
175
|
+
em {
|
|
176
|
+
color: red
|
|
177
|
+
}
|
|
178
|
+
|
|
179
|
+
p {
|
|
180
|
+
margin-bottom: 10px;
|
|
181
|
+
}
|
|
182
|
+
|
|
183
|
+
hr {
|
|
184
|
+
margin: 20px 0;
|
|
185
|
+
border: 0;
|
|
186
|
+
border-top: 1px solid #dadada
|
|
187
|
+
}
|
|
188
|
+
|
|
189
|
+
span {
|
|
190
|
+
display: block;
|
|
191
|
+
font-size: 12px;
|
|
192
|
+
line-height: 12px;
|
|
193
|
+
}
|
|
194
|
+
|
|
195
|
+
.clean {
|
|
196
|
+
clear: both;
|
|
197
|
+
}
|
|
198
|
+
|
|
199
|
+
.browser {
|
|
200
|
+
padding: 10px 10px;
|
|
201
|
+
}
|
|
202
|
+
|
|
203
|
+
.browser li {
|
|
204
|
+
width: auto;
|
|
205
|
+
padding: 0 80px;
|
|
206
|
+
margin-top: 30px;
|
|
207
|
+
height: 34px;
|
|
208
|
+
line-height: 22px;
|
|
209
|
+
float: left;
|
|
210
|
+
list-style: none;
|
|
211
|
+
background: url() no-repeat;
|
|
212
|
+
padding-left: 40px
|
|
213
|
+
}
|
|
214
|
+
|
|
215
|
+
.browser .browser-firefox {
|
|
216
|
+
background-position: 0 -34px
|
|
217
|
+
}
|
|
218
|
+
|
|
219
|
+
.browser .browser-ie {
|
|
220
|
+
background-position: 0 -68px;
|
|
221
|
+
margin-left: 0px
|
|
222
|
+
}
|
|
223
|
+
|
|
224
|
+
.browser .browser-360 {
|
|
225
|
+
background-position: 0 -170px;
|
|
226
|
+
margin-left: -27px
|
|
227
|
+
}
|
|
228
|
+
</style>
|
|
229
|
+
</head>
|
|
230
|
+
|
|
231
|
+
<body style="margin-top:50px">
|
|
232
|
+
<h1>请升级您的浏览器,以便我们更好的为您提供服务!</h1>
|
|
233
|
+
<p>您正在使用 Internet Explorer 的早期版本(IE11以下版本或使用该内核的浏览器)。这意味着在升级浏览器前,您将无法访问此网站。</p>
|
|
234
|
+
<hr>
|
|
235
|
+
<h2>请注意:微软公司对Windows XP 及 Internet Explorer 早期版本的支持已经结束</h2>
|
|
236
|
+
<p>自 2016 年 1 月 12 日起,Microsoft 不再为 IE 11
|
|
237
|
+
以下版本提供相应支持和更新。没有关键的浏览器安全更新,您的电脑可能易受有害病毒、间谍软件和其他恶意软件的攻击,它们可以窃取或损害您的业务数据和信息。请参阅 <a
|
|
238
|
+
href="https://www.microsoft.com/zh-cn/WindowsForBusiness/End-of-IE-support">微软对 Internet Explorer 早期版本的支持将于
|
|
239
|
+
2016 年 1 月 12 日结束的说明</a> 。</p>
|
|
240
|
+
<hr>
|
|
241
|
+
<h2>您可以选择更先进的浏览器</h2>
|
|
242
|
+
<p>推荐使用以下浏览器的最新版本。如果您的电脑已有以下浏览器的最新版本则直接使用该浏览器访问即可。</p>
|
|
243
|
+
<ul class="browser">
|
|
244
|
+
<li class="browser-chrome"><a
|
|
245
|
+
href="https://www.google.cn/chrome/browser/desktop/index.html?hl=zh-CN&standalone=1"> 谷歌浏览器<span>Google
|
|
246
|
+
Chrome</span></a></li>
|
|
247
|
+
<li class="browser-firefox"><a href="https://www.mozilla.org/zh-CN/firefox/new/"> 火狐浏览器<span>Mozilla
|
|
248
|
+
Firefox</span></a></li>
|
|
249
|
+
<li class="browser-ie"><a href="https://windows.microsoft.com/zh-cn/internet-explorer/download-ie"> IE 11
|
|
250
|
+
浏览器<span>Internet Explorer</span></a></li>
|
|
251
|
+
<div class="clean"></div>
|
|
252
|
+
</ul>
|
|
253
|
+
<hr>
|
|
254
|
+
</body>
|
|
255
|
+
|
|
256
|
+
</html>
|
|
@@ -32,15 +32,10 @@ export const FRAMEWORKS = [
|
|
|
32
32
|
workingDir: "target",
|
|
33
33
|
},
|
|
34
34
|
{
|
|
35
|
-
command: "pnpm add date-fns",
|
|
35
|
+
command: "pnpm add date-fns next-themes motion",
|
|
36
36
|
description: "Installing date-fns for date utilities",
|
|
37
37
|
workingDir: "target",
|
|
38
38
|
},
|
|
39
|
-
{
|
|
40
|
-
command: "pnpm add next-themes",
|
|
41
|
-
description: "Installing next-themes for theme support",
|
|
42
|
-
workingDir: "target",
|
|
43
|
-
},
|
|
44
39
|
{
|
|
45
40
|
command: "pnpm dlx shadcn@latest add --all",
|
|
46
41
|
description: "Installing all shadcnui components",
|
|
@@ -64,7 +59,7 @@ export const FRAMEWORKS = [
|
|
|
64
59
|
workingDir: "target",
|
|
65
60
|
},
|
|
66
61
|
{
|
|
67
|
-
command: "pnpm add @tanstack/react-query next-auth prisma",
|
|
62
|
+
command: "pnpm add @tanstack/react-query next-auth prisma motion",
|
|
68
63
|
description: "Installing SSR dependencies",
|
|
69
64
|
workingDir: "target",
|
|
70
65
|
},
|
|
@@ -5,30 +5,38 @@ const TEMPLATE_NAME = "nextjs-csr";
|
|
|
5
5
|
const TEMPLATE_FILES = [
|
|
6
6
|
// Config files
|
|
7
7
|
{ source: "prettier.config.json", destination: ".prettierrc", isJson: true },
|
|
8
|
-
{ source: "eslint.config.
|
|
9
|
-
{ source: "next.config.
|
|
8
|
+
{ source: "eslint.config.mjs", destination: "eslint.config.mjs" },
|
|
9
|
+
{ source: "next.config.ts", destination: "next.config.ts" },
|
|
10
10
|
// DevContainer
|
|
11
11
|
{
|
|
12
|
-
source: "devcontainer.json",
|
|
12
|
+
source: ".devcontainer/devcontainer.json",
|
|
13
13
|
destination: ".devcontainer/devcontainer.json",
|
|
14
14
|
isJson: true,
|
|
15
15
|
},
|
|
16
16
|
// App files
|
|
17
|
-
{ source: "layout.tsx", destination: "src/app/layout.tsx" },
|
|
18
|
-
{ source: "not-found.tsx", destination: "src/app/not-found.tsx" },
|
|
17
|
+
{ source: "src/app/layout.tsx", destination: "src/app/layout.tsx" },
|
|
18
|
+
{ source: "src/app/not-found.tsx", destination: "src/app/not-found.tsx" },
|
|
19
|
+
{ source: "src/app/error.tsx", destination: "src/app/error.tsx" },
|
|
19
20
|
// Components
|
|
20
|
-
{ source: "show.tsx", destination: "src/components/show.tsx" },
|
|
21
|
-
{ source: "build-info.tsx", destination: "src/components/build-info.tsx" },
|
|
21
|
+
{ source: "src/components/show.tsx", destination: "src/components/show.tsx" },
|
|
22
22
|
{
|
|
23
|
-
source: "
|
|
24
|
-
destination: "src/components/
|
|
23
|
+
source: "src/components/build-info.tsx",
|
|
24
|
+
destination: "src/components/build-info.tsx",
|
|
25
25
|
},
|
|
26
26
|
{
|
|
27
|
-
source: "
|
|
28
|
-
destination: "src/components/providers/
|
|
27
|
+
source: "src/components/providers/theme.tsx",
|
|
28
|
+
destination: "src/components/providers/theme.tsx",
|
|
29
|
+
},
|
|
30
|
+
{
|
|
31
|
+
source: "src/components/providers/query.tsx",
|
|
32
|
+
destination: "src/components/providers/query.tsx",
|
|
33
|
+
},
|
|
34
|
+
{
|
|
35
|
+
source: "src/components/providers/index.tsx",
|
|
36
|
+
destination: "src/components/providers/index.tsx",
|
|
29
37
|
},
|
|
30
38
|
// Utils
|
|
31
|
-
{ source: "request.ts", destination: "src/
|
|
39
|
+
{ source: "src/lib/request.ts", destination: "src/lib/request.ts" },
|
|
32
40
|
];
|
|
33
41
|
export function createNextjsCSRFiles(root) {
|
|
34
42
|
// Copy all template files
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
{
|
|
2
|
+
"name": "node:v22.9.0",
|
|
3
|
+
"image": "mcr.microsoft.com/devcontainers/typescript-node:1-22-bookworm",
|
|
4
|
+
"customizations": {
|
|
5
|
+
"vscode": {
|
|
6
|
+
"extensions": [
|
|
7
|
+
"bradlc.vscode-tailwindcss",
|
|
8
|
+
"esbenp.prettier-vscode",
|
|
9
|
+
"dbaeumer.vscode-eslint",
|
|
10
|
+
"ms-vscode.js-debug",
|
|
11
|
+
"yoavbls.pretty-ts-errors",
|
|
12
|
+
"github.vscode-github-actions"
|
|
13
|
+
]
|
|
14
|
+
}
|
|
15
|
+
},
|
|
16
|
+
"remoteUser": "node",
|
|
17
|
+
"mounts": [
|
|
18
|
+
"source=${localEnv:HOME}/.ssh,target=/home/node/.ssh,type=bind,readonly",
|
|
19
|
+
"source=/etc/localtime,target=/etc/localtime,type=bind",
|
|
20
|
+
"source=/etc/timezone,target=/etc/timezone,type=bind"
|
|
21
|
+
],
|
|
22
|
+
"remoteEnv": {
|
|
23
|
+
"SSH_AUTH_SOCK": "/ssh-agent",
|
|
24
|
+
"TZ": "Asia/Shanghai"
|
|
25
|
+
},
|
|
26
|
+
"initializeCommand": "mkdir -p ${localEnv:HOME}/.ssh",
|
|
27
|
+
"runArgs": [
|
|
28
|
+
"--volume=/run/host-services/ssh-auth.sock:/ssh-agent",
|
|
29
|
+
"--network=host",
|
|
30
|
+
"--privileged"
|
|
31
|
+
]
|
|
32
|
+
}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { dirname } from "path";
|
|
2
|
+
import { fileURLToPath } from "url";
|
|
3
|
+
import { FlatCompat } from "@eslint/eslintrc";
|
|
4
|
+
|
|
5
|
+
const __filename = fileURLToPath(import.meta.url);
|
|
6
|
+
const __dirname = dirname(__filename);
|
|
7
|
+
|
|
8
|
+
const compat = new FlatCompat({
|
|
9
|
+
baseDirectory: __dirname,
|
|
10
|
+
});
|
|
11
|
+
|
|
12
|
+
const eslintConfig = [
|
|
13
|
+
...compat.extends("next/core-web-vitals", "next/typescript", "prettier"),
|
|
14
|
+
];
|
|
15
|
+
|
|
16
|
+
export default eslintConfig;
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { format } from 'date-fns';
|
|
2
|
+
|
|
3
|
+
const nextConfig = {};
|
|
4
|
+
|
|
5
|
+
const proxy = async () => {
|
|
6
|
+
return [
|
|
7
|
+
{
|
|
8
|
+
source: '/api/:path*',
|
|
9
|
+
destination: 'http://localhost:8000/api/:path*',
|
|
10
|
+
},
|
|
11
|
+
];
|
|
12
|
+
};
|
|
13
|
+
|
|
14
|
+
switch (process.env.NODE_ENV) {
|
|
15
|
+
case 'production':
|
|
16
|
+
nextConfig.output = 'export';
|
|
17
|
+
nextConfig.images = {};
|
|
18
|
+
nextConfig.images.unoptimized = true;
|
|
19
|
+
nextConfig.distDir = 'dist';
|
|
20
|
+
break;
|
|
21
|
+
case 'development':
|
|
22
|
+
nextConfig.rewrites = proxy;
|
|
23
|
+
break;
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
process.env.NEXT_PUBLIC_BUILD_TIME = format(new Date(), 'yyyy-MM-dd HH:mm');
|
|
27
|
+
|
|
28
|
+
export default nextConfig;
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
{
|
|
2
|
+
"semi": true,
|
|
3
|
+
"trailingComma": "all",
|
|
4
|
+
"singleQuote": true,
|
|
5
|
+
"printWidth": 80,
|
|
6
|
+
"tabWidth": 2,
|
|
7
|
+
"useTabs": false,
|
|
8
|
+
"importOrder": [
|
|
9
|
+
"^@core/(.*)$",
|
|
10
|
+
"^@server/(.*)$",
|
|
11
|
+
"^@ui/(.*)$",
|
|
12
|
+
"^[./]"
|
|
13
|
+
],
|
|
14
|
+
"importOrderSeparation": true,
|
|
15
|
+
"importOrderSortSpecifiers": true,
|
|
16
|
+
"endOfLine": "auto",
|
|
17
|
+
"plugins": [
|
|
18
|
+
"prettier-plugin-tailwindcss",
|
|
19
|
+
"@trivago/prettier-plugin-sort-imports"
|
|
20
|
+
]
|
|
21
|
+
}
|
|
@@ -0,0 +1,326 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import { motion } from "motion/react";
|
|
3
|
+
import Link from "next/link";
|
|
4
|
+
import { Button } from "@/components/ui/button";
|
|
5
|
+
|
|
6
|
+
export default function ErrorPage({
|
|
7
|
+
error,
|
|
8
|
+
reset,
|
|
9
|
+
}: {
|
|
10
|
+
error: Error;
|
|
11
|
+
reset: () => void;
|
|
12
|
+
}) {
|
|
13
|
+
const springConfig = { type: "spring", damping: 10, stiffness: 100 };
|
|
14
|
+
|
|
15
|
+
return (
|
|
16
|
+
<div className="flex flex-col items-center justify-center min-h-screen bg-gray-50 px-4">
|
|
17
|
+
<title>Error </title>
|
|
18
|
+
<motion.h1
|
|
19
|
+
className="text-3xl font-bold text-gray-800 text-center"
|
|
20
|
+
initial={{ y: -50, opacity: 0 }}
|
|
21
|
+
animate={{ y: 0, opacity: 1 }}
|
|
22
|
+
transition={springConfig}
|
|
23
|
+
>
|
|
24
|
+
出错了
|
|
25
|
+
</motion.h1>
|
|
26
|
+
|
|
27
|
+
<motion.p
|
|
28
|
+
className="text-gray-600 text-center"
|
|
29
|
+
initial={{ y: 50, opacity: 0 }}
|
|
30
|
+
animate={{ y: 0, opacity: 1 }}
|
|
31
|
+
transition={{ ...springConfig, delay: 0.1 }}
|
|
32
|
+
>
|
|
33
|
+
{error.message}
|
|
34
|
+
</motion.p>
|
|
35
|
+
|
|
36
|
+
<motion.div
|
|
37
|
+
initial={{ scale: 0.8, opacity: 0 }}
|
|
38
|
+
animate={{ scale: 1, opacity: 1 }}
|
|
39
|
+
transition={{ ...springConfig, delay: 0.2 }}
|
|
40
|
+
className="w-full max-w-sm mx-auto my-10"
|
|
41
|
+
>
|
|
42
|
+
<UnDrawError />
|
|
43
|
+
</motion.div>
|
|
44
|
+
<div className="flex gap-2">
|
|
45
|
+
<motion.div
|
|
46
|
+
initial={{ opacity: 0 }}
|
|
47
|
+
animate={{ opacity: 1 }}
|
|
48
|
+
transition={{ delay: 0.3, duration: 0.5 }}
|
|
49
|
+
>
|
|
50
|
+
<Button onClick={reset} variant="outline">
|
|
51
|
+
重试
|
|
52
|
+
</Button>
|
|
53
|
+
</motion.div>
|
|
54
|
+
<motion.div
|
|
55
|
+
initial={{ opacity: 0 }}
|
|
56
|
+
animate={{ opacity: 1 }}
|
|
57
|
+
transition={{ delay: 0.4, duration: 0.5 }}
|
|
58
|
+
>
|
|
59
|
+
<Link href="/">
|
|
60
|
+
<Button>返回首页</Button>
|
|
61
|
+
</Link>
|
|
62
|
+
</motion.div>
|
|
63
|
+
</div>
|
|
64
|
+
</div>
|
|
65
|
+
);
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
function UnDrawError() {
|
|
69
|
+
return (
|
|
70
|
+
<motion.svg
|
|
71
|
+
animate={{
|
|
72
|
+
y: [0, -10, 0],
|
|
73
|
+
rotate: [0, -1, 1, 0],
|
|
74
|
+
}}
|
|
75
|
+
transition={{
|
|
76
|
+
duration: 5,
|
|
77
|
+
ease: "easeInOut",
|
|
78
|
+
times: [0, 0.2, 0.5, 0.8, 1],
|
|
79
|
+
repeat: Infinity,
|
|
80
|
+
repeatDelay: 1,
|
|
81
|
+
}}
|
|
82
|
+
className="w-full h-auto"
|
|
83
|
+
xmlns="http://www.w3.org/2000/svg"
|
|
84
|
+
data-name="Layer 1"
|
|
85
|
+
width="690"
|
|
86
|
+
height="448.7592"
|
|
87
|
+
viewBox="0 0 690 448.7592"
|
|
88
|
+
>
|
|
89
|
+
<path
|
|
90
|
+
d="M466.81292,645.7313c4.66847-10.08358,9.33339-20.31666,11.35946-31.24223s1.17569-22.78293-4.627-32.25932-17.22813-15.90241-28.13153-13.76022c-8.95532,1.75945-16.14605,8.81268-20.35651,16.90992S419.15759,602.60959,417.52,611.588c-.52917-10.2001-1.0896-20.56436-4.478-30.19975s-10.06045-18.61463-19.5694-22.34313-21.87886-.79648-26.89061,8.1032c-7.06074,12.53818,2.30155,30.12541-5.81734,42.0058-1.39265-11.917-13.85471-21.33234-25.69879-19.4159s-20.70109,14.78128-18.2646,26.5294c1.44978,6.99047,6.21931,12.93631,11.92156,17.232s12.33421,9.27436,18.89475,12.09Z"
|
|
91
|
+
transform="translate(-255 -225.6204)"
|
|
92
|
+
fill="#f2f2f2"
|
|
93
|
+
/>
|
|
94
|
+
<path
|
|
95
|
+
d="M323.01987,598.15781c9.40825,3.28851,18.903,6.61425,27.49226,11.75558,7.698,4.60786,14.553,10.81187,18.88231,18.7569a33.35556,33.35556,0,0,1,4.12583,13.85861c.06251,1.01759,1.65458,1.02469,1.59164,0-.55661-9.061-4.97238-17.353-11.087-23.91075-6.704-7.18984-15.39158-12.10041-24.3611-15.91043-5.31821-2.259-10.76859-4.17895-16.2208-6.08468-.96887-.33866-1.3854,1.19842-.42311,1.53477Z"
|
|
96
|
+
transform="translate(-255 -225.6204)"
|
|
97
|
+
fill="#fff"
|
|
98
|
+
/>
|
|
99
|
+
<path
|
|
100
|
+
d="M377.28745,560.62486a143.38254,143.38254,0,0,1,13.79113,30.61557,145.11672,145.11672,0,0,1,6.361,32.96846,143.30543,143.30543,0,0,1,.15151,18.83685c-.05905,1.02328,1.53278,1.01989,1.59163,0a145.1941,145.1941,0,0,0-2.04032-33.82049,146.92647,146.92647,0,0,0-9.769-32.44022,143.25,143.25,0,0,0-8.71162-16.9635.79641.79641,0,0,0-1.37432.80333Z"
|
|
101
|
+
transform="translate(-255 -225.6204)"
|
|
102
|
+
fill="#fff"
|
|
103
|
+
/>
|
|
104
|
+
<path
|
|
105
|
+
d="M455.188,569.76743a232.04359,232.04359,0,0,0-17.11648,57.57847q-1.34225,8.36487-2.07791,16.81182c-.089,1.02023,1.50317,1.01426,1.59163,0a231.20919,231.20919,0,0,1,12.73788-58.02528q2.83382-7.89209,6.23921-15.56169c.412-.92791-.959-1.73862-1.37433-.80332Z"
|
|
106
|
+
transform="translate(-255 -225.6204)"
|
|
107
|
+
fill="#fff"
|
|
108
|
+
/>
|
|
109
|
+
<rect
|
|
110
|
+
x="709.17625"
|
|
111
|
+
y="639.47815"
|
|
112
|
+
width="9.88235"
|
|
113
|
+
height="46.58824"
|
|
114
|
+
transform="translate(1112.59535 -285.4804) rotate(89.25872)"
|
|
115
|
+
fill="#e6e6e6"
|
|
116
|
+
/>
|
|
117
|
+
<path
|
|
118
|
+
d="M754.02652,669.61624l-6.65257-.0194-4.11239-7.33712,4.445-7.31237,6.1811.01792a11.99893,11.99893,0,1,0,.13889,14.651Z"
|
|
119
|
+
transform="translate(-255 -225.6204)"
|
|
120
|
+
fill="#e6e6e6"
|
|
121
|
+
/>
|
|
122
|
+
<path
|
|
123
|
+
d="M674.20833,669.61624l6.65258-.0194,4.11239-7.33712-4.445-7.31237-6.18109.01792a11.99892,11.99892,0,1,1-.1389,14.651Z"
|
|
124
|
+
transform="translate(-255 -225.6204)"
|
|
125
|
+
fill="#e6e6e6"
|
|
126
|
+
/>
|
|
127
|
+
<path
|
|
128
|
+
d="M944,646.58958H256a1,1,0,0,1,0-2H944a1,1,0,0,1,0,2Z"
|
|
129
|
+
transform="translate(-255 -225.6204)"
|
|
130
|
+
fill="#3f3d56"
|
|
131
|
+
/>
|
|
132
|
+
<circle cx="540.48622" cy="197.96918" r="33" fill="#2f2e41" />
|
|
133
|
+
<polygon
|
|
134
|
+
points="553.859 383.226 556.401 395.219 603.871 391.124 600.12 373.423 553.859 383.226"
|
|
135
|
+
fill="#ffb8b8"
|
|
136
|
+
/>
|
|
137
|
+
<path
|
|
138
|
+
d="M789.18809,618.49673h38.53073a0,0,0,0,1,0,0v14.88687a0,0,0,0,1,0,0H804.07494a14.88685,14.88685,0,0,1-14.88685-14.88685v0A0,0,0,0,1,789.18809,618.49673Z"
|
|
139
|
+
transform="translate(108.71051 1320.97269) rotate(-101.96466)"
|
|
140
|
+
fill="#2f2e41"
|
|
141
|
+
/>
|
|
142
|
+
<polygon
|
|
143
|
+
points="524.12 382.586 518.777 393.621 473.673 378.264 481.559 361.979 524.12 382.586"
|
|
144
|
+
fill="#ffb8b8"
|
|
145
|
+
/>
|
|
146
|
+
<path
|
|
147
|
+
d="M771.03745,617.45562h23.64388a0,0,0,0,1,0,0v14.88687a0,0,0,0,1,0,0H756.15059a0,0,0,0,1,0,0v0A14.88685,14.88685,0,0,1,771.03745,617.45562Z"
|
|
148
|
+
transform="translate(-379.9408 824.86818) rotate(-64.16458)"
|
|
149
|
+
fill="#2f2e41"
|
|
150
|
+
/>
|
|
151
|
+
<path
|
|
152
|
+
d="M690.25925,586.41362a10.74272,10.74272,0,0,0,12.70881-10.48016l74.37388-68.5711-18.47-14.30549-67.33743,71.94341a10.80091,10.80091,0,0,0-1.27527,21.41334Z"
|
|
153
|
+
transform="translate(-255 -225.6204)"
|
|
154
|
+
fill="#ffb8b8"
|
|
155
|
+
/>
|
|
156
|
+
<circle cx="536.34449" cy="207.89831" r="24.56103" fill="#ffb8b8" />
|
|
157
|
+
<path
|
|
158
|
+
d="M813.38612,577.89329c-17.22851.00049-37.978-3.62842-50.77856-18.477l-.28833-.33447.29663-.32813c.09668-.10693,9.51367-10.86865.11084-30.061L749.799,532.67015,736.9286,515.68138l7.12964-21.38916,29.17749-23.50391a26.75074,26.75074,0,0,1,14.6106-5.78906,80.21058,80.21058,0,0,0,27.78467-7.91309,27.906,27.906,0,0,1,12.7998-2.79834l.57373.01611a9.95022,9.95022,0,0,1,9.64063,10.70752c-1.97852,25.62989-5.47242,87.54346,4.7915,108.86133l.26514.55078-.59229.15039A136.1132,136.1132,0,0,1,813.38612,577.89329Z"
|
|
159
|
+
transform="translate(-255 -225.6204)"
|
|
160
|
+
fill="#000000"
|
|
161
|
+
/>
|
|
162
|
+
<path
|
|
163
|
+
d="M765.98622,559.08958s-65-6-72,13,1,28,13,32,41,9,41,9l13-16,34,2s37.88482,21.9732,48.35975,45.47377A30.76193,30.76193,0,0,0,869.12343,662.802c8.398.58447,15.86279-2.5874,15.86279-15.7124,0-30-42-73-42-73Z"
|
|
164
|
+
transform="translate(-255 -225.6204)"
|
|
165
|
+
fill="#2f2e41"
|
|
166
|
+
/>
|
|
167
|
+
<path
|
|
168
|
+
d="M716.48622,588.58958s17-5,44,8"
|
|
169
|
+
transform="translate(-255 -225.6204)"
|
|
170
|
+
fill="#2f2e41"
|
|
171
|
+
/>
|
|
172
|
+
<path
|
|
173
|
+
d="M766.84286,417.85547a73.04115,73.04115,0,0,0,31.59919,10.4119l-3.33084-3.991a24.4775,24.4775,0,0,0,7.5611,1.50142,8.28066,8.28066,0,0,0,6.74954-3.15917,7.70229,7.70229,0,0,0,.51556-7.115,14.58851,14.58851,0,0,0-4.58936-5.7385,27.32286,27.32286,0,0,0-25.43066-4.54493,16.32974,16.32974,0,0,0-7.59542,4.8722,9.23578,9.23578,0,0,0-1.86256,8.56086"
|
|
174
|
+
transform="translate(-255 -225.6204)"
|
|
175
|
+
fill="#2f2e41"
|
|
176
|
+
/>
|
|
177
|
+
<path
|
|
178
|
+
d="M795.30911,398.22407A75.48468,75.48468,0,0,1,814.446,371.70269c5.292-4.70276,11.47246-8.74308,18.44626-9.9627s14.83309.86982,19.11055,6.51116c3.49772,4.613,4.15213,10.79276,3.76672,16.569s-1.67632,11.49651-1.5527,17.28428a35.46794,35.46794,0,0,0,50.52712,31.351c-6.02152,3.32885-10.714,8.59777-16.3048,12.60812s-12.96272,6.7601-19.31233,4.11012c-6.71812-2.80378-9.79963-10.41937-12.20607-17.28984L846.189,402.2443c-1.82434-5.20852-3.739-10.57156-7.462-14.6454s-9.76461-6.5568-14.88927-4.50871c-3.884,1.55225-6.41275,5.25755-8.63029,8.804s-4.557,7.31984-8.30359,9.17935-9.29837.7147-10.52292-3.28471"
|
|
179
|
+
transform="translate(-255 -225.6204)"
|
|
180
|
+
fill="#2f2e41"
|
|
181
|
+
/>
|
|
182
|
+
<rect
|
|
183
|
+
x="802.91902"
|
|
184
|
+
y="543.31418"
|
|
185
|
+
width="9.88235"
|
|
186
|
+
height="46.58824"
|
|
187
|
+
transform="translate(-416.74744 524.13837) rotate(-45.74128)"
|
|
188
|
+
fill="#e6e6e6"
|
|
189
|
+
/>
|
|
190
|
+
<path
|
|
191
|
+
d="M821.51005,579.90944a9.88235,9.88235,0,1,0,13.97459-.18081A9.88238,9.88238,0,0,0,821.51005,579.90944Zm10.111,9.8527a4.23529,4.23529,0,1,1-.07749-5.98911A4.2354,4.2354,0,0,1,831.62105,589.76214Z"
|
|
192
|
+
transform="translate(-255 -225.6204)"
|
|
193
|
+
fill="#e6e6e6"
|
|
194
|
+
/>
|
|
195
|
+
<path
|
|
196
|
+
d="M784.47962,533.54889l4.69037,4.7178-2.28023,8.096-8.3137,2.02755-4.358-4.38337a11.99891,11.99891,0,1,0,10.26158-10.458Z"
|
|
197
|
+
transform="translate(-255 -225.6204)"
|
|
198
|
+
fill="#e6e6e6"
|
|
199
|
+
/>
|
|
200
|
+
<path
|
|
201
|
+
d="M803.736,577.97923a11.579,11.579,0,0,1-1.26831-.07032,11.02341,11.02341,0,0,1-9.68018-9.68115,11.00337,11.00337,0,0,1,10.93115-12.25,10.62483,10.62483,0,0,1,1.46607.10938L838.76332,520.342l-3.50513-11.68457,17.605-7.8916,4.93384,12.06006a20.48972,20.48972,0,0,1-6.17724,23.67236l-36.96119,29.40088a10.25885,10.25885,0,0,1,.06006,1.07861,11.01824,11.01824,0,0,1-3.66382,8.19678A10.87186,10.87186,0,0,1,803.736,577.97923Z"
|
|
202
|
+
transform="translate(-255 -225.6204)"
|
|
203
|
+
fill="#ffb8b8"
|
|
204
|
+
/>
|
|
205
|
+
<path
|
|
206
|
+
d="M829.98622,459.08958h0a9.45335,9.45335,0,0,1,12.628,5.1563l17.372,43.84371-27,18Z"
|
|
207
|
+
transform="translate(-255 -225.6204)"
|
|
208
|
+
fill="#000000"
|
|
209
|
+
/>
|
|
210
|
+
<path
|
|
211
|
+
d="M703.48622,469.32728V250.8827a25.29812,25.29812,0,0,0-25.2623-25.2623H334.95386a25.29813,25.29813,0,0,0-25.2623,25.2623V469.32728a25.29813,25.29813,0,0,0,25.2623,25.2623H678.22392A25.29812,25.29812,0,0,0,703.48622,469.32728ZM334.95386,491.61754a22.31743,22.31743,0,0,1-22.29026-22.29026V250.8827a22.31744,22.31744,0,0,1,22.29026-22.29027H678.22392a22.31744,22.31744,0,0,1,22.29027,22.29027V469.32728a22.31744,22.31744,0,0,1-22.29027,22.29026Z"
|
|
212
|
+
transform="translate(-255 -225.6204)"
|
|
213
|
+
fill="#3f3d56"
|
|
214
|
+
/>
|
|
215
|
+
<path
|
|
216
|
+
d="M700.51419,264.92368H312.6636a1.486,1.486,0,1,1,0-2.972H700.51419a1.486,1.486,0,0,1,0,2.972Z"
|
|
217
|
+
transform="translate(-255 -225.6204)"
|
|
218
|
+
fill="#3f3d56"
|
|
219
|
+
/>
|
|
220
|
+
<circle cx="82.9259" cy="20.80425" r="7.43009" fill="#000000" />
|
|
221
|
+
<circle cx="108.1882" cy="20.80425" r="7.43009" fill="#000000" />
|
|
222
|
+
<circle cx="133.4505" cy="20.80425" r="7.43009" fill="#000000" />
|
|
223
|
+
<path
|
|
224
|
+
d="M443.97867,424.85206a.99974.99974,0,0,1-1-1c0-10.42675-4.5708-16.24218-11.94531-22.24707a.99992.99992,0,1,1,1.2627-1.55078c7.83007,6.375,12.68261,12.58008,12.68261,23.79785A.99973.99973,0,0,1,443.97867,424.85206Z"
|
|
225
|
+
transform="translate(-255 -225.6204)"
|
|
226
|
+
/>
|
|
227
|
+
<path
|
|
228
|
+
d="M358.31656,424.85206a.99974.99974,0,0,1-1-1c0-11.21777,4.85254-17.42285,12.68262-23.79785a.99992.99992,0,1,1,1.2627,1.55078c-7.37452,6.00489-11.94532,11.82129-11.94532,22.24707A.99973.99973,0,0,1,358.31656,424.85206Z"
|
|
229
|
+
transform="translate(-255 -225.6204)"
|
|
230
|
+
/>
|
|
231
|
+
<path
|
|
232
|
+
d="M435.41324,356.32179a1,1,0,0,1-.63183-1.77539c7.58056-6.17139,8.19726-14.93848,8.19726-24.92334a1,1,0,0,1,2,0c0,10.50488-.67236,19.74756-8.93457,26.47412A.99381.99381,0,0,1,435.41324,356.32179Z"
|
|
233
|
+
transform="translate(-255 -225.6204)"
|
|
234
|
+
/>
|
|
235
|
+
<path
|
|
236
|
+
d="M366.88248,355.78663a.99383.99383,0,0,1-.63086-.22461c-8.26269-6.72705-8.93506-15.72705-8.93506-25.939a1,1,0,0,1,2,0c0,10.03662.60352,18.20557,8.19776,24.38818a1,1,0,0,1-.63184,1.77539Z"
|
|
237
|
+
transform="translate(-255 -225.6204)"
|
|
238
|
+
/>
|
|
239
|
+
<path
|
|
240
|
+
d="M456.82828,377.77247H435.41276a1,1,0,0,1,0-2h21.41552a1,1,0,1,1,0,2Z"
|
|
241
|
+
transform="translate(-255 -225.6204)"
|
|
242
|
+
/>
|
|
243
|
+
<path
|
|
244
|
+
d="M366.883,377.77247H345.46744a1,1,0,0,1,0-2H366.883a1,1,0,0,1,0,2Z"
|
|
245
|
+
transform="translate(-255 -225.6204)"
|
|
246
|
+
/>
|
|
247
|
+
<path
|
|
248
|
+
d="M401.14762,420.56886a.99974.99974,0,0,1-1-1V351.03908a1,1,0,0,1,2,0v68.52978A.99974.99974,0,0,1,401.14762,420.56886Z"
|
|
249
|
+
transform="translate(-255 -225.6204)"
|
|
250
|
+
/>
|
|
251
|
+
<path
|
|
252
|
+
d="M401.14762,420.56886A35.30522,35.30522,0,0,1,365.883,385.30372V359.58644c0-16.46826,13.5127-26.69873,35.26465-26.69873,22.74121,0,35.26514,9.48193,35.26514,26.69873v25.71728A35.30533,35.30533,0,0,1,401.14762,420.56886Zm0-85.68115c-16.08106,0-33.26465,6.48828-33.26465,24.69873v25.71728a33.2649,33.2649,0,1,0,66.52979,0V359.58644C434.41276,338.09669,413.571,334.88771,401.14762,334.88771Z"
|
|
253
|
+
transform="translate(-255 -225.6204)"
|
|
254
|
+
/>
|
|
255
|
+
<path
|
|
256
|
+
d="M380.651,339.06154a1.0002,1.0002,0,0,1-.9292-.62989,14.08794,14.08794,0,0,1-.98828-4.53173A22.47566,22.47566,0,0,1,401.089,311.49074h.11475a22.46679,22.46679,0,0,1,22.35938,22.35693,12.22735,12.22735,0,0,1-.91016,4.21094,1,1,0,0,1-1.84961-.76075,10.19507,10.19507,0,0,0,.76074-3.4873,20.45407,20.45407,0,0,0-20.36279-20.31982h-.10986a20.46143,20.46143,0,0,0-20.35938,20.36181,12.07569,12.07569,0,0,0,.84717,3.83789,1.00121,1.00121,0,0,1-.92822,1.3711Z"
|
|
257
|
+
transform="translate(-255 -225.6204)"
|
|
258
|
+
/>
|
|
259
|
+
<path
|
|
260
|
+
d="M502.71045,333.62308h-12a7,7,0,0,1,0-14h12a7,7,0,0,1,0,14Z"
|
|
261
|
+
transform="translate(-255 -225.6204)"
|
|
262
|
+
fill="#ccc"
|
|
263
|
+
/>
|
|
264
|
+
<path
|
|
265
|
+
d="M584.71045,363.12308h-12a7,7,0,0,1,0-14h12a7,7,0,0,1,0,14Z"
|
|
266
|
+
transform="translate(-255 -225.6204)"
|
|
267
|
+
fill="#ccc"
|
|
268
|
+
/>
|
|
269
|
+
<path
|
|
270
|
+
d="M622.71045,363.12308h-12a7,7,0,0,1,0-14h12a7,7,0,0,1,0,14Z"
|
|
271
|
+
transform="translate(-255 -225.6204)"
|
|
272
|
+
fill="#ccc"
|
|
273
|
+
/>
|
|
274
|
+
<path
|
|
275
|
+
d="M660.71045,363.12308h-12a7,7,0,0,1,0-14h12a7,7,0,0,1,0,14Z"
|
|
276
|
+
transform="translate(-255 -225.6204)"
|
|
277
|
+
fill="#ccc"
|
|
278
|
+
/>
|
|
279
|
+
<path
|
|
280
|
+
d="M585.71045,334.12308h-56a7,7,0,0,1,0-14h56a7,7,0,0,1,0,14Z"
|
|
281
|
+
transform="translate(-255 -225.6204)"
|
|
282
|
+
fill="#ccc"
|
|
283
|
+
/>
|
|
284
|
+
<path
|
|
285
|
+
d="M546.71045,362.12308h-56a7,7,0,0,1,0-14h56a7,7,0,0,1,0,14Z"
|
|
286
|
+
transform="translate(-255 -225.6204)"
|
|
287
|
+
fill="#ccc"
|
|
288
|
+
/>
|
|
289
|
+
<path
|
|
290
|
+
d="M656.71045,334.12308h-43a7,7,0,0,1,0-14h43a7,7,0,0,1,0,14Z"
|
|
291
|
+
transform="translate(-255 -225.6204)"
|
|
292
|
+
fill="#ccc"
|
|
293
|
+
/>
|
|
294
|
+
<path
|
|
295
|
+
d="M502.71045,392.62308h-12a7,7,0,0,1,0-14h12a7,7,0,0,1,0,14Z"
|
|
296
|
+
transform="translate(-255 -225.6204)"
|
|
297
|
+
fill="#ccc"
|
|
298
|
+
/>
|
|
299
|
+
<path
|
|
300
|
+
d="M585.71045,393.12308h-56a7,7,0,0,1,0-14h56a7,7,0,0,1,0,14Z"
|
|
301
|
+
transform="translate(-255 -225.6204)"
|
|
302
|
+
fill="#ccc"
|
|
303
|
+
/>
|
|
304
|
+
<path
|
|
305
|
+
d="M656.71045,393.12308h-43a7,7,0,0,1,0-14h43a7,7,0,0,1,0,14Z"
|
|
306
|
+
transform="translate(-255 -225.6204)"
|
|
307
|
+
fill="#ccc"
|
|
308
|
+
/>
|
|
309
|
+
<path
|
|
310
|
+
d="M637.71045,416.62308a7.00786,7.00786,0,0,1,7-7h12a7,7,0,0,1,0,14h-12A7.00785,7.00785,0,0,1,637.71045,416.62308Z"
|
|
311
|
+
transform="translate(-255 -225.6204)"
|
|
312
|
+
fill="#ccc"
|
|
313
|
+
/>
|
|
314
|
+
<path
|
|
315
|
+
d="M554.71045,417.12308a7.00786,7.00786,0,0,1,7-7h56a7,7,0,0,1,0,14h-56A7.00785,7.00785,0,0,1,554.71045,417.12308Z"
|
|
316
|
+
transform="translate(-255 -225.6204)"
|
|
317
|
+
fill="#ccc"
|
|
318
|
+
/>
|
|
319
|
+
<path
|
|
320
|
+
d="M483.71045,417.12308a7.00786,7.00786,0,0,1,7-7h43a7,7,0,0,1,0,14h-43A7.00785,7.00785,0,0,1,483.71045,417.12308Z"
|
|
321
|
+
transform="translate(-255 -225.6204)"
|
|
322
|
+
fill="#ccc"
|
|
323
|
+
/>
|
|
324
|
+
</motion.svg>
|
|
325
|
+
);
|
|
326
|
+
}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import type { Metadata } from "next";
|
|
2
|
+
import { Inter } from "next/font/google";
|
|
3
|
+
import "./globals.css";
|
|
4
|
+
import { Providers } from "@/components/providers";
|
|
5
|
+
|
|
6
|
+
const inter = Inter({ subsets: ["latin"] });
|
|
7
|
+
|
|
8
|
+
export const metadata: Metadata = {
|
|
9
|
+
title: "Create Next App",
|
|
10
|
+
description: "Generated by create next app",
|
|
11
|
+
};
|
|
12
|
+
|
|
13
|
+
export default function RootLayout({
|
|
14
|
+
children,
|
|
15
|
+
}: {
|
|
16
|
+
children: React.ReactNode;
|
|
17
|
+
}) {
|
|
18
|
+
return (
|
|
19
|
+
<html lang="en" suppressHydrationWarning>
|
|
20
|
+
<head>
|
|
21
|
+
<meta httpEquiv="X-UA-Compatible" content="IE=edge,chrome=1" />
|
|
22
|
+
<meta name="renderer" content="webkit" />
|
|
23
|
+
<meta
|
|
24
|
+
name="viewport"
|
|
25
|
+
content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no"
|
|
26
|
+
/>
|
|
27
|
+
{/* eslint-disable-next-line @next/next/no-before-interactive-script-outside-document */}
|
|
28
|
+
<script
|
|
29
|
+
dangerouslySetInnerHTML={{
|
|
30
|
+
__html: `
|
|
31
|
+
(function() {
|
|
32
|
+
var isIE = /MSIE|Trident/.test(navigator.userAgent);
|
|
33
|
+
var isOldIE = /MSIE [1-9]\\.|MSIE 10\\./.test(navigator.userAgent);
|
|
34
|
+
if (isOldIE) {
|
|
35
|
+
window.location.href = '/ie.html';
|
|
36
|
+
}
|
|
37
|
+
})();
|
|
38
|
+
`,
|
|
39
|
+
}}
|
|
40
|
+
/>
|
|
41
|
+
</head>
|
|
42
|
+
<body className={inter.className} suppressHydrationWarning>
|
|
43
|
+
<Providers>{children}</Providers>
|
|
44
|
+
</body>
|
|
45
|
+
</html>
|
|
46
|
+
);
|
|
47
|
+
}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import Link from "next/link";
|
|
2
|
+
|
|
3
|
+
export default function NotFound() {
|
|
4
|
+
return (
|
|
5
|
+
<div className="flex min-h-screen flex-col items-center justify-center">
|
|
6
|
+
<h2 className="text-2xl font-bold">页面未找到</h2>
|
|
7
|
+
<p className="mt-4 text-gray-600">抱歉,您访问的页面不存在。</p>
|
|
8
|
+
<Link
|
|
9
|
+
href="/"
|
|
10
|
+
className="mt-6 rounded bg-blue-500 px-4 py-2 text-white hover:bg-blue-600"
|
|
11
|
+
>
|
|
12
|
+
返回首页
|
|
13
|
+
</Link>
|
|
14
|
+
</div>
|
|
15
|
+
);
|
|
16
|
+
}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
|
|
3
|
+
import { useEffect } from "react";
|
|
4
|
+
|
|
5
|
+
import pkg from "../../package.json";
|
|
6
|
+
|
|
7
|
+
export default function BuildInfo() {
|
|
8
|
+
useEffect(() => {
|
|
9
|
+
const print = (key: string, value: string) =>
|
|
10
|
+
console.log(
|
|
11
|
+
`%c ${key} %c ${value} %c `,
|
|
12
|
+
"background:#20232a ; padding: 1px; border-radius: 3px 0 0 3px; color: #fff",
|
|
13
|
+
"background:#61dafb ;padding: 1px; border-radius: 0 3px 3px 0; color: #20232a; font-weight: bold;",
|
|
14
|
+
"background:transparent"
|
|
15
|
+
);
|
|
16
|
+
print(pkg.name, pkg.version);
|
|
17
|
+
print("build time", `${process.env.NEXT_PUBLIC_BUILD_TIME}`);
|
|
18
|
+
}, []);
|
|
19
|
+
return null;
|
|
20
|
+
}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
import { ThemeProvider } from "./theme";
|
|
2
|
+
import { QueryProvider } from "./query";
|
|
3
|
+
import { Toaster } from "sonner";
|
|
4
|
+
import { TooltipProvider } from "@/components/ui/tooltip";
|
|
5
|
+
|
|
6
|
+
export function Providers({ children }: React.PropsWithChildren) {
|
|
7
|
+
return (
|
|
8
|
+
<QueryProvider>
|
|
9
|
+
<ThemeProvider>
|
|
10
|
+
<TooltipProvider>{children}</TooltipProvider>
|
|
11
|
+
<Toaster position="top-right" richColors />
|
|
12
|
+
</ThemeProvider>
|
|
13
|
+
</QueryProvider>
|
|
14
|
+
);
|
|
15
|
+
}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
|
|
3
|
+
import { QueryClient, QueryClientProvider } from "@tanstack/react-query";
|
|
4
|
+
import { ReactQueryDevtools } from "@tanstack/react-query-devtools";
|
|
5
|
+
import { useState } from "react";
|
|
6
|
+
|
|
7
|
+
export function QueryProvider({ children }: { children: React.ReactNode }) {
|
|
8
|
+
const [queryClient] = useState(
|
|
9
|
+
() =>
|
|
10
|
+
new QueryClient({
|
|
11
|
+
defaultOptions: {
|
|
12
|
+
queries: {
|
|
13
|
+
// 数据缓存时间 (默认 5 分钟)
|
|
14
|
+
staleTime: 5 * 60 * 1000,
|
|
15
|
+
// 数据在内存中的缓存时间 (默认 5 分钟)
|
|
16
|
+
gcTime: 5 * 60 * 1000,
|
|
17
|
+
// 重试次数
|
|
18
|
+
retry: 3,
|
|
19
|
+
// 重试延迟
|
|
20
|
+
retryDelay: (attemptIndex) =>
|
|
21
|
+
Math.min(1000 * 2 ** attemptIndex, 30000),
|
|
22
|
+
// 窗口重新获得焦点时是否重新获取数据
|
|
23
|
+
refetchOnWindowFocus: false,
|
|
24
|
+
// 网络重新连接时是否重新获取数据
|
|
25
|
+
refetchOnReconnect: true,
|
|
26
|
+
},
|
|
27
|
+
mutations: {
|
|
28
|
+
// 重试次数
|
|
29
|
+
retry: 1,
|
|
30
|
+
// 重试延迟
|
|
31
|
+
retryDelay: 1000,
|
|
32
|
+
},
|
|
33
|
+
},
|
|
34
|
+
})
|
|
35
|
+
);
|
|
36
|
+
|
|
37
|
+
return (
|
|
38
|
+
<QueryClientProvider client={queryClient}>
|
|
39
|
+
{children}
|
|
40
|
+
{/* {process.env.NODE_ENV === 'development' && (
|
|
41
|
+
<ReactQueryDevtools initialIsOpen={false} />
|
|
42
|
+
)} */}
|
|
43
|
+
</QueryClientProvider>
|
|
44
|
+
);
|
|
45
|
+
}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
|
|
3
|
+
import { ThemeProvider as NextThemesProvider } from "next-themes";
|
|
4
|
+
import * as React from "react";
|
|
5
|
+
|
|
6
|
+
export function ThemeProvider({ children }: React.PropsWithChildren) {
|
|
7
|
+
return (
|
|
8
|
+
<NextThemesProvider
|
|
9
|
+
attribute="class"
|
|
10
|
+
defaultTheme="system"
|
|
11
|
+
enableSystem
|
|
12
|
+
disableTransitionOnChange
|
|
13
|
+
>
|
|
14
|
+
{children}
|
|
15
|
+
</NextThemesProvider>
|
|
16
|
+
);
|
|
17
|
+
}
|
|
@@ -0,0 +1,204 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* HTTP 请求类封装(强类型,无 any)
|
|
3
|
+
* 配合 React Query 使用,简化超时和重试逻辑
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
import { toast } from "sonner";
|
|
7
|
+
|
|
8
|
+
interface RequestConfig {
|
|
9
|
+
baseURL?: string;
|
|
10
|
+
headers?: Record<string, string>;
|
|
11
|
+
}
|
|
12
|
+
|
|
13
|
+
interface RequestOptions extends RequestInit {
|
|
14
|
+
params?: Record<string, string | number | boolean>;
|
|
15
|
+
data?: unknown; // 用于传递请求体
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
interface ApiResponse<T> {
|
|
19
|
+
data: T;
|
|
20
|
+
status?: number;
|
|
21
|
+
ok?: boolean;
|
|
22
|
+
code?: number; // 后端业务状态码
|
|
23
|
+
msg?: string | null; // 后端消息
|
|
24
|
+
}
|
|
25
|
+
|
|
26
|
+
// 后端 API 响应结构
|
|
27
|
+
interface BackendResponse<T> {
|
|
28
|
+
code: number;
|
|
29
|
+
msg: string | null;
|
|
30
|
+
data: T;
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
export class HttpClient {
|
|
34
|
+
private baseURL: string;
|
|
35
|
+
private defaultHeaders: Record<string, string>;
|
|
36
|
+
|
|
37
|
+
constructor(config: RequestConfig = {}) {
|
|
38
|
+
this.baseURL = config.baseURL || "";
|
|
39
|
+
this.defaultHeaders = {
|
|
40
|
+
"Content-Type": "application/json",
|
|
41
|
+
...config.headers,
|
|
42
|
+
};
|
|
43
|
+
}
|
|
44
|
+
updateToken(token: string) {
|
|
45
|
+
// this.defaultHeaders['Authorization'] = `Bearer ${token}`;
|
|
46
|
+
this.defaultHeaders["token"] = `${token}`;
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
private buildURL(url: string, params?: Record<string, unknown>): string {
|
|
50
|
+
let fullURL = url.startsWith("http") ? url : `${this.baseURL}${url}`;
|
|
51
|
+
|
|
52
|
+
if (params) {
|
|
53
|
+
const searchParams = new URLSearchParams();
|
|
54
|
+
Object.entries(params).forEach(([key, value]) => {
|
|
55
|
+
if (value !== null && value !== undefined) {
|
|
56
|
+
searchParams.append(key, String(value));
|
|
57
|
+
}
|
|
58
|
+
});
|
|
59
|
+
const paramString = searchParams.toString();
|
|
60
|
+
if (paramString) {
|
|
61
|
+
fullURL += `${fullURL.includes("?") ? "&" : "?"}${paramString}`;
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
return fullURL;
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
async request<T>(
|
|
69
|
+
url: string,
|
|
70
|
+
options: RequestOptions = {}
|
|
71
|
+
): Promise<ApiResponse<T>> {
|
|
72
|
+
const { params, data, ...fetchOptions } = options;
|
|
73
|
+
|
|
74
|
+
const fullURL = this.buildURL(url, params);
|
|
75
|
+
|
|
76
|
+
const headers: HeadersInit = {
|
|
77
|
+
...this.defaultHeaders,
|
|
78
|
+
...(fetchOptions.headers || {}),
|
|
79
|
+
};
|
|
80
|
+
|
|
81
|
+
let body = fetchOptions.body;
|
|
82
|
+
|
|
83
|
+
// 如果提供了 data,优先使用
|
|
84
|
+
if (data !== undefined) {
|
|
85
|
+
if (data instanceof FormData) {
|
|
86
|
+
body = data;
|
|
87
|
+
Reflect.deleteProperty(headers, "Content-Type"); // FormData 不需要手动设置 Content-Type
|
|
88
|
+
} else {
|
|
89
|
+
body = JSON.stringify(data);
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
try {
|
|
93
|
+
const response = await fetch(fullURL, {
|
|
94
|
+
...fetchOptions,
|
|
95
|
+
headers,
|
|
96
|
+
body,
|
|
97
|
+
});
|
|
98
|
+
const contentType = response.headers.get("content-type");
|
|
99
|
+
let responseData: T;
|
|
100
|
+
if (contentType?.includes("application/json")) {
|
|
101
|
+
const jsonResponse: BackendResponse<T> = await response.json();
|
|
102
|
+
if (jsonResponse.code == 401) {
|
|
103
|
+
// 清除本地存储
|
|
104
|
+
localStorage.clear();
|
|
105
|
+
|
|
106
|
+
// 退出用户状态
|
|
107
|
+
if (typeof window !== "undefined") {
|
|
108
|
+
// 动态导入store避免循环依赖
|
|
109
|
+
import("@/store")
|
|
110
|
+
.then(({ useStore }) => {
|
|
111
|
+
const { logout, openLoginDialog } = useStore.getState();
|
|
112
|
+
logout();
|
|
113
|
+
openLoginDialog();
|
|
114
|
+
})
|
|
115
|
+
.catch(console.error);
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
toast.error("登录信息已过期,请重新登录");
|
|
119
|
+
}
|
|
120
|
+
return jsonResponse;
|
|
121
|
+
} else if (contentType?.startsWith("text/")) {
|
|
122
|
+
responseData = (await response.text()) as T;
|
|
123
|
+
} else {
|
|
124
|
+
responseData = (await response.blob()) as T;
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
return {
|
|
128
|
+
data: responseData,
|
|
129
|
+
status: response.status,
|
|
130
|
+
ok: response.ok,
|
|
131
|
+
};
|
|
132
|
+
} catch (error: unknown) {
|
|
133
|
+
if (error instanceof Error) {
|
|
134
|
+
throw new Error(error.message);
|
|
135
|
+
}
|
|
136
|
+
throw new Error("网络请求失败");
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
|
|
140
|
+
// GET 请求
|
|
141
|
+
get<T>(
|
|
142
|
+
url: string,
|
|
143
|
+
params?: Record<string, string | number | boolean>,
|
|
144
|
+
options?: Omit<RequestOptions, "params">
|
|
145
|
+
) {
|
|
146
|
+
return this.request<T>(url, { ...options, method: "GET", params });
|
|
147
|
+
}
|
|
148
|
+
|
|
149
|
+
// POST 请求
|
|
150
|
+
post<T = unknown, B = unknown>(
|
|
151
|
+
url: string,
|
|
152
|
+
data?: B,
|
|
153
|
+
options?: Omit<RequestOptions, "data">
|
|
154
|
+
) {
|
|
155
|
+
return this.request<T>(url, { ...options, method: "POST", data });
|
|
156
|
+
}
|
|
157
|
+
|
|
158
|
+
// PUT 请求
|
|
159
|
+
put<T = unknown, B = unknown>(
|
|
160
|
+
url: string,
|
|
161
|
+
data?: B,
|
|
162
|
+
options?: Omit<RequestOptions, "data">
|
|
163
|
+
) {
|
|
164
|
+
return this.request<T>(url, { ...options, method: "PUT", data });
|
|
165
|
+
}
|
|
166
|
+
|
|
167
|
+
// PATCH 请求
|
|
168
|
+
patch<T = unknown, B = unknown>(
|
|
169
|
+
url: string,
|
|
170
|
+
data?: B,
|
|
171
|
+
options?: Omit<RequestOptions, "data">
|
|
172
|
+
) {
|
|
173
|
+
return this.request<T>(url, { ...options, method: "PATCH", data });
|
|
174
|
+
}
|
|
175
|
+
|
|
176
|
+
// DELETE 请求
|
|
177
|
+
delete<T = unknown>(url: string, options?: RequestOptions) {
|
|
178
|
+
return this.request<T>(url, { ...options, method: "DELETE" });
|
|
179
|
+
}
|
|
180
|
+
|
|
181
|
+
// 上传文件
|
|
182
|
+
upload<T = unknown>(
|
|
183
|
+
url: string,
|
|
184
|
+
formData: FormData,
|
|
185
|
+
options?: Omit<RequestOptions, "data" | "body">
|
|
186
|
+
) {
|
|
187
|
+
return this.request<T>(url, { ...options, method: "POST", data: formData });
|
|
188
|
+
}
|
|
189
|
+
}
|
|
190
|
+
|
|
191
|
+
// 创建默认实例
|
|
192
|
+
export const http = new HttpClient({
|
|
193
|
+
baseURL: `${process.env.NEXT_PUBLIC_API_URL || "/api"}`,
|
|
194
|
+
});
|
|
195
|
+
|
|
196
|
+
// 快捷导出函数
|
|
197
|
+
export const get = http.get.bind(http);
|
|
198
|
+
export const post = http.post.bind(http);
|
|
199
|
+
export const put = http.put.bind(http);
|
|
200
|
+
export const patch = http.patch.bind(http);
|
|
201
|
+
export const del = http.delete.bind(http);
|
|
202
|
+
export const upload = http.upload.bind(http);
|
|
203
|
+
|
|
204
|
+
export default http;
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "create-web-kit",
|
|
3
|
-
"version": "25.0728.
|
|
3
|
+
"version": "25.0728.1502",
|
|
4
4
|
"description": "A powerful scaffolding tool for creating modern frontend projects with Vue, Next.js, and Electron templates",
|
|
5
5
|
"type": "module",
|
|
6
6
|
"bin": {
|
|
@@ -13,7 +13,7 @@
|
|
|
13
13
|
"node": "^18.0.0 || >=20.0.0"
|
|
14
14
|
},
|
|
15
15
|
"scripts": {
|
|
16
|
-
"build": "tsc -d --outDir dist",
|
|
16
|
+
"build": "tsc -d --outDir dist && node scripts/copy-templates.mjs",
|
|
17
17
|
"dev": "pnpx tsx src/index.ts",
|
|
18
18
|
"start": "node dist/index.js"
|
|
19
19
|
},
|