nivii 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.
Files changed (83) hide show
  1. package/README.md +56 -0
  2. package/dist/cli.d.ts +3 -0
  3. package/dist/cli.d.ts.map +1 -0
  4. package/dist/cli.js +108 -0
  5. package/dist/cli.js.map +1 -0
  6. package/dist/commands/config.d.ts +2 -0
  7. package/dist/commands/config.d.ts.map +1 -0
  8. package/dist/commands/config.js +32 -0
  9. package/dist/commands/config.js.map +1 -0
  10. package/dist/commands/share.d.ts +18 -0
  11. package/dist/commands/share.d.ts.map +1 -0
  12. package/dist/commands/share.js +131 -0
  13. package/dist/commands/share.js.map +1 -0
  14. package/dist/commands/whoami.d.ts +2 -0
  15. package/dist/commands/whoami.d.ts.map +1 -0
  16. package/dist/commands/whoami.js +17 -0
  17. package/dist/commands/whoami.js.map +1 -0
  18. package/dist/core/analytics.d.ts +11 -0
  19. package/dist/core/analytics.d.ts.map +1 -0
  20. package/dist/core/analytics.js +47 -0
  21. package/dist/core/analytics.js.map +1 -0
  22. package/dist/core/build.d.ts +11 -0
  23. package/dist/core/build.d.ts.map +1 -0
  24. package/dist/core/build.js +34 -0
  25. package/dist/core/build.js.map +1 -0
  26. package/dist/core/detect.d.ts +12 -0
  27. package/dist/core/detect.d.ts.map +1 -0
  28. package/dist/core/detect.js +122 -0
  29. package/dist/core/detect.js.map +1 -0
  30. package/dist/core/qr.d.ts +4 -0
  31. package/dist/core/qr.d.ts.map +1 -0
  32. package/dist/core/qr.js +29 -0
  33. package/dist/core/qr.js.map +1 -0
  34. package/dist/core/tunnel.d.ts +9 -0
  35. package/dist/core/tunnel.d.ts.map +1 -0
  36. package/dist/core/tunnel.js +55 -0
  37. package/dist/core/tunnel.js.map +1 -0
  38. package/dist/core/upload.d.ts +22 -0
  39. package/dist/core/upload.d.ts.map +1 -0
  40. package/dist/core/upload.js +49 -0
  41. package/dist/core/upload.js.map +1 -0
  42. package/dist/ui/spinner.d.ts +7 -0
  43. package/dist/ui/spinner.d.ts.map +1 -0
  44. package/dist/ui/spinner.js +32 -0
  45. package/dist/ui/spinner.js.map +1 -0
  46. package/dist/ui/theme.d.ts +14 -0
  47. package/dist/ui/theme.d.ts.map +1 -0
  48. package/dist/ui/theme.js +32 -0
  49. package/dist/ui/theme.js.map +1 -0
  50. package/dist/ui/welcome.d.ts +3 -0
  51. package/dist/ui/welcome.d.ts.map +1 -0
  52. package/dist/ui/welcome.js +39 -0
  53. package/dist/ui/welcome.js.map +1 -0
  54. package/dist/utils/config.d.ts +17 -0
  55. package/dist/utils/config.d.ts.map +1 -0
  56. package/dist/utils/config.js +31 -0
  57. package/dist/utils/config.js.map +1 -0
  58. package/dist/utils/hash.d.ts +3 -0
  59. package/dist/utils/hash.d.ts.map +1 -0
  60. package/dist/utils/hash.js +10 -0
  61. package/dist/utils/hash.js.map +1 -0
  62. package/dist/utils/zip.d.ts +2 -0
  63. package/dist/utils/zip.d.ts.map +1 -0
  64. package/dist/utils/zip.js +19 -0
  65. package/dist/utils/zip.js.map +1 -0
  66. package/package.json +44 -0
  67. package/src/cli.ts +112 -0
  68. package/src/commands/config.ts +33 -0
  69. package/src/commands/share.ts +166 -0
  70. package/src/commands/whoami.ts +16 -0
  71. package/src/core/analytics.ts +64 -0
  72. package/src/core/build.ts +46 -0
  73. package/src/core/detect.ts +159 -0
  74. package/src/core/qr.ts +30 -0
  75. package/src/core/tunnel.ts +70 -0
  76. package/src/core/upload.ts +67 -0
  77. package/src/ui/spinner.ts +36 -0
  78. package/src/ui/theme.ts +35 -0
  79. package/src/ui/welcome.ts +41 -0
  80. package/src/utils/config.ts +47 -0
  81. package/src/utils/hash.ts +11 -0
  82. package/src/utils/zip.ts +22 -0
  83. package/tsconfig.json +17 -0
