@agent-native/core 0.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (127) hide show
  1. package/dist/adapters/firestore/config.d.ts +20 -0
  2. package/dist/adapters/firestore/config.d.ts.map +1 -0
  3. package/dist/adapters/firestore/config.js +50 -0
  4. package/dist/adapters/firestore/config.js.map +1 -0
  5. package/dist/adapters/firestore/index.d.ts +4 -0
  6. package/dist/adapters/firestore/index.d.ts.map +1 -0
  7. package/dist/adapters/firestore/index.js +4 -0
  8. package/dist/adapters/firestore/index.js.map +1 -0
  9. package/dist/adapters/firestore/merge.d.ts +21 -0
  10. package/dist/adapters/firestore/merge.d.ts.map +1 -0
  11. package/dist/adapters/firestore/merge.js +132 -0
  12. package/dist/adapters/firestore/merge.js.map +1 -0
  13. package/dist/adapters/firestore/sync.d.ts +91 -0
  14. package/dist/adapters/firestore/sync.d.ts.map +1 -0
  15. package/dist/adapters/firestore/sync.js +340 -0
  16. package/dist/adapters/firestore/sync.js.map +1 -0
  17. package/dist/cli/create.d.ts +5 -0
  18. package/dist/cli/create.d.ts.map +1 -0
  19. package/dist/cli/create.js +87 -0
  20. package/dist/cli/create.js.map +1 -0
  21. package/dist/cli/index.d.ts +3 -0
  22. package/dist/cli/index.d.ts.map +1 -0
  23. package/dist/cli/index.js +27 -0
  24. package/dist/cli/index.js.map +1 -0
  25. package/dist/client/fusion-chat.d.ts +27 -0
  26. package/dist/client/fusion-chat.d.ts.map +1 -0
  27. package/dist/client/fusion-chat.js +19 -0
  28. package/dist/client/fusion-chat.js.map +1 -0
  29. package/dist/client/index.d.ts +5 -0
  30. package/dist/client/index.d.ts.map +1 -0
  31. package/dist/client/index.js +5 -0
  32. package/dist/client/index.js.map +1 -0
  33. package/dist/client/use-file-watcher.d.ts +23 -0
  34. package/dist/client/use-file-watcher.d.ts.map +1 -0
  35. package/dist/client/use-file-watcher.js +40 -0
  36. package/dist/client/use-file-watcher.js.map +1 -0
  37. package/dist/client/use-fusion-chat.d.ts +14 -0
  38. package/dist/client/use-fusion-chat.d.ts.map +1 -0
  39. package/dist/client/use-fusion-chat.js +29 -0
  40. package/dist/client/use-fusion-chat.js.map +1 -0
  41. package/dist/client/utils.d.ts +4 -0
  42. package/dist/client/utils.d.ts.map +1 -0
  43. package/dist/client/utils.js +7 -0
  44. package/dist/client/utils.js.map +1 -0
  45. package/dist/index.d.ts +5 -0
  46. package/dist/index.d.ts.map +1 -0
  47. package/dist/index.js +8 -0
  48. package/dist/index.js.map +1 -0
  49. package/dist/scripts/index.d.ts +3 -0
  50. package/dist/scripts/index.d.ts.map +1 -0
  51. package/dist/scripts/index.js +3 -0
  52. package/dist/scripts/index.js.map +1 -0
  53. package/dist/scripts/runner.d.ts +16 -0
  54. package/dist/scripts/runner.d.ts.map +1 -0
  55. package/dist/scripts/runner.js +42 -0
  56. package/dist/scripts/runner.js.map +1 -0
  57. package/dist/scripts/utils.d.ts +30 -0
  58. package/dist/scripts/utils.d.ts.map +1 -0
  59. package/dist/scripts/utils.js +88 -0
  60. package/dist/scripts/utils.js.map +1 -0
  61. package/dist/server/create-server.d.ts +21 -0
  62. package/dist/server/create-server.d.ts.map +1 -0
  63. package/dist/server/create-server.js +27 -0
  64. package/dist/server/create-server.js.map +1 -0
  65. package/dist/server/index.d.ts +4 -0
  66. package/dist/server/index.d.ts.map +1 -0
  67. package/dist/server/index.js +4 -0
  68. package/dist/server/index.js.map +1 -0
  69. package/dist/server/production.d.ts +18 -0
  70. package/dist/server/production.d.ts.map +1 -0
  71. package/dist/server/production.js +37 -0
  72. package/dist/server/production.js.map +1 -0
  73. package/dist/server/sse.d.ts +30 -0
  74. package/dist/server/sse.d.ts.map +1 -0
  75. package/dist/server/sse.js +44 -0
  76. package/dist/server/sse.js.map +1 -0
  77. package/dist/shared/fusion-chat.d.ts +39 -0
  78. package/dist/shared/fusion-chat.d.ts.map +1 -0
  79. package/dist/shared/fusion-chat.js +52 -0
  80. package/dist/shared/fusion-chat.js.map +1 -0
  81. package/dist/shared/index.d.ts +2 -0
  82. package/dist/shared/index.d.ts.map +1 -0
  83. package/dist/shared/index.js +2 -0
  84. package/dist/shared/index.js.map +1 -0
  85. package/dist/tailwind.preset.d.ts +13 -0
  86. package/dist/tailwind.preset.d.ts.map +1 -0
  87. package/dist/tailwind.preset.js +92 -0
  88. package/dist/tailwind.preset.js.map +1 -0
  89. package/dist/vite/client.d.ts +24 -0
  90. package/dist/vite/client.d.ts.map +1 -0
  91. package/dist/vite/client.js +52 -0
  92. package/dist/vite/client.js.map +1 -0
  93. package/dist/vite/express-plugin.d.ts +11 -0
  94. package/dist/vite/express-plugin.d.ts.map +1 -0
  95. package/dist/vite/express-plugin.js +22 -0
  96. package/dist/vite/express-plugin.js.map +1 -0
  97. package/dist/vite/index.d.ts +4 -0
  98. package/dist/vite/index.d.ts.map +1 -0
  99. package/dist/vite/index.js +4 -0
  100. package/dist/vite/index.js.map +1 -0
  101. package/dist/vite/server.d.ts +21 -0
  102. package/dist/vite/server.d.ts.map +1 -0
  103. package/dist/vite/server.js +68 -0
  104. package/dist/vite/server.js.map +1 -0
  105. package/package.json +82 -0
  106. package/src/templates/default/.env.example +5 -0
  107. package/src/templates/default/.prettierrc +5 -0
  108. package/src/templates/default/AGENTS.md +65 -0
  109. package/src/templates/default/_gitignore +29 -0
  110. package/src/templates/default/client/App.tsx +54 -0
  111. package/src/templates/default/client/global.css +72 -0
  112. package/src/templates/default/client/lib/utils.ts +1 -0
  113. package/src/templates/default/client/vite-env.d.ts +1 -0
  114. package/src/templates/default/components.json +20 -0
  115. package/src/templates/default/index.html +14 -0
  116. package/src/templates/default/package.json +46 -0
  117. package/src/templates/default/postcss.config.js +6 -0
  118. package/src/templates/default/scripts/hello.ts +20 -0
  119. package/src/templates/default/scripts/run.ts +9 -0
  120. package/src/templates/default/server/index.ts +18 -0
  121. package/src/templates/default/server/node-build.ts +4 -0
  122. package/src/templates/default/shared/api.ts +6 -0
  123. package/src/templates/default/tailwind.config.ts +7 -0
  124. package/src/templates/default/tsconfig.json +3 -0
  125. package/src/templates/default/vite.config.server.ts +3 -0
  126. package/src/templates/default/vite.config.ts +3 -0
  127. package/tsconfig.base.json +41 -0
