reborn-ui 0.1.68 → 0.1.71
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 +148 -61
- package/dist/index.js.map +1 -1
- package/package.json +53 -53
- package/registry/registry.json +1 -1
- package/templates/composables/useMouseState.ts +0 -25
- package/templates/lib/utils.ts +0 -14
package/dist/index.js
CHANGED
|
@@ -534,24 +534,103 @@ function buildCommand() {
|
|
|
534
534
|
}
|
|
535
535
|
|
|
536
536
|
// src/commands/init.ts
|
|
537
|
-
import
|
|
538
|
-
import
|
|
537
|
+
import path7 from "path";
|
|
538
|
+
import fs6 from "fs/promises";
|
|
539
539
|
import fssync2 from "fs";
|
|
540
540
|
import { Command as Command3 } from "commander";
|
|
541
541
|
import prompts2 from "prompts";
|
|
542
|
+
|
|
543
|
+
// src/utils/templates.ts
|
|
544
|
+
import path6 from "path";
|
|
545
|
+
import fs5 from "fs";
|
|
546
|
+
import { fileURLToPath as fileURLToPath2 } from "url";
|
|
547
|
+
function findNearestPackageRoot2(from) {
|
|
548
|
+
let dir = path6.dirname(fileURLToPath2(from));
|
|
549
|
+
while (true) {
|
|
550
|
+
if (fs5.existsSync(path6.join(dir, "package.json"))) return dir;
|
|
551
|
+
const parent = path6.dirname(dir);
|
|
552
|
+
if (parent === dir) return dir;
|
|
553
|
+
dir = parent;
|
|
554
|
+
}
|
|
555
|
+
}
|
|
556
|
+
|
|
557
|
+
// src/generated/templates.ts
|
|
558
|
+
var TEMPLATES = {
|
|
559
|
+
"web": {
|
|
560
|
+
"lib/tv.ts": 'import { createTV } from "tailwind-variants";\r\nimport { twMergeConfig } from "./utils";\r\n\r\nexport const tv = createTV({\r\n twMergeConfig,\r\n});\r\nexport type { VariantProps } from "tailwind-variants";\r\n',
|
|
561
|
+
"lib/utils.ts": 'import type { ClassValue } from "clsx";\r\nimport { clsx } from "clsx";\r\nimport { extendTailwindMerge } from "tailwind-merge";\r\n\r\nexport const twMergeConfig = {\r\n extend: {\r\n classGroups: {\r\n "font-size": [{ text: [(value: string) => !isNaN(Number(value))] }],\r\n },\r\n },\r\n};\r\n\r\nconst customTwMerge = extendTailwindMerge(twMergeConfig);\r\n\r\nexport function cn(...inputs: ClassValue[]) {\r\n return customTwMerge(clsx(inputs));\r\n}\r\n\r\nexport type ObjectValues<T> = T[keyof T];\r\n',
|
|
562
|
+
"composables/useFieldGroup.ts": "\r\nimport { ref } from 'vue'\r\n\r\nexport function useFieldGroup(props: any) {\r\n return {\r\n orientation: ref(undefined),\r\n size: ref(undefined)\r\n }\r\n}\r\n",
|
|
563
|
+
"composables/useMouseState.ts": 'import { readonly, ref } from "vue";\r\n\r\nexport function useMouseState() {\r\n const isMouseEntered = ref(false);\r\n\r\n function setMouseEntered(value: boolean) {\r\n isMouseEntered.value = value;\r\n }\r\n\r\n return {\r\n isMouseEntered: readonly(isMouseEntered),\r\n setMouseEntered,\r\n };\r\n}\r\n',
|
|
564
|
+
"composables/useNavigation.ts": `import type { ContentNavigationItem } from "@nuxt/content";\r
|
|
565
|
+
\r
|
|
566
|
+
export function useNavigation(navigation?: Ref<ContentNavigationItem[]>) {\r
|
|
567
|
+
const route = useRoute();\r
|
|
568
|
+
\r
|
|
569
|
+
const children = computed(() => {\r
|
|
570
|
+
const nav = toValue(navigation);\r
|
|
571
|
+
\r
|
|
572
|
+
// Get the current path segments\r
|
|
573
|
+
const pathSegments = route.path.split("/").filter(Boolean);\r
|
|
574
|
+
\r
|
|
575
|
+
// Need at least one section (e.g., ['components', 'button'])\r
|
|
576
|
+
if (pathSegments.length < 1) {\r
|
|
577
|
+
return [];\r
|
|
578
|
+
}\r
|
|
579
|
+
\r
|
|
580
|
+
// Build the top parent path (e.g., '/components')\r
|
|
581
|
+
const topParentPath = \`/\${pathSegments[0]}\`;\r
|
|
582
|
+
\r
|
|
583
|
+
// Find the matching top-level navigation item\r
|
|
584
|
+
const topParent = nav?.find((item) => item.path === topParentPath);\r
|
|
585
|
+
\r
|
|
586
|
+
return topParent?.children || [];\r
|
|
587
|
+
});\r
|
|
588
|
+
\r
|
|
589
|
+
const isFlatList = computed(() => {\r
|
|
590
|
+
return children.value.every((child) => !child.children || child.children.length === 0);\r
|
|
591
|
+
});\r
|
|
592
|
+
\r
|
|
593
|
+
const nav = computed(() => {\r
|
|
594
|
+
if (isFlatList.value) {\r
|
|
595
|
+
return [\r
|
|
596
|
+
{\r
|
|
597
|
+
title: "Overview",\r
|
|
598
|
+
path: children.value.at(0)?.path || "",\r
|
|
599
|
+
children: children.value,\r
|
|
600
|
+
},\r
|
|
601
|
+
];\r
|
|
602
|
+
}\r
|
|
603
|
+
\r
|
|
604
|
+
return children.value;\r
|
|
605
|
+
});\r
|
|
606
|
+
\r
|
|
607
|
+
return {\r
|
|
608
|
+
nav,\r
|
|
609
|
+
};\r
|
|
610
|
+
}\r
|
|
611
|
+
`
|
|
612
|
+
},
|
|
613
|
+
"uniapp": {
|
|
614
|
+
"lib/tv.ts": "// @ts-ignore\r\nimport { create } from '@weapp-tailwindcss/variants-v3'\r\n// @ts-ignore\r\nconst isH5 = process.env.UNI_PLATFORM === 'h5'\r\n\r\nconst { tv } = create({\r\n escape: !isH5,\r\n unescape: !isH5,\r\n})\r\n\r\nexport { tv }\r\n",
|
|
615
|
+
"lib/utils.ts": "import { type ClassValue, clsx } from 'clsx'\r\nimport { create } from '@weapp-tailwindcss/merge-v3'\r\n\r\n// @ts-ignore\r\nconst isH5 = process.env.UNI_PLATFORM === 'h5'\r\nconst { twMerge } = create({\r\n escape: !isH5,\r\n unescape: !isH5,\r\n})\r\n\r\nexport function cn(...inputs: ClassValue[]) {\r\n return twMerge(clsx(inputs))\r\n}\r\n",
|
|
616
|
+
"composables/useFieldGroup.ts": "import { ref } from 'vue'\r\n\r\nexport function useFieldGroup(props?: any) {\r\n return {\r\n disabled: ref(undefined),\r\n orientation: ref(undefined),\r\n size: ref(undefined)\r\n }\r\n}\r\n"
|
|
617
|
+
}
|
|
618
|
+
};
|
|
619
|
+
|
|
620
|
+
// src/commands/init.ts
|
|
542
621
|
function looksLikeNuxtProject(cwd) {
|
|
543
622
|
return Promise.all([
|
|
544
|
-
pathExists(
|
|
545
|
-
pathExists(
|
|
546
|
-
pathExists(
|
|
623
|
+
pathExists(path7.join(cwd, "nuxt.config.ts")),
|
|
624
|
+
pathExists(path7.join(cwd, "nuxt.config.js")),
|
|
625
|
+
pathExists(path7.join(cwd, "nuxt.config.mjs"))
|
|
547
626
|
]).then((arr) => arr.some(Boolean));
|
|
548
627
|
}
|
|
549
628
|
function findWorkspaceRoot2(startDir) {
|
|
550
|
-
let current =
|
|
629
|
+
let current = path7.resolve(startDir);
|
|
551
630
|
for (; ; ) {
|
|
552
|
-
const marker =
|
|
631
|
+
const marker = path7.join(current, "pnpm-workspace.yaml");
|
|
553
632
|
if (fssync2.existsSync(marker)) return current;
|
|
554
|
-
const parent =
|
|
633
|
+
const parent = path7.dirname(current);
|
|
555
634
|
if (parent === current) return startDir;
|
|
556
635
|
current = parent;
|
|
557
636
|
}
|
|
@@ -569,53 +648,61 @@ export function cn(...inputs: ClassValue[]) {
|
|
|
569
648
|
async function rewriteAliasInDir(params) {
|
|
570
649
|
const { cwd, targetDir, aliasSymbol } = params;
|
|
571
650
|
if (!aliasSymbol || aliasSymbol === "@") return;
|
|
572
|
-
const absDir =
|
|
651
|
+
const absDir = path7.join(cwd, targetDir);
|
|
573
652
|
if (!await pathExists(absDir)) return;
|
|
574
653
|
const files = await listFilesRecursive(absDir);
|
|
575
654
|
for (const f of files) {
|
|
576
|
-
const ext =
|
|
655
|
+
const ext = path7.extname(f).toLowerCase();
|
|
577
656
|
if (![".ts", ".tsx", ".js", ".jsx", ".vue", ".mjs", ".cjs"].includes(ext)) continue;
|
|
578
|
-
const raw = await
|
|
657
|
+
const raw = await fs6.readFile(f, "utf8");
|
|
579
658
|
const next = raw.replaceAll("@/", `${aliasSymbol}/`);
|
|
580
|
-
if (next !== raw) await
|
|
659
|
+
if (next !== raw) await fs6.writeFile(f, next, "utf8");
|
|
581
660
|
}
|
|
582
661
|
}
|
|
583
662
|
async function copyTemplates(params) {
|
|
584
663
|
const { cwd, workspaceRoot, platform, cfg, overwrite } = params;
|
|
585
|
-
|
|
586
|
-
|
|
587
|
-
|
|
588
|
-
|
|
589
|
-
|
|
590
|
-
|
|
591
|
-
|
|
592
|
-
|
|
593
|
-
});
|
|
594
|
-
}
|
|
595
|
-
if (await pathExists(uniappComposablesSrc)) {
|
|
596
|
-
await copyDirRecursive({
|
|
597
|
-
fromDir: uniappComposablesSrc,
|
|
598
|
-
toDir: path6.join(cwd, cfg.composablesDir),
|
|
599
|
-
overwrite
|
|
600
|
-
});
|
|
601
|
-
}
|
|
602
|
-
} else {
|
|
603
|
-
const webLibSrc = path6.join(workspaceRoot, "app/lib");
|
|
604
|
-
const webComposablesSrc = path6.join(workspaceRoot, "app/composables");
|
|
605
|
-
if (await pathExists(webLibSrc)) {
|
|
606
|
-
await copyDirRecursive({
|
|
607
|
-
fromDir: webLibSrc,
|
|
608
|
-
toDir: path6.join(cwd, cfg.libDir),
|
|
609
|
-
overwrite
|
|
610
|
-
});
|
|
664
|
+
const repoPaths = {
|
|
665
|
+
web: {
|
|
666
|
+
lib: path7.join(workspaceRoot, "app/lib"),
|
|
667
|
+
composables: path7.join(workspaceRoot, "app/composables")
|
|
668
|
+
},
|
|
669
|
+
uniapp: {
|
|
670
|
+
lib: path7.join(workspaceRoot, "packages/uniapp-project/src/lib"),
|
|
671
|
+
composables: path7.join(workspaceRoot, "packages/uniapp-project/src/composables")
|
|
611
672
|
}
|
|
612
|
-
|
|
613
|
-
|
|
614
|
-
|
|
615
|
-
|
|
616
|
-
|
|
617
|
-
|
|
618
|
-
|
|
673
|
+
};
|
|
674
|
+
const currentRepoPaths = repoPaths[platform];
|
|
675
|
+
let copiedFromRepo = false;
|
|
676
|
+
if (await pathExists(currentRepoPaths.lib)) {
|
|
677
|
+
await copyDirRecursive({
|
|
678
|
+
fromDir: currentRepoPaths.lib,
|
|
679
|
+
toDir: path7.join(cwd, cfg.libDir),
|
|
680
|
+
overwrite
|
|
681
|
+
});
|
|
682
|
+
copiedFromRepo = true;
|
|
683
|
+
}
|
|
684
|
+
if (await pathExists(currentRepoPaths.composables)) {
|
|
685
|
+
await copyDirRecursive({
|
|
686
|
+
fromDir: currentRepoPaths.composables,
|
|
687
|
+
toDir: path7.join(cwd, cfg.composablesDir),
|
|
688
|
+
overwrite,
|
|
689
|
+
ignoreFileNames: platform === "web" ? /* @__PURE__ */ new Set(["useComponentCode.ts", "useCopyToClipboard.ts"]) : void 0
|
|
690
|
+
});
|
|
691
|
+
copiedFromRepo = true;
|
|
692
|
+
}
|
|
693
|
+
if (!copiedFromRepo) {
|
|
694
|
+
const platformTemplates = TEMPLATES[platform];
|
|
695
|
+
for (const [relPath, content] of Object.entries(platformTemplates)) {
|
|
696
|
+
let targetPath = "";
|
|
697
|
+
if (relPath.startsWith("lib/")) {
|
|
698
|
+
targetPath = path7.join(cwd, cfg.libDir, relPath.replace("lib/", ""));
|
|
699
|
+
} else if (relPath.startsWith("composables/")) {
|
|
700
|
+
targetPath = path7.join(cwd, cfg.composablesDir, relPath.replace("composables/", ""));
|
|
701
|
+
}
|
|
702
|
+
if (targetPath) {
|
|
703
|
+
if (!overwrite && await pathExists(targetPath)) continue;
|
|
704
|
+
await writeTextFile(targetPath, content);
|
|
705
|
+
}
|
|
619
706
|
}
|
|
620
707
|
}
|
|
621
708
|
}
|
|
@@ -641,11 +728,11 @@ function initCommand() {
|
|
|
641
728
|
"\u9879\u76EE\u6839\u76EE\u5F55\u6620\u5C04\u522B\u540D\u7B26\u53F7\uFF08\u9ED8\u8BA4 @\uFF09",
|
|
642
729
|
defaultConfig().aliasSymbol
|
|
643
730
|
).option("--platform <platform>", "\u76EE\u6807\u5E73\u53F0\uFF1Aweb|uniapp", "web").option("--registry <pkgOrPath>", "registry \u6765\u6E90\uFF08\u9ED8\u8BA4 builtin\uFF09", defaultConfig().registry).action(async (opts) => {
|
|
644
|
-
const cwd =
|
|
731
|
+
const cwd = path7.resolve(opts.cwd);
|
|
645
732
|
console.log(
|
|
646
733
|
"\u63D0\u793A\uFF1A\u9879\u76EE\u4E2D\u6709\u90E8\u5206\u4F9D\u8D56\u9700\u8981\u4F7F\u7528@/ \u8DEF\u5F84\u8FDB\u884C\u914D\u7F6E\uFF0C\u8BF7\u60A8\u5B89\u88C5\u5230\u9879\u76EE\u4E2D\u914D\u7F6E\u597D\u7684\u8DEF\u5F84\u4E0B\uFF0C\u8BF7\u614E\u91CD\u9009\u62E9\u6587\u4EF6\u4F4D\u7F6E"
|
|
647
734
|
);
|
|
648
|
-
const pkgPath =
|
|
735
|
+
const pkgPath = path7.join(cwd, "package.json");
|
|
649
736
|
if (!await pathExists(pkgPath)) {
|
|
650
737
|
throw new Error(`\u672A\u627E\u5230 package.json\uFF1A${pkgPath}`);
|
|
651
738
|
}
|
|
@@ -718,9 +805,9 @@ function initCommand() {
|
|
|
718
805
|
cfg.libDir = res.libDir ?? cfg.libDir;
|
|
719
806
|
cfg.composablesDir = res.composablesDir ?? cfg.composablesDir;
|
|
720
807
|
cfg.aliasSymbol = res.aliasSymbol ?? cfg.aliasSymbol;
|
|
721
|
-
const cfgPath2 =
|
|
808
|
+
const cfgPath2 = path7.join(cwd, opts.config);
|
|
722
809
|
await writeJsonFile(cfgPath2, cfg);
|
|
723
|
-
const workspaceRoot2 = findWorkspaceRoot2(
|
|
810
|
+
const workspaceRoot2 = findWorkspaceRoot2(findNearestPackageRoot2(import.meta.url));
|
|
724
811
|
await copyTemplates({
|
|
725
812
|
cwd,
|
|
726
813
|
workspaceRoot: workspaceRoot2,
|
|
@@ -734,19 +821,19 @@ function initCommand() {
|
|
|
734
821
|
targetDir: cfg.composablesDir,
|
|
735
822
|
aliasSymbol: cfg.aliasSymbol ?? "@"
|
|
736
823
|
});
|
|
737
|
-
const libUtilsPath2 =
|
|
824
|
+
const libUtilsPath2 = path7.join(cwd, cfg.libDir, "utils.ts");
|
|
738
825
|
if (!await pathExists(libUtilsPath2)) await writeTextFile(libUtilsPath2, cnUtilsTs({}));
|
|
739
|
-
console.log(`\u5DF2\u5199\u5165\u914D\u7F6E\uFF1A${
|
|
826
|
+
console.log(`\u5DF2\u5199\u5165\u914D\u7F6E\uFF1A${path7.relative(process.cwd(), cfgPath2)}\uFF1B\u5E76\u751F\u6210 cn/utils\uFF08pm=${pm}\uFF09`);
|
|
740
827
|
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");
|
|
741
828
|
console.log("");
|
|
742
829
|
await showLogo();
|
|
743
830
|
await typewriter(gradientText("\u611F\u8C22\u4F7F\u7528 Reborn UI ! \u2728"), 20);
|
|
744
831
|
return;
|
|
745
832
|
}
|
|
746
|
-
const cfgPath =
|
|
747
|
-
await ensureDir(
|
|
748
|
-
await
|
|
749
|
-
const workspaceRoot = findWorkspaceRoot2(
|
|
833
|
+
const cfgPath = path7.join(cwd, opts.config);
|
|
834
|
+
await ensureDir(path7.dirname(cfgPath));
|
|
835
|
+
await fs6.writeFile(cfgPath, JSON.stringify(cfg, null, 2) + "\n", "utf8");
|
|
836
|
+
const workspaceRoot = findWorkspaceRoot2(findNearestPackageRoot2(import.meta.url));
|
|
750
837
|
await copyTemplates({
|
|
751
838
|
cwd,
|
|
752
839
|
workspaceRoot,
|
|
@@ -760,9 +847,9 @@ function initCommand() {
|
|
|
760
847
|
targetDir: cfg.composablesDir,
|
|
761
848
|
aliasSymbol: cfg.aliasSymbol ?? "@"
|
|
762
849
|
});
|
|
763
|
-
const libUtilsPath =
|
|
850
|
+
const libUtilsPath = path7.join(cwd, cfg.libDir, "utils.ts");
|
|
764
851
|
if (!await pathExists(libUtilsPath)) await writeTextFile(libUtilsPath, cnUtilsTs({}));
|
|
765
|
-
console.log(`\u5DF2\u521D\u59CB\u5316\uFF1A${
|
|
852
|
+
console.log(`\u5DF2\u521D\u59CB\u5316\uFF1A${path7.relative(process.cwd(), cfgPath)}\uFF1B\u5E76\u751F\u6210 cn/utils\uFF08pm=${pm}\uFF09`);
|
|
766
853
|
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");
|
|
767
854
|
console.log("");
|
|
768
855
|
await showLogo();
|
|
@@ -774,7 +861,7 @@ function initCommand() {
|
|
|
774
861
|
// package.json
|
|
775
862
|
var package_default = {
|
|
776
863
|
name: "reborn-ui",
|
|
777
|
-
version: "0.1.
|
|
864
|
+
version: "0.1.71",
|
|
778
865
|
description: "A CLI for Reborn UI",
|
|
779
866
|
author: "1997liuyh-boop",
|
|
780
867
|
license: "MIT",
|
|
@@ -789,7 +876,6 @@ var package_default = {
|
|
|
789
876
|
files: [
|
|
790
877
|
"dist",
|
|
791
878
|
"registry",
|
|
792
|
-
"templates",
|
|
793
879
|
"README.md"
|
|
794
880
|
],
|
|
795
881
|
publishConfig: {
|
|
@@ -801,9 +887,10 @@ var package_default = {
|
|
|
801
887
|
dev: "tsx src/index.ts",
|
|
802
888
|
clean: "rimraf dist",
|
|
803
889
|
prepare: "tsup",
|
|
890
|
+
"templates:sync": "tsx src/scripts/sync-templates.ts",
|
|
804
891
|
"registry:build": "tsx src/index.ts build --root ../.. --uniapp-source packages/uniapp-project/src/components",
|
|
805
|
-
prepack: "npm run build && npm run registry:build",
|
|
806
|
-
prepublishOnly: "npm run build && npm run registry:build"
|
|
892
|
+
prepack: "npm run templates:sync && npm run build && npm run registry:build",
|
|
893
|
+
prepublishOnly: "npm run templates:sync && npm run build && npm run registry:build"
|
|
807
894
|
},
|
|
808
895
|
dependencies: {
|
|
809
896
|
chalk: "^5.6.2",
|
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/utils/ui.ts","../src/commands/build.ts","../src/utils/imports.ts","../src/utils/transformers.ts","../src/commands/init.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 onProgress?: () => void;\r\n platform: \"web\" | \"uniapp\";\r\n}) {\r\n const { cwd, componentsDir, aliasSymbol, component, overwrite, onProgress, platform } = 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 // 过滤逻辑:\r\n // 1. 如果 f.target 存在且不等于 platform,跳过\r\n // 2. 如果 f.target 不存在,视为通用文件,不跳过\r\n if (f.target && f.target !== platform) {\r\n continue;\r\n }\r\n\r\n const target = path.join(baseDir, ...f.path.split(\"/\"));\r\n if (!overwrite && (await pathExists(target))) {\r\n onProgress?.();\r\n continue;\r\n }\r\n const nextContent = rewriteImports({ content: f.content, aliasSymbol });\r\n await writeTextFile(target, nextContent);\r\n onProgress?.();\r\n // 增加一个极小的延迟,让进度条看起来在“跑”\r\n await new Promise(r => setTimeout(r, 10));\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 // 询问平台 (Web / UniApp)\r\n const { platform } = await prompts({\r\n type: \"select\",\r\n name: \"platform\",\r\n message: \"选择目标平台\",\r\n choices: [\r\n { title: \"Web (默认)\", value: \"web\" },\r\n { title: \"UniApp\", value: \"uniapp\" },\r\n ],\r\n initial: 0,\r\n });\r\n\r\n if (!platform) {\r\n throw new Error(\"已取消\");\r\n }\r\n\r\n const totalFiles = targets.reduce((acc, name) => {\r\n const c = registry.components.find((x) => x.name === name);\r\n return acc + (c?.files.length ?? 0);\r\n }, 0);\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(totalFiles, 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 onProgress: () => bar.increment(),\r\n platform,\r\n });\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\nimport figlet from 'figlet';\r\n\r\n/**\r\n * 模拟打字机效果\r\n * @param text 要显示的文本\r\n * @param delay 每字符延迟时间 (ms)\r\n * @param newline 是否在结束时换行\r\n */\r\nexport async function typewriter(text: string, delay: number = 15, newline: boolean = true) {\r\n for (const char of text) {\r\n process.stdout.write(char);\r\n if (delay > 0) {\r\n await new Promise((resolve) => setTimeout(resolve, delay));\r\n }\r\n }\r\n if (newline) {\r\n process.stdout.write('\\n');\r\n }\r\n}\r\n\r\n/**\r\n * 显示 ASCII Logo\r\n */\r\nexport async function showLogo(text: string = 'Reborn UI') {\r\n return new Promise<void>((resolve) => {\r\n figlet.text(text, {\r\n font: 'Slant',\r\n horizontalLayout: 'default',\r\n verticalLayout: 'default',\r\n width: 80,\r\n whitespaceBreak: true\r\n }, async (err, data) => {\r\n if (err) {\r\n console.log(gradientText(text));\r\n resolve();\r\n return;\r\n }\r\n if (data) {\r\n const lines = data.split('\\n');\r\n for (const line of lines) {\r\n console.log(gradientText(line));\r\n await new Promise(r => setTimeout(r, 20)); // 每行显示间隔,增加动感\r\n }\r\n }\r\n resolve();\r\n });\r\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\nimport { transformToUniapp } from \"../utils/transformers.js\";\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 \"app/components/reborn/ui\",\r\n )\r\n .option(\r\n \"--uniapp-source <path>\",\r\n \"UniApp 组件源码目录(相对 root),如果不提供则通过转换生成\",\r\n \"\",\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 uniappSourceDir = opts.uniappSource \r\n ? path.join(rootDir, opts.uniappSource)\r\n : \"\";\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\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\r\n const ext = path.extname(absFile).toLowerCase();\r\n\r\n // 1. Web 版本(原样)\r\n if (ext === \".vue\") {\r\n files.push({ path: rel, content, target: \"web\" });\r\n } else {\r\n files.push({ path: rel, content });\r\n }\r\n\r\n // 只从代码文件里抽依赖\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 // 2. UniApp 版本\r\n // 如果提供了 uniappSourceDir,从那里读取;否则通过转换生成\r\n if (uniappSourceDir) {\r\n const uniappComponentDir = path.join(uniappSourceDir, name);\r\n if (fssync.existsSync(uniappComponentDir)) {\r\n const uniappFiles = (await listFilesRecursive(uniappComponentDir)).filter(\r\n isAllowedFile,\r\n );\r\n \r\n for (const absFile of uniappFiles) {\r\n const rel = path\r\n .relative(uniappComponentDir, absFile)\r\n .split(path.sep)\r\n .join(\"/\");\r\n const content = await fs.readFile(absFile, \"utf8\");\r\n const ext = path.extname(absFile).toLowerCase();\r\n\r\n files.push({ path: rel, content, target: \"uniapp\" });\r\n\r\n // 抽取依赖\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 } else {\r\n // 通过转换生成 UniApp 版本\r\n for (const absFile of absFiles) {\r\n const ext = path.extname(absFile).toLowerCase();\r\n if (ext === \".vue\") {\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({\r\n path: rel,\r\n content: transformToUniapp(content),\r\n target: \"uniapp\",\r\n });\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","\r\nexport function transformToUniapp(code: string): string {\r\n // 1. 标签替换\r\n // div -> view\r\n // span, font -> text(注意:span可能嵌套,正则要注意)\r\n // ul, li -> view\r\n // img -> image\r\n // a -> navigator\r\n // select -> picker\r\n // iframe -> web-view\r\n\r\n let newCode = code;\r\n\r\n // 简单正则替换标签名\r\n const tagMap: Record<string, string> = {\r\n div: \"view\",\r\n span: \"text\",\r\n font: \"text\",\r\n ul: \"view\",\r\n li: \"view\",\r\n img: \"image\",\r\n a: \"navigator\",\r\n select: \"picker\",\r\n iframe: \"web-view\",\r\n };\r\n\r\n for (const [k, v] of Object.entries(tagMap)) {\r\n // 匹配 <tag ...> 和 </tag>\r\n // 1. <tag\r\n newCode = newCode.replace(new RegExp(`<${k}(\\\\s+|>)`, \"g\"), `<${v}$1`);\r\n // 2. </tag>\r\n newCode = newCode.replace(new RegExp(`<\\\\/${k}>`, \"g\"), `</${v}>`);\r\n }\r\n\r\n // 2. 特殊处理\r\n // input[type=\"search\"] -> type=\"text\" confirm-type=\"search\"\r\n newCode = newCode.replace(/type=[\"']search[\"']/g, 'confirm-type=\"search\"');\r\n\r\n return newCode;\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 prompts from \"prompts\";\r\nimport type { CliConfig, PackageManager } from \"../types.js\";\r\nimport { copyDirRecursive, 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, showLogo, 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\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\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\nasync function copyTemplates(params: {\r\n cwd: string;\r\n workspaceRoot: string;\r\n platform: \"web\" | \"uniapp\";\r\n cfg: CliConfig;\r\n overwrite?: boolean;\r\n}) {\r\n const { cwd, workspaceRoot, platform, cfg, overwrite } = params;\r\n\r\n if (platform === \"uniapp\") {\r\n const uniappLibSrc = path.join(workspaceRoot, \"packages/uniapp-project/src/lib\");\r\n const uniappComposablesSrc = path.join(workspaceRoot, \"packages/uniapp-project/src/composables\");\r\n\r\n if (await pathExists(uniappLibSrc)) {\r\n await copyDirRecursive({\r\n fromDir: uniappLibSrc,\r\n toDir: path.join(cwd, cfg.libDir),\r\n overwrite,\r\n });\r\n }\r\n\r\n if (await pathExists(uniappComposablesSrc)) {\r\n await copyDirRecursive({\r\n fromDir: uniappComposablesSrc,\r\n toDir: path.join(cwd, cfg.composablesDir),\r\n overwrite,\r\n });\r\n }\r\n } else {\r\n const webLibSrc = path.join(workspaceRoot, \"app/lib\");\r\n const webComposablesSrc = path.join(workspaceRoot, \"app/composables\");\r\n\r\n if (await pathExists(webLibSrc)) {\r\n await copyDirRecursive({\r\n fromDir: webLibSrc,\r\n toDir: path.join(cwd, cfg.libDir),\r\n overwrite,\r\n });\r\n }\r\n\r\n if (await pathExists(webComposablesSrc)) {\r\n await copyDirRecursive({\r\n fromDir: webComposablesSrc,\r\n toDir: path.join(cwd, cfg.composablesDir),\r\n overwrite,\r\n ignoreFileNames: new Set([\"useComponentCode.ts\", \"useCopyToClipboard.ts\"]),\r\n });\r\n }\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(\"--platform <platform>\", \"目标平台:web|uniapp\", \"web\")\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 platform: opts.platform,\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 cfg.platform = opts.platform ?? existing.platform ?? cfg.platform;\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: \"select\",\r\n name: \"platform\",\r\n message: \"选择目标平台\",\r\n choices: [\r\n { title: \"Web (默认)\", value: \"web\" },\r\n { title: \"UniApp\", value: \"uniapp\" },\r\n ],\r\n initial: cfg.platform === \"uniapp\" ? 1 : 0,\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.platform = res.platform ?? cfg.platform;\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 const workspaceRoot = findWorkspaceRoot(cwd);\r\n await copyTemplates({\r\n cwd,\r\n workspaceRoot,\r\n platform: cfg.platform as \"web\" | \"uniapp\",\r\n cfg,\r\n overwrite: opts.overwrite,\r\n });\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 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 showLogo();\r\n await typewriter(gradientText(\"感谢使用 Reborn UI ! ✨\"), 20);\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 // 复制模板逻辑\r\n const workspaceRoot = findWorkspaceRoot(cwd);\r\n await copyTemplates({\r\n cwd,\r\n workspaceRoot,\r\n platform: cfg.platform as \"web\" | \"uniapp\",\r\n cfg,\r\n overwrite: opts.overwrite,\r\n });\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 showLogo();\r\n await typewriter(gradientText(\"感谢使用 Reborn UI ! ✨\"), 2);\r\n });\r\n\r\n return cmd;\r\n}\r\n\r\n\r\n","{\r\n \"name\": \"reborn-ui\",\r\n \"version\": \"0.1.68\",\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 ../.. --uniapp-source packages/uniapp-project/src/components\",\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 \"chalk\": \"^5.6.2\",\r\n \"cli-progress\": \"^3.12.0\",\r\n \"commander\": \"^14.0.0\",\r\n \"execa\": \"^9.6.0\",\r\n \"figlet\": \"^1.9.4\",\r\n \"ora\": \"^9.0.0\",\r\n \"prompts\": \"^2.4.2\"\r\n },\r\n \"devDependencies\": {\r\n \"@types/cli-progress\": \"^3.11.6\",\r\n \"@types/figlet\": \"^1.7.0\",\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}\r\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","fssync","Command","prompts","path","findWorkspaceRoot","fssync","fs","Command","prompts","cfgPath","workspaceRoot","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/utils/transformers.ts","../src/commands/init.ts","../src/utils/templates.ts","../src/generated/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 onProgress?: () => void;\r\n platform: \"web\" | \"uniapp\";\r\n}) {\r\n const { cwd, componentsDir, aliasSymbol, component, overwrite, onProgress, platform } = 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 // 过滤逻辑:\r\n // 1. 如果 f.target 存在且不等于 platform,跳过\r\n // 2. 如果 f.target 不存在,视为通用文件,不跳过\r\n if (f.target && f.target !== platform) {\r\n continue;\r\n }\r\n\r\n const target = path.join(baseDir, ...f.path.split(\"/\"));\r\n if (!overwrite && (await pathExists(target))) {\r\n onProgress?.();\r\n continue;\r\n }\r\n const nextContent = rewriteImports({ content: f.content, aliasSymbol });\r\n await writeTextFile(target, nextContent);\r\n onProgress?.();\r\n // 增加一个极小的延迟,让进度条看起来在“跑”\r\n await new Promise(r => setTimeout(r, 10));\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 // 询问平台 (Web / UniApp)\r\n const { platform } = await prompts({\r\n type: \"select\",\r\n name: \"platform\",\r\n message: \"选择目标平台\",\r\n choices: [\r\n { title: \"Web (默认)\", value: \"web\" },\r\n { title: \"UniApp\", value: \"uniapp\" },\r\n ],\r\n initial: 0,\r\n });\r\n\r\n if (!platform) {\r\n throw new Error(\"已取消\");\r\n }\r\n\r\n const totalFiles = targets.reduce((acc, name) => {\r\n const c = registry.components.find((x) => x.name === name);\r\n return acc + (c?.files.length ?? 0);\r\n }, 0);\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(totalFiles, 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 onProgress: () => bar.increment(),\r\n platform,\r\n });\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\nimport figlet from 'figlet';\r\n\r\n/**\r\n * 模拟打字机效果\r\n * @param text 要显示的文本\r\n * @param delay 每字符延迟时间 (ms)\r\n * @param newline 是否在结束时换行\r\n */\r\nexport async function typewriter(text: string, delay: number = 15, newline: boolean = true) {\r\n for (const char of text) {\r\n process.stdout.write(char);\r\n if (delay > 0) {\r\n await new Promise((resolve) => setTimeout(resolve, delay));\r\n }\r\n }\r\n if (newline) {\r\n process.stdout.write('\\n');\r\n }\r\n}\r\n\r\n/**\r\n * 显示 ASCII Logo\r\n */\r\nexport async function showLogo(text: string = 'Reborn UI') {\r\n return new Promise<void>((resolve) => {\r\n figlet.text(text, {\r\n font: 'Slant',\r\n horizontalLayout: 'default',\r\n verticalLayout: 'default',\r\n width: 80,\r\n whitespaceBreak: true\r\n }, async (err, data) => {\r\n if (err) {\r\n console.log(gradientText(text));\r\n resolve();\r\n return;\r\n }\r\n if (data) {\r\n const lines = data.split('\\n');\r\n for (const line of lines) {\r\n console.log(gradientText(line));\r\n await new Promise(r => setTimeout(r, 20)); // 每行显示间隔,增加动感\r\n }\r\n }\r\n resolve();\r\n });\r\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\nimport { transformToUniapp } from \"../utils/transformers.js\";\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 \"app/components/reborn/ui\",\r\n )\r\n .option(\r\n \"--uniapp-source <path>\",\r\n \"UniApp 组件源码目录(相对 root),如果不提供则通过转换生成\",\r\n \"\",\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 uniappSourceDir = opts.uniappSource \r\n ? path.join(rootDir, opts.uniappSource)\r\n : \"\";\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\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\r\n const ext = path.extname(absFile).toLowerCase();\r\n\r\n // 1. Web 版本(原样)\r\n if (ext === \".vue\") {\r\n files.push({ path: rel, content, target: \"web\" });\r\n } else {\r\n files.push({ path: rel, content });\r\n }\r\n\r\n // 只从代码文件里抽依赖\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 // 2. UniApp 版本\r\n // 如果提供了 uniappSourceDir,从那里读取;否则通过转换生成\r\n if (uniappSourceDir) {\r\n const uniappComponentDir = path.join(uniappSourceDir, name);\r\n if (fssync.existsSync(uniappComponentDir)) {\r\n const uniappFiles = (await listFilesRecursive(uniappComponentDir)).filter(\r\n isAllowedFile,\r\n );\r\n \r\n for (const absFile of uniappFiles) {\r\n const rel = path\r\n .relative(uniappComponentDir, absFile)\r\n .split(path.sep)\r\n .join(\"/\");\r\n const content = await fs.readFile(absFile, \"utf8\");\r\n const ext = path.extname(absFile).toLowerCase();\r\n\r\n files.push({ path: rel, content, target: \"uniapp\" });\r\n\r\n // 抽取依赖\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 } else {\r\n // 通过转换生成 UniApp 版本\r\n for (const absFile of absFiles) {\r\n const ext = path.extname(absFile).toLowerCase();\r\n if (ext === \".vue\") {\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({\r\n path: rel,\r\n content: transformToUniapp(content),\r\n target: \"uniapp\",\r\n });\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","\r\nexport function transformToUniapp(code: string): string {\r\n // 1. 标签替换\r\n // div -> view\r\n // span, font -> text(注意:span可能嵌套,正则要注意)\r\n // ul, li -> view\r\n // img -> image\r\n // a -> navigator\r\n // select -> picker\r\n // iframe -> web-view\r\n\r\n let newCode = code;\r\n\r\n // 简单正则替换标签名\r\n const tagMap: Record<string, string> = {\r\n div: \"view\",\r\n span: \"text\",\r\n font: \"text\",\r\n ul: \"view\",\r\n li: \"view\",\r\n img: \"image\",\r\n a: \"navigator\",\r\n select: \"picker\",\r\n iframe: \"web-view\",\r\n };\r\n\r\n for (const [k, v] of Object.entries(tagMap)) {\r\n // 匹配 <tag ...> 和 </tag>\r\n // 1. <tag\r\n newCode = newCode.replace(new RegExp(`<${k}(\\\\s+|>)`, \"g\"), `<${v}$1`);\r\n // 2. </tag>\r\n newCode = newCode.replace(new RegExp(`<\\\\/${k}>`, \"g\"), `</${v}>`);\r\n }\r\n\r\n // 2. 特殊处理\r\n // input[type=\"search\"] -> type=\"text\" confirm-type=\"search\"\r\n newCode = newCode.replace(/type=[\"']search[\"']/g, 'confirm-type=\"search\"');\r\n\r\n return newCode;\r\n}\r\n","import path from \"node:path\";\nimport fs from \"node:fs/promises\";\nimport fssync from \"node:fs\";\nimport { Command } from \"commander\";\nimport prompts from \"prompts\";\nimport type { CliConfig, PackageManager } from \"../types.js\";\nimport { copyDirRecursive, ensureDir, listFilesRecursive, pathExists, writeJsonFile, writeTextFile } from \"../utils/fs.js\";\nimport { detectPackageManager } from \"../utils/pm.js\";\nimport { DEFAULT_CONFIG_PATH, defaultConfig, loadConfigCompat } from \"../utils/registry.js\";\nimport { findNearestPackageRoot } from \"../utils/templates.js\";\nimport { TEMPLATES } from \"../generated/templates.js\";\nimport { gradientText, showLogo, typewriter } from \"../utils/ui.js\";\n\nfunction looksLikeNuxtProject(cwd: string) {\n return Promise.all([\n pathExists(path.join(cwd, \"nuxt.config.ts\")),\n pathExists(path.join(cwd, \"nuxt.config.js\")),\n pathExists(path.join(cwd, \"nuxt.config.mjs\")),\n ]).then((arr) => arr.some(Boolean));\n}\n\nfunction findWorkspaceRoot(startDir: string) {\n let current = path.resolve(startDir);\n for (; ;) {\n const marker = path.join(current, \"pnpm-workspace.yaml\");\n if (fssync.existsSync(marker)) return current;\n const parent = path.dirname(current);\n if (parent === current) return startDir;\n current = parent;\n }\n}\n\n\n// function makeDefaultTailwindConfig removed in favor of template file\n\n\n\n\nfunction cnUtilsTs(params: { importPath?: string }) {\n // importPath 预留:如果用户想从别处导入 clsx/twMerge\n void params;\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`;\n}\n\nasync function rewriteAliasInDir(params: {\n cwd: string;\n targetDir: string;\n aliasSymbol: string;\n}) {\n const { cwd, targetDir, aliasSymbol } = params;\n if (!aliasSymbol || aliasSymbol === \"@\") return;\n const absDir = path.join(cwd, targetDir);\n if (!(await pathExists(absDir))) return;\n\n const files = await listFilesRecursive(absDir);\n for (const f of files) {\n const ext = path.extname(f).toLowerCase();\n // 只处理常见文本文件,避免误改二进制\n if (![\".ts\", \".tsx\", \".js\", \".jsx\", \".vue\", \".mjs\", \".cjs\"].includes(ext)) continue;\n const raw = await fs.readFile(f, \"utf8\");\n const next = raw.replaceAll(\"@/\", `${aliasSymbol}/`);\n if (next !== raw) await fs.writeFile(f, next, \"utf8\");\n }\n}\n\nasync function copyTemplates(params: {\n cwd: string;\n workspaceRoot: string;\n platform: \"web\" | \"uniapp\";\n cfg: CliConfig;\n overwrite?: boolean;\n}) {\n const { cwd, workspaceRoot, platform, cfg, overwrite } = params;\n\n // 1. 尝试从仓库源码目录拷贝(本地开发场景)\n const repoPaths = {\n web: {\n lib: path.join(workspaceRoot, \"app/lib\"),\n composables: path.join(workspaceRoot, \"app/composables\"),\n },\n uniapp: {\n lib: path.join(workspaceRoot, \"packages/uniapp-project/src/lib\"),\n composables: path.join(workspaceRoot, \"packages/uniapp-project/src/composables\"),\n },\n };\n\n const currentRepoPaths = repoPaths[platform];\n let copiedFromRepo = false;\n\n if (await pathExists(currentRepoPaths.lib)) {\n await copyDirRecursive({\n fromDir: currentRepoPaths.lib,\n toDir: path.join(cwd, cfg.libDir),\n overwrite,\n });\n copiedFromRepo = true;\n }\n\n if (await pathExists(currentRepoPaths.composables)) {\n await copyDirRecursive({\n fromDir: currentRepoPaths.composables,\n toDir: path.join(cwd, cfg.composablesDir),\n overwrite,\n ignoreFileNames: platform === \"web\" ? new Set([\"useComponentCode.ts\", \"useCopyToClipboard.ts\"]) : undefined,\n });\n copiedFromRepo = true;\n }\n\n // 2. 如果不是在仓库内运行(例如 npx),则使用生成的字符串模板\n if (!copiedFromRepo) {\n const platformTemplates = TEMPLATES[platform];\n for (const [relPath, content] of Object.entries(platformTemplates)) {\n let targetPath = \"\";\n if (relPath.startsWith(\"lib/\")) {\n targetPath = path.join(cwd, cfg.libDir, relPath.replace(\"lib/\", \"\"));\n } else if (relPath.startsWith(\"composables/\")) {\n targetPath = path.join(cwd, cfg.composablesDir, relPath.replace(\"composables/\", \"\"));\n }\n\n if (targetPath) {\n if (!overwrite && (await pathExists(targetPath))) continue;\n await writeTextFile(targetPath, content);\n }\n }\n }\n}\n\nexport function initCommand() {\n const cmd = new Command(\"init\")\n .description(\"初始化新项目\")\n .option(\"--cwd <path>\", \"目标项目目录\", process.cwd())\n .option(\"--pm <pm>\", \"包管理器:pnpm|npm|yarn|bun\")\n .option(\"--yes\", \"跳过交互,使用默认值\", false)\n .option(\"--overwrite\", \"覆盖已存在的模板文件(lib/composables)\", false)\n .option(\n \"--config <path>\",\n \"配置文件路径(相对 cwd)\",\n DEFAULT_CONFIG_PATH,\n )\n .option(\n \"--components-dir <path>\",\n \"组件写入目录\",\n defaultConfig().componentsDir,\n )\n .option(\n \"--lib-dir <path>\",\n \"lib 目录(cn/utils)\",\n defaultConfig().libDir,\n )\n .option(\n \"--composables-dir <path>\",\n \"composables 目录\",\n defaultConfig().composablesDir,\n )\n .option(\n \"--alias-symbol <symbol>\",\n \"项目根目录映射别名符号(默认 @)\",\n defaultConfig().aliasSymbol,\n )\n .option(\"--platform <platform>\", \"目标平台:web|uniapp\", \"web\")\n .option(\"--registry <pkgOrPath>\", \"registry 来源(默认 builtin)\", defaultConfig().registry)\n .action(async (opts) => {\n const cwd = path.resolve(opts.cwd);\n\n // eslint-disable-next-line no-console\n console.log(\n \"提示:项目中有部分依赖需要使用@/ 路径进行配置,请您安装到项目中配置好的路径下,请慎重选择文件位置\",\n );\n\n const pkgPath = path.join(cwd, \"package.json\");\n if (!(await pathExists(pkgPath))) {\n throw new Error(`未找到 package.json:${pkgPath}`);\n }\n\n const pm: PackageManager =\n opts.pm ?? (await detectPackageManager(cwd));\n\n const cfg: CliConfig = {\n schemaVersion: 1,\n componentsDir: opts.componentsDir,\n libDir: opts.libDir,\n composablesDir: opts.composablesDir,\n aliasSymbol: opts.aliasSymbol,\n registry: opts.registry,\n platform: opts.platform,\n };\n\n // 如果已存在 components.json,默认沿用(除非用户显式传参覆盖)\n const existing = await loadConfigCompat(cwd);\n if (existing) {\n cfg.componentsDir = opts.componentsDir ?? existing.componentsDir ?? cfg.componentsDir;\n cfg.libDir = opts.libDir ?? existing.libDir ?? cfg.libDir;\n cfg.composablesDir = opts.composablesDir ?? existing.composablesDir ?? cfg.composablesDir;\n cfg.aliasSymbol = opts.aliasSymbol ?? existing.aliasSymbol ?? cfg.aliasSymbol;\n cfg.registry = opts.registry ?? existing.registry ?? cfg.registry;\n cfg.platform = opts.platform ?? existing.platform ?? cfg.platform;\n }\n\n if (!opts.yes) {\n const nuxt = await looksLikeNuxtProject(cwd);\n const res = await prompts(\n [\n {\n type: \"select\",\n name: \"platform\",\n message: \"选择目标平台\",\n choices: [\n { title: \"Web (默认)\", value: \"web\" },\n { title: \"UniApp\", value: \"uniapp\" },\n ],\n initial: cfg.platform === \"uniapp\" ? 1 : 0,\n },\n {\n type: \"text\",\n name: \"componentsDir\",\n message: \"组件目录(componentsDir)\",\n initial: cfg.componentsDir,\n },\n {\n type: \"text\",\n name: \"libDir\",\n message: \"lib 目录(libDir,用于 cn/utils)\",\n initial: cfg.libDir,\n },\n {\n type: \"text\",\n name: \"composablesDir\",\n message: \"composables 目录(composablesDir)\",\n initial: cfg.composablesDir,\n },\n {\n type: \"text\",\n name: \"aliasSymbol\",\n message: \"基于项目根目录的“映射”的符号是?(aliasSymbol)\",\n initial: cfg.aliasSymbol ?? \"@\",\n },\n ],\n {\n onCancel: () => {\n throw new Error(\"已取消\");\n },\n },\n );\n\n cfg.platform = res.platform ?? cfg.platform;\n cfg.componentsDir = res.componentsDir ?? cfg.componentsDir;\n cfg.libDir = res.libDir ?? cfg.libDir;\n cfg.composablesDir = res.composablesDir ?? cfg.composablesDir;\n cfg.aliasSymbol = res.aliasSymbol ?? cfg.aliasSymbol;\n\n // 写配置\n const cfgPath = path.join(cwd, opts.config);\n await writeJsonFile(cfgPath, cfg);\n\n // 复制模板:lib/ + composables/\n const workspaceRoot = findWorkspaceRoot(findNearestPackageRoot(import.meta.url));\n await copyTemplates({\n cwd,\n workspaceRoot,\n platform: cfg.platform as \"web\" | \"uniapp\",\n cfg,\n overwrite: opts.overwrite,\n });\n\n // 仅替换 \"@/...\" 的别名符号,不改其它路径内容\n await rewriteAliasInDir({ cwd, targetDir: cfg.libDir, aliasSymbol: cfg.aliasSymbol ?? \"@\" });\n await rewriteAliasInDir({\n cwd,\n targetDir: cfg.composablesDir,\n aliasSymbol: cfg.aliasSymbol ?? \"@\",\n });\n\n // 兜底:如果用户模板里没有 utils.ts,则生成 cn\n const libUtilsPath = path.join(cwd, cfg.libDir, \"utils.ts\");\n if (!(await pathExists(libUtilsPath))) await writeTextFile(libUtilsPath, cnUtilsTs({}));\n\n console.log(`已写入配置:${path.relative(process.cwd(), cfgPath)};并生成 cn/utils(pm=${pm})`);\n console.log(\"请按照 https://tw.icebreaker.top/docs/quick-start/v4/uni-app-vite 指引进行项目配置初始化\");\n\n console.log(\"\");\n await showLogo();\n await typewriter(gradientText(\"感谢使用 Reborn UI ! ✨\"), 20);\n return;\n }\n\n // --yes:直接写默认配置\n const cfgPath = path.join(cwd, opts.config);\n await ensureDir(path.dirname(cfgPath));\n await fs.writeFile(cfgPath, JSON.stringify(cfg, null, 2) + \"\\n\", \"utf8\");\n\n // 复制模板逻辑\n const workspaceRoot = findWorkspaceRoot(findNearestPackageRoot(import.meta.url));\n await copyTemplates({\n cwd,\n workspaceRoot,\n platform: cfg.platform as \"web\" | \"uniapp\",\n cfg,\n overwrite: opts.overwrite,\n });\n\n // 仅替换 \"@/...\" 的别名符号,不改其它路径内容\n await rewriteAliasInDir({ cwd, targetDir: cfg.libDir, aliasSymbol: cfg.aliasSymbol ?? \"@\" });\n await rewriteAliasInDir({\n cwd,\n targetDir: cfg.composablesDir,\n aliasSymbol: cfg.aliasSymbol ?? \"@\",\n });\n\n // 兜底:如果用户模板里没有 utils.ts,则生成 cn\n const libUtilsPath = path.join(cwd, cfg.libDir, \"utils.ts\");\n if (!(await pathExists(libUtilsPath))) await writeTextFile(libUtilsPath, cnUtilsTs({}));\n\n // eslint-disable-next-line no-console\n console.log(`已初始化:${path.relative(process.cwd(), cfgPath)};并生成 cn/utils(pm=${pm})`);\n console.log(\"请按照 https://tw.icebreaker.top/docs/quick-start/v4/uni-app-vite 指引进行项目配置初始化\");\n\n console.log(\"\");\n await showLogo();\n await typewriter(gradientText(\"感谢使用 Reborn UI ! ✨\"), 2);\n });\n\n return cmd;\n}\n\n\n","import path from \"node:path\";\nimport fs from \"node:fs\";\nimport { fileURLToPath } from \"node:url\";\n\nexport function 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\n\n\n\n\n\n","// 此文件由 sync-templates.ts 自动生成,请勿手动修改\nexport const TEMPLATES = {\n \"web\": {\n \"lib/tv.ts\": \"import { createTV } from \\\"tailwind-variants\\\";\\r\\nimport { twMergeConfig } from \\\"./utils\\\";\\r\\n\\r\\nexport const tv = createTV({\\r\\n twMergeConfig,\\r\\n});\\r\\nexport type { VariantProps } from \\\"tailwind-variants\\\";\\r\\n\",\n \"lib/utils.ts\": \"import type { ClassValue } from \\\"clsx\\\";\\r\\nimport { clsx } from \\\"clsx\\\";\\r\\nimport { extendTailwindMerge } from \\\"tailwind-merge\\\";\\r\\n\\r\\nexport const twMergeConfig = {\\r\\n extend: {\\r\\n classGroups: {\\r\\n \\\"font-size\\\": [{ text: [(value: string) => !isNaN(Number(value))] }],\\r\\n },\\r\\n },\\r\\n};\\r\\n\\r\\nconst customTwMerge = extendTailwindMerge(twMergeConfig);\\r\\n\\r\\nexport function cn(...inputs: ClassValue[]) {\\r\\n return customTwMerge(clsx(inputs));\\r\\n}\\r\\n\\r\\nexport type ObjectValues<T> = T[keyof T];\\r\\n\",\n \"composables/useFieldGroup.ts\": \"\\r\\nimport { ref } from 'vue'\\r\\n\\r\\nexport function useFieldGroup(props: any) {\\r\\n return {\\r\\n orientation: ref(undefined),\\r\\n size: ref(undefined)\\r\\n }\\r\\n}\\r\\n\",\n \"composables/useMouseState.ts\": \"import { readonly, ref } from \\\"vue\\\";\\r\\n\\r\\nexport function useMouseState() {\\r\\n const isMouseEntered = ref(false);\\r\\n\\r\\n function setMouseEntered(value: boolean) {\\r\\n isMouseEntered.value = value;\\r\\n }\\r\\n\\r\\n return {\\r\\n isMouseEntered: readonly(isMouseEntered),\\r\\n setMouseEntered,\\r\\n };\\r\\n}\\r\\n\",\n \"composables/useNavigation.ts\": \"import type { ContentNavigationItem } from \\\"@nuxt/content\\\";\\r\\n\\r\\nexport function useNavigation(navigation?: Ref<ContentNavigationItem[]>) {\\r\\n const route = useRoute();\\r\\n\\r\\n const children = computed(() => {\\r\\n const nav = toValue(navigation);\\r\\n\\r\\n // Get the current path segments\\r\\n const pathSegments = route.path.split(\\\"/\\\").filter(Boolean);\\r\\n\\r\\n // Need at least one section (e.g., ['components', 'button'])\\r\\n if (pathSegments.length < 1) {\\r\\n return [];\\r\\n }\\r\\n\\r\\n // Build the top parent path (e.g., '/components')\\r\\n const topParentPath = `/${pathSegments[0]}`;\\r\\n\\r\\n // Find the matching top-level navigation item\\r\\n const topParent = nav?.find((item) => item.path === topParentPath);\\r\\n\\r\\n return topParent?.children || [];\\r\\n });\\r\\n\\r\\n const isFlatList = computed(() => {\\r\\n return children.value.every((child) => !child.children || child.children.length === 0);\\r\\n });\\r\\n\\r\\n const nav = computed(() => {\\r\\n if (isFlatList.value) {\\r\\n return [\\r\\n {\\r\\n title: \\\"Overview\\\",\\r\\n path: children.value.at(0)?.path || \\\"\\\",\\r\\n children: children.value,\\r\\n },\\r\\n ];\\r\\n }\\r\\n\\r\\n return children.value;\\r\\n });\\r\\n\\r\\n return {\\r\\n nav,\\r\\n };\\r\\n}\\r\\n\"\n },\n \"uniapp\": {\n \"lib/tv.ts\": \"// @ts-ignore\\r\\nimport { create } from '@weapp-tailwindcss/variants-v3'\\r\\n// @ts-ignore\\r\\nconst isH5 = process.env.UNI_PLATFORM === 'h5'\\r\\n\\r\\nconst { tv } = create({\\r\\n escape: !isH5,\\r\\n unescape: !isH5,\\r\\n})\\r\\n\\r\\nexport { tv }\\r\\n\",\n \"lib/utils.ts\": \"import { type ClassValue, clsx } from 'clsx'\\r\\nimport { create } from '@weapp-tailwindcss/merge-v3'\\r\\n\\r\\n// @ts-ignore\\r\\nconst isH5 = process.env.UNI_PLATFORM === 'h5'\\r\\nconst { twMerge } = create({\\r\\n escape: !isH5,\\r\\n unescape: !isH5,\\r\\n})\\r\\n\\r\\nexport function cn(...inputs: ClassValue[]) {\\r\\n return twMerge(clsx(inputs))\\r\\n}\\r\\n\",\n \"composables/useFieldGroup.ts\": \"import { ref } from 'vue'\\r\\n\\r\\nexport function useFieldGroup(props?: any) {\\r\\n return {\\r\\n disabled: ref(undefined),\\r\\n orientation: ref(undefined),\\r\\n size: ref(undefined)\\r\\n }\\r\\n}\\r\\n\"\n }\n} as const;\n\nexport type Platform = keyof typeof TEMPLATES;\n","{\n \"name\": \"reborn-ui\",\n \"version\": \"0.1.71\",\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 \"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 \"templates:sync\": \"tsx src/scripts/sync-templates.ts\",\n \"registry:build\": \"tsx src/index.ts build --root ../.. --uniapp-source packages/uniapp-project/src/components\",\n \"prepack\": \"npm run templates:sync && npm run build && npm run registry:build\",\n \"prepublishOnly\": \"npm run templates:sync && 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 \"figlet\": \"^1.9.4\",\n \"ora\": \"^9.0.0\",\n \"prompts\": \"^2.4.2\"\n },\n \"devDependencies\": {\n \"@types/cli-progress\": \"^3.11.6\",\n \"@types/figlet\": \"^1.7.0\",\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}\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","fssync","Command","prompts","path","fs","fileURLToPath","findNearestPackageRoot","path","findWorkspaceRoot","fssync","fs","Command","prompts","cfgPath","workspaceRoot","findNearestPackageRoot","libUtilsPath","Command"]}
|
package/package.json
CHANGED
|
@@ -1,53 +1,53 @@
|
|
|
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
|
-
"
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
"
|
|
26
|
-
"
|
|
27
|
-
"
|
|
28
|
-
"
|
|
29
|
-
"
|
|
30
|
-
"registry:build": "tsx src/index.ts build --root ../.. --uniapp-source packages/uniapp-project/src/components",
|
|
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
|
-
"figlet": "^1.9.4",
|
|
40
|
-
"ora": "^9.0.0",
|
|
41
|
-
"prompts": "^2.4.2"
|
|
42
|
-
},
|
|
43
|
-
"devDependencies": {
|
|
44
|
-
"@types/cli-progress": "^3.11.6",
|
|
45
|
-
"@types/figlet": "^1.7.0",
|
|
46
|
-
"@types/node": "^22.10.7",
|
|
47
|
-
"@types/prompts": "^2.4.9",
|
|
48
|
-
"rimraf": "^6.0.1",
|
|
49
|
-
"tsup": "^8.5.0",
|
|
50
|
-
"tsx": "^4.20.0",
|
|
51
|
-
"typescript": "^5.8.3"
|
|
52
|
-
}
|
|
53
|
-
}
|
|
1
|
+
{
|
|
2
|
+
"name": "reborn-ui",
|
|
3
|
+
"version": "0.1.71",
|
|
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
|
+
"README.md"
|
|
19
|
+
],
|
|
20
|
+
"publishConfig": {
|
|
21
|
+
"access": "public"
|
|
22
|
+
},
|
|
23
|
+
"scripts": {
|
|
24
|
+
"cli": "tsx src/index.ts",
|
|
25
|
+
"build": "tsup",
|
|
26
|
+
"dev": "tsx src/index.ts",
|
|
27
|
+
"clean": "rimraf dist",
|
|
28
|
+
"prepare": "tsup",
|
|
29
|
+
"templates:sync": "tsx src/scripts/sync-templates.ts",
|
|
30
|
+
"registry:build": "tsx src/index.ts build --root ../.. --uniapp-source packages/uniapp-project/src/components",
|
|
31
|
+
"prepack": "npm run templates:sync && npm run build && npm run registry:build",
|
|
32
|
+
"prepublishOnly": "npm run templates:sync && 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
|
+
"figlet": "^1.9.4",
|
|
40
|
+
"ora": "^9.0.0",
|
|
41
|
+
"prompts": "^2.4.2"
|
|
42
|
+
},
|
|
43
|
+
"devDependencies": {
|
|
44
|
+
"@types/cli-progress": "^3.11.6",
|
|
45
|
+
"@types/figlet": "^1.7.0",
|
|
46
|
+
"@types/node": "^22.10.7",
|
|
47
|
+
"@types/prompts": "^2.4.9",
|
|
48
|
+
"rimraf": "^6.0.1",
|
|
49
|
+
"tsup": "^8.5.0",
|
|
50
|
+
"tsx": "^4.20.0",
|
|
51
|
+
"typescript": "^5.8.3"
|
|
52
|
+
}
|
|
53
|
+
}
|
package/registry/registry.json
CHANGED
|
@@ -1,25 +0,0 @@
|
|
|
1
|
-
import { ref, readonly } from "vue";
|
|
2
|
-
|
|
3
|
-
export function useMouseState() {
|
|
4
|
-
const isMouseEntered = ref(false);
|
|
5
|
-
|
|
6
|
-
function setMouseEntered(value: boolean) {
|
|
7
|
-
isMouseEntered.value = value;
|
|
8
|
-
}
|
|
9
|
-
|
|
10
|
-
return {
|
|
11
|
-
isMouseEntered: readonly(isMouseEntered),
|
|
12
|
-
setMouseEntered,
|
|
13
|
-
};
|
|
14
|
-
}
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|