adhdev 0.1.53 → 0.2.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 (109) hide show
  1. package/dist/cli-entrypoint.js +12020 -0
  2. package/dist/cli-entrypoint.js.map +1 -0
  3. package/dist/index.js +9789 -9864
  4. package/dist/index.js.map +1 -0
  5. package/package.json +19 -16
  6. package/providers/_builtin/CONTRIBUTING.md +141 -0
  7. package/providers/_builtin/README.md +51 -0
  8. package/providers/_builtin/acp/agentpool/provider.json +47 -0
  9. package/providers/_builtin/acp/amp/provider.json +45 -0
  10. package/providers/_builtin/acp/auggie/provider.json +50 -0
  11. package/providers/_builtin/acp/autodev/provider.json +47 -0
  12. package/providers/_builtin/acp/autohand/provider.json +45 -0
  13. package/providers/_builtin/acp/blackbox-ai/provider.json +47 -0
  14. package/providers/_builtin/acp/claude-agent/provider.json +50 -0
  15. package/providers/_builtin/acp/cline-acp/provider.json +47 -0
  16. package/providers/_builtin/acp/code-assistant/provider.json +47 -0
  17. package/providers/_builtin/acp/codebuddy/provider.json +47 -0
  18. package/providers/_builtin/acp/codex-cli/provider.json +50 -0
  19. package/providers/_builtin/acp/corust-agent/provider.json +45 -0
  20. package/providers/_builtin/acp/crow-cli/provider.json +47 -0
  21. package/providers/_builtin/acp/cursor-acp/provider.json +47 -0
  22. package/providers/_builtin/acp/deepagents/provider.json +45 -0
  23. package/providers/_builtin/acp/dimcode/provider.json +47 -0
  24. package/providers/_builtin/acp/docker-cagent/provider.json +50 -0
  25. package/providers/_builtin/acp/factory-droid/provider.json +53 -0
  26. package/providers/_builtin/acp/fast-agent/provider.json +45 -0
  27. package/providers/_builtin/acp/fount/provider.json +47 -0
  28. package/providers/_builtin/acp/gemini-cli/provider.json +107 -0
  29. package/providers/_builtin/acp/github-copilot/provider.json +47 -0
  30. package/providers/_builtin/acp/goose/provider.json +50 -0
  31. package/providers/_builtin/acp/junie/provider.json +45 -0
  32. package/providers/_builtin/acp/kilo/provider.json +45 -0
  33. package/providers/_builtin/acp/kimi-cli/provider.json +50 -0
  34. package/providers/_builtin/acp/kiro-cli/provider.json +47 -0
  35. package/providers/_builtin/acp/minion-code/provider.json +45 -0
  36. package/providers/_builtin/acp/mistral-vibe/provider.json +50 -0
  37. package/providers/_builtin/acp/nova/provider.json +47 -0
  38. package/providers/_builtin/acp/openclaw/provider.json +47 -0
  39. package/providers/_builtin/acp/opencode/provider.json +45 -0
  40. package/providers/_builtin/acp/openhands/provider.json +47 -0
  41. package/providers/_builtin/acp/pi-acp/provider.json +45 -0
  42. package/providers/_builtin/acp/qoder/provider.json +47 -0
  43. package/providers/_builtin/acp/qwen-code/provider.json +53 -0
  44. package/providers/_builtin/acp/stakpak/provider.json +47 -0
  45. package/providers/_builtin/acp/vtcode/provider.json +47 -0
  46. package/providers/_builtin/cli/claude-cli/provider.json +78 -0
  47. package/providers/_builtin/cli/codex-cli/provider.json +60 -0
  48. package/providers/_builtin/cli/gemini-cli/provider.json +64 -0
  49. package/providers/_builtin/extension/cline/provider.json +11 -0
  50. package/providers/_builtin/extension/cline/scripts/open_panel.js +1 -1
  51. package/providers/_builtin/extension/cline/{provider.js → scripts.js} +29 -55
  52. package/providers/_builtin/extension/roo-code/provider.json +11 -0
  53. package/providers/_builtin/extension/roo-code/{provider.js → scripts.js} +27 -97
  54. package/providers/_builtin/ide/antigravity/provider.json +32 -0
  55. package/providers/_builtin/ide/antigravity/scripts.js +73 -0
  56. package/providers/_builtin/ide/cursor/provider.json +35 -0
  57. package/providers/_builtin/ide/cursor/{provider.js → scripts.js} +31 -69
  58. package/providers/_builtin/ide/kiro/provider.json +36 -0
  59. package/providers/_builtin/ide/kiro/scripts/webview_send_message.js +72 -0
  60. package/providers/_builtin/ide/kiro/scripts.js +62 -0
  61. package/providers/_builtin/ide/pearai/provider.json +36 -0
  62. package/providers/_builtin/ide/pearai/scripts/list_sessions.js +38 -0
  63. package/providers/_builtin/ide/pearai/scripts/new_session.js +55 -0
  64. package/providers/_builtin/ide/pearai/scripts/webview_list_sessions.js +62 -0
  65. package/providers/_builtin/ide/pearai/scripts/webview_new_session.js +32 -4
  66. package/providers/_builtin/ide/pearai/scripts/webview_send_message.js +72 -0
  67. package/providers/_builtin/ide/pearai/scripts/webview_switch_session.js +34 -0
  68. package/providers/_builtin/ide/pearai/scripts.js +74 -0
  69. package/providers/_builtin/ide/trae/provider.json +35 -0
  70. package/providers/_builtin/ide/trae/scripts/send_message.js +53 -3
  71. package/providers/_builtin/ide/trae/scripts.js +57 -0
  72. package/providers/_builtin/ide/vscode/provider.json +33 -0
  73. package/providers/_builtin/ide/vscode-insiders/provider.json +31 -0
  74. package/providers/_builtin/ide/vscodium/provider.json +32 -0
  75. package/providers/_builtin/ide/windsurf/provider.json +22 -0
  76. package/providers/_builtin/ide/windsurf/scripts.js +57 -0
  77. package/providers/_builtin/validate.js +156 -0
  78. package/README.md +0 -43
  79. package/dist/dev-console-monaco.js +0 -176
  80. package/dist/dev-console.css +0 -326
  81. package/dist/dev-console.html +0 -148
  82. package/dist/dev-console.js +0 -1165
  83. package/dist/index.d.ts +0 -2
  84. package/dist/node_datachannel-LPY6EJH5.node +0 -0
  85. package/providers/_builtin/acp/codex-cli/provider.js +0 -54
  86. package/providers/_builtin/acp/goose/provider.js +0 -32
  87. package/providers/_builtin/acp/opencode/provider.js +0 -32
  88. package/providers/_builtin/cli/claude-cli/provider.js +0 -125
  89. package/providers/_builtin/cli/codex-cli/provider.js +0 -77
  90. package/providers/_builtin/cli/gemini-cli/provider.js +0 -121
  91. package/providers/_builtin/ide/antigravity/provider.js +0 -114
  92. package/providers/_builtin/ide/cursor/provider.js.backup +0 -116
  93. package/providers/_builtin/ide/cursor/provider.js.bak +0 -127
  94. package/providers/_builtin/ide/cursor/scripts_backup/focus_editor.js +0 -20
  95. package/providers/_builtin/ide/cursor/scripts_backup/list_chats.js +0 -111
  96. package/providers/_builtin/ide/cursor/scripts_backup/new_session.js +0 -62
  97. package/providers/_builtin/ide/cursor/scripts_backup/open_panel.js +0 -31
  98. package/providers/_builtin/ide/cursor/scripts_backup/read_chat.js +0 -433
  99. package/providers/_builtin/ide/cursor/scripts_backup/resolve_action.js +0 -90
  100. package/providers/_builtin/ide/cursor/scripts_backup/send_message.js +0 -86
  101. package/providers/_builtin/ide/cursor/scripts_backup/switch_session.js +0 -63
  102. package/providers/_builtin/ide/kiro/provider.js +0 -86
  103. package/providers/_builtin/ide/pearai/provider.js +0 -88
  104. package/providers/_builtin/ide/trae/provider.js +0 -83
  105. package/providers/_builtin/ide/vscode/provider.js +0 -36
  106. package/providers/_builtin/ide/vscode-insiders/provider.js +0 -27
  107. package/providers/_builtin/ide/vscodium/provider.js +0 -27
  108. package/providers/_builtin/ide/windsurf/provider.js +0 -76
  109. /package/providers/{_helpers → _builtin/_helpers}/index.js +0 -0
