@tscircuit/cli 0.1.31 → 0.1.33
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/bun.lock +214 -126
- package/cli/export/register.ts +18 -2
- package/cli/init/register.ts +4 -6
- package/dist/main.js +147 -104
- package/lib/shared/generate-gitignore-file.ts +35 -0
- package/lib/shared/generate-ts-config.ts +3 -8
- package/package.json +3 -1
- package/tests/cli/export/__snapshots__/pcb.snap.svg +13 -0
- package/tests/cli/export/__snapshots__/schematic.snap.svg +17 -0
- package/tests/cli/export/export.test.ts +62 -0
package/dist/main.js
CHANGED
|
@@ -4,8 +4,8 @@
|
|
|
4
4
|
import { Command } from "commander";
|
|
5
5
|
|
|
6
6
|
// cli/init/register.ts
|
|
7
|
-
import * as
|
|
8
|
-
import * as
|
|
7
|
+
import * as fs4 from "node:fs";
|
|
8
|
+
import * as path4 from "node:path";
|
|
9
9
|
|
|
10
10
|
// lib/shared/detect-pkg-manager.ts
|
|
11
11
|
import fs from "fs";
|
|
@@ -54,8 +54,20 @@ function setupTsciProject(directory = process.cwd(), dependencies = ["@types/rea
|
|
|
54
54
|
}
|
|
55
55
|
|
|
56
56
|
// lib/shared/generate-ts-config.ts
|
|
57
|
-
import path2 from "path";
|
|
57
|
+
import path2 from "node:path";
|
|
58
|
+
|
|
59
|
+
// lib/shared/write-file-if-not-exists.ts
|
|
58
60
|
import fs3 from "fs";
|
|
61
|
+
var writeFileIfNotExists = (filePath, content) => {
|
|
62
|
+
if (!fs3.existsSync(filePath)) {
|
|
63
|
+
fs3.writeFileSync(filePath, content.trimStart(), "utf-8");
|
|
64
|
+
console.info(`Created: ${filePath}`);
|
|
65
|
+
} else {
|
|
66
|
+
console.info(`Skipped: ${filePath} already exists`);
|
|
67
|
+
}
|
|
68
|
+
};
|
|
69
|
+
|
|
70
|
+
// lib/shared/generate-ts-config.ts
|
|
59
71
|
var generateTsConfig = (dir) => {
|
|
60
72
|
const tsconfigPath = path2.join(dir, "tsconfig.json");
|
|
61
73
|
const tsconfigContent = JSON.stringify(
|
|
@@ -79,23 +91,41 @@ var generateTsConfig = (dir) => {
|
|
|
79
91
|
null,
|
|
80
92
|
2
|
|
81
93
|
);
|
|
82
|
-
|
|
83
|
-
fs3.writeFileSync(tsconfigPath, tsconfigContent.trimStart());
|
|
84
|
-
console.log(`Created: ${tsconfigPath}`);
|
|
85
|
-
} else {
|
|
86
|
-
console.log(`Skipped: ${tsconfigPath} already exists`);
|
|
87
|
-
}
|
|
94
|
+
writeFileIfNotExists(tsconfigPath, tsconfigContent);
|
|
88
95
|
};
|
|
89
96
|
|
|
90
|
-
// lib/shared/
|
|
91
|
-
import
|
|
92
|
-
var
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
97
|
+
// lib/shared/generate-gitignore-file.ts
|
|
98
|
+
import path3 from "node:path";
|
|
99
|
+
var generateGitIgnoreFile = (dir) => {
|
|
100
|
+
const gitignorePath = path3.join(dir, ".gitignore");
|
|
101
|
+
const gitignoreContent = `# Dependencies
|
|
102
|
+
node_modules/
|
|
103
|
+
|
|
104
|
+
# Build output
|
|
105
|
+
dist/
|
|
106
|
+
build/
|
|
107
|
+
|
|
108
|
+
# Environment variables
|
|
109
|
+
.env
|
|
110
|
+
.env.local
|
|
111
|
+
.env.*.local
|
|
112
|
+
|
|
113
|
+
# IDE files
|
|
114
|
+
.vscode/
|
|
115
|
+
.idea/
|
|
116
|
+
*.swp
|
|
117
|
+
*.swo
|
|
118
|
+
|
|
119
|
+
# OS files
|
|
120
|
+
.DS_Store
|
|
121
|
+
Thumbs.db
|
|
122
|
+
|
|
123
|
+
# Debug logs
|
|
124
|
+
npm-debug.log*
|
|
125
|
+
yarn-debug.log*
|
|
126
|
+
yarn-error.log*
|
|
127
|
+
`;
|
|
128
|
+
writeFileIfNotExists(gitignorePath, gitignoreContent);
|
|
99
129
|
};
|
|
100
130
|
|
|
101
131
|
// cli/init/register.ts
|
|
@@ -106,10 +136,10 @@ var registerInit = (program2) => {
|
|
|
106
136
|
"[directory]",
|
|
107
137
|
"Directory name (optional, defaults to current directory)"
|
|
108
138
|
).action((directory) => {
|
|
109
|
-
const projectDir = directory ?
|
|
110
|
-
|
|
139
|
+
const projectDir = directory ? path4.resolve(process.cwd(), directory) : process.cwd();
|
|
140
|
+
fs4.mkdirSync(projectDir, { recursive: true });
|
|
111
141
|
writeFileIfNotExists(
|
|
112
|
-
|
|
142
|
+
path4.join(projectDir, "index.tsx"),
|
|
113
143
|
`
|
|
114
144
|
import "@tscircuit/core";
|
|
115
145
|
|
|
@@ -123,7 +153,7 @@ export default () => (
|
|
|
123
153
|
`
|
|
124
154
|
);
|
|
125
155
|
writeFileIfNotExists(
|
|
126
|
-
|
|
156
|
+
path4.join(projectDir, ".npmrc"),
|
|
127
157
|
`
|
|
128
158
|
@tsci:registry=https://npm.tscircuit.com
|
|
129
159
|
`
|
|
@@ -134,12 +164,8 @@ export default () => (
|
|
|
134
164
|
console.error("Failed to install dependencies:", error);
|
|
135
165
|
process.exit(1);
|
|
136
166
|
}
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
} catch (error) {
|
|
140
|
-
console.error("Failed to generate tsconfig.json:", error);
|
|
141
|
-
process.exit(1);
|
|
142
|
-
}
|
|
167
|
+
generateTsConfig(projectDir);
|
|
168
|
+
generateGitIgnoreFile(projectDir);
|
|
143
169
|
console.info(
|
|
144
170
|
`\u{1F389} Initialization complete! Run ${directory ? `"cd ${directory}" & ` : ""}"tsci dev" to start developing.`
|
|
145
171
|
);
|
|
@@ -148,15 +174,15 @@ export default () => (
|
|
|
148
174
|
};
|
|
149
175
|
|
|
150
176
|
// cli/dev/register.ts
|
|
151
|
-
import * as
|
|
152
|
-
import * as
|
|
177
|
+
import * as path10 from "node:path";
|
|
178
|
+
import * as fs11 from "node:fs";
|
|
153
179
|
|
|
154
180
|
// lib/dependency-analysis/installNodeModuleTypesForSnippet.ts
|
|
155
|
-
import * as
|
|
156
|
-
import * as
|
|
181
|
+
import * as fs5 from "node:fs";
|
|
182
|
+
import * as path5 from "node:path";
|
|
157
183
|
import * as ts from "typescript";
|
|
158
184
|
async function installNodeModuleTypesForSnippet(snippetPath) {
|
|
159
|
-
const content =
|
|
185
|
+
const content = fs5.readFileSync(snippetPath, "utf-8");
|
|
160
186
|
const sourceFile = ts.createSourceFile(
|
|
161
187
|
snippetPath,
|
|
162
188
|
content,
|
|
@@ -177,12 +203,12 @@ async function installNodeModuleTypesForSnippet(snippetPath) {
|
|
|
177
203
|
ts.forEachChild(node, visit);
|
|
178
204
|
}
|
|
179
205
|
visit(sourceFile);
|
|
180
|
-
let projectRoot =
|
|
181
|
-
while (projectRoot !==
|
|
182
|
-
if (
|
|
206
|
+
let projectRoot = path5.dirname(snippetPath);
|
|
207
|
+
while (projectRoot !== path5.parse(projectRoot).root) {
|
|
208
|
+
if (fs5.existsSync(path5.join(projectRoot, "package.json"))) {
|
|
183
209
|
break;
|
|
184
210
|
}
|
|
185
|
-
projectRoot =
|
|
211
|
+
projectRoot = path5.dirname(projectRoot);
|
|
186
212
|
}
|
|
187
213
|
for (const importPath of imports) {
|
|
188
214
|
const [owner, name] = importPath.replace("@tsci/", "").split(".");
|
|
@@ -196,14 +222,14 @@ async function installNodeModuleTypesForSnippet(snippetPath) {
|
|
|
196
222
|
}
|
|
197
223
|
const data = await response.json();
|
|
198
224
|
if (data.snippet.dts) {
|
|
199
|
-
const packageDir =
|
|
225
|
+
const packageDir = path5.join(
|
|
200
226
|
projectRoot,
|
|
201
227
|
"node_modules",
|
|
202
228
|
"@tsci",
|
|
203
229
|
`${owner}.${name}`
|
|
204
230
|
);
|
|
205
|
-
|
|
206
|
-
|
|
231
|
+
fs5.mkdirSync(packageDir, { recursive: true });
|
|
232
|
+
fs5.writeFileSync(path5.join(packageDir, "index.d.ts"), data.snippet.dts);
|
|
207
233
|
}
|
|
208
234
|
} catch (error) {
|
|
209
235
|
console.warn(`Error fetching types for ${importPath}:`, error);
|
|
@@ -216,8 +242,8 @@ import ky2 from "ky";
|
|
|
216
242
|
|
|
217
243
|
// lib/server/createHttpServer.ts
|
|
218
244
|
import * as http from "node:http";
|
|
219
|
-
import * as
|
|
220
|
-
import * as
|
|
245
|
+
import * as fs6 from "node:fs";
|
|
246
|
+
import * as path6 from "node:path";
|
|
221
247
|
import { getNodeHandler } from "winterspec/adapters/node";
|
|
222
248
|
|
|
223
249
|
// package.json
|
|
@@ -225,7 +251,7 @@ var package_default = {
|
|
|
225
251
|
name: "@tscircuit/cli",
|
|
226
252
|
main: "dist/main.js",
|
|
227
253
|
type: "module",
|
|
228
|
-
version: "0.1.
|
|
254
|
+
version: "0.1.32",
|
|
229
255
|
bin: {
|
|
230
256
|
tsci: "./dist/main.js"
|
|
231
257
|
},
|
|
@@ -257,7 +283,9 @@ var package_default = {
|
|
|
257
283
|
"@tscircuit/eval": "^0.0.96",
|
|
258
284
|
"@tscircuit/file-server": "^0.0.13",
|
|
259
285
|
"@tscircuit/runframe": "^0.0.167",
|
|
286
|
+
"bun-match-svg": "^0.0.9",
|
|
260
287
|
chokidar: "4.0.1",
|
|
288
|
+
"circuit-to-svg": "^0.0.101",
|
|
261
289
|
commander: "^12.1.0",
|
|
262
290
|
configstore: "^7.0.0",
|
|
263
291
|
cosmiconfig: "^9.0.0",
|
|
@@ -296,13 +324,13 @@ var createHttpServer = async (port = 3020) => {
|
|
|
296
324
|
const server = http.createServer(async (req, res) => {
|
|
297
325
|
const url = new URL(req.url, `http://${req.headers.host}`);
|
|
298
326
|
if (url.pathname === "/standalone.min.js") {
|
|
299
|
-
const standaloneFilePath = process.env.RUNFRAME_STANDALONE_FILE_PATH ||
|
|
327
|
+
const standaloneFilePath = process.env.RUNFRAME_STANDALONE_FILE_PATH || path6.resolve(
|
|
300
328
|
process.cwd(),
|
|
301
329
|
"node_modules",
|
|
302
330
|
"@tscircuit/runframe/dist/standalone.min.js"
|
|
303
331
|
);
|
|
304
332
|
try {
|
|
305
|
-
const content =
|
|
333
|
+
const content = fs6.readFileSync(standaloneFilePath, "utf8");
|
|
306
334
|
res.writeHead(200, {
|
|
307
335
|
"Content-Type": "application/javascript; charset=utf-8"
|
|
308
336
|
});
|
|
@@ -391,19 +419,19 @@ var EventsWatcher = class extends EventEmitter {
|
|
|
391
419
|
};
|
|
392
420
|
|
|
393
421
|
// cli/dev/DevServer.ts
|
|
394
|
-
import
|
|
395
|
-
import
|
|
422
|
+
import path9 from "node:path";
|
|
423
|
+
import fs10 from "node:fs";
|
|
396
424
|
import * as chokidar from "chokidar";
|
|
397
425
|
|
|
398
426
|
// lib/dependency-analysis/FilesystemTypesHandler.ts
|
|
399
|
-
import * as
|
|
400
|
-
import * as
|
|
427
|
+
import * as fs8 from "node:fs";
|
|
428
|
+
import * as path7 from "node:path";
|
|
401
429
|
|
|
402
430
|
// lib/dependency-analysis/findImportsInSnippet.ts
|
|
403
|
-
import * as
|
|
431
|
+
import * as fs7 from "node:fs";
|
|
404
432
|
import * as ts2 from "typescript";
|
|
405
433
|
function findImportsInSnippet(snippetPath) {
|
|
406
|
-
const content =
|
|
434
|
+
const content = fs7.readFileSync(snippetPath, "utf-8");
|
|
407
435
|
const sourceFile = ts2.createSourceFile(
|
|
408
436
|
snippetPath,
|
|
409
437
|
content,
|
|
@@ -462,22 +490,22 @@ var FilesystemTypesHandler = class {
|
|
|
462
490
|
if (!importPath.startsWith("@tsci/")) return true;
|
|
463
491
|
const pathWithoutPrefix = importPath.replace("@tsci/", "");
|
|
464
492
|
const [owner, name] = pathWithoutPrefix.split(".");
|
|
465
|
-
const typePath =
|
|
493
|
+
const typePath = path7.join(
|
|
466
494
|
this.projectRoot,
|
|
467
495
|
"node_modules",
|
|
468
496
|
"@tsci",
|
|
469
497
|
`${owner}.${name}`,
|
|
470
498
|
"index.d.ts"
|
|
471
499
|
);
|
|
472
|
-
return
|
|
500
|
+
return fs8.existsSync(typePath);
|
|
473
501
|
}
|
|
474
502
|
findProjectRoot(startDir) {
|
|
475
|
-
let root =
|
|
476
|
-
while (root !==
|
|
477
|
-
if (
|
|
503
|
+
let root = path7.resolve(startDir);
|
|
504
|
+
while (root !== path7.parse(root).root) {
|
|
505
|
+
if (fs8.existsSync(path7.join(root, "package.json"))) {
|
|
478
506
|
return root;
|
|
479
507
|
}
|
|
480
|
-
root =
|
|
508
|
+
root = path7.dirname(root);
|
|
481
509
|
}
|
|
482
510
|
return startDir;
|
|
483
511
|
}
|
|
@@ -527,8 +555,8 @@ var getKy = () => {
|
|
|
527
555
|
};
|
|
528
556
|
|
|
529
557
|
// lib/shared/push-snippet.ts
|
|
530
|
-
import * as
|
|
531
|
-
import * as
|
|
558
|
+
import * as fs9 from "node:fs";
|
|
559
|
+
import * as path8 from "node:path";
|
|
532
560
|
import semver from "semver";
|
|
533
561
|
var pushSnippet = async ({
|
|
534
562
|
filePath,
|
|
@@ -543,10 +571,10 @@ var pushSnippet = async ({
|
|
|
543
571
|
}
|
|
544
572
|
let snippetFilePath = null;
|
|
545
573
|
if (filePath) {
|
|
546
|
-
snippetFilePath =
|
|
574
|
+
snippetFilePath = path8.resolve(filePath);
|
|
547
575
|
} else {
|
|
548
|
-
const defaultEntrypoint =
|
|
549
|
-
if (
|
|
576
|
+
const defaultEntrypoint = path8.resolve("index.tsx");
|
|
577
|
+
if (fs9.existsSync(defaultEntrypoint)) {
|
|
550
578
|
snippetFilePath = defaultEntrypoint;
|
|
551
579
|
onSuccess("No file provided. Using 'index.tsx' as the entrypoint.");
|
|
552
580
|
} else {
|
|
@@ -556,24 +584,24 @@ var pushSnippet = async ({
|
|
|
556
584
|
return onExit(1);
|
|
557
585
|
}
|
|
558
586
|
}
|
|
559
|
-
const packageJsonPath =
|
|
560
|
-
|
|
587
|
+
const packageJsonPath = path8.resolve(
|
|
588
|
+
path8.join(path8.dirname(snippetFilePath), "package.json")
|
|
561
589
|
);
|
|
562
590
|
let packageJson = {};
|
|
563
|
-
if (
|
|
591
|
+
if (fs9.existsSync(packageJsonPath)) {
|
|
564
592
|
try {
|
|
565
|
-
packageJson = JSON.parse(
|
|
593
|
+
packageJson = JSON.parse(fs9.readFileSync(packageJsonPath).toString());
|
|
566
594
|
} catch {
|
|
567
595
|
onError("Invalid package.json provided");
|
|
568
596
|
return onExit(1);
|
|
569
597
|
}
|
|
570
598
|
}
|
|
571
|
-
if (!
|
|
599
|
+
if (!fs9.existsSync(snippetFilePath)) {
|
|
572
600
|
onError(`File not found: ${snippetFilePath}`);
|
|
573
601
|
return onExit(1);
|
|
574
602
|
}
|
|
575
603
|
const ky3 = getKy();
|
|
576
|
-
const packageName = (packageJson.name ??
|
|
604
|
+
const packageName = (packageJson.name ?? path8.parse(snippetFilePath).name).replace(/^@/, "");
|
|
577
605
|
const packageAuthor = packageJson.author?.split(" ")[0] ?? cliConfig.get("githubUsername");
|
|
578
606
|
const packageIdentifier = `${packageAuthor}/${packageName}`;
|
|
579
607
|
let packageVersion = packageJson.version ?? await ky3.post("package_releases/list", {
|
|
@@ -592,7 +620,7 @@ var pushSnippet = async ({
|
|
|
592
620
|
if (packageJson.version) {
|
|
593
621
|
try {
|
|
594
622
|
packageJson.version = newVersion ?? `${packageVersion}`;
|
|
595
|
-
|
|
623
|
+
fs9.writeFileSync(packageJsonPath, JSON.stringify(packageJson, null, 2));
|
|
596
624
|
} catch (error) {
|
|
597
625
|
onError("Failed to update package.json version:" + error);
|
|
598
626
|
}
|
|
@@ -642,11 +670,11 @@ var pushSnippet = async ({
|
|
|
642
670
|
return onExit(1);
|
|
643
671
|
});
|
|
644
672
|
onSuccess("\n");
|
|
645
|
-
const directoryFiles =
|
|
673
|
+
const directoryFiles = fs9.readdirSync(path8.dirname(snippetFilePath));
|
|
646
674
|
for (const file of directoryFiles) {
|
|
647
|
-
const fileExtension =
|
|
675
|
+
const fileExtension = path8.extname(file).replace(".", "");
|
|
648
676
|
if (!["json", "tsx", "ts"].includes(fileExtension)) continue;
|
|
649
|
-
const fileContent =
|
|
677
|
+
const fileContent = fs9.readFileSync(path8.join(path8.dirname(snippetFilePath), file)).toString() ?? "";
|
|
650
678
|
await ky3.post("package_files/create", {
|
|
651
679
|
json: {
|
|
652
680
|
file_path: file,
|
|
@@ -702,7 +730,7 @@ var DevServer = class {
|
|
|
702
730
|
}) {
|
|
703
731
|
this.port = port;
|
|
704
732
|
this.componentFilePath = componentFilePath;
|
|
705
|
-
this.projectDir =
|
|
733
|
+
this.projectDir = path9.dirname(componentFilePath);
|
|
706
734
|
this.fsKy = ky2.create({
|
|
707
735
|
prefixUrl: `http://localhost:${port}`
|
|
708
736
|
});
|
|
@@ -737,7 +765,7 @@ var DevServer = class {
|
|
|
737
765
|
this.typesHandler?.handleInitialTypeDependencies(this.componentFilePath);
|
|
738
766
|
}
|
|
739
767
|
async addEntrypoint() {
|
|
740
|
-
const relativeComponentFilePath =
|
|
768
|
+
const relativeComponentFilePath = path9.relative(
|
|
741
769
|
this.projectDir,
|
|
742
770
|
this.componentFilePath
|
|
743
771
|
);
|
|
@@ -759,32 +787,32 @@ circuit.add(<MyCircuit />)
|
|
|
759
787
|
const { file } = await this.fsKy.get("api/files/get", {
|
|
760
788
|
searchParams: { file_path: ev.file_path }
|
|
761
789
|
}).json();
|
|
762
|
-
|
|
763
|
-
|
|
790
|
+
fs10.writeFileSync(
|
|
791
|
+
path9.join(this.projectDir, "manual-edits.json"),
|
|
764
792
|
file.text_content
|
|
765
793
|
);
|
|
766
794
|
}
|
|
767
795
|
}
|
|
768
796
|
async handleFileChangedOnFilesystem(absoluteFilePath) {
|
|
769
|
-
const relativeFilePath =
|
|
797
|
+
const relativeFilePath = path9.relative(this.projectDir, absoluteFilePath);
|
|
770
798
|
if (relativeFilePath.includes("manual-edits.json")) return;
|
|
771
799
|
await this.typesHandler?.handleFileTypeDependencies(absoluteFilePath);
|
|
772
800
|
console.log(`${relativeFilePath} saved. Applying changes...`);
|
|
773
801
|
await this.fsKy.post("api/files/upsert", {
|
|
774
802
|
json: {
|
|
775
803
|
file_path: relativeFilePath,
|
|
776
|
-
text_content:
|
|
804
|
+
text_content: fs10.readFileSync(absoluteFilePath, "utf-8"),
|
|
777
805
|
initiator: "filesystem_change"
|
|
778
806
|
}
|
|
779
807
|
}).json();
|
|
780
808
|
}
|
|
781
809
|
async upsertInitialFiles() {
|
|
782
|
-
const fileNames =
|
|
810
|
+
const fileNames = fs10.readdirSync(this.projectDir);
|
|
783
811
|
for (const fileName of fileNames) {
|
|
784
|
-
if (
|
|
812
|
+
if (fs10.statSync(path9.join(this.projectDir, fileName)).isDirectory())
|
|
785
813
|
continue;
|
|
786
|
-
const fileContent =
|
|
787
|
-
|
|
814
|
+
const fileContent = fs10.readFileSync(
|
|
815
|
+
path9.join(this.projectDir, fileName),
|
|
788
816
|
"utf-8"
|
|
789
817
|
);
|
|
790
818
|
await this.fsKy.post("api/files/upsert", {
|
|
@@ -843,14 +871,14 @@ var registerDev = (program2) => {
|
|
|
843
871
|
}
|
|
844
872
|
let absolutePath;
|
|
845
873
|
if (file) {
|
|
846
|
-
absolutePath =
|
|
874
|
+
absolutePath = path10.resolve(file);
|
|
847
875
|
if (!absolutePath.endsWith(".tsx")) {
|
|
848
876
|
console.error("Error: Only .tsx files are supported");
|
|
849
877
|
return;
|
|
850
878
|
}
|
|
851
879
|
} else {
|
|
852
|
-
const entrypointPath =
|
|
853
|
-
if (
|
|
880
|
+
const entrypointPath = path10.resolve("index.tsx");
|
|
881
|
+
if (fs11.existsSync(entrypointPath)) {
|
|
854
882
|
absolutePath = entrypointPath;
|
|
855
883
|
console.log("No file provided. Using 'index.tsx' as the entrypoint.");
|
|
856
884
|
} else {
|
|
@@ -860,7 +888,7 @@ var registerDev = (program2) => {
|
|
|
860
888
|
return;
|
|
861
889
|
}
|
|
862
890
|
}
|
|
863
|
-
const fileDir =
|
|
891
|
+
const fileDir = path10.dirname(absolutePath);
|
|
864
892
|
try {
|
|
865
893
|
console.log("Installing types for imported snippets...");
|
|
866
894
|
await installNodeModuleTypesForSnippet(absolutePath);
|
|
@@ -957,8 +985,8 @@ var registerConfigPrint = (program2) => {
|
|
|
957
985
|
};
|
|
958
986
|
|
|
959
987
|
// cli/clone/register.ts
|
|
960
|
-
import * as
|
|
961
|
-
import * as
|
|
988
|
+
import * as fs12 from "node:fs";
|
|
989
|
+
import * as path11 from "node:path";
|
|
962
990
|
var registerClone = (program2) => {
|
|
963
991
|
program2.command("clone").description("Clone a snippet from the registry").argument("<snippet>", "Snippet to clone (e.g. author/snippetName)").action(async (snippetPath) => {
|
|
964
992
|
const match = snippetPath.match(/^(?:@tsci\/)?([^/.]+)[/.](.+)$/);
|
|
@@ -989,13 +1017,13 @@ var registerClone = (program2) => {
|
|
|
989
1017
|
);
|
|
990
1018
|
process.exit(1);
|
|
991
1019
|
}
|
|
992
|
-
const dirPath =
|
|
993
|
-
|
|
1020
|
+
const dirPath = path11.resolve(`${author}.${snippetName}`);
|
|
1021
|
+
fs12.mkdirSync(dirPath, { recursive: true });
|
|
994
1022
|
for (const fileInfo of packageFileList.package_files) {
|
|
995
1023
|
const filePath = fileInfo.file_path.replace(/^\/|dist\//g, "");
|
|
996
1024
|
if (!filePath) continue;
|
|
997
|
-
const fullPath =
|
|
998
|
-
|
|
1025
|
+
const fullPath = path11.join(dirPath, filePath);
|
|
1026
|
+
fs12.mkdirSync(path11.dirname(fullPath), { recursive: true });
|
|
999
1027
|
try {
|
|
1000
1028
|
const fileContent = await ky3.post(
|
|
1001
1029
|
"package_files/get",
|
|
@@ -1012,7 +1040,7 @@ var registerClone = (program2) => {
|
|
|
1012
1040
|
|
|
1013
1041
|
${fileText}`;
|
|
1014
1042
|
}
|
|
1015
|
-
|
|
1043
|
+
fs12.writeFileSync(fullPath, fileText);
|
|
1016
1044
|
} catch (error) {
|
|
1017
1045
|
console.warn(
|
|
1018
1046
|
`Skipping ${filePath} due to error:`,
|
|
@@ -1020,15 +1048,15 @@ ${fileText}`;
|
|
|
1020
1048
|
);
|
|
1021
1049
|
}
|
|
1022
1050
|
}
|
|
1023
|
-
|
|
1024
|
-
|
|
1051
|
+
fs12.writeFileSync(
|
|
1052
|
+
path11.join(dirPath, ".npmrc"),
|
|
1025
1053
|
"@tsci:registry=https://npm.tscircuit.com"
|
|
1026
1054
|
);
|
|
1027
1055
|
generateTsConfig(dirPath);
|
|
1028
1056
|
setupTsciProject(dirPath);
|
|
1029
1057
|
console.log(`Successfully cloned to ${dirPath}/`);
|
|
1030
1058
|
console.log(
|
|
1031
|
-
`Run "cd ${
|
|
1059
|
+
`Run "cd ${path11.dirname(dirPath)} && tsci dev" to start developing.`
|
|
1032
1060
|
);
|
|
1033
1061
|
});
|
|
1034
1062
|
};
|
|
@@ -1041,8 +1069,12 @@ import semver2 from "semver";
|
|
|
1041
1069
|
import { createCircuitWebWorker } from "@tscircuit/eval";
|
|
1042
1070
|
import webWorkerBundleUrl from "@tscircuit/eval/blob-url";
|
|
1043
1071
|
import { getVirtualFileSystemFromDirPath } from "make-vfs";
|
|
1044
|
-
import
|
|
1045
|
-
import
|
|
1072
|
+
import path12 from "node:path";
|
|
1073
|
+
import fs13 from "node:fs";
|
|
1074
|
+
import {
|
|
1075
|
+
convertCircuitJsonToSchematicSvg,
|
|
1076
|
+
convertCircuitJsonToPcbSvg
|
|
1077
|
+
} from "circuit-to-svg";
|
|
1046
1078
|
var ALLOWED_FORMATS = [
|
|
1047
1079
|
"json",
|
|
1048
1080
|
"circuit-json",
|
|
@@ -1074,13 +1106,13 @@ Supported formats: ${ALLOWED_FORMATS.join(",")}`
|
|
|
1074
1106
|
);
|
|
1075
1107
|
}
|
|
1076
1108
|
if (!output) {
|
|
1077
|
-
output =
|
|
1109
|
+
output = path12.basename(file).replace(/\.[^.]+$/, "");
|
|
1078
1110
|
}
|
|
1079
1111
|
const worker = await createCircuitWebWorker({
|
|
1080
1112
|
webWorkerUrl: webWorkerBundleUrl
|
|
1081
1113
|
});
|
|
1082
|
-
const projectDir =
|
|
1083
|
-
const relativeComponentPath =
|
|
1114
|
+
const projectDir = path12.dirname(file);
|
|
1115
|
+
const relativeComponentPath = path12.relative(projectDir, file);
|
|
1084
1116
|
await worker.executeWithFsMap({
|
|
1085
1117
|
entrypoint: "entrypoint.tsx",
|
|
1086
1118
|
fsMap: {
|
|
@@ -1097,11 +1129,22 @@ circuit.add(<MyCircuit />)
|
|
|
1097
1129
|
});
|
|
1098
1130
|
await worker.renderUntilSettled();
|
|
1099
1131
|
const circuitJson = await worker.getCircuitJson();
|
|
1100
|
-
const outputPath =
|
|
1132
|
+
const outputPath = path12.join(
|
|
1101
1133
|
projectDir,
|
|
1102
1134
|
`${output}${OUTPUT_EXTENSIONS[format]}`
|
|
1103
1135
|
);
|
|
1104
|
-
|
|
1136
|
+
let outputContent;
|
|
1137
|
+
switch (format) {
|
|
1138
|
+
case "schematic-svg":
|
|
1139
|
+
outputContent = convertCircuitJsonToSchematicSvg(circuitJson);
|
|
1140
|
+
break;
|
|
1141
|
+
case "pcb-svg":
|
|
1142
|
+
outputContent = convertCircuitJsonToPcbSvg(circuitJson);
|
|
1143
|
+
break;
|
|
1144
|
+
default:
|
|
1145
|
+
outputContent = JSON.stringify(circuitJson);
|
|
1146
|
+
}
|
|
1147
|
+
fs13.writeFileSync(outputPath, outputContent);
|
|
1105
1148
|
console.log(`Exported to ${outputPath}`);
|
|
1106
1149
|
process.exit(0);
|
|
1107
1150
|
});
|
|
@@ -1169,4 +1212,4 @@ if (process.argv.length === 2) {
|
|
|
1169
1212
|
export {
|
|
1170
1213
|
program
|
|
1171
1214
|
};
|
|
1172
|
-
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../cli/main.ts", "../cli/init/register.ts", "../lib/shared/detect-pkg-manager.ts", "../lib/shared/setup-tsci-packages.ts", "../lib/shared/generate-ts-config.ts", "../lib/shared/write-file-if-not-exists.ts", "../cli/dev/register.ts", "../lib/dependency-analysis/installNodeModuleTypesForSnippet.ts", "../cli/dev/DevServer.ts", "../lib/server/createHttpServer.ts", "../package.json", "../lib/site/getIndex.ts", "../lib/server/EventsWatcher.ts", "../lib/dependency-analysis/FilesystemTypesHandler.ts", "../lib/dependency-analysis/findImportsInSnippet.ts", "../lib/cli-config/index.ts", "../lib/registry-api/get-ky.ts", "../lib/shared/push-snippet.ts", "../cli/auth/login/register.ts", "../cli/auth/logout/register.ts", "../cli/auth/register.ts", "../cli/config/register.ts", "../cli/config/print/register.ts", "../cli/clone/register.ts", "../cli/export/register.ts", "../cli/auth/print-token/register.ts", "../cli/auth/set-token/register.ts", "../cli/push/register.ts"],
  "sourcesContent": ["#!/usr/bin/env node\nimport { Command } from \"commander\"\nimport { registerInit } from \"./init/register\"\nimport { registerDev } from \"./dev/register\"\nimport { registerAuthLogin } from \"./auth/login/register\"\nimport { registerAuthLogout } from \"./auth/logout/register\"\nimport { registerAuth } from \"./auth/register\"\nimport { registerConfig } from \"./config/register\"\nimport { registerConfigPrint } from \"./config/print/register\"\nimport { registerClone } from \"./clone/register\"\nimport { perfectCli } from \"perfect-cli\"\nimport pkg from \"../package.json\"\nimport semver from \"semver\"\nimport { registerExport } from \"./export/register\"\nimport { registerAuthPrintToken } from \"./auth/print-token/register\"\nimport { registerAuthSetToken } from \"./auth/set-token/register\"\nimport { registerPush } from \"./push/register\"\n\nexport const program = new Command()\n\nprogram\n  .name(\"tsci\")\n  .description(\"CLI for developing tscircuit snippets\")\n  // HACK: at build time the version is old, we need to\n  // fix this at some point...\n  .version(semver.inc(pkg.version, \"patch\") ?? pkg.version)\n\nregisterInit(program)\n\nregisterDev(program)\nregisterClone(program)\nregisterPush(program)\n\nregisterAuth(program)\nregisterAuthLogin(program)\nregisterAuthLogout(program)\nregisterAuthPrintToken(program)\nregisterAuthSetToken(program)\n\nregisterConfig(program)\nregisterConfigPrint(program)\n\nregisterExport(program)\n\nif (process.argv.length === 2) {\n  perfectCli(program, process.argv)\n} else {\n  program.parse()\n}\n", "import type { Command } from \"commander\"\nimport * as fs from \"node:fs\"\nimport * as path from \"node:path\"\nimport { setupTsciProject } from \"lib/shared/setup-tsci-packages\"\nimport { generateTsConfig } from \"lib/shared/generate-ts-config\"\nimport { writeFileIfNotExists } from \"lib/shared/write-file-if-not-exists\"\n\nexport const registerInit = (program: Command) => {\n  program\n    .command(\"init\")\n    .description(\n      \"Initialize a new TSCircuit project in the specified directory (or current directory if none is provided)\",\n    )\n    .argument(\n      \"[directory]\",\n      \"Directory name (optional, defaults to current directory)\",\n    )\n    .action((directory?: string) => {\n      const projectDir = directory\n        ? path.resolve(process.cwd(), directory)\n        : process.cwd()\n\n      // Ensure the directory exists\n      fs.mkdirSync(projectDir, { recursive: true })\n\n      // Create essential project files\n      writeFileIfNotExists(\n        path.join(projectDir, \"index.tsx\"),\n        `\nimport \"@tscircuit/core\";\n\nexport default () => (\n  <board width=\"10mm\" height=\"10mm\">\n    <resistor resistance=\"1k\" footprint=\"0402\" name=\"R1\" schX={3} pcbX={3} />\n    <capacitor capacitance=\"1000pF\" footprint=\"0402\" name=\"C1\" schX={-3} pcbX={-3} />\n    <trace from=\".R1 > .pin1\" to=\".C1 > .pin1\" />\n  </board>\n);\n`,\n      )\n\n      writeFileIfNotExists(\n        path.join(projectDir, \".npmrc\"),\n        `\n@tsci:registry=https://npm.tscircuit.com\n`,\n      )\n\n      // Setup project dependencies\n      try {\n        setupTsciProject(projectDir)\n      } catch (error) {\n        console.error(\"Failed to install dependencies:\", error)\n        process.exit(1)\n      }\n\n      // Generate tsconfig.json\n      try {\n        generateTsConfig(projectDir)\n      } catch (error) {\n        console.error(\"Failed to generate tsconfig.json:\", error)\n        process.exit(1)\n      }\n\n      console.info(\n        `\uD83C\uDF89 Initialization complete! Run ${directory ? `\"cd ${directory}\" & ` : \"\"}\"tsci dev\" to start developing.`,\n      )\n      process.exit(0)\n    })\n}\n", "import fs from \"fs\"\n\n// Detect the package manager being used in the project\nexport const detectPackageManager = (): string => {\n  const userAgent = process.env.npm_config_user_agent || \"\"\n  if (userAgent.startsWith(\"yarn\")) return \"yarn\"\n  if (userAgent.startsWith(\"pnpm\")) return \"pnpm\"\n  if (userAgent.startsWith(\"bun\")) return \"bun\"\n\n  if (fs.existsSync(\"yarn.lock\")) return \"yarn\"\n  if (fs.existsSync(\"pnpm-lock.yaml\")) return \"pnpm\"\n  if (fs.existsSync(\"bun.lockb\")) return \"bun\"\n\n  return \"npm\" // Default to npm\n}\n", "import { detectPackageManager } from \"./detect-pkg-manager\"\nimport fs from \"node:fs\"\nimport path from \"node:path\"\nimport { execSync } from \"node:child_process\"\n\nexport function setupTsciProject(\n  directory = process.cwd(),\n  dependencies = [\"@types/react\", \"@tscircuit/core\"],\n) {\n  const projectPath = path.resolve(directory)\n  if (!fs.existsSync(projectPath)) {\n    fs.mkdirSync(projectPath, { recursive: true })\n  }\n  const packageManager = detectPackageManager()\n\n  console.log(`Initializing project in ${projectPath}...`)\n  process.chdir(projectPath)\n\n  if (!fs.existsSync(\"package.json\")) {\n    const initCommand =\n      packageManager === \"yarn\"\n        ? \"yarn init -y\"\n        : packageManager === \"pnpm\"\n          ? \"pnpm init\"\n          : packageManager === \"bun\"\n            ? \"bun init -y\"\n            : \"npm init -y\"\n\n    execSync(initCommand, { stdio: \"inherit\" })\n    console.log(\"Project initialized successfully.\")\n  }\n\n  // Read and modify package.json\n  const packageJsonPath = path.join(projectPath, \"package.json\")\n  const packageJson = JSON.parse(fs.readFileSync(packageJsonPath, \"utf-8\"))\n\n  // Remove unwanted fields\n  delete packageJson.keywords\n  delete packageJson.author\n  delete packageJson.main\n\n  fs.writeFileSync(packageJsonPath, JSON.stringify(packageJson, null, 2))\n  console.log(\"Updated package.json to remove unnecessary fields.\")\n\n  if (dependencies.length > 0) {\n    console.log(\"Installing dependencies...\")\n    const installCommand =\n      packageManager === \"yarn\"\n        ? `yarn add -D ${dependencies.join(\" \")}`\n        : packageManager === \"pnpm\"\n          ? `pnpm add -D ${dependencies.join(\" \")}`\n          : packageManager === \"bun\"\n            ? `bun add -D ${dependencies.join(\" \")}`\n            : `npm install -D ${dependencies.join(\" \")}`\n\n    execSync(installCommand, { stdio: \"inherit\" })\n    console.log(\"Dependencies installed successfully.\")\n  }\n\n  return packageJson.name || \"unknown\"\n}\n", "import path from \"path\"\nimport fs from \"fs\"\n\n// Generate a React-compatible tsconfig.json\nexport const generateTsConfig = (dir: string) => {\n  const tsconfigPath = path.join(dir, \"tsconfig.json\")\n  const tsconfigContent = JSON.stringify(\n    {\n      compilerOptions: {\n        target: \"ES6\",\n        module: \"ESNext\",\n        jsx: \"react-jsx\",\n        outDir: \"dist\",\n        strict: true,\n        esModuleInterop: true,\n        moduleResolution: \"node\",\n        skipLibCheck: true,\n        forceConsistentCasingInFileNames: true,\n        resolveJsonModule: true,\n        sourceMap: true,\n        allowSyntheticDefaultImports: true,\n        experimentalDecorators: true,\n      },\n    },\n    null,\n    2,\n  )\n  if (!fs.existsSync(tsconfigPath)) {\n    fs.writeFileSync(tsconfigPath, tsconfigContent.trimStart())\n    console.log(`Created: ${tsconfigPath}`)\n  } else {\n    console.log(`Skipped: ${tsconfigPath} already exists`)\n  }\n}\n", "import fs from \"fs\"\n\nexport const writeFileIfNotExists = (filePath: string, content: string) => {\n  if (!fs.existsSync(filePath)) {\n    fs.writeFileSync(filePath, content.trimStart(), \"utf-8\")\n    console.info(`Created: ${filePath}`)\n  } else {\n    console.info(`Skipped: ${filePath} already exists`)\n  }\n}\n", "import type { Command } from \"commander\"\nimport * as path from \"node:path\"\nimport * as chokidar from \"chokidar\"\nimport * as fs from \"node:fs\"\nimport { createHttpServer } from \"lib/server/createHttpServer\"\nimport { getLocalFileDependencies } from \"lib/dependency-analysis/getLocalFileDependencies\"\nimport { installNodeModuleTypesForSnippet } from \"../../lib/dependency-analysis/installNodeModuleTypesForSnippet\"\nimport { EventsWatcher } from \"../../lib/server/EventsWatcher\"\nimport { DevServer } from \"./DevServer\"\nimport * as net from \"node:net\"\n\nexport const registerDev = (program: Command) => {\n  program\n    .command(\"dev\")\n    .description(\"Start development server for a snippet\")\n    .argument(\"[file]\", \"Path to the snippet file\")\n    .option(\"-p, --port <number>\", \"Port to run server on\", \"3020\")\n    .action(async (file: string, options: { port: string }) => {\n      let port = parseInt(options.port)\n\n      const isPortAvailable = (port: number): Promise<boolean> => {\n        return new Promise((resolve) => {\n          const server = net.createServer()\n          server.once(\"error\", () => resolve(false))\n          server.once(\"listening\", () => {\n            server.close(() => resolve(true))\n          })\n          server.listen(port)\n        })\n      }\n\n      while (!(await isPortAvailable(port))) {\n        console.log(`Port ${port} is in use, trying port ${port + 1}...`)\n        port += 1\n      }\n\n      let absolutePath: string\n\n      if (file) {\n        absolutePath = path.resolve(file)\n        if (!absolutePath.endsWith(\".tsx\")) {\n          console.error(\"Error: Only .tsx files are supported\")\n          return\n        }\n      } else {\n        const entrypointPath = path.resolve(\"index.tsx\")\n        if (fs.existsSync(entrypointPath)) {\n          absolutePath = entrypointPath\n          console.log(\"No file provided. Using 'index.tsx' as the entrypoint.\")\n        } else {\n          console.log(\n            \"No entrypoint found. Run 'tsci init' to bootstrap a basic project.\",\n          )\n          return\n        }\n      }\n\n      const fileDir = path.dirname(absolutePath)\n\n      try {\n        console.log(\"Installing types for imported snippets...\")\n        await installNodeModuleTypesForSnippet(absolutePath)\n        console.log(\"Types installed successfully\")\n      } catch (error) {\n        console.warn(\"Failed to install types:\", error)\n      }\n\n      const server = new DevServer({\n        port,\n        componentFilePath: absolutePath,\n      })\n\n      await server.start()\n      await server.addEntrypoint()\n    })\n}\n", "import * as fs from \"node:fs\"\nimport * as path from \"node:path\"\nimport * as ts from \"typescript\"\n\ninterface SnippetApiResponse {\n  snippet: {\n    dts: string\n  }\n}\n\nexport async function installNodeModuleTypesForSnippet(snippetPath: string) {\n  const content = fs.readFileSync(snippetPath, \"utf-8\")\n  const sourceFile = ts.createSourceFile(\n    snippetPath,\n    content,\n    ts.ScriptTarget.Latest,\n    true,\n  )\n\n  const imports: string[] = []\n\n  function visit(node: ts.Node) {\n    if (ts.isImportDeclaration(node)) {\n      const moduleSpecifier = node.moduleSpecifier\n      if (moduleSpecifier && ts.isStringLiteral(moduleSpecifier)) {\n        const importPath = moduleSpecifier.text\n        if (importPath.startsWith(\"@tsci/\")) {\n          imports.push(importPath)\n        }\n      }\n    }\n    ts.forEachChild(node, visit)\n  }\n\n  visit(sourceFile)\n\n  let projectRoot = path.dirname(snippetPath)\n  while (projectRoot !== path.parse(projectRoot).root) {\n    if (fs.existsSync(path.join(projectRoot, \"package.json\"))) {\n      break\n    }\n    projectRoot = path.dirname(projectRoot)\n  }\n\n  for (const importPath of imports) {\n    const [owner, name] = importPath.replace(\"@tsci/\", \"\").split(\".\")\n    try {\n      const response = await fetch(\n        `https://registry-api.tscircuit.com/snippets/get?owner_name=${owner}&unscoped_name=${name}`,\n      )\n\n      if (!response.ok) {\n        console.warn(`Failed to fetch types for ${importPath}`)\n        continue\n      }\n\n      const data: SnippetApiResponse = await response.json()\n\n      if (data.snippet.dts) {\n        const packageDir = path.join(\n          projectRoot,\n          \"node_modules\",\n          \"@tsci\",\n          `${owner}.${name}`,\n        )\n        fs.mkdirSync(packageDir, { recursive: true })\n\n        fs.writeFileSync(path.join(packageDir, \"index.d.ts\"), data.snippet.dts)\n      }\n    } catch (error) {\n      console.warn(`Error fetching types for ${importPath}:`, error)\n    }\n  }\n}\n", "import ky from \"ky\"\nimport type { FileServerRoutes } from \"lib/file-server/FileServerRoutes\"\nimport { createHttpServer } from \"lib/server/createHttpServer\"\nimport { EventsWatcher } from \"lib/server/EventsWatcher\"\nimport type http from \"node:http\"\nimport type { TypedKyInstance } from \"typed-ky\"\nimport path from \"node:path\"\nimport fs from \"node:fs\"\nimport type { FileUpdatedEvent } from \"lib/file-server/FileServerEvent\"\nimport * as chokidar from \"chokidar\"\nimport { FilesystemTypesHandler } from \"lib/dependency-analysis/FilesystemTypesHandler\"\nimport { pushSnippet } from \"lib/shared/push-snippet\"\n\nexport class DevServer {\n  port: number\n  /**\n   * The path to a component that exports a <board /> or <group /> component\n   */\n  componentFilePath: string\n\n  projectDir: string\n\n  /**\n   * The HTTP server that hosts the file server and event bus. You can use\n   * fsKy to communicate with the file server/event bus\n   */\n  httpServer?: http.Server\n  /**\n   * Watches for events on the event bus by polling `api/events/list`\n   */\n  eventsWatcher?: EventsWatcher\n  /**\n   * A ky instance that can be used to communicate with the file server and\n   * event bus\n   */\n  fsKy: TypedKyInstance<keyof FileServerRoutes, FileServerRoutes>\n  /**\n   * A chokidar instance that watches the project directory for file changes\n   */\n  filesystemWatcher?: chokidar.FSWatcher\n\n  private typesHandler?: FilesystemTypesHandler\n\n  constructor({\n    port,\n    componentFilePath,\n  }: {\n    port: number\n    componentFilePath: string\n  }) {\n    this.port = port\n    this.componentFilePath = componentFilePath\n    this.projectDir = path.dirname(componentFilePath)\n    this.fsKy = ky.create({\n      prefixUrl: `http://localhost:${port}`,\n    }) as any\n    this.typesHandler = new FilesystemTypesHandler(this.projectDir)\n  }\n\n  async start() {\n    const { server } = await createHttpServer(this.port)\n    this.httpServer = server\n\n    this.eventsWatcher = new EventsWatcher(`http://localhost:${this.port}`)\n    this.eventsWatcher.start()\n\n    this.eventsWatcher.on(\n      \"FILE_UPDATED\",\n      this.handleFileUpdatedEventFromServer.bind(this),\n    )\n\n    this.eventsWatcher.on(\n      \"REQUEST_TO_SAVE_SNIPPET\",\n      this.saveSnippet.bind(this),\n    )\n\n    this.filesystemWatcher = chokidar.watch(this.projectDir, {\n      persistent: true,\n      ignoreInitial: true,\n    })\n\n    this.filesystemWatcher.on(\"change\", (filePath) =>\n      this.handleFileChangedOnFilesystem(filePath),\n    )\n    this.filesystemWatcher.on(\"add\", (filePath) =>\n      this.handleFileChangedOnFilesystem(filePath),\n    )\n\n    this.upsertInitialFiles()\n\n    this.typesHandler?.handleInitialTypeDependencies(this.componentFilePath)\n  }\n\n  async addEntrypoint() {\n    const relativeComponentFilePath = path.relative(\n      this.projectDir,\n      this.componentFilePath,\n    )\n    await this.fsKy.post(\"api/files/upsert\", {\n      json: {\n        file_path: \"entrypoint.tsx\",\n        text_content: `\nimport MyCircuit from \"./${relativeComponentFilePath}\"\n\ncircuit.add(<MyCircuit />)\n`,\n      },\n    })\n  }\n\n  async handleFileUpdatedEventFromServer(ev: FileUpdatedEvent) {\n    if (ev.initiator === \"filesystem_change\") return\n\n    if (ev.file_path === \"manual-edits.json\") {\n      console.log(\"Manual edits updated, updating on filesystem...\")\n      const { file } = await this.fsKy\n        .get(\"api/files/get\", {\n          searchParams: { file_path: ev.file_path },\n        })\n        .json()\n      fs.writeFileSync(\n        path.join(this.projectDir, \"manual-edits.json\"),\n        file.text_content,\n      )\n    }\n  }\n\n  async handleFileChangedOnFilesystem(absoluteFilePath: string) {\n    const relativeFilePath = path.relative(this.projectDir, absoluteFilePath)\n    // We've temporarily disabled upserting manual edits from filesystem changes\n    // because it can be edited by the browser\n    if (relativeFilePath.includes(\"manual-edits.json\")) return\n\n    await this.typesHandler?.handleFileTypeDependencies(absoluteFilePath)\n\n    console.log(`${relativeFilePath} saved. Applying changes...`)\n    await this.fsKy\n      .post(\"api/files/upsert\", {\n        json: {\n          file_path: relativeFilePath,\n          text_content: fs.readFileSync(absoluteFilePath, \"utf-8\"),\n          initiator: \"filesystem_change\",\n        },\n      })\n      .json()\n  }\n\n  async upsertInitialFiles() {\n    // Scan project directory for all files and upsert them\n    const fileNames = fs.readdirSync(this.projectDir)\n    for (const fileName of fileNames) {\n      if (fs.statSync(path.join(this.projectDir, fileName)).isDirectory())\n        continue\n      const fileContent = fs.readFileSync(\n        path.join(this.projectDir, fileName),\n        \"utf-8\",\n      )\n      await this.fsKy.post(\"api/files/upsert\", {\n        json: {\n          file_path: fileName,\n          text_content: fileContent,\n          initiator: \"filesystem_change\",\n        },\n      })\n    }\n  }\n\n  private async saveSnippet() {\n    const postEvent = async (\n      event: \"FAILED_TO_SAVE_SNIPPET\" | \"SNIPPET_SAVED\",\n    ) =>\n      this.fsKy.post(\"api/events/create\", {\n        json: { event_type: event },\n        throwHttpErrors: false,\n      })\n\n    await pushSnippet({\n      filePath: this.componentFilePath,\n      onExit: (e) => {\n        console.error(\"Failed to save snippet\", e)\n        postEvent(\"FAILED_TO_SAVE_SNIPPET\")\n      },\n      onError: (e) => {\n        console.error(\"Failed to save snippet\", e)\n        postEvent(\"FAILED_TO_SAVE_SNIPPET\")\n      },\n      onSuccess: () => {\n        postEvent(\"SNIPPET_SAVED\")\n      },\n    })\n  }\n\n  async stop() {\n    this.httpServer?.close()\n    this.eventsWatcher?.stop()\n  }\n}\n", "import * as http from \"node:http\"\nimport * as fs from \"node:fs\"\nimport * as path from \"node:path\"\nimport { getNodeHandler } from \"winterspec/adapters/node\"\nimport pkg from \"../../package.json\"\n\n// @ts-ignore\nimport winterspecBundle from \"@tscircuit/file-server/dist/bundle.js\"\nimport { getIndex } from \"../site/getIndex\"\n\nexport const createHttpServer = async (port = 3020) => {\n  const fileServerHandler = getNodeHandler(winterspecBundle as any, {})\n\n  const server = http.createServer(async (req, res) => {\n    const url = new URL(req.url!, `http://${req.headers.host}`)\n\n    if (url.pathname === \"/standalone.min.js\") {\n      const standaloneFilePath =\n        process.env.RUNFRAME_STANDALONE_FILE_PATH ||\n        path.resolve(\n          process.cwd(),\n          \"node_modules\",\n          \"@tscircuit/runframe/dist/standalone.min.js\",\n        )\n\n      try {\n        const content = fs.readFileSync(standaloneFilePath, \"utf8\")\n        res.writeHead(200, {\n          \"Content-Type\": \"application/javascript; charset=utf-8\",\n        })\n        res.end(content)\n        return\n      } catch (error) {\n        console.error(\"Error serving standalone.min.js:\", error)\n      }\n\n      res.writeHead(302, {\n        Location: `https://cdn.jsdelivr.net/npm/@tscircuit/runframe@${pkg.dependencies[\"@tscircuit/runframe\"].replace(/^[^0-9]+/, \"\")}/dist/standalone.min.js`,\n      })\n      res.end()\n      return\n    }\n\n    if (url.pathname === \"/\") {\n      const html = await getIndex()\n      res.writeHead(200, { \"Content-Type\": \"text/html\" })\n      res.end(html)\n      return\n    }\n\n    if (url.pathname.startsWith(\"/api/\")) {\n      req.url = req.url!.replace(\"/api/\", \"/\")\n      fileServerHandler(req, res)\n      return\n    }\n\n    res.writeHead(404)\n    res.end(\"Not found\")\n  })\n\n  return new Promise<{ server: http.Server }>((resolve) => {\n    server.listen(port, () => {\n      console.log(`Server running at http://localhost:${port}`)\n      resolve({ server })\n    })\n  })\n}\n", "{\n  \"name\": \"@tscircuit/cli\",\n  \"main\": \"dist/main.js\",\n  \"type\": \"module\",\n  \"version\": \"0.1.30\",\n  \"bin\": {\n    \"tsci\": \"./dist/main.js\"\n  },\n  \"scripts\": {\n    \"start\": \"bun run dev\",\n    \"dev\": \"bun --hot ./cli/main.ts dev ./example-dir/snippet1-basic.tsx\",\n    \"build\": \"tsup-node cli/main.ts --format esm --sourcemap inline\",\n    \"format\": \"biome format --write .\",\n    \"format:check\": \"biome format .\",\n    \"cli\": \"bun ./cli/main.ts\"\n  },\n  \"devDependencies\": {\n    \"@biomejs/biome\": \"^1.9.4\",\n    \"@tscircuit/core\": \"^0.0.249\",\n    \"@tscircuit/fake-snippets\": \"^0.0.5\",\n    \"@types/bun\": \"^1.1.15\",\n    \"@types/configstore\": \"^6.0.2\",\n    \"@types/react\": \"^19.0.8\",\n    \"@types/semver\": \"^7.5.8\",\n    \"get-port\": \"^7.1.0\",\n    \"tempy\": \"^3.1.0\",\n    \"tsup\": \"^8.3.5\",\n    \"typed-ky\": \"^0.0.4\"\n  },\n  \"peerDependencies\": {\n    \"typescript\": \"^5.0.0\"\n  },\n  \"dependencies\": {\n    \"@tscircuit/eval\": \"^0.0.96\",\n    \"@tscircuit/file-server\": \"^0.0.13\",\n    \"@tscircuit/runframe\": \"^0.0.167\",\n    \"chokidar\": \"4.0.1\",\n    \"commander\": \"^12.1.0\",\n    \"configstore\": \"^7.0.0\",\n    \"cosmiconfig\": \"^9.0.0\",\n    \"delay\": \"^6.0.0\",\n    \"jwt-decode\": \"^4.0.0\",\n    \"ky\": \"^1.7.4\",\n    \"make-vfs\": \"^1.0.15\",\n    \"perfect-cli\": \"^1.0.20\",\n    \"redaxios\": \"^0.5.1\",\n    \"semver\": \"^7.6.3\"\n  }\n}\n", "import pkg from \"../../package.json\"\n\nexport const getIndex = async () => {\n  return `<html>\n    <head>\n    </head>\n    <body>\n      <script src=\"https://cdn.tailwindcss.com\"></script>\n      <div id=\"root\">loading...</div>\n      <script>\n      globalThis.process = { env: { NODE_ENV: \"production\" } }\n      </script>\n      <script src=\"/standalone.min.js\"></script>\n    </body>\n  </html>`\n}\n\n// <script src=\"https://cdn.jsdelivr.net/npm/@tscircuit/runframe@${pkg.dependencies[\"@tscircuit/runframe\"].replace(/^[^0-9]+/, \"\")}/dist/standalone.min.js\"></script>\n", "import { EventEmitter } from \"events\"\n\ninterface Event {\n  event_id: string\n  created_at: string\n  event_type: string\n  [key: string]: any\n}\n\ninterface EventsResponse {\n  event_list: Event[]\n}\n\nexport class EventsWatcher extends EventEmitter {\n  private lastPollTime: string\n  private pollInterval: number\n  private baseUrl: string\n  private polling = false\n  private timeoutId?: NodeJS.Timeout\n\n  constructor(baseUrl = \"http://localhost:3000\", pollInterval = 1000) {\n    super()\n    this.baseUrl = baseUrl\n    this.pollInterval = pollInterval\n    this.lastPollTime = new Date().toISOString()\n  }\n\n  async start() {\n    if (this.polling) return\n    this.polling = true\n    await this.poll()\n  }\n\n  stop() {\n    this.polling = false\n    if (this.timeoutId) {\n      clearTimeout(this.timeoutId)\n    }\n  }\n\n  private async poll() {\n    if (!this.polling) return\n\n    try {\n      const response = await fetch(\n        `${this.baseUrl}/api/events/list?since=${encodeURIComponent(this.lastPollTime)}`,\n      )\n\n      if (!response.ok) {\n        throw new Error(`HTTP error! status: ${response.status}`)\n      }\n\n      const data: EventsResponse = await response.json()\n\n      // Update last poll time to latest event or current time\n      const latestEvent = data.event_list[data.event_list.length - 1]\n      this.lastPollTime = latestEvent\n        ? latestEvent.created_at\n        : new Date().toISOString()\n\n      // Emit events in chronological order\n      data.event_list.forEach((event) => {\n        this.emit(event.event_type, event)\n        this.emit(\"*\", event)\n      })\n    } catch (error) {\n      this.emit(\"error\", error)\n    }\n    // Schedule next poll\n    this.timeoutId = globalThis.setTimeout(\n      () => this.poll(),\n      this.pollInterval,\n    ) as unknown as NodeJS.Timeout\n  }\n}\n", "import * as fs from \"node:fs\"\nimport * as path from \"node:path\"\nimport { findImportsInSnippet } from \"./findImportsInSnippet\"\nimport { installNodeModuleTypesForSnippet } from \"./installNodeModuleTypesForSnippet\"\n\nexport class FilesystemTypesHandler {\n  private projectRoot: string\n\n  constructor(initialDir: string) {\n    this.projectRoot = this.findProjectRoot(initialDir)\n  }\n\n  async handleInitialTypeDependencies(filePath: string) {\n    console.log(\"Checking initial type dependencies...\")\n    try {\n      if (!this.areTypesInstalled(filePath)) {\n        console.log(\"Installing missing initial types...\")\n        await installNodeModuleTypesForSnippet(filePath)\n      }\n    } catch (error) {\n      console.warn(\"Error handling initial type dependencies:\", error)\n    }\n  }\n\n  async handleFileTypeDependencies(filePath: string) {\n    try {\n      if (!this.areTypesInstalled(filePath)) {\n        console.log(\"Installing missing file types...\")\n        await installNodeModuleTypesForSnippet(filePath)\n      }\n    } catch (error) {\n      console.warn(\"Failed to verify types:\", error)\n    }\n  }\n\n  private areTypesInstalled(filePath: string): boolean {\n    const imports = findImportsInSnippet(filePath)\n    return imports.every((imp) => this.checkTypeExists(imp))\n  }\n\n  private checkTypeExists(importPath: string): boolean {\n    if (!importPath.startsWith(\"@tsci/\")) return true\n\n    const pathWithoutPrefix = importPath.replace(\"@tsci/\", \"\")\n    const [owner, name] = pathWithoutPrefix.split(\".\")\n\n    const typePath = path.join(\n      this.projectRoot,\n      \"node_modules\",\n      \"@tsci\",\n      `${owner}.${name}`,\n      \"index.d.ts\",\n    )\n\n    return fs.existsSync(typePath)\n  }\n\n  private findProjectRoot(startDir: string): string {\n    let root = path.resolve(startDir)\n    while (root !== path.parse(root).root) {\n      if (fs.existsSync(path.join(root, \"package.json\"))) {\n        return root\n      }\n      root = path.dirname(root)\n    }\n    return startDir\n  }\n}\n", "import * as fs from \"node:fs\"\nimport * as ts from \"typescript\"\n\nexport function findImportsInSnippet(snippetPath: string): string[] {\n  const content = fs.readFileSync(snippetPath, \"utf-8\")\n  const sourceFile = ts.createSourceFile(\n    snippetPath,\n    content,\n    ts.ScriptTarget.Latest,\n    true,\n  )\n\n  const imports: string[] = []\n\n  function visit(node: ts.Node) {\n    if (ts.isImportDeclaration(node)) {\n      const moduleSpecifier = node.moduleSpecifier\n      if (moduleSpecifier && ts.isStringLiteral(moduleSpecifier)) {\n        const importPath = moduleSpecifier.text\n        if (importPath.startsWith(\"@tsci/\")) {\n          imports.push(importPath)\n        }\n      }\n    }\n    ts.forEachChild(node, visit)\n  }\n\n  visit(sourceFile)\n\n  return imports\n}\n", "import Configstore from \"configstore\"\nimport type { TypedConfigstore } from \"./TypedConfigStore\"\nimport { jwtDecode } from \"jwt-decode\"\n\nexport interface CliConfig {\n  sessionToken?: string\n  githubUsername?: string\n  registryApiUrl?: string\n}\n\nexport const cliConfig: TypedConfigstore<CliConfig> = new Configstore(\n  \"tscircuit\",\n)\n\nexport const setSessionToken = (token: string) => {\n  cliConfig.set(\"sessionToken\", token)\n  const decoded = jwtDecode<{\n    github_username: string\n  }>(token)\n  cliConfig.set(\"githubUsername\", decoded.github_username)\n}\n\nexport const clearSession = () => {\n  cliConfig.delete(\"sessionToken\")\n  cliConfig.delete(\"githubUsername\")\n}\n\nexport const getRegistryApiUrl = (): string => {\n  return cliConfig.get(\"registryApiUrl\") ?? \"https://registry-api.tscircuit.com\"\n}\n", "import { getRegistryApiUrl } from \"lib/cli-config\"\nimport ky, { type AfterResponseHook } from \"ky\"\n\nexport const prettyResponseErrorHook: AfterResponseHook = async (\n  _request,\n  _options,\n  response,\n) => {\n  if (!response.ok) {\n    try {\n      const errorData = await response.json()\n      throw new Error(\n        `FAIL [${response.status}]: ${_request.method} ${\n          new URL(_request.url).pathname\n        } \\n\\n ${JSON.stringify(errorData, null, 2)}`,\n      )\n    } catch (e) {\n      //ignore, allow the error to be thrown\n    }\n  }\n}\n\nexport const getKy = () => {\n  return ky.create({\n    prefixUrl: getRegistryApiUrl(),\n    hooks: {\n      afterResponse: [prettyResponseErrorHook],\n    },\n  })\n}\n", "import { cliConfig } from \"lib/cli-config\"\nimport { getKy } from \"lib/registry-api/get-ky\"\nimport * as fs from \"node:fs\"\nimport * as path from \"node:path\"\nimport semver from \"semver\"\n\ntype PushOptions = {\n  filePath?: string\n  onExit?: (code: number) => void\n  onError?: (message: string) => void\n  onSuccess?: (message: string) => void\n}\n\nexport const pushSnippet = async ({\n  filePath,\n  onExit = (code) => process.exit(code),\n  onError = (message) => console.error(message),\n  onSuccess = (message) => console.log(message),\n}: PushOptions) => {\n  const sessionToken = cliConfig.get(\"sessionToken\")\n  if (!sessionToken) {\n    onError(\"You need to log in to save snippet.\")\n    return onExit(1)\n  }\n\n  let snippetFilePath: string | null = null\n  if (filePath) {\n    snippetFilePath = path.resolve(filePath)\n  } else {\n    const defaultEntrypoint = path.resolve(\"index.tsx\")\n    if (fs.existsSync(defaultEntrypoint)) {\n      snippetFilePath = defaultEntrypoint\n      onSuccess(\"No file provided. Using 'index.tsx' as the entrypoint.\")\n    } else {\n      onError(\n        \"No entrypoint found. Run 'tsci init' to bootstrap a basic project.\",\n      )\n      return onExit(1)\n    }\n  }\n\n  const packageJsonPath = path.resolve(\n    path.join(path.dirname(snippetFilePath), \"package.json\"),\n  )\n  let packageJson: { name?: string; author?: string; version?: string } = {}\n  if (fs.existsSync(packageJsonPath)) {\n    try {\n      packageJson = JSON.parse(fs.readFileSync(packageJsonPath).toString())\n    } catch {\n      onError(\"Invalid package.json provided\")\n      return onExit(1)\n    }\n  }\n\n  if (!fs.existsSync(snippetFilePath)) {\n    onError(`File not found: ${snippetFilePath}`)\n    return onExit(1)\n  }\n\n  const ky = getKy()\n  const packageName = (\n    packageJson.name ?? path.parse(snippetFilePath).name\n  ).replace(/^@/, \"\")\n  const packageAuthor =\n    packageJson.author?.split(\" \")[0] ?? cliConfig.get(\"githubUsername\")\n  const packageIdentifier = `${packageAuthor}/${packageName}`\n\n  let packageVersion =\n    packageJson.version ??\n    (await ky\n      .post<{\n        error?: { error_code: string }\n        package_releases?: { version: string; is_latest: boolean }[]\n      }>(\"package_releases/list\", {\n        json: { package_name: packageIdentifier },\n      })\n      .json()\n      .then(\n        (response) =>\n          response.package_releases?.[response.package_releases.length - 1]\n            ?.version,\n      )\n      .catch((error) => {\n        onError(\"Failed to retrieve latest package version:\" + error)\n        return onExit(1)\n      }))\n\n  if (!packageVersion) {\n    onError(\"Failed to retrieve package version.\")\n    return onExit(1)\n  }\n\n  const updatePackageJsonVersion = (newVersion?: string) => {\n    if (packageJson.version) {\n      try {\n        packageJson.version = newVersion ?? `${packageVersion}`\n        fs.writeFileSync(packageJsonPath, JSON.stringify(packageJson, null, 2))\n      } catch (error) {\n        onError(\"Failed to update package.json version:\" + error)\n      }\n    }\n  }\n\n  const doesPackageExist = await ky\n    .post<{ error?: { error_code: string } }>(\"packages/get\", {\n      json: { name: packageIdentifier },\n      throwHttpErrors: false,\n    })\n    .json()\n    .then((response) => !(response.error?.error_code === \"package_not_found\"))\n\n  if (!doesPackageExist) {\n    await ky\n      .post(\"packages/create\", {\n        json: { name: packageIdentifier },\n        headers: { Authorization: `Bearer ${sessionToken}` },\n      })\n      .catch((error) => {\n        onError(\"Error creating package:\" + error)\n        return onExit(1)\n      })\n  }\n\n  const doesReleaseExist = await ky\n    .post<{\n      error?: { error_code: string }\n      package_release?: { version: string }\n    }>(\"package_releases/get\", {\n      json: {\n        package_name_with_version: `${packageIdentifier}@${packageVersion}`,\n      },\n      throwHttpErrors: false,\n    })\n    .json()\n    .then((response) => {\n      if (response.package_release?.version) {\n        packageVersion = response.package_release.version\n        updatePackageJsonVersion(response.package_release.version)\n        return true\n      }\n      return !(response.error?.error_code === \"package_release_not_found\")\n    })\n\n  if (doesReleaseExist) {\n    const bumpedVersion = semver.inc(packageVersion, \"patch\")!\n    onSuccess(\n      `Incrementing Package Version ${packageVersion} -> ${bumpedVersion}`,\n    )\n    packageVersion = bumpedVersion\n    updatePackageJsonVersion(packageVersion)\n  }\n\n  await ky\n    .post(\"package_releases/create\", {\n      json: {\n        package_name_with_version: `${packageIdentifier}@${packageVersion}`,\n      },\n      throwHttpErrors: false,\n    })\n    .catch((error) => {\n      onError(\"Error creating release:\" + error)\n      return onExit(1)\n    })\n\n  onSuccess(\"\\n\")\n\n  const directoryFiles = fs.readdirSync(path.dirname(snippetFilePath))\n  for (const file of directoryFiles) {\n    const fileExtension = path.extname(file).replace(\".\", \"\")\n    if (![\"json\", \"tsx\", \"ts\"].includes(fileExtension)) continue\n    const fileContent =\n      fs\n        .readFileSync(path.join(path.dirname(snippetFilePath), file))\n        .toString() ?? \"\"\n    await ky\n      .post(\"package_files/create\", {\n        json: {\n          file_path: file,\n          content_text: fileContent,\n          package_name_with_version: `${packageIdentifier}@${packageVersion}`,\n        },\n        throwHttpErrors: false,\n      })\n      .then(() => {\n        onSuccess(`Uploaded file ${file} to the registry.`)\n      })\n      .catch((error) => {\n        onError(`Error uploading file ${file}:` + error)\n      })\n  }\n\n  onSuccess(\n    [\n      `\\n\uD83C\uDF89 Successfully pushed package ${packageIdentifier}@${packageVersion} to the registry!${Bun.color(\"blue\", \"ansi\")}`,\n      `https://tscircuit.com/${packageIdentifier} \\x1b[0m`,\n    ].join(\" \"),\n  )\n}\n", "import type { Command } from \"commander\"\nimport { setSessionToken } from \"lib/cli-config\"\nimport delay from \"delay\"\nimport { getKy } from \"lib/registry-api/get-ky\"\nimport type { EndpointResponse } from \"lib/registry-api/endpoint-types\"\n\nexport const registerAuthLogin = (program: Command) => {\n  // Define the login action once to share between both commands\n  const loginAction = async () => {\n    const ky = getKy()\n\n    const { login_page } = await ky\n      .post<EndpointResponse[\"sessions/login_page/create\"]>(\n        \"sessions/login_page/create\",\n        {\n          json: {},\n        },\n      )\n      .json()\n\n    console.log(\"Please visit the following URL to log in:\")\n    console.log(login_page.url)\n\n    // Wait until we receive confirmation\n    while (true) {\n      const { login_page: new_login_page } = await ky\n        .post<EndpointResponse[\"sessions/login_page/get\"]>(\n          \"sessions/login_page/get\",\n          {\n            json: {\n              login_page_id: login_page.login_page_id,\n            },\n            headers: {\n              Authorization: `Bearer ${login_page.login_page_auth_token}`,\n            },\n          },\n        )\n        .json()\n\n      if (new_login_page.was_login_successful) {\n        console.log(\"Logged in! Generating token...\")\n        break\n      }\n\n      if (new_login_page.is_expired) {\n        throw new Error(\"Login page expired\")\n      }\n\n      await delay(1000)\n    }\n\n    const { session } = await ky\n      .post<EndpointResponse[\"sessions/login_page/exchange_for_cli_session\"]>(\n        \"sessions/login_page/exchange_for_cli_session\",\n        {\n          json: {\n            login_page_id: login_page.login_page_id,\n          },\n          headers: {\n            Authorization: `Bearer ${login_page.login_page_auth_token}`,\n          },\n        },\n      )\n      .json()\n\n    setSessionToken(session.token)\n    console.log(\"\\nReady to use!\")\n  }\n\n  // Register the auth login subcommand\n  program.commands\n    .find((c) => c.name() === \"auth\")!\n    .command(\"login\")\n    .description(\"Authenticate CLI, login to registry\")\n    .action(loginAction)\n\n  // Register the top-level login command as an alias\n  program\n    .command(\"login\")\n    .description(\"Login to tscircuit registry\")\n    .action(loginAction)\n}\n", "import type { Command } from \"commander\"\nimport { clearSession } from \"lib/cli-config\"\n\nexport const registerAuthLogout = (program: Command) => {\n  const logoutAction = () => {\n    clearSession()\n    console.log(\"You have been logged out!\")\n  }\n\n  // Register the auth logout subcommand\n  program.commands\n    .find((c) => c.name() === \"auth\")!\n    .command(\"logout\")\n    .description(\"Logout from registry\")\n    .action(logoutAction)\n\n  // Register the top-level logout command as an alias\n  program\n    .command(\"logout\")\n    .description(\"Logout from tscircuit registry\")\n    .action(logoutAction)\n}\n", "import type { Command } from \"commander\"\n\nexport const registerAuth = (program: Command) => {\n  program.command(\"auth\").description(\"Login/logout\")\n}\n", "import type { Command } from \"commander\"\n\nexport const registerConfig = (program: Command) => {\n  program.command(\"config\").description(\"Manage tscircuit CLI configuration\")\n}\n", "import type { Command } from \"commander\"\nimport { cliConfig } from \"lib/cli-config\"\n\nexport const registerConfigPrint = (program: Command) => {\n  program.commands\n    .find((c) => c.name() === \"config\")!\n    .command(\"print\")\n    .description(\"Print the current config\")\n    .action(() => {\n      console.log(JSON.stringify(cliConfig.all, null, 2))\n    })\n}\n", "import type { Command } from \"commander\"\nimport { getKy } from \"lib/registry-api/get-ky\"\nimport * as fs from \"node:fs\"\nimport * as path from \"node:path\"\nimport { setupTsciProject } from \"lib/shared/setup-tsci-packages\"\nimport { generateTsConfig } from \"lib/shared/generate-ts-config\"\n\nexport const registerClone = (program: Command) => {\n  program\n    .command(\"clone\")\n    .description(\"Clone a snippet from the registry\")\n    .argument(\"<snippet>\", \"Snippet to clone (e.g. author/snippetName)\")\n    .action(async (snippetPath: string) => {\n      const match = snippetPath.match(/^(?:@tsci\\/)?([^/.]+)[/.](.+)$/)\n      if (!match) {\n        console.error(\n          \"Invalid snippet path. Use format: author/snippetName, author.snippetName, or @tsci/author.snippetName\",\n        )\n        process.exit(1)\n      }\n\n      const [, author, snippetName] = match\n      console.log(`Cloning ${author}/${snippetName}...`)\n\n      const ky = getKy()\n      let packageFileList\n      try {\n        packageFileList = await ky\n          .post<{ package_files: Array<{ file_path: string }> }>(\n            \"package_files/list\",\n            {\n              json: {\n                package_name: `${author}/${snippetName}`,\n                use_latest_version: true,\n              },\n            },\n          )\n          .json()\n      } catch (error) {\n        console.error(\n          \"Failed to fetch package files:\",\n          error instanceof Error ? error.message : error,\n        )\n        process.exit(1)\n      }\n\n      const dirPath = path.resolve(`${author}.${snippetName}`)\n      fs.mkdirSync(dirPath, { recursive: true })\n\n      for (const fileInfo of packageFileList.package_files) {\n        const filePath = fileInfo.file_path.replace(/^\\/|dist\\//g, \"\")\n        if (!filePath) continue\n\n        const fullPath = path.join(dirPath, filePath)\n        fs.mkdirSync(path.dirname(fullPath), { recursive: true })\n\n        try {\n          const fileContent = await ky\n            .post<{ package_file: { content_text: string } }>(\n              \"package_files/get\",\n              {\n                json: {\n                  package_name: `${author}/${snippetName}`,\n                  file_path: fileInfo.file_path,\n                },\n              },\n            )\n            .json()\n\n          let fileText = fileContent.package_file.content_text\n\n          // Ensure all .tsx files contain \"import '@tscircuit/core';\"\n          if (\n            filePath.endsWith(\".tsx\") &&\n            !fileText.includes(\"@tscircuit/core\")\n          ) {\n            fileText = `import \"@tscircuit/core\";\\n\\n${fileText}`\n          }\n\n          fs.writeFileSync(fullPath, fileText)\n        } catch (error) {\n          console.warn(\n            `Skipping ${filePath} due to error:`,\n            error instanceof Error ? error.message : error,\n          )\n        }\n      }\n\n      fs.writeFileSync(\n        path.join(dirPath, \".npmrc\"),\n        \"@tsci:registry=https://npm.tscircuit.com\",\n      )\n\n      generateTsConfig(dirPath)\n      setupTsciProject(dirPath)\n\n      console.log(`Successfully cloned to ${dirPath}/`)\n      console.log(\n        `Run \"cd ${path.dirname(dirPath)} && tsci dev\" to start developing.`,\n      )\n    })\n}\n", "import type { Command } from \"commander\"\nimport { createCircuitWebWorker } from \"@tscircuit/eval\"\nimport webWorkerBundleUrl from \"@tscircuit/eval/blob-url\"\nimport { getVirtualFileSystemFromDirPath } from \"make-vfs\"\nimport path from \"node:path\"\nimport fs from \"node:fs\"\n\nconst ALLOWED_FORMATS = [\n  \"json\",\n  \"circuit-json\",\n  \"schematic-svg\",\n  \"pcb-svg\",\n  \"gerbers\",\n  \"readable-netlist\",\n  \"gltf\",\n  \"specctra-dsn\",\n] as const\n\ntype Format = (typeof ALLOWED_FORMATS)[number]\n\nconst OUTPUT_EXTENSIONS = {\n  json: \".circuit.json\",\n  \"circuit-json\": \".circuit.json\",\n  \"schematic-svg\": \"-schematic.svg\",\n  \"pcb-svg\": \"-pcb.svg\",\n  gerbers: \"-gerbers.zip\",\n  \"readable-netlist\": \"-readable.netlist\",\n  gltf: \".gltf\",\n  \"specctra-dsn\": \".dsn\",\n}\n\nexport const registerExport = (program: Command) => {\n  program\n    .command(\"export\")\n    .description(\"Export tscircuit code to various formats\")\n    .argument(\"<file>\", \"Path to the snippet file\")\n    .option(\"-f, --format <format>\", \"Output format\")\n    .option(\"-o, --output <path>\", \"Output file path\")\n    .action(async (file, options) => {\n      const { format = \"circuit-json\" } = options\n      let { output } = options\n      if (!ALLOWED_FORMATS.includes(format)) {\n        throw new Error(\n          `Invalid format: ${format}\\nSupported formats: ${ALLOWED_FORMATS.join(\",\")}`,\n        )\n      }\n\n      if (!output) {\n        output = path.basename(file).replace(/\\.[^.]+$/, \"\")\n      }\n\n      const worker = await createCircuitWebWorker({\n        webWorkerUrl: webWorkerBundleUrl,\n      })\n\n      const projectDir = path.dirname(file)\n\n      const relativeComponentPath = path.relative(projectDir, file)\n\n      await worker.executeWithFsMap({\n        entrypoint: \"entrypoint.tsx\",\n        fsMap: {\n          ...((await getVirtualFileSystemFromDirPath({\n            dirPath: projectDir,\n            contentFormat: \"string\",\n          })) as Record<string, string>),\n          \"entrypoint.tsx\": `\nimport MyCircuit from \"./${relativeComponentPath}\"\n\ncircuit.add(<MyCircuit />)\n        `,\n        },\n      })\n\n      await worker.renderUntilSettled()\n\n      const circuitJson = await worker.getCircuitJson()\n\n      const outputPath = path.join(\n        projectDir,\n        `${output}${OUTPUT_EXTENSIONS[format as Format]}`,\n      )\n\n      fs.writeFileSync(outputPath, JSON.stringify(circuitJson))\n\n      console.log(`Exported to ${outputPath}`)\n\n      process.exit(0)\n    })\n}\n", "import type { Command } from \"commander\"\nimport { cliConfig } from \"lib/cli-config\"\n\nexport const registerAuthPrintToken = (program: Command) => {\n  program.commands\n    .find((c) => c.name() === \"auth\")!\n    .command(\"print-token\")\n    .description(\"Prints your auth token\")\n    .action(() => {\n      const token = cliConfig.get(\"sessionToken\")\n      if (!token) return console.log(\"You need to log in to access this.\")\n      console.log(\"Your Token:\\n\", token)\n    })\n}\n", "import type { Command } from \"commander\"\nimport { setSessionToken } from \"lib/cli-config\"\n\nfunction validateJWTLength(token: string) {\n  const parts = token.split(\".\")\n\n  if (parts.length === 3 && parts.every((part) => part.length > 0)) {\n    return true\n  } else {\n    return false\n  }\n}\nexport const registerAuthSetToken = (program: Command) => {\n  program.commands\n    .find((c) => c.name() === \"auth\")!\n    .command(\"set-token\")\n    .description(\"Explicitly set your auth token\")\n    .argument(\"<token>\", \"New token to manually configure\")\n    .action((token) => {\n      if (!validateJWTLength(token))\n        return console.log(\"Invalid token provided\")\n      setSessionToken(token)\n      console.log(\"Token manually updated.\")\n    })\n}\n", "import { pushSnippet } from \"lib/shared/push-snippet\"\nimport type { Command } from \"commander\"\n\nexport const registerPush = (program: Command) => {\n  program\n    .command(\"push\")\n    .description(\"Save snippet code to Registry API\")\n    .argument(\"[file]\", \"Path to the snippet file\")\n    .action(async (filePath?: string) => {\n      await pushSnippet({\n        filePath,\n        onExit: (code) => process.exit(code),\n        onError: (message) => console.error(message),\n        onSuccess: (message) => console.log(message),\n      })\n    })\n}\n"],
  "mappings": "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",
  "names": ["fs", "path", "fs", "path", "fs", "fs", "program", "path", "fs", "fs", "path", "ky", "fs", "path", "resolve", "path", "fs", "fs", "path", "fs", "ts", "fs", "path", "ky", "path", "ky", "fs", "program", "port", "resolve", "server", "program", "ky", "program", "program", "program", "program", "fs", "path", "program", "ky", "semver", "path", "fs", "program", "program", "program", "program", "semver"]
}

|
|
1215
|
+
//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["../cli/main.ts", "../cli/init/register.ts", "../lib/shared/detect-pkg-manager.ts", "../lib/shared/setup-tsci-packages.ts", "../lib/shared/generate-ts-config.ts", "../lib/shared/write-file-if-not-exists.ts", "../lib/shared/generate-gitignore-file.ts", "../cli/dev/register.ts", "../lib/dependency-analysis/installNodeModuleTypesForSnippet.ts", "../cli/dev/DevServer.ts", "../lib/server/createHttpServer.ts", "../package.json", "../lib/site/getIndex.ts", "../lib/server/EventsWatcher.ts", "../lib/dependency-analysis/FilesystemTypesHandler.ts", "../lib/dependency-analysis/findImportsInSnippet.ts", "../lib/cli-config/index.ts", "../lib/registry-api/get-ky.ts", "../lib/shared/push-snippet.ts", "../cli/auth/login/register.ts", "../cli/auth/logout/register.ts", "../cli/auth/register.ts", "../cli/config/register.ts", "../cli/config/print/register.ts", "../cli/clone/register.ts", "../cli/export/register.ts", "../cli/auth/print-token/register.ts", "../cli/auth/set-token/register.ts", "../cli/push/register.ts"],
  "sourcesContent": ["#!/usr/bin/env node\nimport { Command } from \"commander\"\nimport { registerInit } from \"./init/register\"\nimport { registerDev } from \"./dev/register\"\nimport { registerAuthLogin } from \"./auth/login/register\"\nimport { registerAuthLogout } from \"./auth/logout/register\"\nimport { registerAuth } from \"./auth/register\"\nimport { registerConfig } from \"./config/register\"\nimport { registerConfigPrint } from \"./config/print/register\"\nimport { registerClone } from \"./clone/register\"\nimport { perfectCli } from \"perfect-cli\"\nimport pkg from \"../package.json\"\nimport semver from \"semver\"\nimport { registerExport } from \"./export/register\"\nimport { registerAuthPrintToken } from \"./auth/print-token/register\"\nimport { registerAuthSetToken } from \"./auth/set-token/register\"\nimport { registerPush } from \"./push/register\"\n\nexport const program = new Command()\n\nprogram\n  .name(\"tsci\")\n  .description(\"CLI for developing tscircuit snippets\")\n  // HACK: at build time the version is old, we need to\n  // fix this at some point...\n  .version(semver.inc(pkg.version, \"patch\") ?? pkg.version)\n\nregisterInit(program)\n\nregisterDev(program)\nregisterClone(program)\nregisterPush(program)\n\nregisterAuth(program)\nregisterAuthLogin(program)\nregisterAuthLogout(program)\nregisterAuthPrintToken(program)\nregisterAuthSetToken(program)\n\nregisterConfig(program)\nregisterConfigPrint(program)\n\nregisterExport(program)\n\nif (process.argv.length === 2) {\n  perfectCli(program, process.argv)\n} else {\n  program.parse()\n}\n", "import type { Command } from \"commander\"\nimport * as fs from \"node:fs\"\nimport * as path from \"node:path\"\nimport { setupTsciProject } from \"lib/shared/setup-tsci-packages\"\nimport { generateTsConfig } from \"lib/shared/generate-ts-config\"\nimport { writeFileIfNotExists } from \"lib/shared/write-file-if-not-exists\"\nimport { generateGitIgnoreFile } from \"lib/shared/generate-gitignore-file\"\n\nexport const registerInit = (program: Command) => {\n  program\n    .command(\"init\")\n    .description(\n      \"Initialize a new TSCircuit project in the specified directory (or current directory if none is provided)\",\n    )\n    .argument(\n      \"[directory]\",\n      \"Directory name (optional, defaults to current directory)\",\n    )\n    .action((directory?: string) => {\n      const projectDir = directory\n        ? path.resolve(process.cwd(), directory)\n        : process.cwd()\n\n      // Ensure the directory exists\n      fs.mkdirSync(projectDir, { recursive: true })\n\n      // Create essential project files\n      writeFileIfNotExists(\n        path.join(projectDir, \"index.tsx\"),\n        `\nimport \"@tscircuit/core\";\n\nexport default () => (\n  <board width=\"10mm\" height=\"10mm\">\n    <resistor resistance=\"1k\" footprint=\"0402\" name=\"R1\" schX={3} pcbX={3} />\n    <capacitor capacitance=\"1000pF\" footprint=\"0402\" name=\"C1\" schX={-3} pcbX={-3} />\n    <trace from=\".R1 > .pin1\" to=\".C1 > .pin1\" />\n  </board>\n);\n`,\n      )\n\n      writeFileIfNotExists(\n        path.join(projectDir, \".npmrc\"),\n        `\n@tsci:registry=https://npm.tscircuit.com\n`,\n      )\n\n      // Setup project dependencies\n      try {\n        setupTsciProject(projectDir)\n      } catch (error) {\n        console.error(\"Failed to install dependencies:\", error)\n        process.exit(1)\n      }\n\n      // Generate tsconfig.json\n      generateTsConfig(projectDir)\n      // Create .gitignore file\n      generateGitIgnoreFile(projectDir)\n\n      console.info(\n        `\uD83C\uDF89 Initialization complete! Run ${directory ? `\"cd ${directory}\" & ` : \"\"}\"tsci dev\" to start developing.`,\n      )\n      process.exit(0)\n    })\n}\n", "import fs from \"fs\"\n\n// Detect the package manager being used in the project\nexport const detectPackageManager = (): string => {\n  const userAgent = process.env.npm_config_user_agent || \"\"\n  if (userAgent.startsWith(\"yarn\")) return \"yarn\"\n  if (userAgent.startsWith(\"pnpm\")) return \"pnpm\"\n  if (userAgent.startsWith(\"bun\")) return \"bun\"\n\n  if (fs.existsSync(\"yarn.lock\")) return \"yarn\"\n  if (fs.existsSync(\"pnpm-lock.yaml\")) return \"pnpm\"\n  if (fs.existsSync(\"bun.lockb\")) return \"bun\"\n\n  return \"npm\" // Default to npm\n}\n", "import { detectPackageManager } from \"./detect-pkg-manager\"\nimport fs from \"node:fs\"\nimport path from \"node:path\"\nimport { execSync } from \"node:child_process\"\n\nexport function setupTsciProject(\n  directory = process.cwd(),\n  dependencies = [\"@types/react\", \"@tscircuit/core\"],\n) {\n  const projectPath = path.resolve(directory)\n  if (!fs.existsSync(projectPath)) {\n    fs.mkdirSync(projectPath, { recursive: true })\n  }\n  const packageManager = detectPackageManager()\n\n  console.log(`Initializing project in ${projectPath}...`)\n  process.chdir(projectPath)\n\n  if (!fs.existsSync(\"package.json\")) {\n    const initCommand =\n      packageManager === \"yarn\"\n        ? \"yarn init -y\"\n        : packageManager === \"pnpm\"\n          ? \"pnpm init\"\n          : packageManager === \"bun\"\n            ? \"bun init -y\"\n            : \"npm init -y\"\n\n    execSync(initCommand, { stdio: \"inherit\" })\n    console.log(\"Project initialized successfully.\")\n  }\n\n  // Read and modify package.json\n  const packageJsonPath = path.join(projectPath, \"package.json\")\n  const packageJson = JSON.parse(fs.readFileSync(packageJsonPath, \"utf-8\"))\n\n  // Remove unwanted fields\n  delete packageJson.keywords\n  delete packageJson.author\n  delete packageJson.main\n\n  fs.writeFileSync(packageJsonPath, JSON.stringify(packageJson, null, 2))\n  console.log(\"Updated package.json to remove unnecessary fields.\")\n\n  if (dependencies.length > 0) {\n    console.log(\"Installing dependencies...\")\n    const installCommand =\n      packageManager === \"yarn\"\n        ? `yarn add -D ${dependencies.join(\" \")}`\n        : packageManager === \"pnpm\"\n          ? `pnpm add -D ${dependencies.join(\" \")}`\n          : packageManager === \"bun\"\n            ? `bun add -D ${dependencies.join(\" \")}`\n            : `npm install -D ${dependencies.join(\" \")}`\n\n    execSync(installCommand, { stdio: \"inherit\" })\n    console.log(\"Dependencies installed successfully.\")\n  }\n\n  return packageJson.name || \"unknown\"\n}\n", "import path from \"node:path\"\nimport { writeFileIfNotExists } from \"./write-file-if-not-exists\"\n\n// Generate a React-compatible tsconfig.json\nexport const generateTsConfig = (dir: string) => {\n  const tsconfigPath = path.join(dir, \"tsconfig.json\")\n  const tsconfigContent = JSON.stringify(\n    {\n      compilerOptions: {\n        target: \"ES6\",\n        module: \"ESNext\",\n        jsx: \"react-jsx\",\n        outDir: \"dist\",\n        strict: true,\n        esModuleInterop: true,\n        moduleResolution: \"node\",\n        skipLibCheck: true,\n        forceConsistentCasingInFileNames: true,\n        resolveJsonModule: true,\n        sourceMap: true,\n        allowSyntheticDefaultImports: true,\n        experimentalDecorators: true,\n      },\n    },\n    null,\n    2,\n  )\n  writeFileIfNotExists(tsconfigPath, tsconfigContent)\n}\n", "import fs from \"fs\"\n\nexport const writeFileIfNotExists = (filePath: string, content: string) => {\n  if (!fs.existsSync(filePath)) {\n    fs.writeFileSync(filePath, content.trimStart(), \"utf-8\")\n    console.info(`Created: ${filePath}`)\n  } else {\n    console.info(`Skipped: ${filePath} already exists`)\n  }\n}\n", "import { writeFileIfNotExists } from \"./write-file-if-not-exists\"\nimport path from \"node:path\"\n\nexport const generateGitIgnoreFile = (dir: string) => {\n  const gitignorePath = path.join(dir, \".gitignore\")\n  const gitignoreContent = `# Dependencies\nnode_modules/\n\n# Build output\ndist/\nbuild/\n\n# Environment variables\n.env\n.env.local\n.env.*.local\n\n# IDE files\n.vscode/\n.idea/\n*.swp\n*.swo\n\n# OS files\n.DS_Store\nThumbs.db\n\n# Debug logs\nnpm-debug.log*\nyarn-debug.log*\nyarn-error.log*\n`\n\n  writeFileIfNotExists(gitignorePath, gitignoreContent)\n}\n", "import type { Command } from \"commander\"\nimport * as path from \"node:path\"\nimport * as chokidar from \"chokidar\"\nimport * as fs from \"node:fs\"\nimport { createHttpServer } from \"lib/server/createHttpServer\"\nimport { getLocalFileDependencies } from \"lib/dependency-analysis/getLocalFileDependencies\"\nimport { installNodeModuleTypesForSnippet } from \"../../lib/dependency-analysis/installNodeModuleTypesForSnippet\"\nimport { EventsWatcher } from \"../../lib/server/EventsWatcher\"\nimport { DevServer } from \"./DevServer\"\nimport * as net from \"node:net\"\n\nexport const registerDev = (program: Command) => {\n  program\n    .command(\"dev\")\n    .description(\"Start development server for a snippet\")\n    .argument(\"[file]\", \"Path to the snippet file\")\n    .option(\"-p, --port <number>\", \"Port to run server on\", \"3020\")\n    .action(async (file: string, options: { port: string }) => {\n      let port = parseInt(options.port)\n\n      const isPortAvailable = (port: number): Promise<boolean> => {\n        return new Promise((resolve) => {\n          const server = net.createServer()\n          server.once(\"error\", () => resolve(false))\n          server.once(\"listening\", () => {\n            server.close(() => resolve(true))\n          })\n          server.listen(port)\n        })\n      }\n\n      while (!(await isPortAvailable(port))) {\n        console.log(`Port ${port} is in use, trying port ${port + 1}...`)\n        port += 1\n      }\n\n      let absolutePath: string\n\n      if (file) {\n        absolutePath = path.resolve(file)\n        if (!absolutePath.endsWith(\".tsx\")) {\n          console.error(\"Error: Only .tsx files are supported\")\n          return\n        }\n      } else {\n        const entrypointPath = path.resolve(\"index.tsx\")\n        if (fs.existsSync(entrypointPath)) {\n          absolutePath = entrypointPath\n          console.log(\"No file provided. Using 'index.tsx' as the entrypoint.\")\n        } else {\n          console.log(\n            \"No entrypoint found. Run 'tsci init' to bootstrap a basic project.\",\n          )\n          return\n        }\n      }\n\n      const fileDir = path.dirname(absolutePath)\n\n      try {\n        console.log(\"Installing types for imported snippets...\")\n        await installNodeModuleTypesForSnippet(absolutePath)\n        console.log(\"Types installed successfully\")\n      } catch (error) {\n        console.warn(\"Failed to install types:\", error)\n      }\n\n      const server = new DevServer({\n        port,\n        componentFilePath: absolutePath,\n      })\n\n      await server.start()\n      await server.addEntrypoint()\n    })\n}\n", "import * as fs from \"node:fs\"\nimport * as path from \"node:path\"\nimport * as ts from \"typescript\"\n\ninterface SnippetApiResponse {\n  snippet: {\n    dts: string\n  }\n}\n\nexport async function installNodeModuleTypesForSnippet(snippetPath: string) {\n  const content = fs.readFileSync(snippetPath, \"utf-8\")\n  const sourceFile = ts.createSourceFile(\n    snippetPath,\n    content,\n    ts.ScriptTarget.Latest,\n    true,\n  )\n\n  const imports: string[] = []\n\n  function visit(node: ts.Node) {\n    if (ts.isImportDeclaration(node)) {\n      const moduleSpecifier = node.moduleSpecifier\n      if (moduleSpecifier && ts.isStringLiteral(moduleSpecifier)) {\n        const importPath = moduleSpecifier.text\n        if (importPath.startsWith(\"@tsci/\")) {\n          imports.push(importPath)\n        }\n      }\n    }\n    ts.forEachChild(node, visit)\n  }\n\n  visit(sourceFile)\n\n  let projectRoot = path.dirname(snippetPath)\n  while (projectRoot !== path.parse(projectRoot).root) {\n    if (fs.existsSync(path.join(projectRoot, \"package.json\"))) {\n      break\n    }\n    projectRoot = path.dirname(projectRoot)\n  }\n\n  for (const importPath of imports) {\n    const [owner, name] = importPath.replace(\"@tsci/\", \"\").split(\".\")\n    try {\n      const response = await fetch(\n        `https://registry-api.tscircuit.com/snippets/get?owner_name=${owner}&unscoped_name=${name}`,\n      )\n\n      if (!response.ok) {\n        console.warn(`Failed to fetch types for ${importPath}`)\n        continue\n      }\n\n      const data: SnippetApiResponse = await response.json()\n\n      if (data.snippet.dts) {\n        const packageDir = path.join(\n          projectRoot,\n          \"node_modules\",\n          \"@tsci\",\n          `${owner}.${name}`,\n        )\n        fs.mkdirSync(packageDir, { recursive: true })\n\n        fs.writeFileSync(path.join(packageDir, \"index.d.ts\"), data.snippet.dts)\n      }\n    } catch (error) {\n      console.warn(`Error fetching types for ${importPath}:`, error)\n    }\n  }\n}\n", "import ky from \"ky\"\nimport type { FileServerRoutes } from \"lib/file-server/FileServerRoutes\"\nimport { createHttpServer } from \"lib/server/createHttpServer\"\nimport { EventsWatcher } from \"lib/server/EventsWatcher\"\nimport type http from \"node:http\"\nimport type { TypedKyInstance } from \"typed-ky\"\nimport path from \"node:path\"\nimport fs from \"node:fs\"\nimport type { FileUpdatedEvent } from \"lib/file-server/FileServerEvent\"\nimport * as chokidar from \"chokidar\"\nimport { FilesystemTypesHandler } from \"lib/dependency-analysis/FilesystemTypesHandler\"\nimport { pushSnippet } from \"lib/shared/push-snippet\"\n\nexport class DevServer {\n  port: number\n  /**\n   * The path to a component that exports a <board /> or <group /> component\n   */\n  componentFilePath: string\n\n  projectDir: string\n\n  /**\n   * The HTTP server that hosts the file server and event bus. You can use\n   * fsKy to communicate with the file server/event bus\n   */\n  httpServer?: http.Server\n  /**\n   * Watches for events on the event bus by polling `api/events/list`\n   */\n  eventsWatcher?: EventsWatcher\n  /**\n   * A ky instance that can be used to communicate with the file server and\n   * event bus\n   */\n  fsKy: TypedKyInstance<keyof FileServerRoutes, FileServerRoutes>\n  /**\n   * A chokidar instance that watches the project directory for file changes\n   */\n  filesystemWatcher?: chokidar.FSWatcher\n\n  private typesHandler?: FilesystemTypesHandler\n\n  constructor({\n    port,\n    componentFilePath,\n  }: {\n    port: number\n    componentFilePath: string\n  }) {\n    this.port = port\n    this.componentFilePath = componentFilePath\n    this.projectDir = path.dirname(componentFilePath)\n    this.fsKy = ky.create({\n      prefixUrl: `http://localhost:${port}`,\n    }) as any\n    this.typesHandler = new FilesystemTypesHandler(this.projectDir)\n  }\n\n  async start() {\n    const { server } = await createHttpServer(this.port)\n    this.httpServer = server\n\n    this.eventsWatcher = new EventsWatcher(`http://localhost:${this.port}`)\n    this.eventsWatcher.start()\n\n    this.eventsWatcher.on(\n      \"FILE_UPDATED\",\n      this.handleFileUpdatedEventFromServer.bind(this),\n    )\n\n    this.eventsWatcher.on(\n      \"REQUEST_TO_SAVE_SNIPPET\",\n      this.saveSnippet.bind(this),\n    )\n\n    this.filesystemWatcher = chokidar.watch(this.projectDir, {\n      persistent: true,\n      ignoreInitial: true,\n    })\n\n    this.filesystemWatcher.on(\"change\", (filePath) =>\n      this.handleFileChangedOnFilesystem(filePath),\n    )\n    this.filesystemWatcher.on(\"add\", (filePath) =>\n      this.handleFileChangedOnFilesystem(filePath),\n    )\n\n    this.upsertInitialFiles()\n\n    this.typesHandler?.handleInitialTypeDependencies(this.componentFilePath)\n  }\n\n  async addEntrypoint() {\n    const relativeComponentFilePath = path.relative(\n      this.projectDir,\n      this.componentFilePath,\n    )\n    await this.fsKy.post(\"api/files/upsert\", {\n      json: {\n        file_path: \"entrypoint.tsx\",\n        text_content: `\nimport MyCircuit from \"./${relativeComponentFilePath}\"\n\ncircuit.add(<MyCircuit />)\n`,\n      },\n    })\n  }\n\n  async handleFileUpdatedEventFromServer(ev: FileUpdatedEvent) {\n    if (ev.initiator === \"filesystem_change\") return\n\n    if (ev.file_path === \"manual-edits.json\") {\n      console.log(\"Manual edits updated, updating on filesystem...\")\n      const { file } = await this.fsKy\n        .get(\"api/files/get\", {\n          searchParams: { file_path: ev.file_path },\n        })\n        .json()\n      fs.writeFileSync(\n        path.join(this.projectDir, \"manual-edits.json\"),\n        file.text_content,\n      )\n    }\n  }\n\n  async handleFileChangedOnFilesystem(absoluteFilePath: string) {\n    const relativeFilePath = path.relative(this.projectDir, absoluteFilePath)\n    // We've temporarily disabled upserting manual edits from filesystem changes\n    // because it can be edited by the browser\n    if (relativeFilePath.includes(\"manual-edits.json\")) return\n\n    await this.typesHandler?.handleFileTypeDependencies(absoluteFilePath)\n\n    console.log(`${relativeFilePath} saved. Applying changes...`)\n    await this.fsKy\n      .post(\"api/files/upsert\", {\n        json: {\n          file_path: relativeFilePath,\n          text_content: fs.readFileSync(absoluteFilePath, \"utf-8\"),\n          initiator: \"filesystem_change\",\n        },\n      })\n      .json()\n  }\n\n  async upsertInitialFiles() {\n    // Scan project directory for all files and upsert them\n    const fileNames = fs.readdirSync(this.projectDir)\n    for (const fileName of fileNames) {\n      if (fs.statSync(path.join(this.projectDir, fileName)).isDirectory())\n        continue\n      const fileContent = fs.readFileSync(\n        path.join(this.projectDir, fileName),\n        \"utf-8\",\n      )\n      await this.fsKy.post(\"api/files/upsert\", {\n        json: {\n          file_path: fileName,\n          text_content: fileContent,\n          initiator: \"filesystem_change\",\n        },\n      })\n    }\n  }\n\n  private async saveSnippet() {\n    const postEvent = async (\n      event: \"FAILED_TO_SAVE_SNIPPET\" | \"SNIPPET_SAVED\",\n    ) =>\n      this.fsKy.post(\"api/events/create\", {\n        json: { event_type: event },\n        throwHttpErrors: false,\n      })\n\n    await pushSnippet({\n      filePath: this.componentFilePath,\n      onExit: (e) => {\n        console.error(\"Failed to save snippet\", e)\n        postEvent(\"FAILED_TO_SAVE_SNIPPET\")\n      },\n      onError: (e) => {\n        console.error(\"Failed to save snippet\", e)\n        postEvent(\"FAILED_TO_SAVE_SNIPPET\")\n      },\n      onSuccess: () => {\n        postEvent(\"SNIPPET_SAVED\")\n      },\n    })\n  }\n\n  async stop() {\n    this.httpServer?.close()\n    this.eventsWatcher?.stop()\n  }\n}\n", "import * as http from \"node:http\"\nimport * as fs from \"node:fs\"\nimport * as path from \"node:path\"\nimport { getNodeHandler } from \"winterspec/adapters/node\"\nimport pkg from \"../../package.json\"\n\n// @ts-ignore\nimport winterspecBundle from \"@tscircuit/file-server/dist/bundle.js\"\nimport { getIndex } from \"../site/getIndex\"\n\nexport const createHttpServer = async (port = 3020) => {\n  const fileServerHandler = getNodeHandler(winterspecBundle as any, {})\n\n  const server = http.createServer(async (req, res) => {\n    const url = new URL(req.url!, `http://${req.headers.host}`)\n\n    if (url.pathname === \"/standalone.min.js\") {\n      const standaloneFilePath =\n        process.env.RUNFRAME_STANDALONE_FILE_PATH ||\n        path.resolve(\n          process.cwd(),\n          \"node_modules\",\n          \"@tscircuit/runframe/dist/standalone.min.js\",\n        )\n\n      try {\n        const content = fs.readFileSync(standaloneFilePath, \"utf8\")\n        res.writeHead(200, {\n          \"Content-Type\": \"application/javascript; charset=utf-8\",\n        })\n        res.end(content)\n        return\n      } catch (error) {\n        console.error(\"Error serving standalone.min.js:\", error)\n      }\n\n      res.writeHead(302, {\n        Location: `https://cdn.jsdelivr.net/npm/@tscircuit/runframe@${pkg.dependencies[\"@tscircuit/runframe\"].replace(/^[^0-9]+/, \"\")}/dist/standalone.min.js`,\n      })\n      res.end()\n      return\n    }\n\n    if (url.pathname === \"/\") {\n      const html = await getIndex()\n      res.writeHead(200, { \"Content-Type\": \"text/html\" })\n      res.end(html)\n      return\n    }\n\n    if (url.pathname.startsWith(\"/api/\")) {\n      req.url = req.url!.replace(\"/api/\", \"/\")\n      fileServerHandler(req, res)\n      return\n    }\n\n    res.writeHead(404)\n    res.end(\"Not found\")\n  })\n\n  return new Promise<{ server: http.Server }>((resolve) => {\n    server.listen(port, () => {\n      console.log(`Server running at http://localhost:${port}`)\n      resolve({ server })\n    })\n  })\n}\n", "{\n  \"name\": \"@tscircuit/cli\",\n  \"main\": \"dist/main.js\",\n  \"type\": \"module\",\n  \"version\": \"0.1.32\",\n  \"bin\": {\n    \"tsci\": \"./dist/main.js\"\n  },\n  \"scripts\": {\n    \"start\": \"bun run dev\",\n    \"dev\": \"bun --hot ./cli/main.ts dev ./example-dir/snippet1-basic.tsx\",\n    \"build\": \"tsup-node cli/main.ts --format esm --sourcemap inline\",\n    \"format\": \"biome format --write .\",\n    \"format:check\": \"biome format .\",\n    \"cli\": \"bun ./cli/main.ts\"\n  },\n  \"devDependencies\": {\n    \"@biomejs/biome\": \"^1.9.4\",\n    \"@tscircuit/core\": \"^0.0.249\",\n    \"@tscircuit/fake-snippets\": \"^0.0.5\",\n    \"@types/bun\": \"^1.1.15\",\n    \"@types/configstore\": \"^6.0.2\",\n    \"@types/react\": \"^19.0.8\",\n    \"@types/semver\": \"^7.5.8\",\n    \"get-port\": \"^7.1.0\",\n    \"tempy\": \"^3.1.0\",\n    \"tsup\": \"^8.3.5\",\n    \"typed-ky\": \"^0.0.4\"\n  },\n  \"peerDependencies\": {\n    \"typescript\": \"^5.0.0\"\n  },\n  \"dependencies\": {\n    \"@tscircuit/eval\": \"^0.0.96\",\n    \"@tscircuit/file-server\": \"^0.0.13\",\n    \"@tscircuit/runframe\": \"^0.0.167\",\n    \"bun-match-svg\": \"^0.0.9\",\n    \"chokidar\": \"4.0.1\",\n    \"circuit-to-svg\": \"^0.0.101\",\n    \"commander\": \"^12.1.0\",\n    \"configstore\": \"^7.0.0\",\n    \"cosmiconfig\": \"^9.0.0\",\n    \"delay\": \"^6.0.0\",\n    \"jwt-decode\": \"^4.0.0\",\n    \"ky\": \"^1.7.4\",\n    \"make-vfs\": \"^1.0.15\",\n    \"perfect-cli\": \"^1.0.20\",\n    \"redaxios\": \"^0.5.1\",\n    \"semver\": \"^7.6.3\"\n  }\n}\n", "import pkg from \"../../package.json\"\n\nexport const getIndex = async () => {\n  return `<html>\n    <head>\n    </head>\n    <body>\n      <script src=\"https://cdn.tailwindcss.com\"></script>\n      <div id=\"root\">loading...</div>\n      <script>\n      globalThis.process = { env: { NODE_ENV: \"production\" } }\n      </script>\n      <script src=\"/standalone.min.js\"></script>\n    </body>\n  </html>`\n}\n\n// <script src=\"https://cdn.jsdelivr.net/npm/@tscircuit/runframe@${pkg.dependencies[\"@tscircuit/runframe\"].replace(/^[^0-9]+/, \"\")}/dist/standalone.min.js\"></script>\n", "import { EventEmitter } from \"events\"\n\ninterface Event {\n  event_id: string\n  created_at: string\n  event_type: string\n  [key: string]: any\n}\n\ninterface EventsResponse {\n  event_list: Event[]\n}\n\nexport class EventsWatcher extends EventEmitter {\n  private lastPollTime: string\n  private pollInterval: number\n  private baseUrl: string\n  private polling = false\n  private timeoutId?: NodeJS.Timeout\n\n  constructor(baseUrl = \"http://localhost:3000\", pollInterval = 1000) {\n    super()\n    this.baseUrl = baseUrl\n    this.pollInterval = pollInterval\n    this.lastPollTime = new Date().toISOString()\n  }\n\n  async start() {\n    if (this.polling) return\n    this.polling = true\n    await this.poll()\n  }\n\n  stop() {\n    this.polling = false\n    if (this.timeoutId) {\n      clearTimeout(this.timeoutId)\n    }\n  }\n\n  private async poll() {\n    if (!this.polling) return\n\n    try {\n      const response = await fetch(\n        `${this.baseUrl}/api/events/list?since=${encodeURIComponent(this.lastPollTime)}`,\n      )\n\n      if (!response.ok) {\n        throw new Error(`HTTP error! status: ${response.status}`)\n      }\n\n      const data: EventsResponse = await response.json()\n\n      // Update last poll time to latest event or current time\n      const latestEvent = data.event_list[data.event_list.length - 1]\n      this.lastPollTime = latestEvent\n        ? latestEvent.created_at\n        : new Date().toISOString()\n\n      // Emit events in chronological order\n      data.event_list.forEach((event) => {\n        this.emit(event.event_type, event)\n        this.emit(\"*\", event)\n      })\n    } catch (error) {\n      this.emit(\"error\", error)\n    }\n    // Schedule next poll\n    this.timeoutId = globalThis.setTimeout(\n      () => this.poll(),\n      this.pollInterval,\n    ) as unknown as NodeJS.Timeout\n  }\n}\n", "import * as fs from \"node:fs\"\nimport * as path from \"node:path\"\nimport { findImportsInSnippet } from \"./findImportsInSnippet\"\nimport { installNodeModuleTypesForSnippet } from \"./installNodeModuleTypesForSnippet\"\n\nexport class FilesystemTypesHandler {\n  private projectRoot: string\n\n  constructor(initialDir: string) {\n    this.projectRoot = this.findProjectRoot(initialDir)\n  }\n\n  async handleInitialTypeDependencies(filePath: string) {\n    console.log(\"Checking initial type dependencies...\")\n    try {\n      if (!this.areTypesInstalled(filePath)) {\n        console.log(\"Installing missing initial types...\")\n        await installNodeModuleTypesForSnippet(filePath)\n      }\n    } catch (error) {\n      console.warn(\"Error handling initial type dependencies:\", error)\n    }\n  }\n\n  async handleFileTypeDependencies(filePath: string) {\n    try {\n      if (!this.areTypesInstalled(filePath)) {\n        console.log(\"Installing missing file types...\")\n        await installNodeModuleTypesForSnippet(filePath)\n      }\n    } catch (error) {\n      console.warn(\"Failed to verify types:\", error)\n    }\n  }\n\n  private areTypesInstalled(filePath: string): boolean {\n    const imports = findImportsInSnippet(filePath)\n    return imports.every((imp) => this.checkTypeExists(imp))\n  }\n\n  private checkTypeExists(importPath: string): boolean {\n    if (!importPath.startsWith(\"@tsci/\")) return true\n\n    const pathWithoutPrefix = importPath.replace(\"@tsci/\", \"\")\n    const [owner, name] = pathWithoutPrefix.split(\".\")\n\n    const typePath = path.join(\n      this.projectRoot,\n      \"node_modules\",\n      \"@tsci\",\n      `${owner}.${name}`,\n      \"index.d.ts\",\n    )\n\n    return fs.existsSync(typePath)\n  }\n\n  private findProjectRoot(startDir: string): string {\n    let root = path.resolve(startDir)\n    while (root !== path.parse(root).root) {\n      if (fs.existsSync(path.join(root, \"package.json\"))) {\n        return root\n      }\n      root = path.dirname(root)\n    }\n    return startDir\n  }\n}\n", "import * as fs from \"node:fs\"\nimport * as ts from \"typescript\"\n\nexport function findImportsInSnippet(snippetPath: string): string[] {\n  const content = fs.readFileSync(snippetPath, \"utf-8\")\n  const sourceFile = ts.createSourceFile(\n    snippetPath,\n    content,\n    ts.ScriptTarget.Latest,\n    true,\n  )\n\n  const imports: string[] = []\n\n  function visit(node: ts.Node) {\n    if (ts.isImportDeclaration(node)) {\n      const moduleSpecifier = node.moduleSpecifier\n      if (moduleSpecifier && ts.isStringLiteral(moduleSpecifier)) {\n        const importPath = moduleSpecifier.text\n        if (importPath.startsWith(\"@tsci/\")) {\n          imports.push(importPath)\n        }\n      }\n    }\n    ts.forEachChild(node, visit)\n  }\n\n  visit(sourceFile)\n\n  return imports\n}\n", "import Configstore from \"configstore\"\nimport type { TypedConfigstore } from \"./TypedConfigStore\"\nimport { jwtDecode } from \"jwt-decode\"\n\nexport interface CliConfig {\n  sessionToken?: string\n  githubUsername?: string\n  registryApiUrl?: string\n}\n\nexport const cliConfig: TypedConfigstore<CliConfig> = new Configstore(\n  \"tscircuit\",\n)\n\nexport const setSessionToken = (token: string) => {\n  cliConfig.set(\"sessionToken\", token)\n  const decoded = jwtDecode<{\n    github_username: string\n  }>(token)\n  cliConfig.set(\"githubUsername\", decoded.github_username)\n}\n\nexport const clearSession = () => {\n  cliConfig.delete(\"sessionToken\")\n  cliConfig.delete(\"githubUsername\")\n}\n\nexport const getRegistryApiUrl = (): string => {\n  return cliConfig.get(\"registryApiUrl\") ?? \"https://registry-api.tscircuit.com\"\n}\n", "import { getRegistryApiUrl } from \"lib/cli-config\"\nimport ky, { type AfterResponseHook } from \"ky\"\n\nexport const prettyResponseErrorHook: AfterResponseHook = async (\n  _request,\n  _options,\n  response,\n) => {\n  if (!response.ok) {\n    try {\n      const errorData = await response.json()\n      throw new Error(\n        `FAIL [${response.status}]: ${_request.method} ${\n          new URL(_request.url).pathname\n        } \\n\\n ${JSON.stringify(errorData, null, 2)}`,\n      )\n    } catch (e) {\n      //ignore, allow the error to be thrown\n    }\n  }\n}\n\nexport const getKy = () => {\n  return ky.create({\n    prefixUrl: getRegistryApiUrl(),\n    hooks: {\n      afterResponse: [prettyResponseErrorHook],\n    },\n  })\n}\n", "import { cliConfig } from \"lib/cli-config\"\nimport { getKy } from \"lib/registry-api/get-ky\"\nimport * as fs from \"node:fs\"\nimport * as path from \"node:path\"\nimport semver from \"semver\"\n\ntype PushOptions = {\n  filePath?: string\n  onExit?: (code: number) => void\n  onError?: (message: string) => void\n  onSuccess?: (message: string) => void\n}\n\nexport const pushSnippet = async ({\n  filePath,\n  onExit = (code) => process.exit(code),\n  onError = (message) => console.error(message),\n  onSuccess = (message) => console.log(message),\n}: PushOptions) => {\n  const sessionToken = cliConfig.get(\"sessionToken\")\n  if (!sessionToken) {\n    onError(\"You need to log in to save snippet.\")\n    return onExit(1)\n  }\n\n  let snippetFilePath: string | null = null\n  if (filePath) {\n    snippetFilePath = path.resolve(filePath)\n  } else {\n    const defaultEntrypoint = path.resolve(\"index.tsx\")\n    if (fs.existsSync(defaultEntrypoint)) {\n      snippetFilePath = defaultEntrypoint\n      onSuccess(\"No file provided. Using 'index.tsx' as the entrypoint.\")\n    } else {\n      onError(\n        \"No entrypoint found. Run 'tsci init' to bootstrap a basic project.\",\n      )\n      return onExit(1)\n    }\n  }\n\n  const packageJsonPath = path.resolve(\n    path.join(path.dirname(snippetFilePath), \"package.json\"),\n  )\n  let packageJson: { name?: string; author?: string; version?: string } = {}\n  if (fs.existsSync(packageJsonPath)) {\n    try {\n      packageJson = JSON.parse(fs.readFileSync(packageJsonPath).toString())\n    } catch {\n      onError(\"Invalid package.json provided\")\n      return onExit(1)\n    }\n  }\n\n  if (!fs.existsSync(snippetFilePath)) {\n    onError(`File not found: ${snippetFilePath}`)\n    return onExit(1)\n  }\n\n  const ky = getKy()\n  const packageName = (\n    packageJson.name ?? path.parse(snippetFilePath).name\n  ).replace(/^@/, \"\")\n  const packageAuthor =\n    packageJson.author?.split(\" \")[0] ?? cliConfig.get(\"githubUsername\")\n  const packageIdentifier = `${packageAuthor}/${packageName}`\n\n  let packageVersion =\n    packageJson.version ??\n    (await ky\n      .post<{\n        error?: { error_code: string }\n        package_releases?: { version: string; is_latest: boolean }[]\n      }>(\"package_releases/list\", {\n        json: { package_name: packageIdentifier },\n      })\n      .json()\n      .then(\n        (response) =>\n          response.package_releases?.[response.package_releases.length - 1]\n            ?.version,\n      )\n      .catch((error) => {\n        onError(\"Failed to retrieve latest package version:\" + error)\n        return onExit(1)\n      }))\n\n  if (!packageVersion) {\n    onError(\"Failed to retrieve package version.\")\n    return onExit(1)\n  }\n\n  const updatePackageJsonVersion = (newVersion?: string) => {\n    if (packageJson.version) {\n      try {\n        packageJson.version = newVersion ?? `${packageVersion}`\n        fs.writeFileSync(packageJsonPath, JSON.stringify(packageJson, null, 2))\n      } catch (error) {\n        onError(\"Failed to update package.json version:\" + error)\n      }\n    }\n  }\n\n  const doesPackageExist = await ky\n    .post<{ error?: { error_code: string } }>(\"packages/get\", {\n      json: { name: packageIdentifier },\n      throwHttpErrors: false,\n    })\n    .json()\n    .then((response) => !(response.error?.error_code === \"package_not_found\"))\n\n  if (!doesPackageExist) {\n    await ky\n      .post(\"packages/create\", {\n        json: { name: packageIdentifier },\n        headers: { Authorization: `Bearer ${sessionToken}` },\n      })\n      .catch((error) => {\n        onError(\"Error creating package:\" + error)\n        return onExit(1)\n      })\n  }\n\n  const doesReleaseExist = await ky\n    .post<{\n      error?: { error_code: string }\n      package_release?: { version: string }\n    }>(\"package_releases/get\", {\n      json: {\n        package_name_with_version: `${packageIdentifier}@${packageVersion}`,\n      },\n      throwHttpErrors: false,\n    })\n    .json()\n    .then((response) => {\n      if (response.package_release?.version) {\n        packageVersion = response.package_release.version\n        updatePackageJsonVersion(response.package_release.version)\n        return true\n      }\n      return !(response.error?.error_code === \"package_release_not_found\")\n    })\n\n  if (doesReleaseExist) {\n    const bumpedVersion = semver.inc(packageVersion, \"patch\")!\n    onSuccess(\n      `Incrementing Package Version ${packageVersion} -> ${bumpedVersion}`,\n    )\n    packageVersion = bumpedVersion\n    updatePackageJsonVersion(packageVersion)\n  }\n\n  await ky\n    .post(\"package_releases/create\", {\n      json: {\n        package_name_with_version: `${packageIdentifier}@${packageVersion}`,\n      },\n      throwHttpErrors: false,\n    })\n    .catch((error) => {\n      onError(\"Error creating release:\" + error)\n      return onExit(1)\n    })\n\n  onSuccess(\"\\n\")\n\n  const directoryFiles = fs.readdirSync(path.dirname(snippetFilePath))\n  for (const file of directoryFiles) {\n    const fileExtension = path.extname(file).replace(\".\", \"\")\n    if (![\"json\", \"tsx\", \"ts\"].includes(fileExtension)) continue\n    const fileContent =\n      fs\n        .readFileSync(path.join(path.dirname(snippetFilePath), file))\n        .toString() ?? \"\"\n    await ky\n      .post(\"package_files/create\", {\n        json: {\n          file_path: file,\n          content_text: fileContent,\n          package_name_with_version: `${packageIdentifier}@${packageVersion}`,\n        },\n        throwHttpErrors: false,\n      })\n      .then(() => {\n        onSuccess(`Uploaded file ${file} to the registry.`)\n      })\n      .catch((error) => {\n        onError(`Error uploading file ${file}:` + error)\n      })\n  }\n\n  onSuccess(\n    [\n      `\\n\uD83C\uDF89 Successfully pushed package ${packageIdentifier}@${packageVersion} to the registry!${Bun.color(\"blue\", \"ansi\")}`,\n      `https://tscircuit.com/${packageIdentifier} \\x1b[0m`,\n    ].join(\" \"),\n  )\n}\n", "import type { Command } from \"commander\"\nimport { setSessionToken } from \"lib/cli-config\"\nimport delay from \"delay\"\nimport { getKy } from \"lib/registry-api/get-ky\"\nimport type { EndpointResponse } from \"lib/registry-api/endpoint-types\"\n\nexport const registerAuthLogin = (program: Command) => {\n  // Define the login action once to share between both commands\n  const loginAction = async () => {\n    const ky = getKy()\n\n    const { login_page } = await ky\n      .post<EndpointResponse[\"sessions/login_page/create\"]>(\n        \"sessions/login_page/create\",\n        {\n          json: {},\n        },\n      )\n      .json()\n\n    console.log(\"Please visit the following URL to log in:\")\n    console.log(login_page.url)\n\n    // Wait until we receive confirmation\n    while (true) {\n      const { login_page: new_login_page } = await ky\n        .post<EndpointResponse[\"sessions/login_page/get\"]>(\n          \"sessions/login_page/get\",\n          {\n            json: {\n              login_page_id: login_page.login_page_id,\n            },\n            headers: {\n              Authorization: `Bearer ${login_page.login_page_auth_token}`,\n            },\n          },\n        )\n        .json()\n\n      if (new_login_page.was_login_successful) {\n        console.log(\"Logged in! Generating token...\")\n        break\n      }\n\n      if (new_login_page.is_expired) {\n        throw new Error(\"Login page expired\")\n      }\n\n      await delay(1000)\n    }\n\n    const { session } = await ky\n      .post<EndpointResponse[\"sessions/login_page/exchange_for_cli_session\"]>(\n        \"sessions/login_page/exchange_for_cli_session\",\n        {\n          json: {\n            login_page_id: login_page.login_page_id,\n          },\n          headers: {\n            Authorization: `Bearer ${login_page.login_page_auth_token}`,\n          },\n        },\n      )\n      .json()\n\n    setSessionToken(session.token)\n    console.log(\"\\nReady to use!\")\n  }\n\n  // Register the auth login subcommand\n  program.commands\n    .find((c) => c.name() === \"auth\")!\n    .command(\"login\")\n    .description(\"Authenticate CLI, login to registry\")\n    .action(loginAction)\n\n  // Register the top-level login command as an alias\n  program\n    .command(\"login\")\n    .description(\"Login to tscircuit registry\")\n    .action(loginAction)\n}\n", "import type { Command } from \"commander\"\nimport { clearSession } from \"lib/cli-config\"\n\nexport const registerAuthLogout = (program: Command) => {\n  const logoutAction = () => {\n    clearSession()\n    console.log(\"You have been logged out!\")\n  }\n\n  // Register the auth logout subcommand\n  program.commands\n    .find((c) => c.name() === \"auth\")!\n    .command(\"logout\")\n    .description(\"Logout from registry\")\n    .action(logoutAction)\n\n  // Register the top-level logout command as an alias\n  program\n    .command(\"logout\")\n    .description(\"Logout from tscircuit registry\")\n    .action(logoutAction)\n}\n", "import type { Command } from \"commander\"\n\nexport const registerAuth = (program: Command) => {\n  program.command(\"auth\").description(\"Login/logout\")\n}\n", "import type { Command } from \"commander\"\n\nexport const registerConfig = (program: Command) => {\n  program.command(\"config\").description(\"Manage tscircuit CLI configuration\")\n}\n", "import type { Command } from \"commander\"\nimport { cliConfig } from \"lib/cli-config\"\n\nexport const registerConfigPrint = (program: Command) => {\n  program.commands\n    .find((c) => c.name() === \"config\")!\n    .command(\"print\")\n    .description(\"Print the current config\")\n    .action(() => {\n      console.log(JSON.stringify(cliConfig.all, null, 2))\n    })\n}\n", "import type { Command } from \"commander\"\nimport { getKy } from \"lib/registry-api/get-ky\"\nimport * as fs from \"node:fs\"\nimport * as path from \"node:path\"\nimport { setupTsciProject } from \"lib/shared/setup-tsci-packages\"\nimport { generateTsConfig } from \"lib/shared/generate-ts-config\"\n\nexport const registerClone = (program: Command) => {\n  program\n    .command(\"clone\")\n    .description(\"Clone a snippet from the registry\")\n    .argument(\"<snippet>\", \"Snippet to clone (e.g. author/snippetName)\")\n    .action(async (snippetPath: string) => {\n      const match = snippetPath.match(/^(?:@tsci\\/)?([^/.]+)[/.](.+)$/)\n      if (!match) {\n        console.error(\n          \"Invalid snippet path. Use format: author/snippetName, author.snippetName, or @tsci/author.snippetName\",\n        )\n        process.exit(1)\n      }\n\n      const [, author, snippetName] = match\n      console.log(`Cloning ${author}/${snippetName}...`)\n\n      const ky = getKy()\n      let packageFileList\n      try {\n        packageFileList = await ky\n          .post<{ package_files: Array<{ file_path: string }> }>(\n            \"package_files/list\",\n            {\n              json: {\n                package_name: `${author}/${snippetName}`,\n                use_latest_version: true,\n              },\n            },\n          )\n          .json()\n      } catch (error) {\n        console.error(\n          \"Failed to fetch package files:\",\n          error instanceof Error ? error.message : error,\n        )\n        process.exit(1)\n      }\n\n      const dirPath = path.resolve(`${author}.${snippetName}`)\n      fs.mkdirSync(dirPath, { recursive: true })\n\n      for (const fileInfo of packageFileList.package_files) {\n        const filePath = fileInfo.file_path.replace(/^\\/|dist\\//g, \"\")\n        if (!filePath) continue\n\n        const fullPath = path.join(dirPath, filePath)\n        fs.mkdirSync(path.dirname(fullPath), { recursive: true })\n\n        try {\n          const fileContent = await ky\n            .post<{ package_file: { content_text: string } }>(\n              \"package_files/get\",\n              {\n                json: {\n                  package_name: `${author}/${snippetName}`,\n                  file_path: fileInfo.file_path,\n                },\n              },\n            )\n            .json()\n\n          let fileText = fileContent.package_file.content_text\n\n          // Ensure all .tsx files contain \"import '@tscircuit/core';\"\n          if (\n            filePath.endsWith(\".tsx\") &&\n            !fileText.includes(\"@tscircuit/core\")\n          ) {\n            fileText = `import \"@tscircuit/core\";\\n\\n${fileText}`\n          }\n\n          fs.writeFileSync(fullPath, fileText)\n        } catch (error) {\n          console.warn(\n            `Skipping ${filePath} due to error:`,\n            error instanceof Error ? error.message : error,\n          )\n        }\n      }\n\n      fs.writeFileSync(\n        path.join(dirPath, \".npmrc\"),\n        \"@tsci:registry=https://npm.tscircuit.com\",\n      )\n\n      generateTsConfig(dirPath)\n      setupTsciProject(dirPath)\n\n      console.log(`Successfully cloned to ${dirPath}/`)\n      console.log(\n        `Run \"cd ${path.dirname(dirPath)} && tsci dev\" to start developing.`,\n      )\n    })\n}\n", "import type { Command } from \"commander\"\nimport { createCircuitWebWorker } from \"@tscircuit/eval\"\nimport webWorkerBundleUrl from \"@tscircuit/eval/blob-url\"\nimport { getVirtualFileSystemFromDirPath } from \"make-vfs\"\nimport path from \"node:path\"\nimport fs from \"node:fs\"\nimport {\n  convertCircuitJsonToSchematicSvg,\n  convertCircuitJsonToPcbSvg,\n} from \"circuit-to-svg\"\n\nconst ALLOWED_FORMATS = [\n  \"json\",\n  \"circuit-json\",\n  \"schematic-svg\",\n  \"pcb-svg\",\n  \"gerbers\",\n  \"readable-netlist\",\n  \"gltf\",\n  \"specctra-dsn\",\n] as const\n\ntype Format = (typeof ALLOWED_FORMATS)[number]\n\nconst OUTPUT_EXTENSIONS = {\n  json: \".circuit.json\",\n  \"circuit-json\": \".circuit.json\",\n  \"schematic-svg\": \"-schematic.svg\",\n  \"pcb-svg\": \"-pcb.svg\",\n  gerbers: \"-gerbers.zip\",\n  \"readable-netlist\": \"-readable.netlist\",\n  gltf: \".gltf\",\n  \"specctra-dsn\": \".dsn\",\n}\n\nexport const registerExport = (program: Command) => {\n  program\n    .command(\"export\")\n    .description(\"Export tscircuit code to various formats\")\n    .argument(\"<file>\", \"Path to the snippet file\")\n    .option(\"-f, --format <format>\", \"Output format\")\n    .option(\"-o, --output <path>\", \"Output file path\")\n    .action(async (file, options) => {\n      const { format = \"circuit-json\" } = options\n      let { output } = options\n      if (!ALLOWED_FORMATS.includes(format)) {\n        throw new Error(\n          `Invalid format: ${format}\\nSupported formats: ${ALLOWED_FORMATS.join(\",\")}`,\n        )\n      }\n\n      if (!output) {\n        output = path.basename(file).replace(/\\.[^.]+$/, \"\")\n      }\n\n      const worker = await createCircuitWebWorker({\n        webWorkerUrl: webWorkerBundleUrl,\n      })\n\n      const projectDir = path.dirname(file)\n\n      const relativeComponentPath = path.relative(projectDir, file)\n\n      await worker.executeWithFsMap({\n        entrypoint: \"entrypoint.tsx\",\n        fsMap: {\n          ...((await getVirtualFileSystemFromDirPath({\n            dirPath: projectDir,\n            contentFormat: \"string\",\n          })) as Record<string, string>),\n          \"entrypoint.tsx\": `\nimport MyCircuit from \"./${relativeComponentPath}\"\n\ncircuit.add(<MyCircuit />)\n        `,\n        },\n      })\n\n      await worker.renderUntilSettled()\n\n      const circuitJson = await worker.getCircuitJson()\n      const outputPath = path.join(\n        projectDir,\n        `${output}${OUTPUT_EXTENSIONS[format as Format]}`,\n      )\n\n      let outputContent: string\n\n      switch (format) {\n        case \"schematic-svg\":\n          outputContent = convertCircuitJsonToSchematicSvg(circuitJson)\n          break\n        case \"pcb-svg\":\n          outputContent = convertCircuitJsonToPcbSvg(circuitJson)\n          break\n        default:\n          outputContent = JSON.stringify(circuitJson)\n      }\n\n      fs.writeFileSync(outputPath, outputContent)\n\n      console.log(`Exported to ${outputPath}`)\n\n      process.exit(0)\n    })\n}\n", "import type { Command } from \"commander\"\nimport { cliConfig } from \"lib/cli-config\"\n\nexport const registerAuthPrintToken = (program: Command) => {\n  program.commands\n    .find((c) => c.name() === \"auth\")!\n    .command(\"print-token\")\n    .description(\"Prints your auth token\")\n    .action(() => {\n      const token = cliConfig.get(\"sessionToken\")\n      if (!token) return console.log(\"You need to log in to access this.\")\n      console.log(\"Your Token:\\n\", token)\n    })\n}\n", "import type { Command } from \"commander\"\nimport { setSessionToken } from \"lib/cli-config\"\n\nfunction validateJWTLength(token: string) {\n  const parts = token.split(\".\")\n\n  if (parts.length === 3 && parts.every((part) => part.length > 0)) {\n    return true\n  } else {\n    return false\n  }\n}\nexport const registerAuthSetToken = (program: Command) => {\n  program.commands\n    .find((c) => c.name() === \"auth\")!\n    .command(\"set-token\")\n    .description(\"Explicitly set your auth token\")\n    .argument(\"<token>\", \"New token to manually configure\")\n    .action((token) => {\n      if (!validateJWTLength(token))\n        return console.log(\"Invalid token provided\")\n      setSessionToken(token)\n      console.log(\"Token manually updated.\")\n    })\n}\n", "import { pushSnippet } from \"lib/shared/push-snippet\"\nimport type { Command } from \"commander\"\n\nexport const registerPush = (program: Command) => {\n  program\n    .command(\"push\")\n    .description(\"Save snippet code to Registry API\")\n    .argument(\"[file]\", \"Path to the snippet file\")\n    .action(async (filePath?: string) => {\n      await pushSnippet({\n        filePath,\n        onExit: (code) => process.exit(code),\n        onError: (message) => console.error(message),\n        onSuccess: (message) => console.log(message),\n      })\n    })\n}\n"],
  "mappings": "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",
  "names": ["fs", "path", "fs", "path", "fs", "path", "path", "program", "path", "fs", "fs", "path", "ky", "fs", "path", "resolve", "path", "fs", "fs", "path", "fs", "ts", "fs", "path", "ky", "path", "ky", "fs", "program", "port", "resolve", "server", "program", "ky", "program", "program", "program", "program", "fs", "path", "program", "ky", "semver", "path", "fs", "program", "program", "program", "program", "semver"]
}

|