@kimesh/cli 0.1.0-nightly.20260119170404 → 0.1.0

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/bin/kmi.mjs ADDED
@@ -0,0 +1,2 @@
1
+ #!/usr/bin/env node
2
+ import '../dist/run.mjs'
@@ -0,0 +1,2 @@
1
+ import { banner, buildArgs, clearKitCache, commands, devArgs, getBuildDir, getCurrentDir, getKit, isGlobalInstall, loadKit, logger, main, prepareArgs, resolveRoot, run, sharedArgs, step, success, timing, version, withSpinner } from "kmi";
2
+ export { banner, buildArgs, clearKitCache, commands, devArgs, getBuildDir, getCurrentDir, getKit, isGlobalInstall, loadKit, logger, main, prepareArgs, resolveRoot, run, sharedArgs, step, success, timing, version, withSpinner };
package/dist/index.js ADDED
@@ -0,0 +1,3 @@
1
+ import { banner, buildArgs, clearKitCache, commands, devArgs, getBuildDir, getCurrentDir, getKit, isGlobalInstall, loadKit, logger, main, prepareArgs, resolveRoot, run, sharedArgs, step, success, timing, version, withSpinner } from "kmi";
2
+
3
+ export { banner, buildArgs, clearKitCache, commands, devArgs, getBuildDir, getCurrentDir, getKit, isGlobalInstall, loadKit, logger, main, prepareArgs, resolveRoot, run, sharedArgs, step, success, timing, version, withSpinner };
package/dist/main.d.ts ADDED
@@ -0,0 +1,2 @@
1
+ import { main, version } from "kmi";
2
+ export { main, version };
package/dist/main.js ADDED
@@ -0,0 +1,3 @@
1
+ import { main, version } from "kmi";
2
+
3
+ export { main, version };
package/dist/run.d.ts ADDED
@@ -0,0 +1,2 @@
1
+ import { run } from "kmi";
2
+ export { run };
package/dist/run.js ADDED
@@ -0,0 +1,7 @@
1
+ import { run } from "kmi";
2
+
3
+ //#region src/run.ts
4
+ run();
5
+
6
+ //#endregion
7
+ export { run };
package/package.json CHANGED
@@ -1,19 +1,21 @@
1
1
  {
2
2
  "name": "@kimesh/cli",
3
- "version": "0.1.0-nightly.20260119170404",
4
- "description": "CLI for Kimesh framework",
3
+ "version": "0.1.0",
4
+ "description": "Kimesh CLI for integration with main package",
5
5
  "type": "module",
6
- "bin": {
7
- "km": "./bin/km.mjs"
8
- },
9
6
  "exports": {
10
7
  ".": {
11
8
  "types": "./dist/index.d.mts",
12
9
  "import": "./dist/index.mjs"
13
- }
10
+ },
11
+ "./cli": "./bin/kmi.mjs"
14
12
  },
15
13
  "main": "./dist/index.mjs",
16
14
  "types": "./dist/index.d.mts",
15
+ "bin": {
16
+ "kmi": "bin/kmi.mjs",
17
+ "km": "bin/kmi.mjs"
18
+ },
17
19
  "files": [
18
20
  "dist",
19
21
  "bin"
@@ -24,17 +26,10 @@
24
26
  "typecheck": "tsc --noEmit"
25
27
  },
26
28
  "dependencies": {
27
- "@kimesh/kit": "0.1.0-nightly.20260119170404",
28
- "citty": "^0.1.6",
29
- "consola": "^3.4.2",
30
- "picocolors": "^1.1.1"
29
+ "kmi": "workspace:*"
31
30
  },
32
31
  "devDependencies": {
33
- "@types/node": "^25.0.8",
34
- "typescript": "^5.9.3",
35
- "tsdown": "^0.20.0-beta.3"
36
- },
37
- "peerDependencies": {
38
- "vite": "^8.0.0-beta.8"
32
+ "tsdown": "^0.11.7",
33
+ "typescript": "^5.8.2"
39
34
  }
40
35
  }
