@sigx/cli 0.1.1 → 0.1.2

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/LICENSE ADDED
@@ -0,0 +1,21 @@
1
+ MIT License
2
+
3
+ Copyright (c) 2025-2026 Andreas Ekdahl
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
package/dist/cli.js CHANGED
File without changes
@@ -69,6 +69,43 @@ var lynxStylingOptions = [{
69
69
  label: "Tailwind CSS",
70
70
  description: "Tailwind with Lynx preset"
71
71
  }];
72
+ var TEXT_EXTS = new Set([
73
+ "ts",
74
+ "tsx",
75
+ "js",
76
+ "jsx",
77
+ "mjs",
78
+ "cjs",
79
+ "mts",
80
+ "cts",
81
+ "json",
82
+ "json5",
83
+ "jsonc",
84
+ "md",
85
+ "mdx",
86
+ "txt",
87
+ "html",
88
+ "htm",
89
+ "css",
90
+ "scss",
91
+ "sass",
92
+ "less",
93
+ "yml",
94
+ "yaml",
95
+ "toml",
96
+ "xml",
97
+ "svg",
98
+ "gitignore",
99
+ "gitattributes",
100
+ "editorconfig",
101
+ "npmrc",
102
+ "nvmrc",
103
+ "env"
104
+ ]);
105
+ function isTextExtension(filename) {
106
+ const ext = filename.startsWith(".") ? filename.slice(1).toLowerCase() : filename.split(".").pop()?.toLowerCase() ?? "";
107
+ return TEXT_EXTS.has(ext);
108
+ }
72
109
  function copyDirectory(src, dest, projectName) {
73
110
  if (!existsSync(dest)) mkdirSync(dest, { recursive: true });
74
111
  const entries = readdirSync(src);
@@ -76,11 +113,11 @@ function copyDirectory(src, dest, projectName) {
76
113
  const srcPath = join(src, entry);
77
114
  const destPath = join(dest, entry);
78
115
  if (statSync(srcPath).isDirectory()) copyDirectory(srcPath, destPath, projectName);
79
- else {
116
+ else if (isTextExtension(entry)) {
80
117
  let content = readFileSync(srcPath, "utf-8");
81
118
  content = content.replace(/\{\{projectName\}\}/g, projectName);
82
119
  writeFileSync(destPath, content);
83
- }
120
+ } else writeFileSync(destPath, readFileSync(srcPath));
84
121
  }
85
122
  }