@@ -1,326 +0,0 @@
1
- @import url('https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;600&family=Inter:wght@400;500;600&display=swap');
2
-
3
- :root {
4
- --bg: #0d1117;
5
- --bg-panel: #161b22;
6
- --bg-input: #0d1117;
7
- --border: #30363d;
8
- --text: #c9d1d9;
9
- --text-dim: #8b949e;
10
- --accent: #58a6ff;
11
- --accent-green: #3fb950;
12
- --accent-red: #f85149;
13
- --accent-yellow: #d29922;
14
- --accent-purple: #bc8cff;
15
- }
16
-
17
- * { margin: 0; padding: 0; box-sizing: border-box; }
18
- body {
19
- font-family: 'Inter', sans-serif;
20
- background: var(--bg);
21
- color: var(--text);
22
- height: 100vh;
23
- display: flex;
24
- flex-direction: column;
25
- overflow: hidden;
26
- }
27
-
28
- /* ─── Toolbar ─── */
29
- .toolbar {
30
- display: flex;
31
- align-items: center;
32
- gap: 8px;
33
- padding: 8px 16px;
34
- background: var(--bg-panel);
35
- border-bottom: 1px solid var(--border);
36
- flex-shrink: 0;
37
- }
38
- .toolbar .logo {
39
- font-weight: 600;
40
- font-size: 14px;
41
- color: var(--accent);
42
- margin-right: 12px;
43
- white-space: nowrap;
44
- }
45
- .toolbar select, .toolbar button {
46
- font-family: 'Inter', sans-serif;
47
- font-size: 12px;
48
- border: 1px solid var(--border);
49
- border-radius: 6px;
50
- padding: 6px 12px;
51
- background: var(--bg-input);
52
- color: var(--text);
53
- cursor: pointer;
54
- transition: all 0.15s;
55
- }
56
- .toolbar button:hover { border-color: var(--accent); background: rgba(88,166,255,0.1); }
57
- .toolbar button.primary {
58
- background: var(--accent);
59
- color: #000;
60
- border-color: var(--accent);
61
- font-weight: 600;
62
- }
63
- .toolbar button.primary:hover { background: #79c0ff; }
64
- .toolbar button.danger { border-color: var(--accent-red); color: var(--accent-red); }
65
- .toolbar button.danger:hover { background: rgba(248,81,73,0.1); }
66
- .toolbar .spacer { flex: 1; }
67
- .toolbar .status {
68
- font-size: 11px;
69
- color: var(--text-dim);
70
- display: flex;
71
- align-items: center;
72
- gap: 4px;
73
- }
74
- .toolbar .status .dot {
75
- width: 6px; height: 6px; border-radius: 50%;
76
- display: inline-block;
77
- }
78
- .toolbar .status .dot.on { background: var(--accent-green); }
79
- .toolbar .status .dot.off { background: var(--accent-red); }
80
-
81
- /* ─── Main Layout ─── */
82
- .main {
83
- flex: 1;
84
- display: flex;
85
- overflow: hidden;
86
- }
87
-
88
- /* Left: Editor */
89
- .editor-panel {
90
- width: 50%;
91
- display: flex;
92
- flex-direction: column;
93
- border-right: 1px solid var(--border);
94
- }
95
- .editor-header {
96
- display: flex;
97
- align-items: center;
98
- gap: 6px;
99
- padding: 6px 12px;
100
- background: var(--bg-panel);
101
- border-bottom: 1px solid var(--border);
102
- font-size: 12px;
103
- color: var(--text-dim);
104
- }
105
- .editor-header .tab {
106
- padding: 4px 10px;
107
- border-radius: 4px;
108
- cursor: pointer;
109
- font-size: 11px;
110
- }
111
- .editor-header .tab.active {
112
- background: rgba(88,166,255,0.15);
113
- color: var(--accent);
114
- }
115
- .editor-header .tab:hover { background: rgba(255,255,255,0.05); }
116
- #editor-container {
117
- flex: 1;
118
- overflow: hidden;
119
- background: var(--bg);
120
- }
121
- /* Hidden textarea for backward compat */
122
- #editor { display: none; }
123
-
124
- /* Right: Preview + Output */
125
- .right-panel {
126
- width: 50%;
127
- display: flex;
128
- flex-direction: column;
129
- }
130
-
131
- /* Screenshot */
132
- .screenshot-panel {
133
- flex: 0 0 50%;
134
- position: relative;
135
- overflow: hidden;
136
- border-bottom: 1px solid var(--border);
137
- background: #000;
138
- }
139
- .screenshot-panel img {
140
- width: 100%;
141
- height: 100%;
142
- object-fit: contain;
143
- }
144
- .screenshot-panel .placeholder {
145
- display: flex;
146
- align-items: center;
147
- justify-content: center;
148
- height: 100%;
149
- color: var(--text-dim);
150
- font-size: 13px;
151
- }
152
- .screenshot-panel .overlay {
153
- position: absolute;
154
- border: 2px solid var(--accent);
155
- background: rgba(88,166,255,0.08);
156
- pointer-events: none;
157
- transition: all 0.2s;
158
- }
159
- .screenshot-panel .overlay .label {
160
- position: absolute;
161
- top: -18px;
162
- left: 0;
163
- font-size: 10px;
164
- background: var(--accent);
165
- color: #000;
166
- padding: 1px 4px;
167
- border-radius: 2px;
168
- white-space: nowrap;
169
- font-family: 'JetBrains Mono', monospace;
170
- }
171
-
172
- /* Output */
173
- .output-panel {
174
- flex: 1;
175
- display: flex;
176
- flex-direction: column;
177
- overflow: hidden;
178
- }
179
- .output-header {
180
- display: flex;
181
- align-items: center;
182
- gap: 8px;
183
- padding: 6px 12px;
184
- background: var(--bg-panel);
185
- border-bottom: 1px solid var(--border);
186
- font-size: 12px;
187
- color: var(--text-dim);
188
- }
189
- .output-header .badge {
190
- font-size: 10px;
191
- padding: 1px 6px;
192
- border-radius: 8px;
193
- font-weight: 600;
194
- }
195
- .output-header .badge.ok { background: rgba(63,185,80,0.2); color: var(--accent-green); }
196
- .output-header .badge.err { background: rgba(248,81,73,0.2); color: var(--accent-red); }
197
- .output-search {
198
- font-family: 'JetBrains Mono', monospace;
199
- font-size: 11px;
200
- border: 1px solid var(--border);
201
- border-radius: 4px;
202
- padding: 2px 8px;
203
- background: var(--bg-input);
204
- color: var(--text);
205
- width: 140px;
206
- outline: none;
207
- }
208
- .output-search:focus { border-color: var(--accent); }
209
- #output {
210
- flex: 1;
211
- overflow-y: auto;
212
- padding: 4px 0;
213
- font-family: 'JetBrains Mono', monospace;
214
- font-size: 12px;
215
- line-height: 1.5;
216
- }
217
- .output-entry {
218
- padding: 4px 12px;
219
- border-bottom: 1px solid rgba(48,54,61,0.3);
220
- display: flex;
221
- gap: 8px;
222
- align-items: flex-start;
223
- transition: background 0.15s;
224
- }
225
- .output-entry:hover { background: rgba(255,255,255,0.02); }
226
- .output-entry .ts {
227
- color: var(--text-dim);
228
- font-size: 10px;
229
- flex-shrink: 0;
230
- min-width: 60px;
231
- padding-top: 1px;
232
- }
233
- .output-entry .icon {
234
- flex-shrink: 0;
235
- width: 16px;
236
- text-align: center;
237
- font-size: 11px;
238
- }
239
- .output-entry .content {
240
- flex: 1;
241
- white-space: pre-wrap;
242
- word-break: break-all;
243
- }
244
- .output-entry.type-log .icon { color: var(--text-dim); }
245
- .output-entry.type-result .icon { color: var(--accent-green); }
246
- .output-entry.type-error .icon { color: var(--accent-red); }
247
- .output-entry.type-error .content { color: var(--accent-red); }
248
- .output-entry.type-warn .icon { color: var(--accent-yellow); }
249
- .output-entry.type-warn .content { color: var(--accent-yellow); }
250
- .output-entry.type-query .icon { color: var(--accent-purple); }
251
- .output-entry.hidden { display: none; }
252
-
253
- /* Watch indicator */
254
- .watch-indicator {
255
- display: none;
256
- align-items: center;
257
- gap: 4px;
258
- font-size: 11px;
259
- color: var(--accent-green);
260
- animation: pulse 2s infinite;
261
- }
262
- .watch-indicator.active { display: flex; }
263
- @keyframes pulse {
264
- 0%, 100% { opacity: 1; }
265
- 50% { opacity: 0.4; }
266
- }
267
-
268
- /* Script list dropdown */
269
- .script-menu {
270
- position: relative;
271
- }
272
- .script-dropdown {
273
- display: none;
274
- position: absolute;
275
- top: 100%;
276
- left: 0;
277
- background: var(--bg-panel);
278
- border: 1px solid var(--border);
279
- border-radius: 6px;
280
- padding: 4px;
281
- min-width: 200px;
282
- z-index: 100;
283
- box-shadow: 0 8px 24px rgba(0,0,0,0.4);
284
- }
285
- .script-dropdown.show { display: block; }
286
- .script-dropdown .item {
287
- padding: 6px 10px;
288
- border-radius: 4px;
289
- cursor: pointer;
290
- font-size: 12px;
291
- display: flex;
292
- justify-content: space-between;
293
- }
294
- .script-dropdown .item:hover { background: rgba(255,255,255,0.05); }
295
- .script-dropdown .item .hint { color: var(--text-dim); font-size: 11px; }
296
-
297
- /* Selector tester */
298
- .selector-bar {
299
- display: flex;
300
- gap: 6px;
301
- padding: 4px 8px;
302
- background: var(--bg-panel);
303
- border-bottom: 1px solid var(--border);
304
- }
305
- .selector-bar input {
306
- flex: 1;
307
- font-family: 'JetBrains Mono', monospace;
308
- font-size: 12px;
309
- border: 1px solid var(--border);
310
- border-radius: 4px;
311
- padding: 4px 8px;
312
- background: var(--bg-input);
313
- color: var(--text);
314
- outline: none;
315
- }
316
- .selector-bar input:focus { border-color: var(--accent); }
317
- .selector-bar button {
318
- font-size: 11px;
319
- padding: 4px 8px;
320
- border: 1px solid var(--border);
321
- border-radius: 4px;
322
- background: var(--bg-input);
323
- color: var(--text);
324
- cursor: pointer;
325
- }
326
- .selector-bar .count { font-size: 11px; color: var(--text-dim); line-height: 28px; }
@@ -1,148 +0,0 @@
1
- <!DOCTYPE html>
2
- <html lang="en">
3
- <head>
4
- <meta charset="UTF-8">
5
- <meta name="viewport" content="width=device-width, initial-scale=1.0">
6
- <title>ADHDev DevConsole — Script Development</title>
7
- <script src="https://cdnjs.cloudflare.com/ajax/libs/monaco-editor/0.52.2/min/vs/loader.min.js"></script>
8
- <link rel="stylesheet" href="/static/dev-console.css">
9
- </head>
10
- <body>
11
-
12
- <!-- Toolbar -->
13
- <div class="toolbar">
14
- <span class="logo">🔧 ADHDev DevConsole</span>
15
- <select id="providerSelect"><option value="">Loading...</option></select>
16
- <button id="newBtn" title="Create new provider">+ New</button>
17
- <select id="ideTargetSelect" title="CDP Target IDE"><option value="">Auto</option></select>
18
- <div class="script-menu">
19
- <button id="scriptBtn">📜 Scripts ▾</button>
20
- <div class="script-dropdown" id="scriptDropdown"></div>
21
- </div>
22
- <button class="primary" id="runBtn" title="Ctrl+Enter">▶ Run</button>
23
-
24
- <button id="screenshotBtn">📸</button>
25
- <button id="domDebugBtn" title="Analyze inputs, buttons, textareas">🔍 DOM</button>
26
- <button id="reloadBtn">🔄</button>
27
- <button id="watchBtn">👁 Watch</button>
28
- <button id="sourceBtn">📄 Edit Source</button>
29
- <button id="saveBtn" style="display:none;background:var(--accent-green);color:#000;border-color:var(--accent-green);font-weight:600">💾 Save & Run</button>
30
- <div class="spacer"></div>
31
- <div class="watch-indicator" id="watchIndicator">● Watch</div>
32
- <div class="status" id="statusBar"><span class="dot off"></span> Connecting...</div>
33
- </div>
34
-
35
- <!-- Scaffold Modal -->
36
- <div id="scaffoldModal" style="display:none;position:fixed;inset:0;background:rgba(0,0,0,0.75);z-index:200;display:none;align-items:center;justify-content:center">
37
- <div style="background:var(--bg-panel);border:1px solid var(--border);border-radius:12px;padding:24px;width:460px;box-shadow:0 20px 40px rgba(0,0,0,0.6);max-height:85vh;overflow-y:auto">
38
- <h3 style="margin:0 0 16px;font-size:16px;color:var(--accent)">+ New Provider</h3>
39
- <div style="display:flex;flex-direction:column;gap:10px">
40
- <div style="display:flex;gap:8px">
41
- <div style="flex:1">
42
- <label style="font-size:11px;color:var(--text-dim);display:block;margin-bottom:4px">Type ID</label>
43
- <input id="scaffoldType" style="width:100%;padding:8px;background:var(--bg-input);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:13px" placeholder="zed">
44
- </div>
45
- <div style="flex:1">
46
- <label style="font-size:11px;color:var(--text-dim);display:block;margin-bottom:4px">Display Name</label>
47
- <input id="scaffoldName" style="width:100%;padding:8px;background:var(--bg-input);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:13px" placeholder="Zed">
48
- </div>
49
- </div>
50
- <div>
51
- <label style="font-size:11px;color:var(--text-dim);display:block;margin-bottom:4px">Category</label>
52
- <select id="scaffoldCategory" onchange="toggleScaffoldFields()" style="width:100%;padding:8px;background:var(--bg-input);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:13px">
53
- <option value="ide">💻 IDE (main window CDP)</option>
54
- <option value="extension">🧩 Extension (webview CDP)</option>
55
- <option value="cli">⌨️ CLI (terminal agent)</option>
56
- </select>
57
- </div>
58
- <!-- IDE/Extension fields -->
59
- <div id="scaffoldIdeFields">
60
- <div style="display:flex;gap:8px;margin-bottom:8px">
61
- <div style="flex:1">
62
- <label style="font-size:11px;color:var(--text-dim);display:block;margin-bottom:4px">CDP Port (primary)</label>
63
- <input id="scaffoldCdpPort1" type="number" style="width:100%;padding:8px;background:var(--bg-input);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:13px" placeholder="9222">
64
- </div>
65
- <div style="flex:1">
66
- <label style="font-size:11px;color:var(--text-dim);display:block;margin-bottom:4px">CDP Port (fallback)</label>
67
- <input id="scaffoldCdpPort2" type="number" style="width:100%;padding:8px;background:var(--bg-input);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:13px" placeholder="9223">
68
- </div>
69
- </div>
70
- <div style="display:flex;gap:8px">
71
- <div style="flex:1">
72
- <label style="font-size:11px;color:var(--text-dim);display:block;margin-bottom:4px">CLI Command</label>
73
- <input id="scaffoldCli" style="width:100%;padding:8px;background:var(--bg-input);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:13px" placeholder="cursor">
74
- </div>
75
- <div style="flex:1">
76
- <label style="font-size:11px;color:var(--text-dim);display:block;margin-bottom:4px">Process Name</label>
77
- <input id="scaffoldProcess" style="width:100%;padding:8px;background:var(--bg-input);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:13px" placeholder="Cursor">
78
- </div>
79
- </div>
80
- </div>
81
- <!-- Extension-only field -->
82
- <div id="scaffoldExtFields" style="display:none">
83
- <label style="font-size:11px;color:var(--text-dim);display:block;margin-bottom:4px">Extension ID</label>
84
- <input id="scaffoldExtId" style="width:100%;padding:8px;background:var(--bg-input);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:13px" placeholder="publisher.extension-name">
85
- </div>
86
- <!-- CLI-only field -->
87
- <div id="scaffoldCliFields" style="display:none">
88
- <label style="font-size:11px;color:var(--text-dim);display:block;margin-bottom:4px">Binary Path</label>
89
- <input id="scaffoldBinary" style="width:100%;padding:8px;background:var(--bg-input);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:13px" placeholder="gemini-cli">
90
- </div>
91
- <div>
92
- <label style="font-size:11px;color:var(--text-dim);display:block;margin-bottom:4px">Install Path (optional)</label>
93
- <input id="scaffoldInstallPath" style="width:100%;padding:8px;background:var(--bg-input);border:1px solid var(--border);border-radius:6px;color:var(--text);font-size:13px" placeholder="/Applications/MyIDE.app">
94
- </div>
95
- <div style="display:flex;gap:8px;justify-content:flex-end;margin-top:8px">
96
- <button onclick="document.getElementById('scaffoldModal').style.display='none'" style="padding:8px 16px;background:transparent;border:1px solid var(--border);border-radius:6px;color:var(--text-dim);cursor:pointer">Cancel</button>
97
- <button onclick="doScaffold()" style="padding:8px 16px;background:var(--accent);color:#000;border:none;border-radius:6px;font-weight:600;cursor:pointer">Create</button>
98
- </div>
99
- </div>
100
- </div>
101
- </div>
102
-
103
- <!-- Main -->
104
- <div class="main">
105
- <!-- Left: Editor -->
106
- <div class="editor-panel">
107
- <div class="editor-header">
108
- <span class="tab active" data-tab="editor" title="Write and run CDP scripts on the target IDE">🖥 Editor</span>
109
- <span class="tab" data-tab="template" title="Provider scaffold template — copy & customize for a new provider">📋 New Provider Template</span>
110
- <span class="tab" data-tab="contracts" title="Reference: required JSON output format for each script function">📑 Output Spec</span>
111
- <div style="flex:1"></div>
112
- <span id="execTime" style="font-size:11px;color:var(--text-dim)"></span>
113
- </div>
114
- <textarea id="editor" style="display:none"></textarea>
115
- <div id="editor-container"></div>
116
- </div>
117
-
118
- <!-- Right: Screenshot + Output -->
119
- <div class="right-panel">
120
- <div class="screenshot-panel" id="screenshotPanel" style="position:relative">
121
- <div class="placeholder" id="screenshotPlaceholder">Click 📸 Screenshot to capture IDE<br><small style="color:var(--text-dim)">Then click on the screenshot to inspect elements</small></div>
122
- <img id="screenshotImg" style="display:none;cursor:crosshair" />
123
- <div id="inspectCrosshair" style="display:none;position:absolute;width:20px;height:20px;border:2px solid var(--accent);border-radius:50%;pointer-events:none;transform:translate(-50%,-50%);z-index:10;box-shadow:0 0 8px var(--accent)"></div>
124
- </div>
125
-
126
- <div class="selector-bar">
127
- <input id="selectorInput" placeholder="CSS selector to test..." />
128
- <button id="selectorBtn">Query</button>
129
- <span class="count" id="selectorCount"></span>
130
- </div>
131
-
132
- <div class="output-panel">
133
- <div class="output-header">
134
- <span>Output</span>
135
- <span class="badge" id="outputBadge" style="display:none"></span>
136
- <div style="flex:1"></div>
137
- <input class="output-search" id="outputSearch" placeholder="Filter..." />
138
- <button style="font-size:11px;padding:2px 6px;border:1px solid var(--border);border-radius:3px;background:transparent;color:var(--text-dim);cursor:pointer" id="clearBtn">Clear</button>
139
- </div>
140
- <div id="output"></div>
141
- </div>
142
- </div>
143
- </div>
144
-
145
- <script src="/static/dev-console.js"></script>
146
- <script src="/static/dev-console-monaco.js"></script>
147
- </body>
148
- </html>