nivii 0.3.4 → 0.4.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.
Files changed (121) hide show
  1. package/README.md +223 -113
  2. package/dist/cli.js +1 -48
  3. package/dist/cli.js.map +1 -1
  4. package/dist/commands/share.d.ts.map +1 -1
  5. package/dist/commands/share.js +4 -5
  6. package/dist/commands/share.js.map +1 -1
  7. package/dist/core/upload.d.ts +1 -2
  8. package/dist/core/upload.d.ts.map +1 -1
  9. package/dist/core/upload.js +0 -2
  10. package/dist/core/upload.js.map +1 -1
  11. package/dist/dist/cli.d.ts +3 -0
  12. package/dist/dist/cli.d.ts.map +1 -0
  13. package/dist/dist/cli.js +157 -0
  14. package/dist/dist/cli.js.map +1 -0
  15. package/dist/dist/commands/config.d.ts +2 -0
  16. package/dist/dist/commands/config.d.ts.map +1 -0
  17. package/dist/dist/commands/config.js +32 -0
  18. package/dist/dist/commands/config.js.map +1 -0
  19. package/dist/dist/commands/share.d.ts +18 -0
  20. package/dist/dist/commands/share.d.ts.map +1 -0
  21. package/dist/dist/commands/share.js +126 -0
  22. package/dist/dist/commands/share.js.map +1 -0
  23. package/dist/dist/commands/whoami.d.ts +2 -0
  24. package/dist/dist/commands/whoami.d.ts.map +1 -0
  25. package/dist/dist/commands/whoami.js +17 -0
  26. package/dist/dist/commands/whoami.js.map +1 -0
  27. package/dist/dist/core/analytics.d.ts +11 -0
  28. package/dist/dist/core/analytics.d.ts.map +1 -0
  29. package/dist/dist/core/analytics.js +47 -0
  30. package/dist/dist/core/analytics.js.map +1 -0
  31. package/dist/dist/core/build.d.ts +11 -0
  32. package/dist/dist/core/build.d.ts.map +1 -0
  33. package/dist/dist/core/build.js +34 -0
  34. package/dist/dist/core/build.js.map +1 -0
  35. package/dist/dist/core/detect.d.ts +12 -0
  36. package/dist/dist/core/detect.d.ts.map +1 -0
  37. package/dist/dist/core/detect.js +122 -0
  38. package/dist/dist/core/detect.js.map +1 -0
  39. package/dist/dist/core/qr.d.ts +4 -0
  40. package/dist/dist/core/qr.d.ts.map +1 -0
  41. package/dist/dist/core/qr.js +29 -0
  42. package/dist/dist/core/qr.js.map +1 -0
  43. package/dist/dist/core/tunnel.d.ts +9 -0
  44. package/dist/dist/core/tunnel.d.ts.map +1 -0
  45. package/dist/dist/core/tunnel.js +55 -0
  46. package/dist/dist/core/tunnel.js.map +1 -0
  47. package/dist/dist/core/upload.d.ts +23 -0
  48. package/dist/dist/core/upload.d.ts.map +1 -0
  49. package/dist/dist/core/upload.js +75 -0
  50. package/dist/dist/core/upload.js.map +1 -0
  51. package/dist/dist/ui/spinner.d.ts +8 -0
  52. package/dist/dist/ui/spinner.d.ts.map +1 -0
  53. package/dist/dist/ui/spinner.js +35 -0
  54. package/dist/dist/ui/spinner.js.map +1 -0
  55. package/dist/dist/ui/theme.d.ts +14 -0
  56. package/dist/dist/ui/theme.d.ts.map +1 -0
  57. package/dist/dist/ui/theme.js +32 -0
  58. package/dist/dist/ui/theme.js.map +1 -0
  59. package/dist/dist/ui/welcome.d.ts +4 -0
  60. package/dist/dist/ui/welcome.d.ts.map +1 -0
  61. package/dist/dist/ui/welcome.js +95 -0
  62. package/dist/dist/ui/welcome.js.map +1 -0
  63. package/dist/dist/utils/config.d.ts +20 -0
  64. package/dist/dist/utils/config.d.ts.map +1 -0
  65. package/dist/dist/utils/config.js +31 -0
  66. package/dist/dist/utils/config.js.map +1 -0
  67. package/dist/dist/utils/hash.d.ts +3 -0
  68. package/dist/dist/utils/hash.d.ts.map +1 -0
  69. package/dist/dist/utils/hash.js +10 -0
  70. package/dist/dist/utils/hash.js.map +1 -0
  71. package/dist/dist/utils/zip.d.ts +2 -0
  72. package/dist/dist/utils/zip.d.ts.map +1 -0
  73. package/dist/dist/utils/zip.js +19 -0
  74. package/dist/dist/utils/zip.js.map +1 -0
  75. package/dist/ui/spinner.d.ts +0 -1
  76. package/dist/ui/spinner.d.ts.map +1 -1
  77. package/dist/ui/spinner.js +0 -3
  78. package/dist/ui/spinner.js.map +1 -1
  79. package/dist/ui/welcome.d.ts.map +1 -1
  80. package/dist/ui/welcome.js +3 -6
  81. package/dist/ui/welcome.js.map +1 -1
  82. package/dist/utils/config.d.ts +0 -3
  83. package/dist/utils/config.d.ts.map +1 -1
  84. package/dist/utils/config.js.map +1 -1
  85. package/package.json +1 -1
  86. package/src/cli.ts +118 -0
  87. package/src/commands/config.ts +33 -0
  88. package/src/commands/share.ts +159 -0
  89. package/src/commands/whoami.ts +16 -0
  90. package/src/core/analytics.ts +64 -0
  91. package/src/core/build.ts +46 -0
  92. package/src/core/detect.ts +159 -0
  93. package/src/core/qr.ts +30 -0
  94. package/src/core/tunnel.ts +70 -0
  95. package/src/core/upload.ts +95 -0
  96. package/src/ui/spinner.ts +36 -0
  97. package/src/ui/theme.ts +35 -0
  98. package/src/ui/welcome.ts +104 -0
  99. package/src/utils/config.ts +47 -0
  100. package/src/utils/hash.ts +11 -0
  101. package/src/utils/zip.ts +22 -0
  102. /package/dist/{commands → dist/commands}/fullstack.d.ts +0 -0
  103. /package/dist/{commands → dist/commands}/fullstack.d.ts.map +0 -0
  104. /package/dist/{commands → dist/commands}/fullstack.js +0 -0
  105. /package/dist/{commands → dist/commands}/fullstack.js.map +0 -0
  106. /package/dist/{commands → dist/commands}/pro.d.ts +0 -0
  107. /package/dist/{commands → dist/commands}/pro.d.ts.map +0 -0
  108. /package/dist/{commands → dist/commands}/pro.js +0 -0
  109. /package/dist/{commands → dist/commands}/pro.js.map +0 -0
  110. /package/dist/{core → dist/core}/backend.d.ts +0 -0
  111. /package/dist/{core → dist/core}/backend.d.ts.map +0 -0
  112. /package/dist/{core → dist/core}/backend.js +0 -0
  113. /package/dist/{core → dist/core}/backend.js.map +0 -0
  114. /package/dist/{core → dist/core}/env.d.ts +0 -0
  115. /package/dist/{core → dist/core}/env.d.ts.map +0 -0
  116. /package/dist/{core → dist/core}/env.js +0 -0
  117. /package/dist/{core → dist/core}/env.js.map +0 -0
  118. /package/dist/{core → dist/core}/fullstack.d.ts +0 -0
  119. /package/dist/{core → dist/core}/fullstack.d.ts.map +0 -0
  120. /package/dist/{core → dist/core}/fullstack.js +0 -0
  121. /package/dist/{core → dist/core}/fullstack.js.map +0 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cli.d.ts","sourceRoot":"","sources":["../src/cli.ts"],"names":[],"mappings":""}