86
123
  /**
@@ -1 +1 @@
1
- {"version":3,"file":"create.js","names":[],"sources":["../../src/commands/create.tsx"],"sourcesContent":["/** @jsxImportSource @sigx/terminal */\nimport { signal, component, defineApp, Input, Button, ProgressBar, Select } from '@sigx/terminal';\nimport { existsSync, mkdirSync, readdirSync, statSync, writeFileSync, readFileSync } from 'fs';\nimport { dirname, resolve, join } from 'path';\nimport { fileURLToPath } from 'url';\n\nconst __dirname = dirname(fileURLToPath(import.meta.url));\n\ntype Step = 'name' | 'type' | 'styling' | 'creating' | 'done';\ntype ProjectType = 'basic' | 'ssr' | 'ssg' | 'lynx';\ntype Styling = 'none' | 'tailwind' | 'daisyui';\n\n// Parse CLI args (supports both interactive default and --flag headless mode).\nconst rawArgs = process.argv.slice(2);\nfunction getFlag(name: string): string | undefined {\n const eq = rawArgs.find(a => a.startsWith(`--${name}=`));\n if (eq) return eq.slice(name.length + 3);\n const idx = rawArgs.indexOf(`--${name}`);\n if (idx !== -1 && rawArgs[idx + 1] && !rawArgs[idx + 1].startsWith('-')) return rawArgs[idx + 1];\n return undefined;\n}\nfunction hasFlag(name: string, short?: string): boolean {\n return rawArgs.includes(`--${name}`) || (short ? rawArgs.includes(`-${short}`) : false);\n}\nconst positionalArgs = rawArgs.filter(a => !a.startsWith('-') && a !== 'create');\nconst argProjectName = positionalArgs[0] || '';\nconst argType = getFlag('type') as ProjectType | undefined;\nconst argStyling = getFlag('styling') as Styling | undefined;\nconst flagYes = hasFlag('yes', 'y');\nconst isNonInteractive = !process.stdout.isTTY || !process.stdin.isTTY || flagYes\n || Boolean(argType && argProjectName);\n\nconst projectTypeOptions = [\n { value: 'basic' as ProjectType, label: 'Basic SPA', description: 'Simple single-page application (web)' },\n { value: 'ssr' as ProjectType, label: 'SSR', description: 'Server-side rendering with Express (web)' },\n { value: 'ssg' as ProjectType, label: 'SSG', description: 'Static site with file-based routing & MDX (web)' },\n { value: 'lynx' as ProjectType, label: 'Lynx', description: 'Native mobile app with Lynx runtime' },\n];\n\nconst webStylingOptions = [\n { value: 'none' as Styling, label: 'None', description: 'No CSS framework' },\n { value: 'tailwind' as Styling, label: 'Tailwind CSS', description: 'Utility-first CSS framework' },\n { value: 'daisyui' as Styling, label: 'Tailwind + Daisy UI', description: 'Tailwind with component library' },\n];\n\nconst lynxStylingOptions = [\n { value: 'none' as Styling, label: 'None', description: 'No CSS framework' },\n { value: 'tailwind' as Styling, label: 'Tailwind CSS', description: 'Tailwind with Lynx preset' },\n];\n\nfunction copyDirectory(src: string, dest: string, projectName: string) {\n if (!existsSync(dest)) {\n mkdirSync(dest, { recursive: true });\n }\n\n const entries = readdirSync(src);\n for (const entry of entries) {\n const srcPath = join(src, entry);\n const destPath = join(dest, entry);\n const stat = statSync(srcPath);\n\n if (stat.isDirectory()) {\n copyDirectory(srcPath, destPath, projectName);\n } else {\n let content = readFileSync(srcPath, 'utf-8');\n content = content.replace(/\\{\\{projectName\\}\\}/g, projectName);\n writeFileSync(destPath, content);\n }\n }\n}\n\n/**\n * Detect if the target directory is inside a pnpm workspace that includes @sigx packages.\n * If so, rewrite @sigx/* dependency versions to workspace:* in package.json.\n */\nfunction patchWorkspaceDeps(targetDir: string) {\n const pkgPath = join(targetDir, 'package.json');\n if (!existsSync(pkgPath)) return;\n\n // Walk up to find pnpm-workspace.yaml\n let dir = dirname(targetDir);\n let isWorkspace = false;\n for (let i = 0; i < 10; i++) {\n if (existsSync(join(dir, 'pnpm-workspace.yaml'))) {\n isWorkspace = true;\n break;\n }\n const parent = dirname(dir);\n if (parent === dir) break;\n dir = parent;\n }\n if (!isWorkspace) return;\n\n const pkg = JSON.parse(readFileSync(pkgPath, 'utf-8'));\n for (const section of ['dependencies', 'devDependencies'] as const) {\n if (!pkg[section]) continue;\n for (const dep of Object.keys(pkg[section])) {\n if (dep.startsWith('@sigx/')) {\n pkg[section][dep] = 'workspace:*';\n }\n }\n }\n writeFileSync(pkgPath, JSON.stringify(pkg, null, 4) + '\\n');\n}\n\nfunction scaffoldProject(opts: {\n projectName: string;\n projectType: ProjectType;\n styling: Styling;\n}): { ok: true } | { ok: false; error: string } {\n const targetDir = resolve(process.cwd(), opts.projectName);\n let templateName: string;\n if (opts.projectType === 'lynx') {\n templateName = opts.styling === 'tailwind' ? 'lynx-tailwind' : 'lynx';\n } else {\n templateName = opts.styling !== 'none' ? `${opts.projectType}-${opts.styling}` : opts.projectType;\n }\n const templateDir = resolve(__dirname, '..', 'templates', templateName);\n if (existsSync(targetDir)) return { ok: false, error: `Directory \"${opts.projectName}\" already exists!` };\n if (!existsSync(templateDir)) return { ok: false, error: `Template \"${templateName}\" not found at ${templateDir}` };\n copyDirectory(templateDir, targetDir, opts.projectName);\n patchWorkspaceDeps(targetDir);\n return { ok: true };\n}\n\nconst CreateSigx = component(() => {\n const state = signal({\n step: 'name' as Step,\n projectName: argProjectName || 'my-sigx-app',\n projectType: 'basic' as ProjectType,\n styling: 'none' as Styling,\n progress: 0,\n error: '',\n });\n\n const createProject = () => {\n state.step = 'creating';\n state.progress = 30;\n const result = scaffoldProject({\n projectName: state.projectName,\n projectType: state.projectType,\n styling: state.styling,\n });\n if (!result.ok) {\n state.error = result.error;\n return;\n }\n state.progress = 100;\n state.step = 'done';\n };\n\n const handleNameSubmit = () => {\n if (state.projectName.trim()) {\n state.step = 'type';\n }\n };\n\n const handleTypeSubmit = () => {\n state.step = 'styling';\n };\n\n const handleStylingSubmit = () => {\n createProject();\n };\n\n const handleExit = () => {\n process.exit(0);\n };\n\n return () => {\n if (state.error) {\n return (\n <box border=\"double\" borderColor=\"red\" label=\" Error \">\n <text color=\"red\"> {state.error}</text>\n <br />\n <br />\n <Button label=\"Exit\" onClick={handleExit} />\n </box>\n );\n }\n\n const projectTypeLabel = (t: ProjectType) => {\n switch (t) {\n case 'basic': return 'Basic SPA';\n case 'ssr': return 'SSR';\n case 'ssg': return 'SSG';\n case 'lynx': return 'Lynx (Native)';\n }\n };\n\n const stylingLabel = (s: Styling) => {\n switch (s) {\n case 'none': return 'None';\n case 'tailwind': return 'Tailwind CSS';\n case 'daisyui': return 'Tailwind + Daisy UI';\n }\n };\n\n // Render step-specific content as a single element to avoid\n // multiple conditional children causing duplicate nodes\n const stepContent = (() => {\n switch (state.step) {\n case 'name':\n return (\n <box>\n <text color=\"gray\"> Step 1 of 3</text>\n <br />\n <br />\n <text color=\"white\"> What is your project called?</text>\n <br />\n <br />\n <Input\n model={() => state.projectName}\n label=\" Project Name \"\n placeholder=\"my-sigx-app\"\n autofocus\n onSubmit={handleNameSubmit}\n />\n <br />\n <text color=\"gray\"> Press Enter to continue</text>\n </box>\n );\n case 'type':\n return (\n <box>\n <text color=\"gray\"> Step 2 of 3</text>\n <br />\n <br />\n <text color=\"white\"> What type of project?</text>\n <br />\n <br />\n <Select\n model={() => state.projectType}\n label=\" Project Type \"\n options={projectTypeOptions}\n showDescription\n autofocus\n onSubmit={handleTypeSubmit}\n />\n <br />\n <text color=\"gray\"> ↑/↓ navigate · Enter select</text>\n </box>\n );\n case 'styling':\n return (\n <box>\n <text color=\"gray\"> Step 3 of 3</text>\n <br />\n <br />\n <text color=\"white\"> Choose a styling approach:</text>\n <br />\n <br />\n <Select\n model={() => state.styling}\n label=\" Styling \"\n options={state.projectType === 'lynx' ? lynxStylingOptions : webStylingOptions}\n showDescription\n autofocus\n onSubmit={handleStylingSubmit}\n />\n <br />\n <text color=\"gray\"> ↑/↓ navigate · Enter select</text>\n </box>\n );\n case 'creating':\n return (\n <box>\n <br />\n <text color=\"yellow\"> Creating project...</text>\n <br />\n <ProgressBar value={state.progress} max={100} width={40} color=\"green\" />\n </box>\n );\n case 'done':\n return (\n <box>\n <br />\n <text color=\"green\"> ✓ Project \"{state.projectName}\" created!</text>\n <br />\n <br />\n <text color=\"gray\"> Type: {projectTypeLabel(state.projectType)}</text>\n <br />\n <text color=\"gray\"> Styling: {stylingLabel(state.styling)}</text>\n <br />\n <br />\n <text color=\"white\"> Next steps:</text>\n <br />\n <br />\n <text color=\"cyan\"> cd {state.projectName}</text>\n <br />\n <text color=\"cyan\"> pnpm install</text>\n <br />\n <text color=\"cyan\"> {state.projectType === 'lynx' ? 'sigx dev' : 'pnpm dev'}</text>\n <br />\n <br />\n <Button label=\"Exit\" onClick={handleExit} />\n </box>\n );\n }\n })();\n\n return (\n <box>\n <text color=\"cyan\"> ⚡ Create SignalX App</text>\n <br />\n {stepContent}\n </box>\n );\n };\n});\n\nfunction runHeadless(): number {\n const validTypes: ProjectType[] = ['basic', 'ssr', 'ssg', 'lynx'];\n const validStyling: Styling[] = ['none', 'tailwind', 'daisyui'];\n\n const projectName = argProjectName || 'my-sigx-app';\n const projectType: ProjectType = argType ?? 'basic';\n const styling: Styling = argStyling ?? 'none';\n\n if (!validTypes.includes(projectType)) {\n console.error(`Error: --type must be one of ${validTypes.join(', ')}`);\n return 2;\n }\n if (!validStyling.includes(styling)) {\n console.error(`Error: --styling must be one of ${validStyling.join(', ')}`);\n return 2;\n }\n if (projectType === 'lynx' && styling === 'daisyui') {\n console.error('Error: --styling=daisyui is not supported for Lynx projects (use none or tailwind)');\n return 2;\n }\n\n console.log(`\\n ⚡ Creating SignalX app \"${projectName}\"`);\n console.log(` type: ${projectType}`);\n console.log(` styling: ${styling}\\n`);\n\n const result = scaffoldProject({ projectName, projectType, styling });\n if (!result.ok) {\n console.error(`Error: ${result.error}`);\n return 1;\n }\n\n console.log(` ✓ Project created\\n`);\n console.log(` Next steps:`);\n console.log(` cd ${projectName}`);\n console.log(` pnpm install`);\n console.log(` ${projectType === 'lynx' ? 'sigx dev' : 'pnpm dev'}\\n`);\n return 0;\n}\n\nexport function runCreate() {\n if (isNonInteractive) {\n process.exit(runHeadless());\n }\n defineApp(<CreateSigx />).mount({ clearConsole: true });\n // Keep process alive for TUI\n setInterval(() => { }, 10000);\n}\n"],"mappings":"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"}
1
+ {"version":3,"file":"create.js","names":[],"sources":["../../src/commands/create.tsx"],"sourcesContent":["/** @jsxImportSource @sigx/terminal */\nimport { signal, component, defineApp, Input, Button, ProgressBar, Select } from '@sigx/terminal';\nimport { existsSync, mkdirSync, readdirSync, statSync, writeFileSync, readFileSync } from 'fs';\nimport { dirname, resolve, join } from 'path';\nimport { fileURLToPath } from 'url';\n\nconst __dirname = dirname(fileURLToPath(import.meta.url));\n\ntype Step = 'name' | 'type' | 'styling' | 'creating' | 'done';\ntype ProjectType = 'basic' | 'ssr' | 'ssg' | 'lynx';\ntype Styling = 'none' | 'tailwind' | 'daisyui';\n\n// Parse CLI args (supports both interactive default and --flag headless mode).\nconst rawArgs = process.argv.slice(2);\nfunction getFlag(name: string): string | undefined {\n const eq = rawArgs.find(a => a.startsWith(`--${name}=`));\n if (eq) return eq.slice(name.length + 3);\n const idx = rawArgs.indexOf(`--${name}`);\n if (idx !== -1 && rawArgs[idx + 1] && !rawArgs[idx + 1].startsWith('-')) return rawArgs[idx + 1];\n return undefined;\n}\nfunction hasFlag(name: string, short?: string): boolean {\n return rawArgs.includes(`--${name}`) || (short ? rawArgs.includes(`-${short}`) : false);\n}\nconst positionalArgs = rawArgs.filter(a => !a.startsWith('-') && a !== 'create');\nconst argProjectName = positionalArgs[0] || '';\nconst argType = getFlag('type') as ProjectType | undefined;\nconst argStyling = getFlag('styling') as Styling | undefined;\nconst flagYes = hasFlag('yes', 'y');\nconst isNonInteractive = !process.stdout.isTTY || !process.stdin.isTTY || flagYes\n || Boolean(argType && argProjectName);\n\nconst projectTypeOptions = [\n { value: 'basic' as ProjectType, label: 'Basic SPA', description: 'Simple single-page application (web)' },\n { value: 'ssr' as ProjectType, label: 'SSR', description: 'Server-side rendering with Express (web)' },\n { value: 'ssg' as ProjectType, label: 'SSG', description: 'Static site with file-based routing & MDX (web)' },\n { value: 'lynx' as ProjectType, label: 'Lynx', description: 'Native mobile app with Lynx runtime' },\n];\n\nconst webStylingOptions = [\n { value: 'none' as Styling, label: 'None', description: 'No CSS framework' },\n { value: 'tailwind' as Styling, label: 'Tailwind CSS', description: 'Utility-first CSS framework' },\n { value: 'daisyui' as Styling, label: 'Tailwind + Daisy UI', description: 'Tailwind with component library' },\n];\n\nconst lynxStylingOptions = [\n { value: 'none' as Styling, label: 'None', description: 'No CSS framework' },\n { value: 'tailwind' as Styling, label: 'Tailwind CSS', description: 'Tailwind with Lynx preset' },\n];\n\nconst TEXT_EXTS = new Set([\n 'ts', 'tsx', 'js', 'jsx', 'mjs', 'cjs', 'mts', 'cts',\n 'json', 'json5', 'jsonc',\n 'md', 'mdx', 'txt',\n 'html', 'htm', 'css', 'scss', 'sass', 'less',\n 'yml', 'yaml', 'toml', 'xml', 'svg',\n 'gitignore', 'gitattributes', 'editorconfig', 'npmrc', 'nvmrc', 'env',\n]);\n\nfunction isTextExtension(filename: string): boolean {\n // Dotfiles: name after leading dot (.gitignore → \"gitignore\").\n const ext = filename.startsWith('.')\n ? filename.slice(1).toLowerCase()\n : filename.split('.').pop()?.toLowerCase() ?? '';\n return TEXT_EXTS.has(ext);\n}\n\nfunction copyDirectory(src: string, dest: string, projectName: string) {\n if (!existsSync(dest)) {\n mkdirSync(dest, { recursive: true });\n }\n\n const entries = readdirSync(src);\n for (const entry of entries) {\n const srcPath = join(src, entry);\n const destPath = join(dest, entry);\n const stat = statSync(srcPath);\n\n if (stat.isDirectory()) {\n copyDirectory(srcPath, destPath, projectName);\n } else if (isTextExtension(entry)) {\n let content = readFileSync(srcPath, 'utf-8');\n content = content.replace(/\\{\\{projectName\\}\\}/g, projectName);\n writeFileSync(destPath, content);\n } else {\n // Binary asset — copy bytes verbatim. Reading as UTF-8 would corrupt\n // non-ASCII bytes (e.g. PNG magic 0x89 → U+FFFD).\n writeFileSync(destPath, readFileSync(srcPath));\n }\n }\n}\n\n/**\n * Detect if the target directory is inside a pnpm workspace that includes @sigx packages.\n * If so, rewrite @sigx/* dependency versions to workspace:* in package.json.\n */\nfunction patchWorkspaceDeps(targetDir: string) {\n const pkgPath = join(targetDir, 'package.json');\n if (!existsSync(pkgPath)) return;\n\n // Walk up to find pnpm-workspace.yaml\n let dir = dirname(targetDir);\n let isWorkspace = false;\n for (let i = 0; i < 10; i++) {\n if (existsSync(join(dir, 'pnpm-workspace.yaml'))) {\n isWorkspace = true;\n break;\n }\n const parent = dirname(dir);\n if (parent === dir) break;\n dir = parent;\n }\n if (!isWorkspace) return;\n\n const pkg = JSON.parse(readFileSync(pkgPath, 'utf-8'));\n for (const section of ['dependencies', 'devDependencies'] as const) {\n if (!pkg[section]) continue;\n for (const dep of Object.keys(pkg[section])) {\n if (dep.startsWith('@sigx/')) {\n pkg[section][dep] = 'workspace:*';\n }\n }\n }\n writeFileSync(pkgPath, JSON.stringify(pkg, null, 4) + '\\n');\n}\n\nfunction scaffoldProject(opts: {\n projectName: string;\n projectType: ProjectType;\n styling: Styling;\n}): { ok: true } | { ok: false; error: string } {\n const targetDir = resolve(process.cwd(), opts.projectName);\n let templateName: string;\n if (opts.projectType === 'lynx') {\n templateName = opts.styling === 'tailwind' ? 'lynx-tailwind' : 'lynx';\n } else {\n templateName = opts.styling !== 'none' ? `${opts.projectType}-${opts.styling}` : opts.projectType;\n }\n const templateDir = resolve(__dirname, '..', 'templates', templateName);\n if (existsSync(targetDir)) return { ok: false, error: `Directory \"${opts.projectName}\" already exists!` };\n if (!existsSync(templateDir)) return { ok: false, error: `Template \"${templateName}\" not found at ${templateDir}` };\n copyDirectory(templateDir, targetDir, opts.projectName);\n patchWorkspaceDeps(targetDir);\n return { ok: true };\n}\n\nconst CreateSigx = component(() => {\n const state = signal({\n step: 'name' as Step,\n projectName: argProjectName || 'my-sigx-app',\n projectType: 'basic' as ProjectType,\n styling: 'none' as Styling,\n progress: 0,\n error: '',\n });\n\n const createProject = () => {\n state.step = 'creating';\n state.progress = 30;\n const result = scaffoldProject({\n projectName: state.projectName,\n projectType: state.projectType,\n styling: state.styling,\n });\n if (!result.ok) {\n state.error = result.error;\n return;\n }\n state.progress = 100;\n state.step = 'done';\n };\n\n const handleNameSubmit = () => {\n if (state.projectName.trim()) {\n state.step = 'type';\n }\n };\n\n const handleTypeSubmit = () => {\n state.step = 'styling';\n };\n\n const handleStylingSubmit = () => {\n createProject();\n };\n\n const handleExit = () => {\n process.exit(0);\n };\n\n return () => {\n if (state.error) {\n return (\n <box border=\"double\" borderColor=\"red\" label=\" Error \">\n <text color=\"red\"> {state.error}</text>\n <br />\n <br />\n <Button label=\"Exit\" onClick={handleExit} />\n </box>\n );\n }\n\n const projectTypeLabel = (t: ProjectType) => {\n switch (t) {\n case 'basic': return 'Basic SPA';\n case 'ssr': return 'SSR';\n case 'ssg': return 'SSG';\n case 'lynx': return 'Lynx (Native)';\n }\n };\n\n const stylingLabel = (s: Styling) => {\n switch (s) {\n case 'none': return 'None';\n case 'tailwind': return 'Tailwind CSS';\n case 'daisyui': return 'Tailwind + Daisy UI';\n }\n };\n\n // Render step-specific content as a single element to avoid\n // multiple conditional children causing duplicate nodes\n const stepContent = (() => {\n switch (state.step) {\n case 'name':\n return (\n <box>\n <text color=\"gray\"> Step 1 of 3</text>\n <br />\n <br />\n <text color=\"white\"> What is your project called?</text>\n <br />\n <br />\n <Input\n model={() => state.projectName}\n label=\" Project Name \"\n placeholder=\"my-sigx-app\"\n autofocus\n onSubmit={handleNameSubmit}\n />\n <br />\n <text color=\"gray\"> Press Enter to continue</text>\n </box>\n );\n case 'type':\n return (\n <box>\n <text color=\"gray\"> Step 2 of 3</text>\n <br />\n <br />\n <text color=\"white\"> What type of project?</text>\n <br />\n <br />\n <Select\n model={() => state.projectType}\n label=\" Project Type \"\n options={projectTypeOptions}\n showDescription\n autofocus\n onSubmit={handleTypeSubmit}\n />\n <br />\n <text color=\"gray\"> ↑/↓ navigate · Enter select</text>\n </box>\n );\n case 'styling':\n return (\n <box>\n <text color=\"gray\"> Step 3 of 3</text>\n <br />\n <br />\n <text color=\"white\"> Choose a styling approach:</text>\n <br />\n <br />\n <Select\n model={() => state.styling}\n label=\" Styling \"\n options={state.projectType === 'lynx' ? lynxStylingOptions : webStylingOptions}\n showDescription\n autofocus\n onSubmit={handleStylingSubmit}\n />\n <br />\n <text color=\"gray\"> ↑/↓ navigate · Enter select</text>\n </box>\n );\n case 'creating':\n return (\n <box>\n <br />\n <text color=\"yellow\"> Creating project...</text>\n <br />\n <ProgressBar value={state.progress} max={100} width={40} color=\"green\" />\n </box>\n );\n case 'done':\n return (\n <box>\n <br />\n <text color=\"green\"> ✓ Project \"{state.projectName}\" created!</text>\n <br />\n <br />\n <text color=\"gray\"> Type: {projectTypeLabel(state.projectType)}</text>\n <br />\n <text color=\"gray\"> Styling: {stylingLabel(state.styling)}</text>\n <br />\n <br />\n <text color=\"white\"> Next steps:</text>\n <br />\n <br />\n <text color=\"cyan\"> cd {state.projectName}</text>\n <br />\n <text color=\"cyan\"> pnpm install</text>\n <br />\n <text color=\"cyan\"> {state.projectType === 'lynx' ? 'sigx dev' : 'pnpm dev'}</text>\n <br />\n <br />\n <Button label=\"Exit\" onClick={handleExit} />\n </box>\n );\n }\n })();\n\n return (\n <box>\n <text color=\"cyan\"> ⚡ Create SignalX App</text>\n <br />\n {stepContent}\n </box>\n );\n };\n});\n\nfunction runHeadless(): number {\n const validTypes: ProjectType[] = ['basic', 'ssr', 'ssg', 'lynx'];\n const validStyling: Styling[] = ['none', 'tailwind', 'daisyui'];\n\n const projectName = argProjectName || 'my-sigx-app';\n const projectType: ProjectType = argType ?? 'basic';\n const styling: Styling = argStyling ?? 'none';\n\n if (!validTypes.includes(projectType)) {\n console.error(`Error: --type must be one of ${validTypes.join(', ')}`);\n return 2;\n }\n if (!validStyling.includes(styling)) {\n console.error(`Error: --styling must be one of ${validStyling.join(', ')}`);\n return 2;\n }\n if (projectType === 'lynx' && styling === 'daisyui') {\n console.error('Error: --styling=daisyui is not supported for Lynx projects (use none or tailwind)');\n return 2;\n }\n\n console.log(`\\n ⚡ Creating SignalX app \"${projectName}\"`);\n console.log(` type: ${projectType}`);\n console.log(` styling: ${styling}\\n`);\n\n const result = scaffoldProject({ projectName, projectType, styling });\n if (!result.ok) {\n console.error(`Error: ${result.error}`);\n return 1;\n }\n\n console.log(` ✓ Project created\\n`);\n console.log(` Next steps:`);\n console.log(` cd ${projectName}`);\n console.log(` pnpm install`);\n console.log(` ${projectType === 'lynx' ? 'sigx dev' : 'pnpm dev'}\\n`);\n return 0;\n}\n\nexport function runCreate() {\n if (isNonInteractive) {\n process.exit(runHeadless());\n }\n defineApp(<CreateSigx />).mount({ clearConsole: true });\n // Keep process alive for TUI\n setInterval(() => { }, 10000);\n}\n"],"mappings":"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"}
@@ -10,17 +10,23 @@
10
10
  "prebuild": "sigx prebuild"
