create-web-kit 25.728.1414 → 25.728.1636

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.
@@ -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>
@@ -27,7 +27,7 @@ export const FRAMEWORKS = [
27
27
  workingDir: "target",
28
28
  },
29
29
  {
30
- command: "pnpm add -D prettier @types/node",
30
+ command: "pnpm add -D prettier @types/node husky lint-staged prettier-plugin-tailwindcss @trivago/prettier-plugin-sort-imports eslint-config-prettier",
31
31
  description: "Installing development dependencies",
32
32
  workingDir: "target",
33
33
  },
@@ -1,5 +1,6 @@
1
1
  import fs from "node:fs";
2
2
  import path from "node:path";
3
+ import { execSync } from "node:child_process";
3
4
  import { copyTemplateFiles } from "../utils/template.js";
4
5
  const TEMPLATE_NAME = "nextjs-csr";
5
6
  const TEMPLATE_FILES = [
@@ -7,6 +8,11 @@ const TEMPLATE_FILES = [
7
8
  { source: "prettier.config.json", destination: ".prettierrc", isJson: true },
8
9
  { source: "eslint.config.mjs", destination: "eslint.config.mjs" },
9
10
  { source: "next.config.ts", destination: "next.config.ts" },
11
+ { source: ".env.test", destination: ".env.test" },
12
+ { source: ".env.development", destination: ".env.development" },
13
+ { source: ".env.production", destination: ".env.production" },
14
+ { source: ".husky/pre-commit", destination: ".husky/pre-commit" },
15
+ { source: ".husky/_/husky.sh", destination: ".husky/_/husky.sh" },
10
16
  // DevContainer
11
17
  {
12
18
  source: ".devcontainer/devcontainer.json",
@@ -41,8 +47,83 @@ const TEMPLATE_FILES = [
41
47
  export function createNextjsCSRFiles(root) {
42
48
  // Copy all template files
43
49
  copyTemplateFiles(TEMPLATE_NAME, TEMPLATE_FILES, root);
44
- // Copy IE compatibility page from assets
50
+ // Configure package.json with husky and lint-staged
51
+ copyConfigHuskyPackage(root);
52
+ // Copy IE compatibility page
45
53
  copyIECompatibilityPage(root);
54
+ // Initialize husky after all files are copied
55
+ initializeHusky(root);
56
+ }
57
+ function copyConfigHuskyPackage(root) {
58
+ const pkgPath = path.join(root, "package.json");
59
+ try {
60
+ const pkgContent = fs.readFileSync(pkgPath, "utf-8");
61
+ const pkg = JSON.parse(pkgContent);
62
+ // 添加 prepare 脚本
63
+ if (!pkg.scripts) {
64
+ pkg.scripts = {};
65
+ }
66
+ pkg.scripts.prepare = "husky";
67
+ // 添加 lint-staged 配置
68
+ pkg["lint-staged"] = {
69
+ "**/*.{js,jsx,ts,tsx,json,css,scss,md}": ["prettier --write"],
70
+ "**/*.{js,jsx,ts,tsx}": ["eslint --fix"],
71
+ };
72
+ // 写回文件
73
+ fs.writeFileSync(pkgPath, JSON.stringify(pkg, null, 2) + "\n");
74
+ console.log("✅ Updated package.json with husky and lint-staged configuration");
75
+ }
76
+ catch (error) {
77
+ console.error("❌ Failed to update package.json:", error);
78
+ }
79
+ }
80
+ function initializeHusky(root) {
81
+ try {
82
+ console.log("🔧 Initializing Git repository...");
83
+ try {
84
+ execSync("git init", {
85
+ cwd: root,
86
+ stdio: "inherit",
87
+ });
88
+ console.log("✅ Git repository initialized");
89
+ }
90
+ catch (gitError) {
91
+ console.warn("⚠️ Git init failed or already initialized:", gitError);
92
+ }
93
+ execSync("npx husky install", {
94
+ cwd: root,
95
+ stdio: "inherit",
96
+ });
97
+ // 确保 .husky 目录存在
98
+ const huskyDir = path.join(root, ".husky");
99
+ if (!fs.existsSync(huskyDir)) {
100
+ fs.mkdirSync(huskyDir, { recursive: true });
101
+ }
102
+ // 确保 .husky/_/ 目录存在
103
+ const huskyUnderscoreDir = path.join(huskyDir, "_");
104
+ if (!fs.existsSync(huskyUnderscoreDir)) {
105
+ fs.mkdirSync(huskyUnderscoreDir, { recursive: true });
106
+ }
107
+ // 创建 pre-commit 钩子文件
108
+ const preCommitPath = path.join(huskyDir, "pre-commit");
109
+ const preCommitContent = `#!/usr/bin/env sh
110
+ . "$(dirname -- "$0")/_/husky.sh"
111
+
112
+ npx lint-staged
113
+ `;
114
+ fs.writeFileSync(preCommitPath, preCommitContent);
115
+ // 设置执行权限
116
+ try {
117
+ fs.chmodSync(preCommitPath, 0o755);
118
+ }
119
+ catch (chmodError) {
120
+ console.warn("⚠️ Could not set execute permission for pre-commit hook");
121
+ }
122
+ console.log("✅ Husky pre-commit hook created successfully");
123
+ }
124
+ catch (error) {
125
+ console.error("❌ Failed to initialize husky:", error);
126
+ }
46
127
  }
47
128
  function copyIECompatibilityPage(root) {
48
129
  const ieHtmlPath = path.join(path.dirname(new URL(import.meta.url).pathname), "../assets/html/ie.html");
@@ -51,21 +132,7 @@ function copyIECompatibilityPage(root) {
51
132
  ieHtmlContent = fs.readFileSync(ieHtmlPath, "utf-8");
52
133
  }
53
134
  catch (error) {
54
- // Fallback content if file doesn't exist
55
- ieHtmlContent = `<!DOCTYPE html>
56
- <html lang="zh-CN">
57
- <head>
58
- <meta charset="UTF-8">
59
- <meta httpEquiv="X-UA-Compatible" content="IE=edge,chrome=1" />
60
- <meta name="renderer" content="webkit" />
61
- <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no" />
62
- <title>浏览器兼容性提示</title>
63
- </head>
64
- <body>
65
- <h1>请升级您的浏览器</h1>
66
- <p>您正在使用过时的浏览器版本,请升级到现代浏览器以获得更好的体验。</p>
67
- </body>
68
- </html>`;
135
+ console.error(error);
69
136
  }
70
137
  // Ensure public directory exists
71
138
  const publicDir = path.join(root, "public");
@@ -0,0 +1,7 @@
1
+ module.exports = {
2
+ extends: ['electron', '@electron-toolkit/eslint-config-ts', 'prettier'],
3
+ rules: {
4
+ '@typescript-eslint/no-unused-vars': 'error',
5
+ '@typescript-eslint/no-explicit-any': 'warn',
6
+ },
7
+ };
@@ -0,0 +1,7 @@
1
+ module.exports = {
2
+ extends: ['electron', '@electron-toolkit/eslint-config-ts', 'prettier'],
3
+ rules: {
4
+ '@typescript-eslint/no-unused-vars': 'error',
5
+ '@typescript-eslint/no-explicit-any': 'warn',
6
+ },
7
+ };
@@ -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,2 @@
1
+ NEXT_PUBLIC_API_URL=/api
2
+ NEXT_PUBLIC_BASE_URL=/
@@ -0,0 +1,2 @@
1
+ NEXT_PUBLIC_API_URL=/api
2
+ NEXT_PUBLIC_BASE_URL=/
@@ -0,0 +1,2 @@
1
+ NEXT_PUBLIC_API_URL=/api
2
+ NEXT_PUBLIC_BASE_URL=/
@@ -0,0 +1,36 @@
1
+ #!/usr/bin/env sh
2
+ if [ -z "$husky_skip_init" ]; then
3
+ debug () {
4
+ if [ "$HUSKY_DEBUG" = "1" ]; then
5
+ echo "husky (debug) - $1"
6
+ fi
7
+ }
8
+
9
+ readonly hook_name="$(basename -- "$0")"
10
+ debug "starting $hook_name..."
11
+
12
+ if [ "$HUSKY" = "0" ]; then
13
+ debug "HUSKY env variable is set to 0, skipping hook"
14
+ exit 0
15
+ fi
16
+
17
+ if [ -f ~/.huskyrc ]; then
18
+ debug "sourcing ~/.huskyrc"
19
+ . ~/.huskyrc
20
+ fi
21
+
22
+ readonly husky_skip_init=1
23
+ export husky_skip_init
24
+ sh -e "$0" "$@"
25
+ exitcode="$?"
26
+
27
+ if [ $exitcode != 0 ]; then
28
+ echo "husky - $hook_name hook exited with code $exitcode (error)"
29
+ fi
30
+
31
+ if [ $exitcode = 127 ]; then
32
+ echo "husky - command not found in PATH=$PATH"
33
+ fi
34
+
35
+ exit $exitcode
36
+ fi
@@ -0,0 +1,4 @@
1
+ #!/usr/bin/env sh
2
+ . "$(dirname -- "$0")/_/husky.sh"
3
+
4
+ npx lint-staged
@@ -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
+ }