@@ -0,0 +1,157 @@
1
+ #!/usr/bin/env node
2
+ import { cac } from 'cac';
3
+ import chalk from 'chalk';
4
+ import { runShare } from './commands/share.js';
5
+ import { runFullStack } from './commands/fullstack.js';
6
+ import { runConfig } from './commands/config.js';
7
+ import { runWhoami } from './commands/whoami.js';
8
+ import { runPro } from './commands/pro.js';
9
+ import { runAnalytics } from './core/analytics.js';
10
+ import { loadConfig, updateConfig } from './utils/config.js';
11
+ import { showWelcome, showHelp } from './ui/welcome.js';
12
+ const cli = cac('nivii');
13
+ // ─── First run ────────────────────────────────────────────────────────────────
14
+ const config = loadConfig();
15
+ if (config.firstRun) {
16
+ showWelcome();
17
+ updateConfig({ firstRun: false });
18
+ }
19
+ // ─── share ────────────────────────────────────────────────────────────────────
20
+ cli
21
+ .command('share', 'Deploy your project and get a live URL')
22
+ .option('--dir <dir>', 'Directory to deploy (default: cwd)')
23
+ .option('--slug <slug>', 'Custom slug (Pro) e.g. my-demo → my-demo.nivii.app')
24
+ .option('--pass <password>', 'Password-protect your deployment')
25
+ .option('--otp', 'Enable one-time password access')
26
+ .option('--expires <duration>', 'Expiry: 1h / 24h / 7d / 30d / never')
27
+ .option('--live', 'Enable live sync (watch & auto-redeploy on changes)')
28
+ .option('--collab', 'Enable real-time collaborative preview (Pro)')
29
+ .option('--no-build', 'Skip build, use existing output directory')
30
+ .option('--cmd <cmd>', 'Custom build command')
31
+ .option('--port <port>', 'Port for server-mode proxy', { default: 3000 })
32
+ .option('--max-views <n>', 'Self-destruct after N views')
33
+ .option('--self-destruct', 'Self-destruct after first view')
34
+ .option('--no-qr', 'Skip QR code')
35
+ .option('--no-open', 'Do not open browser')
36
+ .action(async (options) => {
37
+ try {
38
+ await runShare({
39
+ dir: options.dir,
40
+ slug: options.slug,
41
+ pass: options.pass,
42
+ otp: options.otp,
43
+ expires: options.expires,
44
+ live: options.live,
45
+ collab: options.collab,
46
+ noBuild: options['no-build'],
47
+ cmd: options.cmd,
48
+ port: options.port,
49
+ maxViews: options.maxViews,
50
+ selfDestruct: options.selfDestruct,
51
+ open: options.open,
52
+ qr: options.qr,
53
+ });
54
+ }
55
+ catch (err) {
56
+ console.error(chalk.red('\n ✗ ') + err.message);
57
+ process.exit(1);
58
+ }
59
+ });
60
+ // ─── fullstack ────────────────────────────────────────────────────────────────
61
+ cli
62
+ .command('fullstack', 'Deploy frontend + backend together, auto-wired')
63
+ .alias('fs')
64
+ .option('--dir <dir>', 'Root directory (default: cwd)')
65
+ .option('--slug <slug>', 'Custom slug')
66
+ .option('--expires <duration>', 'Expiry: 1h / 24h / 7d / 30d')
67
+ .option('--fly-token <token>', 'Fly.io API token for backend deploy')
68
+ .option('--skip-backend', 'Deploy frontend only')
69
+ .option('--skip-frontend', 'Deploy backend only')
70
+ .option('--no-qr', 'Skip QR code')
71
+ .option('--no-open', 'Do not open browser')
72
+ .action(async (options) => {
73
+ try {
74
+ await runFullStack({
75
+ dir: options.dir,
76
+ slug: options.slug,
77
+ expires: options.expires,
78
+ flyToken: options.flyToken,
79
+ skipBackend: options.skipBackend,
80
+ skipFrontend: options.skipFrontend,
81
+ noQr: options['no-qr'],
82
+ noOpen: options['no-open'],
83
+ });
84
+ }
85
+ catch (err) {
86
+ console.error(chalk.red('\n ✗ ') + err.message);
87
+ process.exit(1);
88
+ }
89
+ });
90
+ // ─── pro ──────────────────────────────────────────────────────────────────────
91
+ cli
92
+ .command('pro [subcommand]', 'Manage your Nivii Pro early access')
93
+ .action(async (subcommand) => {
94
+ try {
95
+ await runPro(subcommand);
96
+ }
97
+ catch (err) {
98
+ console.error(chalk.red('\n ✗ ') + err.message);
99
+ process.exit(1);
100
+ }
101
+ });
102
+ // ─── config ───────────────────────────────────────────────────────────────────
103
+ cli
104
+ .command('config [key] [value]', 'View or set config values')
105
+ .action((key, value) => {
106
+ runConfig(key, value);
107
+ });
108
+ // ─── whoami ───────────────────────────────────────────────────────────────────
109
+ cli
110
+ .command('whoami', 'Show current account info')
111
+ .action(() => {
112
+ runWhoami();
113
+ });
114
+ // ─── ls (list deployments) ────────────────────────────────────────────────────
115
+ cli
116
+ .command('ls', 'List your recent deployments')
117
+ .action(() => {
118
+ const cfg = loadConfig();
119
+ const deployments = cfg.deployments || [];
120
+ if (!deployments.length) {
121
+ console.log(chalk.hex('#6B7280')('\n No deployments yet. Run: nivii share\n'));
122
+ return;
123
+ }
124
+ console.log('');
125
+ console.log(chalk.hex('#A78BFA')(' Recent Deployments'));
126
+ console.log('');
127
+ deployments.forEach((d) => {
128
+ const age = timeSince(new Date(d.createdAt));
129
+ console.log(` ${chalk.cyan(d.slug)} · ${chalk.underline(d.url)} · ${chalk.hex('#6B7280')(age)}`);
130
+ });
131
+ console.log('');
132
+ });
133
+ // ─── analytics ────────────────────────────────────────────────────────────────
134
+ cli
135
+ .command('analytics [slug]', 'View analytics for a deployment')
136
+ .action(async (slug) => {
137
+ await runAnalytics(slug);
138
+ });
139
+ cli.version('0.1.8');
140
+ // ─── Show help when no command given ─────────────────────────────────────────
141
+ cli.parse(process.argv, { run: false });
142
+ if (!cli.matchedCommand) {
143
+ showHelp();
144
+ process.exit(0);
145
+ }
146
+ await cli.runMatchedCommand();
147
+ function timeSince(date) {
148
+ const seconds = Math.floor((Date.now() - date.getTime()) / 1000);
149
+ if (seconds < 60)
150
+ return `${seconds}s ago`;
151
+ if (seconds < 3600)
152
+ return `${Math.floor(seconds / 60)}m ago`;
153
+ if (seconds < 86400)
154
+ return `${Math.floor(seconds / 3600)}h ago`;
155
+ return `${Math.floor(seconds / 86400)}d ago`;
156
+ }
157
+ //# sourceMappingURL=cli.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cli.js","sourceRoot":"","sources":["../src/cli.ts"],"names":[],"mappings":";AACA,OAAO,EAAE,GAAG,EAAE,MAAM,KAAK,CAAC;AAC1B,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,QAAQ,EAAE,MAAM,qBAAqB,CAAC;AAC/C,OAAO,EAAE,YAAY,EAAE,MAAM,yBAAyB,CAAC;AACvD,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AACjD,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AACjD,OAAO,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAC;AAC3C,OAAO,EAAE,YAAY,EAAE,MAAM,qBAAqB,CAAC;AACnD,OAAO,EAAE,UAAU,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AAC7D,OAAO,EAAE,WAAW,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAExD,MAAM,GAAG,GAAG,GAAG,CAAC,OAAO,CAAC,CAAC;AAEzB,iFAAiF;AACjF,MAAM,MAAM,GAAG,UAAU,EAAE,CAAC;AAC5B,IAAI,MAAM,CAAC,QAAQ,EAAE,CAAC;IACpB,WAAW,EAAE,CAAC;IACd,YAAY,CAAC,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,CAAC;AACpC,CAAC;AAED,iFAAiF;AACjF,GAAG;KACA,OAAO,CAAC,OAAO,EAAE,wCAAwC,CAAC;KAC1D,MAAM,CAAC,aAAa,EAAE,oCAAoC,CAAC;KAC3D,MAAM,CAAC,eAAe,EAAE,oDAAoD,CAAC;KAC7E,MAAM,CAAC,mBAAmB,EAAE,kCAAkC,CAAC;KAC/D,MAAM,CAAC,OAAO,EAAE,iCAAiC,CAAC;KAClD,MAAM,CAAC,sBAAsB,EAAE,qCAAqC,CAAC;KACrE,MAAM,CAAC,QAAQ,EAAE,qDAAqD,CAAC;KACvE,MAAM,CAAC,UAAU,EAAE,8CAA8C,CAAC;KAClE,MAAM,CAAC,YAAY,EAAE,2CAA2C,CAAC;KACjE,MAAM,CAAC,aAAa,EAAE,sBAAsB,CAAC;KAC7C,MAAM,CAAC,eAAe,EAAE,4BAA4B,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;KACxE,MAAM,CAAC,iBAAiB,EAAE,6BAA6B,CAAC;KACxD,MAAM,CAAC,iBAAiB,EAAE,gCAAgC,CAAC;KAC3D,MAAM,CAAC,SAAS,EAAE,cAAc,CAAC;KACjC,MAAM,CAAC,WAAW,EAAE,qBAAqB,CAAC;KAC1C,MAAM,CAAC,KAAK,EAAE,OAAO,EAAE,EAAE;IACxB,IAAI,CAAC;QACH,MAAM,QAAQ,CAAC;YACb,GAAG,EAAE,OAAO,CAAC,GAAG;YAChB,IAAI,EAAE,OAAO,CAAC,IAAI;YAClB,IAAI,EAAE,OAAO,CAAC,IAAI;YAClB,GAAG,EAAE,OAAO,CAAC,GAAG;YAChB,OAAO,EAAE,OAAO,CAAC,OAAO;YACxB,IAAI,EAAE,OAAO,CAAC,IAAI;YAClB,MAAM,EAAE,OAAO,CAAC,MAAM;YACtB,OAAO,EAAE,OAAO,CAAC,UAAU,CAAC;YAC5B,GAAG,EAAE,OAAO,CAAC,GAAG;YAChB,IAAI,EAAE,OAAO,CAAC,IAAI;YAClB,QAAQ,EAAE,OAAO,CAAC,QAAQ;YAC1B,YAAY,EAAE,OAAO,CAAC,YAAY;YAClC,IAAI,EAAE,OAAO,CAAC,IAAI;YAClB,EAAE,EAAE,OAAO,CAAC,EAAE;SACf,CAAC,CAAC;IACL,CAAC;IAAC,OAAO,GAAQ,EAAE,CAAC;QAClB,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,GAAG,GAAG,CAAC,OAAO,CAAC,CAAC;QACjD,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC;AACH,CAAC,CAAC,CAAC;AAEL,iFAAiF;AACjF,GAAG;KACA,OAAO,CAAC,WAAW,EAAE,gDAAgD,CAAC;KACtE,KAAK,CAAC,IAAI,CAAC;KACX,MAAM,CAAC,aAAa,EAAE,+BAA+B,CAAC;KACtD,MAAM,CAAC,eAAe,EAAE,aAAa,CAAC;KACtC,MAAM,CAAC,sBAAsB,EAAE,6BAA6B,CAAC;KAC7D,MAAM,CAAC,qBAAqB,EAAE,qCAAqC,CAAC;KACpE,MAAM,CAAC,gBAAgB,EAAE,sBAAsB,CAAC;KAChD,MAAM,CAAC,iBAAiB,EAAE,qBAAqB,CAAC;KAChD,MAAM,CAAC,SAAS,EAAE,cAAc,CAAC;KACjC,MAAM,CAAC,WAAW,EAAE,qBAAqB,CAAC;KAC1C,MAAM,CAAC,KAAK,EAAE,OAAO,EAAE,EAAE;IACxB,IAAI,CAAC;QACH,MAAM,YAAY,CAAC;YACjB,GAAG,EAAE,OAAO,CAAC,GAAG;YAChB,IAAI,EAAE,OAAO,CAAC,IAAI;YAClB,OAAO,EAAE,OAAO,CAAC,OAAO;YACxB,QAAQ,EAAE,OAAO,CAAC,QAAQ;YAC1B,WAAW,EAAE,OAAO,CAAC,WAAW;YAChC,YAAY,EAAE,OAAO,CAAC,YAAY;YAClC,IAAI,EAAE,OAAO,CAAC,OAAO,CAAC;YACtB,MAAM,EAAE,OAAO,CAAC,SAAS,CAAC;SAC3B,CAAC,CAAC;IACL,CAAC;IAAC,OAAO,GAAQ,EAAE,CAAC;QAClB,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,GAAG,GAAG,CAAC,OAAO,CAAC,CAAC;QACjD,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC;AACH,CAAC,CAAC,CAAC;AAEL,iFAAiF;AACjF,GAAG;KACA,OAAO,CAAC,kBAAkB,EAAE,oCAAoC,CAAC;KACjE,MAAM,CAAC,KAAK,EAAE,UAAU,EAAE,EAAE;IAC3B,IAAI,CAAC;QACH,MAAM,MAAM,CAAC,UAAU,CAAC,CAAC;IAC3B,CAAC;IAAC,OAAO,GAAQ,EAAE,CAAC;QAClB,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,GAAG,CAAC,QAAQ,CAAC,GAAG,GAAG,CAAC,OAAO,CAAC,CAAC;QACjD,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC;AACH,CAAC,CAAC,CAAC;AAEL,iFAAiF;AACjF,GAAG;KACA,OAAO,CAAC,sBAAsB,EAAE,2BAA2B,CAAC;KAC5D,MAAM,CAAC,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE;IACrB,SAAS,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;AACxB,CAAC,CAAC,CAAC;AAEL,iFAAiF;AACjF,GAAG;KACA,OAAO,CAAC,QAAQ,EAAE,2BAA2B,CAAC;KAC9C,MAAM,CAAC,GAAG,EAAE;IACX,SAAS,EAAE,CAAC;AACd,CAAC,CAAC,CAAC;AAEL,iFAAiF;AACjF,GAAG;KACA,OAAO,CAAC,IAAI,EAAE,8BAA8B,CAAC;KAC7C,MAAM,CAAC,GAAG,EAAE;IACX,MAAM,GAAG,GAAG,UAAU,EAAE,CAAC;IACzB,MAAM,WAAW,GAAG,GAAG,CAAC,WAAW,IAAI,EAAE,CAAC;IAC1C,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC;QACxB,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,4CAA4C,CAAC,CAAC,CAAC;QAChF,OAAO;IACT,CAAC;IACD,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IAChB,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,sBAAsB,CAAC,CAAC,CAAC;IAC1D,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IAChB,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE;QACxB,MAAM,GAAG,GAAG,SAAS,CAAC,IAAI,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC;QAC7C,OAAO,CAAC,GAAG,CAAC,KAAK,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,MAAM,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,CAAC,MAAM,KAAK,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IACpG,CAAC,CAAC,CAAC;IACH,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;AAClB,CAAC,CAAC,CAAC;AAEL,iFAAiF;AACjF,GAAG;KACA,OAAO,CAAC,kBAAkB,EAAE,iCAAiC,CAAC;KAC9D,MAAM,CAAC,KAAK,EAAE,IAAI,EAAE,EAAE;IACrB,MAAM,YAAY,CAAC,IAAI,CAAC,CAAC;AAC3B,CAAC,CAAC,CAAC;AAEL,GAAG,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;AAErB,gFAAgF;AAChF,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,EAAE,EAAE,GAAG,EAAE,KAAK,EAAE,CAAC,CAAC;AACxC,IAAI,CAAC,GAAG,CAAC,cAAc,EAAE,CAAC;IACxB,QAAQ,EAAE,CAAC;IACX,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;AAClB,CAAC;AACD,MAAM,GAAG,CAAC,iBAAiB,EAAE,CAAC;AAE9B,SAAS,SAAS,CAAC,IAAU;IAC3B,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,GAAG,EAAE,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC;IACjE,IAAI,OAAO,GAAG,EAAE;QAAE,OAAO,GAAG,OAAO,OAAO,CAAC;IAC3C,IAAI,OAAO,GAAG,IAAI;QAAE,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,GAAG,EAAE,CAAC,OAAO,CAAC;IAC9D,IAAI,OAAO,GAAG,KAAK;QAAE,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC;IACjE,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,GAAG,KAAK,CAAC,OAAO,CAAC;AAC/C,CAAC"}
@@ -0,0 +1,2 @@
1
+ export declare function runConfig(key?: string, value?: string): void;
2
+ //# sourceMappingURL=config.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../../src/commands/config.ts"],"names":[],"mappings":"AAIA,wBAAgB,SAAS,CAAC,GAAG,CAAC,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,MAAM,QA4BrD"}
@@ -0,0 +1,32 @@
1
+ import chalk from 'chalk';
2
+ import { loadConfig, saveConfig } from '../utils/config.js';
3
+ import { theme } from '../ui/theme.js';
4
+ export function runConfig(key, value) {
5
+ const config = loadConfig();
6
+ if (!key) {
7
+ console.log('');
8
+ console.log(theme.primary(' Nivii Config') + theme.muted(' (~/.nivii/config.json)'));
9
+ console.log('');
10
+ Object.entries(config).forEach(([k, v]) => {
11
+ if (k === 'token') {
12
+ console.log(` ${chalk.cyan(k)}: ${chalk.hex('#6B7280')('[hidden]')}`);
13
+ }
14
+ else if (k === 'deployments') {
15
+ console.log(` ${chalk.cyan(k)}: ${chalk.hex('#6B7280')(JSON.stringify(v).slice(0, 60) + '…')}`);
16
+ }
17
+ else {
18
+ console.log(` ${chalk.cyan(k)}: ${chalk.white(String(v))}`);
19
+ }
20
+ });
21
+ console.log('');
22
+ return;
23
+ }
24
+ if (value === undefined) {
25
+ console.log(` ${chalk.cyan(key)}: ${chalk.white(String(config[key] ?? 'not set'))}`);
26
+ return;
27
+ }
28
+ config[key] = value;
29
+ saveConfig(config);
30
+ console.log(theme.success(` ✓ Set ${key} = ${value}`));
31
+ }
32
+ //# sourceMappingURL=config.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"config.js","sourceRoot":"","sources":["../../src/commands/config.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAC5D,OAAO,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAC;AAEvC,MAAM,UAAU,SAAS,CAAC,GAAY,EAAE,KAAc;IACpD,MAAM,MAAM,GAAG,UAAU,EAAE,CAAC;IAE5B,IAAI,CAAC,GAAG,EAAE,CAAC;QACT,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QAChB,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,gBAAgB,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,yBAAyB,CAAC,CAAC,CAAC;QACtF,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QAChB,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,EAAE;YACxC,IAAI,CAAC,KAAK,OAAO,EAAE,CAAC;gBAClB,OAAO,CAAC,GAAG,CAAC,KAAK,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,KAAK,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC;YACzE,CAAC;iBAAM,IAAI,CAAC,KAAK,aAAa,EAAE,CAAC;gBAC/B,OAAO,CAAC,GAAG,CAAC,KAAK,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,KAAK,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,GAAG,CAAC,EAAE,CAAC,CAAC;YACnG,CAAC;iBAAM,CAAC;gBACN,OAAO,CAAC,GAAG,CAAC,KAAK,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;YAC/D,CAAC;QACH,CAAC,CAAC,CAAC;QACH,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;QAChB,OAAO;IACT,CAAC;IAED,IAAI,KAAK,KAAK,SAAS,EAAE,CAAC;QACxB,OAAO,CAAC,GAAG,CAAC,KAAK,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,KAAK,CAAC,KAAK,CAAC,MAAM,CAAE,MAAc,CAAC,GAAG,CAAC,IAAI,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC;QAC/F,OAAO;IACT,CAAC;IAEA,MAAc,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;IAC7B,UAAU,CAAC,MAAM,CAAC,CAAC;IACnB,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,WAAW,GAAG,MAAM,KAAK,EAAE,CAAC,CAAC,CAAC;AAC1D,CAAC"}
@@ -0,0 +1,18 @@
1
+ export interface ShareOptions {
2
+ dir?: string;
3
+ slug?: string;
4
+ pass?: string;
5
+ otp?: boolean;
6
+ expires?: string;
7
+ live?: boolean;
8
+ collab?: boolean;
9
+ noBuild?: boolean;
10
+ cmd?: string;
11
+ port?: number;
12
+ maxViews?: number;
13
+ selfDestruct?: boolean;
14
+ open?: boolean;
15
+ qr?: boolean;
16
+ }
17
+ export declare function runShare(opts: ShareOptions): Promise<void>;
18
+ //# sourceMappingURL=share.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"share.d.ts","sourceRoot":"","sources":["../../src/commands/share.ts"],"names":[],"mappings":"AAaA,MAAM,WAAW,YAAY;IAC3B,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,GAAG,CAAC,EAAE,OAAO,CAAC;IACd,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,IAAI,CAAC,EAAE,OAAO,CAAC;IACf,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,IAAI,CAAC,EAAE,OAAO,CAAC;IACf,EAAE,CAAC,EAAE,OAAO,CAAC;CACd;AAED,wBAAsB,QAAQ,CAAC,IAAI,EAAE,YAAY,iBAiIhD"}
@@ -0,0 +1,126 @@
1
+ import path from 'path';
2
+ import chalk from 'chalk';
3
+ import { detectFramework } from '../core/detect.js';
4
+ import { runBuild } from '../core/build.js';
5
+ import { uploadDeploy } from '../core/upload.js';
6
+ import { generateSlug } from '../utils/hash.js';
7
+ import { loadConfig, updateConfig } from '../utils/config.js';
8
+ import { showQR, copyToClipboard, openBrowser } from '../core/qr.js';
9
+ import { startLiveSync } from '../core/tunnel.js';
10
+ import { showBanner } from '../ui/welcome.js';
11
+ import { step, success, warn } from '../ui/spinner.js';
12
+ import { theme } from '../ui/theme.js';
13
+ export async function runShare(opts) {
14
+ showBanner();
15
+ const cwd = opts.dir ? path.resolve(opts.dir) : process.cwd();
16
+ const config = loadConfig();
17
+ // ─── 1. Detect framework ───────────────────────────────────────────────────
18
+ step('🔍', 'Detecting project type…', cwd);
19
+ const detected = detectFramework(cwd);
20
+ const frameworkLabel = {
21
+ nextjs: 'Next.js', vite: 'Vite', 'react-cra': 'React (CRA)',
22
+ vue: 'Vue', svelte: 'Svelte', sveltekit: 'SvelteKit',
23
+ astro: 'Astro', remix: 'Remix', nuxt: 'Nuxt',
24
+ solid: 'Solid.js', express: 'Express', fastify: 'Fastify',
25
+ hono: 'Hono', static: 'Static HTML', unknown: 'Unknown',
26
+ };
27
+ success(`Detected ${chalk.cyan(frameworkLabel[detected.framework] || detected.framework)} ` +
28
+ `${theme.muted(`(${detected.confidence}% confidence)`)}`);
29
+ if (detected.framework === 'unknown' && !opts.noBuild) {
30
+ warn('Could not detect framework. Using current directory as static site.');
31
+ }
32
+ // ─── 2. Build ──────────────────────────────────────────────────────────────
33
+ const { outputDir } = await runBuild({
34
+ cwd,
35
+ detect: detected,
36
+ customCmd: opts.cmd,
37
+ noBuild: opts.noBuild,
38
+ });
39
+ const fullOutputDir = path.resolve(cwd, outputDir);
40
+ // ─── 3. Slug ───────────────────────────────────────────────────────────────
41
+ let slug = opts.slug;
42
+ if (!slug) {
43
+ slug = generateSlug(8);
44
+ }
45
+ else if (!config.proEmail) {
46
+ warn('Custom slugs require Pro. Run: nivii pro join');
47
+ slug = generateSlug(8);
48
+ }
49
+ // ─── 4. Upload (files directly, no zip) ────────────────────────────────────
50
+ const deployResult = await uploadDeploy({
51
+ buildDir: fullOutputDir,
52
+ slug,
53
+ token: config.token,
54
+ proEmail: config.proEmail,
55
+ password: opts.pass,
56
+ otp: opts.otp,
57
+ expires: opts.expires || '48h',
58
+ live: opts.live,
59
+ collab: opts.collab,
60
+ maxViews: opts.maxViews,
61
+ selfDestruct: opts.selfDestruct,
62
+ });
63
+ // ─── 5. Save to config ─────────────────────────────────────────────────────
64
+ const deployments = config.deployments || [];
65
+ deployments.unshift({
66
+ slug: deployResult.slug,
67
+ url: deployResult.url,
68
+ createdAt: new Date().toISOString(),
69
+ expiresAt: deployResult.expiresAt,
70
+ });
71
+ updateConfig({ deployments: deployments.slice(0, 20) });
72
+ // ─── 6. Output ─────────────────────────────────────────────────────────────
73
+ console.log('');
74
+ console.log(theme.box([
75
+ theme.accent(' 🚀 Your project is live!'),
76
+ '',
77
+ ' ' + theme.primary('URL:') + ' ' + chalk.underline.cyan(deployResult.url),
78
+ ...(deployResult.expiresAt ? [' ' + theme.muted('Expires:') + ' ' + theme.muted(new Date(deployResult.expiresAt).toLocaleString())] : []),
79
+ ...(opts.pass ? [' ' + theme.muted('Protected:') + ' ' + theme.success('✓ Password')] : []),
80
+ ...(opts.otp && deployResult.otpCode ? [' ' + theme.muted('OTP:') + ' ' + theme.warning(deployResult.otpCode)] : []),
81
+ ...(opts.live ? [' ' + theme.muted('Live sync:') + ' ' + theme.success('✓ Active')] : []),
82
+ ...(opts.collab && deployResult.collabId ? [' ' + theme.muted('Collab: ') + ' ' + theme.success('✓ Active — share URL for cursors')] : []),
83
+ ]));
84
+ console.log('');
85
+ // ─── 7. Copy URL to clipboard ──────────────────────────────────────────────
86
+ const copied = await copyToClipboard(deployResult.url);
87
+ if (copied) {
88
+ success('URL copied to clipboard');
89
+ }
90
+ // ─── 8. QR code ────────────────────────────────────────────────────────────
91
+ if (opts.qr !== false) {
92
+ await showQR(deployResult.url);
93
+ }
94
+ // ─── 9. Open browser ───────────────────────────────────────────────────────
95
+ if (opts.open !== false) {
96
+ await openBrowser(deployResult.url);
97
+ }
98
+ // ─── 10. Live sync ─────────────────────────────────────────────────────────
99
+ if (opts.live && deployResult.liveToken) {
100
+ console.log('');
101
+ console.log(theme.accent(' ⚡ Live Sync Active') + theme.muted(' — watching for changes…'));
102
+ console.log(theme.muted(' Press Ctrl+C to stop'));
103
+ console.log('');
104
+ const stopLive = startLiveSync({
105
+ watchDir: fullOutputDir,
106
+ slug: deployResult.slug,
107
+ liveToken: deployResult.liveToken,
108
+ onUpdate: async () => {
109
+ await uploadDeploy({
110
+ buildDir: fullOutputDir,
111
+ slug: deployResult.slug,
112
+ token: config.token,
113
+ live: true,
114
+ });
115
+ },
116
+ });
117
+ process.on('SIGINT', () => {
118
+ stopLive();
119
+ console.log('');
120
+ console.log(theme.muted(' ↳ Live sync stopped'));
121
+ process.exit(0);
122
+ });
123
+ await new Promise(() => { });
124
+ }
125
+ }
126
+ //# sourceMappingURL=share.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"share.js","sourceRoot":"","sources":["../../src/commands/share.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export declare function runWhoami(): void;
2
+ //# sourceMappingURL=whoami.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"whoami.d.ts","sourceRoot":"","sources":["../../src/commands/whoami.ts"],"names":[],"mappings":"AAIA,wBAAgB,SAAS,SAWxB"}
@@ -0,0 +1,17 @@
1
+ import chalk from 'chalk';
2
+ import { loadConfig } from '../utils/config.js';
3
+ import { theme } from '../ui/theme.js';
4
+ export function runWhoami() {
5
+ const config = loadConfig();
6
+ console.log('');
7
+ if (!config.token) {
8
+ console.log(theme.muted(' Not logged in. Using anonymous mode.'));
9
+ console.log(' ' + theme.accent('nivii login') + theme.muted(' to unlock Pro features.'));
10
+ }
11
+ else {
12
+ console.log(theme.success(' ✓ Logged in'));
13
+ console.log(' ' + chalk.cyan('Plan: ') + chalk.white(config.plan || 'free'));
14
+ }
15
+ console.log('');
16
+ }
17
+ //# sourceMappingURL=whoami.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"whoami.js","sourceRoot":"","sources":["../../src/commands/whoami.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AAChD,OAAO,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAC;AAEvC,MAAM,UAAU,SAAS;IACvB,MAAM,MAAM,GAAG,UAAU,EAAE,CAAC;IAC5B,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IAChB,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC;QAClB,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,CAAC,wCAAwC,CAAC,CAAC,CAAC;QACnE,OAAO,CAAC,GAAG,CAAC,IAAI,GAAG,KAAK,CAAC,MAAM,CAAC,aAAa,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,0BAA0B,CAAC,CAAC,CAAC;IAC5F,CAAC;SAAM,CAAC;QACN,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,eAAe,CAAC,CAAC,CAAC;QAC5C,OAAO,CAAC,GAAG,CAAC,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,IAAI,MAAM,CAAC,CAAC,CAAC;IAChF,CAAC;IACD,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;AAClB,CAAC"}
@@ -0,0 +1,11 @@
1
+ export interface AnalyticsData {
2
+ views: number;
3
+ sessions: Array<{
4
+ timestamp: string;
5
+ country: string;
6
+ city: string;
7
+ ua: string;
8
+ }>;
9
+ }
10
+ export declare function runAnalytics(slug?: string): Promise<void>;
11
+ //# sourceMappingURL=analytics.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"analytics.d.ts","sourceRoot":"","sources":["../../src/core/analytics.ts"],"names":[],"mappings":"AAOA,MAAM,WAAW,aAAa;IAC5B,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,EAAE,KAAK,CAAC;QACd,SAAS,EAAE,MAAM,CAAC;QAClB,OAAO,EAAE,MAAM,CAAC;QAChB,IAAI,EAAE,MAAM,CAAC;QACb,EAAE,EAAE,MAAM,CAAC;KACZ,CAAC,CAAC;CACJ;AAED,wBAAsB,YAAY,CAAC,IAAI,CAAC,EAAE,MAAM,iBA8C/C"}
@@ -0,0 +1,47 @@
1
+ /**
2
+ * Nivii Analytics — View deployment analytics
3
+ */
4
+ import { loadConfig } from '../utils/config.js';
5
+ import { theme } from '../ui/theme.js';
6
+ import chalk from 'chalk';
7
+ export async function runAnalytics(slug) {
8
+ const config = loadConfig();
9
+ const apiBase = config.apiBase || 'https://api.nivii.app';
10
+ if (!slug) {
11
+ const deployments = config.deployments || [];
12
+ if (!deployments.length) {
13
+ console.log(theme.muted('\n No deployments found. Run: nivii share\n'));
14
+ return;
15
+ }
16
+ slug = deployments[0].slug;
17
+ }
18
+ console.log('');
19
+ console.log(theme.primary(' Analytics') + theme.muted(` for ${slug}.nivii.app`));
20
+ console.log('');
21
+ try {
22
+ const { default: fetch } = await import('node-fetch');
23
+ const res = await fetch(`${apiBase}/analytics/${slug}`, {
24
+ headers: config.token ? { Authorization: `Bearer ${config.token}` } : {},
25
+ });
26
+ if (!res.ok) {
27
+ console.log(theme.error(' Failed to fetch analytics: ' + res.status));
28
+ return;
29
+ }
30
+ const data = await res.json();
31
+ console.log(' ' + chalk.cyan('Total views:') + ' ' + chalk.white(String(data.views)));
32
+ console.log('');
33
+ if (data.sessions && data.sessions.length > 0) {
34
+ console.log(' ' + theme.muted('Recent visitors:'));
35
+ console.log('');
36
+ data.sessions.slice(-10).reverse().forEach(s => {
37
+ const time = new Date(s.timestamp).toLocaleString();
38
+ console.log(` ${chalk.hex('#6B7280')(time)} ${chalk.cyan(s.country)}/${chalk.white(s.city)}`);
39
+ });
40
+ }
41
+ console.log('');
42
+ }
43
+ catch (err) {
44
+ console.log(theme.error(' ' + err.message));
45
+ }
46
+ }
47
+ //# sourceMappingURL=analytics.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"analytics.js","sourceRoot":"","sources":["../../src/core/analytics.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,11 @@
1
+ import type { DetectResult } from './detect.js';
2
+ export interface BuildOptions {
3
+ cwd: string;
4
+ detect: DetectResult;
5
+ customCmd?: string;
6
+ noBuild?: boolean;
7
+ }
8
+ export declare function runBuild(opts: BuildOptions): Promise<{
9
+ outputDir: string;
10
+ }>;
11
+ //# sourceMappingURL=build.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"build.d.ts","sourceRoot":"","sources":["../../src/core/build.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAIhD,MAAM,WAAW,YAAY;IAC3B,GAAG,EAAE,MAAM,CAAC;IACZ,MAAM,EAAE,YAAY,CAAC;IACrB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,OAAO,CAAC,EAAE,OAAO,CAAC;CACnB;AAED,wBAAsB,QAAQ,CAAC,IAAI,EAAE,YAAY,GAAG,OAAO,CAAC;IAAE,SAAS,EAAE,MAAM,CAAA;CAAE,CAAC,CAiCjF"}
@@ -0,0 +1,34 @@
1
+ import { spawn } from 'child_process';
2
+ import { createSpinner, step } from '../ui/spinner.js';
3
+ import chalk from 'chalk';
4
+ export async function runBuild(opts) {
5
+ const { cwd, detect, customCmd, noBuild } = opts;
6
+ if (noBuild || detect.buildCommand === null) {
7
+ step('📁', 'Skipping build', detect.outputDir);
8
+ return { outputDir: detect.outputDir };
9
+ }
10
+ const cmd = customCmd || detect.buildCommand;
11
+ const spinner = createSpinner(`Building with ${chalk.cyan(detect.framework)}…`);
12
+ spinner.start();
13
+ return new Promise((resolve, reject) => {
14
+ const proc = spawn(cmd, [], {
15
+ cwd,
16
+ shell: true,
17
+ env: { ...process.env, NODE_ENV: 'production', CI: '1' },
18
+ });
19
+ let stderr = '';
20
+ proc.stderr.on('data', d => { stderr += d.toString(); });
21
+ proc.on('close', code => {
22
+ if (code === 0) {
23
+ spinner.succeed(chalk.hex('#10B981')(`Build complete `) + chalk.hex('#6B7280')(`(${detect.framework})`));
24
+ resolve({ outputDir: detect.outputDir });
25
+ }
26
+ else {
27
+ spinner.fail(chalk.hex('#EF4444')('Build failed'));
28
+ console.log(chalk.hex('#6B7280')(stderr.slice(-800)));
29
+ reject(new Error(`Build exited with code ${code}`));
30
+ }
31
+ });
32
+ });
33
+ }
34
+ //# sourceMappingURL=build.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"build.js","sourceRoot":"","sources":["../../src/core/build.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AAEtC,OAAO,EAAE,aAAa,EAAE,IAAI,EAAE,MAAM,kBAAkB,CAAC;AACvD,OAAO,KAAK,MAAM,OAAO,CAAC;AAS1B,MAAM,CAAC,KAAK,UAAU,QAAQ,CAAC,IAAkB;IAC/C,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,SAAS,EAAE,OAAO,EAAE,GAAG,IAAI,CAAC;IAEjD,IAAI,OAAO,IAAI,MAAM,CAAC,YAAY,KAAK,IAAI,EAAE,CAAC;QAC5C,IAAI,CAAC,IAAI,EAAE,gBAAgB,EAAE,MAAM,CAAC,SAAS,CAAC,CAAC;QAC/C,OAAO,EAAE,SAAS,EAAE,MAAM,CAAC,SAAS,EAAE,CAAC;IACzC,CAAC;IAED,MAAM,GAAG,GAAG,SAAS,IAAI,MAAM,CAAC,YAAY,CAAC;IAC7C,MAAM,OAAO,GAAG,aAAa,CAAC,iBAAiB,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC;IAChF,OAAO,CAAC,KAAK,EAAE,CAAC;IAEhB,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;QACrC,MAAM,IAAI,GAAG,KAAK,CAAC,GAAG,EAAE,EAAE,EAAE;YAC1B,GAAG;YACH,KAAK,EAAE,IAAI;YACX,GAAG,EAAE,EAAE,GAAG,OAAO,CAAC,GAAG,EAAE,QAAQ,EAAE,YAAY,EAAE,EAAE,EAAE,GAAG,EAAE;SACzD,CAAC,CAAC;QAEH,IAAI,MAAM,GAAG,EAAE,CAAC;QAChB,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,CAAC,EAAE,GAAG,MAAM,IAAI,CAAC,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QAEzD,IAAI,CAAC,EAAE,CAAC,OAAO,EAAE,IAAI,CAAC,EAAE;YACtB,IAAI,IAAI,KAAK,CAAC,EAAE,CAAC;gBACf,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,iBAAiB,CAAC,GAAG,KAAK,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,IAAI,MAAM,CAAC,SAAS,GAAG,CAAC,CAAC,CAAC;gBACzG,OAAO,CAAC,EAAE,SAAS,EAAE,MAAM,CAAC,SAAS,EAAE,CAAC,CAAC;YAC3C,CAAC;iBAAM,CAAC;gBACN,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC;gBACnD,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;gBACtD,MAAM,CAAC,IAAI,KAAK,CAAC,0BAA0B,IAAI,EAAE,CAAC,CAAC,CAAC;YACtD,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;AACL,CAAC"}
@@ -0,0 +1,12 @@
1
+ export type Framework = 'nextjs' | 'vite' | 'react-cra' | 'vue' | 'svelte' | 'sveltekit' | 'astro' | 'remix' | 'nuxt' | 'solid' | 'express' | 'fastify' | 'hono' | 'static' | 'unknown';
2
+ export interface DetectResult {
3
+ framework: Framework;
4
+ buildCommand: string | null;
5
+ outputDir: string;
6
+ isServer: boolean;
7
+ port?: number;
8
+ packageManager: 'npm' | 'pnpm' | 'yarn' | 'bun';
9
+ confidence: number;
10
+ }
11
+ export declare function detectFramework(cwd: string): DetectResult;
12
+ //# sourceMappingURL=detect.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"detect.d.ts","sourceRoot":"","sources":["../../src/core/detect.ts"],"names":[],"mappings":"AAGA,MAAM,MAAM,SAAS,GACjB,QAAQ,GACR,MAAM,GACN,WAAW,GACX,KAAK,GACL,QAAQ,GACR,WAAW,GACX,OAAO,GACP,OAAO,GACP,MAAM,GACN,OAAO,GACP,SAAS,GACT,SAAS,GACT,MAAM,GACN,QAAQ,GACR,SAAS,CAAC;AAEd,MAAM,WAAW,YAAY;IAC3B,SAAS,EAAE,SAAS,CAAC;IACrB,YAAY,EAAE,MAAM,GAAG,IAAI,CAAC;IAC5B,SAAS,EAAE,MAAM,CAAC;IAClB,QAAQ,EAAE,OAAO,CAAC;IAClB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,cAAc,EAAE,KAAK,GAAG,MAAM,GAAG,MAAM,GAAG,KAAK,CAAC;IAChD,UAAU,EAAE,MAAM,CAAC;CACpB;AAED,wBAAgB,eAAe,CAAC,GAAG,EAAE,MAAM,GAAG,YAAY,CAiHzD"}