11
11
  },
12
12
  "dependencies": {
13
- "@sigx/lynx": "^0.1.0",
14
- "@sigx/runtime-lynx": "^0.2.4",
15
- "@sigx/runtime-lynx-main": "^0.2.4",
13
+ "@sigx/lynx": "^0.1.2",
14
+ "@sigx/lynx-runtime": "^0.2.4",
15
+ "@sigx/lynx-runtime-main": "^0.2.4",
16
16
  "@sigx/lynx-core": "^0.1.0",
17
17
  "@sigx/reactivity": "^0.4.1",
18
- "@sigx/runtime-core": "^0.4.1"
18
+ "@sigx/runtime-core": "^0.4.1",
19
+ "@sigx/lynx-storage": "^0.1.0",
20
+ "@sigx/lynx-clipboard": "^0.1.0",
21
+ "@sigx/lynx-haptics": "^0.1.0",
22
+ "@sigx/lynx-device-info": "^0.1.0",
23
+ "@sigx/lynx-network": "^0.1.0"
19
24
  },
20
25
  "devDependencies": {
21
26
  "@sigx/cli": "^0.1.0",
22
27
  "@sigx/lynx-cli": "^0.1.0",
23
28
  "@sigx/lynx-plugin": "^0.2.4",
29
+ "@sigx/lynx-dev-client": "^0.1.0",
24
30
  "@lynx-js/rspeedy": ">=0.1.0",
25
31
  "@lynx-js/css-extract-webpack-plugin": ">=0.1.0",
26
32
  "@lynx-js/template-webpack-plugin": ">=0.1.0",
@@ -10,17 +10,23 @@
10
10
  "prebuild": "sigx prebuild"
11
11
  },