package/README.md DELETED
@@ -1,3 +0,0 @@
1
- # @kimesh/cli
2
-
3
- Part of the [Kimesh](https://github.com/kimesh/kimesh) framework.
package/bin/km.mjs DELETED
@@ -1,2 +0,0 @@
1
- #!/usr/bin/env node
2
- import '../dist/cli.mjs'
@@ -1,43 +0,0 @@
1
- import { defineCommand } from "citty";
2
- import { resolve } from "node:path";
3
- import consola from "consola";
4
-
5
- //#region src/commands/build.ts
6
- var build_default = defineCommand({
7
- meta: {
8
- name: "build",
9
- description: "Build for production"
10
- },
11
- args: {
12
- root: {
13
- type: "string",
14
- alias: "r",
15
- description: "Project root directory"
16
- },
17
- config: {
18
- type: "string",
19
- alias: "c",
20
- description: "Config file path"
21
- }
22
- },
23
- async run({ args }) {
24
- const root = resolve(args.root || process.cwd());
25
- consola.info(`Building for production...`);
26
- const { loadConfig, kimeshPlugin } = await import("@kimesh/kit");
27
- const kmConfig = await loadConfig({
28
- root,
29
- configFile: args.config
30
- });
31
- const { build } = await import("vite");
32
- await build({
33
- root,
34
- configFile: false,
35
- plugins: [kimeshPlugin({ config: kmConfig })]
36
- });
37
- consola.success(`Build complete!`);
38
- }
39
- });
40
-
41
- //#endregion
42
- export { build_default as t };
43
- //# sourceMappingURL=build-DBrdh66Y.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"build-DBrdh66Y.mjs","names":[],"sources":["../src/commands/build.ts"],"sourcesContent":["import { defineCommand } from \"citty\";\nimport { resolve } from \"node:path\";\nimport consola from \"consola\";\nimport pc from \"picocolors\";\n\nexport default defineCommand({\n meta: {\n name: \"build\",\n description: \"Build for production\",\n },\n args: {\n root: {\n type: \"string\",\n alias: \"r\",\n description: \"Project root directory\",\n },\n config: {\n type: \"string\",\n alias: \"c\",\n description: \"Config file path\",\n },\n },\n async run({ args }) {\n const root = resolve(args.root || process.cwd());\n\n consola.info(`Building for production...`);\n\n // Load Kimesh config\n const { loadConfig, kimeshPlugin } = await import(\"@kimesh/kit\");\n const kmConfig = await loadConfig({\n root,\n configFile: args.config,\n });\n\n // Import Vite\n const { build } = await import(\"vite\");\n\n // Run Vite build\n await build({\n root,\n configFile: false,\n plugins: [kimeshPlugin({ config: kmConfig })] as any,\n });\n\n consola.success(`Build complete!`);\n },\n});\n"],"mappings":";;;;;AAKA,oBAAe,cAAc;CAC3B,MAAM;EACJ,MAAM;EACN,aAAa;EACd;CACD,MAAM;EACJ,MAAM;GACJ,MAAM;GACN,OAAO;GACP,aAAa;GACd;EACD,QAAQ;GACN,MAAM;GACN,OAAO;GACP,aAAa;GACd;EACF;CACD,MAAM,IAAI,EAAE,QAAQ;EAClB,MAAM,OAAO,QAAQ,KAAK,QAAQ,QAAQ,KAAK,CAAC;AAEhD,UAAQ,KAAK,6BAA6B;EAG1C,MAAM,EAAE,YAAY,iBAAiB,MAAM,OAAO;EAClD,MAAM,WAAW,MAAM,WAAW;GAChC;GACA,YAAY,KAAK;GAClB,CAAC;EAGF,MAAM,EAAE,UAAU,MAAM,OAAO;AAG/B,QAAM,MAAM;GACV;GACA,YAAY;GACZ,SAAS,CAAC,aAAa,EAAE,QAAQ,UAAU,CAAC,CAAC;GAC9C,CAAC;AAEF,UAAQ,QAAQ,kBAAkB;;CAErC,CAAC"}
@@ -1,3 +0,0 @@
1
- import { t as build_default } from "./build-DBrdh66Y.mjs";
2
-
3
- export { build_default as default };
package/dist/cli.d.mts DELETED
@@ -1 +0,0 @@
1
- export { };
package/dist/cli.mjs DELETED
@@ -1,27 +0,0 @@
1
- import { defineCommand, runMain } from "citty";
2
- import consola from "consola";
3
- import pc from "picocolors";
4
-
5
- //#region src/cli.ts
6
- const version = "0.1.0";
7
- runMain(defineCommand({
8
- meta: {
9
- name: "km",
10
- version,
11
- description: "Kimesh Framework CLI"
12
- },
13
- subCommands: {
14
- dev: () => import("./dev-BS9Wi0ha.mjs").then((m) => m.default),
15
- build: () => import("./build-SbtFzvBZ.mjs").then((m) => m.default),
16
- generate: () => import("./generate-DDtc1Ah6.mjs").then((m) => m.default),
17
- layer: () => import("./layer-C4xuYktL.mjs").then((m) => m.default),
18
- prepare: () => import("./prepare-4Ydu9NNx.mjs").then((m) => m.default)
19
- },
20
- setup() {
21
- consola.log(pc.cyan(`\n 🚀 Kimesh Framework v${version}\n`));
22
- }
23
- }));
24
-
25
- //#endregion
26
- export { };
27
- //# sourceMappingURL=cli.mjs.map
package/dist/cli.mjs.map DELETED
@@ -1 +0,0 @@
1
- {"version":3,"file":"cli.mjs","names":[],"sources":["../src/cli.ts"],"sourcesContent":["import { defineCommand, runMain } from \"citty\";\nimport consola from \"consola\";\nimport pc from \"picocolors\";\n\nconst version = \"0.1.0\";\n\nconst main = defineCommand({\n meta: {\n name: \"km\",\n version,\n description: \"Kimesh Framework CLI\",\n },\n subCommands: {\n dev: () => import(\"./commands/dev\").then((m) => m.default),\n build: () => import(\"./commands/build\").then((m) => m.default),\n generate: () => import(\"./commands/generate\").then((m) => m.default),\n layer: () => import(\"./commands/layer\").then((m) => m.default),\n prepare: () => import(\"./commands/prepare\").then((m) => m.default),\n },\n setup() {\n consola.log(pc.cyan(`\\n 🚀 Kimesh Framework v${version}\\n`));\n },\n});\n\nrunMain(main);\n"],"mappings":";;;;;AAIA,MAAM,UAAU;AAoBhB,QAlBa,cAAc;CACzB,MAAM;EACJ,MAAM;EACN;EACA,aAAa;EACd;CACD,aAAa;EACX,WAAW,OAAO,sBAAkB,MAAM,MAAM,EAAE,QAAQ;EAC1D,aAAa,OAAO,wBAAoB,MAAM,MAAM,EAAE,QAAQ;EAC9D,gBAAgB,OAAO,2BAAuB,MAAM,MAAM,EAAE,QAAQ;EACpE,aAAa,OAAO,wBAAoB,MAAM,MAAM,EAAE,QAAQ;EAC9D,eAAe,OAAO,0BAAsB,MAAM,MAAM,EAAE,QAAQ;EACnE;CACD,QAAQ;AACN,UAAQ,IAAI,GAAG,KAAK,4BAA4B,QAAQ,IAAI,CAAC;;CAEhE,CAAC,CAEW"}
@@ -1,3 +0,0 @@
1
- import { t as dev_default } from "./dev-C9X23BeN.mjs";
2
-
3
- export { dev_default as default };
@@ -1,112 +0,0 @@
1
- import { defineCommand } from "citty";
2
- import { resolve } from "node:path";
3
- import consola from "consola";
4
- import pc from "picocolors";
5
-
6
- //#region src/commands/dev.ts
7
- var dev_default = defineCommand({
8
- meta: {
9
- name: "dev",
10
- description: "Start development server"
11
- },
12
- args: {
13
- port: {
14
- type: "string",
15
- alias: "p",
16
- description: "Server port",
17
- default: "3000"
18
- },
19
- host: {
20
- type: "string",
21
- alias: "h",
22
- description: "Server host"
23
- },
24
- open: {
25
- type: "boolean",
26
- alias: "o",
27
- description: "Open browser on start",
28
- default: false
29
- },
30
- config: {
31
- type: "string",
32
- alias: "c",
33
- description: "Config file path"
34
- },
35
- root: {
36
- type: "string",
37
- alias: "r",
38
- description: "Project root directory"
39
- },
40
- layers: {
41
- type: "string",
42
- alias: "l",
43
- description: "Comma-separated list of layers to enable (e.g., 'cms,auth') or 'all'/'none'"
44
- },
45
- "exclude-layers": {
46
- type: "string",
47
- alias: "x",
48
- description: "Comma-separated list of layers to exclude"
49
- }
50
- },
51
- async run({ args }) {
52
- const root = resolve(args.root || process.cwd());
53
- const { loadConfig } = await import("@kimesh/kit");
54
- const kmConfig = await loadConfig({
55
- root,
56
- configFile: args.config
57
- });
58
- const enabledLayers = parseLayersArg(args.layers);
59
- const excludedLayers = args["exclude-layers"] ? args["exclude-layers"].split(",").map((l) => l.trim()) : [];
60
- consola.info(`Starting ${pc.cyan(kmConfig.name || "Kimesh")} dev server...`);
61
- if (enabledLayers === "all") consola.info(`Layers: ${pc.green("all")}`);
62
- else if (enabledLayers === "none") consola.info(`Layers: ${pc.yellow("none (host only)")}`);
63
- else if (Array.isArray(enabledLayers)) consola.info(`Layers: ${pc.cyan(enabledLayers.join(", "))}`);
64
- if (excludedLayers.length > 0) consola.info(`Excluded: ${pc.yellow(excludedLayers.join(", "))}`);
65
- const { createServer } = await import("vite");
66
- const { kimeshPlugin } = await import("@kimesh/kit");
67
- const port = args.port ? parseInt(args.port, 10) : kmConfig.dev?.port ?? 3e3;
68
- const host = args.host ?? kmConfig.dev?.host ?? "localhost";
69
- const open = args.open ?? kmConfig.dev?.open ?? false;
70
- const server = await createServer({
71
- root,
72
- configFile: false,
73
- plugins: [kimeshPlugin({
74
- config: kmConfig,
75
- layers: {
76
- enabled: enabledLayers,
77
- excluded: excludedLayers
78
- }
79
- })],
80
- server: {
81
- port,
82
- host,
83
- open
84
- }
85
- });
86
- await server.listen();
87
- server.printUrls();
88
- consola.success(`Dev server started!`);
89
- const cleanup = async () => {
90
- consola.info("Shutting down...");
91
- await server.close();
92
- process.exit(0);
93
- };
94
- process.on("SIGINT", cleanup);
95
- process.on("SIGTERM", cleanup);
96
- }
97
- });
98
- /**
99
- * Parse the --layers argument
100
- */
101
- function parseLayersArg(arg) {
102
- const envLayers = process.env.KM_LAYERS;
103
- const layersArg = arg ?? envLayers;
104
- if (!layersArg) return "all";
105
- if (layersArg === "all") return "all";
106
- if (layersArg === "none") return "none";
107
- return layersArg.split(",").map((l) => l.trim()).filter(Boolean);
108
- }
109
-
110
- //#endregion
111
- export { dev_default as t };
112
- //# sourceMappingURL=dev-C9X23BeN.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"dev-C9X23BeN.mjs","names":[],"sources":["../src/commands/dev.ts"],"sourcesContent":["import { defineCommand } from \"citty\";\nimport { resolve } from \"node:path\";\nimport consola from \"consola\";\nimport pc from \"picocolors\";\n\nexport default defineCommand({\n meta: {\n name: \"dev\",\n description: \"Start development server\",\n },\n args: {\n port: {\n type: \"string\",\n alias: \"p\",\n description: \"Server port\",\n default: \"3000\",\n },\n host: {\n type: \"string\",\n alias: \"h\",\n description: \"Server host\",\n },\n open: {\n type: \"boolean\",\n alias: \"o\",\n description: \"Open browser on start\",\n default: false,\n },\n config: {\n type: \"string\",\n alias: \"c\",\n description: \"Config file path\",\n },\n root: {\n type: \"string\",\n alias: \"r\",\n description: \"Project root directory\",\n },\n layers: {\n type: \"string\",\n alias: \"l\",\n description: \"Comma-separated list of layers to enable (e.g., 'cms,auth') or 'all'/'none'\",\n },\n \"exclude-layers\": {\n type: \"string\",\n alias: \"x\",\n description: \"Comma-separated list of layers to exclude\",\n },\n },\n async run({ args }) {\n const root = resolve(args.root || process.cwd());\n\n // Load Kimesh config\n const { loadConfig } = await import(\"@kimesh/kit\");\n const kmConfig = await loadConfig({\n root,\n configFile: args.config,\n });\n\n // Parse layer arguments\n const enabledLayers = parseLayersArg(args.layers);\n const excludedLayers = args[\"exclude-layers\"]\n ? args[\"exclude-layers\"].split(\",\").map((l: string) => l.trim())\n : [];\n\n consola.info(\n `Starting ${pc.cyan(kmConfig.name || \"Kimesh\")} dev server...`\n );\n\n // Log layer configuration\n if (enabledLayers === \"all\") {\n consola.info(`Layers: ${pc.green(\"all\")}`);\n } else if (enabledLayers === \"none\") {\n consola.info(`Layers: ${pc.yellow(\"none (host only)\")}`);\n } else if (Array.isArray(enabledLayers)) {\n consola.info(`Layers: ${pc.cyan(enabledLayers.join(\", \"))}`);\n }\n\n if (excludedLayers.length > 0) {\n consola.info(`Excluded: ${pc.yellow(excludedLayers.join(\", \"))}`);\n }\n\n // Import Vite and Kimesh plugin\n const { createServer } = await import(\"vite\");\n const { kimeshPlugin } = await import(\"@kimesh/kit\");\n\n // Create Vite dev server\n const port = args.port\n ? parseInt(args.port, 10)\n : kmConfig.dev?.port ?? 3000;\n const host = args.host ?? kmConfig.dev?.host ?? \"localhost\";\n const open = args.open ?? kmConfig.dev?.open ?? false;\n\n const server = await createServer({\n root,\n configFile: false, // We handle config ourselves\n plugins: [\n kimeshPlugin({\n config: kmConfig,\n layers: {\n enabled: enabledLayers,\n excluded: excludedLayers,\n },\n }) as any,\n ],\n server: {\n port,\n host,\n open,\n } as any,\n });\n\n await server.listen();\n server.printUrls();\n\n consola.success(`Dev server started!`);\n\n // Handle shutdown\n const cleanup = async () => {\n consola.info(\"Shutting down...\");\n await server.close();\n process.exit(0);\n };\n\n process.on(\"SIGINT\", cleanup);\n process.on(\"SIGTERM\", cleanup);\n },\n});\n\n/**\n * Parse the --layers argument\n */\nfunction parseLayersArg(arg: string | undefined): string[] | \"all\" | \"none\" {\n // Check environment variable first\n const envLayers = process.env.KM_LAYERS;\n const layersArg = arg ?? envLayers;\n\n if (!layersArg) {\n return \"all\";\n }\n\n if (layersArg === \"all\") {\n return \"all\";\n }\n\n if (layersArg === \"none\") {\n return \"none\";\n }\n\n return layersArg.split(\",\").map((l) => l.trim()).filter(Boolean);\n}\n"],"mappings":";;;;;;AAKA,kBAAe,cAAc;CAC3B,MAAM;EACJ,MAAM;EACN,aAAa;EACd;CACD,MAAM;EACJ,MAAM;GACJ,MAAM;GACN,OAAO;GACP,aAAa;GACb,SAAS;GACV;EACD,MAAM;GACJ,MAAM;GACN,OAAO;GACP,aAAa;GACd;EACD,MAAM;GACJ,MAAM;GACN,OAAO;GACP,aAAa;GACb,SAAS;GACV;EACD,QAAQ;GACN,MAAM;GACN,OAAO;GACP,aAAa;GACd;EACD,MAAM;GACJ,MAAM;GACN,OAAO;GACP,aAAa;GACd;EACD,QAAQ;GACN,MAAM;GACN,OAAO;GACP,aAAa;GACd;EACD,kBAAkB;GAChB,MAAM;GACN,OAAO;GACP,aAAa;GACd;EACF;CACD,MAAM,IAAI,EAAE,QAAQ;EAClB,MAAM,OAAO,QAAQ,KAAK,QAAQ,QAAQ,KAAK,CAAC;EAGhD,MAAM,EAAE,eAAe,MAAM,OAAO;EACpC,MAAM,WAAW,MAAM,WAAW;GAChC;GACA,YAAY,KAAK;GAClB,CAAC;EAGF,MAAM,gBAAgB,eAAe,KAAK,OAAO;EACjD,MAAM,iBAAiB,KAAK,oBACxB,KAAK,kBAAkB,MAAM,IAAI,CAAC,KAAK,MAAc,EAAE,MAAM,CAAC,GAC9D,EAAE;AAEN,UAAQ,KACN,YAAY,GAAG,KAAK,SAAS,QAAQ,SAAS,CAAC,gBAChD;AAGD,MAAI,kBAAkB,MACpB,SAAQ,KAAK,WAAW,GAAG,MAAM,MAAM,GAAG;WACjC,kBAAkB,OAC3B,SAAQ,KAAK,WAAW,GAAG,OAAO,mBAAmB,GAAG;WAC/C,MAAM,QAAQ,cAAc,CACrC,SAAQ,KAAK,WAAW,GAAG,KAAK,cAAc,KAAK,KAAK,CAAC,GAAG;AAG9D,MAAI,eAAe,SAAS,EAC1B,SAAQ,KAAK,aAAa,GAAG,OAAO,eAAe,KAAK,KAAK,CAAC,GAAG;EAInE,MAAM,EAAE,iBAAiB,MAAM,OAAO;EACtC,MAAM,EAAE,iBAAiB,MAAM,OAAO;EAGtC,MAAM,OAAO,KAAK,OACd,SAAS,KAAK,MAAM,GAAG,GACvB,SAAS,KAAK,QAAQ;EAC1B,MAAM,OAAO,KAAK,QAAQ,SAAS,KAAK,QAAQ;EAChD,MAAM,OAAO,KAAK,QAAQ,SAAS,KAAK,QAAQ;EAEhD,MAAM,SAAS,MAAM,aAAa;GAChC;GACA,YAAY;GACZ,SAAS,CACP,aAAa;IACX,QAAQ;IACR,QAAQ;KACN,SAAS;KACT,UAAU;KACX;IACF,CAAC,CACH;GACD,QAAQ;IACN;IACA;IACA;IACD;GACF,CAAC;AAEF,QAAM,OAAO,QAAQ;AACrB,SAAO,WAAW;AAElB,UAAQ,QAAQ,sBAAsB;EAGtC,MAAM,UAAU,YAAY;AAC1B,WAAQ,KAAK,mBAAmB;AAChC,SAAM,OAAO,OAAO;AACpB,WAAQ,KAAK,EAAE;;AAGjB,UAAQ,GAAG,UAAU,QAAQ;AAC7B,UAAQ,GAAG,WAAW,QAAQ;;CAEjC,CAAC;;;;AAKF,SAAS,eAAe,KAAoD;CAE1E,MAAM,YAAY,QAAQ,IAAI;CAC9B,MAAM,YAAY,OAAO;AAEzB,KAAI,CAAC,UACH,QAAO;AAGT,KAAI,cAAc,MAChB,QAAO;AAGT,KAAI,cAAc,OAChB,QAAO;AAGT,QAAO,UAAU,MAAM,IAAI,CAAC,KAAK,MAAM,EAAE,MAAM,CAAC,CAAC,OAAO,QAAQ"}
@@ -1,25 +0,0 @@
1
- import { defineCommand } from "citty";
2
- import consola from "consola";
3
- import pc from "picocolors";
4
-
5
- //#region src/commands/generate.ts
6
- var generate_default = defineCommand({
7
- meta: {
8
- name: "generate",
9
- description: "Generate routes and types"
10
- },
11
- args: { root: {
12
- type: "string",
13
- alias: "r",
14
- description: "Project root directory"
15
- } },
16
- async run({ args }) {
17
- consola.info(`Generating routes and types...`);
18
- consola.warn(pc.yellow("Route generation will be available in Phase 2"));
19
- consola.success(`Generation complete!`);
20
- }
21
- });
22
-
23
- //#endregion
24
- export { generate_default as t };
25
- //# sourceMappingURL=generate-BEf3_Td5.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"generate-BEf3_Td5.mjs","names":[],"sources":["../src/commands/generate.ts"],"sourcesContent":["import { defineCommand } from \"citty\";\nimport consola from \"consola\";\nimport pc from \"picocolors\";\n\nexport default defineCommand({\n meta: {\n name: \"generate\",\n description: \"Generate routes and types\",\n },\n args: {\n root: {\n type: \"string\",\n alias: \"r\",\n description: \"Project root directory\",\n },\n },\n async run({ args }) {\n consola.info(`Generating routes and types...`);\n\n // TODO: Implement in Phase 2 - File-based routing\n consola.warn(pc.yellow(\"Route generation will be available in Phase 2\"));\n\n consola.success(`Generation complete!`);\n },\n});\n"],"mappings":";;;;;AAIA,uBAAe,cAAc;CAC3B,MAAM;EACJ,MAAM;EACN,aAAa;EACd;CACD,MAAM,EACJ,MAAM;EACJ,MAAM;EACN,OAAO;EACP,aAAa;EACd,EACF;CACD,MAAM,IAAI,EAAE,QAAQ;AAClB,UAAQ,KAAK,iCAAiC;AAG9C,UAAQ,KAAK,GAAG,OAAO,gDAAgD,CAAC;AAExE,UAAQ,QAAQ,uBAAuB;;CAE1C,CAAC"}
@@ -1,3 +0,0 @@
1
- import { t as generate_default } from "./generate-BEf3_Td5.mjs";
2
-
3
- export { generate_default as default };
package/dist/index.d.mts DELETED
@@ -1,69 +0,0 @@
1
- import * as citty0 from "citty";
2
- import { KimeshConfig, KimeshPluginOptions, LoadConfigOptions } from "@kimesh/kit";
3
-
4
- //#region src/commands/dev.d.ts
5
- declare const _default$1: citty0.CommandDef<{
6
- port: {
7
- type: "string";
8
- alias: string;
9
- description: string;
10
- default: string;
11
- };
12
- host: {
13
- type: "string";
14
- alias: string;
15
- description: string;
16
- };
17
- open: {
18
- type: "boolean";
19
- alias: string;
20
- description: string;
21
- default: false;
22
- };
23
- config: {
24
- type: "string";
25
- alias: string;
26
- description: string;
27
- };
28
- root: {
29
- type: "string";
30
- alias: string;
31
- description: string;
32
- };
33
- layers: {
34
- type: "string";
35
- alias: string;
36
- description: string;
37
- };
38
- "exclude-layers": {
39
- type: "string";
40
- alias: string;
41
- description: string;
42
- };
43
- }>;
44
- //#endregion
45
- //#region src/commands/build.d.ts
46
- declare const _default: citty0.CommandDef<{
47
- root: {
48
- type: "string";
49
- alias: string;
50
- description: string;
51
- };
52
- config: {
53
- type: "string";
54
- alias: string;
55
- description: string;
56
- };
57
- }>;
58
- //#endregion
59
- //#region src/commands/generate.d.ts
60
- declare const _default$2: citty0.CommandDef<{
61
- root: {
62
- type: "string";
63
- alias: string;
64
- description: string;
65
- };
66
- }>;
67
- //#endregion
68
- export { type KimeshConfig, type KimeshPluginOptions, type LoadConfigOptions, _default as buildCommand, _default$1 as devCommand, _default$2 as generateCommand };
69
- //# sourceMappingURL=index.d.mts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.mts","names":[],"sources":["../src/commands/dev.ts","../src/commands/build.ts","../src/commands/generate.ts"],"mappings":""}
package/dist/index.mjs DELETED
@@ -1,5 +0,0 @@
1
- import { t as dev_default } from "./dev-C9X23BeN.mjs";
2
- import { t as build_default } from "./build-DBrdh66Y.mjs";
3
- import { t as generate_default } from "./generate-BEf3_Td5.mjs";
4
-
5
- export { build_default as buildCommand, dev_default as devCommand, generate_default as generateCommand };
@@ -1,268 +0,0 @@
1
- import { defineCommand } from "citty";
2
- import { join, resolve } from "node:path";
3
- import consola from "consola";
4
- import pc from "picocolors";
5
- import * as fs from "node:fs";
6
-
7
- //#region src/commands/layer.ts
8
- var layer_default = defineCommand({
9
- meta: {
10
- name: "layer",
11
- description: "Manage Kimesh layers"
12
- },
13
- subCommands: {
14
- list: defineCommand({
15
- meta: {
16
- name: "list",
17
- description: "List available layers"
18
- },
19
- args: { root: {
20
- type: "string",
21
- alias: "r",
22
- description: "Project root directory"
23
- } },
24
- async run({ args }) {
25
- const root = resolve(typeof args.root === "string" ? args.root : process.cwd());
26
- const { loadConfig } = await import("@kimesh/kit");
27
- const kmConfig = await loadConfig({ root });
28
- consola.info(`${pc.cyan("Available layers:")}\n`);
29
- const extendsLayers = kmConfig.extends || [];
30
- if (extendsLayers.length > 0) {
31
- consola.log(pc.bold("From config (extends):"));
32
- for (const layer of extendsLayers) {
33
- const name = typeof layer === "string" ? layer : layer.name;
34
- consola.log(` ${pc.green("✓")} ${name}`);
35
- }
36
- consola.log("");
37
- }
38
- const layersDir = join(root, "layers");
39
- if (fs.existsSync(layersDir)) {
40
- const layers = fs.readdirSync(layersDir, { withFileTypes: true }).filter((e) => e.isDirectory());
41
- if (layers.length > 0) {
42
- consola.log(pc.bold("Auto-discovered (layers/):"));
43
- for (const layer of layers) {
44
- const layerPath = join(layersDir, layer.name);
45
- const hasConfig = fs.existsSync(join(layerPath, "kimesh.config.ts"));
46
- const hasRoutes = fs.existsSync(join(layerPath, "routes"));
47
- const hasComponents = fs.existsSync(join(layerPath, "components"));
48
- const hasComposables = fs.existsSync(join(layerPath, "composables"));
49
- const features = [
50
- hasConfig ? "config" : null,
51
- hasRoutes ? "routes" : null,
52
- hasComponents ? "components" : null,
53
- hasComposables ? "composables" : null
54
- ].filter(Boolean).join(", ");
55
- consola.log(` ${pc.green("✓")} ${layer.name} ${pc.dim(`(${features})`)}`);
56
- }
57
- }
58
- } else consola.log(pc.dim("No layers/ directory found"));
59
- }
60
- }),
61
- info: defineCommand({
62
- meta: {
63
- name: "info",
64
- description: "Show detailed information about a layer"
65
- },
66
- args: {
67
- name: {
68
- type: "positional",
69
- description: "Layer name",
70
- required: true
71
- },
72
- root: {
73
- type: "string",
74
- alias: "r",
75
- description: "Project root directory"
76
- }
77
- },
78
- async run({ args }) {
79
- const root = resolve(typeof args.root === "string" ? args.root : process.cwd());
80
- const layerName = args.name;
81
- const layerPath = join(root, "layers", layerName);
82
- if (!fs.existsSync(layerPath)) {
83
- consola.error(`Layer not found: ${layerName}`);
84
- consola.info(`Checked: ${layerPath}`);
85
- process.exit(1);
86
- }
87
- consola.log(`\n${pc.cyan(pc.bold(`Layer: ${layerName}`))}\n`);
88
- consola.log(`${pc.bold("Path:")} ${layerPath}`);
89
- const structure = [];
90
- const checkDir = (dir, label) => {
91
- const fullPath = join(layerPath, dir);
92
- if (fs.existsSync(fullPath)) {
93
- const files = fs.readdirSync(fullPath);
94
- structure.push(`${label}: ${files.length} files`);
95
- }
96
- };
97
- checkDir("routes", "Routes");
98
- checkDir("components", "Components");
99
- checkDir("composables", "Composables");
100
- checkDir("utils", "Utilities");
101
- checkDir("stores", "Stores");
102
- if (structure.length > 0) {
103
- consola.log(`\n${pc.bold("Structure:")}`);
104
- for (const item of structure) consola.log(` ${pc.green("•")} ${item}`);
105
- }
106
- const configPath = join(layerPath, "kimesh.config.ts");
107
- if (fs.existsSync(configPath)) consola.log(`\n${pc.bold("Config:")} ${pc.green("Found")}`);
108
- }
109
- }),
110
- create: defineCommand({
111
- meta: {
112
- name: "create",
113
- description: "Create a new layer scaffold"
114
- },
115
- args: {
116
- name: {
117
- type: "positional",
118
- description: "Layer name",
119
- required: true
120
- },
121
- root: {
122
- type: "string",
123
- alias: "r",
124
- description: "Project root directory"
125
- },
126
- basePath: {
127
- type: "string",
128
- alias: "b",
129
- description: "Base path for routes (e.g., /cms)"
130
- }
131
- },
132
- async run({ args }) {
133
- const root = resolve(typeof args.root === "string" ? args.root : process.cwd());
134
- const layerName = args.name;
135
- const basePath = args.basePath || `/${layerName}`;
136
- const layerPath = join(join(root, "layers"), layerName);
137
- if (fs.existsSync(layerPath)) {
138
- consola.error(`Layer already exists: ${layerPath}`);
139
- process.exit(1);
140
- }
141
- consola.info(`Creating layer: ${pc.cyan(layerName)}`);
142
- for (const dir of [
143
- "",
144
- "routes",
145
- "components",
146
- "composables",
147
- "utils",
148
- "stores"
149
- ]) {
150
- const dirPath = join(layerPath, dir);
151
- fs.mkdirSync(dirPath, { recursive: true });
152
- consola.log(` ${pc.green("+")} ${dir || layerName}/`);
153
- }
154
- const configContent = `import { defineKmConfig } from '@kimesh/kit'
155
-
156
- export default defineKmConfig({
157
- name: '${layerName}',
158
-
159
- // Base path for all routes in this layer
160
- basePath: '${basePath}',
161
-
162
- // Routes configuration
163
- routes: {
164
- basePath: '${basePath}',
165
- folder: 'routes',
166
- },
167
-
168
- // Component configuration
169
- components: {
170
- dirs: ['components'],
171
- prefix: '${toPascalCase(layerName)}',
172
- },
173
-
174
- // Composable configuration
175
- composables: {
176
- dirs: ['composables'],
177
- },
178
- })
179
- `;
180
- fs.writeFileSync(join(layerPath, "kimesh.config.ts"), configContent);
181
- consola.log(` ${pc.green("+")} kimesh.config.ts`);
182
- const indexRouteContent = `<script setup lang="ts">
183
- // ${layerName} layer index route
184
- <\/script>
185
-
186
- <template>
187
- <div class="${layerName}-index">
188
- <h1>${toPascalCase(layerName)} Layer</h1>
189
- <p>Welcome to the ${layerName} layer.</p>
190
- </div>
191
- </template>
192
- `;
193
- fs.writeFileSync(join(layerPath, "routes", "index.vue"), indexRouteContent);
194
- consola.log(` ${pc.green("+")} routes/index.vue`);
195
- const layoutContent = `<script setup lang="ts">
196
- // ${layerName} layer layout
197
- <\/script>
198
-
199
- <template>
200
- <div class="${layerName}-layout">
201
- <slot />
202
- </div>
203
- </template>
204
- `;
205
- fs.writeFileSync(join(layerPath, "routes", "_layout.vue"), layoutContent);
206
- consola.log(` ${pc.green("+")} routes/_layout.vue`);
207
- consola.success(`\nLayer created at: ${pc.cyan(layerPath)}`);
208
- consola.info(`\nNext steps:`);
209
- consola.log(` 1. Add to your config: extends: ['./${join("layers", layerName)}']`);
210
- consola.log(` 2. Start dev server: ${pc.cyan("km dev")}`);
211
- consola.log(` 3. Visit: ${pc.cyan(`http://localhost:3000${basePath}`)}`);
212
- }
213
- }),
214
- validate: defineCommand({
215
- meta: {
216
- name: "validate",
217
- description: "Validate layer configurations"
218
- },
219
- args: { root: {
220
- type: "string",
221
- alias: "r",
222
- description: "Project root directory"
223
- } },
224
- async run({ args }) {
225
- const root = resolve(typeof args.root === "string" ? args.root : process.cwd());
226
- consola.info("Validating layers...\n");
227
- const layersDir = join(root, "layers");
228
- let errors = 0;
229
- let warnings = 0;
230
- if (!fs.existsSync(layersDir)) {
231
- consola.info("No layers/ directory found");
232
- return;
233
- }
234
- const layers = fs.readdirSync(layersDir, { withFileTypes: true }).filter((e) => e.isDirectory());
235
- for (const layer of layers) {
236
- const layerPath = join(layersDir, layer.name);
237
- consola.log(`${pc.bold(layer.name)}:`);
238
- const hasRoutes = fs.existsSync(join(layerPath, "routes"));
239
- const hasComponents = fs.existsSync(join(layerPath, "components"));
240
- const hasComposables = fs.existsSync(join(layerPath, "composables"));
241
- const hasConfig = fs.existsSync(join(layerPath, "kimesh.config.ts"));
242
- if (!hasRoutes && !hasComponents && !hasComposables) {
243
- consola.log(` ${pc.yellow("⚠")} No routes/, components/, or composables/ directory`);
244
- warnings++;
245
- } else consola.log(` ${pc.green("✓")} Valid layer structure`);
246
- if (!hasConfig) consola.log(` ${pc.dim("○")} No kimesh.config.ts (using defaults)`);
247
- else consola.log(` ${pc.green("✓")} Has kimesh.config.ts`);
248
- consola.log("");
249
- }
250
- if (errors > 0) {
251
- consola.error(`\n${errors} error(s) found`);
252
- process.exit(1);
253
- } else if (warnings > 0) consola.warn(`\n${warnings} warning(s)`);
254
- else consola.success("\nAll layers valid!");
255
- }
256
- })
257
- }
258
- });
259
- /**
260
- * Convert string to PascalCase
261
- */
262
- function toPascalCase(str) {
263
- return str.split(/[-_]/).map((part) => part.charAt(0).toUpperCase() + part.slice(1).toLowerCase()).join("");
264
- }
265
-
266
- //#endregion
267
- export { layer_default as default };
268
- //# sourceMappingURL=layer-C4xuYktL.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"layer-C4xuYktL.mjs","names":[],"sources":["../src/commands/layer.ts"],"sourcesContent":["import { defineCommand } from \"citty\";\nimport { resolve, join } from \"node:path\";\nimport * as fs from \"node:fs\";\nimport consola from \"consola\";\nimport pc from \"picocolors\";\n\nexport default defineCommand({\n meta: {\n name: \"layer\",\n description: \"Manage Kimesh layers\",\n },\n subCommands: {\n list: defineCommand({\n meta: {\n name: \"list\",\n description: \"List available layers\",\n },\n args: {\n root: {\n type: \"string\",\n alias: \"r\",\n description: \"Project root directory\",\n },\n },\n async run({ args }) {\n const root = resolve(typeof args.root === 'string' ? args.root : process.cwd());\n\n // Load Kimesh config\n const { loadConfig } = await import(\"@kimesh/kit\");\n const kmConfig = await loadConfig({ root });\n\n consola.info(`${pc.cyan(\"Available layers:\")}\\n`);\n\n // Check extends array in config\n const extendsLayers = (kmConfig as any).extends || [];\n\n if (extendsLayers.length > 0) {\n consola.log(pc.bold(\"From config (extends):\"));\n for (const layer of extendsLayers) {\n const name = typeof layer === \"string\" ? layer : layer.name;\n consola.log(` ${pc.green(\"✓\")} ${name}`);\n }\n consola.log(\"\");\n }\n\n // Check layers/ directory\n const layersDir = join(root, \"layers\");\n if (fs.existsSync(layersDir)) {\n const entries = fs.readdirSync(layersDir, { withFileTypes: true });\n const layers = entries.filter((e) => e.isDirectory());\n\n if (layers.length > 0) {\n consola.log(pc.bold(\"Auto-discovered (layers/):\"));\n for (const layer of layers) {\n const layerPath = join(layersDir, layer.name);\n const hasConfig = fs.existsSync(\n join(layerPath, \"kimesh.config.ts\")\n );\n const hasRoutes = fs.existsSync(join(layerPath, \"routes\"));\n const hasComponents = fs.existsSync(\n join(layerPath, \"components\")\n );\n const hasComposables = fs.existsSync(\n join(layerPath, \"composables\")\n );\n\n const features = [\n hasConfig ? \"config\" : null,\n hasRoutes ? \"routes\" : null,\n hasComponents ? \"components\" : null,\n hasComposables ? \"composables\" : null,\n ]\n .filter(Boolean)\n .join(\", \");\n\n consola.log(\n ` ${pc.green(\"✓\")} ${layer.name} ${pc.dim(`(${features})`)}`\n );\n }\n }\n } else {\n consola.log(pc.dim(\"No layers/ directory found\"));\n }\n },\n }),\n\n info: defineCommand({\n meta: {\n name: \"info\",\n description: \"Show detailed information about a layer\",\n },\n args: {\n name: {\n type: \"positional\",\n description: \"Layer name\",\n required: true,\n },\n root: {\n type: \"string\",\n alias: \"r\",\n description: \"Project root directory\",\n },\n },\n async run({ args }) {\n const root = resolve(typeof args.root === 'string' ? args.root : process.cwd());\n const layerName = args.name as string;\n\n // Try to find the layer\n const layerPath = join(root, \"layers\", layerName);\n\n if (!fs.existsSync(layerPath)) {\n consola.error(`Layer not found: ${layerName}`);\n consola.info(`Checked: ${layerPath}`);\n process.exit(1);\n }\n\n consola.log(`\\n${pc.cyan(pc.bold(`Layer: ${layerName}`))}\\n`);\n consola.log(`${pc.bold(\"Path:\")} ${layerPath}`);\n\n // Check structure\n const structure: string[] = [];\n const checkDir = (dir: string, label: string) => {\n const fullPath = join(layerPath, dir);\n if (fs.existsSync(fullPath)) {\n const files = fs.readdirSync(fullPath);\n structure.push(`${label}: ${files.length} files`);\n }\n };\n\n checkDir(\"routes\", \"Routes\");\n checkDir(\"components\", \"Components\");\n checkDir(\"composables\", \"Composables\");\n checkDir(\"utils\", \"Utilities\");\n checkDir(\"stores\", \"Stores\");\n\n if (structure.length > 0) {\n consola.log(`\\n${pc.bold(\"Structure:\")}`);\n for (const item of structure) {\n consola.log(` ${pc.green(\"•\")} ${item}`);\n }\n }\n\n // Check for config file\n const configPath = join(layerPath, \"kimesh.config.ts\");\n if (fs.existsSync(configPath)) {\n consola.log(`\\n${pc.bold(\"Config:\")} ${pc.green(\"Found\")}`);\n }\n },\n }),\n\n create: defineCommand({\n meta: {\n name: \"create\",\n description: \"Create a new layer scaffold\",\n },\n args: {\n name: {\n type: \"positional\",\n description: \"Layer name\",\n required: true,\n },\n root: {\n type: \"string\",\n alias: \"r\",\n description: \"Project root directory\",\n },\n basePath: {\n type: \"string\",\n alias: \"b\",\n description: \"Base path for routes (e.g., /cms)\",\n },\n },\n async run({ args }) {\n const root = resolve(typeof args.root === 'string' ? args.root : process.cwd());\n const layerName = args.name as string;\n const basePath = args.basePath || `/${layerName}`;\n\n const layersDir = join(root, \"layers\");\n const layerPath = join(layersDir, layerName);\n\n // Check if layer already exists\n if (fs.existsSync(layerPath)) {\n consola.error(`Layer already exists: ${layerPath}`);\n process.exit(1);\n }\n\n consola.info(`Creating layer: ${pc.cyan(layerName)}`);\n\n // Create directory structure\n const dirs = [\n \"\",\n \"routes\",\n \"components\",\n \"composables\",\n \"utils\",\n \"stores\",\n ];\n\n for (const dir of dirs) {\n const dirPath = join(layerPath, dir);\n fs.mkdirSync(dirPath, { recursive: true });\n consola.log(` ${pc.green(\"+\")} ${dir || layerName}/`);\n }\n\n // Create kimesh.config.ts\n const configContent = `import { defineKmConfig } from '@kimesh/kit'\n\nexport default defineKmConfig({\n name: '${layerName}',\n\n // Base path for all routes in this layer\n basePath: '${basePath}',\n\n // Routes configuration\n routes: {\n basePath: '${basePath}',\n folder: 'routes',\n },\n\n // Component configuration\n components: {\n dirs: ['components'],\n prefix: '${toPascalCase(layerName)}',\n },\n\n // Composable configuration\n composables: {\n dirs: ['composables'],\n },\n})\n`;\n fs.writeFileSync(join(layerPath, \"kimesh.config.ts\"), configContent);\n consola.log(` ${pc.green(\"+\")} kimesh.config.ts`);\n\n // Create index route\n const indexRouteContent = `<script setup lang=\"ts\">\n// ${layerName} layer index route\n</script>\n\n<template>\n <div class=\"${layerName}-index\">\n <h1>${toPascalCase(layerName)} Layer</h1>\n <p>Welcome to the ${layerName} layer.</p>\n </div>\n</template>\n`;\n fs.writeFileSync(\n join(layerPath, \"routes\", \"index.vue\"),\n indexRouteContent\n );\n consola.log(` ${pc.green(\"+\")} routes/index.vue`);\n\n // Create layout\n const layoutContent = `<script setup lang=\"ts\">\n// ${layerName} layer layout\n</script>\n\n<template>\n <div class=\"${layerName}-layout\">\n <slot />\n </div>\n</template>\n`;\n fs.writeFileSync(\n join(layerPath, \"routes\", \"_layout.vue\"),\n layoutContent\n );\n consola.log(` ${pc.green(\"+\")} routes/_layout.vue`);\n\n consola.success(`\\nLayer created at: ${pc.cyan(layerPath)}`);\n consola.info(`\\nNext steps:`);\n consola.log(` 1. Add to your config: extends: ['./${join(\"layers\", layerName)}']`);\n consola.log(` 2. Start dev server: ${pc.cyan(\"km dev\")}`);\n consola.log(` 3. Visit: ${pc.cyan(`http://localhost:3000${basePath}`)}`);\n },\n }),\n\n validate: defineCommand({\n meta: {\n name: \"validate\",\n description: \"Validate layer configurations\",\n },\n args: {\n root: {\n type: \"string\",\n alias: \"r\",\n description: \"Project root directory\",\n },\n },\n async run({ args }) {\n const root = resolve(typeof args.root === 'string' ? args.root : process.cwd());\n\n consola.info(\"Validating layers...\\n\");\n\n const layersDir = join(root, \"layers\");\n let errors = 0;\n let warnings = 0;\n\n if (!fs.existsSync(layersDir)) {\n consola.info(\"No layers/ directory found\");\n return;\n }\n\n const entries = fs.readdirSync(layersDir, { withFileTypes: true });\n const layers = entries.filter((e) => e.isDirectory());\n\n for (const layer of layers) {\n const layerPath = join(layersDir, layer.name);\n consola.log(`${pc.bold(layer.name)}:`);\n\n // Check for valid structure\n const hasRoutes = fs.existsSync(join(layerPath, \"routes\"));\n const hasComponents = fs.existsSync(join(layerPath, \"components\"));\n const hasComposables = fs.existsSync(join(layerPath, \"composables\"));\n const hasConfig = fs.existsSync(join(layerPath, \"kimesh.config.ts\"));\n\n if (!hasRoutes && !hasComponents && !hasComposables) {\n consola.log(` ${pc.yellow(\"⚠\")} No routes/, components/, or composables/ directory`);\n warnings++;\n } else {\n consola.log(` ${pc.green(\"✓\")} Valid layer structure`);\n }\n\n if (!hasConfig) {\n consola.log(` ${pc.dim(\"○\")} No kimesh.config.ts (using defaults)`);\n } else {\n consola.log(` ${pc.green(\"✓\")} Has kimesh.config.ts`);\n }\n\n consola.log(\"\");\n }\n\n if (errors > 0) {\n consola.error(`\\n${errors} error(s) found`);\n process.exit(1);\n } else if (warnings > 0) {\n consola.warn(`\\n${warnings} warning(s)`);\n } else {\n consola.success(\"\\nAll layers valid!\");\n }\n },\n }),\n },\n});\n\n/**\n * Convert string to PascalCase\n */\nfunction toPascalCase(str: string): string {\n return str\n .split(/[-_]/)\n .map((part) => part.charAt(0).toUpperCase() + part.slice(1).toLowerCase())\n .join(\"\");\n}\n"],"mappings":"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"}
@@ -1,60 +0,0 @@
1
- import { defineCommand } from "citty";
2
- import { resolve } from "node:path";
3
- import consola from "consola";
4
- import pc from "picocolors";
5
-
6
- //#region src/commands/prepare.ts
7
- var prepare_default = defineCommand({
8
- meta: {
9
- name: "prepare",
10
- description: "Generate .kimesh directory for TypeScript support"
11
- },
12
- args: {
13
- root: {
14
- type: "string",
15
- alias: "r",
16
- description: "Project root directory"
17
- },
18
- config: {
19
- type: "string",
20
- alias: "c",
21
- description: "Config file path"
22
- },
23
- verbose: {
24
- type: "boolean",
25
- alias: "v",
26
- description: "Enable verbose logging",
27
- default: false
28
- }
29
- },
30
- async run({ args }) {
31
- const root = resolve(args.root || process.cwd());
32
- const startTime = Date.now();
33
- consola.info(`Preparing ${pc.cyan(root)}...`);
34
- const { prepare } = await import("@kimesh/kit");
35
- try {
36
- const result = await prepare({
37
- root,
38
- configFile: args.config,
39
- verbose: args.verbose
40
- });
41
- const duration = Date.now() - startTime;
42
- consola.success(`Prepared in ${pc.cyan(`${duration}ms`)}`);
43
- consola.info(` ${pc.gray("Build directory:")} ${pc.cyan(result.buildDir)}`);
44
- consola.info(` ${pc.gray("Layers:")} ${pc.cyan(result.layerCount.toString())}`);
45
- consola.info(` ${pc.gray("Aliases:")} ${pc.cyan(result.aliasCount.toString())}`);
46
- consola.info(` ${pc.gray("Generated files:")} ${pc.cyan(result.generatedFiles.join(", "))}`);
47
- consola.log("");
48
- consola.info(`${pc.green("✓")} TypeScript is now ready! Your IDE should recognize path aliases.`);
49
- consola.log("");
50
- consola.info(`${pc.gray("Tip:")} Make sure your ${pc.cyan("tsconfig.json")} extends ${pc.cyan(".kimesh/tsconfig.json")}`);
51
- } catch (error) {
52
- consola.error("Failed to prepare project:", error);
53
- process.exit(1);
54
- }
55
- }
56
- });
57
-
58
- //#endregion
59
- export { prepare_default as default };
60
- //# sourceMappingURL=prepare-4Ydu9NNx.mjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"prepare-4Ydu9NNx.mjs","names":[],"sources":["../src/commands/prepare.ts"],"sourcesContent":["import { defineCommand } from \"citty\";\nimport { resolve } from \"node:path\";\nimport consola from \"consola\";\nimport pc from \"picocolors\";\n\nexport default defineCommand({\n meta: {\n name: \"prepare\",\n description: \"Generate .kimesh directory for TypeScript support\",\n },\n args: {\n root: {\n type: \"string\",\n alias: \"r\",\n description: \"Project root directory\",\n },\n config: {\n type: \"string\",\n alias: \"c\",\n description: \"Config file path\",\n },\n verbose: {\n type: \"boolean\",\n alias: \"v\",\n description: \"Enable verbose logging\",\n default: false,\n },\n },\n async run({ args }) {\n const root = resolve(args.root || process.cwd());\n const startTime = Date.now();\n\n consola.info(`Preparing ${pc.cyan(root)}...`);\n\n // Import prepare function from kit\n const { prepare } = await import(\"@kimesh/kit\");\n\n try {\n const result = await prepare({\n root,\n configFile: args.config,\n verbose: args.verbose,\n });\n\n const duration = Date.now() - startTime;\n\n consola.success(\n `Prepared in ${pc.cyan(`${duration}ms`)}`\n );\n\n consola.info(\n ` ${pc.gray(\"Build directory:\")} ${pc.cyan(result.buildDir)}`\n );\n consola.info(\n ` ${pc.gray(\"Layers:\")} ${pc.cyan(result.layerCount.toString())}`\n );\n consola.info(\n ` ${pc.gray(\"Aliases:\")} ${pc.cyan(result.aliasCount.toString())}`\n );\n consola.info(\n ` ${pc.gray(\"Generated files:\")} ${pc.cyan(result.generatedFiles.join(\", \"))}`\n );\n\n consola.log(\"\");\n consola.info(\n `${pc.green(\"✓\")} TypeScript is now ready! Your IDE should recognize path aliases.`\n );\n consola.log(\"\");\n consola.info(\n `${pc.gray(\"Tip:\")} Make sure your ${pc.cyan(\"tsconfig.json\")} extends ${pc.cyan(\".kimesh/tsconfig.json\")}`\n );\n } catch (error) {\n consola.error(\"Failed to prepare project:\", error);\n process.exit(1);\n }\n },\n});\n"],"mappings":";;;;;;AAKA,sBAAe,cAAc;CAC3B,MAAM;EACJ,MAAM;EACN,aAAa;EACd;CACD,MAAM;EACJ,MAAM;GACJ,MAAM;GACN,OAAO;GACP,aAAa;GACd;EACD,QAAQ;GACN,MAAM;GACN,OAAO;GACP,aAAa;GACd;EACD,SAAS;GACP,MAAM;GACN,OAAO;GACP,aAAa;GACb,SAAS;GACV;EACF;CACD,MAAM,IAAI,EAAE,QAAQ;EAClB,MAAM,OAAO,QAAQ,KAAK,QAAQ,QAAQ,KAAK,CAAC;EAChD,MAAM,YAAY,KAAK,KAAK;AAE5B,UAAQ,KAAK,aAAa,GAAG,KAAK,KAAK,CAAC,KAAK;EAG7C,MAAM,EAAE,YAAY,MAAM,OAAO;AAEjC,MAAI;GACF,MAAM,SAAS,MAAM,QAAQ;IAC3B;IACA,YAAY,KAAK;IACjB,SAAS,KAAK;IACf,CAAC;GAEF,MAAM,WAAW,KAAK,KAAK,GAAG;AAE9B,WAAQ,QACN,eAAe,GAAG,KAAK,GAAG,SAAS,IAAI,GACxC;AAED,WAAQ,KACN,KAAK,GAAG,KAAK,mBAAmB,CAAC,GAAG,GAAG,KAAK,OAAO,SAAS,GAC7D;AACD,WAAQ,KACN,KAAK,GAAG,KAAK,UAAU,CAAC,GAAG,GAAG,KAAK,OAAO,WAAW,UAAU,CAAC,GACjE;AACD,WAAQ,KACN,KAAK,GAAG,KAAK,WAAW,CAAC,GAAG,GAAG,KAAK,OAAO,WAAW,UAAU,CAAC,GAClE;AACD,WAAQ,KACN,KAAK,GAAG,KAAK,mBAAmB,CAAC,GAAG,GAAG,KAAK,OAAO,eAAe,KAAK,KAAK,CAAC,GAC9E;AAED,WAAQ,IAAI,GAAG;AACf,WAAQ,KACN,GAAG,GAAG,MAAM,IAAI,CAAC,mEAClB;AACD,WAAQ,IAAI,GAAG;AACf,WAAQ,KACN,GAAG,GAAG,KAAK,OAAO,CAAC,kBAAkB,GAAG,KAAK,gBAAgB,CAAC,WAAW,GAAG,KAAK,wBAAwB,GAC1G;WACM,OAAO;AACd,WAAQ,MAAM,8BAA8B,MAAM;AAClD,WAAQ,KAAK,EAAE;;;CAGpB,CAAC"}