@bravostudioai/react 0.1.32 → 0.1.35

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.
@@ -1,17 +1,17 @@
1
- import { promises as k, existsSync as v } from "fs";
2
- import { join as i, dirname as W } from "path";
3
- import { m as Y } from "../../_virtual/main.js";
4
- import { CONST_APPS_SERVICE_URL as q, CONST_COMPONENTS_CDN_URL as z } from "../../packages/encore-lib/constants.js";
5
- import { findSlidersAndDataBindings as X, findStandaloneComponents as Z, findInputGroups as H, findForms as Q, qualifyFormInputs as ee, findStandaloneSelectInputs as te, findActionButtons as oe, sanitizePropName as A } from "../../codegen/parser.js";
6
- import { generateComponentCode as ne, generateReadme as ae } from "../../codegen/generator.js";
7
- const { writeFile: P, mkdir: G, readFile: R } = k;
8
- Y.config();
9
- const E = process.env.APPS_SERVICE_URL || process.env.VITE_APPS_SERVICE_URL || q;
10
- console.log(`Using APPS_SERVICE_URL: ${E}`);
11
- const se = z;
12
- async function U(o, s) {
1
+ import { promises as z, existsSync as P } from "fs";
2
+ import { join as c, dirname as H } from "path";
3
+ import { m as K } from "../../_virtual/main.js";
4
+ import { CONST_APPS_SERVICE_URL as Q, CONST_COMPONENTS_CDN_URL as X } from "../../packages/encore-lib/constants.js";
5
+ import { findSlidersAndDataBindings as Y, findStandaloneComponents as Z, findInputGroups as I, findForms as ee, qualifyFormInputs as te, findStandaloneSelectInputs as oe, findActionButtons as ne, sanitizePropName as _ } from "../../codegen/parser.js";
6
+ import { generateComponentCode as ae, generateReadme as se } from "../../codegen/generator.js";
7
+ const { writeFile: C, mkdir: L, readFile: N } = z;
8
+ K.config();
9
+ const S = process.env.APPS_SERVICE_URL || process.env.VITE_APPS_SERVICE_URL || Q;
10
+ console.log(`Using APPS_SERVICE_URL: ${S}`);
11
+ const re = X;
12
+ async function O(o, n) {
13
13
  const t = await fetch(o, {
14
- headers: s || {}
14
+ headers: n || {}
15
15
  });
16
16
  if (!t.ok)
17
17
  throw new Error(
@@ -19,255 +19,234 @@ async function U(o, s) {
19
19
  );
20
20
  return await t.text();
21
21
  }
22
- function re(o, s) {
23
- const t = A(o), p = A(s), u = t.charAt(0).toUpperCase() + t.slice(1), f = p.charAt(0).toUpperCase() + p.slice(1);
22
+ function ie(o, n) {
23
+ const t = _(o), i = _(n), a = t.charAt(0).toUpperCase() + t.slice(1), d = i.charAt(0).toUpperCase() + i.slice(1);
24
24
  return {
25
- directoryPath: i(u, f),
26
- componentName: f
25
+ directoryPath: c(a, d),
26
+ componentName: d
27
27
  };
28
28
  }
29
- async function ie(o) {
30
- const s = `${E}/devices/apps/${o}`;
31
- console.log(`Fetching app data from ${s}...`);
29
+ async function ce(o) {
30
+ const n = `${S}/devices/apps/${o}`;
31
+ console.log(`Fetching app data from ${n}...`);
32
32
  try {
33
- const t = await U(s), p = JSON.parse(t);
34
- return { pages: p?.app?.data?.pages || [], appData: p };
33
+ const t = await O(n), i = JSON.parse(t);
34
+ return { pages: i?.app?.data?.pages || [], appData: i };
35
35
  } catch (t) {
36
36
  throw console.error("Failed to fetch app data:", t), t;
37
37
  }
38
38
  }
39
- async function b({
39
+ async function G({
40
40
  appId: o,
41
- pageId: s,
41
+ pageId: n,
42
42
  outputPath: t,
43
- cachedAppData: p,
44
- isProduction: u,
45
- usedNames: f
43
+ cachedAppData: i,
44
+ mode: a = "dynamic",
45
+ usedNames: d
46
46
  }) {
47
- console.log(`Generating wrapper for app: ${o}, page: ${s}`);
48
- let n = t, h = !1;
49
- const l = t.split(".").pop()?.toLowerCase();
50
- if (l !== "tsx" && l !== "ts" && l !== "jsx" && l !== "js") {
47
+ console.log(
48
+ `Generating wrapper for app: ${o}, page: ${n}, mode: ${a}`
49
+ );
50
+ let l = t, m = !1;
51
+ const f = t.split(".").pop()?.toLowerCase();
52
+ if (f !== "tsx" && f !== "ts" && f !== "jsx" && f !== "js") {
51
53
  const { stat: e } = await import("fs/promises");
52
54
  try {
53
- (await e(t)).isDirectory() && (h = !0);
55
+ (await e(t)).isDirectory() && (m = !0);
54
56
  } catch {
55
- (!l || t.endsWith("/")) && (h = !0);
57
+ (!f || t.endsWith("/")) && (m = !0);
56
58
  }
57
59
  }
58
- h && console.log(
60
+ m && console.log(
59
61
  "Output path is a directory, will generate filename from app/page names"
60
62
  ), console.log(`Output path: ${t}`);
61
- const d = i(process.cwd(), ".temp-bravo", o, s);
62
- v(d) || await G(d, { recursive: !0 });
63
- const _ = [
63
+ const g = c(process.cwd(), ".temp-bravo", o, n);
64
+ P(g) || await L(g, { recursive: !0 });
65
+ const T = [
64
66
  {
65
- url: `${E}/devices/apps/${o}`,
67
+ url: `${S}/devices/apps/${o}`,
66
68
  filename: "app.json",
67
69
  skipIfCached: !0
68
70
  },
69
71
  {
70
- url: `${E}/devices/apps/${o}/node/${s}`,
72
+ url: `${S}/devices/apps/${o}/node/${n}`,
71
73
  filename: "page.json"
72
74
  },
73
75
  {
74
- url: `${se}/${o}/draft/components/${s}.js`,
76
+ url: `${re}/${o}/draft/components/${n}.js`,
75
77
  filename: "component.js"
76
78
  }
77
79
  ];
78
- for (const e of _) {
79
- if (e.skipIfCached && p) {
80
+ for (const e of T) {
81
+ if (e.skipIfCached && i) {
80
82
  console.log(`Using cached ${e.filename} (skipping download)`);
81
- const r = i(d, e.filename);
82
- await P(
83
+ const r = c(g, e.filename);
84
+ await C(
83
85
  r,
84
- JSON.stringify(p, null, 2),
86
+ JSON.stringify(i, null, 2),
85
87
  "utf-8"
86
88
  ), console.log(`✓ Saved ${e.filename} from cache`);
87
89
  continue;
88
90
  }
89
91
  try {
90
92
  console.log(`Downloading ${e.filename} from ${e.url}...`);
91
- const r = await U(e.url, e.headers), c = i(d, e.filename);
92
- await P(c, r, "utf-8"), console.log(`✓ Saved ${e.filename}`);
93
+ const r = await O(e.url, e.headers), p = c(g, e.filename);
94
+ await C(p, r, "utf-8"), console.log(`✓ Saved ${e.filename}`);
93
95
  } catch (r) {
94
96
  throw console.error(`✗ Failed to download ${e.filename}:`, r), r;
95
97
  }
96
98
  }
97
- const w = i(d, "page.json"), C = await R(w, "utf-8"), x = JSON.parse(C);
98
- let a = x.data || x;
99
- if (!a.body && !a.data?.body) {
99
+ const V = c(g, "page.json"), k = await N(V, "utf-8"), R = JSON.parse(k);
100
+ let s = R.data || R;
101
+ if (!s.body && !s.data?.body) {
100
102
  console.log("Page data doesn't have body, trying app.json...");
101
103
  try {
102
- let e = p;
104
+ let e = i;
103
105
  if (!e) {
104
- const g = `${E}/devices/apps/${o}`, y = await U(g);
106
+ const h = `${S}/devices/apps/${o}`, y = await O(h);
105
107
  e = JSON.parse(y);
106
108
  }
107
- const c = (e?.app?.data?.pages || []).find((g) => g.id === s);
108
- c && (a = c, console.log("✓ Found page data in app.json"));
109
+ const p = (e?.app?.data?.pages || []).find((h) => h.id === n);
110
+ p && (s = p, console.log("✓ Found page data in app.json"));
109
111
  } catch (e) {
110
112
  console.warn("Could not load app.json:", e);
111
113
  }
112
114
  }
113
- const O = X(a), j = Z(a), D = H(a), $ = Q(a);
114
- ee($);
115
- const F = te(a, $), J = oe(a);
116
- let S = "Encore App", N = "Page";
115
+ const j = Y(s), x = Z(s), v = I(s), $ = ee(s);
116
+ te($);
117
+ const J = oe(s, $), U = ne(s);
118
+ let w = "Encore App", E = "Page";
117
119
  try {
118
- let e = p;
120
+ let e = i;
119
121
  if (!e) {
120
- const r = i(d, "app.json");
121
- if (v(r)) {
122
- const c = await R(r, "utf-8");
123
- e = JSON.parse(c);
122
+ const r = c(g, "app.json");
123
+ if (P(r)) {
124
+ const p = await N(r, "utf-8");
125
+ e = JSON.parse(p);
124
126
  }
125
127
  }
126
- e && (S = e?.app?.store?.name || S);
128
+ e && (w = e?.app?.store?.name || w);
127
129
  } catch {
128
130
  }
129
- N = a.name || a.id || N;
130
- let { directoryPath: L, componentName: m } = re(S, N);
131
- if (f) {
132
- let e = m, r = 2;
133
- for (; f.has(e); )
134
- e = `${m}${r}`, r++;
135
- if (e !== m) {
136
- m = e;
137
- const c = A(S), g = c.charAt(0).toUpperCase() + c.slice(1);
138
- L = i(g, m);
131
+ E = s.name || s.id || E;
132
+ let { directoryPath: D, componentName: u } = ie(w, E);
133
+ if (d) {
134
+ let e = u, r = 2;
135
+ for (; d.has(e); )
136
+ e = `${u}${r}`, r++;
137
+ if (e !== u) {
138
+ u = e;
139
+ const p = _(w), h = p.charAt(0).toUpperCase() + p.slice(1);
140
+ D = c(h, u);
139
141
  }
140
- f.add(m);
142
+ d.add(u);
141
143
  }
142
- const T = L;
143
- if (h)
144
- n = i(t, T);
144
+ const F = D;
145
+ if (m)
146
+ l = c(t, F);
145
147
  else {
146
- const e = W(n);
147
- n = i(e, T);
148
+ const e = H(l);
149
+ l = c(e, F);
148
150
  }
149
- const K = ne(
151
+ const M = a === "production" || a === "optimistic", b = ae(
150
152
  o,
151
- s,
152
- m,
153
- O,
153
+ n,
154
+ u,
154
155
  j,
155
- D,
156
+ x,
157
+ v,
156
158
  $,
157
- F,
158
159
  J,
159
- !!u,
160
+ U,
161
+ a,
160
162
  {
161
- width: a.style?.width,
162
- height: a.style?.height,
163
- aspectRatio: a.style?.width && a.style?.height ? a.style.width / a.style.height : void 0
163
+ width: s.style?.width,
164
+ height: s.style?.height,
165
+ aspectRatio: s.style?.width && s.style?.height ? s.style.width / s.style.height : void 0
164
166
  }
165
- ), V = ae(
167
+ ), B = se(
166
168
  o,
167
- s,
168
- S,
169
- N,
170
- m,
171
- O,
169
+ n,
170
+ w,
171
+ E,
172
+ u,
172
173
  j,
173
- D,
174
+ x,
175
+ v,
174
176
  $,
175
- F,
176
- J
177
+ J,
178
+ U
177
179
  );
178
- if (v(n) || await G(n, { recursive: !0 }), u) {
179
- const e = i(d, "component.js");
180
+ if (P(l) || await L(l, { recursive: !0 }), M) {
181
+ const e = c(g, "component.js");
180
182
  let r = "";
181
183
  try {
182
- r = await R(e, "utf-8");
184
+ r = await N(e, "utf-8");
183
185
  } catch {
184
186
  }
185
- let c = p;
186
- if (!c)
187
+ let p = i;
188
+ if (!p)
187
189
  try {
188
- const y = i(d, "app.json"), M = await R(y, "utf-8");
189
- c = JSON.parse(M);
190
+ const y = c(g, "app.json"), W = await N(y, "utf-8");
191
+ p = JSON.parse(W);
190
192
  } catch {
191
193
  }
192
- const g = {
193
- app: c,
194
- page: a,
194
+ const h = {
195
+ app: p,
196
+ page: s,
195
197
  componentCode: r
196
198
  };
197
- await P(
198
- i(n, "data.json"),
199
- JSON.stringify(g, null, 2),
199
+ await C(
200
+ c(l, "data.json"),
201
+ JSON.stringify(h, null, 2),
200
202
  "utf-8"
201
203
  );
202
204
  }
203
- const I = i(n, "index.tsx"), B = i(n, "README.md");
204
- await P(I, K, "utf-8"), await P(B, V, "utf-8"), console.log(`✓ Generated wrapper component at: ${I}`);
205
+ const A = c(l, "index.tsx"), q = c(l, "README.md");
206
+ await C(A, b, "utf-8"), await C(q, B, "utf-8"), console.log(`✓ Generated wrapper component at: ${A}`);
205
207
  }
206
- function pe() {
207
- console.log(`
208
- Usage: generate-wrapper.ts <appId> [pageId] <outputPath>
209
-
210
- Arguments:
211
- appId The Encore app ID
212
- pageId The Encore page ID (optional - if omitted, generates wrappers for ALL pages)
213
- outputPath Path where the generated TSX file(s) should be saved
214
- --production Generate for production (bundles data)
215
- --preseed Alias for --production (bundles data)
216
-
217
- Environment variables:
218
- APPS_SERVICE_URL Base URL for the apps service
219
-
220
- Example:
221
- generate-wrapper.ts 01KA964B1T6KCKSKCNMYSTKRKZ 01KA964B2F42MN4WGCYDTG1Y70 ./src/components/MyEncoreApp.tsx
222
- `);
223
- }
224
- async function ge(o) {
225
- const s = o.includes("--production") || o.includes("--preseed"), t = o.filter(
226
- (n) => n !== "--production" && n !== "--preseed"
227
- );
228
- if ((t.length < 2 || t.includes("--help") || t.includes("-h")) && (pe(), process.exit(
229
- t.includes("--help") || t.includes("-h") ? 0 : 1
230
- )), t.length === 2) {
231
- const [n, h] = t;
208
+ async function ue(o, n, t, i) {
209
+ if ((!o || !n && !t) && (console.error(
210
+ "Error: Missing required arguments. Usage: generate <appId> [pageId] <outputPath>"
211
+ ), process.exit(1)), t || (console.error("Error: Missing output path."), process.exit(1)), !n) {
232
212
  try {
233
- const { pages: l, appData: d } = await ie(n);
234
- if (l.length === 0) {
213
+ const { pages: a, appData: d } = await ce(o);
214
+ if (a.length === 0) {
235
215
  console.warn("No pages found for this app.");
236
216
  return;
237
217
  }
238
- const _ = /* @__PURE__ */ new Set();
239
- for (const w of l)
240
- if (w.id)
218
+ const l = /* @__PURE__ */ new Set();
219
+ for (const m of a)
220
+ if (m.id)
241
221
  try {
242
- await b({
243
- appId: n,
244
- pageId: w.id,
245
- outputPath: h,
222
+ await G({
223
+ appId: o,
224
+ pageId: m.id,
225
+ outputPath: t,
246
226
  cachedAppData: d,
247
- isProduction: s,
248
- usedNames: _
227
+ mode: i,
228
+ usedNames: l
249
229
  });
250
- } catch (C) {
230
+ } catch (f) {
251
231
  console.warn(
252
- `Error with page ${w.id}:`,
253
- C instanceof Error ? C.message : C
232
+ `Error with page ${m.id}:`,
233
+ f instanceof Error ? f.message : f
254
234
  );
255
235
  }
256
- } catch (l) {
236
+ } catch (a) {
257
237
  console.error(`
258
- Error:`, l instanceof Error ? l.message : l), process.exit(1);
238
+ Error:`, a instanceof Error ? a.message : a), process.exit(1);
259
239
  }
260
240
  return;
261
241
  }
262
- const [p, u, f] = t;
263
242
  try {
264
- await b({ appId: p, pageId: u, outputPath: f, isProduction: s });
265
- } catch (n) {
243
+ await G({ appId: o, pageId: n, outputPath: t, mode: i });
244
+ } catch (a) {
266
245
  console.error(`
267
- Error:`, n instanceof Error ? n.message : n), process.exit(1);
246
+ Error:`, a instanceof Error ? a.message : a), process.exit(1);
268
247
  }
269
248
  }
270
249
  export {
271
- ge as runGenerate
250
+ ue as runGenerate
272
251
  };
273
252
  //# sourceMappingURL=generate.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"generate.js","sources":["../../../src/cli/commands/generate.ts"],"sourcesContent":["import { promises as fs } from \"fs\";\nimport { join, dirname } from \"path\";\nimport { existsSync } from \"fs\";\nimport * as dotenv from \"dotenv\";\nimport {\n CONST_APPS_SERVICE_URL,\n CONST_COMPONENTS_CDN_URL,\n} from \"../../../constants\";\nimport {\n findSlidersAndDataBindings,\n findStandaloneComponents,\n findInputGroups,\n findForms,\n findStandaloneSelectInputs,\n findActionButtons,\n qualifyFormInputs,\n generateComponentCode,\n generateReadme,\n sanitizePropName,\n} from \"../../codegen\";\n\nconst { writeFile, mkdir, readFile } = fs;\n\ndotenv.config();\n\n// Default apps service URL (can be overridden with APPS_SERVICE_URL env var)\nconst APPS_SERVICE_URL =\n process.env.APPS_SERVICE_URL ||\n process.env.VITE_APPS_SERVICE_URL ||\n CONST_APPS_SERVICE_URL;\nconsole.log(`Using APPS_SERVICE_URL: ${APPS_SERVICE_URL}`);\nconst COMPONENTS_CDN_URL = CONST_COMPONENTS_CDN_URL;\n\nasync function downloadFile(\n url: string,\n headers?: Record<string, string>\n): Promise<string> {\n const response = await fetch(url, {\n headers: headers || {},\n });\n\n if (!response.ok) {\n throw new Error(\n `Failed to download ${url}: ${response.status} ${response.statusText}`\n );\n }\n\n return await response.text();\n}\n\nfunction generateNames(\n appName: string,\n pageName: string\n): { directoryPath: string; componentName: string } {\n const appCamel = sanitizePropName(appName);\n const pageCamel = sanitizePropName(pageName);\n // Capitalize first letter for PascalCase\n const appPascal = appCamel.charAt(0).toUpperCase() + appCamel.slice(1);\n const pagePascal = pageCamel.charAt(0).toUpperCase() + pageCamel.slice(1);\n return {\n directoryPath: join(appPascal, pagePascal),\n componentName: pagePascal,\n };\n}\n\nasync function getAppPages(\n appId: string\n): Promise<{ pages: any[]; appData: any }> {\n const url = `${APPS_SERVICE_URL}/devices/apps/${appId}`;\n console.log(`Fetching app data from ${url}...`);\n try {\n const content = await downloadFile(url);\n const appData = JSON.parse(content);\n const pages = appData?.app?.data?.pages || [];\n return { pages, appData };\n } catch (error) {\n console.error(\"Failed to fetch app data:\", error);\n throw error;\n }\n}\n\nasync function generateWrapper({\n appId,\n pageId,\n outputPath,\n cachedAppData,\n isProduction,\n usedNames,\n}: {\n appId: string;\n pageId: string;\n outputPath: string;\n cachedAppData?: any;\n isProduction?: boolean;\n usedNames?: Set<string>;\n}) {\n console.log(`Generating wrapper for app: ${appId}, page: ${pageId}`);\n\n // Determine final output path - we'll update it after we get app/page names\n let finalOutputPath = outputPath;\n let needsFilenameGeneration = false;\n const pathExt = outputPath.split(\".\").pop()?.toLowerCase();\n if (\n pathExt !== \"tsx\" &&\n pathExt !== \"ts\" &&\n pathExt !== \"jsx\" &&\n pathExt !== \"js\"\n ) {\n // Path doesn't have a file extension, treat as directory\n const { stat } = await import(\"fs/promises\");\n try {\n const pathStats = await stat(outputPath);\n if (pathStats.isDirectory()) {\n needsFilenameGeneration = true;\n }\n } catch {\n // Path doesn't exist, check if it looks like a directory (no extension)\n if (!pathExt || outputPath.endsWith(\"/\")) {\n needsFilenameGeneration = true;\n }\n }\n }\n\n if (needsFilenameGeneration) {\n console.log(\n `Output path is a directory, will generate filename from app/page names`\n );\n }\n\n console.log(`Output path: ${outputPath}`);\n\n // Create temp directory for downloaded files\n const tempDir = join(process.cwd(), \".temp-bravo\", appId, pageId);\n if (!existsSync(tempDir)) {\n await mkdir(tempDir, { recursive: true });\n }\n\n // Download files (skip app.json if we have cached data)\n const files: Array<{\n url: string;\n filename: string;\n headers?: Record<string, string>;\n skipIfCached?: boolean;\n }> = [\n {\n url: `${APPS_SERVICE_URL}/devices/apps/${appId}`,\n filename: \"app.json\",\n skipIfCached: true,\n },\n {\n url: `${APPS_SERVICE_URL}/devices/apps/${appId}/node/${pageId}`,\n filename: \"page.json\",\n },\n {\n url: `${COMPONENTS_CDN_URL}/${appId}/draft/components/${pageId}.js`,\n filename: \"component.js\",\n },\n ];\n\n for (const file of files) {\n // Skip app.json if we have cached data\n if (file.skipIfCached && cachedAppData) {\n console.log(`Using cached ${file.filename} (skipping download)`);\n const filePath = join(tempDir, file.filename);\n await writeFile(\n filePath,\n JSON.stringify(cachedAppData, null, 2),\n \"utf-8\"\n );\n console.log(`✓ Saved ${file.filename} from cache`);\n continue;\n }\n\n try {\n console.log(`Downloading ${file.filename} from ${file.url}...`);\n const content = await downloadFile(file.url, file.headers);\n const filePath = join(tempDir, file.filename);\n await writeFile(filePath, content, \"utf-8\");\n console.log(`✓ Saved ${file.filename}`);\n } catch (error) {\n console.error(`✗ Failed to download ${file.filename}:`, error);\n throw error;\n }\n }\n\n // Read and parse page.json\n const pageJsonPath = join(tempDir, \"page.json\");\n const pageJsonContent = await readFile(pageJsonPath, \"utf-8\");\n const pageResponse = JSON.parse(pageJsonContent);\n\n // Extract page data - API response has it under 'data' field\n let pageData = pageResponse.data || pageResponse;\n\n // If pageData doesn't have body, try using cached app.json or downloading as fallback\n if (!pageData.body && !(pageData as any).data?.body) {\n console.log(\"Page data doesn't have body, trying app.json...\");\n try {\n let appData = cachedAppData;\n\n // If we don't have cached data, download it\n if (!appData) {\n const appUrl = `${APPS_SERVICE_URL}/devices/apps/${appId}`;\n const appContent = await downloadFile(appUrl);\n appData = JSON.parse(appContent);\n }\n\n // Find the page in app.data.pages\n const pages = appData?.app?.data?.pages || [];\n const page = pages.find((p: any) => p.id === pageId);\n if (page) {\n pageData = page;\n console.log(\"✓ Found page data in app.json\");\n }\n } catch (error) {\n console.warn(\"Could not load app.json:\", error);\n }\n }\n\n // Find components using extracted logic\n const sliders = findSlidersAndDataBindings(pageData);\n const standaloneComponents = findStandaloneComponents(pageData);\n const inputGroups = findInputGroups(pageData);\n const forms = findForms(pageData);\n\n // Qualify form input prop names\n qualifyFormInputs(forms);\n\n const selectInputs = findStandaloneSelectInputs(pageData, forms);\n const actionButtons = findActionButtons(pageData);\n\n // Extract app name and page name\n let appName = \"Encore App\";\n let pageName = \"Page\";\n\n try {\n let appDataForName = cachedAppData;\n if (!appDataForName) {\n const appJsonPath = join(tempDir, \"app.json\");\n if (existsSync(appJsonPath)) {\n const appJsonContent = await readFile(appJsonPath, \"utf-8\");\n appDataForName = JSON.parse(appJsonContent);\n }\n }\n if (appDataForName) {\n appName = appDataForName?.app?.store?.name || appName;\n }\n } catch (error) {\n // Ignore errors, use defaults\n }\n\n pageName = pageData.name || pageData.id || pageName;\n\n // Generate component name and directory name\n let { directoryPath, componentName } = generateNames(appName, pageName);\n\n // Ensure unique component name\n if (usedNames) {\n let uniqueName = componentName;\n let counter = 2;\n while (usedNames.has(uniqueName)) {\n uniqueName = `${componentName}${counter}`;\n counter++;\n }\n if (uniqueName !== componentName) {\n componentName = uniqueName;\n // Reconstitute directory path with new component name\n // generateNames uses: join(appPascal, pagePascal) where pagePascal is componentName\n const appCamel = sanitizePropName(appName);\n const appPascal = appCamel.charAt(0).toUpperCase() + appCamel.slice(1);\n directoryPath = join(appPascal, componentName);\n }\n usedNames.add(componentName);\n }\n\n const directoryName = directoryPath;\n\n // Update output path\n if (needsFilenameGeneration) {\n finalOutputPath = join(outputPath, directoryName);\n } else {\n const providedDir = dirname(finalOutputPath);\n finalOutputPath = join(providedDir, directoryName);\n }\n\n // Generate component code and README\n const componentCode = generateComponentCode(\n appId,\n pageId,\n componentName,\n sliders,\n standaloneComponents,\n inputGroups,\n forms,\n selectInputs,\n actionButtons,\n !!isProduction,\n {\n width: pageData.style?.width,\n height: pageData.style?.height,\n aspectRatio:\n pageData.style?.width && pageData.style?.height\n ? pageData.style.width / pageData.style.height\n : undefined,\n }\n );\n\n const readmeContent = generateReadme(\n appId,\n pageId,\n appName,\n pageName,\n componentName,\n sliders,\n standaloneComponents,\n inputGroups,\n forms,\n selectInputs,\n actionButtons\n );\n\n // Ensure output directory exists\n if (!existsSync(finalOutputPath)) {\n await mkdir(finalOutputPath, { recursive: true });\n }\n\n // Write files\n if (isProduction) {\n const componentJsPath = join(tempDir, \"component.js\");\n let componentCodeContent = \"\";\n try {\n componentCodeContent = await readFile(componentJsPath, \"utf-8\");\n } catch (e) {}\n\n let appDataForProd = cachedAppData;\n if (!appDataForProd) {\n try {\n const appJsonPath = join(tempDir, \"app.json\");\n const appJsonContent = await readFile(appJsonPath, \"utf-8\");\n appDataForProd = JSON.parse(appJsonContent);\n } catch (e) {}\n }\n\n const productionData = {\n app: appDataForProd,\n page: pageData,\n componentCode: componentCodeContent,\n };\n await writeFile(\n join(finalOutputPath, \"data.json\"),\n JSON.stringify(productionData, null, 2),\n \"utf-8\"\n );\n }\n\n const indexPath = join(finalOutputPath, \"index.tsx\");\n const readmePath = join(finalOutputPath, \"README.md\");\n\n await writeFile(indexPath, componentCode, \"utf-8\");\n await writeFile(readmePath, readmeContent, \"utf-8\");\n\n console.log(`✓ Generated wrapper component at: ${indexPath}`);\n}\n\nfunction printUsage() {\n console.log(`\nUsage: generate-wrapper.ts <appId> [pageId] <outputPath>\n\nArguments:\n appId The Encore app ID\n pageId The Encore page ID (optional - if omitted, generates wrappers for ALL pages)\n outputPath Path where the generated TSX file(s) should be saved\n --production Generate for production (bundles data)\n --preseed Alias for --production (bundles data)\n\nEnvironment variables:\n APPS_SERVICE_URL Base URL for the apps service\n\nExample:\n generate-wrapper.ts 01KA964B1T6KCKSKCNMYSTKRKZ 01KA964B2F42MN4WGCYDTG1Y70 ./src/components/MyEncoreApp.tsx\n`);\n}\n\nexport async function runGenerate(args: string[]) {\n const isProduction =\n args.includes(\"--production\") || args.includes(\"--preseed\");\n const cleanArgs = args.filter(\n (arg) => arg !== \"--production\" && arg !== \"--preseed\"\n );\n\n if (\n cleanArgs.length < 2 ||\n cleanArgs.includes(\"--help\") ||\n cleanArgs.includes(\"-h\")\n ) {\n printUsage();\n process.exit(\n cleanArgs.includes(\"--help\") || cleanArgs.includes(\"-h\") ? 0 : 1\n );\n }\n\n if (cleanArgs.length === 2) {\n const [appId, outputPath] = cleanArgs;\n\n try {\n const { pages, appData } = await getAppPages(appId);\n if (pages.length === 0) {\n console.warn(\"No pages found for this app.\");\n return;\n }\n\n const usedNames = new Set<string>();\n for (const page of pages) {\n if (!page.id) continue;\n try {\n await generateWrapper({\n appId,\n pageId: page.id,\n outputPath,\n cachedAppData: appData,\n isProduction,\n usedNames,\n });\n } catch (error) {\n console.warn(\n `Error with page ${page.id}:`,\n error instanceof Error ? error.message : error\n );\n }\n }\n } catch (error) {\n console.error(\"\\nError:\", error instanceof Error ? error.message : error);\n process.exit(1);\n }\n return;\n }\n\n const [appId, pageId, outputPath] = cleanArgs;\n\n try {\n await generateWrapper({ appId, pageId, outputPath, isProduction }); // Single page generation, no collision context needed unless we wanted global uniqueness but usually used for one-off\n } catch (error) {\n console.error(\"\\nError:\", error instanceof Error ? error.message : error);\n process.exit(1);\n }\n}\n"],"names":["writeFile","mkdir","readFile","fs","dotenv.config","APPS_SERVICE_URL","CONST_APPS_SERVICE_URL","COMPONENTS_CDN_URL","CONST_COMPONENTS_CDN_URL","downloadFile","url","headers","response","generateNames","appName","pageName","appCamel","sanitizePropName","pageCamel","appPascal","pagePascal","join","getAppPages","appId","content","appData","error","generateWrapper","pageId","outputPath","cachedAppData","isProduction","usedNames","finalOutputPath","needsFilenameGeneration","pathExt","stat","tempDir","existsSync","files","file","filePath","pageJsonPath","pageJsonContent","pageResponse","pageData","appUrl","appContent","page","p","sliders","findSlidersAndDataBindings","standaloneComponents","findStandaloneComponents","inputGroups","findInputGroups","forms","findForms","qualifyFormInputs","selectInputs","findStandaloneSelectInputs","actionButtons","findActionButtons","appDataForName","appJsonPath","appJsonContent","directoryPath","componentName","uniqueName","counter","directoryName","providedDir","dirname","componentCode","generateComponentCode","readmeContent","generateReadme","componentJsPath","componentCodeContent","appDataForProd","productionData","indexPath","readmePath","printUsage","runGenerate","args","cleanArgs","arg","pages"],"mappings":"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"}
1
+ {"version":3,"file":"generate.js","sources":["../../../src/cli/commands/generate.ts"],"sourcesContent":["import { promises as fs } from \"fs\";\nimport { join, dirname } from \"path\";\nimport { existsSync } from \"fs\";\nimport * as dotenv from \"dotenv\";\nimport {\n CONST_APPS_SERVICE_URL,\n CONST_COMPONENTS_CDN_URL,\n} from \"../../../constants\";\nimport {\n findSlidersAndDataBindings,\n findStandaloneComponents,\n findInputGroups,\n findForms,\n findStandaloneSelectInputs,\n findActionButtons,\n qualifyFormInputs,\n generateComponentCode,\n generateReadme,\n sanitizePropName,\n} from \"../../codegen\";\n\nconst { writeFile, mkdir, readFile } = fs;\n\ndotenv.config();\n\n// Default apps service URL (can be overridden with APPS_SERVICE_URL env var)\nconst APPS_SERVICE_URL =\n process.env.APPS_SERVICE_URL ||\n process.env.VITE_APPS_SERVICE_URL ||\n CONST_APPS_SERVICE_URL;\nconsole.log(`Using APPS_SERVICE_URL: ${APPS_SERVICE_URL}`);\nconst COMPONENTS_CDN_URL = CONST_COMPONENTS_CDN_URL;\n\nasync function downloadFile(\n url: string,\n headers?: Record<string, string>\n): Promise<string> {\n const response = await fetch(url, {\n headers: headers || {},\n });\n\n if (!response.ok) {\n throw new Error(\n `Failed to download ${url}: ${response.status} ${response.statusText}`\n );\n }\n\n return await response.text();\n}\n\nfunction generateNames(\n appName: string,\n pageName: string\n): { directoryPath: string; componentName: string } {\n const appCamel = sanitizePropName(appName);\n const pageCamel = sanitizePropName(pageName);\n // Capitalize first letter for PascalCase\n const appPascal = appCamel.charAt(0).toUpperCase() + appCamel.slice(1);\n const pagePascal = pageCamel.charAt(0).toUpperCase() + pageCamel.slice(1);\n return {\n directoryPath: join(appPascal, pagePascal),\n componentName: pagePascal,\n };\n}\n\nasync function getAppPages(\n appId: string\n): Promise<{ pages: any[]; appData: any }> {\n const url = `${APPS_SERVICE_URL}/devices/apps/${appId}`;\n console.log(`Fetching app data from ${url}...`);\n try {\n const content = await downloadFile(url);\n const appData = JSON.parse(content);\n const pages = appData?.app?.data?.pages || [];\n return { pages, appData };\n } catch (error) {\n console.error(\"Failed to fetch app data:\", error);\n throw error;\n }\n}\n\nasync function generateWrapper({\n appId,\n pageId,\n outputPath,\n cachedAppData,\n mode = \"dynamic\",\n usedNames,\n}: {\n appId: string;\n pageId: string;\n outputPath: string;\n cachedAppData?: any;\n mode?: string;\n usedNames?: Set<string>;\n}) {\n console.log(\n `Generating wrapper for app: ${appId}, page: ${pageId}, mode: ${mode}`\n );\n\n // Determine final output path - we'll update it after we get app/page names\n let finalOutputPath = outputPath;\n let needsFilenameGeneration = false;\n const pathExt = outputPath.split(\".\").pop()?.toLowerCase();\n if (\n pathExt !== \"tsx\" &&\n pathExt !== \"ts\" &&\n pathExt !== \"jsx\" &&\n pathExt !== \"js\"\n ) {\n // Path doesn't have a file extension, treat as directory\n const { stat } = await import(\"fs/promises\");\n try {\n const pathStats = await stat(outputPath);\n if (pathStats.isDirectory()) {\n needsFilenameGeneration = true;\n }\n } catch {\n // Path doesn't exist, check if it looks like a directory (no extension)\n if (!pathExt || outputPath.endsWith(\"/\")) {\n needsFilenameGeneration = true;\n }\n }\n }\n\n if (needsFilenameGeneration) {\n console.log(\n `Output path is a directory, will generate filename from app/page names`\n );\n }\n\n console.log(`Output path: ${outputPath}`);\n\n // Create temp directory for downloaded files\n const tempDir = join(process.cwd(), \".temp-bravo\", appId, pageId);\n if (!existsSync(tempDir)) {\n await mkdir(tempDir, { recursive: true });\n }\n\n // Download files (skip app.json if we have cached data)\n const files: Array<{\n url: string;\n filename: string;\n headers?: Record<string, string>;\n skipIfCached?: boolean;\n }> = [\n {\n url: `${APPS_SERVICE_URL}/devices/apps/${appId}`,\n filename: \"app.json\",\n skipIfCached: true,\n },\n {\n url: `${APPS_SERVICE_URL}/devices/apps/${appId}/node/${pageId}`,\n filename: \"page.json\",\n },\n {\n url: `${COMPONENTS_CDN_URL}/${appId}/draft/components/${pageId}.js`,\n filename: \"component.js\",\n },\n ];\n\n for (const file of files) {\n // Skip app.json if we have cached data\n if (file.skipIfCached && cachedAppData) {\n console.log(`Using cached ${file.filename} (skipping download)`);\n const filePath = join(tempDir, file.filename);\n await writeFile(\n filePath,\n JSON.stringify(cachedAppData, null, 2),\n \"utf-8\"\n );\n console.log(`✓ Saved ${file.filename} from cache`);\n continue;\n }\n\n try {\n console.log(`Downloading ${file.filename} from ${file.url}...`);\n const content = await downloadFile(file.url, file.headers);\n const filePath = join(tempDir, file.filename);\n await writeFile(filePath, content, \"utf-8\");\n console.log(`✓ Saved ${file.filename}`);\n } catch (error) {\n console.error(`✗ Failed to download ${file.filename}:`, error);\n throw error;\n }\n }\n\n // Read and parse page.json\n const pageJsonPath = join(tempDir, \"page.json\");\n const pageJsonContent = await readFile(pageJsonPath, \"utf-8\");\n const pageResponse = JSON.parse(pageJsonContent);\n\n // Extract page data - API response has it under 'data' field\n let pageData = pageResponse.data || pageResponse;\n\n // If pageData doesn't have body, try using cached app.json or downloading as fallback\n if (!pageData.body && !(pageData as any).data?.body) {\n console.log(\"Page data doesn't have body, trying app.json...\");\n try {\n let appData = cachedAppData;\n\n // If we don't have cached data, download it\n if (!appData) {\n const appUrl = `${APPS_SERVICE_URL}/devices/apps/${appId}`;\n const appContent = await downloadFile(appUrl);\n appData = JSON.parse(appContent);\n }\n\n // Find the page in app.data.pages\n const pages = appData?.app?.data?.pages || [];\n const page = pages.find((p: any) => p.id === pageId);\n if (page) {\n pageData = page;\n console.log(\"✓ Found page data in app.json\");\n }\n } catch (error) {\n console.warn(\"Could not load app.json:\", error);\n }\n }\n\n // Find components using extracted logic\n const sliders = findSlidersAndDataBindings(pageData);\n const standaloneComponents = findStandaloneComponents(pageData);\n const inputGroups = findInputGroups(pageData);\n const forms = findForms(pageData);\n\n // Qualify form input prop names\n qualifyFormInputs(forms);\n\n const selectInputs = findStandaloneSelectInputs(pageData, forms);\n const actionButtons = findActionButtons(pageData);\n\n // Extract app name and page name\n let appName = \"Encore App\";\n let pageName = \"Page\";\n\n try {\n let appDataForName = cachedAppData;\n if (!appDataForName) {\n const appJsonPath = join(tempDir, \"app.json\");\n if (existsSync(appJsonPath)) {\n const appJsonContent = await readFile(appJsonPath, \"utf-8\");\n appDataForName = JSON.parse(appJsonContent);\n }\n }\n if (appDataForName) {\n appName = appDataForName?.app?.store?.name || appName;\n }\n } catch (error) {\n // Ignore errors, use defaults\n }\n\n pageName = pageData.name || pageData.id || pageName;\n\n // Generate component name and directory name\n let { directoryPath, componentName } = generateNames(appName, pageName);\n\n // Ensure unique component name\n if (usedNames) {\n let uniqueName = componentName;\n let counter = 2;\n while (usedNames.has(uniqueName)) {\n uniqueName = `${componentName}${counter}`;\n counter++;\n }\n if (uniqueName !== componentName) {\n componentName = uniqueName;\n // Reconstitute directory path with new component name\n // generateNames uses: join(appPascal, pagePascal) where pagePascal is componentName\n const appCamel = sanitizePropName(appName);\n const appPascal = appCamel.charAt(0).toUpperCase() + appCamel.slice(1);\n directoryPath = join(appPascal, componentName);\n }\n usedNames.add(componentName);\n }\n\n const directoryName = directoryPath;\n\n // Update output path\n if (needsFilenameGeneration) {\n finalOutputPath = join(outputPath, directoryName);\n } else {\n const providedDir = dirname(finalOutputPath);\n finalOutputPath = join(providedDir, directoryName);\n }\n\n // Generate component code and README\n const shouldBundleData = mode === \"production\" || mode === \"optimistic\";\n const componentCode = generateComponentCode(\n appId,\n pageId,\n componentName,\n sliders,\n standaloneComponents,\n inputGroups,\n forms,\n selectInputs,\n actionButtons,\n mode,\n {\n width: pageData.style?.width,\n height: pageData.style?.height,\n aspectRatio:\n pageData.style?.width && pageData.style?.height\n ? pageData.style.width / pageData.style.height\n : undefined,\n }\n );\n\n const readmeContent = generateReadme(\n appId,\n pageId,\n appName,\n pageName,\n componentName,\n sliders,\n standaloneComponents,\n inputGroups,\n forms,\n selectInputs,\n actionButtons\n );\n\n // Ensure output directory exists\n if (!existsSync(finalOutputPath)) {\n await mkdir(finalOutputPath, { recursive: true });\n }\n\n // Write files\n if (shouldBundleData) {\n const componentJsPath = join(tempDir, \"component.js\");\n let componentCodeContent = \"\";\n try {\n componentCodeContent = await readFile(componentJsPath, \"utf-8\");\n } catch (e) {}\n\n let appDataForProd = cachedAppData;\n if (!appDataForProd) {\n try {\n const appJsonPath = join(tempDir, \"app.json\");\n const appJsonContent = await readFile(appJsonPath, \"utf-8\");\n appDataForProd = JSON.parse(appJsonContent);\n } catch (e) {}\n }\n\n const productionData = {\n app: appDataForProd,\n page: pageData,\n componentCode: componentCodeContent,\n };\n await writeFile(\n join(finalOutputPath, \"data.json\"),\n JSON.stringify(productionData, null, 2),\n \"utf-8\"\n );\n }\n\n const indexPath = join(finalOutputPath, \"index.tsx\");\n const readmePath = join(finalOutputPath, \"README.md\");\n\n await writeFile(indexPath, componentCode, \"utf-8\");\n await writeFile(readmePath, readmeContent, \"utf-8\");\n\n console.log(`✓ Generated wrapper component at: ${indexPath}`);\n}\n\nexport async function runGenerate(\n appId: string,\n pageId: string | undefined,\n outputPath: string | undefined,\n mode: string\n) {\n if (!appId || (!pageId && !outputPath)) {\n console.error(\n \"Error: Missing required arguments. Usage: generate <appId> [pageId] <outputPath>\"\n );\n process.exit(1);\n }\n\n // If outputPath is missing but we have 2 args logic from caller, handle it.\n // actually caller logic:\n // if 2 args (appId, pageId/output), caller puts output in output and pageId=undefined.\n // so if we are here, we have appId and outputPath. pageId might be undefined.\n\n // Wait, if I changed the caller to pass (appId, undefined, outputPath), I need to be sure.\n // arguments: appId, pageId, outputPath.\n // If user ran: generate app out\n // caller: appId=app, pageId=out, output=undefined.\n // caller logic: if (pageId && !output) -> output=pageId, pageId=undefined.\n // caller calls: runGenerate(app, undefined, out, prod).\n\n // If user ran: generate app page out\n // caller: appId=app, pageId=page, output=out.\n // caller calls: runGenerate(app, page, out, prod).\n\n // So outputPath MUST be defined here effectively if the CLI usage was correct.\n if (!outputPath) {\n console.error(\"Error: Missing output path.\");\n process.exit(1);\n }\n\n // Default mode: Generate all pages\n if (!pageId) {\n try {\n const { pages, appData } = await getAppPages(appId);\n if (pages.length === 0) {\n console.warn(\"No pages found for this app.\");\n return;\n }\n\n const usedNames = new Set<string>();\n for (const page of pages) {\n if (!page.id) continue;\n try {\n await generateWrapper({\n appId,\n pageId: page.id,\n outputPath,\n cachedAppData: appData,\n mode,\n usedNames,\n });\n } catch (error) {\n console.warn(\n `Error with page ${page.id}:`,\n error instanceof Error ? error.message : error\n );\n }\n }\n } catch (error) {\n console.error(\"\\nError:\", error instanceof Error ? error.message : error);\n process.exit(1);\n }\n return;\n }\n\n // Single page generation\n try {\n await generateWrapper({ appId, pageId, outputPath, mode });\n } catch (error) {\n console.error(\"\\nError:\", error instanceof Error ? error.message : error);\n process.exit(1);\n }\n}\n"],"names":["writeFile","mkdir","readFile","fs","dotenv.config","APPS_SERVICE_URL","CONST_APPS_SERVICE_URL","COMPONENTS_CDN_URL","CONST_COMPONENTS_CDN_URL","downloadFile","url","headers","response","generateNames","appName","pageName","appCamel","sanitizePropName","pageCamel","appPascal","pagePascal","join","getAppPages","appId","content","appData","error","generateWrapper","pageId","outputPath","cachedAppData","mode","usedNames","finalOutputPath","needsFilenameGeneration","pathExt","stat","tempDir","existsSync","files","file","filePath","pageJsonPath","pageJsonContent","pageResponse","pageData","appUrl","appContent","page","p","sliders","findSlidersAndDataBindings","standaloneComponents","findStandaloneComponents","inputGroups","findInputGroups","forms","findForms","qualifyFormInputs","selectInputs","findStandaloneSelectInputs","actionButtons","findActionButtons","appDataForName","appJsonPath","appJsonContent","directoryPath","componentName","uniqueName","counter","directoryName","providedDir","dirname","shouldBundleData","componentCode","generateComponentCode","readmeContent","generateReadme","componentJsPath","componentCodeContent","appDataForProd","productionData","indexPath","readmePath","runGenerate","pages"],"mappings":"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"}
package/dist/cli.js CHANGED
@@ -1,25 +1,22 @@
1
- import { runDownload as n } from "./cli/commands/download.js";
2
- import { runGenerate as t } from "./cli/commands/generate.js";
3
- async function r() {
4
- const e = process.argv.slice(2);
5
- (e.length === 0 || e.includes("--help") || e.includes("-h")) && (console.log(`
6
- Usage: encore-lib <command> [options]
7
-
8
- Commands:
9
- download <appId> <pageId> <targetPath> Download Encore page data
10
- generate <appId> [pageId] <outputPath> Generate React wrapper components
11
- `), process.exit(0));
12
- const a = e[0], o = e.slice(1);
13
- switch (a) {
14
- case "download":
15
- await n(o);
16
- break;
17
- case "generate":
18
- await t(o);
19
- break;
20
- default:
21
- console.error(`Unknown command: ${a}`), process.exit(1);
22
- }
23
- }
24
- r();
1
+ import { Command as i } from "commander";
2
+ import { runDownload as p } from "./cli/commands/download.js";
3
+ import { runGenerate as c } from "./cli/commands/generate.js";
4
+ const o = new i();
5
+ o.name("encore-lib").description("Encore CLI tools").version("0.1.32");
6
+ o.command("download").description("Download Encore page data").argument("<appId>", "The Encore app ID").argument("<pageId>", "The Encore page ID").argument("<targetPath>", "Path where files should be saved").action(async (n, e, a) => {
7
+ await p(n, e, a);
8
+ });
9
+ o.command("generate").description("Generate React wrapper components").argument("<appId>", "The Encore app ID").argument("[pageId]", "The Encore page ID (optional)").argument(
10
+ "[outputPath]",
11
+ "Path where the generated TSX file(s) should be saved"
12
+ ).option(
13
+ "--mode <mode>",
14
+ "Deployment mode: dynamic (default), optimistic, or production"
15
+ ).action(async (n, e, a, m) => {
16
+ let t = e, r = a;
17
+ e && !a && (r = e, t = void 0);
18
+ const d = m.mode || "dynamic";
19
+ await c(n, t, r, d);
20
+ });
21
+ o.parse();
25
22
  //# sourceMappingURL=cli.js.map
package/dist/cli.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"cli.js","sources":["../src/cli/index.ts"],"sourcesContent":["\nimport { runDownload } from \"./commands/download\";\nimport { runGenerate } from \"./commands/generate\";\n\nasync function main() {\n const args = process.argv.slice(2);\n\n if (args.length === 0 || args.includes(\"--help\") || args.includes(\"-h\")) {\n console.log(`\nUsage: encore-lib <command> [options]\n\nCommands:\n download <appId> <pageId> <targetPath> Download Encore page data\n generate <appId> [pageId] <outputPath> Generate React wrapper components\n`);\n process.exit(0);\n }\n\n const command = args[0];\n const commandArgs = args.slice(1);\n\n switch (command) {\n case \"download\":\n await runDownload(commandArgs);\n break;\n case \"generate\":\n await runGenerate(commandArgs);\n break;\n default:\n console.error(`Unknown command: ${command}`);\n process.exit(1);\n }\n}\n\nmain();\n"],"names":["main","args","command","commandArgs","runDownload","runGenerate"],"mappings":";;AAIA,eAAeA,IAAO;AACpB,QAAMC,IAAO,QAAQ,KAAK,MAAM,CAAC;AAEjC,GAAIA,EAAK,WAAW,KAAKA,EAAK,SAAS,QAAQ,KAAKA,EAAK,SAAS,IAAI,OACpE,QAAQ,IAAI;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,CAMf,GACG,QAAQ,KAAK,CAAC;AAGhB,QAAMC,IAAUD,EAAK,CAAC,GAChBE,IAAcF,EAAK,MAAM,CAAC;AAEhC,UAAQC,GAAA;AAAA,IACN,KAAK;AACH,YAAME,EAAYD,CAAW;AAC7B;AAAA,IACF,KAAK;AACH,YAAME,EAAYF,CAAW;AAC7B;AAAA,IACF;AACE,cAAQ,MAAM,oBAAoBD,CAAO,EAAE,GAC3C,QAAQ,KAAK,CAAC;AAAA,EAAA;AAEpB;AAEAF,EAAA;"}
1
+ {"version":3,"file":"cli.js","sources":["../src/cli/index.ts"],"sourcesContent":["import { Command } from \"commander\";\nimport { runDownload } from \"./commands/download\";\nimport { runGenerate } from \"./commands/generate\";\n\nconst program = new Command();\n\nprogram\n .name(\"encore-lib\")\n .description(\"Encore CLI tools\")\n // We'll read version from package.json in build or hardcode for now to avoid async import issues in simple CLI\n .version(\"0.1.32\");\n\nprogram\n .command(\"download\")\n .description(\"Download Encore page data\")\n .argument(\"<appId>\", \"The Encore app ID\")\n .argument(\"<pageId>\", \"The Encore page ID\")\n .argument(\"<targetPath>\", \"Path where files should be saved\")\n .action(async (appId, pageId, targetPath) => {\n await runDownload(appId, pageId, targetPath);\n });\n\nprogram\n .command(\"generate\")\n .description(\"Generate React wrapper components\")\n .argument(\"<appId>\", \"The Encore app ID\")\n .argument(\"[pageId]\", \"The Encore page ID (optional)\")\n .argument(\n \"[outputPath]\",\n \"Path where the generated TSX file(s) should be saved\"\n )\n .option(\n \"--mode <mode>\",\n \"Deployment mode: dynamic (default), optimistic, or production\"\n )\n .action(async (appId, pageId, outputPath, options) => {\n // Handle overload: generate <appId> <outputPath> vs generate <appId> <pageId> <outputPath>\n let finalPageId = pageId;\n let finalOutputPath = outputPath;\n\n // If only 2 arguments provided (appId and pageId/outputPath), the second one is outputPath\n if (pageId && !outputPath) {\n finalOutputPath = pageId;\n finalPageId = undefined;\n }\n\n const mode = options.mode || \"dynamic\";\n\n await runGenerate(appId, finalPageId, finalOutputPath, mode);\n });\n\nprogram.parse();\n"],"names":["program","Command","appId","pageId","targetPath","runDownload","outputPath","options","finalPageId","finalOutputPath","mode","runGenerate"],"mappings":";;;AAIA,MAAMA,IAAU,IAAIC,EAAA;AAEpBD,EACG,KAAK,YAAY,EACjB,YAAY,kBAAkB,EAE9B,QAAQ,QAAQ;AAEnBA,EACG,QAAQ,UAAU,EAClB,YAAY,2BAA2B,EACvC,SAAS,WAAW,mBAAmB,EACvC,SAAS,YAAY,oBAAoB,EACzC,SAAS,gBAAgB,kCAAkC,EAC3D,OAAO,OAAOE,GAAOC,GAAQC,MAAe;AAC3C,QAAMC,EAAYH,GAAOC,GAAQC,CAAU;AAC7C,CAAC;AAEHJ,EACG,QAAQ,UAAU,EAClB,YAAY,mCAAmC,EAC/C,SAAS,WAAW,mBAAmB,EACvC,SAAS,YAAY,+BAA+B,EACpD;AAAA,EACC;AAAA,EACA;AACF,EACC;AAAA,EACC;AAAA,EACA;AACF,EACC,OAAO,OAAOE,GAAOC,GAAQG,GAAYC,MAAY;AAEpD,MAAIC,IAAcL,GACdM,IAAkBH;AAGtB,EAAIH,KAAU,CAACG,MACbG,IAAkBN,GAClBK,IAAc;AAGhB,QAAME,IAAOH,EAAQ,QAAQ;AAE7B,QAAMI,EAAYT,GAAOM,GAAaC,GAAiBC,CAAI;AAC7D,CAAC;AAEHV,EAAQ,MAAA;"}