12
12
  "dependencies": {
13
- "@sigx/lynx": "^0.1.0",
14
- "@sigx/runtime-lynx": "^0.2.4",
15
- "@sigx/runtime-lynx-main": "^0.2.4",
13
+ "@sigx/lynx": "^0.1.2",
14
+ "@sigx/lynx-runtime": "^0.2.4",
15
+ "@sigx/lynx-runtime-main": "^0.2.4",
16
16
  "@sigx/lynx-core": "^0.1.0",
17
17
  "@sigx/reactivity": "^0.4.1",
18
- "@sigx/runtime-core": "^0.4.1"
18
+ "@sigx/runtime-core": "^0.4.1",
19
+ "@sigx/lynx-storage": "^0.1.0",
20
+ "@sigx/lynx-clipboard": "^0.1.0",
21
+ "@sigx/lynx-haptics": "^0.1.0",
22
+ "@sigx/lynx-device-info": "^0.1.0",
23
+ "@sigx/lynx-network": "^0.1.0"
19
24
  },
20
25
  "devDependencies": {
21
26
  "@sigx/cli": "^0.1.0",
22
27
  "@sigx/lynx-cli": "^0.1.0",
23
28
  "@sigx/lynx-plugin": "^0.2.4",
29
+ "@sigx/lynx-dev-client": "^0.1.0",
24
30
  "@lynx-js/rspeedy": ">=0.1.0",
25
31
  "@lynx-js/css-extract-webpack-plugin": ">=0.1.0",
26
32
  "@lynx-js/template-webpack-plugin": ">=0.1.0",
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@sigx/cli",
3
- "version": "0.1.1",
3
+ "version": "0.1.2",
4
4
  "description": "Unified CLI for SignalX — create, dev, build, and run projects",
5
5
  "type": "module",
6
6
  "main": "./dist/index.js",
@@ -26,19 +26,15 @@
26
26
  "dist",
27
27
  "templates"
28
28
  ],
