reborn-ui 0.1.5 → 0.1.6
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/index.js +61 -5
- package/dist/index.js.map +1 -1
- package/package.json +50 -46
- package/registry/registry.json +1 -1
package/dist/index.js
CHANGED
|
@@ -151,6 +151,38 @@ async function loadConfigCompat(cwd, configPath) {
|
|
|
151
151
|
return await loadConfig(cwd, "shadcn-docs.json");
|
|
152
152
|
}
|
|
153
153
|
|
|
154
|
+
// src/commands/add.ts
|
|
155
|
+
import cliProgress from "cli-progress";
|
|
156
|
+
import chalk2 from "chalk";
|
|
157
|
+
|
|
158
|
+
// src/utils/ui.ts
|
|
159
|
+
import chalk from "chalk";
|
|
160
|
+
async function typewriter(text, delay = 30) {
|
|
161
|
+
for (const char of text) {
|
|
162
|
+
process.stdout.write(char);
|
|
163
|
+
await new Promise((resolve) => setTimeout(resolve, delay));
|
|
164
|
+
}
|
|
165
|
+
process.stdout.write("\n");
|
|
166
|
+
}
|
|
167
|
+
function successLog(message) {
|
|
168
|
+
console.log(`${chalk.green("\u2714")} ${message}`);
|
|
169
|
+
}
|
|
170
|
+
function gradientText(text) {
|
|
171
|
+
const colors = [
|
|
172
|
+
chalk.hex("#FF0080"),
|
|
173
|
+
chalk.hex("#FF8C00"),
|
|
174
|
+
chalk.hex("#40E0D0"),
|
|
175
|
+
chalk.hex("#0080FF"),
|
|
176
|
+
chalk.hex("#7B68EE")
|
|
177
|
+
];
|
|
178
|
+
let result = "";
|
|
179
|
+
for (let i = 0; i < text.length; i++) {
|
|
180
|
+
const color = colors[i % colors.length];
|
|
181
|
+
result += color(text[i]);
|
|
182
|
+
}
|
|
183
|
+
return result;
|
|
184
|
+
}
|
|
185
|
+
|
|
154
186
|
// src/commands/add.ts
|
|
155
187
|
function rewriteImports(params) {
|
|
156
188
|
const { content, aliasSymbol } = params;
|
|
@@ -206,19 +238,35 @@ function addCommand() {
|
|
|
206
238
|
);
|
|
207
239
|
targets = res.selected ?? [];
|
|
208
240
|
}
|
|
241
|
+
const bar = new cliProgress.SingleBar({
|
|
242
|
+
format: "\u6B63\u5728\u6DFB\u52A0\u7EC4\u4EF6 |" + chalk2.cyan("{bar}") + "| {percentage}% || {value}/{total} \u7EC4\u4EF6",
|
|
243
|
+
barCompleteChar: "\u2588",
|
|
244
|
+
barIncompleteChar: "\u2591",
|
|
245
|
+
hideCursor: true
|
|
246
|
+
});
|
|
247
|
+
bar.start(targets.length, 0);
|
|
209
248
|
for (const name of targets) {
|
|
210
249
|
const c = registry.components.find((x) => x.name === name);
|
|
211
|
-
if (!c)
|
|
212
|
-
|
|
250
|
+
if (!c) {
|
|
251
|
+
bar.stop();
|
|
252
|
+
throw new Error(`registry \u4E2D\u4E0D\u5B58\u5728\u8BE5\u7EC4\u4EF6\uFF1A${name}`);
|
|
253
|
+
}
|
|
254
|
+
await writeComponentFiles({
|
|
213
255
|
cwd,
|
|
214
256
|
componentsDir: cfg.componentsDir,
|
|
215
257
|
aliasSymbol: cfg.aliasSymbol ?? "@",
|
|
216
258
|
component: c,
|
|
217
259
|
overwrite: opts.overwrite
|
|
218
260
|
});
|
|
219
|
-
|
|
261
|
+
bar.increment();
|
|
262
|
+
}
|
|
263
|
+
bar.stop();
|
|
264
|
+
console.log("");
|
|
265
|
+
for (const name of targets) {
|
|
266
|
+
successLog(`\u7EC4\u4EF6 ${chalk2.bold(name)} \u5DF2\u6210\u529F\u6DFB\u52A0\u5230\u9879\u76EE`);
|
|
220
267
|
}
|
|
221
|
-
console.log(
|
|
268
|
+
console.log(`
|
|
269
|
+
${chalk2.bold.green("DONE")} \u5DF2\u5B8C\u6210 ${targets.length} \u4E2A\u7EC4\u4EF6\u7684\u6DFB\u52A0\uFF08pm=${pm}\uFF09`);
|
|
222
270
|
});
|
|
223
271
|
return cmd;
|
|
224
272
|
}
|
|
@@ -540,6 +588,8 @@ function initCommand() {
|
|
|
540
588
|
if (!await pathExists(libUtilsPath2)) await writeTextFile(libUtilsPath2, cnUtilsTs({}));
|
|
541
589
|
console.log(`\u5DF2\u5199\u5165\u914D\u7F6E\uFF1A${path7.relative(process.cwd(), cfgPath2)}\uFF1B\u5E76\u751F\u6210 cn/utils\uFF08pm=${pm}\uFF09`);
|
|
542
590
|
console.log("\u8BF7\u6309\u7167 https://tw.icebreaker.top/docs/quick-start/v4/uni-app-vite \u6307\u5F15\u8FDB\u884C\u9879\u76EE\u914D\u7F6E\u521D\u59CB\u5316");
|
|
591
|
+
console.log("");
|
|
592
|
+
await typewriter(gradientText("\u611F\u8C22\u4F7F\u7528 Reborn UI ! \u2728"), 50);
|
|
543
593
|
return;
|
|
544
594
|
}
|
|
545
595
|
const cfgPath = path7.join(cwd, opts.config);
|
|
@@ -567,6 +617,8 @@ function initCommand() {
|
|
|
567
617
|
if (!await pathExists(libUtilsPath)) await writeTextFile(libUtilsPath, cnUtilsTs({}));
|
|
568
618
|
console.log(`\u5DF2\u521D\u59CB\u5316\uFF1A${path7.relative(process.cwd(), cfgPath)}\uFF1B\u5E76\u751F\u6210 cn/utils\uFF08pm=${pm}\uFF09`);
|
|
569
619
|
console.log("\u8BF7\u6309\u7167 https://tw.icebreaker.top/docs/quick-start/v4/uni-app-vite \u6307\u5F15\u8FDB\u884C\u9879\u76EE\u914D\u7F6E\u521D\u59CB\u5316");
|
|
620
|
+
console.log("");
|
|
621
|
+
await typewriter(gradientText("\u611F\u8C22\u4F7F\u7528 Reborn UI ! \u2728"), 50);
|
|
570
622
|
});
|
|
571
623
|
return cmd;
|
|
572
624
|
}
|
|
@@ -574,7 +626,7 @@ function initCommand() {
|
|
|
574
626
|
// package.json
|
|
575
627
|
var package_default = {
|
|
576
628
|
name: "reborn-ui",
|
|
577
|
-
version: "0.1.
|
|
629
|
+
version: "0.1.6",
|
|
578
630
|
description: "A CLI for Reborn UI",
|
|
579
631
|
author: "1997liuyh-boop",
|
|
580
632
|
license: "MIT",
|
|
@@ -606,11 +658,15 @@ var package_default = {
|
|
|
606
658
|
prepublishOnly: "npm run build && npm run registry:build"
|
|
607
659
|
},
|
|
608
660
|
dependencies: {
|
|
661
|
+
chalk: "^5.6.2",
|
|
662
|
+
"cli-progress": "^3.12.0",
|
|
609
663
|
commander: "^14.0.0",
|
|
610
664
|
execa: "^9.6.0",
|
|
665
|
+
ora: "^9.0.0",
|
|
611
666
|
prompts: "^2.4.2"
|
|
612
667
|
},
|
|
613
668
|
devDependencies: {
|
|
669
|
+
"@types/cli-progress": "^3.11.6",
|
|
614
670
|
"@types/node": "^22.10.7",
|
|
615
671
|
"@types/prompts": "^2.4.9",
|
|
616
672
|
rimraf: "^6.0.1",
|
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/index.ts","../src/commands/add.ts","../src/utils/fs.ts","../src/utils/pm.ts","../src/utils/registry.ts","../src/commands/build.ts","../src/utils/imports.ts","../src/commands/init.ts","../src/utils/templates.ts","../package.json"],"sourcesContent":["import { Command } from \"commander\";\r\nimport { addCommand } from \"./commands/add.js\";\r\nimport { buildCommand } from \"./commands/build.js\";\r\nimport { initCommand } from \"./commands/init.js\";\r\nimport packageJson from \"../package.json\" assert { type: \"json\" };\r\n\r\nconst program = new Command()\r\n .name(\"reborn-ui\")\r\n .description(\"Reborn UI - 组件安装与 registry 辅助 CLI\")\r\n .version(packageJson.version);\r\n\r\nprogram.addCommand(initCommand());\r\nprogram.addCommand(addCommand());\r\nprogram.addCommand(buildCommand());\r\n\r\nawait program.parseAsync(process.argv);\r\n\r\n\r\n","import path from \"node:path\";\r\nimport { Command } from \"commander\";\r\nimport prompts from \"prompts\";\r\nimport type { PackageManager, RegistryComponent } from \"../types.js\";\r\nimport { ensureDir, pathExists, writeTextFile } from \"../utils/fs.js\";\r\nimport {\r\n detectPackageManager,\r\n readPackageJson,\r\n} from \"../utils/pm.js\";\r\nimport { defaultConfig, loadConfigCompat, loadRegistry } from \"../utils/registry.js\";\r\n\r\nfunction rewriteImports(params: {\r\n content: string;\r\n aliasSymbol: string;\r\n}) {\r\n const { content, aliasSymbol } = params;\r\n if (!aliasSymbol || aliasSymbol === \"@\") return content;\r\n\r\n // 仅替换项目根目录映射符号:把 \"@/xxx\" -> \"<aliasSymbol>/xxx\"\r\n // 注意:不要影响 scoped package(@scope/name),这里只替换 \"@/\" 前缀。\r\n return content.replaceAll(\"@/\", `${aliasSymbol}/`);\r\n}\r\n\r\nasync function writeComponentFiles(params: {\r\n cwd: string;\r\n componentsDir: string;\r\n aliasSymbol: string;\r\n component: RegistryComponent;\r\n overwrite?: boolean;\r\n}) {\r\n const { cwd, componentsDir, aliasSymbol, component, overwrite } = params;\r\n const baseDir = path.join(cwd, componentsDir, component.name);\r\n await ensureDir(baseDir);\r\n\r\n for (const f of component.files) {\r\n const target = path.join(baseDir, ...f.path.split(\"/\"));\r\n if (!overwrite && (await pathExists(target))) continue;\r\n const nextContent = rewriteImports({ content: f.content, aliasSymbol });\r\n await writeTextFile(target, nextContent);\r\n }\r\n\r\n return baseDir;\r\n}\r\n\r\nexport function addCommand() {\r\n const cmd = new Command(\"add\")\r\n .description(\"向项目中添加组件与相关依赖\")\r\n .argument(\"[components...]\", \"组件名(可多个)\")\r\n .option(\"--cwd <path>\", \"目标项目目录\", process.cwd())\r\n .option(\"--pm <pm>\", \"包管理器:pnpm|npm|yarn|bun\")\r\n .option(\"--yes\", \"跳过交互\", false)\r\n .option(\"--overwrite\", \"覆盖已存在文件\", false)\r\n .option(\"--config <path>\", \"配置文件路径(相对 cwd)\", \"components.json\")\r\n .option(\"--registry <pkgOrPath>\", \"覆盖配置里的 registry\")\r\n .option(\"--components-dir <path>\", \"覆盖配置里的 componentsDir\")\r\n .option(\"--lib-dir <path>\", \"覆盖配置里的 libDir\")\r\n .option(\"--alias-symbol <symbol>\", \"覆盖配置里的 aliasSymbol(默认 @)\")\r\n .action(async (components: string[], opts) => {\r\n const cwd = path.resolve(opts.cwd);\r\n const pm: PackageManager =\r\n opts.pm ?? (await detectPackageManager(cwd));\r\n\r\n const cfg = (await loadConfigCompat(cwd, opts.config)) ?? defaultConfig();\r\n if (opts.registry) cfg.registry = opts.registry;\r\n if (opts.componentsDir) cfg.componentsDir = opts.componentsDir;\r\n if (opts.libDir) cfg.libDir = opts.libDir;\r\n if (opts.aliasSymbol) cfg.aliasSymbol = opts.aliasSymbol;\r\n\r\n const registry = await loadRegistry({ cwd, registry: cfg.registry });\r\n\r\n let targets = components ?? [];\r\n if (!targets.length) {\r\n if (opts.yes) {\r\n throw new Error(\"未指定组件名;请传入组件参数或去掉 --yes 以交互选择。\");\r\n }\r\n const choices = registry.components.map((c) => ({\r\n title: c.name,\r\n value: c.name,\r\n }));\r\n const res = await prompts(\r\n [\r\n {\r\n type: \"multiselect\",\r\n name: \"selected\",\r\n message: \"选择要添加的组件\",\r\n choices,\r\n min: 1,\r\n },\r\n ],\r\n {\r\n onCancel: () => {\r\n throw new Error(\"已取消\");\r\n },\r\n },\r\n );\r\n targets = res.selected ?? [];\r\n }\r\n\r\n for (const name of targets) {\r\n const c = registry.components.find((x) => x.name === name);\r\n if (!c) throw new Error(`registry 中不存在该组件:${name}`);\r\n\r\n const outDir = await writeComponentFiles({\r\n cwd,\r\n componentsDir: cfg.componentsDir,\r\n aliasSymbol: cfg.aliasSymbol ?? \"@\",\r\n component: c,\r\n overwrite: opts.overwrite,\r\n });\r\n\r\n // eslint-disable-next-line no-console\r\n console.log(`已写入组件:${name} -> ${path.relative(cwd, outDir)}`);\r\n }\r\n\r\n // eslint-disable-next-line no-console\r\n console.log(`完成:已向项目添加 ${targets.length} 个组件(pm=${pm})`);\r\n });\r\n\r\n return cmd;\r\n}\r\n\r\n\r\n","import { createHash } from \"node:crypto\";\nimport fs from \"node:fs/promises\";\nimport path from \"node:path\";\n\nexport async function pathExists(p: string) {\n try {\n await fs.access(p);\n return true;\n } catch {\n return false;\n }\n}\n\nexport async function ensureDir(dirPath: string) {\n await fs.mkdir(dirPath, { recursive: true });\n}\n\nexport async function readJsonFile<T>(filePath: string): Promise<T> {\n const raw = await fs.readFile(filePath, \"utf8\");\n return JSON.parse(raw) as T;\n}\n\nexport async function writeJsonFile(filePath: string, data: unknown) {\n await ensureDir(path.dirname(filePath));\n await fs.writeFile(filePath, JSON.stringify(data, null, 2) + \"\\n\", \"utf8\");\n}\n\nexport async function writeTextFile(filePath: string, content: string) {\n await ensureDir(path.dirname(filePath));\n await fs.writeFile(filePath, content, \"utf8\");\n}\n\nexport async function listFilesRecursive(\n dirPath: string,\n opts?: { ignoreDirNames?: Set<string> },\n) {\n const ignoreDirNames =\n opts?.ignoreDirNames ??\n new Set([\"node_modules\", \".git\", \".nuxt\", \"dist\", \".output\"]);\n\n const out: string[] = [];\n\n async function walk(current: string) {\n const entries = await fs.readdir(current, { withFileTypes: true });\n for (const entry of entries) {\n const p = path.join(current, entry.name);\n if (entry.isDirectory()) {\n if (ignoreDirNames.has(entry.name)) continue;\n await walk(p);\n } else if (entry.isFile()) {\n out.push(p);\n }\n }\n }\n\n await walk(dirPath);\n return out;\n}\n\nexport async function copyDirRecursive(params: {\n fromDir: string;\n toDir: string;\n overwrite?: boolean;\n ignoreFileNames?: Set<string>;\n}) {\n const { fromDir, toDir, overwrite } = params;\n const ignoreFileNames = params.ignoreFileNames ?? new Set([\".DS_Store\"]);\n\n const entries = await fs.readdir(fromDir, { withFileTypes: true });\n await ensureDir(toDir);\n\n for (const entry of entries) {\n if (ignoreFileNames.has(entry.name)) continue;\n const from = path.join(fromDir, entry.name);\n const to = path.join(toDir, entry.name);\n\n if (entry.isDirectory()) {\n await copyDirRecursive({ fromDir: from, toDir: to, overwrite, ignoreFileNames });\n continue;\n }\n\n if (!entry.isFile()) continue;\n\n if (!overwrite) {\n try {\n await fs.access(to);\n continue; // 已存在则跳过\n } catch {\n // not exists\n }\n }\n\n await ensureDir(path.dirname(to));\n await fs.copyFile(from, to);\n }\n}\n\nexport function sha1(text: string) {\n return createHash(\"sha1\").update(text).digest(\"hex\");\n}\n\n\n","import fs from \"node:fs/promises\";\r\nimport path from \"node:path\";\r\nimport { execa } from \"execa\";\r\nimport type { PackageManager } from \"../types.js\";\r\nimport { pathExists, readJsonFile, writeJsonFile } from \"./fs.js\";\r\n\r\nexport async function detectPackageManager(cwd: string): Promise<PackageManager> {\r\n if (await pathExists(path.join(cwd, \"pnpm-lock.yaml\"))) return \"pnpm\";\r\n if (await pathExists(path.join(cwd, \"yarn.lock\"))) return \"yarn\";\r\n if (await pathExists(path.join(cwd, \"package-lock.json\"))) return \"npm\";\r\n if (await pathExists(path.join(cwd, \"bun.lockb\"))) return \"bun\";\r\n return \"pnpm\";\r\n}\r\n\r\nexport async function readPackageJson(\r\n cwd: string,\r\n): Promise<Record<string, any> & { dependencies?: Record<string, string>; devDependencies?: Record<string, string> }> {\r\n return await readJsonFile(path.join(cwd, \"package.json\"));\r\n}\r\n\r\nexport async function writePackageJson(cwd: string, pkg: unknown) {\r\n await writeJsonFile(path.join(cwd, \"package.json\"), pkg);\r\n}\r\n\r\nexport function getMissingDeps(\r\n pkg: { dependencies?: Record<string, string>; devDependencies?: Record<string, string> },\r\n deps: string[],\r\n) {\r\n const existing = new Set([\r\n ...Object.keys(pkg.dependencies ?? {}),\r\n ...Object.keys(pkg.devDependencies ?? {}),\r\n ]);\r\n return deps.filter((d) => !existing.has(d));\r\n}\r\n\r\nexport async function installDeps(params: {\r\n cwd: string;\r\n pm: PackageManager;\r\n deps: string[];\r\n dev?: boolean;\r\n}) {\r\n const { cwd, pm, deps, dev } = params;\r\n if (!deps.length) return;\r\n\r\n const args: string[] = [];\r\n if (pm === \"pnpm\") args.push(\"add\");\r\n else if (pm === \"npm\") args.push(\"install\");\r\n else if (pm === \"yarn\") args.push(\"add\");\r\n else if (pm === \"bun\") args.push(\"add\");\r\n\r\n if (dev) {\r\n if (pm === \"npm\") args.push(\"--save-dev\");\r\n else args.push(\"-D\");\r\n }\r\n\r\n args.push(...deps);\r\n\r\n await execa(pm, args, { cwd, stdio: \"inherit\" });\r\n}\r\n\r\nexport async function ensureJsonFile(cwd: string, relPath: string, defaultJson: unknown) {\r\n const p = path.join(cwd, relPath);\r\n if (await pathExists(p)) return;\r\n await fs.mkdir(path.dirname(p), { recursive: true });\r\n await fs.writeFile(p, JSON.stringify(defaultJson, null, 2) + \"\\n\", \"utf8\");\r\n}\r\n\r\n\r\n","import path from \"node:path\";\nimport fs from \"node:fs\";\nimport { createRequire } from \"node:module\";\nimport { fileURLToPath } from \"node:url\";\nimport type { CliConfig, RegistryFile } from \"../types.js\";\nimport { pathExists, readJsonFile } from \"./fs.js\";\n\nexport const DEFAULT_CONFIG_PATH = \"components.json\";\n\nfunction findNearestPackageRoot(from: string) {\n // from: import.meta.url\n let dir = path.dirname(fileURLToPath(from));\n while (true) {\n if (fs.existsSync(path.join(dir, \"package.json\"))) return dir;\n const parent = path.dirname(dir);\n if (parent === dir) return dir;\n dir = parent;\n }\n}\n\nexport function defaultConfig(): CliConfig {\n return {\n schemaVersion: 1,\n componentsDir: \"components\",\n libDir: \"lib\",\n composablesDir: \"composables\",\n // 默认使用 CLI 包内置的 registry(随 reborn-ui 一起发布)\n registry: \"builtin\",\n // 项目根目录映射别名符号(默认 @)\n aliasSymbol: \"@\",\n };\n}\n\nexport async function loadConfig(cwd: string, configPath = DEFAULT_CONFIG_PATH) {\n const abs = path.isAbsolute(configPath)\n ? configPath\n : path.join(cwd, configPath);\n if (!(await pathExists(abs))) return null;\n return await readJsonFile<CliConfig>(abs);\n}\n\nexport function resolveRegistryJsonPath(params: { cwd: string; registry: string }) {\n const { cwd, registry } = params;\n\n // 0) 内置 registry\n if (!registry || registry === \"builtin\") {\n // 注意:CLI 经过打包后可能变成单文件(例如 dist/index.js),\n // import.meta.url 的相对基准会变化,不能用固定的 ../../registry/...\n // 这里通过向上查找最近的 package.json 来定位包根目录。\n const pkgRoot = findNearestPackageRoot(import.meta.url);\n return path.join(pkgRoot, \"registry\", \"registry.json\");\n }\n\n // 1) 如果是文件路径(包含分隔符或 .json),优先当成路径处理\n const looksLikePath =\n registry.includes(\"/\") ||\n registry.includes(\"\\\\\") ||\n registry.endsWith(\".json\");\n\n if (looksLikePath) {\n const abs = path.isAbsolute(registry) ? registry : path.join(cwd, registry);\n return abs;\n }\n\n // 2) 当成包名处理:默认读取 <pkg>/registry/registry.json\n const require = createRequire(import.meta.url);\n // 不显式绑定 cwd,避免 npx 场景下找不到 registry 包\n return require.resolve(`${registry}/registry/registry.json`);\n}\n\nexport async function loadRegistry(params: { cwd: string; registry: string }) {\n const jsonPath = resolveRegistryJsonPath(params);\n return await readJsonFile<RegistryFile>(jsonPath);\n}\n\n// 兼容旧配置文件名:shadcn-docs.json\nexport async function loadConfigCompat(cwd: string, configPath?: string) {\n if (configPath) return await loadConfig(cwd, configPath);\n const primary = await loadConfig(cwd, DEFAULT_CONFIG_PATH);\n if (primary) return primary;\n return await loadConfig(cwd, \"shadcn-docs.json\");\n}\n\n\n","import path from \"node:path\";\r\nimport fs from \"node:fs/promises\";\r\nimport fssync from \"node:fs\";\r\nimport { Command } from \"commander\";\r\nimport type { RegistryComponent, RegistryFile } from \"../types.js\";\r\nimport { listFilesRecursive, sha1, writeJsonFile } from \"../utils/fs.js\";\r\nimport { extractNpmDependenciesFromText } from \"../utils/imports.js\";\r\n\r\nfunction isAllowedFile(filePath: string) {\r\n const ext = path.extname(filePath).toLowerCase();\r\n return [\r\n \".vue\",\r\n \".ts\",\r\n \".js\",\r\n \".json\",\r\n \".css\",\r\n \".md\",\r\n \".svg\",\r\n ].includes(ext);\r\n}\r\n\r\nfunction findWorkspaceRoot(startDir: string) {\r\n let current = path.resolve(startDir);\r\n for (;;) {\r\n const marker = path.join(current, \"pnpm-workspace.yaml\");\r\n if (fssync.existsSync(marker)) return current;\r\n const parent = path.dirname(current);\r\n if (parent === current) return startDir;\r\n current = parent;\r\n }\r\n}\r\n\r\nexport function buildCommand() {\r\n const cmd = new Command(\"build\")\r\n .description(\"(内部)扫描组件源码并生成 registry JSON\")\r\n .option(\"--root <path>\", \"仓库根目录(默认自动向上查找 pnpm-workspace.yaml)\")\r\n .option(\r\n \"--source <path>\",\r\n \"组件源码目录(相对 root)\",\r\n \"components/content/reborn\",\r\n )\r\n .option(\r\n \"--out <path>\",\r\n \"输出 registry.json 路径(相对 root)\",\r\n \"packages/cli/registry/registry.json\",\r\n )\r\n .option(\r\n \"--also-out <path>\",\r\n \"额外再输出一份 registry.json(可重复传参)\",\r\n (val, acc: string[]) => {\r\n acc.push(val);\r\n return acc;\r\n },\r\n [],\r\n )\r\n .action(async (opts) => {\r\n const rootDir = opts.root\r\n ? path.resolve(opts.root)\r\n : findWorkspaceRoot(process.cwd());\r\n const sourceDir = path.join(rootDir, opts.source);\r\n const outPath = path.join(rootDir, opts.out);\r\n const alsoOutPaths: string[] = (opts.alsoOut ?? []).map((p: string) =>\r\n path.join(rootDir, p),\r\n );\r\n\r\n const dirents = await fs.readdir(sourceDir, { withFileTypes: true });\r\n const componentDirs = dirents\r\n .filter((d) => d.isDirectory())\r\n .map((d) => path.join(sourceDir, d.name))\r\n .sort((a, b) => a.localeCompare(b));\r\n\r\n const components: RegistryComponent[] = [];\r\n\r\n for (const absComponentDir of componentDirs) {\r\n const name = path.basename(absComponentDir);\r\n const absFiles = (await listFilesRecursive(absComponentDir)).filter(\r\n isAllowedFile,\r\n );\r\n\r\n const files: RegistryComponent[\"files\"] = [];\r\n const depSet = new Set<string>();\r\n\r\n for (const absFile of absFiles) {\r\n const rel = path\r\n .relative(absComponentDir, absFile)\r\n .split(path.sep)\r\n .join(\"/\");\r\n const content = await fs.readFile(absFile, \"utf8\");\r\n files.push({ path: rel, content });\r\n\r\n // 只从代码文件里抽依赖\r\n const ext = path.extname(absFile).toLowerCase();\r\n if (ext === \".ts\" || ext === \".js\" || ext === \".vue\") {\r\n for (const dep of extractNpmDependenciesFromText(content)) {\r\n depSet.add(dep);\r\n }\r\n }\r\n }\r\n\r\n components.push({\r\n name,\r\n dependencies: [...depSet].sort(),\r\n files,\r\n });\r\n }\r\n\r\n const registry: RegistryFile = {\r\n schemaVersion: 1,\r\n generatedAt: new Date().toISOString(),\r\n source: {\r\n rootDir: rootDir.split(path.sep).join(\"/\"),\r\n componentsDir: opts.source,\r\n },\r\n components,\r\n };\r\n\r\n async function writeOut(targetRegistryPath: string) {\r\n const outComponentsDir = path.join(\r\n path.dirname(targetRegistryPath),\r\n \"components\",\r\n );\r\n await writeJsonFile(targetRegistryPath, registry);\r\n\r\n // 额外输出每个组件的 json,方便调试/按需读取\r\n await fs.mkdir(outComponentsDir, { recursive: true });\r\n for (const c of components) {\r\n await writeJsonFile(\r\n path.join(outComponentsDir, `${c.name}.json`),\r\n {\r\n ...c,\r\n fileCount: c.files.length,\r\n contentHash: sha1(JSON.stringify(c.files.map((f) => f.content))),\r\n },\r\n );\r\n }\r\n }\r\n\r\n await writeOut(outPath);\r\n for (const p of alsoOutPaths) await writeOut(p);\r\n\r\n // eslint-disable-next-line no-console\r\n console.log(\r\n `registry 已生成:${path.relative(process.cwd(), outPath)}(${components.length} 个组件)`,\r\n );\r\n });\r\n\r\n return cmd;\r\n}\r\n\r\n\r\n","const IMPORT_RE =\r\n /\\bfrom\\s+[\"']([^\"']+)[\"']|\\bimport\\(\\s*[\"']([^\"']+)[\"']\\s*\\)|\\brequire\\(\\s*[\"']([^\"']+)[\"']\\s*\\)/g;\r\n\r\nfunction normalizePackageName(specifier: string) {\r\n // ignore relative/alias/virtual\r\n if (\r\n specifier.startsWith(\".\") ||\r\n specifier.startsWith(\"/\") ||\r\n specifier.startsWith(\"@/\") ||\r\n specifier.startsWith(\"~/\") ||\r\n specifier.startsWith(\"#\") ||\r\n specifier.startsWith(\"virtual:\")\r\n ) {\r\n return null;\r\n }\r\n\r\n // scoped package: @scope/name[/...]\r\n if (specifier.startsWith(\"@\")) {\r\n const parts = specifier.split(\"/\");\r\n if (parts.length >= 2) return `${parts[0]}/${parts[1]}`;\r\n return specifier;\r\n }\r\n\r\n // normal package: name[/...]\r\n return specifier.split(\"/\")[0] ?? null;\r\n}\r\n\r\nexport function extractNpmDependenciesFromText(text: string) {\r\n const out = new Set<string>();\r\n\r\n for (const match of text.matchAll(IMPORT_RE)) {\r\n const spec = match[1] ?? match[2] ?? match[3];\r\n if (!spec) continue;\r\n const pkg = normalizePackageName(spec);\r\n if (!pkg) continue;\r\n out.add(pkg);\r\n }\r\n\r\n // 常见“框架自带/不应自动安装”的虚拟模块\r\n out.delete(\"nuxt\");\r\n out.delete(\"vue\");\r\n\r\n return [...out].sort();\r\n}\r\n\r\n\r\n","import path from \"node:path\";\r\nimport fs from \"node:fs/promises\";\r\nimport { Command } from \"commander\";\r\nimport prompts from \"prompts\";\r\nimport type { CliConfig, PackageManager } from \"../types.js\";\r\nimport { ensureDir, listFilesRecursive, pathExists, writeJsonFile, writeTextFile } from \"../utils/fs.js\";\r\nimport { detectPackageManager, readPackageJson } from \"../utils/pm.js\";\r\nimport { DEFAULT_CONFIG_PATH, defaultConfig, loadConfigCompat } from \"../utils/registry.js\";\r\nimport { copyTemplateSubdir } from \"../utils/templates.js\";\r\n\r\nfunction looksLikeNuxtProject(cwd: string) {\r\n return Promise.all([\r\n pathExists(path.join(cwd, \"nuxt.config.ts\")),\r\n pathExists(path.join(cwd, \"nuxt.config.js\")),\r\n pathExists(path.join(cwd, \"nuxt.config.mjs\")),\r\n ]).then((arr) => arr.some(Boolean));\r\n}\r\n\r\n\r\n// function makeDefaultTailwindConfig removed in favor of template file\r\n\r\n\r\n\r\n\r\nfunction cnUtilsTs(params: { importPath?: string }) {\r\n // importPath 预留:如果用户想从别处导入 clsx/twMerge\r\n void params;\r\n return `import { type ClassValue, clsx } from \"clsx\";\\nimport { twMerge } from \"tailwind-merge\";\\n\\nexport function cn(...inputs: ClassValue[]) {\\n return twMerge(clsx(inputs));\\n}\\n`;\r\n}\r\n\r\nasync function rewriteAliasInDir(params: {\r\n cwd: string;\r\n targetDir: string;\r\n aliasSymbol: string;\r\n}) {\r\n const { cwd, targetDir, aliasSymbol } = params;\r\n if (!aliasSymbol || aliasSymbol === \"@\") return;\r\n const absDir = path.join(cwd, targetDir);\r\n if (!(await pathExists(absDir))) return;\r\n\r\n const files = await listFilesRecursive(absDir);\r\n for (const f of files) {\r\n const ext = path.extname(f).toLowerCase();\r\n // 只处理常见文本文件,避免误改二进制\r\n if (![\".ts\", \".tsx\", \".js\", \".jsx\", \".vue\", \".mjs\", \".cjs\"].includes(ext)) continue;\r\n const raw = await fs.readFile(f, \"utf8\");\r\n const next = raw.replaceAll(\"@/\", `${aliasSymbol}/`);\r\n if (next !== raw) await fs.writeFile(f, next, \"utf8\");\r\n }\r\n}\r\n\r\nexport function initCommand() {\r\n const cmd = new Command(\"init\")\r\n .description(\"初始化新项目\")\r\n .option(\"--cwd <path>\", \"目标项目目录\", process.cwd())\r\n .option(\"--pm <pm>\", \"包管理器:pnpm|npm|yarn|bun\")\r\n .option(\"--yes\", \"跳过交互,使用默认值\", false)\r\n .option(\"--overwrite\", \"覆盖已存在的模板文件(lib/composables)\", false)\r\n .option(\r\n \"--config <path>\",\r\n \"配置文件路径(相对 cwd)\",\r\n DEFAULT_CONFIG_PATH,\r\n )\r\n .option(\r\n \"--components-dir <path>\",\r\n \"组件写入目录\",\r\n defaultConfig().componentsDir,\r\n )\r\n .option(\r\n \"--lib-dir <path>\",\r\n \"lib 目录(cn/utils)\",\r\n defaultConfig().libDir,\r\n )\r\n .option(\r\n \"--composables-dir <path>\",\r\n \"composables 目录\",\r\n defaultConfig().composablesDir,\r\n )\r\n .option(\r\n \"--alias-symbol <symbol>\",\r\n \"项目根目录映射别名符号(默认 @)\",\r\n defaultConfig().aliasSymbol,\r\n )\r\n .option(\"--registry <pkgOrPath>\", \"registry 来源(默认 builtin)\", defaultConfig().registry)\r\n .action(async (opts) => {\r\n const cwd = path.resolve(opts.cwd);\r\n\r\n // eslint-disable-next-line no-console\r\n console.log(\r\n \"提示:项目中有部分依赖需要使用@/ 路径进行配置,请您安装到项目中配置好的路径下,请慎重选择文件位置\",\r\n );\r\n\r\n const pkgPath = path.join(cwd, \"package.json\");\r\n if (!(await pathExists(pkgPath))) {\r\n throw new Error(`未找到 package.json:${pkgPath}`);\r\n }\r\n\r\n const pm: PackageManager =\r\n opts.pm ?? (await detectPackageManager(cwd));\r\n\r\n const cfg: CliConfig = {\r\n schemaVersion: 1,\r\n componentsDir: opts.componentsDir,\r\n libDir: opts.libDir,\r\n composablesDir: opts.composablesDir,\r\n aliasSymbol: opts.aliasSymbol,\r\n registry: opts.registry,\r\n };\r\n\r\n // 如果已存在 components.json,默认沿用(除非用户显式传参覆盖)\r\n const existing = await loadConfigCompat(cwd);\r\n if (existing) {\r\n cfg.componentsDir = opts.componentsDir ?? existing.componentsDir ?? cfg.componentsDir;\r\n cfg.libDir = opts.libDir ?? existing.libDir ?? cfg.libDir;\r\n cfg.composablesDir = opts.composablesDir ?? existing.composablesDir ?? cfg.composablesDir;\r\n cfg.aliasSymbol = opts.aliasSymbol ?? existing.aliasSymbol ?? cfg.aliasSymbol;\r\n cfg.registry = opts.registry ?? existing.registry ?? cfg.registry;\r\n }\r\n\r\n if (!opts.yes) {\r\n const nuxt = await looksLikeNuxtProject(cwd);\r\n const res = await prompts(\r\n [\r\n {\r\n type: \"text\",\r\n name: \"componentsDir\",\r\n message: \"组件目录(componentsDir)\",\r\n initial: cfg.componentsDir,\r\n },\r\n {\r\n type: \"text\",\r\n name: \"libDir\",\r\n message: \"lib 目录(libDir,用于 cn/utils)\",\r\n initial: cfg.libDir,\r\n },\r\n {\r\n type: \"text\",\r\n name: \"composablesDir\",\r\n message: \"composables 目录(composablesDir)\",\r\n initial: cfg.composablesDir,\r\n },\r\n {\r\n type: \"text\",\r\n name: \"aliasSymbol\",\r\n message: \"基于项目根目录的“映射”的符号是?(aliasSymbol)\",\r\n initial: cfg.aliasSymbol ?? \"@\",\r\n },\r\n ],\r\n {\r\n onCancel: () => {\r\n throw new Error(\"已取消\");\r\n },\r\n },\r\n );\r\n\r\n cfg.componentsDir = res.componentsDir ?? cfg.componentsDir;\r\n cfg.libDir = res.libDir ?? cfg.libDir;\r\n cfg.composablesDir = res.composablesDir ?? cfg.composablesDir;\r\n cfg.aliasSymbol = res.aliasSymbol ?? cfg.aliasSymbol;\r\n\r\n // 写配置\r\n const cfgPath = path.join(cwd, opts.config);\r\n await writeJsonFile(cfgPath, cfg);\r\n\r\n // 复制模板:lib/ + composables/\r\n await copyTemplateSubdir({\r\n subdir: \"lib\",\r\n cwd,\r\n targetDir: cfg.libDir,\r\n overwrite: opts.overwrite,\r\n });\r\n await copyTemplateSubdir({\r\n subdir: \"composables\",\r\n cwd,\r\n targetDir: cfg.composablesDir,\r\n overwrite: opts.overwrite,\r\n });\r\n // 仅替换 \"@/...\" 的别名符号,不改其它路径内容\r\n await rewriteAliasInDir({ cwd, targetDir: cfg.libDir, aliasSymbol: cfg.aliasSymbol ?? \"@\" });\r\n await rewriteAliasInDir({\r\n cwd,\r\n targetDir: cfg.composablesDir,\r\n aliasSymbol: cfg.aliasSymbol ?? \"@\",\r\n });\r\n\r\n // 兜底:如果用户模板里没有 utils.ts,则生成 cn\r\n const libUtilsPath = path.join(cwd, cfg.libDir, \"utils.ts\");\r\n if (!(await pathExists(libUtilsPath))) await writeTextFile(libUtilsPath, cnUtilsTs({}));\r\n\r\n // eslint-disable-next-line no-console\r\n console.log(`已写入配置:${path.relative(process.cwd(), cfgPath)};并生成 cn/utils(pm=${pm})`);\r\n console.log(\"请按照 https://tw.icebreaker.top/docs/quick-start/v4/uni-app-vite 指引进行项目配置初始化\");\r\n return;\r\n }\r\n\r\n // --yes:直接写默认配置\r\n const cfgPath = path.join(cwd, opts.config);\r\n await ensureDir(path.dirname(cfgPath));\r\n await fs.writeFile(cfgPath, JSON.stringify(cfg, null, 2) + \"\\n\", \"utf8\");\r\n\r\n // 复制模板:lib/ + composables/\r\n await copyTemplateSubdir({\r\n subdir: \"lib\",\r\n cwd,\r\n targetDir: cfg.libDir,\r\n overwrite: opts.overwrite,\r\n });\r\n await copyTemplateSubdir({\r\n subdir: \"composables\",\r\n cwd,\r\n targetDir: cfg.composablesDir,\r\n overwrite: opts.overwrite,\r\n });\r\n // 仅替换 \"@/...\" 的别名符号,不改其它路径内容\r\n await rewriteAliasInDir({ cwd, targetDir: cfg.libDir, aliasSymbol: cfg.aliasSymbol ?? \"@\" });\r\n await rewriteAliasInDir({\r\n cwd,\r\n targetDir: cfg.composablesDir,\r\n aliasSymbol: cfg.aliasSymbol ?? \"@\",\r\n });\r\n\r\n // 兜底:如果用户模板里没有 utils.ts,则生成 cn\r\n const libUtilsPath = path.join(cwd, cfg.libDir, \"utils.ts\");\r\n if (!(await pathExists(libUtilsPath))) await writeTextFile(libUtilsPath, cnUtilsTs({}));\r\n\r\n // eslint-disable-next-line no-console\r\n console.log(`已初始化:${path.relative(process.cwd(), cfgPath)};并生成 cn/utils(pm=${pm})`);\r\n console.log(\"请按照 https://tw.icebreaker.top/docs/quick-start/v4/uni-app-vite 指引进行项目配置初始化\");\r\n });\r\n\r\n return cmd;\r\n}\r\n\r\n\r\n","import path from \"node:path\";\nimport fs from \"node:fs\";\nimport { fileURLToPath } from \"node:url\";\nimport { pathExists } from \"./fs.js\";\nimport { copyDirRecursive } from \"./fs.js\";\n\nfunction findNearestPackageRoot(from: string) {\n // from: import.meta.url\n let dir = path.dirname(fileURLToPath(from));\n while (true) {\n if (fs.existsSync(path.join(dir, \"package.json\"))) return dir;\n const parent = path.dirname(dir);\n if (parent === dir) return dir;\n dir = parent;\n }\n}\n\nexport function getTemplatesRootDir() {\n // 注意:CLI 打包后可能变成单文件(dist/index.js),此时 import.meta.url 的相对基准会变化。\n // 通过向上查找最近的 package.json 来定位包根目录。\n const pkgRoot = findNearestPackageRoot(import.meta.url);\n return path.join(pkgRoot, \"templates\");\n}\n\nexport async function copyTemplateSubdir(params: {\n subdir: \"lib\" | \"composables\";\n cwd: string;\n targetDir: string;\n overwrite?: boolean;\n}) {\n const templatesRoot = getTemplatesRootDir();\n const fromDir = path.join(templatesRoot, params.subdir);\n if (!(await pathExists(fromDir))) return false;\n\n const toDir = path.join(params.cwd, params.targetDir);\n await copyDirRecursive({ fromDir, toDir, overwrite: params.overwrite });\n return true;\n}\n\n\n\n\n\n\n","{\r\n \"name\": \"reborn-ui\",\r\n \"version\": \"0.1.5\",\r\n \"description\": \"A CLI for Reborn UI\",\r\n \"author\": \"1997liuyh-boop\",\r\n \"license\": \"MIT\",\r\n \"repository\": {\r\n \"type\": \"git\",\r\n \"url\": \"https://github.com/1997liuyh-boop/Reborn-UI.git\"\r\n },\r\n \"type\": \"module\",\r\n \"bin\": {\r\n \"reborn-ui\": \"dist/index.js\"\r\n },\r\n \"files\": [\r\n \"dist\",\r\n \"registry\",\r\n \"templates\",\r\n \"README.md\"\r\n ],\r\n \"publishConfig\": {\r\n \"access\": \"public\"\r\n },\r\n \"scripts\": {\r\n \"cli\": \"tsx src/index.ts\",\r\n \"build\": \"tsup\",\r\n \"dev\": \"tsx src/index.ts\",\r\n \"clean\": \"rimraf dist\",\r\n \"prepare\": \"tsup\",\r\n \"registry:build\": \"tsx src/index.ts build --root ../..\",\r\n \"prepack\": \"npm run build && npm run registry:build\",\r\n \"prepublishOnly\": \"npm run build && npm run registry:build\"\r\n },\r\n \"dependencies\": {\r\n \"commander\": \"^14.0.0\",\r\n \"execa\": \"^9.6.0\",\r\n \"prompts\": \"^2.4.2\"\r\n },\r\n \"devDependencies\": {\r\n \"@types/node\": \"^22.10.7\",\r\n \"@types/prompts\": \"^2.4.9\",\r\n \"rimraf\": \"^6.0.1\",\r\n \"tsup\": \"^8.5.0\",\r\n \"tsx\": \"^4.20.0\",\r\n \"typescript\": \"^5.8.3\"\r\n }\r\n}"],"mappings":"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","names":["Command","path","fs","path","path","path","fs","path","fs","require","path","path","fs","Command","path","Command","fs","path","fs","Command","prompts","path","fs","fileURLToPath","findNearestPackageRoot","path","fileURLToPath","fs","path","fs","Command","prompts","cfgPath","libUtilsPath","Command"]}
|
|
1
|
+
{"version":3,"sources":["../src/index.ts","../src/commands/add.ts","../src/utils/fs.ts","../src/utils/pm.ts","../src/utils/registry.ts","../src/utils/ui.ts","../src/commands/build.ts","../src/utils/imports.ts","../src/commands/init.ts","../src/utils/templates.ts","../package.json"],"sourcesContent":["import { Command } from \"commander\";\r\nimport { addCommand } from \"./commands/add.js\";\r\nimport { buildCommand } from \"./commands/build.js\";\r\nimport { initCommand } from \"./commands/init.js\";\r\nimport packageJson from \"../package.json\" assert { type: \"json\" };\r\n\r\nconst program = new Command()\r\n .name(\"reborn-ui\")\r\n .description(\"Reborn UI - 组件安装与 registry 辅助 CLI\")\r\n .version(packageJson.version);\r\n\r\nprogram.addCommand(initCommand());\r\nprogram.addCommand(addCommand());\r\nprogram.addCommand(buildCommand());\r\n\r\nawait program.parseAsync(process.argv);\r\n\r\n\r\n","import path from \"node:path\";\r\nimport { Command } from \"commander\";\r\nimport prompts from \"prompts\";\r\nimport type { PackageManager, RegistryComponent } from \"../types.js\";\r\nimport { ensureDir, pathExists, writeTextFile } from \"../utils/fs.js\";\r\nimport {\r\n detectPackageManager,\r\n readPackageJson,\r\n} from \"../utils/pm.js\";\r\nimport { defaultConfig, loadConfigCompat, loadRegistry } from \"../utils/registry.js\";\r\nimport cliProgress from \"cli-progress\";\r\nimport chalk from \"chalk\";\r\nimport { successLog } from \"../utils/ui.js\";\r\n\r\nfunction rewriteImports(params: {\r\n content: string;\r\n aliasSymbol: string;\r\n}) {\r\n const { content, aliasSymbol } = params;\r\n if (!aliasSymbol || aliasSymbol === \"@\") return content;\r\n\r\n // 仅替换项目根目录映射符号:把 \"@/xxx\" -> \"<aliasSymbol>/xxx\"\r\n // 注意:不要影响 scoped package(@scope/name),这里只替换 \"@/\" 前缀。\r\n return content.replaceAll(\"@/\", `${aliasSymbol}/`);\r\n}\r\n\r\nasync function writeComponentFiles(params: {\r\n cwd: string;\r\n componentsDir: string;\r\n aliasSymbol: string;\r\n component: RegistryComponent;\r\n overwrite?: boolean;\r\n}) {\r\n const { cwd, componentsDir, aliasSymbol, component, overwrite } = params;\r\n const baseDir = path.join(cwd, componentsDir, component.name);\r\n await ensureDir(baseDir);\r\n\r\n for (const f of component.files) {\r\n const target = path.join(baseDir, ...f.path.split(\"/\"));\r\n if (!overwrite && (await pathExists(target))) continue;\r\n const nextContent = rewriteImports({ content: f.content, aliasSymbol });\r\n await writeTextFile(target, nextContent);\r\n }\r\n\r\n return baseDir;\r\n}\r\n\r\nexport function addCommand() {\r\n const cmd = new Command(\"add\")\r\n .description(\"向项目中添加组件与相关依赖\")\r\n .argument(\"[components...]\", \"组件名(可多个)\")\r\n .option(\"--cwd <path>\", \"目标项目目录\", process.cwd())\r\n .option(\"--pm <pm>\", \"包管理器:pnpm|npm|yarn|bun\")\r\n .option(\"--yes\", \"跳过交互\", false)\r\n .option(\"--overwrite\", \"覆盖已存在文件\", false)\r\n .option(\"--config <path>\", \"配置文件路径(相对 cwd)\", \"components.json\")\r\n .option(\"--registry <pkgOrPath>\", \"覆盖配置里的 registry\")\r\n .option(\"--components-dir <path>\", \"覆盖配置里的 componentsDir\")\r\n .option(\"--lib-dir <path>\", \"覆盖配置里的 libDir\")\r\n .option(\"--alias-symbol <symbol>\", \"覆盖配置里的 aliasSymbol(默认 @)\")\r\n .action(async (components: string[], opts) => {\r\n const cwd = path.resolve(opts.cwd);\r\n const pm: PackageManager =\r\n opts.pm ?? (await detectPackageManager(cwd));\r\n\r\n const cfg = (await loadConfigCompat(cwd, opts.config)) ?? defaultConfig();\r\n if (opts.registry) cfg.registry = opts.registry;\r\n if (opts.componentsDir) cfg.componentsDir = opts.componentsDir;\r\n if (opts.libDir) cfg.libDir = opts.libDir;\r\n if (opts.aliasSymbol) cfg.aliasSymbol = opts.aliasSymbol;\r\n\r\n const registry = await loadRegistry({ cwd, registry: cfg.registry });\r\n\r\n let targets = components ?? [];\r\n if (!targets.length) {\r\n if (opts.yes) {\r\n throw new Error(\"未指定组件名;请传入组件参数或去掉 --yes 以交互选择。\");\r\n }\r\n const choices = registry.components.map((c) => ({\r\n title: c.name,\r\n value: c.name,\r\n }));\r\n const res = await prompts(\r\n [\r\n {\r\n type: \"multiselect\",\r\n name: \"selected\",\r\n message: \"选择要添加的组件\",\r\n choices,\r\n min: 1,\r\n },\r\n ],\r\n {\r\n onCancel: () => {\r\n throw new Error(\"已取消\");\r\n },\r\n },\r\n );\r\n targets = res.selected ?? [];\r\n }\r\n\r\n const bar = new cliProgress.SingleBar({\r\n format: '正在添加组件 |' + chalk.cyan('{bar}') + '| {percentage}% || {value}/{total} 组件',\r\n barCompleteChar: '\\u2588',\r\n barIncompleteChar: '\\u2591',\r\n hideCursor: true\r\n });\r\n\r\n bar.start(targets.length, 0);\r\n\r\n for (const name of targets) {\r\n const c = registry.components.find((x) => x.name === name);\r\n if (!c) {\r\n bar.stop();\r\n throw new Error(`registry 中不存在该组件:${name}`);\r\n }\r\n\r\n await writeComponentFiles({\r\n cwd,\r\n componentsDir: cfg.componentsDir,\r\n aliasSymbol: cfg.aliasSymbol ?? \"@\",\r\n component: c,\r\n overwrite: opts.overwrite,\r\n });\r\n\r\n bar.increment();\r\n }\r\n bar.stop();\r\n\r\n console.log(\"\");\r\n for (const name of targets) {\r\n successLog(`组件 ${chalk.bold(name)} 已成功添加到项目`);\r\n }\r\n\r\n // eslint-disable-next-line no-console\r\n console.log(`\\n${chalk.bold.green('DONE')} 已完成 ${targets.length} 个组件的添加(pm=${pm})`);\r\n });\r\n\r\n return cmd;\r\n}\r\n\r\n\r\n","import { createHash } from \"node:crypto\";\nimport fs from \"node:fs/promises\";\nimport path from \"node:path\";\n\nexport async function pathExists(p: string) {\n try {\n await fs.access(p);\n return true;\n } catch {\n return false;\n }\n}\n\nexport async function ensureDir(dirPath: string) {\n await fs.mkdir(dirPath, { recursive: true });\n}\n\nexport async function readJsonFile<T>(filePath: string): Promise<T> {\n const raw = await fs.readFile(filePath, \"utf8\");\n return JSON.parse(raw) as T;\n}\n\nexport async function writeJsonFile(filePath: string, data: unknown) {\n await ensureDir(path.dirname(filePath));\n await fs.writeFile(filePath, JSON.stringify(data, null, 2) + \"\\n\", \"utf8\");\n}\n\nexport async function writeTextFile(filePath: string, content: string) {\n await ensureDir(path.dirname(filePath));\n await fs.writeFile(filePath, content, \"utf8\");\n}\n\nexport async function listFilesRecursive(\n dirPath: string,\n opts?: { ignoreDirNames?: Set<string> },\n) {\n const ignoreDirNames =\n opts?.ignoreDirNames ??\n new Set([\"node_modules\", \".git\", \".nuxt\", \"dist\", \".output\"]);\n\n const out: string[] = [];\n\n async function walk(current: string) {\n const entries = await fs.readdir(current, { withFileTypes: true });\n for (const entry of entries) {\n const p = path.join(current, entry.name);\n if (entry.isDirectory()) {\n if (ignoreDirNames.has(entry.name)) continue;\n await walk(p);\n } else if (entry.isFile()) {\n out.push(p);\n }\n }\n }\n\n await walk(dirPath);\n return out;\n}\n\nexport async function copyDirRecursive(params: {\n fromDir: string;\n toDir: string;\n overwrite?: boolean;\n ignoreFileNames?: Set<string>;\n}) {\n const { fromDir, toDir, overwrite } = params;\n const ignoreFileNames = params.ignoreFileNames ?? new Set([\".DS_Store\"]);\n\n const entries = await fs.readdir(fromDir, { withFileTypes: true });\n await ensureDir(toDir);\n\n for (const entry of entries) {\n if (ignoreFileNames.has(entry.name)) continue;\n const from = path.join(fromDir, entry.name);\n const to = path.join(toDir, entry.name);\n\n if (entry.isDirectory()) {\n await copyDirRecursive({ fromDir: from, toDir: to, overwrite, ignoreFileNames });\n continue;\n }\n\n if (!entry.isFile()) continue;\n\n if (!overwrite) {\n try {\n await fs.access(to);\n continue; // 已存在则跳过\n } catch {\n // not exists\n }\n }\n\n await ensureDir(path.dirname(to));\n await fs.copyFile(from, to);\n }\n}\n\nexport function sha1(text: string) {\n return createHash(\"sha1\").update(text).digest(\"hex\");\n}\n\n\n","import fs from \"node:fs/promises\";\r\nimport path from \"node:path\";\r\nimport { execa } from \"execa\";\r\nimport type { PackageManager } from \"../types.js\";\r\nimport { pathExists, readJsonFile, writeJsonFile } from \"./fs.js\";\r\n\r\nexport async function detectPackageManager(cwd: string): Promise<PackageManager> {\r\n if (await pathExists(path.join(cwd, \"pnpm-lock.yaml\"))) return \"pnpm\";\r\n if (await pathExists(path.join(cwd, \"yarn.lock\"))) return \"yarn\";\r\n if (await pathExists(path.join(cwd, \"package-lock.json\"))) return \"npm\";\r\n if (await pathExists(path.join(cwd, \"bun.lockb\"))) return \"bun\";\r\n return \"pnpm\";\r\n}\r\n\r\nexport async function readPackageJson(\r\n cwd: string,\r\n): Promise<Record<string, any> & { dependencies?: Record<string, string>; devDependencies?: Record<string, string> }> {\r\n return await readJsonFile(path.join(cwd, \"package.json\"));\r\n}\r\n\r\nexport async function writePackageJson(cwd: string, pkg: unknown) {\r\n await writeJsonFile(path.join(cwd, \"package.json\"), pkg);\r\n}\r\n\r\nexport function getMissingDeps(\r\n pkg: { dependencies?: Record<string, string>; devDependencies?: Record<string, string> },\r\n deps: string[],\r\n) {\r\n const existing = new Set([\r\n ...Object.keys(pkg.dependencies ?? {}),\r\n ...Object.keys(pkg.devDependencies ?? {}),\r\n ]);\r\n return deps.filter((d) => !existing.has(d));\r\n}\r\n\r\nexport async function installDeps(params: {\r\n cwd: string;\r\n pm: PackageManager;\r\n deps: string[];\r\n dev?: boolean;\r\n}) {\r\n const { cwd, pm, deps, dev } = params;\r\n if (!deps.length) return;\r\n\r\n const args: string[] = [];\r\n if (pm === \"pnpm\") args.push(\"add\");\r\n else if (pm === \"npm\") args.push(\"install\");\r\n else if (pm === \"yarn\") args.push(\"add\");\r\n else if (pm === \"bun\") args.push(\"add\");\r\n\r\n if (dev) {\r\n if (pm === \"npm\") args.push(\"--save-dev\");\r\n else args.push(\"-D\");\r\n }\r\n\r\n args.push(...deps);\r\n\r\n await execa(pm, args, { cwd, stdio: \"inherit\" });\r\n}\r\n\r\nexport async function ensureJsonFile(cwd: string, relPath: string, defaultJson: unknown) {\r\n const p = path.join(cwd, relPath);\r\n if (await pathExists(p)) return;\r\n await fs.mkdir(path.dirname(p), { recursive: true });\r\n await fs.writeFile(p, JSON.stringify(defaultJson, null, 2) + \"\\n\", \"utf8\");\r\n}\r\n\r\n\r\n","import path from \"node:path\";\nimport fs from \"node:fs\";\nimport { createRequire } from \"node:module\";\nimport { fileURLToPath } from \"node:url\";\nimport type { CliConfig, RegistryFile } from \"../types.js\";\nimport { pathExists, readJsonFile } from \"./fs.js\";\n\nexport const DEFAULT_CONFIG_PATH = \"components.json\";\n\nfunction findNearestPackageRoot(from: string) {\n // from: import.meta.url\n let dir = path.dirname(fileURLToPath(from));\n while (true) {\n if (fs.existsSync(path.join(dir, \"package.json\"))) return dir;\n const parent = path.dirname(dir);\n if (parent === dir) return dir;\n dir = parent;\n }\n}\n\nexport function defaultConfig(): CliConfig {\n return {\n schemaVersion: 1,\n componentsDir: \"components\",\n libDir: \"lib\",\n composablesDir: \"composables\",\n // 默认使用 CLI 包内置的 registry(随 reborn-ui 一起发布)\n registry: \"builtin\",\n // 项目根目录映射别名符号(默认 @)\n aliasSymbol: \"@\",\n };\n}\n\nexport async function loadConfig(cwd: string, configPath = DEFAULT_CONFIG_PATH) {\n const abs = path.isAbsolute(configPath)\n ? configPath\n : path.join(cwd, configPath);\n if (!(await pathExists(abs))) return null;\n return await readJsonFile<CliConfig>(abs);\n}\n\nexport function resolveRegistryJsonPath(params: { cwd: string; registry: string }) {\n const { cwd, registry } = params;\n\n // 0) 内置 registry\n if (!registry || registry === \"builtin\") {\n // 注意:CLI 经过打包后可能变成单文件(例如 dist/index.js),\n // import.meta.url 的相对基准会变化,不能用固定的 ../../registry/...\n // 这里通过向上查找最近的 package.json 来定位包根目录。\n const pkgRoot = findNearestPackageRoot(import.meta.url);\n return path.join(pkgRoot, \"registry\", \"registry.json\");\n }\n\n // 1) 如果是文件路径(包含分隔符或 .json),优先当成路径处理\n const looksLikePath =\n registry.includes(\"/\") ||\n registry.includes(\"\\\\\") ||\n registry.endsWith(\".json\");\n\n if (looksLikePath) {\n const abs = path.isAbsolute(registry) ? registry : path.join(cwd, registry);\n return abs;\n }\n\n // 2) 当成包名处理:默认读取 <pkg>/registry/registry.json\n const require = createRequire(import.meta.url);\n // 不显式绑定 cwd,避免 npx 场景下找不到 registry 包\n return require.resolve(`${registry}/registry/registry.json`);\n}\n\nexport async function loadRegistry(params: { cwd: string; registry: string }) {\n const jsonPath = resolveRegistryJsonPath(params);\n return await readJsonFile<RegistryFile>(jsonPath);\n}\n\n// 兼容旧配置文件名:shadcn-docs.json\nexport async function loadConfigCompat(cwd: string, configPath?: string) {\n if (configPath) return await loadConfig(cwd, configPath);\n const primary = await loadConfig(cwd, DEFAULT_CONFIG_PATH);\n if (primary) return primary;\n return await loadConfig(cwd, \"shadcn-docs.json\");\n}\n\n\n","import chalk from 'chalk';\r\n\r\n/**\r\n * 模拟打字机效果\r\n * @param text 要显示的文本\r\n * @param delay 每字符延迟时间 (ms)\r\n */\r\nexport async function typewriter(text: string, delay: number = 30) {\r\n for (const char of text) {\r\n process.stdout.write(char);\r\n await new Promise((resolve) => setTimeout(resolve, delay));\r\n }\r\n process.stdout.write('\\n');\r\n}\r\n\r\n/**\r\n * 带有样式的成功提示\r\n */\r\nexport function successLog(message: string) {\r\n console.log(`${chalk.green('✔')} ${message}`);\r\n}\r\n\r\n/**\r\n * 带有样式的警告提示\r\n */\r\nexport function warnLog(message: string) {\r\n console.log(`${chalk.yellow('⚠')} ${message}`);\r\n}\r\n\r\n/**\r\n * 带有样式的错误提示\r\n */\r\nexport function errorLog(message: string) {\r\n console.log(`${chalk.red('✘')} ${message}`);\r\n}\r\n\r\n/**\r\n * 渐变色文本 (简单模拟,不依赖第三方复杂渐变库)\r\n */\r\nexport function gradientText(text: string) {\r\n const colors = [\r\n chalk.hex('#FF0080'),\r\n chalk.hex('#FF8C00'),\r\n chalk.hex('#40E0D0'),\r\n chalk.hex('#0080FF'),\r\n chalk.hex('#7B68EE'),\r\n ];\r\n\r\n let result = '';\r\n for (let i = 0; i < text.length; i++) {\r\n const color = colors[i % colors.length];\r\n result += color!(text[i]);\r\n }\r\n return result;\r\n}\r\n","import path from \"node:path\";\r\nimport fs from \"node:fs/promises\";\r\nimport fssync from \"node:fs\";\r\nimport { Command } from \"commander\";\r\nimport type { RegistryComponent, RegistryFile } from \"../types.js\";\r\nimport { listFilesRecursive, sha1, writeJsonFile } from \"../utils/fs.js\";\r\nimport { extractNpmDependenciesFromText } from \"../utils/imports.js\";\r\n\r\nfunction isAllowedFile(filePath: string) {\r\n const ext = path.extname(filePath).toLowerCase();\r\n return [\r\n \".vue\",\r\n \".ts\",\r\n \".js\",\r\n \".json\",\r\n \".css\",\r\n \".md\",\r\n \".svg\",\r\n ].includes(ext);\r\n}\r\n\r\nfunction findWorkspaceRoot(startDir: string) {\r\n let current = path.resolve(startDir);\r\n for (;;) {\r\n const marker = path.join(current, \"pnpm-workspace.yaml\");\r\n if (fssync.existsSync(marker)) return current;\r\n const parent = path.dirname(current);\r\n if (parent === current) return startDir;\r\n current = parent;\r\n }\r\n}\r\n\r\nexport function buildCommand() {\r\n const cmd = new Command(\"build\")\r\n .description(\"(内部)扫描组件源码并生成 registry JSON\")\r\n .option(\"--root <path>\", \"仓库根目录(默认自动向上查找 pnpm-workspace.yaml)\")\r\n .option(\r\n \"--source <path>\",\r\n \"组件源码目录(相对 root)\",\r\n \"components/content/reborn\",\r\n )\r\n .option(\r\n \"--out <path>\",\r\n \"输出 registry.json 路径(相对 root)\",\r\n \"packages/cli/registry/registry.json\",\r\n )\r\n .option(\r\n \"--also-out <path>\",\r\n \"额外再输出一份 registry.json(可重复传参)\",\r\n (val, acc: string[]) => {\r\n acc.push(val);\r\n return acc;\r\n },\r\n [],\r\n )\r\n .action(async (opts) => {\r\n const rootDir = opts.root\r\n ? path.resolve(opts.root)\r\n : findWorkspaceRoot(process.cwd());\r\n const sourceDir = path.join(rootDir, opts.source);\r\n const outPath = path.join(rootDir, opts.out);\r\n const alsoOutPaths: string[] = (opts.alsoOut ?? []).map((p: string) =>\r\n path.join(rootDir, p),\r\n );\r\n\r\n const dirents = await fs.readdir(sourceDir, { withFileTypes: true });\r\n const componentDirs = dirents\r\n .filter((d) => d.isDirectory())\r\n .map((d) => path.join(sourceDir, d.name))\r\n .sort((a, b) => a.localeCompare(b));\r\n\r\n const components: RegistryComponent[] = [];\r\n\r\n for (const absComponentDir of componentDirs) {\r\n const name = path.basename(absComponentDir);\r\n const absFiles = (await listFilesRecursive(absComponentDir)).filter(\r\n isAllowedFile,\r\n );\r\n\r\n const files: RegistryComponent[\"files\"] = [];\r\n const depSet = new Set<string>();\r\n\r\n for (const absFile of absFiles) {\r\n const rel = path\r\n .relative(absComponentDir, absFile)\r\n .split(path.sep)\r\n .join(\"/\");\r\n const content = await fs.readFile(absFile, \"utf8\");\r\n files.push({ path: rel, content });\r\n\r\n // 只从代码文件里抽依赖\r\n const ext = path.extname(absFile).toLowerCase();\r\n if (ext === \".ts\" || ext === \".js\" || ext === \".vue\") {\r\n for (const dep of extractNpmDependenciesFromText(content)) {\r\n depSet.add(dep);\r\n }\r\n }\r\n }\r\n\r\n components.push({\r\n name,\r\n dependencies: [...depSet].sort(),\r\n files,\r\n });\r\n }\r\n\r\n const registry: RegistryFile = {\r\n schemaVersion: 1,\r\n generatedAt: new Date().toISOString(),\r\n source: {\r\n rootDir: rootDir.split(path.sep).join(\"/\"),\r\n componentsDir: opts.source,\r\n },\r\n components,\r\n };\r\n\r\n async function writeOut(targetRegistryPath: string) {\r\n const outComponentsDir = path.join(\r\n path.dirname(targetRegistryPath),\r\n \"components\",\r\n );\r\n await writeJsonFile(targetRegistryPath, registry);\r\n\r\n // 额外输出每个组件的 json,方便调试/按需读取\r\n await fs.mkdir(outComponentsDir, { recursive: true });\r\n for (const c of components) {\r\n await writeJsonFile(\r\n path.join(outComponentsDir, `${c.name}.json`),\r\n {\r\n ...c,\r\n fileCount: c.files.length,\r\n contentHash: sha1(JSON.stringify(c.files.map((f) => f.content))),\r\n },\r\n );\r\n }\r\n }\r\n\r\n await writeOut(outPath);\r\n for (const p of alsoOutPaths) await writeOut(p);\r\n\r\n // eslint-disable-next-line no-console\r\n console.log(\r\n `registry 已生成:${path.relative(process.cwd(), outPath)}(${components.length} 个组件)`,\r\n );\r\n });\r\n\r\n return cmd;\r\n}\r\n\r\n\r\n","const IMPORT_RE =\r\n /\\bfrom\\s+[\"']([^\"']+)[\"']|\\bimport\\(\\s*[\"']([^\"']+)[\"']\\s*\\)|\\brequire\\(\\s*[\"']([^\"']+)[\"']\\s*\\)/g;\r\n\r\nfunction normalizePackageName(specifier: string) {\r\n // ignore relative/alias/virtual\r\n if (\r\n specifier.startsWith(\".\") ||\r\n specifier.startsWith(\"/\") ||\r\n specifier.startsWith(\"@/\") ||\r\n specifier.startsWith(\"~/\") ||\r\n specifier.startsWith(\"#\") ||\r\n specifier.startsWith(\"virtual:\")\r\n ) {\r\n return null;\r\n }\r\n\r\n // scoped package: @scope/name[/...]\r\n if (specifier.startsWith(\"@\")) {\r\n const parts = specifier.split(\"/\");\r\n if (parts.length >= 2) return `${parts[0]}/${parts[1]}`;\r\n return specifier;\r\n }\r\n\r\n // normal package: name[/...]\r\n return specifier.split(\"/\")[0] ?? null;\r\n}\r\n\r\nexport function extractNpmDependenciesFromText(text: string) {\r\n const out = new Set<string>();\r\n\r\n for (const match of text.matchAll(IMPORT_RE)) {\r\n const spec = match[1] ?? match[2] ?? match[3];\r\n if (!spec) continue;\r\n const pkg = normalizePackageName(spec);\r\n if (!pkg) continue;\r\n out.add(pkg);\r\n }\r\n\r\n // 常见“框架自带/不应自动安装”的虚拟模块\r\n out.delete(\"nuxt\");\r\n out.delete(\"vue\");\r\n\r\n return [...out].sort();\r\n}\r\n\r\n\r\n","import path from \"node:path\";\r\nimport fs from \"node:fs/promises\";\r\nimport { Command } from \"commander\";\r\nimport prompts from \"prompts\";\r\nimport type { CliConfig, PackageManager } from \"../types.js\";\r\nimport { ensureDir, listFilesRecursive, pathExists, writeJsonFile, writeTextFile } from \"../utils/fs.js\";\r\nimport { detectPackageManager, readPackageJson } from \"../utils/pm.js\";\r\nimport { DEFAULT_CONFIG_PATH, defaultConfig, loadConfigCompat } from \"../utils/registry.js\";\r\nimport { copyTemplateSubdir } from \"../utils/templates.js\";\r\nimport { gradientText, typewriter } from \"../utils/ui.js\";\r\n\r\nfunction looksLikeNuxtProject(cwd: string) {\r\n return Promise.all([\r\n pathExists(path.join(cwd, \"nuxt.config.ts\")),\r\n pathExists(path.join(cwd, \"nuxt.config.js\")),\r\n pathExists(path.join(cwd, \"nuxt.config.mjs\")),\r\n ]).then((arr) => arr.some(Boolean));\r\n}\r\n\r\n\r\n// function makeDefaultTailwindConfig removed in favor of template file\r\n\r\n\r\n\r\n\r\nfunction cnUtilsTs(params: { importPath?: string }) {\r\n // importPath 预留:如果用户想从别处导入 clsx/twMerge\r\n void params;\r\n return `import { type ClassValue, clsx } from \"clsx\";\\nimport { twMerge } from \"tailwind-merge\";\\n\\nexport function cn(...inputs: ClassValue[]) {\\n return twMerge(clsx(inputs));\\n}\\n`;\r\n}\r\n\r\nasync function rewriteAliasInDir(params: {\r\n cwd: string;\r\n targetDir: string;\r\n aliasSymbol: string;\r\n}) {\r\n const { cwd, targetDir, aliasSymbol } = params;\r\n if (!aliasSymbol || aliasSymbol === \"@\") return;\r\n const absDir = path.join(cwd, targetDir);\r\n if (!(await pathExists(absDir))) return;\r\n\r\n const files = await listFilesRecursive(absDir);\r\n for (const f of files) {\r\n const ext = path.extname(f).toLowerCase();\r\n // 只处理常见文本文件,避免误改二进制\r\n if (![\".ts\", \".tsx\", \".js\", \".jsx\", \".vue\", \".mjs\", \".cjs\"].includes(ext)) continue;\r\n const raw = await fs.readFile(f, \"utf8\");\r\n const next = raw.replaceAll(\"@/\", `${aliasSymbol}/`);\r\n if (next !== raw) await fs.writeFile(f, next, \"utf8\");\r\n }\r\n}\r\n\r\nexport function initCommand() {\r\n const cmd = new Command(\"init\")\r\n .description(\"初始化新项目\")\r\n .option(\"--cwd <path>\", \"目标项目目录\", process.cwd())\r\n .option(\"--pm <pm>\", \"包管理器:pnpm|npm|yarn|bun\")\r\n .option(\"--yes\", \"跳过交互,使用默认值\", false)\r\n .option(\"--overwrite\", \"覆盖已存在的模板文件(lib/composables)\", false)\r\n .option(\r\n \"--config <path>\",\r\n \"配置文件路径(相对 cwd)\",\r\n DEFAULT_CONFIG_PATH,\r\n )\r\n .option(\r\n \"--components-dir <path>\",\r\n \"组件写入目录\",\r\n defaultConfig().componentsDir,\r\n )\r\n .option(\r\n \"--lib-dir <path>\",\r\n \"lib 目录(cn/utils)\",\r\n defaultConfig().libDir,\r\n )\r\n .option(\r\n \"--composables-dir <path>\",\r\n \"composables 目录\",\r\n defaultConfig().composablesDir,\r\n )\r\n .option(\r\n \"--alias-symbol <symbol>\",\r\n \"项目根目录映射别名符号(默认 @)\",\r\n defaultConfig().aliasSymbol,\r\n )\r\n .option(\"--registry <pkgOrPath>\", \"registry 来源(默认 builtin)\", defaultConfig().registry)\r\n .action(async (opts) => {\r\n const cwd = path.resolve(opts.cwd);\r\n\r\n // eslint-disable-next-line no-console\r\n console.log(\r\n \"提示:项目中有部分依赖需要使用@/ 路径进行配置,请您安装到项目中配置好的路径下,请慎重选择文件位置\",\r\n );\r\n\r\n const pkgPath = path.join(cwd, \"package.json\");\r\n if (!(await pathExists(pkgPath))) {\r\n throw new Error(`未找到 package.json:${pkgPath}`);\r\n }\r\n\r\n const pm: PackageManager =\r\n opts.pm ?? (await detectPackageManager(cwd));\r\n\r\n const cfg: CliConfig = {\r\n schemaVersion: 1,\r\n componentsDir: opts.componentsDir,\r\n libDir: opts.libDir,\r\n composablesDir: opts.composablesDir,\r\n aliasSymbol: opts.aliasSymbol,\r\n registry: opts.registry,\r\n };\r\n\r\n // 如果已存在 components.json,默认沿用(除非用户显式传参覆盖)\r\n const existing = await loadConfigCompat(cwd);\r\n if (existing) {\r\n cfg.componentsDir = opts.componentsDir ?? existing.componentsDir ?? cfg.componentsDir;\r\n cfg.libDir = opts.libDir ?? existing.libDir ?? cfg.libDir;\r\n cfg.composablesDir = opts.composablesDir ?? existing.composablesDir ?? cfg.composablesDir;\r\n cfg.aliasSymbol = opts.aliasSymbol ?? existing.aliasSymbol ?? cfg.aliasSymbol;\r\n cfg.registry = opts.registry ?? existing.registry ?? cfg.registry;\r\n }\r\n\r\n if (!opts.yes) {\r\n const nuxt = await looksLikeNuxtProject(cwd);\r\n const res = await prompts(\r\n [\r\n {\r\n type: \"text\",\r\n name: \"componentsDir\",\r\n message: \"组件目录(componentsDir)\",\r\n initial: cfg.componentsDir,\r\n },\r\n {\r\n type: \"text\",\r\n name: \"libDir\",\r\n message: \"lib 目录(libDir,用于 cn/utils)\",\r\n initial: cfg.libDir,\r\n },\r\n {\r\n type: \"text\",\r\n name: \"composablesDir\",\r\n message: \"composables 目录(composablesDir)\",\r\n initial: cfg.composablesDir,\r\n },\r\n {\r\n type: \"text\",\r\n name: \"aliasSymbol\",\r\n message: \"基于项目根目录的“映射”的符号是?(aliasSymbol)\",\r\n initial: cfg.aliasSymbol ?? \"@\",\r\n },\r\n ],\r\n {\r\n onCancel: () => {\r\n throw new Error(\"已取消\");\r\n },\r\n },\r\n );\r\n\r\n cfg.componentsDir = res.componentsDir ?? cfg.componentsDir;\r\n cfg.libDir = res.libDir ?? cfg.libDir;\r\n cfg.composablesDir = res.composablesDir ?? cfg.composablesDir;\r\n cfg.aliasSymbol = res.aliasSymbol ?? cfg.aliasSymbol;\r\n\r\n // 写配置\r\n const cfgPath = path.join(cwd, opts.config);\r\n await writeJsonFile(cfgPath, cfg);\r\n\r\n // 复制模板:lib/ + composables/\r\n await copyTemplateSubdir({\r\n subdir: \"lib\",\r\n cwd,\r\n targetDir: cfg.libDir,\r\n overwrite: opts.overwrite,\r\n });\r\n await copyTemplateSubdir({\r\n subdir: \"composables\",\r\n cwd,\r\n targetDir: cfg.composablesDir,\r\n overwrite: opts.overwrite,\r\n });\r\n // 仅替换 \"@/...\" 的别名符号,不改其它路径内容\r\n await rewriteAliasInDir({ cwd, targetDir: cfg.libDir, aliasSymbol: cfg.aliasSymbol ?? \"@\" });\r\n await rewriteAliasInDir({\r\n cwd,\r\n targetDir: cfg.composablesDir,\r\n aliasSymbol: cfg.aliasSymbol ?? \"@\",\r\n });\r\n\r\n // 兜底:如果用户模板里没有 utils.ts,则生成 cn\r\n const libUtilsPath = path.join(cwd, cfg.libDir, \"utils.ts\");\r\n if (!(await pathExists(libUtilsPath))) await writeTextFile(libUtilsPath, cnUtilsTs({}));\r\n\r\n // eslint-disable-next-line no-console\r\n console.log(`已写入配置:${path.relative(process.cwd(), cfgPath)};并生成 cn/utils(pm=${pm})`);\r\n console.log(\"请按照 https://tw.icebreaker.top/docs/quick-start/v4/uni-app-vite 指引进行项目配置初始化\");\r\n\r\n console.log(\"\");\r\n await typewriter(gradientText(\"感谢使用 Reborn UI ! ✨\"), 50);\r\n return;\r\n }\r\n\r\n // --yes:直接写默认配置\r\n const cfgPath = path.join(cwd, opts.config);\r\n await ensureDir(path.dirname(cfgPath));\r\n await fs.writeFile(cfgPath, JSON.stringify(cfg, null, 2) + \"\\n\", \"utf8\");\r\n\r\n // 复制模板:lib/ + composables/\r\n await copyTemplateSubdir({\r\n subdir: \"lib\",\r\n cwd,\r\n targetDir: cfg.libDir,\r\n overwrite: opts.overwrite,\r\n });\r\n await copyTemplateSubdir({\r\n subdir: \"composables\",\r\n cwd,\r\n targetDir: cfg.composablesDir,\r\n overwrite: opts.overwrite,\r\n });\r\n // 仅替换 \"@/...\" 的别名符号,不改其它路径内容\r\n await rewriteAliasInDir({ cwd, targetDir: cfg.libDir, aliasSymbol: cfg.aliasSymbol ?? \"@\" });\r\n await rewriteAliasInDir({\r\n cwd,\r\n targetDir: cfg.composablesDir,\r\n aliasSymbol: cfg.aliasSymbol ?? \"@\",\r\n });\r\n\r\n // 兜底:如果用户模板里没有 utils.ts,则生成 cn\r\n const libUtilsPath = path.join(cwd, cfg.libDir, \"utils.ts\");\r\n if (!(await pathExists(libUtilsPath))) await writeTextFile(libUtilsPath, cnUtilsTs({}));\r\n\r\n // eslint-disable-next-line no-console\r\n console.log(`已初始化:${path.relative(process.cwd(), cfgPath)};并生成 cn/utils(pm=${pm})`);\r\n console.log(\"请按照 https://tw.icebreaker.top/docs/quick-start/v4/uni-app-vite 指引进行项目配置初始化\");\r\n\r\n console.log(\"\");\r\n await typewriter(gradientText(\"感谢使用 Reborn UI ! ✨\"), 50);\r\n });\r\n\r\n return cmd;\r\n}\r\n\r\n\r\n","import path from \"node:path\";\nimport fs from \"node:fs\";\nimport { fileURLToPath } from \"node:url\";\nimport { pathExists } from \"./fs.js\";\nimport { copyDirRecursive } from \"./fs.js\";\n\nfunction findNearestPackageRoot(from: string) {\n // from: import.meta.url\n let dir = path.dirname(fileURLToPath(from));\n while (true) {\n if (fs.existsSync(path.join(dir, \"package.json\"))) return dir;\n const parent = path.dirname(dir);\n if (parent === dir) return dir;\n dir = parent;\n }\n}\n\nexport function getTemplatesRootDir() {\n // 注意:CLI 打包后可能变成单文件(dist/index.js),此时 import.meta.url 的相对基准会变化。\n // 通过向上查找最近的 package.json 来定位包根目录。\n const pkgRoot = findNearestPackageRoot(import.meta.url);\n return path.join(pkgRoot, \"templates\");\n}\n\nexport async function copyTemplateSubdir(params: {\n subdir: \"lib\" | \"composables\";\n cwd: string;\n targetDir: string;\n overwrite?: boolean;\n}) {\n const templatesRoot = getTemplatesRootDir();\n const fromDir = path.join(templatesRoot, params.subdir);\n if (!(await pathExists(fromDir))) return false;\n\n const toDir = path.join(params.cwd, params.targetDir);\n await copyDirRecursive({ fromDir, toDir, overwrite: params.overwrite });\n return true;\n}\n\n\n\n\n\n\n","{\n \"name\": \"reborn-ui\",\n \"version\": \"0.1.6\",\n \"description\": \"A CLI for Reborn UI\",\n \"author\": \"1997liuyh-boop\",\n \"license\": \"MIT\",\n \"repository\": {\n \"type\": \"git\",\n \"url\": \"https://github.com/1997liuyh-boop/Reborn-UI.git\"\n },\n \"type\": \"module\",\n \"bin\": {\n \"reborn-ui\": \"dist/index.js\"\n },\n \"files\": [\n \"dist\",\n \"registry\",\n \"templates\",\n \"README.md\"\n ],\n \"publishConfig\": {\n \"access\": \"public\"\n },\n \"scripts\": {\n \"cli\": \"tsx src/index.ts\",\n \"build\": \"tsup\",\n \"dev\": \"tsx src/index.ts\",\n \"clean\": \"rimraf dist\",\n \"prepare\": \"tsup\",\n \"registry:build\": \"tsx src/index.ts build --root ../..\",\n \"prepack\": \"npm run build && npm run registry:build\",\n \"prepublishOnly\": \"npm run build && npm run registry:build\"\n },\n \"dependencies\": {\n \"chalk\": \"^5.6.2\",\n \"cli-progress\": \"^3.12.0\",\n \"commander\": \"^14.0.0\",\n \"execa\": \"^9.6.0\",\n \"ora\": \"^9.0.0\",\n \"prompts\": \"^2.4.2\"\n },\n \"devDependencies\": {\n \"@types/cli-progress\": \"^3.11.6\",\n \"@types/node\": \"^22.10.7\",\n \"@types/prompts\": \"^2.4.9\",\n \"rimraf\": \"^6.0.1\",\n \"tsup\": \"^8.5.0\",\n \"tsx\": \"^4.20.0\",\n \"typescript\": \"^5.8.3\"\n }\n}"],"mappings":"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","names":["Command","path","fs","path","path","path","fs","path","fs","require","chalk","path","chalk","path","fs","Command","path","Command","fs","path","fs","Command","prompts","path","fs","fileURLToPath","findNearestPackageRoot","path","fileURLToPath","fs","path","fs","Command","prompts","cfgPath","libUtilsPath","Command"]}
|
package/package.json
CHANGED
|
@@ -1,47 +1,51 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "reborn-ui",
|
|
3
|
-
"version": "0.1.
|
|
4
|
-
"description": "A CLI for Reborn UI",
|
|
5
|
-
"author": "1997liuyh-boop",
|
|
6
|
-
"license": "MIT",
|
|
7
|
-
"repository": {
|
|
8
|
-
"type": "git",
|
|
9
|
-
"url": "https://github.com/1997liuyh-boop/Reborn-UI.git"
|
|
10
|
-
},
|
|
11
|
-
"type": "module",
|
|
12
|
-
"bin": {
|
|
13
|
-
"reborn-ui": "dist/index.js"
|
|
14
|
-
},
|
|
15
|
-
"files": [
|
|
16
|
-
"dist",
|
|
17
|
-
"registry",
|
|
18
|
-
"templates",
|
|
19
|
-
"README.md"
|
|
20
|
-
],
|
|
21
|
-
"publishConfig": {
|
|
22
|
-
"access": "public"
|
|
23
|
-
},
|
|
24
|
-
"scripts": {
|
|
25
|
-
"cli": "tsx src/index.ts",
|
|
26
|
-
"build": "tsup",
|
|
27
|
-
"dev": "tsx src/index.ts",
|
|
28
|
-
"clean": "rimraf dist",
|
|
29
|
-
"prepare": "tsup",
|
|
30
|
-
"registry:build": "tsx src/index.ts build --root ../..",
|
|
31
|
-
"prepack": "npm run build && npm run registry:build",
|
|
32
|
-
"prepublishOnly": "npm run build && npm run registry:build"
|
|
33
|
-
},
|
|
34
|
-
"dependencies": {
|
|
35
|
-
"
|
|
36
|
-
"
|
|
37
|
-
"
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
"
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
"
|
|
44
|
-
"
|
|
45
|
-
"
|
|
46
|
-
|
|
1
|
+
{
|
|
2
|
+
"name": "reborn-ui",
|
|
3
|
+
"version": "0.1.6",
|
|
4
|
+
"description": "A CLI for Reborn UI",
|
|
5
|
+
"author": "1997liuyh-boop",
|
|
6
|
+
"license": "MIT",
|
|
7
|
+
"repository": {
|
|
8
|
+
"type": "git",
|
|
9
|
+
"url": "https://github.com/1997liuyh-boop/Reborn-UI.git"
|
|
10
|
+
},
|
|
11
|
+
"type": "module",
|
|
12
|
+
"bin": {
|
|
13
|
+
"reborn-ui": "dist/index.js"
|
|
14
|
+
},
|
|
15
|
+
"files": [
|
|
16
|
+
"dist",
|
|
17
|
+
"registry",
|
|
18
|
+
"templates",
|
|
19
|
+
"README.md"
|
|
20
|
+
],
|
|
21
|
+
"publishConfig": {
|
|
22
|
+
"access": "public"
|
|
23
|
+
},
|
|
24
|
+
"scripts": {
|
|
25
|
+
"cli": "tsx src/index.ts",
|
|
26
|
+
"build": "tsup",
|
|
27
|
+
"dev": "tsx src/index.ts",
|
|
28
|
+
"clean": "rimraf dist",
|
|
29
|
+
"prepare": "tsup",
|
|
30
|
+
"registry:build": "tsx src/index.ts build --root ../..",
|
|
31
|
+
"prepack": "npm run build && npm run registry:build",
|
|
32
|
+
"prepublishOnly": "npm run build && npm run registry:build"
|
|
33
|
+
},
|
|
34
|
+
"dependencies": {
|
|
35
|
+
"chalk": "^5.6.2",
|
|
36
|
+
"cli-progress": "^3.12.0",
|
|
37
|
+
"commander": "^14.0.0",
|
|
38
|
+
"execa": "^9.6.0",
|
|
39
|
+
"ora": "^9.0.0",
|
|
40
|
+
"prompts": "^2.4.2"
|
|
41
|
+
},
|
|
42
|
+
"devDependencies": {
|
|
43
|
+
"@types/cli-progress": "^3.11.6",
|
|
44
|
+
"@types/node": "^22.10.7",
|
|
45
|
+
"@types/prompts": "^2.4.9",
|
|
46
|
+
"rimraf": "^6.0.1",
|
|
47
|
+
"tsup": "^8.5.0",
|
|
48
|
+
"tsx": "^4.20.0",
|
|
49
|
+
"typescript": "^5.8.3"
|
|
50
|
+
}
|
|
47
51
|
}
|