@@ -0,0 +1,340 @@
1
+ import fs from "fs";
2
+ import path from "path";
3
+ import { EventEmitter } from "events";
4
+ import { watch } from "chokidar";
5
+ import { shouldSyncFile, getDocId, loadSyncConfig } from "./config.js";
6
+ import { threeWayMerge } from "./merge.js";
7
+ // ---------------------------------------------------------------------------
8
+ // Core sync implementation
9
+ // ---------------------------------------------------------------------------
10
+ const TTL_MS = 3000;
11
+ export class FileSync {
12
+ options;
13
+ recentlyPulled = new Map();
14
+ recentlyPushed = new Map();
15
+ lastSyncedContent = new Map();
16
+ sharedSyncInitialized = false;
17
+ privateSyncInitialized = false;
18
+ purgeTimer = null;
19
+ syncEvents = new EventEmitter();
20
+ constructor(options) {
21
+ this.options = options;
22
+ }
23
+ // ── Public API ──────────────────────────────────────────────────────
24
+ /**
25
+ * Initialize the shared sync channel.
26
+ * Runs startup sync, starts Firestore listener, and starts file watcher.
27
+ */
28
+ async initFileSync() {
29
+ if (this.sharedSyncInitialized)
30
+ return;
31
+ this.sharedSyncInitialized = true;
32
+ const config = loadSyncConfig(this.options.syncConfigPath);
33
+ const patterns = config.syncFilePatterns;
34
+ if (patterns.length === 0) {
35
+ console.log("[file-sync] No syncFilePatterns configured - file sync disabled");
36
+ return;
37
+ }
38
+ console.log(`[file-sync:shared] Initializing with ${patterns.length} pattern(s)`);
39
+ this.startPurgeTimer();
40
+ await this.initStartupSync(patterns, this.options.ownerId, "shared");
41
+ this.startFirestoreListener(patterns, this.options.ownerId, "shared");
42
+ this.startFileWatcher(patterns, this.options.ownerId, "shared");
43
+ }
44
+ /**
45
+ * Initialize the private sync channel using a per-user UID.
46
+ */
47
+ async initPrivateSync(userUid) {
48
+ if (this.privateSyncInitialized)
49
+ return;
50
+ this.privateSyncInitialized = true;
51
+ const config = loadSyncConfig(this.options.syncConfigPath);
52
+ const patterns = config.privateSyncFilePatterns;
53
+ if (patterns.length === 0) {
54
+ console.log("[file-sync:private] No privateSyncFilePatterns configured");
55
+ return;
56
+ }
57
+ console.log(`[file-sync:private] Initializing private sync for user ${userUid.slice(0, 8)}...`);
58
+ await this.initStartupSync(patterns, userUid, "private");
59
+ this.startFirestoreListener(patterns, userUid, "private");
60
+ this.startFileWatcher(patterns, userUid, "private");
61
+ }
62
+ // ── Private helpers ─────────────────────────────────────────────────
63
+ emitSyncEvent(event) {
64
+ this.syncEvents.emit("sync", event);
65
+ }
66
+ markRecent(map, filePath) {
67
+ map.set(filePath, Date.now());
68
+ }
69
+ wasRecent(map, filePath) {
70
+ const ts = map.get(filePath);
71
+ if (!ts)
72
+ return false;
73
+ if (Date.now() - ts > TTL_MS) {
74
+ map.delete(filePath);
75
+ return false;
76
+ }
77
+ return true;
78
+ }
79
+ startPurgeTimer() {
80
+ this.purgeTimer = setInterval(() => {
81
+ const now = Date.now();
82
+ for (const [k, v] of this.recentlyPulled) {
83
+ if (now - v > TTL_MS)
84
+ this.recentlyPulled.delete(k);
85
+ }
86
+ for (const [k, v] of this.recentlyPushed) {
87
+ if (now - v > TTL_MS)
88
+ this.recentlyPushed.delete(k);
89
+ }
90
+ }, TTL_MS * 2);
91
+ }
92
+ readLocalFile(absPath) {
93
+ try {
94
+ return fs.readFileSync(absPath, "utf-8");
95
+ }
96
+ catch {
97
+ return null;
98
+ }
99
+ }
100
+ writeSyncedFile(filePath, absPath, content) {
101
+ this.markRecent(this.recentlyPulled, filePath);
102
+ fs.mkdirSync(path.dirname(absPath), { recursive: true });
103
+ fs.writeFileSync(absPath, content, "utf-8");
104
+ this.lastSyncedContent.set(filePath, content);
105
+ }
106
+ docId(filePath) {
107
+ return getDocId(this.options.appId, filePath);
108
+ }
109
+ collection() {
110
+ return this.options.getFileCollection();
111
+ }
112
+ // ── Conflict resolution ─────────────────────────────────────────────
113
+ resolveConflict(filePath, absPath, localContent, remoteContent, ownerId) {
114
+ const base = this.lastSyncedContent.get(filePath);
115
+ if (base !== undefined) {
116
+ const result = threeWayMerge(base, localContent, remoteContent);
117
+ if (result.success && result.merged !== null) {
118
+ this.writeSyncedFile(filePath, absPath, result.merged);
119
+ const now = Date.now();
120
+ this.collection()
121
+ .doc(this.docId(filePath))
122
+ .set({
123
+ path: filePath,
124
+ content: result.merged,
125
+ app: this.options.appId,
126
+ ownerId,
127
+ lastUpdated: now,
128
+ }, { merge: true })
129
+ .then(() => this.markRecent(this.recentlyPushed, filePath))
130
+ .catch((err) => console.error(`[file-sync] Failed to push merged ${filePath}:`, err));
131
+ this.emitSyncEvent({
132
+ type: "conflict-resolved",
133
+ path: filePath,
134
+ strategy: "auto-merge",
135
+ });
136
+ console.log(`[file-sync] auto-merged ${filePath}`);
137
+ return;
138
+ }
139
+ }
140
+ // Auto-merge failed or no base — write .conflict sidecar
141
+ const conflictPath = absPath + ".conflict";
142
+ fs.writeFileSync(conflictPath, remoteContent, "utf-8");
143
+ console.log(`[file-sync] conflict in ${filePath} - wrote ${filePath}.conflict`);
144
+ this.emitSyncEvent({
145
+ type: "conflict-saved",
146
+ path: filePath,
147
+ conflictFile: filePath + ".conflict",
148
+ });
149
+ this.emitSyncEvent({
150
+ type: "conflict-needs-llm",
151
+ path: filePath,
152
+ localSnippet: localContent.slice(0, 500),
153
+ remoteSnippet: remoteContent.slice(0, 500),
154
+ });
155
+ }
156
+ // ── Startup sync ────────────────────────────────────────────────────
157
+ async initStartupSync(patterns, ownerId, label) {
158
+ if (patterns.length === 0)
159
+ return;
160
+ console.log(`[file-sync:${label}] Running full startup sync...`);
161
+ const baseQuery = this.collection()
162
+ .where("app", "==", this.options.appId)
163
+ .where("ownerId", "==", ownerId);
164
+ const snapshot = await baseQuery.get();
165
+ const docsByPath = new Map();
166
+ const orphanedDocIds = [];
167
+ for (const doc of snapshot.docs) {
168
+ const filePath = doc.data().path;
169
+ const canonicalId = this.docId(filePath);
170
+ if (doc.id !== canonicalId) {
171
+ orphanedDocIds.push(doc.id);
172
+ continue;
173
+ }
174
+ docsByPath.set(filePath, doc);
175
+ }
176
+ if (orphanedDocIds.length > 0) {
177
+ console.log(`[file-sync:${label}] Cleaning up ${orphanedDocIds.length} orphaned doc(s)...`);
178
+ for (const id of orphanedDocIds) {
179
+ await this.collection().doc(id).delete().catch(() => { });
180
+ }
181
+ }
182
+ const projectRoot = path.resolve(this.options.contentRoot, "..");
183
+ let syncedCount = 0;
184
+ for (const [filePath, doc] of docsByPath) {
185
+ const data = doc.data();
186
+ if (!shouldSyncFile(filePath, patterns))
187
+ continue;
188
+ const absPath = path.resolve(projectRoot, filePath);
189
+ const firestoreContent = data.content ?? "";
190
+ const localContent = this.readLocalFile(absPath);
191
+ if (localContent === null) {
192
+ this.writeSyncedFile(filePath, absPath, firestoreContent);
193
+ syncedCount++;
194
+ }
195
+ else if (localContent !== firestoreContent) {
196
+ const firestoreMs = data.lastUpdated ?? 0;
197
+ let localMs = 0;
198
+ try {
199
+ localMs = fs.statSync(absPath).mtimeMs;
200
+ }
201
+ catch { }
202
+ if (firestoreMs > localMs) {
203
+ this.writeSyncedFile(filePath, absPath, firestoreContent);
204
+ syncedCount++;
205
+ }
206
+ else {
207
+ const now = Date.now();
208
+ await this.collection()
209
+ .doc(this.docId(filePath))
210
+ .set({
211
+ path: filePath,
212
+ content: localContent,
213
+ app: this.options.appId,
214
+ ownerId,
215
+ lastUpdated: now,
216
+ createdAt: data.createdAt ?? now,
217
+ }, { merge: true });
218
+ this.lastSyncedContent.set(filePath, localContent);
219
+ this.markRecent(this.recentlyPushed, filePath);
220
+ syncedCount++;
221
+ }
222
+ }
223
+ else {
224
+ this.lastSyncedContent.set(filePath, localContent);
225
+ }
226
+ }
227
+ console.log(`[file-sync:${label}] Startup sync complete - ${syncedCount} file(s) synced`);
228
+ }
229
+ // ── Firestore -> disk listener ──────────────────────────────────────
230
+ startFirestoreListener(patterns, ownerId, label) {
231
+ if (patterns.length === 0)
232
+ return;
233
+ console.log(`[file-sync:${label}] Listening for Firestore changes...`);
234
+ const projectRoot = path.resolve(this.options.contentRoot, "..");
235
+ this.collection()
236
+ .where("app", "==", this.options.appId)
237
+ .where("ownerId", "==", ownerId)
238
+ .onSnapshot((snapshot) => {
239
+ for (const change of snapshot.docChanges()) {
240
+ const data = change.doc.data();
241
+ const filePath = data.path;
242
+ if (!shouldSyncFile(filePath, patterns))
243
+ continue;
244
+ if (change.type === "added" || change.type === "modified") {
245
+ if (change.doc.id !== this.docId(filePath))
246
+ continue;
247
+ if (this.wasRecent(this.recentlyPushed, filePath))
248
+ continue;
249
+ const absPath = path.resolve(projectRoot, filePath);
250
+ const incoming = data.content ?? "";
251
+ const local = this.readLocalFile(absPath);
252
+ if (local === incoming) {
253
+ this.lastSyncedContent.set(filePath, incoming);
254
+ continue;
255
+ }
256
+ if (local === null) {
257
+ this.writeSyncedFile(filePath, absPath, incoming);
258
+ continue;
259
+ }
260
+ const lastSynced = this.lastSyncedContent.get(filePath);
261
+ if (lastSynced === undefined || local === lastSynced) {
262
+ this.writeSyncedFile(filePath, absPath, incoming);
263
+ }
264
+ else {
265
+ this.resolveConflict(filePath, absPath, local, incoming, ownerId);
266
+ }
267
+ }
268
+ if (change.type === "removed") {
269
+ const absPath = path.resolve(projectRoot, filePath);
270
+ if (fs.existsSync(absPath)) {
271
+ fs.unlinkSync(absPath);
272
+ this.lastSyncedContent.delete(filePath);
273
+ }
274
+ }
275
+ }
276
+ }, (err) => {
277
+ console.error(`[file-sync:${label}] Firestore listener error:`, err);
278
+ });
279
+ }
280
+ // ── Disk -> Firestore watcher ───────────────────────────────────────
281
+ startFileWatcher(patterns, ownerId, label) {
282
+ if (patterns.length === 0)
283
+ return;
284
+ const projectRoot = path.resolve(this.options.contentRoot, "..");
285
+ console.log(`[file-sync:${label}] Watching local files for changes...`);
286
+ const watcher = watch(this.options.contentRoot, {
287
+ ignoreInitial: true,
288
+ });
289
+ const handleChange = async (absPath) => {
290
+ const relPath = path.relative(projectRoot, absPath);
291
+ if (!shouldSyncFile(relPath, patterns))
292
+ return;
293
+ if (this.wasRecent(this.recentlyPulled, relPath))
294
+ return;
295
+ const content = this.readLocalFile(absPath);
296
+ if (content === null)
297
+ return;
298
+ const docRef = this.collection().doc(this.docId(relPath));
299
+ const existing = await docRef.get();
300
+ if (existing.exists && existing.data()?.content === content)
301
+ return;
302
+ const now = Date.now();
303
+ const payload = {
304
+ path: relPath,
305
+ content,
306
+ app: this.options.appId,
307
+ ownerId,
308
+ lastUpdated: now,
309
+ };
310
+ if (!existing.exists) {
311
+ payload.createdAt = now;
312
+ }
313
+ docRef
314
+ .set(payload, { merge: true })
315
+ .then(() => {
316
+ this.lastSyncedContent.set(relPath, content);
317
+ this.markRecent(this.recentlyPushed, relPath);
318
+ console.log(`[file-sync:${label}] -> pushed ${relPath}`);
319
+ })
320
+ .catch((err) => console.error(`[file-sync:${label}] Failed to push ${relPath}:`, err));
321
+ };
322
+ const handleDelete = (absPath) => {
323
+ const relPath = path.relative(projectRoot, absPath);
324
+ if (!shouldSyncFile(relPath, patterns))
325
+ return;
326
+ this.collection()
327
+ .doc(this.docId(relPath))
328
+ .delete()
329
+ .then(() => {
330
+ this.lastSyncedContent.delete(relPath);
331
+ console.log(`[file-sync:${label}] -> deleted ${relPath}`);
332
+ })
333
+ .catch((err) => console.error(`[file-sync:${label}] Failed to delete ${relPath}:`, err));
334
+ };
335
+ watcher.on("add", handleChange);
336
+ watcher.on("change", handleChange);
337
+ watcher.on("unlink", handleDelete);
338
+ }
339
+ }
340
+ //# sourceMappingURL=sync.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sync.js","sourceRoot":"","sources":["../../../src/adapters/firestore/sync.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Scaffold a new @agent-native/core app from the default template.
3
+ */
4
+ export declare function createApp(name?: string): void;
5
+ //# sourceMappingURL=create.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"create.d.ts","sourceRoot":"","sources":["../../src/cli/create.ts"],"names":[],"mappings":"AAQA;;GAEG;AACH,wBAAgB,SAAS,CAAC,IAAI,CAAC,EAAE,MAAM,GAAG,IAAI,CAmF7C"}
@@ -0,0 +1,87 @@
1
+ import fs from "fs";
2
+ import path from "path";
3
+ import { fileURLToPath } from "url";
4
+ const __filename = fileURLToPath(import.meta.url);
5
+ const __dirname = path.dirname(__filename);
6
+ /**
7
+ * Scaffold a new @agent-native/core app from the default template.
8
+ */
9
+ export function createApp(name) {
10
+ if (!name) {
11
+ console.error("Usage: @agent-native/core create <app-name>");
12
+ process.exit(1);
13
+ }
14
+ // Validate name
15
+ if (!/^[a-z][a-z0-9-]*$/.test(name)) {
16
+ console.error(`Invalid app name "${name}". Use lowercase letters, numbers, and hyphens.`);
17
+ process.exit(1);
18
+ }
19
+ const targetDir = path.resolve(process.cwd(), name);
20
+ if (fs.existsSync(targetDir)) {
21
+ console.error(`Directory "${name}" already exists.`);
22
+ process.exit(1);
23
+ }
24
+ // Locate the template directory
25
+ // In dist: dist/cli/create.js -> ../../src/templates/default
26
+ // Resolve relative to the package root
27
+ const packageRoot = path.resolve(__dirname, "../..");
28
+ const templateDir = path.join(packageRoot, "src/templates/default");
29
+ if (!fs.existsSync(templateDir)) {
30
+ console.error(`Template directory not found at ${templateDir}. Is the package installed correctly?`);
31
+ process.exit(1);
32
+ }
33
+ console.log(`Creating ${name}...`);
34
+ // Copy template
35
+ copyDir(templateDir, targetDir);
36
+ // Replace placeholders in package.json
37
+ const pkgPath = path.join(targetDir, "package.json");
38
+ if (fs.existsSync(pkgPath)) {
39
+ let content = fs.readFileSync(pkgPath, "utf-8");
40
+ content = content.replace(/\{\{APP_NAME\}\}/g, name);
41
+ fs.writeFileSync(pkgPath, content);
42
+ }
43
+ // Replace placeholders in index.html
44
+ const htmlPath = path.join(targetDir, "index.html");
45
+ if (fs.existsSync(htmlPath)) {
46
+ let content = fs.readFileSync(htmlPath, "utf-8");
47
+ content = content.replace(/\{\{APP_TITLE\}\}/g, name
48
+ .split("-")
49
+ .map((w) => w[0].toUpperCase() + w.slice(1))
50
+ .join(" "));
51
+ fs.writeFileSync(htmlPath, content);
52
+ }
53
+ // Replace placeholders in AGENTS.md
54
+ const agentsPath = path.join(targetDir, "AGENTS.md");
55
+ if (fs.existsSync(agentsPath)) {
56
+ let content = fs.readFileSync(agentsPath, "utf-8");
57
+ content = content.replace(/\{\{APP_NAME\}\}/g, name);
58
+ fs.writeFileSync(agentsPath, content);
59
+ }
60
+ // Rename gitignore (npm strips .gitignore from packages)
61
+ const gitignoreSrc = path.join(targetDir, "_gitignore");
62
+ const gitignoreDst = path.join(targetDir, ".gitignore");
63
+ if (fs.existsSync(gitignoreSrc)) {
64
+ fs.renameSync(gitignoreSrc, gitignoreDst);
65
+ }
66
+ console.log(`\nDone! Created ${name} at ${targetDir}\n`);
67
+ console.log(`Next steps:`);
68
+ console.log(` cd ${name}`);
69
+ console.log(` pnpm install`);
70
+ console.log(` pnpm dev`);
71
+ console.log(``);
72
+ console.log(`Your app will be running at http://localhost:8080`);
73
+ }
74
+ function copyDir(src, dest) {
75
+ fs.mkdirSync(dest, { recursive: true });
76
+ for (const entry of fs.readdirSync(src, { withFileTypes: true })) {
77
+ const srcPath = path.join(src, entry.name);
78
+ const destPath = path.join(dest, entry.name);
79
+ if (entry.isDirectory()) {
80
+ copyDir(srcPath, destPath);
81
+ }
82
+ else {
83
+ fs.copyFileSync(srcPath, destPath);
84
+ }
85
+ }
86
+ }
87
+ //# sourceMappingURL=create.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"create.js","sourceRoot":"","sources":["../../src/cli/create.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ #!/usr/bin/env node
2
+ export {};
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/cli/index.ts"],"names":[],"mappings":""}
@@ -0,0 +1,27 @@
1
+ #!/usr/bin/env node
2
+ import { createApp } from "./create.js";
3
+ const command = process.argv[2];
4
+ const args = process.argv.slice(3);
5
+ switch (command) {
6
+ case "create":
7
+ createApp(args[0]);
8
+ break;
9
+ case "--help":
10
+ case "-h":
11
+ case undefined:
12
+ console.log(`agent-native CLI
13
+
14
+ Usage:
15
+ agent-native create <app-name> Scaffold a new agent-native app
16
+ agent-native --help Show this help message
17
+
18
+ Examples:
19
+ npx @agent-native/core create my-app
20
+ agent-native create fusion-analytics`);
21
+ break;
22
+ default:
23
+ console.error(`Unknown command: ${command}`);
24
+ console.error(`Run "agent-native --help" for usage.`);
25
+ process.exit(1);
26
+ }
27
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/cli/index.ts"],"names":[],"mappings":";AAEA,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAExC,MAAM,OAAO,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;AAChC,MAAM,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;AAEnC,QAAQ,OAAO,EAAE,CAAC;IAChB,KAAK,QAAQ;QACX,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;QACnB,MAAM;IACR,KAAK,QAAQ,CAAC;IACd,KAAK,IAAI,CAAC;IACV,KAAK,SAAS;QACZ,OAAO,CAAC,GAAG,CAAC;;;;;;;;uCAQuB,CAAC,CAAC;QACrC,MAAM;IACR;QACE,OAAO,CAAC,KAAK,CAAC,oBAAoB,OAAO,EAAE,CAAC,CAAC;QAC7C,OAAO,CAAC,KAAK,CAAC,sCAAsC,CAAC,CAAC;QACtD,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;AACpB,CAAC"}
@@ -0,0 +1,27 @@
1
+ /**
2
+ * Fusion Chat Bridge (browser)
3
+ *
4
+ * Sends structured messages to the Fusion AI chat from UI interactions.
5
+ * Messages are sent via postMessage to the parent window (or self if top-level).
6
+ */
7
+ export interface FusionChatMessage {
8
+ /** The visible prompt message sent to the chat */
9
+ message: string;
10
+ /** Hidden context appended to the message (not shown in chat UI) */
11
+ context?: string;
12
+ /** true = auto-submit, false = prefill only, omit = use project setting */
13
+ submit?: boolean;
14
+ /** Optional project slug for structured context */
15
+ projectSlug?: string;
16
+ /** Optional preset name for downstream consumers */
17
+ preset?: string;
18
+ /** Optional reference image paths */
19
+ referenceImagePaths?: string[];
20
+ /** Optional uploaded reference images */
21
+ uploadedReferenceImages?: string[];
22
+ }
23
+ /**
24
+ * Send a message to the Fusion AI chat via postMessage.
25
+ */
26
+ export declare function sendToFusionChat(opts: FusionChatMessage): void;
27
+ //# sourceMappingURL=fusion-chat.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"fusion-chat.d.ts","sourceRoot":"","sources":["../../src/client/fusion-chat.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,MAAM,WAAW,iBAAiB;IAChC,kDAAkD;IAClD,OAAO,EAAE,MAAM,CAAC;IAChB,oEAAoE;IACpE,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,2EAA2E;IAC3E,MAAM,CAAC,EAAE,OAAO,CAAC;IACjB,mDAAmD;IACnD,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,oDAAoD;IACpD,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,qCAAqC;IACrC,mBAAmB,CAAC,EAAE,MAAM,EAAE,CAAC;IAC/B,yCAAyC;IACzC,uBAAuB,CAAC,EAAE,MAAM,EAAE,CAAC;CACpC;AAID;;GAEG;AACH,wBAAgB,gBAAgB,CAAC,IAAI,EAAE,iBAAiB,GAAG,IAAI,CAQ9D"}
@@ -0,0 +1,19 @@
1
+ /**
2
+ * Fusion Chat Bridge (browser)
3
+ *
4
+ * Sends structured messages to the Fusion AI chat from UI interactions.
5
+ * Messages are sent via postMessage to the parent window (or self if top-level).
6
+ */
7
+ const FUSION_MESSAGE_TYPE = "builder.submitChat";
8
+ /**
9
+ * Send a message to the Fusion AI chat via postMessage.
10
+ */
11
+ export function sendToFusionChat(opts) {
12
+ const payload = {
13
+ type: FUSION_MESSAGE_TYPE,
14
+ data: opts,
15
+ };
16
+ const target = window.parent !== window ? window.parent : window;
17
+ target.postMessage(payload, "*");
18
+ }
19
+ //# sourceMappingURL=fusion-chat.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"fusion-chat.js","sourceRoot":"","sources":["../../src/client/fusion-chat.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAmBH,MAAM,mBAAmB,GAAG,oBAAoB,CAAC;AAEjD;;GAEG;AACH,MAAM,UAAU,gBAAgB,CAAC,IAAuB;IACtD,MAAM,OAAO,GAAG;QACd,IAAI,EAAE,mBAAmB;QACzB,IAAI,EAAE,IAAI;KACX,CAAC;IAEF,MAAM,MAAM,GAAG,MAAM,CAAC,MAAM,KAAK,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC;IACjE,MAAM,CAAC,WAAW,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC;AACnC,CAAC"}
@@ -0,0 +1,5 @@
1
+ export { sendToFusionChat, type FusionChatMessage } from "./fusion-chat.js";
2
+ export { useFusionChatGenerating } from "./use-fusion-chat.js";
3
+ export { useFileWatcher } from "./use-file-watcher.js";
4
+ export { cn } from "./utils.js";
5
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/client/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,KAAK,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AAC5E,OAAO,EAAE,uBAAuB,EAAE,MAAM,sBAAsB,CAAC;AAC/D,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AACvD,OAAO,EAAE,EAAE,EAAE,MAAM,YAAY,CAAC"}
@@ -0,0 +1,5 @@
1
+ export { sendToFusionChat } from "./fusion-chat.js";
2
+ export { useFusionChatGenerating } from "./use-fusion-chat.js";
3
+ export { useFileWatcher } from "./use-file-watcher.js";
4
+ export { cn } from "./utils.js";
5
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/client/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAA0B,MAAM,kBAAkB,CAAC;AAC5E,OAAO,EAAE,uBAAuB,EAAE,MAAM,sBAAsB,CAAC;AAC/D,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AACvD,OAAO,EAAE,EAAE,EAAE,MAAM,YAAY,CAAC"}
@@ -0,0 +1,23 @@
1
+ interface QueryClient {
2
+ invalidateQueries(opts: {
3
+ queryKey: string[];
4
+ }): void;
5
+ }
6
+ /**
7
+ * Hook that opens an EventSource connection to /api/events and invalidates
8
+ * react-query caches when file changes are detected.
9
+ *
10
+ * @param options.queryClient - The react-query QueryClient instance (from useQueryClient())
11
+ * @param options.queryKeys - Array of query key prefixes to invalidate on change.
12
+ * Default: ["file", "fileTree"]
13
+ * @param options.eventsUrl - SSE endpoint URL. Default: "/api/events"
14
+ * @param options.onEvent - Optional callback for each SSE event
15
+ */
16
+ export declare function useFileWatcher(options?: {
17
+ queryClient?: QueryClient;
18
+ queryKeys?: string[];
19
+ eventsUrl?: string;
20
+ onEvent?: (data: any) => void;
21
+ }): void;
22
+ export {};
23
+ //# sourceMappingURL=use-file-watcher.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-file-watcher.d.ts","sourceRoot":"","sources":["../../src/client/use-file-watcher.ts"],"names":[],"mappings":"AAEA,UAAU,WAAW;IACnB,iBAAiB,CAAC,IAAI,EAAE;QAAE,QAAQ,EAAE,MAAM,EAAE,CAAA;KAAE,GAAG,IAAI,CAAC;CACvD;AAED;;;;;;;;;GASG;AACH,wBAAgB,cAAc,CAAC,OAAO,GAAE;IACtC,WAAW,CAAC,EAAE,WAAW,CAAC;IAC1B,SAAS,CAAC,EAAE,MAAM,EAAE,CAAC;IACrB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,OAAO,CAAC,EAAE,CAAC,IAAI,EAAE,GAAG,KAAK,IAAI,CAAC;CAC1B,GAAG,IAAI,CAgCZ"}