29
- "scripts": {
30
- "build": "vite build && node scripts/generate-types.js && node scripts/copy-templates.js",
31
- "dev": "vite build --watch"
32
- },
33
29
  "dependencies": {
34
- "@sigx/terminal": "^0.3.2",
30
+ "@sigx/terminal": "^0.4.1",
35
31
  "citty": "^0.2.2"
36
32
  },
37
33
  "devDependencies": {
38
- "@sigx/vite": "^0.4.1",
34
+ "@sigx/vite": "^0.4.3",
39
35
  "@types/node": "^22.0.0",
40
36
  "typescript": "^5.9.3",
41
- "vite": "^8.0.3"
37
+ "vite": "^8.0.12"
42
38
  },
43
39
  "author": "Andreas Ekdahl",
44
40
  "license": "MIT",
@@ -61,5 +57,9 @@
61
57
  ],
62
58
  "publishConfig": {
63
59
  "access": "public"
60
+ },
61
+ "scripts": {
62
+ "build": "vite build && node scripts/generate-types.js && node scripts/copy-templates.js",
63
+ "dev": "vite build --watch"
64
64
  }
65
- }
65
+ }
@@ -10,17 +10,23 @@
10
10
  "prebuild": "sigx prebuild"
11
11
  },
12
12
  "dependencies": {
13
- "@sigx/lynx": "^0.1.0",
14
- "@sigx/runtime-lynx": "^0.2.4",
15
- "@sigx/runtime-lynx-main": "^0.2.4",
13
+ "@sigx/lynx": "^0.1.2",
14
+ "@sigx/lynx-runtime": "^0.2.4",
15
+ "@sigx/lynx-runtime-main": "^0.2.4",
16
16
  "@sigx/lynx-core": "^0.1.0",
17
17
  "@sigx/reactivity": "^0.4.1",
18
- "@sigx/runtime-core": "^0.4.1"
18
+ "@sigx/runtime-core": "^0.4.1",
19
+ "@sigx/lynx-storage": "^0.1.0",
20
+ "@sigx/lynx-clipboard": "^0.1.0",
21
+ "@sigx/lynx-haptics": "^0.1.0",
22
+ "@sigx/lynx-device-info": "^0.1.0",
23
+ "@sigx/lynx-network": "^0.1.0"
19
24
  },
