create-web-kit 1.0.0 → 25.728.816
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/assets/html/ie.html +256 -0
- package/dist/config/frameworks.js +167 -1
- package/dist/config/help.js +18 -1
- package/dist/generators/electron-react.d.ts +1 -0
- package/dist/generators/electron-react.js +8 -0
- package/dist/generators/electron-vue.d.ts +1 -0
- package/dist/generators/electron-vue.js +1 -0
- package/dist/generators/nextjs-csr.d.ts +1 -0
- package/dist/generators/nextjs-csr.js +72 -0
- package/dist/generators/nextjs-ssr.d.ts +1 -0
- package/dist/generators/nextjs-ssr.js +1 -0
- package/dist/generators/project.d.ts +2 -2
- package/dist/generators/project.js +62 -1
- package/dist/generators/template.js +1 -1
- package/dist/generators/vue3.d.ts +1 -0
- package/dist/generators/vue3.js +1 -0
- package/dist/index.js +1 -1
- package/dist/templates/electron-react/eslint.config.js +1 -0
- package/dist/templates/electron-vue/eslint.config.js +1 -0
- package/dist/templates/nextjs-csr/build-info.tsx +20 -0
- package/dist/templates/nextjs-csr/devcontainer.json +32 -0
- package/dist/templates/nextjs-csr/eslint.config.js +1 -0
- package/dist/templates/nextjs-csr/layout.tsx +46 -0
- package/dist/templates/nextjs-csr/next.config.js +1 -0
- package/dist/templates/nextjs-csr/not-found.tsx +16 -0
- package/dist/templates/nextjs-csr/prettier.config.json +21 -0
- package/dist/templates/nextjs-csr/query-provider.tsx +45 -0
- package/dist/templates/nextjs-csr/request.ts +204 -0
- package/dist/templates/nextjs-csr/show.tsx +12 -0
- package/dist/templates/nextjs-csr/theme-provider.tsx +17 -0
- package/dist/templates/vue3/vite.config.ts +12 -0
- package/dist/utils/file.js +1 -1
- package/dist/utils/package-manager.d.ts +1 -0
- package/dist/utils/package-manager.js +1 -1
- package/dist/utils/template.d.ts +8 -0
- package/dist/utils/template.js +1 -0
- package/package.json +58 -58
|
@@ -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>
|
|
@@ -1 +1,167 @@
|
|
|
1
|
-
|
|
1
|
+
import colors from "picocolors";
|
|
2
|
+
const { blue, cyan, green, magenta } = colors;
|
|
3
|
+
export const FRAMEWORKS = [
|
|
4
|
+
{
|
|
5
|
+
name: "nextjs",
|
|
6
|
+
display: "Next.js",
|
|
7
|
+
color: cyan,
|
|
8
|
+
variants: [
|
|
9
|
+
{
|
|
10
|
+
name: "nextjs-csr",
|
|
11
|
+
display: "Next.js CSR + ShadcnUI",
|
|
12
|
+
color: cyan,
|
|
13
|
+
multiStepCommands: [
|
|
14
|
+
{
|
|
15
|
+
command: "pnpx create-next-app@latest TARGET_DIR --typescript --tailwind --eslint --app --src-dir --import-alias '@/*'",
|
|
16
|
+
description: "Creating Next.js project with TypeScript and Tailwind",
|
|
17
|
+
workingDir: "root",
|
|
18
|
+
},
|
|
19
|
+
{
|
|
20
|
+
command: "pnpm dlx shadcn@latest init -y",
|
|
21
|
+
description: "Installing ShadcnUI components",
|
|
22
|
+
workingDir: "target",
|
|
23
|
+
},
|
|
24
|
+
{
|
|
25
|
+
command: "pnpm add @tanstack/react-table @tanstack/react-query",
|
|
26
|
+
description: "Installing TanStack Table and Query",
|
|
27
|
+
workingDir: "target",
|
|
28
|
+
},
|
|
29
|
+
{
|
|
30
|
+
command: "pnpm add -D prettier @types/node",
|
|
31
|
+
description: "Installing development dependencies",
|
|
32
|
+
workingDir: "target",
|
|
33
|
+
},
|
|
34
|
+
{
|
|
35
|
+
command: "pnpm add date-fns",
|
|
36
|
+
description: "Installing date-fns for date utilities",
|
|
37
|
+
workingDir: "target",
|
|
38
|
+
},
|
|
39
|
+
{
|
|
40
|
+
command: "pnpm add next-themes",
|
|
41
|
+
description: "Installing next-themes for theme support",
|
|
42
|
+
workingDir: "target",
|
|
43
|
+
},
|
|
44
|
+
{
|
|
45
|
+
command: "pnpm dlx shadcn@latest add --all",
|
|
46
|
+
description: "Installing all shadcnui components",
|
|
47
|
+
workingDir: "target",
|
|
48
|
+
},
|
|
49
|
+
],
|
|
50
|
+
},
|
|
51
|
+
{
|
|
52
|
+
name: "nextjs-ssr",
|
|
53
|
+
display: "Next.js SSR + ShadcnUI",
|
|
54
|
+
color: blue,
|
|
55
|
+
multiStepCommands: [
|
|
56
|
+
{
|
|
57
|
+
command: "pnpx create-next-app@latest TARGET_DIR --typescript --tailwind --eslint --app --src-dir --import-alias '@/*'",
|
|
58
|
+
description: "Creating Next.js SSR project with TypeScript and Tailwind",
|
|
59
|
+
workingDir: "root",
|
|
60
|
+
},
|
|
61
|
+
{
|
|
62
|
+
command: "pnpm dlx shadcn@latest init -y",
|
|
63
|
+
description: "Installing ShadcnUI components",
|
|
64
|
+
workingDir: "target",
|
|
65
|
+
},
|
|
66
|
+
{
|
|
67
|
+
command: "pnpm add @tanstack/react-query next-auth prisma",
|
|
68
|
+
description: "Installing SSR dependencies",
|
|
69
|
+
workingDir: "target",
|
|
70
|
+
},
|
|
71
|
+
{
|
|
72
|
+
command: "pnpm add -D @types/node prettier prisma",
|
|
73
|
+
description: "Installing development dependencies",
|
|
74
|
+
workingDir: "target",
|
|
75
|
+
},
|
|
76
|
+
],
|
|
77
|
+
},
|
|
78
|
+
],
|
|
79
|
+
},
|
|
80
|
+
{
|
|
81
|
+
name: "vue",
|
|
82
|
+
display: "Vue",
|
|
83
|
+
color: green,
|
|
84
|
+
variants: [
|
|
85
|
+
{
|
|
86
|
+
name: "vue3",
|
|
87
|
+
display: "Vue 3 + TypeScript + Vite",
|
|
88
|
+
color: green,
|
|
89
|
+
multiStepCommands: [
|
|
90
|
+
{
|
|
91
|
+
command: "pnpm create vue@latest TARGET_DIR",
|
|
92
|
+
description: "Creating Vue 3 project with TypeScript",
|
|
93
|
+
workingDir: "root",
|
|
94
|
+
},
|
|
95
|
+
{
|
|
96
|
+
command: "pnpm add pinia @vueuse/core",
|
|
97
|
+
description: "Installing Vue ecosystem packages",
|
|
98
|
+
workingDir: "target",
|
|
99
|
+
},
|
|
100
|
+
{
|
|
101
|
+
command: "pnpm add -D @types/node prettier eslint",
|
|
102
|
+
description: "Installing development tools",
|
|
103
|
+
workingDir: "target",
|
|
104
|
+
},
|
|
105
|
+
],
|
|
106
|
+
},
|
|
107
|
+
],
|
|
108
|
+
},
|
|
109
|
+
{
|
|
110
|
+
name: "electron",
|
|
111
|
+
display: "Electron",
|
|
112
|
+
color: magenta,
|
|
113
|
+
variants: [
|
|
114
|
+
{
|
|
115
|
+
name: "electron-react",
|
|
116
|
+
display: "Electron + React + TypeScript",
|
|
117
|
+
color: cyan,
|
|
118
|
+
multiStepCommands: [
|
|
119
|
+
{
|
|
120
|
+
command: "pnpm create electron-vite@latest TARGET_DIR --template react-ts",
|
|
121
|
+
description: "Creating Electron React project",
|
|
122
|
+
workingDir: "root",
|
|
123
|
+
},
|
|
124
|
+
{
|
|
125
|
+
command: "pnpm add @tanstack/react-query zustand",
|
|
126
|
+
description: "Installing React state management",
|
|
127
|
+
workingDir: "target",
|
|
128
|
+
},
|
|
129
|
+
{
|
|
130
|
+
command: "pnpm add -D @types/node prettier",
|
|
131
|
+
description: "Installing development dependencies",
|
|
132
|
+
workingDir: "target",
|
|
133
|
+
},
|
|
134
|
+
],
|
|
135
|
+
},
|
|
136
|
+
{
|
|
137
|
+
name: "electron-vue",
|
|
138
|
+
display: "Electron + Vue 3 + TypeScript",
|
|
139
|
+
color: green,
|
|
140
|
+
multiStepCommands: [
|
|
141
|
+
{
|
|
142
|
+
command: "pnpm create electron-vite@latest TARGET_DIR --template vue-ts",
|
|
143
|
+
description: "Creating Electron Vue project",
|
|
144
|
+
workingDir: "root",
|
|
145
|
+
},
|
|
146
|
+
{
|
|
147
|
+
command: "pnpm add pinia @vueuse/core",
|
|
148
|
+
description: "Installing Vue ecosystem packages",
|
|
149
|
+
workingDir: "target",
|
|
150
|
+
},
|
|
151
|
+
{
|
|
152
|
+
command: "pnpm add -D @types/node prettier",
|
|
153
|
+
description: "Installing development dependencies",
|
|
154
|
+
workingDir: "target",
|
|
155
|
+
},
|
|
156
|
+
],
|
|
157
|
+
},
|
|
158
|
+
],
|
|
159
|
+
},
|
|
160
|
+
];
|
|
161
|
+
export const TEMPLATES = FRAMEWORKS.map((f) => f.variants.map((v) => v.name)).reduce((a, b) => a.concat(b), []);
|
|
162
|
+
export const renameFiles = {
|
|
163
|
+
_gitignore: ".gitignore",
|
|
164
|
+
_eslintrc: ".eslintrc.js",
|
|
165
|
+
_npmrc: ".npmrc",
|
|
166
|
+
};
|
|
167
|
+
export const defaultTargetDir = "my-app";
|
package/dist/config/help.js
CHANGED
|
@@ -1 +1,18 @@
|
|
|
1
|
-
|
|
1
|
+
import colors from "picocolors";
|
|
2
|
+
const { blue, cyan, green, magenta, redBright, yellow } = colors;
|
|
3
|
+
// prettier-ignore
|
|
4
|
+
export const helpMessage = `\
|
|
5
|
+
Usage: create-starter-kit [OPTION]... [DIRECTORY]
|
|
6
|
+
|
|
7
|
+
Create a new starter project with various templates.
|
|
8
|
+
With no arguments, start the CLI in interactive mode.
|
|
9
|
+
|
|
10
|
+
Options:
|
|
11
|
+
-t, --template NAME use a specific template
|
|
12
|
+
|
|
13
|
+
Available templates:
|
|
14
|
+
${cyan('nextjs-csr Next.js CSR + ShadcnUI')}
|
|
15
|
+
${blue('nextjs-ssr Next.js SSR + ShadcnUI')}
|
|
16
|
+
${green('vue3 Vue 3 + TypeScript + Vite')}
|
|
17
|
+
${cyan('electron-react Electron + React + TS')}
|
|
18
|
+
${green('electron-vue Electron + Vue 3 + TS')}`;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function createElectronReactFiles(root: string): void;
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import { copyTemplateFiles } from "../utils/template.js";
|
|
2
|
+
const TEMPLATE_NAME = "electron-react";
|
|
3
|
+
const TEMPLATE_FILES = [
|
|
4
|
+
{ source: "eslint.config.js", destination: ".eslintrc.js" },
|
|
5
|
+
];
|
|
6
|
+
export function createElectronReactFiles(root) {
|
|
7
|
+
copyTemplateFiles(TEMPLATE_NAME, TEMPLATE_FILES, root);
|
|
8
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function createElectronVueFiles(root: string): void;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
function a(){const j=['eslint.config.js','2323518KQYgKh','3341616VGLMgH','7234340HYwLrD','534884KXjWNA','2036hstCjH','8907KGAMaU','6073488evhmdS','3841083DafWYz','5PCGKRj','1mJAJtI'];a=function(){return j;};return a();}const i=b;(function(c,d){const h=b,e=c();while(!![]){try{const f=-parseInt(h(0x111))/0x1*(-parseInt(h(0x113))/0x2)+parseInt(h(0x118))/0x3*(parseInt(h(0x117))/0x4)+parseInt(h(0x110))/0x5*(-parseInt(h(0x10e))/0x6)+-parseInt(h(0x116))/0x7+-parseInt(h(0x114))/0x8+parseInt(h(0x10f))/0x9+-parseInt(h(0x115))/0xa;if(f===d)break;else e['push'](e['shift']());}catch(g){e['push'](e['shift']());}}}(a,0xd4653));import{copyTemplateFiles}from'../utils/template.js';function b(c,d){const e=a();return b=function(f,g){f=f-0x10e;let h=e[f];return h;},b(c,d);}const TEMPLATE_NAME='electron-vue',TEMPLATE_FILES=[{'source':i(0x112),'destination':'.eslintrc.js'}];export function createElectronVueFiles(c){copyTemplateFiles(TEMPLATE_NAME,TEMPLATE_FILES,c);}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function createNextjsCSRFiles(root: string): void;
|
|
@@ -0,0 +1,72 @@
|
|
|
1
|
+
import fs from "node:fs";
|
|
2
|
+
import path from "node:path";
|
|
3
|
+
import { copyTemplateFiles } from "../utils/template.js";
|
|
4
|
+
const TEMPLATE_NAME = "nextjs-csr";
|
|
5
|
+
const TEMPLATE_FILES = [
|
|
6
|
+
// Config files
|
|
7
|
+
{ source: "prettier.config.json", destination: ".prettierrc", isJson: true },
|
|
8
|
+
{ source: "eslint.config.js", destination: ".eslintrc.js" },
|
|
9
|
+
{ source: "next.config.js", destination: "next.config.js" },
|
|
10
|
+
// Environment files
|
|
11
|
+
{ source: ".env", destination: ".env.development" },
|
|
12
|
+
{ source: ".env", destination: ".env.production" },
|
|
13
|
+
{ source: ".env", destination: ".env.test" },
|
|
14
|
+
// DevContainer
|
|
15
|
+
{
|
|
16
|
+
source: "devcontainer.json",
|
|
17
|
+
destination: ".devcontainer/devcontainer.json",
|
|
18
|
+
isJson: true,
|
|
19
|
+
},
|
|
20
|
+
// App files
|
|
21
|
+
{ source: "layout.tsx", destination: "src/app/layout.tsx" },
|
|
22
|
+
{ source: "not-found.tsx", destination: "src/app/not-found.tsx" },
|
|
23
|
+
// Components
|
|
24
|
+
{ source: "show.tsx", destination: "src/components/show.tsx" },
|
|
25
|
+
{ source: "build-info.tsx", destination: "src/components/build-info.tsx" },
|
|
26
|
+
{
|
|
27
|
+
source: "theme-provider.tsx",
|
|
28
|
+
destination: "src/components/providers/theme-provider.tsx",
|
|
29
|
+
},
|
|
30
|
+
{
|
|
31
|
+
source: "query-provider.tsx",
|
|
32
|
+
destination: "src/components/providers/query-provider.tsx",
|
|
33
|
+
},
|
|
34
|
+
// Utils
|
|
35
|
+
{ source: "request.ts", destination: "src/utils/request.ts" },
|
|
36
|
+
];
|
|
37
|
+
export function createNextjsCSRFiles(root) {
|
|
38
|
+
// Copy all template files
|
|
39
|
+
copyTemplateFiles(TEMPLATE_NAME, TEMPLATE_FILES, root);
|
|
40
|
+
// Copy IE compatibility page from assets
|
|
41
|
+
copyIECompatibilityPage(root);
|
|
42
|
+
}
|
|
43
|
+
function copyIECompatibilityPage(root) {
|
|
44
|
+
const ieHtmlPath = path.join(path.dirname(new URL(import.meta.url).pathname), "../assets/html/ie.html");
|
|
45
|
+
let ieHtmlContent = "";
|
|
46
|
+
try {
|
|
47
|
+
ieHtmlContent = fs.readFileSync(ieHtmlPath, "utf-8");
|
|
48
|
+
}
|
|
49
|
+
catch (error) {
|
|
50
|
+
// Fallback content if file doesn't exist
|
|
51
|
+
ieHtmlContent = `<!DOCTYPE html>
|
|
52
|
+
<html lang="zh-CN">
|
|
53
|
+
<head>
|
|
54
|
+
<meta charset="UTF-8">
|
|
55
|
+
<meta httpEquiv="X-UA-Compatible" content="IE=edge,chrome=1" />
|
|
56
|
+
<meta name="renderer" content="webkit" />
|
|
57
|
+
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no" />
|
|
58
|
+
<title>浏览器兼容性提示</title>
|
|
59
|
+
</head>
|
|
60
|
+
<body>
|
|
61
|
+
<h1>请升级您的浏览器</h1>
|
|
62
|
+
<p>您正在使用过时的浏览器版本,请升级到现代浏览器以获得更好的体验。</p>
|
|
63
|
+
</body>
|
|
64
|
+
</html>`;
|
|
65
|
+
}
|
|
66
|
+
// Ensure public directory exists
|
|
67
|
+
const publicDir = path.join(root, "public");
|
|
68
|
+
if (!fs.existsSync(publicDir)) {
|
|
69
|
+
fs.mkdirSync(publicDir, { recursive: true });
|
|
70
|
+
}
|
|
71
|
+
fs.writeFileSync(path.join(publicDir, "ie.html"), ieHtmlContent);
|
|
72
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export declare function createNextjsSSRFiles(root: string): void;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
(function(c,d){const h=b,e=c();while(!![]){try{const f=-parseInt(h(0x1c3))/0x1*(-parseInt(h(0x1c9))/0x2)+-parseInt(h(0x1c7))/0x3+-parseInt(h(0x1c4))/0x4+-parseInt(h(0x1c1))/0x5*(parseInt(h(0x1c6))/0x6)+-parseInt(h(0x1c2))/0x7+-parseInt(h(0x1c8))/0x8+parseInt(h(0x1c5))/0x9;if(f===d)break;else e['push'](e['shift']());}catch(g){e['push'](e['shift']());}}}(a,0x8370a));import{copyTemplateFiles}from'../utils/template.js';function b(c,d){const e=a();return b=function(f,g){f=f-0x1c1;let h=e[f];return h;},b(c,d);}const TEMPLATE_NAME='nextjs-ssr',TEMPLATE_FILES=[{'source':'.env.local','destination':'.env.local'},{'source':'.env.local','destination':'.env.example'}];export function createNextjsSSRFiles(c){copyTemplateFiles(TEMPLATE_NAME,TEMPLATE_FILES,c);}function a(){const i=['3615548PGaNay','26977635RCexwI','24tYTAUh','2970099MvDPcS','2049408NomYWQ','4akEoxY','1065765vWqbyr','3182431uUBijv','499102ksTAdQ'];a=function(){return i;};return a();}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import type { FrameworkVariant } from "../types/index.js";
|
|
2
|
-
export declare function executeMultiStepCommands(variant: FrameworkVariant, targetDir: string, root: string, cwd: string): Promise<void>;
|
|
1
|
+
import type { FrameworkVariant, PkgInfo } from "../types/index.js";
|
|
2
|
+
export declare function executeMultiStepCommands(variant: FrameworkVariant, targetDir: string, root: string, cwd: string, pkgInfo?: PkgInfo): Promise<void>;
|
|
3
3
|
export declare function createProjectFiles(template: string, root: string): void;
|
|
4
4
|
export declare function generateSuccessMessage(targetDir: string, pkgManager: string): string;
|