@_davideast/stitch-mcp 0.5.1 → 0.5.2

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 (56) hide show
  1. package/dist/chunk-1fbzpreg.js +137 -0
  2. package/dist/chunk-1fbzpreg.js.map +10 -0
  3. package/dist/chunk-4zqw9exz.js +370 -0
  4. package/dist/chunk-4zqw9exz.js.map +16 -0
  5. package/dist/chunk-9g1t32qk.js +273 -0
  6. package/dist/chunk-9g1t32qk.js.map +10 -0
  7. package/dist/chunk-aa5ptn4s.js +768 -0
  8. package/dist/chunk-aa5ptn4s.js.map +18 -0
  9. package/dist/chunk-b9nzx4rf.js +19 -0
  10. package/dist/chunk-b9nzx4rf.js.map +9 -0
  11. package/dist/chunk-c87d10w8.js +109 -0
  12. package/dist/chunk-c87d10w8.js.map +10 -0
  13. package/dist/chunk-d0ffvq20.js +19 -0
  14. package/dist/chunk-d0ffvq20.js.map +9 -0
  15. package/dist/chunk-d8nttd6z.js +683 -0
  16. package/dist/chunk-d8nttd6z.js.map +17 -0
  17. package/dist/chunk-e4q3v109.js +31464 -0
  18. package/dist/chunk-e4q3v109.js.map +245 -0
  19. package/dist/chunk-etcps0m5.js +1495 -0
  20. package/dist/chunk-etcps0m5.js.map +23 -0
  21. package/dist/chunk-f89ve6pt.js +256 -0
  22. package/dist/chunk-f89ve6pt.js.map +11 -0
  23. package/dist/chunk-gydabgsn.js +10 -0
  24. package/dist/chunk-gydabgsn.js.map +9 -0
  25. package/dist/chunk-m4fp3pqc.js +167 -0
  26. package/dist/chunk-m4fp3pqc.js.map +10 -0
  27. package/dist/chunk-nnep362g.js +124 -0
  28. package/dist/chunk-nnep362g.js.map +12 -0
  29. package/dist/chunk-pgqvwkcy.js +736 -0
  30. package/dist/chunk-pgqvwkcy.js.map +16 -0
  31. package/dist/chunk-q8cr9t2z.js +415 -0
  32. package/dist/chunk-q8cr9t2z.js.map +20 -0
  33. package/dist/chunk-s2d39pkr.js +19 -0
  34. package/dist/chunk-s2d39pkr.js.map +9 -0
  35. package/dist/chunk-ststnnry.js +44150 -0
  36. package/dist/chunk-ststnnry.js.map +237 -0
  37. package/dist/chunk-sv2nt87j.js +24 -0
  38. package/dist/chunk-sv2nt87j.js.map +9 -0
  39. package/dist/chunk-t2razx5k.js +69 -0
  40. package/dist/chunk-t2razx5k.js.map +10 -0
  41. package/dist/commands/doctor/command.js +10 -6
  42. package/dist/commands/doctor/command.js.map +4 -4
  43. package/dist/commands/doctor/spec.d.ts +6 -0
  44. package/dist/commands/init/command.js +17 -9
  45. package/dist/commands/init/command.js.map +4 -4
  46. package/dist/commands/init/spec.d.ts +6 -0
  47. package/dist/commands/proxy/command.js +2 -3
  48. package/dist/commands/proxy/command.js.map +3 -3
  49. package/dist/commands/screens/command.js +2 -2
  50. package/dist/commands/serve/command.js +3 -3
  51. package/dist/commands/site/command.js +1 -1
  52. package/dist/commands/snapshot/command.js +1 -1
  53. package/dist/commands/tool/command.js +1 -1
  54. package/dist/commands/view/command.js +1 -1
  55. package/dist/index.js +2 -2
  56. package/package.json +1 -1