20
25
  "devDependencies": {
21
26
  "@sigx/cli": "^0.1.0",
22
27
  "@sigx/lynx-cli": "^0.1.0",
23
28
  "@sigx/lynx-plugin": "^0.2.4",
29
+ "@sigx/lynx-dev-client": "^0.1.0",
24
30
  "@lynx-js/rspeedy": ">=0.1.0",
25
31
  "@lynx-js/css-extract-webpack-plugin": ">=0.1.0",
26
32
  "@lynx-js/template-webpack-plugin": ">=0.1.0",
@@ -10,17 +10,23 @@
10
10
  "prebuild": "sigx prebuild"
11
11
  },
12
12
  "dependencies": {
13
- "@sigx/lynx": "^0.1.0",
14
- "@sigx/runtime-lynx": "^0.2.4",
15
- "@sigx/runtime-lynx-main": "^0.2.4",
13
+ "@sigx/lynx": "^0.1.2",
14
+ "@sigx/lynx-runtime": "^0.2.4",
15
+ "@sigx/lynx-runtime-main": "^0.2.4",
16
16
  "@sigx/lynx-core": "^0.1.0",
17
17
  "@sigx/reactivity": "^0.4.1",
18
- "@sigx/runtime-core": "^0.4.1"
18
+ "@sigx/runtime-core": "^0.4.1",
19
+ "@sigx/lynx-storage": "^0.1.0",
20
+ "@sigx/lynx-clipboard": "^0.1.0",
21
+ "@sigx/lynx-haptics": "^0.1.0",
22
+ "@sigx/lynx-device-info": "^0.1.0",
23
+ "@sigx/lynx-network": "^0.1.0"
19
24
  },
20
25
  "devDependencies": {
21
26
  "@sigx/cli": "^0.1.0",
22
27
  "@sigx/lynx-cli": "^0.1.0",
23
28
  "@sigx/lynx-plugin": "^0.2.4",
29
+ "@sigx/lynx-dev-client": "^0.1.0",
24
30
  "@lynx-js/rspeedy": ">=0.1.0",
25
31
  "@lynx-js/css-extract-webpack-plugin": ">=0.1.0",
26
32
  "@lynx-js/template-webpack-plugin": ">=0.1.0",