package/README.md ADDED
@@ -0,0 +1,56 @@
1
+ # Nivii CLI
2
+
3
+ > ⚡ The fastest, most beautiful way to share any local dev project.
4
+
5
+ ## Install
6
+
7
+ ```bash
8
+ npm i -g nivii
9
+ ```
10
+
11
+ ## Usage
12
+
13
+ ```bash
14
+ # Share your project instantly
15
+ nivii share
16
+
17
+ # Share with custom slug (Pro)
18
+ nivii share --slug my-demo
19
+
20
+ # Password protect
21
+ nivii share --pass secret123
22
+
23
+ # Live sync mode
24
+ nivii share --live
25
+
26
+ # List deployments
27
+ nivii ls
28
+
29
+ # View analytics
30
+ nivii analytics
31
+
32
+ # Config
33
+ nivii config
34
+ ```
35
+
36
+ ## Flags
37
+
38
+ | Flag | Description |
39
+ |------|-------------|
40
+ | `--dir <dir>` | Directory to deploy |
41
+ | `--slug <slug>` | Custom slug (Pro) |
42
+ | `--pass <password>` | Password protection |
43
+ | `--otp` | One-time password |
44
+ | `--expires <duration>` | 1h / 24h / 7d / 30d / never |
45
+ | `--live` | Live sync mode |
46
+ | `--collab` | Collaborative preview (Pro) |
47
+ | `--no-build` | Skip build step |
48
+ | `--cmd <cmd>` | Custom build command |
49
+ | `--max-views <n>` | Self-destruct after N views |
50
+ | `--self-destruct` | Destroy after first view |
51
+ | `--no-qr` | Skip QR code |
52
+ | `--no-open` | Don't auto-open browser |
53
+
54
+ ## License
55
+
56
+ AGPL-3.0
package/dist/cli.d.ts ADDED
@@ -0,0 +1,3 @@
1
+ #!/usr/bin/env node
2
+ export {};
3
+ //# sourceMappingURL=cli.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cli.d.ts","sourceRoot":"","sources":["../src/cli.ts"],"names":[],"mappings":""}
package/dist/cli.js ADDED
@@ -0,0 +1,108 @@
1
+ #!/usr/bin/env node
2
+ import { cac } from 'cac';
3
+ import chalk from 'chalk';
4
+ import { runShare } from './commands/share.js';
5
+ import { runConfig } from './commands/config.js';
6
+ import { runWhoami } from './commands/whoami.js';
7
+ import { runAnalytics } from './core/analytics.js';
8
+ import { loadConfig, updateConfig } from './utils/config.js';
9
+ import { showWelcome } from './ui/welcome.js';
10
+ const cli = cac('nivii');
11
+ // ─── First run ────────────────────────────────────────────────────────────────
12
+ const config = loadConfig();
13
+ if (config.firstRun) {
14
+ showWelcome();
15
+ updateConfig({ firstRun: false });
16
+ }
17
+ // ─── share ────────────────────────────────────────────────────────────────────
18
+ cli
19
+ .command('share', 'Deploy your project and get a live URL')
20
+ .option('--dir <dir>', 'Directory to deploy (default: cwd)')
21
+ .option('--slug <slug>', 'Custom slug (Pro) e.g. my-demo → my-demo.nivii.app')
22
+ .option('--pass <password>', 'Password-protect your deployment')
23
+ .option('--otp', 'Enable one-time password access')
24
+ .option('--expires <duration>', 'Expiry: 1h / 24h / 7d / 30d / never')
25
+ .option('--live', 'Enable live sync (watch & auto-redeploy on changes)')
26
+ .option('--collab', 'Enable real-time collaborative preview (Pro)')
27
+ .option('--no-build', 'Skip build, use existing output directory')
28
+ .option('--cmd <cmd>', 'Custom build command')
29
+ .option('--port <port>', 'Port for server-mode proxy', { default: 3000 })
30
+ .option('--max-views <n>', 'Self-destruct after N views')
31
+ .option('--self-destruct', 'Self-destruct after first view')
32
+ .option('--no-qr', 'Skip QR code')
33
+ .option('--no-open', 'Do not open browser')
34
+ .action(async (options) => {
35
+ try {
36
+ await runShare({
37
+ dir: options.dir,
38
+ slug: options.slug,
39
+ pass: options.pass,
40
+ otp: options.otp,
41
+ expires: options.expires,
42
+ live: options.live,
43
+ collab: options.collab,
44
+ noBuild: options['no-build'],
45
+ cmd: options.cmd,
46
+ port: options.port,
47
+ maxViews: options.maxViews,
48
+ selfDestruct: options.selfDestruct,
49
+ open: options.open,
50
+ qr: options.qr,
51
+ });
52
+ }
53
+ catch (err) {
54
+ console.error(chalk.red('\n ✗ ') + err.message);
55
+ process.exit(1);
56
+ }
57
+ });
58
+ // ─── config ───────────────────────────────────────────────────────────────────
59
+ cli
60
+ .command('config [key] [value]', 'View or set config values')
61
+ .action((key, value) => {
62
+ runConfig(key, value);
63
+ });
64
+ // ─── whoami ───────────────────────────────────────────────────────────────────
65
+ cli
66
+ .command('whoami', 'Show current account info')
67
+ .action(() => {
68
+ runWhoami();
69
+ });
70
+ // ─── ls (list deployments) ────────────────────────────────────────────────────
71
+ cli
72
+ .command('ls', 'List your recent deployments')
73
+ .action(() => {
74
+ const cfg = loadConfig();
75
+ const deployments = cfg.deployments || [];
76
+ if (!deployments.length) {
77
+ console.log(chalk.hex('#6B7280')('\n No deployments yet. Run: nivii share\n'));
78
+ return;
79
+ }
80
+ console.log('');
81
+ console.log(chalk.hex('#A78BFA')(' Recent Deployments'));
82
+ console.log('');
83
+ deployments.forEach((d) => {
84
+ const age = timeSince(new Date(d.createdAt));
85
+ console.log(` ${chalk.cyan(d.slug)} · ${chalk.underline(d.url)} · ${chalk.hex('#6B7280')(age)}`);
86
+ });
87
+ console.log('');
88
+ });
89
+ // ─── analytics ────────────────────────────────────────────────────────────────
90
+ cli
91
+ .command('analytics [slug]', 'View analytics for a deployment')
92
+ .action(async (slug) => {
93
+ await runAnalytics(slug);
94
+ });
95
+ cli.help();
96
+ cli.version('0.1.0');
97
+ cli.parse();
98
+ function timeSince(date) {
99
+ const seconds = Math.floor((Date.now() - date.getTime()) / 1000);
100
+ if (seconds < 60)
101
+ return `${seconds}s ago`;
102
+ if (seconds < 3600)
103
+ return `${Math.floor(seconds / 60)}m ago`;
104
+ if (seconds < 86400)
105
+ return `${Math.floor(seconds / 3600)}h ago`;
106
+ return `${Math.floor(seconds / 86400)}d ago`;
107
+ }
108
+ //# sourceMappingURL=cli.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"cli.js","sourceRoot":"","sources":["../src/cli.ts"],"names":[],"mappings":"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"}
@@ -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":"AAcA,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,iBAsIhD"}
@@ -0,0 +1,131 @@
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 { zipDirectory } from '../utils/zip.js';
6
+ import { uploadDeploy } from '../core/upload.js';
7
+ import { generateSlug } from '../utils/hash.js';
8
+ import { loadConfig, updateConfig } from '../utils/config.js';
9
+ import { showQR, copyToClipboard, openBrowser } from '../core/qr.js';
10
+ import { startLiveSync } from '../core/tunnel.js';
11
+ import { showBanner } from '../ui/welcome.js';
12
+ import { step, success, warn } from '../ui/spinner.js';
13
+ import { theme } from '../ui/theme.js';
14
+ export async function runShare(opts) {
15
+ showBanner();
16
+ const cwd = opts.dir ? path.resolve(opts.dir) : process.cwd();
17
+ const config = loadConfig();
18
+ // ─── 1. Detect framework ───────────────────────────────────────────────────
19
+ step('🔍', 'Detecting project type…', cwd);
20
+ const detected = detectFramework(cwd);
21
+ const frameworkLabel = {
22
+ nextjs: 'Next.js', vite: 'Vite', 'react-cra': 'React (CRA)',
23
+ vue: 'Vue', svelte: 'Svelte', sveltekit: 'SvelteKit',
24
+ astro: 'Astro', remix: 'Remix', nuxt: 'Nuxt',
25
+ solid: 'Solid.js', express: 'Express', fastify: 'Fastify',
26
+ hono: 'Hono', static: 'Static HTML', unknown: 'Unknown',
27
+ };
28
+ success(`Detected ${chalk.cyan(frameworkLabel[detected.framework] || detected.framework)} ` +
29
+ `${theme.muted(`(${detected.confidence}% confidence)`)}`);
30
+ if (detected.framework === 'unknown' && !opts.noBuild) {
31
+ warn('Could not detect framework. Using current directory as static site.');
32
+ }
33
+ // ─── 2. Build ──────────────────────────────────────────────────────────────
34
+ const { outputDir } = await runBuild({
35
+ cwd,
36
+ detect: detected,
37
+ customCmd: opts.cmd,
38
+ noBuild: opts.noBuild,
39
+ });
40
+ const fullOutputDir = path.resolve(cwd, outputDir);
41
+ // ─── 3. Slug ───────────────────────────────────────────────────────────────
42
+ let slug = opts.slug;
43
+ if (!slug) {
44
+ slug = generateSlug(8);
45
+ }
46
+ else if (config.plan !== 'pro') {
47
+ warn('Custom slugs require Nivii Pro. Using random slug instead.');
48
+ slug = generateSlug(8);
49
+ }
50
+ // ─── 4. Zip ────────────────────────────────────────────────────────────────
51
+ step('📦', 'Compressing project…');
52
+ const zipPath = await zipDirectory(fullOutputDir);
53
+ // ─── 5. Upload ─────────────────────────────────────────────────────────────
54
+ const deployResult = await uploadDeploy({
55
+ zipPath,
56
+ slug,
57
+ token: config.token,
58
+ password: opts.pass,
59
+ otp: opts.otp,
60
+ expires: opts.expires || (config.plan === 'pro' ? undefined : '48h'),
61
+ live: opts.live,
62
+ collab: opts.collab,
63
+ maxViews: opts.maxViews,
64
+ selfDestruct: opts.selfDestruct,
65
+ });
66
+ // ─── 6. Save to config ─────────────────────────────────────────────────────
67
+ const deployments = config.deployments || [];
68
+ deployments.unshift({
69
+ slug: deployResult.slug,
70
+ url: deployResult.url,
71
+ createdAt: new Date().toISOString(),
72
+ expiresAt: deployResult.expiresAt,
73
+ });
74
+ updateConfig({ deployments: deployments.slice(0, 20) });
75
+ // ─── 7. Output ─────────────────────────────────────────────────────────────
76
+ console.log('');
77
+ console.log(theme.box([
78
+ theme.accent(' 🚀 Your project is live!'),
79
+ '',
80
+ ' ' + theme.primary('URL:') + ' ' + chalk.underline.cyan(deployResult.url),
81
+ ...(deployResult.expiresAt ? [' ' + theme.muted('Expires:') + ' ' + theme.muted(new Date(deployResult.expiresAt).toLocaleString())] : []),
82
+ ...(opts.pass ? [' ' + theme.muted('Protected:') + ' ' + theme.success('✓ Password')] : []),
83
+ ...(opts.otp && deployResult.otpCode ? [' ' + theme.muted('OTP:') + ' ' + theme.warning(deployResult.otpCode)] : []),
84
+ ...(opts.live ? [' ' + theme.muted('Live sync:') + ' ' + theme.success('✓ Active')] : []),
85
+ ...(opts.collab ? [' ' + theme.muted('Collab:') + ' ' + theme.success('✓ Active')] : []),
86
+ ]));
87
+ console.log('');
88
+ // ─── 8. Copy URL to clipboard ──────────────────────────────────────────────
89
+ const copied = await copyToClipboard(deployResult.url);
90
+ if (copied) {
91
+ success('URL copied to clipboard');
92
+ }
93
+ // ─── 9. QR code ────────────────────────────────────────────────────────────
94
+ if (opts.qr !== false) {
95
+ await showQR(deployResult.url);
96
+ }
97
+ // ─── 10. Open browser ──────────────────────────────────────────────────────
98
+ if (opts.open !== false) {
99
+ await openBrowser(deployResult.url);
100
+ }
101
+ // ─── 11. Live sync ─────────────────────────────────────────────────────────
102
+ if (opts.live && deployResult.liveToken) {
103
+ console.log('');
104
+ console.log(theme.accent(' ⚡ Live Sync Active') + theme.muted(' — watching for changes…'));
105
+ console.log(theme.muted(' Press Ctrl+C to stop'));
106
+ console.log('');
107
+ const stopLive = startLiveSync({
108
+ watchDir: fullOutputDir,
109
+ slug: deployResult.slug,
110
+ liveToken: deployResult.liveToken,
111
+ onUpdate: async () => {
112
+ const newZip = await zipDirectory(fullOutputDir);
113
+ await uploadDeploy({
114
+ zipPath: newZip,
115
+ slug: deployResult.slug,
116
+ token: config.token,
117
+ live: true,
118
+ });
119
+ },
120
+ });
121
+ process.on('SIGINT', () => {
122
+ stopLive();
123
+ console.log('');
124
+ console.log(theme.muted(' ↳ Live sync stopped'));
125
+ process.exit(0);
126
+ });
127
+ // Keep process alive
128
+ await new Promise(() => { });
129
+ }
130
+ }
131
+ //# 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"}