@@ -0,0 +1,273 @@
1
+ import {
2
+ openUrl,
3
+ require_jsx_dev_runtime
4
+ } from "./chunk-krfqppg2.js";
5
+ import {
6
+ StitchViteServer
7
+ } from "./chunk-ststnnry.js";
8
+ import"./chunk-abf1r0jh.js";
9
+ import {
10
+ Box_default,
11
+ Text,
12
+ use_app_default,
13
+ use_input_default
14
+ } from "./chunk-7y4xzvkz.js";
15
+ import {
16
+ require_react
17
+ } from "./chunk-4jwmvjb4.js";
18
+ import {
19
+ downloadText
20
+ } from "./chunk-34w2wfyp.js";
21
+ import {
22
+ clipboardy_default
23
+ } from "./chunk-akd997ec.js";
24
+ import"./chunk-q6sv0243.js";
25
+ import"./chunk-4jygt4d6.js";
26
+ import"./chunk-tz7wnw4s.js";
27
+ import"./chunk-3sfn889r.js";
28
+ import {
29
+ __toESM
30
+ } from "./chunk-9wyra8hs.js";
31
+
32
+ // src/commands/screens/ScreensView.tsx
33
+ var import_react = __toESM(require_react(), 1);
34
+ var jsx_dev_runtime = __toESM(require_jsx_dev_runtime(), 1);
35
+ function ScreensView({ projectId, projectTitle, screens }) {
36
+ const { exit } = use_app_default();
37
+ const [selectedIndex, setSelectedIndex] = import_react.useState(0);
38
+ const [windowStart, setWindowStart] = import_react.useState(0);
39
+ const [status, setStatus] = import_react.useState("");
40
+ const [serverUrl, setServerUrl] = import_react.useState(null);
41
+ const serverRef = import_react.useRef(null);
42
+ const VIEW_HEIGHT = 10;
43
+ import_react.default.useEffect(() => {
44
+ if (selectedIndex < windowStart) {
45
+ setWindowStart(selectedIndex);
46
+ } else if (selectedIndex >= windowStart + VIEW_HEIGHT) {
47
+ setWindowStart(selectedIndex - VIEW_HEIGHT + 1);
48
+ }
49
+ }, [selectedIndex, windowStart, VIEW_HEIGHT]);
50
+ import_react.useEffect(() => {
51
+ return () => {
52
+ if (serverRef.current)
53
+ serverRef.current.stop();
54
+ };
55
+ }, []);
56
+ async function serveScreen(screen) {
57
+ if (!screen.hasCode || !screen.codeUrl) {
58
+ setStatus("No HTML to serve");
59
+ return;
60
+ }
61
+ setStatus("Preparing server...");
62
+ let srv = serverRef.current;
63
+ let url = serverUrl;
64
+ let justStarted = false;
65
+ if (!srv) {
66
+ srv = new StitchViteServer;
67
+ url = await srv.start(0);
68
+ serverRef.current = srv;
69
+ setServerUrl(url);
70
+ justStarted = true;
71
+ }
72
+ if (!url)
73
+ return;
74
+ try {
75
+ const html = await downloadText(screen.codeUrl);
76
+ const route = `/screens/${screen.screenId}`;
77
+ srv.mount(route, html);
78
+ const fullUrl = `${url}${route}`;
79
+ if (justStarted) {
80
+ openUrl(fullUrl);
81
+ } else {
82
+ srv.navigate(fullUrl);
83
+ }
84
+ setStatus(`Serving at ${fullUrl}`);
85
+ } catch (e) {
86
+ setStatus("Error serving screen");
87
+ }
88
+ }
89
+ use_input_default((input, key) => {
90
+ if (input === "q") {
91
+ exit();
92
+ return;
93
+ }
94
+ if (key.upArrow || input === "k") {
95
+ setSelectedIndex((prev) => Math.max(0, prev - 1));
96
+ setStatus("");
97
+ }
98
+ if (key.downArrow || input === "j") {
99
+ setSelectedIndex((prev) => Math.min(screens.length - 1, prev + 1));
100
+ setStatus("");
101
+ }
102
+ if (input === "c") {
103
+ const screen = screens[selectedIndex];
104
+ if (screen?.hasCode && screen.codeUrl) {
105
+ setStatus("Copying...");
106
+ downloadText(screen.codeUrl).then((code) => {
107
+ clipboardy_default.write(code);
108
+ setStatus("HTML copied!");
109
+ }).catch(() => setStatus("Failed to copy"));
110
+ } else {
111
+ setStatus("No HTML available");
112
+ }
113
+ }
114
+ if (input === "i") {
115
+ const screen = screens[selectedIndex];
116
+ if (screen?.hasImage) {
117
+ setStatus("Image copy not implemented");
118
+ } else {
119
+ setStatus("No image available");
120
+ }
121
+ }
122
+ if (input === "s") {
123
+ const screen = screens[selectedIndex];
124
+ if (screen) {
125
+ serveScreen(screen);
126
+ }
127
+ }
128
+ });
129
+ const visibleScreens = screens.slice(windowStart, windowStart + VIEW_HEIGHT);
130
+ return /* @__PURE__ */ jsx_dev_runtime.jsxDEV(Box_default, {
131
+ flexDirection: "column",
132
+ padding: 1,
133
+ children: [
134
+ /* @__PURE__ */ jsx_dev_runtime.jsxDEV(Text, {
135
+ bold: true,
136
+ children: [
137
+ projectTitle,
138
+ " (",
139
+ screens.length,
140
+ " screens)"
141
+ ]
142
+ }, undefined, true, undefined, this),
143
+ /* @__PURE__ */ jsx_dev_runtime.jsxDEV(Text, {
144
+ dimColor: true,
145
+ children: [
146
+ "projectId: ",
147
+ projectId
148
+ ]
149
+ }, undefined, true, undefined, this),
150
+ serverUrl && /* @__PURE__ */ jsx_dev_runtime.jsxDEV(Text, {
151
+ dimColor: true,
152
+ children: [
153
+ "Server: ",
154
+ /* @__PURE__ */ jsx_dev_runtime.jsxDEV(Text, {
155
+ color: "green",
156
+ children: serverUrl
157
+ }, undefined, false, undefined, this)
158
+ ]
159
+ }, undefined, true, undefined, this),
160
+ /* @__PURE__ */ jsx_dev_runtime.jsxDEV(Text, {
161
+ children: " "
162
+ }, undefined, false, undefined, this),
163
+ /* @__PURE__ */ jsx_dev_runtime.jsxDEV(Box_default, {
164
+ flexDirection: "column",
165
+ borderStyle: "single",
166
+ borderColor: "yellow",
167
+ paddingX: 1,
168
+ children: [
169
+ windowStart > 0 && /* @__PURE__ */ jsx_dev_runtime.jsxDEV(Text, {
170
+ dimColor: true,
171
+ children: [
172
+ "... ",
173
+ windowStart,
174
+ " more above ..."
175
+ ]
176
+ }, undefined, true, undefined, this),
177
+ visibleScreens.map((screen, index) => {
178
+ const absoluteIndex = windowStart + index;
179
+ const isSelected = absoluteIndex === selectedIndex;
180
+ const num = String(absoluteIndex + 1).padStart(2, " ");
181
+ const selector = isSelected ? "▸" : " ";
182
+ return /* @__PURE__ */ jsx_dev_runtime.jsxDEV(Box_default, {
183
+ flexDirection: "column",
184
+ children: [
185
+ /* @__PURE__ */ jsx_dev_runtime.jsxDEV(Box_default, {
186
+ justifyContent: "space-between",
187
+ children: [
188
+ /* @__PURE__ */ jsx_dev_runtime.jsxDEV(Box_default, {
189
+ children: [
190
+ /* @__PURE__ */ jsx_dev_runtime.jsxDEV(Text, {
191
+ dimColor: true,
192
+ children: num
193
+ }, undefined, false, undefined, this),
194
+ /* @__PURE__ */ jsx_dev_runtime.jsxDEV(Text, {
195
+ color: isSelected ? "cyan" : undefined,
196
+ children: [
197
+ " ",
198
+ selector,
199
+ " "
200
+ ]
201
+ }, undefined, true, undefined, this),
202
+ /* @__PURE__ */ jsx_dev_runtime.jsxDEV(Text, {
203
+ color: isSelected ? "cyan" : undefined,
204
+ bold: isSelected,
205
+ children: screen.title.slice(0, 28)
206
+ }, undefined, false, undefined, this)
207
+ ]
208
+ }, undefined, true, undefined, this),
209
+ /* @__PURE__ */ jsx_dev_runtime.jsxDEV(Box_default, {
210
+ children: [
211
+ /* @__PURE__ */ jsx_dev_runtime.jsxDEV(Text, {
212
+ dimColor: true,
213
+ children: "html"
214
+ }, undefined, false, undefined, this),
215
+ /* @__PURE__ */ jsx_dev_runtime.jsxDEV(Text, {
216
+ color: screen.hasCode ? "green" : "gray",
217
+ children: screen.hasCode ? "[✓]" : "[ ]"
218
+ }, undefined, false, undefined, this),
219
+ /* @__PURE__ */ jsx_dev_runtime.jsxDEV(Text, {
220
+ children: " "
221
+ }, undefined, false, undefined, this),
222
+ /* @__PURE__ */ jsx_dev_runtime.jsxDEV(Text, {
223
+ dimColor: true,
224
+ children: "img"
225
+ }, undefined, false, undefined, this),
226
+ /* @__PURE__ */ jsx_dev_runtime.jsxDEV(Text, {
227
+ color: screen.hasImage ? "green" : "gray",
228
+ children: screen.hasImage ? "[✓]" : "[ ]"
229
+ }, undefined, false, undefined, this)
230
+ ]
231
+ }, undefined, true, undefined, this)
232
+ ]
233
+ }, undefined, true, undefined, this),
234
+ /* @__PURE__ */ jsx_dev_runtime.jsxDEV(Text, {
235
+ dimColor: true,
236
+ color: "gray",
237
+ children: [
238
+ " screenId: ",
239
+ screen.screenId
240
+ ]
241
+ }, undefined, true, undefined, this),
242
+ /* @__PURE__ */ jsx_dev_runtime.jsxDEV(Text, {
243
+ children: " "
244
+ }, undefined, false, undefined, this)
245
+ ]
246
+ }, screen.screenId, true, undefined, this);
247
+ }),
248
+ windowStart + VIEW_HEIGHT < screens.length && /* @__PURE__ */ jsx_dev_runtime.jsxDEV(Text, {
249
+ dimColor: true,
250
+ children: [
251
+ "... ",
252
+ screens.length - (windowStart + VIEW_HEIGHT),
253
+ " more below ..."
254
+ ]
255
+ }, undefined, true, undefined, this)
256
+ ]
257
+ }, undefined, true, undefined, this),
258
+ /* @__PURE__ */ jsx_dev_runtime.jsxDEV(Text, {
259
+ dimColor: true,
260
+ children: "[c]opy html [i]mage [s]erve [q]uit"
261
+ }, undefined, false, undefined, this),
262
+ status && /* @__PURE__ */ jsx_dev_runtime.jsxDEV(Text, {
263
+ color: "yellow",
264
+ children: status
265
+ }, undefined, false, undefined, this)
266
+ ]
267
+ }, undefined, true, undefined, this);
268
+ }
269
+ export {
270
+ ScreensView
271
+ };
272
+
273
+ //# debugId=A890852E888CB14764756E2164756E21
@@ -0,0 +1,10 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../src/commands/screens/ScreensView.tsx"],
4
+ "sourcesContent": [
5
+ "import React, { useState, useEffect, useRef } from 'react';\nimport { Box, Text, useInput, useApp } from 'ink';\nimport { downloadText } from '../../ui/copy-behaviors/clipboard.js';\nimport clipboard from 'clipboardy';\nimport { StitchViteServer } from '../../lib/server/vite/StitchViteServer.js';\nimport { openUrl } from '../../platform/browser.js';\n\ninterface Screen {\n screenId: string;\n title: string;\n hasCode: boolean;\n codeUrl: string | null;\n hasImage: boolean;\n}\n\ninterface ScreensViewProps {\n projectId: string;\n projectTitle: string;\n screens: Screen[];\n}\n\nexport function ScreensView({ projectId, projectTitle, screens }: ScreensViewProps) {\n const { exit } = useApp();\n const [selectedIndex, setSelectedIndex] = useState(0);\n const [windowStart, setWindowStart] = useState(0);\n const [status, setStatus] = useState('');\n const [serverUrl, setServerUrl] = useState<string | null>(null);\n\n const serverRef = useRef<StitchViteServer | null>(null);\n\n const VIEW_HEIGHT = 10;\n\n // Helper to sync window with selection\n React.useEffect(() => {\n if (selectedIndex < windowStart) {\n setWindowStart(selectedIndex);\n } else if (selectedIndex >= windowStart + VIEW_HEIGHT) {\n setWindowStart(selectedIndex - VIEW_HEIGHT + 1);\n }\n }, [selectedIndex, windowStart, VIEW_HEIGHT]);\n\n useEffect(() => {\n return () => {\n if (serverRef.current) serverRef.current.stop();\n };\n }, []);\n\n async function serveScreen(screen: Screen) {\n if (!screen.hasCode || !screen.codeUrl) {\n setStatus('No HTML to serve');\n return;\n }\n\n setStatus('Preparing server...');\n let srv = serverRef.current;\n let url = serverUrl;\n let justStarted = false;\n\n if (!srv) {\n srv = new StitchViteServer();\n url = await srv.start(0);\n serverRef.current = srv;\n setServerUrl(url);\n justStarted = true;\n }\n\n if (!url) return; // Should not happen\n\n try {\n const html = await downloadText(screen.codeUrl);\n const route = `/screens/${screen.screenId}`;\n srv.mount(route, html);\n\n const fullUrl = `${url}${route}`;\n\n if (justStarted) {\n openUrl(fullUrl);\n } else {\n srv.navigate(fullUrl);\n }\n setStatus(`Serving at ${fullUrl}`);\n } catch (e) {\n setStatus('Error serving screen');\n }\n }\n\n useInput((input, key) => {\n if (input === 'q') {\n exit();\n return;\n }\n\n if (key.upArrow || input === 'k') {\n setSelectedIndex(prev => Math.max(0, prev - 1));\n setStatus('');\n }\n\n if (key.downArrow || input === 'j') {\n setSelectedIndex(prev => Math.min(screens.length - 1, prev + 1));\n setStatus('');\n }\n\n // Copy code\n if (input === 'c') {\n const screen = screens[selectedIndex];\n if (screen?.hasCode && screen.codeUrl) {\n setStatus('Copying...');\n downloadText(screen.codeUrl)\n .then(code => {\n clipboard.write(code);\n setStatus('HTML copied!');\n })\n .catch(() => setStatus('Failed to copy'));\n } else {\n setStatus('No HTML available');\n }\n }\n\n // Copy image (placeholder)\n if (input === 'i') {\n const screen = screens[selectedIndex];\n if (screen?.hasImage) {\n setStatus('Image copy not implemented');\n } else {\n setStatus('No image available');\n }\n }\n\n // Serve\n if (input === 's') {\n const screen = screens[selectedIndex];\n if (screen) {\n serveScreen(screen);\n }\n }\n });\n\n const visibleScreens = screens.slice(windowStart, windowStart + VIEW_HEIGHT);\n\n return (\n <Box flexDirection=\"column\" padding={1}>\n {/* Header */}\n <Text bold>{projectTitle} ({screens.length} screens)</Text>\n <Text dimColor>projectId: {projectId}</Text>\n {serverUrl && <Text dimColor>Server: <Text color=\"green\">{serverUrl}</Text></Text>}\n <Text> </Text>\n\n {/* Screen List */}\n <Box flexDirection=\"column\" borderStyle=\"single\" borderColor=\"yellow\" paddingX={1}>\n {windowStart > 0 && <Text dimColor>... {windowStart} more above ...</Text>}\n\n {visibleScreens.map((screen, index) => {\n // Adjust index for absolute position\n const absoluteIndex = windowStart + index;\n const isSelected = absoluteIndex === selectedIndex;\n const num = String(absoluteIndex + 1).padStart(2, ' ');\n const selector = isSelected ? '▸' : ' ';\n\n return (\n <Box key={screen.screenId} flexDirection=\"column\">\n {/* Row 1: Title + Checkboxes */}\n <Box justifyContent=\"space-between\">\n <Box>\n <Text dimColor>{num}</Text>\n <Text color={isSelected ? 'cyan' : undefined}> {selector} </Text>\n <Text color={isSelected ? 'cyan' : undefined} bold={isSelected}>\n {screen.title.slice(0, 28)}\n </Text>\n </Box>\n <Box>\n <Text dimColor>html</Text>\n <Text color={screen.hasCode ? 'green' : 'gray'}>\n {screen.hasCode ? '[✓]' : '[ ]'}\n </Text>\n <Text> </Text>\n <Text dimColor>img</Text>\n <Text color={screen.hasImage ? 'green' : 'gray'}>\n {screen.hasImage ? '[✓]' : '[ ]'}\n </Text>\n </Box>\n </Box>\n {/* Row 2: screenId */}\n <Text dimColor color=\"gray\"> screenId: {screen.screenId}</Text>\n <Text> </Text>\n </Box>\n );\n })}\n\n {windowStart + VIEW_HEIGHT < screens.length && (\n <Text dimColor>... {screens.length - (windowStart + VIEW_HEIGHT)} more below ...</Text>\n )}\n </Box>\n\n {/* Footer */}\n <Text dimColor>[c]opy html [i]mage [s]erve [q]uit</Text>\n {status && <Text color=\"yellow\">{status}</Text>}\n </Box>\n );\n}\n"
6
+ ],
7
+ "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;;AAqBO,SAAS,WAAW,GAAG,WAAW,cAAc,WAA6B;AAAA,EAClF,QAAQ,SAAS,gBAAO;AAAA,EACxB,OAAO,eAAe,oBAAoB,sBAAS,CAAC;AAAA,EACpD,OAAO,aAAa,kBAAkB,sBAAS,CAAC;AAAA,EAChD,OAAO,QAAQ,aAAa,sBAAS,EAAE;AAAA,EACvC,OAAO,WAAW,gBAAgB,sBAAwB,IAAI;AAAA,EAE9D,MAAM,YAAY,oBAAgC,IAAI;AAAA,EAEtD,MAAM,cAAc;AAAA,EAGpB,qBAAM,UAAU,MAAM;AAAA,IACpB,IAAI,gBAAgB,aAAa;AAAA,MAC/B,eAAe,aAAa;AAAA,IAC9B,EAAO,SAAI,iBAAiB,cAAc,aAAa;AAAA,MACrD,eAAe,gBAAgB,cAAc,CAAC;AAAA,IAChD;AAAA,KACC,CAAC,eAAe,aAAa,WAAW,CAAC;AAAA,EAE5C,uBAAU,MAAM;AAAA,IACZ,OAAO,MAAM;AAAA,MACT,IAAI,UAAU;AAAA,QAAS,UAAU,QAAQ,KAAK;AAAA;AAAA,KAEnD,CAAC,CAAC;AAAA,EAEL,eAAe,WAAW,CAAC,QAAgB;AAAA,IACvC,IAAI,CAAC,OAAO,WAAW,CAAC,OAAO,SAAS;AAAA,MACpC,UAAU,kBAAkB;AAAA,MAC5B;AAAA,IACJ;AAAA,IAEA,UAAU,qBAAqB;AAAA,IAC/B,IAAI,MAAM,UAAU;AAAA,IACpB,IAAI,MAAM;AAAA,IACV,IAAI,cAAc;AAAA,IAElB,IAAI,CAAC,KAAK;AAAA,MACN,MAAM,IAAI;AAAA,MACV,MAAM,MAAM,IAAI,MAAM,CAAC;AAAA,MACvB,UAAU,UAAU;AAAA,MACpB,aAAa,GAAG;AAAA,MAChB,cAAc;AAAA,IAClB;AAAA,IAEA,IAAI,CAAC;AAAA,MAAK;AAAA,IAEV,IAAI;AAAA,MACA,MAAM,OAAO,MAAM,aAAa,OAAO,OAAO;AAAA,MAC9C,MAAM,QAAQ,YAAY,OAAO;AAAA,MACjC,IAAI,MAAM,OAAO,IAAI;AAAA,MAErB,MAAM,UAAU,GAAG,MAAM;AAAA,MAEzB,IAAI,aAAa;AAAA,QACZ,QAAQ,OAAO;AAAA,MACpB,EAAO;AAAA,QACH,IAAI,SAAS,OAAO;AAAA;AAAA,MAExB,UAAU,cAAc,SAAS;AAAA,MACnC,OAAO,GAAG;AAAA,MACR,UAAU,sBAAsB;AAAA;AAAA;AAAA,EAIxC,kBAAS,CAAC,OAAO,QAAQ;AAAA,IACvB,IAAI,UAAU,KAAK;AAAA,MACjB,KAAK;AAAA,MACL;AAAA,IACF;AAAA,IAEA,IAAI,IAAI,WAAW,UAAU,KAAK;AAAA,MAChC,iBAAiB,UAAQ,KAAK,IAAI,GAAG,OAAO,CAAC,CAAC;AAAA,MAC9C,UAAU,EAAE;AAAA,IACd;AAAA,IAEA,IAAI,IAAI,aAAa,UAAU,KAAK;AAAA,MAClC,iBAAiB,UAAQ,KAAK,IAAI,QAAQ,SAAS,GAAG,OAAO,CAAC,CAAC;AAAA,MAC/D,UAAU,EAAE;AAAA,IACd;AAAA,IAGA,IAAI,UAAU,KAAK;AAAA,MACjB,MAAM,SAAS,QAAQ;AAAA,MACvB,IAAI,QAAQ,WAAW,OAAO,SAAS;AAAA,QACrC,UAAU,YAAY;AAAA,QACtB,aAAa,OAAO,OAAO,EACxB,KAAK,UAAQ;AAAA,UACZ,mBAAU,MAAM,IAAI;AAAA,UACpB,UAAU,cAAc;AAAA,SACzB,EACA,MAAM,MAAM,UAAU,gBAAgB,CAAC;AAAA,MAC5C,EAAO;AAAA,QACL,UAAU,mBAAmB;AAAA;AAAA,IAEjC;AAAA,IAGA,IAAI,UAAU,KAAK;AAAA,MACjB,MAAM,SAAS,QAAQ;AAAA,MACvB,IAAI,QAAQ,UAAU;AAAA,QACpB,UAAU,4BAA4B;AAAA,MACxC,EAAO;AAAA,QACL,UAAU,oBAAoB;AAAA;AAAA,IAElC;AAAA,IAGA,IAAI,UAAU,KAAK;AAAA,MACjB,MAAM,SAAS,QAAQ;AAAA,MACvB,IAAI,QAAQ;AAAA,QACR,YAAY,MAAM;AAAA,MACtB;AAAA,IACF;AAAA,GACD;AAAA,EAED,MAAM,iBAAiB,QAAQ,MAAM,aAAa,cAAc,WAAW;AAAA,EAE3E,uBACE,uBAwDE,aAxDF;AAAA,IAAK,eAAc;AAAA,IAAS,SAAS;AAAA,IAArC,UAwDE;AAAA,sBAtDA,uBAAsD,MAAtD;AAAA,QAAM,MAAI;AAAA,QAAV,UAAsD;AAAA,UAA1C;AAAA,UAAZ;AAAA,UAA4B,QAAQ;AAAA,UAApC;AAAA;AAAA,yCAAsD;AAAA,sBACtD,uBAAuC,MAAvC;AAAA,QAAM,UAAQ;AAAA,QAAd,UAAuC;AAAA,UAAvC;AAAA,UAA2B;AAAA;AAAA,SAA3B,gCAAuC;AAAA,MACtC,6BAAa,uBAA+D,MAA/D;AAAA,QAAM,UAAQ;AAAA,QAAd,UAA+D;AAAA,UAA/D;AAAA,0BAAuB,uBAAiC,MAAjC;AAAA,YAAM,OAAM;AAAA,YAAZ,UAAqB;AAAA,aAArB,iCAAiC;AAAA;AAAA,SAAxD,gCAA+D;AAAA,sBAC7E,uBAAS,MAAT;AAAA;AAAA,0CAAS;AAAA,sBAGT,uBA2CE,aA3CF;AAAA,QAAK,eAAc;AAAA,QAAS,aAAY;AAAA,QAAS,aAAY;AAAA,QAAS,UAAU;AAAA,QAAhF,UA2CE;AAAA,UA1CC,cAAc,qBAAK,uBAAiD,MAAjD;AAAA,YAAM,UAAQ;AAAA,YAAd,UAAiD;AAAA,cAAjD;AAAA,cAAoB;AAAA,cAApB;AAAA;AAAA,6CAAiD;AAAA,UAEpE,eAAe,IAAI,CAAC,QAAQ,UAAU;AAAA,YAErC,MAAM,gBAAgB,cAAc;AAAA,YACpC,MAAM,aAAa,kBAAkB;AAAA,YACrC,MAAM,MAAM,OAAO,gBAAgB,CAAC,EAAE,SAAS,GAAG,GAAG;AAAA,YACrD,MAAM,WAAW,aAAa,MAAK;AAAA,YAEnC,uBACE,uBAyBE,aAzBF;AAAA,cAA2B,eAAc;AAAA,cAAzC,UAyBE;AAAA,gCAvBA,uBAmBE,aAnBF;AAAA,kBAAK,gBAAe;AAAA,kBAApB,UAmBE;AAAA,oCAlBA,uBAME,aANF;AAAA,gCAME;AAAA,wCALA,uBAAsB,MAAtB;AAAA,0BAAM,UAAQ;AAAA,0BAAd,UAAgB;AAAA,2BAAhB,iCAAsB;AAAA,wCACtB,uBAA4D,MAA5D;AAAA,0BAAM,OAAO,aAAa,SAAS;AAAA,0BAAnC,UAA4D;AAAA,4BAA5D;AAAA,4BAAgD;AAAA,4BAAhD;AAAA;AAAA,2DAA4D;AAAA,wCAC5D,uBAEE,MAFF;AAAA,0BAAM,OAAO,aAAa,SAAS;AAAA,0BAAW,MAAM;AAAA,0BAApD,UACG,OAAO,MAAM,MAAM,GAAG,EAAE;AAAA,2BAD3B,iCAEE;AAAA;AAAA,uBALJ,gCAME;AAAA,oCACF,uBAUE,aAVF;AAAA,gCAUE;AAAA,wCATA,uBAAqB,MAArB;AAAA,0BAAM,UAAQ;AAAA,0BAAd;AAAA,4DAAqB;AAAA,wCACrB,uBAEE,MAFF;AAAA,0BAAM,OAAO,OAAO,UAAU,UAAU;AAAA,0BAAxC,UACG,OAAO,UAAU,QAAO;AAAA,2BAD3B,iCAEE;AAAA,wCACF,uBAAU,MAAV;AAAA;AAAA,4DAAU;AAAA,wCACV,uBAAoB,MAApB;AAAA,0BAAM,UAAQ;AAAA,0BAAd;AAAA,4DAAoB;AAAA,wCACpB,uBAEE,MAFF;AAAA,0BAAM,OAAO,OAAO,WAAW,UAAU;AAAA,0BAAzC,UACG,OAAO,WAAW,QAAO;AAAA,2BAD5B,iCAEE;AAAA;AAAA,uBATJ,gCAUE;AAAA;AAAA,mBAlBJ,gCAmBE;AAAA,gCAEF,uBAA8D,MAA9D;AAAA,kBAAM,UAAQ;AAAA,kBAAC,OAAM;AAAA,kBAArB,UAA8D;AAAA,oBAA9D;AAAA,oBAA4C,OAAO;AAAA;AAAA,mBAAnD,gCAA8D;AAAA,gCAC9D,uBAAS,MAAT;AAAA;AAAA,oDAAS;AAAA;AAAA,eAxBD,OAAO,UAAjB,qBAyBE;AAAA,WAEL;AAAA,UAEA,cAAc,cAAc,QAAQ,0BACnC,uBAAkF,MAAlF;AAAA,YAAM,UAAQ;AAAA,YAAd,UAAkF;AAAA,cAAlF;AAAA,cAAoB,QAAQ,UAAU,cAAc;AAAA,cAApD;AAAA;AAAA,6CAAkF;AAAA;AAAA,SAzCtF,gCA2CE;AAAA,sBAGF,uBAAsD,MAAtD;AAAA,QAAM,UAAQ;AAAA,QAAd;AAAA,0CAAsD;AAAA,MACrD,0BAAU,uBAA+B,MAA/B;AAAA,QAAM,OAAM;AAAA,QAAZ,UAAsB;AAAA,SAAtB,iCAA+B;AAAA;AAAA,KAvD5C,gCAwDE;AAAA;",
8
+ "debugId": "A890852E888CB14764756E2164756E21",
9
+ "names": []
10
+ }