@brainfish-ai/devdoc 0.1.36 → 0.1.37

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.
@@ -0,0 +1,561 @@
1
+ ---
2
+ name: whisk-theme
3
+ description: Analyze repository branding and generate custom documentation theme with branded components.
4
+ ---
5
+
6
+ ## Instructions
7
+
8
+ When asked to "whisk theme", "generate theme", "customize theme", or "match branding":
9
+
10
+ ### Step 1: Scan for Brand Colors
11
+
12
+ Search repository for brand colors in priority order:
13
+
14
+ **Tailwind Config** (`tailwind.config.js/ts`):
15
+ ```javascript
16
+ theme: { colors: { primary: '#xxx', brand: '#xxx' } }
17
+ ```
18
+
19
+ **CSS Variables** (`globals.css`, `variables.css`, `app.css`):
20
+ ```css
21
+ :root { --primary: #xxx; --brand-color: #xxx; }
22
+ ```
23
+
24
+ **UI Frameworks**:
25
+ - Chakra: `colors.brand.500`
26
+ - MUI: `palette.primary.main`
27
+ - shadcn: `--primary: H S% L%`
28
+
29
+ ### Step 2: Scan for Logo & Fonts
30
+
31
+ **Logo**: `public/logo.svg`, `assets/logo.*`, `favicon.svg`
32
+ **Fonts**: Tailwind fontFamily, CSS font-family, Next.js font imports
33
+
34
+ ### Step 3: Present Findings
35
+
36
+ ```
37
+ 🎨 Brand Analysis Complete!
38
+
39
+ COLORS:
40
+ Primary: #3B82F6 ████ (from tailwind.config.js)
41
+
42
+ LOGO: ✓ public/logo.svg
43
+ FONT: Inter
44
+
45
+ Apply to docs? (yes/customize/cancel)
46
+ ```
47
+
48
+ ### Step 4: Update Theme Files
49
+
50
+ #### theme.json
51
+ ```json
52
+ {
53
+ "$schema": "https://devdoc.sh/theme.json",
54
+ "name": "{ProductName} Docs",
55
+ "colors": {
56
+ "primary": "{primary}",
57
+ "primaryLight": "{lighten_15%}",
58
+ "primaryDark": "{darken_15%}"
59
+ },
60
+ "typography": {
61
+ "fontFamily": "{font}, system-ui, sans-serif"
62
+ }
63
+ }
64
+ ```
65
+
66
+ #### custom.css
67
+ ```css
68
+ :root {
69
+ --devdoc-primary: {primary};
70
+ --devdoc-primary-light: {primaryLight};
71
+ --devdoc-primary-dark: {primaryDark};
72
+ --devdoc-font-family: '{font}', system-ui, sans-serif;
73
+ }
74
+ ```
75
+
76
+ ### Step 5: Update Branded Components
77
+
78
+ Generate component overrides based on brand colors and product type.
79
+
80
+ #### Callouts & Notices
81
+
82
+ ```css
83
+ /* Branded callouts */
84
+ .callout-info {
85
+ background: linear-gradient(135deg, var(--devdoc-primary-light) 0%, transparent 100%);
86
+ border-left: 4px solid var(--devdoc-primary);
87
+ }
88
+
89
+ .callout-tip {
90
+ border-left-color: var(--devdoc-primary);
91
+ }
92
+
93
+ .callout-warning {
94
+ border-left-color: #f59e0b;
95
+ }
96
+
97
+ .callout-danger {
98
+ border-left-color: #ef4444;
99
+ }
100
+ ```
101
+
102
+ #### Cards & Card Groups
103
+
104
+ ```css
105
+ /* Branded cards */
106
+ .card {
107
+ border: 1px solid var(--border);
108
+ border-radius: 0.5rem;
109
+ transition: border-color 0.2s, box-shadow 0.2s;
110
+ }
111
+
112
+ .card:hover {
113
+ border-color: var(--devdoc-primary);
114
+ box-shadow: 0 4px 12px rgba(var(--devdoc-primary-rgb), 0.15);
115
+ }
116
+
117
+ .card-icon {
118
+ color: var(--devdoc-primary);
119
+ }
120
+ ```
121
+
122
+ #### Tabs
123
+
124
+ ```css
125
+ /* Branded tabs */
126
+ .tabs-trigger[data-state="active"] {
127
+ color: var(--devdoc-primary);
128
+ border-bottom-color: var(--devdoc-primary);
129
+ }
130
+
131
+ .tabs-trigger:hover {
132
+ color: var(--devdoc-primary-dark);
133
+ }
134
+ ```
135
+
136
+ #### Accordions
137
+
138
+ ```css
139
+ /* Branded accordions */
140
+ .accordion-trigger:hover {
141
+ color: var(--devdoc-primary);
142
+ }
143
+
144
+ .accordion-trigger[data-state="open"] {
145
+ color: var(--devdoc-primary);
146
+ }
147
+
148
+ .accordion-trigger[data-state="open"] svg {
149
+ color: var(--devdoc-primary);
150
+ }
151
+ ```
152
+
153
+ #### Buttons
154
+
155
+ ```css
156
+ /* Primary button */
157
+ .btn-primary {
158
+ background-color: var(--devdoc-primary);
159
+ color: white;
160
+ }
161
+
162
+ .btn-primary:hover {
163
+ background-color: var(--devdoc-primary-dark);
164
+ }
165
+
166
+ /* Secondary/outline button */
167
+ .btn-secondary {
168
+ border: 1px solid var(--devdoc-primary);
169
+ color: var(--devdoc-primary);
170
+ background: transparent;
171
+ }
172
+
173
+ .btn-secondary:hover {
174
+ background-color: var(--devdoc-primary);
175
+ color: white;
176
+ }
177
+ ```
178
+
179
+ #### Code Blocks
180
+
181
+ ```css
182
+ /* Branded code blocks */
183
+ .code-block {
184
+ border: 1px solid var(--border);
185
+ border-radius: 0.5rem;
186
+ }
187
+
188
+ .code-block-header {
189
+ background: var(--muted);
190
+ border-bottom: 1px solid var(--border);
191
+ }
192
+
193
+ .code-block .copy-button:hover {
194
+ color: var(--devdoc-primary);
195
+ }
196
+
197
+ /* Syntax highlighting accent */
198
+ .token.function,
199
+ .token.class-name {
200
+ color: var(--devdoc-primary);
201
+ }
202
+ ```
203
+
204
+ #### API Playground
205
+
206
+ ```css
207
+ /* API playground branding */
208
+ .api-method-get {
209
+ background-color: #10b981;
210
+ }
211
+
212
+ .api-method-post {
213
+ background-color: var(--devdoc-primary);
214
+ }
215
+
216
+ .api-method-put {
217
+ background-color: #f59e0b;
218
+ }
219
+
220
+ .api-method-delete {
221
+ background-color: #ef4444;
222
+ }
223
+
224
+ .try-it-button {
225
+ background-color: var(--devdoc-primary);
226
+ }
227
+
228
+ .try-it-button:hover {
229
+ background-color: var(--devdoc-primary-dark);
230
+ }
231
+ ```
232
+
233
+ #### Navigation
234
+
235
+ ```css
236
+ /* Sidebar navigation */
237
+ .nav-link {
238
+ color: var(--foreground);
239
+ transition: color 0.2s;
240
+ }
241
+
242
+ .nav-link:hover {
243
+ color: var(--devdoc-primary);
244
+ }
245
+
246
+ .nav-link.active {
247
+ color: var(--devdoc-primary);
248
+ font-weight: 500;
249
+ }
250
+
251
+ .nav-group-title {
252
+ color: var(--muted-foreground);
253
+ font-weight: 600;
254
+ }
255
+
256
+ /* Tab navigation */
257
+ .nav-tab.active {
258
+ color: var(--devdoc-primary);
259
+ border-bottom: 2px solid var(--devdoc-primary);
260
+ }
261
+ ```
262
+
263
+ #### Search
264
+
265
+ ```css
266
+ /* Search styling */
267
+ .search-input:focus {
268
+ border-color: var(--devdoc-primary);
269
+ box-shadow: 0 0 0 2px rgba(var(--devdoc-primary-rgb), 0.2);
270
+ }
271
+
272
+ .search-result:hover {
273
+ background-color: var(--muted);
274
+ }
275
+
276
+ .search-result-title mark {
277
+ background-color: rgba(var(--devdoc-primary-rgb), 0.2);
278
+ color: var(--devdoc-primary-dark);
279
+ }
280
+ ```
281
+
282
+ #### Table of Contents
283
+
284
+ ```css
285
+ /* TOC styling */
286
+ .toc-link {
287
+ color: var(--muted-foreground);
288
+ }
289
+
290
+ .toc-link:hover {
291
+ color: var(--devdoc-primary);
292
+ }
293
+
294
+ .toc-link.active {
295
+ color: var(--devdoc-primary);
296
+ font-weight: 500;
297
+ }
298
+
299
+ .toc-indicator {
300
+ background-color: var(--devdoc-primary);
301
+ }
302
+ ```
303
+
304
+ #### Steps Component
305
+
306
+ ```css
307
+ /* Steps styling */
308
+ .step-number {
309
+ background-color: var(--devdoc-primary);
310
+ color: white;
311
+ border-radius: 50%;
312
+ }
313
+
314
+ .step-connector {
315
+ background-color: var(--border);
316
+ }
317
+
318
+ .step-completed .step-number {
319
+ background-color: var(--devdoc-primary);
320
+ }
321
+
322
+ .step-completed .step-connector {
323
+ background-color: var(--devdoc-primary);
324
+ }
325
+ ```
326
+
327
+ #### Tooltips
328
+
329
+ ```css
330
+ /* Tooltip styling */
331
+ .tooltip {
332
+ background-color: var(--foreground);
333
+ color: var(--background);
334
+ border-radius: 0.375rem;
335
+ }
336
+
337
+ .tooltip-arrow {
338
+ fill: var(--foreground);
339
+ }
340
+ ```
341
+
342
+ ### Step 6: Project-Specific Customizations
343
+
344
+ Based on detected project type, add specific styles:
345
+
346
+ #### For API Documentation
347
+ ```css
348
+ /* API-specific styles */
349
+ .endpoint-badge {
350
+ font-family: var(--devdoc-code-font-family);
351
+ font-weight: 600;
352
+ }
353
+
354
+ .response-status.success {
355
+ color: #10b981;
356
+ }
357
+
358
+ .response-status.error {
359
+ color: #ef4444;
360
+ }
361
+
362
+ .schema-property {
363
+ border-left: 2px solid var(--border);
364
+ }
365
+
366
+ .schema-property:hover {
367
+ border-left-color: var(--devdoc-primary);
368
+ }
369
+ ```
370
+
371
+ #### For SDK/Library Documentation
372
+ ```css
373
+ /* SDK-specific styles */
374
+ .language-selector {
375
+ border: 1px solid var(--border);
376
+ }
377
+
378
+ .language-selector button.active {
379
+ background-color: var(--devdoc-primary);
380
+ color: white;
381
+ }
382
+
383
+ .install-command {
384
+ background: var(--muted);
385
+ border-radius: 0.5rem;
386
+ font-family: var(--devdoc-code-font-family);
387
+ }
388
+ ```
389
+
390
+ #### For Product Documentation
391
+ ```css
392
+ /* Product-specific styles */
393
+ .feature-card {
394
+ border: 1px solid var(--border);
395
+ border-radius: 0.75rem;
396
+ }
397
+
398
+ .feature-card:hover {
399
+ border-color: var(--devdoc-primary);
400
+ }
401
+
402
+ .feature-icon {
403
+ color: var(--devdoc-primary);
404
+ font-size: 2rem;
405
+ }
406
+
407
+ .screenshot {
408
+ border: 1px solid var(--border);
409
+ border-radius: 0.5rem;
410
+ box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
411
+ }
412
+ ```
413
+
414
+ ### Step 7: Complete custom.css Template
415
+
416
+ Generate the full `custom.css` with all branded components:
417
+
418
+ ```css
419
+ /* {ProductName} Documentation Theme */
420
+ /* Generated by DevDoc whisk-theme */
421
+
422
+ /* ============================================
423
+ 1. CSS Variables
424
+ ============================================ */
425
+
426
+ :root {
427
+ /* Brand Colors */
428
+ --devdoc-primary: {primary};
429
+ --devdoc-primary-light: {primaryLight};
430
+ --devdoc-primary-dark: {primaryDark};
431
+ --devdoc-primary-rgb: {primaryRGB};
432
+
433
+ /* Typography */
434
+ --devdoc-font-family: '{font}', system-ui, sans-serif;
435
+ --devdoc-heading-font-family: '{font}', system-ui, sans-serif;
436
+ --devdoc-code-font-family: 'JetBrains Mono', 'Fira Code', monospace;
437
+
438
+ /* Layout */
439
+ --devdoc-sidebar-width: 280px;
440
+ --devdoc-content-max-width: 768px;
441
+ }
442
+
443
+ /* ============================================
444
+ 2. Base Styles
445
+ ============================================ */
446
+
447
+ * {
448
+ transition: background-color 0.2s ease, border-color 0.2s ease, color 0.2s ease;
449
+ }
450
+
451
+ ::selection {
452
+ background-color: var(--devdoc-primary);
453
+ color: white;
454
+ }
455
+
456
+ /* ============================================
457
+ 3. Links
458
+ ============================================ */
459
+
460
+ .docs-content a:not([class]) {
461
+ color: var(--devdoc-primary);
462
+ text-decoration: underline;
463
+ text-underline-offset: 2px;
464
+ }
465
+
466
+ .docs-content a:not([class]):hover {
467
+ color: var(--devdoc-primary-dark);
468
+ }
469
+
470
+ /* ============================================
471
+ 4. Navigation
472
+ ============================================ */
473
+
474
+ .nav-link:hover { color: var(--devdoc-primary); }
475
+ .nav-link.active { color: var(--devdoc-primary); font-weight: 500; }
476
+ .nav-tab.active { color: var(--devdoc-primary); border-bottom: 2px solid var(--devdoc-primary); }
477
+
478
+ /* ============================================
479
+ 5. Components
480
+ ============================================ */
481
+
482
+ /* Buttons */
483
+ .btn-primary { background-color: var(--devdoc-primary); color: white; }
484
+ .btn-primary:hover { background-color: var(--devdoc-primary-dark); }
485
+
486
+ /* Cards */
487
+ .card:hover { border-color: var(--devdoc-primary); }
488
+ .card-icon { color: var(--devdoc-primary); }
489
+
490
+ /* Callouts */
491
+ .callout { border-left: 4px solid var(--devdoc-primary); }
492
+
493
+ /* Tabs */
494
+ .tabs-trigger[data-state="active"] { color: var(--devdoc-primary); border-bottom-color: var(--devdoc-primary); }
495
+
496
+ /* Accordions */
497
+ .accordion-trigger[data-state="open"] { color: var(--devdoc-primary); }
498
+
499
+ /* Steps */
500
+ .step-number { background-color: var(--devdoc-primary); color: white; }
501
+
502
+ /* Search */
503
+ .search-input:focus { border-color: var(--devdoc-primary); }
504
+ .search-result-title mark { background-color: rgba(var(--devdoc-primary-rgb), 0.2); }
505
+
506
+ /* TOC */
507
+ .toc-link.active { color: var(--devdoc-primary); }
508
+ .toc-indicator { background-color: var(--devdoc-primary); }
509
+
510
+ /* ============================================
511
+ 6. Code
512
+ ============================================ */
513
+
514
+ pre code {
515
+ font-family: var(--devdoc-code-font-family);
516
+ font-size: 0.875rem;
517
+ line-height: 1.7;
518
+ }
519
+
520
+ :not(pre) > code {
521
+ background-color: var(--muted);
522
+ padding: 0.125rem 0.375rem;
523
+ border-radius: 0.25rem;
524
+ font-size: 0.875em;
525
+ }
526
+
527
+ .code-block .copy-button:hover { color: var(--devdoc-primary); }
528
+
529
+ /* ============================================
530
+ 7. API Reference
531
+ ============================================ */
532
+
533
+ .api-method-post { background-color: var(--devdoc-primary); }
534
+ .try-it-button { background-color: var(--devdoc-primary); }
535
+ .try-it-button:hover { background-color: var(--devdoc-primary-dark); }
536
+ ```
537
+
538
+ ### Step 8: Confirm Changes
539
+
540
+ ```
541
+ ✅ Theme & Components Updated!
542
+
543
+ Files modified:
544
+ ✓ theme.json - brand colors, typography
545
+ ✓ custom.css - variables, components, styles
546
+ ✓ docs.json - logo paths
547
+ ✓ public/logo.svg - copied
548
+
549
+ Components branded:
550
+ • Navigation (sidebar, tabs, TOC)
551
+ • Buttons (primary, secondary)
552
+ • Cards & Card groups
553
+ • Callouts & Notices
554
+ • Tabs & Accordions
555
+ • Code blocks
556
+ • Search
557
+ • API playground
558
+ • Steps component
559
+
560
+ Run `devdoc dev` to preview!
561
+ ```
@@ -0,0 +1,301 @@
1
+ ---
2
+ description: Analyze repository branding and generate custom theme for documentation
3
+ globs: ["**/theme.json", "**/custom.css", "**/tailwind.config.*", "**/*.css", "**/*.scss"]
4
+ ---
5
+
6
+ # Whisk Theme - Brand Analysis & Theme Generation
7
+
8
+ When asked to "whisk theme", "generate theme", "customize branding", or "match brand":
9
+
10
+ ## Step 1: Scan for Brand Colors
11
+
12
+ Search these sources in order of priority:
13
+
14
+ ### 1a. Tailwind Config (highest priority)
15
+ ```javascript
16
+ // tailwind.config.js or tailwind.config.ts
17
+ theme: {
18
+ colors: {
19
+ primary: '#xxx', // → primary
20
+ secondary: '#xxx', // → accent
21
+ brand: '#xxx', // → primary
22
+ }
23
+ }
24
+ ```
25
+
26
+ ### 1b. CSS Variables
27
+ ```css
28
+ /* Look in: globals.css, variables.css, theme.css, app.css */
29
+ :root {
30
+ --primary: #xxx;
31
+ --brand-color: #xxx;
32
+ --accent: #xxx;
33
+ --color-primary: #xxx;
34
+ }
35
+ ```
36
+
37
+ ### 1c. SCSS Variables
38
+ ```scss
39
+ /* Look in: _variables.scss, _colors.scss */
40
+ $primary: #xxx;
41
+ $brand-color: #xxx;
42
+ $accent-color: #xxx;
43
+ ```
44
+
45
+ ### 1d. UI Framework Themes
46
+ ```javascript
47
+ // Chakra UI: theme.js
48
+ colors: { brand: { 500: '#xxx' } }
49
+
50
+ // MUI: theme.js
51
+ palette: { primary: { main: '#xxx' } }
52
+
53
+ // shadcn: globals.css
54
+ --primary: 220 90% 56%;
55
+ ```
56
+
57
+ ### 1e. Package.json / Brand Files
58
+ ```json
59
+ // package.json (rare but check)
60
+ { "brand": { "color": "#xxx" } }
61
+
62
+ // brand.json, colors.json
63
+ { "primary": "#xxx" }
64
+ ```
65
+
66
+ ## Step 2: Scan for Logo
67
+
68
+ Search for logo files:
69
+ ```
70
+ public/logo.svg, public/logo.png
71
+ assets/logo.*, images/logo.*
72
+ src/assets/logo.*
73
+ favicon.svg, favicon.ico
74
+ ```
75
+
76
+ **If SVG logo found:**
77
+ - Extract fill colors as potential brand colors
78
+ - Note path for docs.json update
79
+
80
+ ## Step 3: Scan for Fonts
81
+
82
+ ```javascript
83
+ // tailwind.config.js
84
+ fontFamily: {
85
+ sans: ['CustomFont', ...],
86
+ }
87
+
88
+ // CSS
89
+ --font-family: 'CustomFont';
90
+ font-family: 'CustomFont', sans-serif;
91
+
92
+ // Next.js fonts
93
+ import { Inter } from 'next/font/google'
94
+ ```
95
+
96
+ ## Step 4: Present Findings
97
+
98
+ Show user what was discovered:
99
+
100
+ ```
101
+ 🎨 Brand Analysis Complete
102
+
103
+ Colors detected:
104
+ Primary: #3B82F6 ████ (from tailwind.config.js)
105
+ Secondary: #10B981 ████ (from tailwind.config.js)
106
+
107
+ Logo found:
108
+ public/logo.svg
109
+
110
+ Font detected:
111
+ Inter (from next/font)
112
+
113
+ Apply these to your docs theme?
114
+ 1. **Yes** - Update theme.json and custom.css
115
+ 2. **Customize** - Let me adjust the colors
116
+ 3. **Cancel** - Keep current theme
117
+ ```
118
+
119
+ ## Step 5: Generate Theme Files
120
+
121
+ ### 5a. Update theme.json
122
+
123
+ ```json
124
+ {
125
+ "$schema": "https://devdoc.sh/theme.json",
126
+ "name": "{Product Name} Docs",
127
+ "description": "Custom theme matching {Product Name} branding",
128
+ "colors": {
129
+ "primary": "{detected_primary}",
130
+ "primaryLight": "{lighten_15%}",
131
+ "primaryDark": "{darken_15%}"
132
+ },
133
+ "typography": {
134
+ "fontFamily": "{detected_font}, system-ui, sans-serif",
135
+ "headingFontFamily": "{detected_font}, system-ui, sans-serif",
136
+ "codeFontFamily": "'JetBrains Mono', 'Fira Code', monospace"
137
+ },
138
+ "header": {
139
+ "showSearch": true,
140
+ "showThemeToggle": true,
141
+ "showAskAI": true
142
+ },
143
+ "layout": {
144
+ "sidebarWidth": 280,
145
+ "contentMaxWidth": 768
146
+ },
147
+ "defaultTheme": "system"
148
+ }
149
+ ```
150
+
151
+ ### 5b. Update custom.css with Branded Components
152
+
153
+ Generate comprehensive component styles based on brand:
154
+
155
+ ```css
156
+ /* {Product Name} Documentation Theme */
157
+ /* Generated by DevDoc whisk-theme */
158
+
159
+ /* === 1. CSS Variables === */
160
+ :root {
161
+ --devdoc-primary: {primary};
162
+ --devdoc-primary-light: {primaryLight};
163
+ --devdoc-primary-dark: {primaryDark};
164
+ --devdoc-primary-rgb: {primaryRGB};
165
+ --devdoc-font-family: '{fontFamily}', system-ui, sans-serif;
166
+ --devdoc-code-font-family: 'JetBrains Mono', monospace;
167
+ }
168
+
169
+ /* === 2. Base === */
170
+ * { transition: background-color 0.2s, border-color 0.2s, color 0.2s; }
171
+ ::selection { background-color: var(--devdoc-primary); color: white; }
172
+
173
+ /* === 3. Links === */
174
+ .docs-content a:not([class]) { color: var(--devdoc-primary); text-decoration: underline; }
175
+ .docs-content a:not([class]):hover { color: var(--devdoc-primary-dark); }
176
+
177
+ /* === 4. Navigation === */
178
+ .nav-link:hover { color: var(--devdoc-primary); }
179
+ .nav-link.active { color: var(--devdoc-primary); font-weight: 500; }
180
+ .nav-tab.active { color: var(--devdoc-primary); border-bottom: 2px solid var(--devdoc-primary); }
181
+ .toc-link:hover, .toc-link.active { color: var(--devdoc-primary); }
182
+ .toc-indicator { background-color: var(--devdoc-primary); }
183
+
184
+ /* === 5. Buttons === */
185
+ .btn-primary { background-color: var(--devdoc-primary); color: white; }
186
+ .btn-primary:hover { background-color: var(--devdoc-primary-dark); }
187
+ .btn-secondary { border: 1px solid var(--devdoc-primary); color: var(--devdoc-primary); }
188
+ .btn-secondary:hover { background-color: var(--devdoc-primary); color: white; }
189
+
190
+ /* === 6. Cards === */
191
+ .card:hover { border-color: var(--devdoc-primary); box-shadow: 0 4px 12px rgba(var(--devdoc-primary-rgb), 0.15); }
192
+ .card-icon { color: var(--devdoc-primary); }
193
+
194
+ /* === 7. Callouts === */
195
+ .callout { border-left: 4px solid var(--devdoc-primary); }
196
+ .callout-info { border-left-color: var(--devdoc-primary); }
197
+ .callout-tip { border-left-color: #10b981; }
198
+ .callout-warning { border-left-color: #f59e0b; }
199
+ .callout-danger { border-left-color: #ef4444; }
200
+
201
+ /* === 8. Tabs === */
202
+ .tabs-trigger[data-state="active"] { color: var(--devdoc-primary); border-bottom-color: var(--devdoc-primary); }
203
+ .tabs-trigger:hover { color: var(--devdoc-primary-dark); }
204
+
205
+ /* === 9. Accordions === */
206
+ .accordion-trigger:hover { color: var(--devdoc-primary); }
207
+ .accordion-trigger[data-state="open"] { color: var(--devdoc-primary); }
208
+ .accordion-trigger[data-state="open"] svg { color: var(--devdoc-primary); }
209
+
210
+ /* === 10. Steps === */
211
+ .step-number { background-color: var(--devdoc-primary); color: white; border-radius: 50%; }
212
+ .step-completed .step-connector { background-color: var(--devdoc-primary); }
213
+
214
+ /* === 11. Code === */
215
+ pre code { font-family: var(--devdoc-code-font-family); font-size: 0.875rem; line-height: 1.7; }
216
+ :not(pre) > code { background-color: var(--muted); padding: 0.125rem 0.375rem; border-radius: 0.25rem; }
217
+ .code-block .copy-button:hover { color: var(--devdoc-primary); }
218
+
219
+ /* === 12. Search === */
220
+ .search-input:focus { border-color: var(--devdoc-primary); box-shadow: 0 0 0 2px rgba(var(--devdoc-primary-rgb), 0.2); }
221
+ .search-result-title mark { background-color: rgba(var(--devdoc-primary-rgb), 0.2); color: var(--devdoc-primary-dark); }
222
+
223
+ /* === 13. API Reference === */
224
+ .api-method-get { background-color: #10b981; }
225
+ .api-method-post { background-color: var(--devdoc-primary); }
226
+ .api-method-put { background-color: #f59e0b; }
227
+ .api-method-delete { background-color: #ef4444; }
228
+ .try-it-button { background-color: var(--devdoc-primary); }
229
+ .try-it-button:hover { background-color: var(--devdoc-primary-dark); }
230
+ .schema-property:hover { border-left-color: var(--devdoc-primary); }
231
+
232
+ /* === 14. Features (Product Docs) === */
233
+ .feature-card:hover { border-color: var(--devdoc-primary); }
234
+ .feature-icon { color: var(--devdoc-primary); }
235
+ ```
236
+
237
+ ### 5c. Copy Logo (if found and not already in docs)
238
+
239
+ ```
240
+ 1. Copy logo to docs/public/logo.svg
241
+ 2. If dark variant exists, copy to docs/public/logo-dark.svg
242
+ 3. Update docs.json:
243
+
244
+ {
245
+ "logo": {
246
+ "light": "/logo.svg",
247
+ "dark": "/logo-dark.svg" // or same as light
248
+ }
249
+ }
250
+ ```
251
+
252
+ ## Step 6: Confirm Changes
253
+
254
+ ```
255
+ ✅ Theme updated!
256
+
257
+ Files modified:
258
+ - theme.json (colors, fonts)
259
+ - custom.css (brand variables, styles)
260
+ - docs.json (logo paths)
261
+ - public/logo.svg (copied from source)
262
+
263
+ Preview your docs with `devdoc dev` to see the changes.
264
+ ```
265
+
266
+ ## Color Utilities
267
+
268
+ When generating lighter/darker variants:
269
+
270
+ ```
271
+ Primary: #3B82F6
272
+ → primaryLight: lighten by 15% → #60A5FA
273
+ → primaryDark: darken by 15% → #2563EB
274
+ ```
275
+
276
+ **HSL method (preferred):**
277
+ - Light: increase L by 10-15%
278
+ - Dark: decrease L by 10-15%
279
+
280
+ ## Common Brand Patterns
281
+
282
+ | Framework | Primary Color Location |
283
+ |-----------|----------------------|
284
+ | Tailwind | `theme.colors.primary` or `theme.extend.colors` |
285
+ | Chakra UI | `theme.colors.brand.500` |
286
+ | MUI | `palette.primary.main` |
287
+ | shadcn/ui | `--primary` in HSL format |
288
+ | Bootstrap | `$primary` SCSS variable |
289
+ | Ant Design | `@primary-color` |
290
+
291
+ ## Fallback Defaults
292
+
293
+ If no brand colors detected:
294
+ ```
295
+ Primary: #10b981 (DevDoc green)
296
+ Font: Inter, system-ui, sans-serif
297
+ ```
298
+
299
+ Ask user: "No brand colors found. Would you like to:
300
+ 1. Enter your brand color (hex)
301
+ 2. Use DevDoc defaults"
@@ -85,6 +85,7 @@ async function promptSelect(question, choices) {
85
85
  // Claude Code skills to create
86
86
  const CLAUDE_SKILLS = [
87
87
  'bootstrap-docs',
88
+ 'whisk-theme',
88
89
  'migrate-docs',
89
90
  'import-api-spec',
90
91
  'check-docs',
@@ -98,6 +99,7 @@ const CLAUDE_SKILLS = [
98
99
  const CURSOR_RULES = [
99
100
  'devdoc.mdc',
100
101
  'devdoc-bootstrap.mdc',
102
+ 'devdoc-whisk-theme.mdc',
101
103
  'devdoc-migrate.mdc',
102
104
  'devdoc-blame.mdc',
103
105
  'devdoc-create.mdc',
@@ -313,6 +315,7 @@ async function ai(options) {
313
315
  if (tool === 'claude' || tool === 'both') {
314
316
  console.log('Available Claude Code commands:');
315
317
  console.log(' /bootstrap-docs - Analyze repo and generate initial documentation');
318
+ console.log(' /whisk-theme - Analyze branding and generate custom theme');
316
319
  console.log(' /migrate-docs - Migrate from Mintlify, Docusaurus, GitBook, etc.');
317
320
  console.log(' /import-api-spec - Import OpenAPI, GraphQL, or AsyncAPI specs');
318
321
  console.log(' /check-docs - Quick health check without changes');
@@ -328,6 +331,7 @@ async function ai(options) {
328
331
  console.log();
329
332
  console.log('Suggested prompts in Agent mode:');
330
333
  console.log(' "Analyze this repo and generate initial documentation"');
334
+ console.log(' "Whisk theme - match docs to my brand colors"');
331
335
  console.log(' "Migrate my Mintlify docs to DevDoc format"');
332
336
  console.log(' "Check my docs for outdated content"');
333
337
  console.log(' "Create a new guide about authentication"');
@@ -346,4 +350,4 @@ async function ai(options) {
346
350
  console.log();
347
351
  }
348
352
  }
349
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ai.js","sourceRoot":"","sources":["../../../src/cli/commands/ai.ts"],"names":[],"mappings":"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","sourcesContent":["import path from 'path';\nimport fs from 'fs-extra';\nimport { logger } from '../../utils/logger';\n\ntype AITool = 'claude' | 'cursor' | 'both';\n\ninterface AIOptions {\n  tool?: AITool;\n  update?: boolean;\n}\n\n// Simple prompt helper using readline\nasync function prompt(question: string, defaultValue?: string): Promise<string> {\n  const readline = await import('readline');\n  const rl = readline.createInterface({\n    input: process.stdin,\n    output: process.stdout,\n  });\n\n  return new Promise((resolve) => {\n    const displayQuestion = defaultValue \n      ? `${question} (${defaultValue}): `\n      : `${question}: `;\n    \n    rl.question(displayQuestion, (answer) => {\n      rl.close();\n      resolve(answer.trim() || defaultValue || '');\n    });\n  });\n}\n\nasync function promptSelect(question: string, choices: { value: string; label: string }[]): Promise<string> {\n  console.log(`\\n${question}\\n`);\n  choices.forEach((choice, i) => {\n    console.log(`  ${i + 1}. ${choice.label}`);\n  });\n  console.log();\n  \n  const readline = await import('readline');\n  const rl = readline.createInterface({\n    input: process.stdin,\n    output: process.stdout,\n  });\n\n  return new Promise((resolve) => {\n    rl.question('Enter number: ', (answer) => {\n      rl.close();\n      const index = parseInt(answer.trim(), 10) - 1;\n      if (index >= 0 && index < choices.length) {\n        resolve(choices[index].value);\n      } else {\n        // Default to first choice\n        resolve(choices[0].value);\n      }\n    });\n  });\n}\n\n// Claude Code skills to create\nconst CLAUDE_SKILLS = [\n  'bootstrap-docs',\n  'migrate-docs',\n  'import-api-spec',\n  'check-docs',\n  'blame-doc',\n  'create-doc',\n  'update-doc',\n  'delete-doc',\n  'commit-doc',\n];\n\n// Cursor rules to create\nconst CURSOR_RULES = [\n  'devdoc.mdc',\n  'devdoc-bootstrap.mdc',\n  'devdoc-migrate.mdc',\n  'devdoc-blame.mdc',\n  'devdoc-create.mdc',\n  'devdoc-update.mdc',\n  'devdoc-delete.mdc',\n  'devdoc-commit.mdc',\n];\n\n/**\n * Get the AI agents template directory path (handles both development and installed package scenarios)\n */\nfunction getTemplateDir(): string {\n  // Try relative to compiled dist (packages/devdoc/dist/cli/commands -> packages/devdoc/ai-agents)\n  let templateDir = path.join(__dirname, '..', '..', '..', 'ai-agents');\n  \n  if (fs.existsSync(templateDir)) {\n    return templateDir;\n  }\n  \n  // Try relative to source (packages/devdoc/src/cli/commands -> packages/devdoc/ai-agents)\n  templateDir = path.join(__dirname, '..', '..', '..', 'ai-agents');\n  \n  if (fs.existsSync(templateDir)) {\n    return templateDir;\n  }\n  \n  // Try devdoc/templates at repo root (development - monorepo structure)\n  // __dirname is packages/devdoc/dist/cli/commands -> go up 5 levels to repo root\n  templateDir = path.join(__dirname, '..', '..', '..', '..', '..', 'devdoc', 'templates', 'starter');\n  \n  if (fs.existsSync(templateDir)) {\n    return templateDir;\n  }\n  \n  throw new Error('Could not find template directory');\n}\n\n/**\n * Copy CLAUDE.md to project root\n * Returns 'created' | 'updated' | 'skipped'\n */\nfunction copyClaudeMd(projectPath: string, templateDir: string): 'created' | 'updated' | 'skipped' {\n  const sourcePath = path.join(templateDir, 'CLAUDE.md');\n  const destPath = path.join(projectPath, 'CLAUDE.md');\n  \n  if (!fs.existsSync(sourcePath)) {\n    return 'skipped';\n  }\n  \n  const existed = fs.existsSync(destPath);\n  fs.copySync(sourcePath, destPath);\n  return existed ? 'updated' : 'created';\n}\n\n/**\n * Copy Claude Code skills to .claude/skills/\n * Returns array of { skill, status: 'created' | 'updated' }\n */\nfunction copyClaudeSkills(projectPath: string, templateDir: string): { skill: string; status: 'created' | 'updated' }[] {\n  const results: { skill: string; status: 'created' | 'updated' }[] = [];\n  const sourceSkillsDir = path.join(templateDir, '.claude', 'skills');\n  const destSkillsDir = path.join(projectPath, '.claude', 'skills');\n  \n  if (!fs.existsSync(sourceSkillsDir)) {\n    logger.warn('Claude skills template directory not found');\n    return results;\n  }\n  \n  // Ensure destination directory exists\n  fs.ensureDirSync(destSkillsDir);\n  \n  for (const skill of CLAUDE_SKILLS) {\n    const sourceDir = path.join(sourceSkillsDir, skill);\n    const destDir = path.join(destSkillsDir, skill);\n    \n    if (fs.existsSync(sourceDir)) {\n      const existed = fs.existsSync(destDir);\n      fs.copySync(sourceDir, destDir);\n      results.push({ skill, status: existed ? 'updated' : 'created' });\n    }\n  }\n  \n  return results;\n}\n\n/**\n * Copy Cursor rules to .cursor/rules/\n * Returns array of { rule, status: 'created' | 'updated' }\n */\nfunction copyCursorRules(projectPath: string, templateDir: string): { rule: string; status: 'created' | 'updated' }[] {\n  const results: { rule: string; status: 'created' | 'updated' }[] = [];\n  const sourceRulesDir = path.join(templateDir, '.cursor', 'rules');\n  const destRulesDir = path.join(projectPath, '.cursor', 'rules');\n  \n  if (!fs.existsSync(sourceRulesDir)) {\n    logger.warn('Cursor rules template directory not found');\n    return results;\n  }\n  \n  // Ensure destination directory exists\n  fs.ensureDirSync(destRulesDir);\n  \n  for (const rule of CURSOR_RULES) {\n    const sourcePath = path.join(sourceRulesDir, rule);\n    const destPath = path.join(destRulesDir, rule);\n    \n    if (fs.existsSync(sourcePath)) {\n      const existed = fs.existsSync(destPath);\n      fs.copySync(sourcePath, destPath);\n      results.push({ rule, status: existed ? 'updated' : 'created' });\n    }\n  }\n  \n  return results;\n}\n\n/**\n * Check if AI tools are already installed\n */\nfunction checkExistingInstallation(projectPath: string): { claude: boolean; cursor: boolean } {\n  const claudeDir = path.join(projectPath, '.claude', 'skills');\n  const cursorDir = path.join(projectPath, '.cursor', 'rules');\n  \n  return {\n    claude: fs.existsSync(claudeDir) && fs.readdirSync(claudeDir).length > 0,\n    cursor: fs.existsSync(cursorDir) && fs.readdirSync(cursorDir).some(f => f.startsWith('devdoc')),\n  };\n}\n\nexport async function ai(options: AIOptions): Promise<void> {\n  console.log();\n  \n  const projectPath = process.cwd();\n  const existing = checkExistingInstallation(projectPath);\n  const isUpdate = options.update || existing.claude || existing.cursor;\n  \n  if (isUpdate) {\n    logger.info('DevDoc AI Agent Update');\n  } else {\n    logger.info('DevDoc AI Agent Setup');\n  }\n  console.log();\n\n  // Check if this is a DevDoc project\n  const docsJsonPath = path.join(projectPath, 'docs.json');\n  const hasDocsJson = fs.existsSync(docsJsonPath);\n  \n  if (!hasDocsJson) {\n    logger.warn('No docs.json found. This may not be a DevDoc project.');\n    console.log();\n  }\n\n  // Get template directory\n  let templateDir: string;\n  try {\n    templateDir = getTemplateDir();\n  } catch {\n    logger.error('Could not find AI agent templates. Please ensure DevDoc is installed correctly.');\n    process.exit(1);\n  }\n\n  // Get tool selection if not provided\n  let tool: AITool = options.tool || 'both';\n  \n  if (!options.tool) {\n    // If updating, default to updating what's already installed\n    if (isUpdate && existing.claude && !existing.cursor) {\n      tool = 'claude';\n    } else if (isUpdate && existing.cursor && !existing.claude) {\n      tool = 'cursor';\n    } else {\n      const toolChoices = [\n        { value: 'both', label: 'Both - Claude Code and Cursor' },\n        { value: 'claude', label: 'Claude Code - Skills and CLAUDE.md' },\n        { value: 'cursor', label: 'Cursor - Rules (.cursor/rules/)' },\n      ];\n\n      tool = await promptSelect('Which AI tool do you use?', toolChoices) as AITool;\n    }\n  }\n\n  console.log();\n  if (isUpdate) {\n    logger.info('Updating AI agent configuration...');\n  } else {\n    logger.info('Setting up AI agent configuration...');\n  }\n  console.log();\n\n  let createdCount = 0;\n  let updatedCount = 0;\n\n  // Setup Claude Code\n  if (tool === 'claude' || tool === 'both') {\n    // Copy CLAUDE.md\n    const claudeMdStatus = copyClaudeMd(projectPath, templateDir);\n    if (claudeMdStatus === 'created') {\n      logger.success('Created CLAUDE.md');\n      createdCount++;\n    } else if (claudeMdStatus === 'updated') {\n      logger.success('Updated CLAUDE.md');\n      updatedCount++;\n    }\n    \n    // Copy skills\n    const skillResults = copyClaudeSkills(projectPath, templateDir);\n    for (const { skill, status } of skillResults) {\n      if (status === 'created') {\n        logger.success(`Created .claude/skills/${skill}/SKILL.md`);\n        createdCount++;\n      } else {\n        logger.success(`Updated .claude/skills/${skill}/SKILL.md`);\n        updatedCount++;\n      }\n    }\n  }\n\n  // Setup Cursor\n  if (tool === 'cursor' || tool === 'both') {\n    const ruleResults = copyCursorRules(projectPath, templateDir);\n    for (const { rule, status } of ruleResults) {\n      if (status === 'created') {\n        logger.success(`Created .cursor/rules/${rule}`);\n        createdCount++;\n      } else {\n        logger.success(`Updated .cursor/rules/${rule}`);\n        updatedCount++;\n      }\n    }\n  }\n\n  // Summary\n  console.log();\n  if (updatedCount > 0 && createdCount > 0) {\n    logger.success(`AI agent configuration complete! (${createdCount} created, ${updatedCount} updated)`);\n  } else if (updatedCount > 0) {\n    logger.success(`AI agent configuration updated! (${updatedCount} files)`);\n  } else {\n    logger.success('AI agent configuration complete!');\n  }\n  console.log();\n\n  if (tool === 'claude' || tool === 'both') {\n    console.log('Available Claude Code commands:');\n    console.log('  /bootstrap-docs    - Analyze repo and generate initial documentation');\n    console.log('  /migrate-docs      - Migrate from Mintlify, Docusaurus, GitBook, etc.');\n    console.log('  /import-api-spec   - Import OpenAPI, GraphQL, or AsyncAPI specs');\n    console.log('  /check-docs        - Quick health check without changes');\n    console.log('  /blame-doc         - Find duplicates, outdated content, discrepancies');\n    console.log('  /create-doc        - Create a new documentation page');\n    console.log('  /update-doc        - Update existing documentation');\n    console.log('  /delete-doc        - Delete documentation pages');\n    console.log('  /commit-doc        - Commit documentation changes');\n    console.log();\n  }\n\n  if (tool === 'cursor' || tool === 'both') {\n    console.log('Cursor rules configured for *.mdx files.');\n    console.log();\n    console.log('Suggested prompts in Agent mode:');\n    console.log('  \"Analyze this repo and generate initial documentation\"');\n    console.log('  \"Migrate my Mintlify docs to DevDoc format\"');\n    console.log('  \"Check my docs for outdated content\"');\n    console.log('  \"Create a new guide about authentication\"');\n    console.log();\n  }\n\n  console.log('Quick start:');\n  if (tool === 'claude' || tool === 'both') {\n    console.log('  Claude Code: /bootstrap-docs');\n  }\n  if (tool === 'cursor' || tool === 'both') {\n    console.log('  Cursor: Ask \"generate initial documentation from this repo\"');\n  }\n  console.log();\n  \n  if (isUpdate) {\n    console.log('Tip: Restart Claude Code or Cursor to load the updated skills/rules.');\n    console.log();\n  }\n}\n"]}
353
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ai.js","sourceRoot":"","sources":["../../../src/cli/commands/ai.ts"],"names":[],"mappings":"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","sourcesContent":["import path from 'path';\nimport fs from 'fs-extra';\nimport { logger } from '../../utils/logger';\n\ntype AITool = 'claude' | 'cursor' | 'both';\n\ninterface AIOptions {\n  tool?: AITool;\n  update?: boolean;\n}\n\n// Simple prompt helper using readline\nasync function prompt(question: string, defaultValue?: string): Promise<string> {\n  const readline = await import('readline');\n  const rl = readline.createInterface({\n    input: process.stdin,\n    output: process.stdout,\n  });\n\n  return new Promise((resolve) => {\n    const displayQuestion = defaultValue \n      ? `${question} (${defaultValue}): `\n      : `${question}: `;\n    \n    rl.question(displayQuestion, (answer) => {\n      rl.close();\n      resolve(answer.trim() || defaultValue || '');\n    });\n  });\n}\n\nasync function promptSelect(question: string, choices: { value: string; label: string }[]): Promise<string> {\n  console.log(`\\n${question}\\n`);\n  choices.forEach((choice, i) => {\n    console.log(`  ${i + 1}. ${choice.label}`);\n  });\n  console.log();\n  \n  const readline = await import('readline');\n  const rl = readline.createInterface({\n    input: process.stdin,\n    output: process.stdout,\n  });\n\n  return new Promise((resolve) => {\n    rl.question('Enter number: ', (answer) => {\n      rl.close();\n      const index = parseInt(answer.trim(), 10) - 1;\n      if (index >= 0 && index < choices.length) {\n        resolve(choices[index].value);\n      } else {\n        // Default to first choice\n        resolve(choices[0].value);\n      }\n    });\n  });\n}\n\n// Claude Code skills to create\nconst CLAUDE_SKILLS = [\n  'bootstrap-docs',\n  'whisk-theme',\n  'migrate-docs',\n  'import-api-spec',\n  'check-docs',\n  'blame-doc',\n  'create-doc',\n  'update-doc',\n  'delete-doc',\n  'commit-doc',\n];\n\n// Cursor rules to create\nconst CURSOR_RULES = [\n  'devdoc.mdc',\n  'devdoc-bootstrap.mdc',\n  'devdoc-whisk-theme.mdc',\n  'devdoc-migrate.mdc',\n  'devdoc-blame.mdc',\n  'devdoc-create.mdc',\n  'devdoc-update.mdc',\n  'devdoc-delete.mdc',\n  'devdoc-commit.mdc',\n];\n\n/**\n * Get the AI agents template directory path (handles both development and installed package scenarios)\n */\nfunction getTemplateDir(): string {\n  // Try relative to compiled dist (packages/devdoc/dist/cli/commands -> packages/devdoc/ai-agents)\n  let templateDir = path.join(__dirname, '..', '..', '..', 'ai-agents');\n  \n  if (fs.existsSync(templateDir)) {\n    return templateDir;\n  }\n  \n  // Try relative to source (packages/devdoc/src/cli/commands -> packages/devdoc/ai-agents)\n  templateDir = path.join(__dirname, '..', '..', '..', 'ai-agents');\n  \n  if (fs.existsSync(templateDir)) {\n    return templateDir;\n  }\n  \n  // Try devdoc/templates at repo root (development - monorepo structure)\n  // __dirname is packages/devdoc/dist/cli/commands -> go up 5 levels to repo root\n  templateDir = path.join(__dirname, '..', '..', '..', '..', '..', 'devdoc', 'templates', 'starter');\n  \n  if (fs.existsSync(templateDir)) {\n    return templateDir;\n  }\n  \n  throw new Error('Could not find template directory');\n}\n\n/**\n * Copy CLAUDE.md to project root\n * Returns 'created' | 'updated' | 'skipped'\n */\nfunction copyClaudeMd(projectPath: string, templateDir: string): 'created' | 'updated' | 'skipped' {\n  const sourcePath = path.join(templateDir, 'CLAUDE.md');\n  const destPath = path.join(projectPath, 'CLAUDE.md');\n  \n  if (!fs.existsSync(sourcePath)) {\n    return 'skipped';\n  }\n  \n  const existed = fs.existsSync(destPath);\n  fs.copySync(sourcePath, destPath);\n  return existed ? 'updated' : 'created';\n}\n\n/**\n * Copy Claude Code skills to .claude/skills/\n * Returns array of { skill, status: 'created' | 'updated' }\n */\nfunction copyClaudeSkills(projectPath: string, templateDir: string): { skill: string; status: 'created' | 'updated' }[] {\n  const results: { skill: string; status: 'created' | 'updated' }[] = [];\n  const sourceSkillsDir = path.join(templateDir, '.claude', 'skills');\n  const destSkillsDir = path.join(projectPath, '.claude', 'skills');\n  \n  if (!fs.existsSync(sourceSkillsDir)) {\n    logger.warn('Claude skills template directory not found');\n    return results;\n  }\n  \n  // Ensure destination directory exists\n  fs.ensureDirSync(destSkillsDir);\n  \n  for (const skill of CLAUDE_SKILLS) {\n    const sourceDir = path.join(sourceSkillsDir, skill);\n    const destDir = path.join(destSkillsDir, skill);\n    \n    if (fs.existsSync(sourceDir)) {\n      const existed = fs.existsSync(destDir);\n      fs.copySync(sourceDir, destDir);\n      results.push({ skill, status: existed ? 'updated' : 'created' });\n    }\n  }\n  \n  return results;\n}\n\n/**\n * Copy Cursor rules to .cursor/rules/\n * Returns array of { rule, status: 'created' | 'updated' }\n */\nfunction copyCursorRules(projectPath: string, templateDir: string): { rule: string; status: 'created' | 'updated' }[] {\n  const results: { rule: string; status: 'created' | 'updated' }[] = [];\n  const sourceRulesDir = path.join(templateDir, '.cursor', 'rules');\n  const destRulesDir = path.join(projectPath, '.cursor', 'rules');\n  \n  if (!fs.existsSync(sourceRulesDir)) {\n    logger.warn('Cursor rules template directory not found');\n    return results;\n  }\n  \n  // Ensure destination directory exists\n  fs.ensureDirSync(destRulesDir);\n  \n  for (const rule of CURSOR_RULES) {\n    const sourcePath = path.join(sourceRulesDir, rule);\n    const destPath = path.join(destRulesDir, rule);\n    \n    if (fs.existsSync(sourcePath)) {\n      const existed = fs.existsSync(destPath);\n      fs.copySync(sourcePath, destPath);\n      results.push({ rule, status: existed ? 'updated' : 'created' });\n    }\n  }\n  \n  return results;\n}\n\n/**\n * Check if AI tools are already installed\n */\nfunction checkExistingInstallation(projectPath: string): { claude: boolean; cursor: boolean } {\n  const claudeDir = path.join(projectPath, '.claude', 'skills');\n  const cursorDir = path.join(projectPath, '.cursor', 'rules');\n  \n  return {\n    claude: fs.existsSync(claudeDir) && fs.readdirSync(claudeDir).length > 0,\n    cursor: fs.existsSync(cursorDir) && fs.readdirSync(cursorDir).some(f => f.startsWith('devdoc')),\n  };\n}\n\nexport async function ai(options: AIOptions): Promise<void> {\n  console.log();\n  \n  const projectPath = process.cwd();\n  const existing = checkExistingInstallation(projectPath);\n  const isUpdate = options.update || existing.claude || existing.cursor;\n  \n  if (isUpdate) {\n    logger.info('DevDoc AI Agent Update');\n  } else {\n    logger.info('DevDoc AI Agent Setup');\n  }\n  console.log();\n\n  // Check if this is a DevDoc project\n  const docsJsonPath = path.join(projectPath, 'docs.json');\n  const hasDocsJson = fs.existsSync(docsJsonPath);\n  \n  if (!hasDocsJson) {\n    logger.warn('No docs.json found. This may not be a DevDoc project.');\n    console.log();\n  }\n\n  // Get template directory\n  let templateDir: string;\n  try {\n    templateDir = getTemplateDir();\n  } catch {\n    logger.error('Could not find AI agent templates. Please ensure DevDoc is installed correctly.');\n    process.exit(1);\n  }\n\n  // Get tool selection if not provided\n  let tool: AITool = options.tool || 'both';\n  \n  if (!options.tool) {\n    // If updating, default to updating what's already installed\n    if (isUpdate && existing.claude && !existing.cursor) {\n      tool = 'claude';\n    } else if (isUpdate && existing.cursor && !existing.claude) {\n      tool = 'cursor';\n    } else {\n      const toolChoices = [\n        { value: 'both', label: 'Both - Claude Code and Cursor' },\n        { value: 'claude', label: 'Claude Code - Skills and CLAUDE.md' },\n        { value: 'cursor', label: 'Cursor - Rules (.cursor/rules/)' },\n      ];\n\n      tool = await promptSelect('Which AI tool do you use?', toolChoices) as AITool;\n    }\n  }\n\n  console.log();\n  if (isUpdate) {\n    logger.info('Updating AI agent configuration...');\n  } else {\n    logger.info('Setting up AI agent configuration...');\n  }\n  console.log();\n\n  let createdCount = 0;\n  let updatedCount = 0;\n\n  // Setup Claude Code\n  if (tool === 'claude' || tool === 'both') {\n    // Copy CLAUDE.md\n    const claudeMdStatus = copyClaudeMd(projectPath, templateDir);\n    if (claudeMdStatus === 'created') {\n      logger.success('Created CLAUDE.md');\n      createdCount++;\n    } else if (claudeMdStatus === 'updated') {\n      logger.success('Updated CLAUDE.md');\n      updatedCount++;\n    }\n    \n    // Copy skills\n    const skillResults = copyClaudeSkills(projectPath, templateDir);\n    for (const { skill, status } of skillResults) {\n      if (status === 'created') {\n        logger.success(`Created .claude/skills/${skill}/SKILL.md`);\n        createdCount++;\n      } else {\n        logger.success(`Updated .claude/skills/${skill}/SKILL.md`);\n        updatedCount++;\n      }\n    }\n  }\n\n  // Setup Cursor\n  if (tool === 'cursor' || tool === 'both') {\n    const ruleResults = copyCursorRules(projectPath, templateDir);\n    for (const { rule, status } of ruleResults) {\n      if (status === 'created') {\n        logger.success(`Created .cursor/rules/${rule}`);\n        createdCount++;\n      } else {\n        logger.success(`Updated .cursor/rules/${rule}`);\n        updatedCount++;\n      }\n    }\n  }\n\n  // Summary\n  console.log();\n  if (updatedCount > 0 && createdCount > 0) {\n    logger.success(`AI agent configuration complete! (${createdCount} created, ${updatedCount} updated)`);\n  } else if (updatedCount > 0) {\n    logger.success(`AI agent configuration updated! (${updatedCount} files)`);\n  } else {\n    logger.success('AI agent configuration complete!');\n  }\n  console.log();\n\n  if (tool === 'claude' || tool === 'both') {\n    console.log('Available Claude Code commands:');\n    console.log('  /bootstrap-docs    - Analyze repo and generate initial documentation');\n    console.log('  /whisk-theme       - Analyze branding and generate custom theme');\n    console.log('  /migrate-docs      - Migrate from Mintlify, Docusaurus, GitBook, etc.');\n    console.log('  /import-api-spec   - Import OpenAPI, GraphQL, or AsyncAPI specs');\n    console.log('  /check-docs        - Quick health check without changes');\n    console.log('  /blame-doc         - Find duplicates, outdated content, discrepancies');\n    console.log('  /create-doc        - Create a new documentation page');\n    console.log('  /update-doc        - Update existing documentation');\n    console.log('  /delete-doc        - Delete documentation pages');\n    console.log('  /commit-doc        - Commit documentation changes');\n    console.log();\n  }\n\n  if (tool === 'cursor' || tool === 'both') {\n    console.log('Cursor rules configured for *.mdx files.');\n    console.log();\n    console.log('Suggested prompts in Agent mode:');\n    console.log('  \"Analyze this repo and generate initial documentation\"');\n    console.log('  \"Whisk theme - match docs to my brand colors\"');\n    console.log('  \"Migrate my Mintlify docs to DevDoc format\"');\n    console.log('  \"Check my docs for outdated content\"');\n    console.log('  \"Create a new guide about authentication\"');\n    console.log();\n  }\n\n  console.log('Quick start:');\n  if (tool === 'claude' || tool === 'both') {\n    console.log('  Claude Code: /bootstrap-docs');\n  }\n  if (tool === 'cursor' || tool === 'both') {\n    console.log('  Cursor: Ask \"generate initial documentation from this repo\"');\n  }\n  console.log();\n  \n  if (isUpdate) {\n    console.log('Tip: Restart Claude Code or Cursor to load the updated skills/rules.');\n    console.log();\n  }\n}\n"]}
@@ -304,6 +304,7 @@ function generateDocsConfig(projectName, templateType) {
304
304
  // Claude Code skills to create
305
305
  const CLAUDE_SKILLS = [
306
306
  'bootstrap-docs',
307
+ 'whisk-theme',
307
308
  'migrate-docs',
308
309
  'import-api-spec',
309
310
  'check-docs',
@@ -317,6 +318,7 @@ const CLAUDE_SKILLS = [
317
318
  const CURSOR_RULES = [
318
319
  'devdoc.mdc',
319
320
  'devdoc-bootstrap.mdc',
321
+ 'devdoc-whisk-theme.mdc',
320
322
  'devdoc-migrate.mdc',
321
323
  'devdoc-blame.mdc',
322
324
  'devdoc-create.mdc',
@@ -717,4 +719,4 @@ async function create(projectDirectory, options) {
717
719
  console.log('Happy documenting!');
718
720
  console.log();
719
721
  }
720
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create.js","sourceRoot":"","sources":["../../../src/cli/commands/create.ts"],"names":[],"mappings":"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","sourcesContent":["import { execSync } from 'child_process';\nimport path from 'path';\nimport fs from 'fs-extra';\nimport { downloadTemplate } from 'giget';\nimport { logger } from '../../utils/logger';\nimport { DEFAULT_API_URL } from '../../constants';\n\n// Remote template repository - single starter template\nconst TEMPLATE_REPO = 'github:brainfish-ai/devdoc/templates/starter';\n\n// Available template types (all use the same starter template, just different configs)\nconst TEMPLATES = {\n  basic: {\n    name: 'Basic',\n    description: 'Simple documentation site with guides and pages',\n    color: '#10b981',\n  },\n  openapi: {\n    name: 'OpenAPI',\n    description: 'Documentation with REST API reference (OpenAPI/Swagger)',\n    color: '#10b981',\n  },\n  graphql: {\n    name: 'GraphQL',\n    description: 'Documentation with GraphQL API playground',\n    color: '#e535ab',\n  },\n} as const;\n\ntype TemplateType = keyof typeof TEMPLATES;\n\n// Documentation types\nconst DOC_TYPES = {\n  public: {\n    name: 'Public',\n    description: 'User-facing docs with custom subdomain and deployment',\n  },\n  internal: {\n    name: 'Internal',\n    description: 'Developer docs for local/private use (no subdomain needed)',\n  },\n} as const;\n\ntype DocType = keyof typeof DOC_TYPES;\n\ninterface CreateOptions {\n  template?: TemplateType;\n  docType?: DocType;\n  git?: boolean;\n  install?: boolean;\n  url?: string;\n  subdomain?: string;\n}\n\ninterface CheckSubdomainResponse {\n  available: boolean;\n  error?: string;\n  suggestion?: string;\n}\n\n// Simple prompt helper using readline\nasync function prompt(question: string, defaultValue?: string): Promise<string> {\n  const readline = await import('readline');\n  const rl = readline.createInterface({\n    input: process.stdin,\n    output: process.stdout,\n  });\n\n  return new Promise((resolve) => {\n    const displayQuestion = defaultValue \n      ? `${question} (${defaultValue}): `\n      : `${question}: `;\n    \n    rl.question(displayQuestion, (answer) => {\n      rl.close();\n      resolve(answer.trim() || defaultValue || '');\n    });\n  });\n}\n\nasync function promptSelect(question: string, choices: { value: string; label: string }[]): Promise<string> {\n  console.log(`\\n${question}\\n`);\n  choices.forEach((choice, i) => {\n    console.log(`  ${i + 1}. ${choice.label}`);\n  });\n  console.log();\n  \n  const readline = await import('readline');\n  const rl = readline.createInterface({\n    input: process.stdin,\n    output: process.stdout,\n  });\n\n  return new Promise((resolve) => {\n    rl.question('Enter number: ', (answer) => {\n      rl.close();\n      const index = parseInt(answer.trim(), 10) - 1;\n      if (index >= 0 && index < choices.length) {\n        resolve(choices[index].value);\n      } else {\n        // Default to first choice\n        resolve(choices[0].value);\n      }\n    });\n  });\n}\n\nasync function promptConfirm(question: string, defaultValue = false): Promise<boolean> {\n  const readline = await import('readline');\n  const rl = readline.createInterface({\n    input: process.stdin,\n    output: process.stdout,\n  });\n\n  return new Promise((resolve) => {\n    const hint = defaultValue ? '[Y/n]' : '[y/N]';\n    rl.question(`${question} ${hint}: `, (answer) => {\n      rl.close();\n      const normalized = answer.trim().toLowerCase();\n      if (normalized === '') {\n        resolve(defaultValue);\n      } else {\n        resolve(normalized === 'y' || normalized === 'yes');\n      }\n    });\n  });\n}\n\nfunction validateProjectName(name: string): { valid: boolean; error?: string } {\n  if (!name) {\n    return { valid: false, error: 'Project name is required' };\n  }\n  \n  // Check for valid npm package name\n  if (!/^[a-z0-9][a-z0-9-._]*$/i.test(name)) {\n    return { valid: false, error: 'Invalid project name. Use lowercase letters, numbers, and dashes.' };\n  }\n  \n  return { valid: true };\n}\n\n/**\n * Basic subdomain format validation (server does full validation including blacklist)\n */\nfunction isValidSubdomainFormat(subdomain: string): { valid: boolean; error?: string } {\n  if (!subdomain) {\n    return { valid: false, error: 'Subdomain is required' };\n  }\n  \n  if (subdomain.length < 3) {\n    return { valid: false, error: 'Subdomain must be at least 3 characters' };\n  }\n  \n  if (subdomain.length > 63) {\n    return { valid: false, error: 'Subdomain must be 63 characters or less' };\n  }\n  \n  if (!/^[a-z0-9]([a-z0-9-]*[a-z0-9])?$/.test(subdomain)) {\n    return { valid: false, error: 'Subdomain must start and end with alphanumeric, can contain hyphens' };\n  }\n  \n  if (/--/.test(subdomain)) {\n    return { valid: false, error: 'Subdomain cannot contain consecutive hyphens' };\n  }\n  \n  return { valid: true };\n}\n\n/**\n * Check subdomain availability via API (also validates against server blacklist)\n */\nasync function checkSubdomainAvailability(\n  subdomain: string,\n  apiUrl: string\n): Promise<CheckSubdomainResponse> {\n  try {\n    const response = await fetch(`${apiUrl}/api/subdomains/check`, {\n      method: 'POST',\n      headers: {\n        'Content-Type': 'application/json',\n      },\n      body: JSON.stringify({ subdomain }),\n    });\n    \n    const result = await response.json() as CheckSubdomainResponse;\n    return result;\n  } catch {\n    // If API is unavailable, allow proceeding (will fail at registration if invalid)\n    return { available: true };\n  }\n}\n\nfunction formatProjectName(name: string): string {\n  return name\n    .replace(/-/g, ' ')\n    .replace(/\\b\\w/g, (char) => char.toUpperCase());\n}\n\nfunction getPackageManager(): string {\n  const userAgent = process.env.npm_config_user_agent || '';\n  \n  if (userAgent.startsWith('yarn')) {\n    return 'yarn';\n  }\n  \n  if (userAgent.startsWith('pnpm')) {\n    return 'pnpm';\n  }\n  \n  return 'npm';\n}\n\n/**\n * Generate docs.json configuration based on template type\n */\nfunction generateDocsConfig(projectName: string, templateType: TemplateType): object {\n  const formattedName = formatProjectName(projectName);\n  const template = TEMPLATES[templateType];\n  \n  // Base configuration (shared across all templates)\n  const baseConfig = {\n    $schema: 'https://devdoc.sh/docs.json',\n    name: formattedName,\n    favicon: '/favicon.svg',\n    logo: {\n      light: '/logo.svg',\n      dark: '/logo.svg',\n    },\n    colors: {\n      primary: template.color,\n    },\n    navigation: {\n      tabs: [] as object[],\n      global: {\n        anchors: [\n          {\n            anchor: 'GitHub',\n            href: 'https://github.com/your-org/your-repo',\n            icon: 'github-logo',\n          },\n        ],\n      },\n    },\n  };\n\n  // Documentation tab (always present)\n  const docsTab = {\n    tab: 'Documentation',\n    type: 'docs',\n    groups: [\n      {\n        group: 'Getting Started',\n        icon: 'rocket-launch',\n        pages: ['index', 'quickstart'],\n      },\n      {\n        group: 'Guides',\n        icon: 'book-open',\n        pages: ['guides/overview', 'guides/configuration'],\n      },\n    ],\n  };\n\n  baseConfig.navigation.tabs.push(docsTab);\n\n  // Add API reference tab based on template type\n  if (templateType === 'openapi') {\n    baseConfig.navigation.tabs.push({\n      tab: 'API Reference',\n      type: 'openapi',\n      path: '/api-reference',\n      versions: [\n        { version: 'v1', spec: 'api-reference/openapi.json', default: true },\n      ],\n      groups: [\n        {\n          group: 'Overview',\n          icon: 'book-open',\n          pages: [\n            'api-reference/introduction',\n            'api-reference/authentication',\n            'api-reference/errors',\n          ],\n        },\n      ],\n    });\n\n    // Add API playground config\n    (baseConfig as any).api = {\n      baseUrl: 'https://api.example.com',\n      playground: {\n        mode: 'show',\n      },\n    };\n  } else if (templateType === 'graphql') {\n    baseConfig.navigation.tabs.push({\n      tab: 'GraphQL API',\n      type: 'graphql',\n      path: '/graphql-api',\n      schema: 'api-reference/schema.graphql',\n      endpoint: 'https://api.example.com/graphql',\n      groups: [\n        {\n          group: 'Overview',\n          icon: 'book-open',\n          pages: [\n            'api-reference/introduction',\n            'api-reference/authentication',\n          ],\n        },\n      ],\n    });\n  }\n\n  return baseConfig;\n}\n\n// Claude Code skills to create\nconst CLAUDE_SKILLS = [\n  'bootstrap-docs',\n  'migrate-docs',\n  'import-api-spec',\n  'check-docs',\n  'blame-doc',\n  'create-doc',\n  'update-doc',\n  'delete-doc',\n  'commit-doc',\n];\n\n// Cursor rules to create\nconst CURSOR_RULES = [\n  'devdoc.mdc',\n  'devdoc-bootstrap.mdc',\n  'devdoc-migrate.mdc',\n  'devdoc-blame.mdc',\n  'devdoc-create.mdc',\n  'devdoc-update.mdc',\n  'devdoc-delete.mdc',\n  'devdoc-commit.mdc',\n];\n\n/**\n * Get the AI agents template directory path\n */\nfunction getAIAgentsDir(): string | null {\n  // Try relative to compiled dist (packages/devdoc/dist/cli/commands -> packages/devdoc/ai-agents)\n  let agentsDir = path.join(__dirname, '..', '..', '..', 'ai-agents');\n  \n  if (fs.existsSync(agentsDir)) {\n    return agentsDir;\n  }\n  \n  // Try devdoc/templates at repo root (development)\n  agentsDir = path.join(__dirname, '..', '..', '..', '..', '..', 'devdoc', 'templates', 'starter');\n  \n  if (fs.existsSync(agentsDir)) {\n    return agentsDir;\n  }\n  \n  return null;\n}\n\n/**\n * Install AI agent configuration files\n */\nfunction installAIAgents(\n  projectPath: string, \n  tool: 'claude' | 'cursor' | 'both'\n): { claudeMd: boolean; claudeSkills: string[]; cursorRules: string[] } {\n  const results = {\n    claudeMd: false,\n    claudeSkills: [] as string[],\n    cursorRules: [] as string[],\n  };\n\n  const agentsDir = getAIAgentsDir();\n  if (!agentsDir) {\n    logger.warn('AI agent templates not found');\n    return results;\n  }\n\n  // Install Claude Code files\n  if (tool === 'claude' || tool === 'both') {\n    // Copy CLAUDE.md\n    const claudeMdSource = path.join(agentsDir, 'CLAUDE.md');\n    const claudeMdDest = path.join(projectPath, 'CLAUDE.md');\n    if (fs.existsSync(claudeMdSource)) {\n      fs.copySync(claudeMdSource, claudeMdDest);\n      results.claudeMd = true;\n    }\n\n    // Copy skills\n    const sourceSkillsDir = path.join(agentsDir, '.claude', 'skills');\n    const destSkillsDir = path.join(projectPath, '.claude', 'skills');\n    \n    if (fs.existsSync(sourceSkillsDir)) {\n      fs.ensureDirSync(destSkillsDir);\n      \n      for (const skill of CLAUDE_SKILLS) {\n        const sourceDir = path.join(sourceSkillsDir, skill);\n        const destDir = path.join(destSkillsDir, skill);\n        \n        if (fs.existsSync(sourceDir)) {\n          fs.copySync(sourceDir, destDir);\n          results.claudeSkills.push(skill);\n        }\n      }\n    }\n  }\n\n  // Install Cursor files\n  if (tool === 'cursor' || tool === 'both') {\n    const sourceRulesDir = path.join(agentsDir, '.cursor', 'rules');\n    const destRulesDir = path.join(projectPath, '.cursor', 'rules');\n    \n    if (fs.existsSync(sourceRulesDir)) {\n      fs.ensureDirSync(destRulesDir);\n      \n      for (const rule of CURSOR_RULES) {\n        const sourcePath = path.join(sourceRulesDir, rule);\n        const destPath = path.join(destRulesDir, rule);\n        \n        if (fs.existsSync(sourcePath)) {\n          fs.copySync(sourcePath, destPath);\n          results.cursorRules.push(rule);\n        }\n      }\n    }\n  }\n\n  return results;\n}\n\n/**\n * Clean up unused API files based on template type\n */\nfunction cleanupUnusedFiles(resolvedPath: string, templateType: TemplateType): void {\n  const apiRefPath = path.join(resolvedPath, 'api-reference');\n  \n  if (templateType === 'basic') {\n    // Remove entire api-reference folder for basic template\n    if (fs.existsSync(apiRefPath)) {\n      fs.removeSync(apiRefPath);\n      logger.debug('Removed api-reference folder (not needed for basic template)');\n    }\n  } else if (templateType === 'openapi') {\n    // Remove GraphQL schema for OpenAPI template\n    const graphqlSchema = path.join(apiRefPath, 'schema.graphql');\n    if (fs.existsSync(graphqlSchema)) {\n      fs.removeSync(graphqlSchema);\n      logger.debug('Removed schema.graphql (not needed for OpenAPI template)');\n    }\n  } else if (templateType === 'graphql') {\n    // Remove OpenAPI spec and errors.mdx for GraphQL template\n    const openapiSpec = path.join(apiRefPath, 'openapi.json');\n    const errorsFile = path.join(apiRefPath, 'errors.mdx');\n    if (fs.existsSync(openapiSpec)) {\n      fs.removeSync(openapiSpec);\n      logger.debug('Removed openapi.json (not needed for GraphQL template)');\n    }\n    if (fs.existsSync(errorsFile)) {\n      fs.removeSync(errorsFile);\n      logger.debug('Removed errors.mdx (not needed for GraphQL template)');\n    }\n  }\n}\n\nexport async function create(projectDirectory: string | undefined, options: CreateOptions): Promise<void> {\n  console.log();\n  logger.info('🐟 Create DevDoc Doc');\n  console.log();\n\n  const apiUrl = options.url || process.env.DEVDOC_API_URL || DEFAULT_API_URL;\n\n  // Get project name if not provided\n  let projectPath = projectDirectory;\n\n  if (!projectPath) {\n    projectPath = await prompt('What is your project named?', 'my-docs');\n    \n    if (!projectPath) {\n      logger.error('Project name is required');\n      process.exit(1);\n    }\n  }\n\n  // Validate project name\n  const validation = validateProjectName(projectPath);\n  if (!validation.valid) {\n    logger.error(validation.error || 'Invalid project name');\n    process.exit(1);\n  }\n\n  // Get doc type selection if not provided\n  let docType: DocType = options.docType || 'public';\n  \n  if (!options.docType) {\n    const docTypeChoices = Object.entries(DOC_TYPES).map(([key, value]) => ({\n      value: key,\n      label: `${value.name} - ${value.description}`,\n    }));\n\n    docType = await promptSelect('What type of documentation are you creating?', docTypeChoices) as DocType;\n  }\n\n  const isInternalDocs = docType === 'internal';\n\n  // Get template selection if not provided\n  let template: TemplateType = options.template || 'basic';\n  \n  if (!options.template) {\n    const templateChoices = Object.entries(TEMPLATES).map(([key, value]) => ({\n      value: key,\n      label: `${value.name} - ${value.description}`,\n    }));\n\n    template = await promptSelect('Which template would you like to use?', templateChoices) as TemplateType;\n  }\n\n  // Resolve full path\n  const resolvedPath = path.resolve(projectPath);\n  const projectName = path.basename(resolvedPath);\n  const slug = projectName.toLowerCase().replace(/[^a-z0-9]+/g, '-').replace(/^-|-$/g, '');\n\n  // Get subdomain - only for public docs\n  let subdomain: string | undefined = options.subdomain;\n  \n  if (!isInternalDocs) {\n    if (!subdomain) {\n      console.log();\n      subdomain = await prompt(`Enter subdomain for your docs (${slug}.devdoc.sh)`, slug);\n      subdomain = subdomain.toLowerCase().replace(/[^a-z0-9-]/g, '-').replace(/^-|-$/g, '');\n    }\n\n    // Validate subdomain format locally\n    const formatCheck = isValidSubdomainFormat(subdomain);\n    if (!formatCheck.valid) {\n      logger.error(formatCheck.error!);\n      process.exit(1);\n    }\n\n    // Check subdomain availability via API (server validates blacklist)\n    // Loop until we find an available subdomain\n    let subdomainAvailable = false;\n    while (!subdomainAvailable) {\n      logger.info(`Checking if ${subdomain}.devdoc.sh is available...`);\n      const availability = await checkSubdomainAvailability(subdomain, apiUrl);\n      \n      if (!availability.available) {\n        console.log();\n        logger.warn(availability.error || `Subdomain \"${subdomain}\" is not available`);\n        \n        const suggestion = availability.suggestion || `${subdomain}-docs`;\n        console.log();\n        logger.info(`Suggestion: ${suggestion}.devdoc.sh`);\n        console.log();\n        \n        // Prompt for new subdomain\n        subdomain = await prompt('Enter a different subdomain', suggestion);\n        subdomain = subdomain.toLowerCase().replace(/[^a-z0-9-]/g, '-').replace(/^-|-$/g, '');\n        \n        // Validate format\n        const formatCheck = isValidSubdomainFormat(subdomain);\n        if (!formatCheck.valid) {\n          logger.error(formatCheck.error!);\n          continue;\n        }\n        \n        console.log();\n      } else {\n        subdomainAvailable = true;\n        logger.success(`✓ ${subdomain}.devdoc.sh is available!`);\n      }\n    }\n  }\n\n  // Check if directory exists\n  if (fs.existsSync(resolvedPath)) {\n    const files = fs.readdirSync(resolvedPath);\n    if (files.length > 0) {\n      const overwrite = await promptConfirm(`Directory ${projectName} is not empty. Continue anyway?`, false);\n      \n      if (!overwrite) {\n        logger.error('Operation cancelled');\n        process.exit(1);\n      }\n    }\n  }\n\n  const selectedTemplate = TEMPLATES[template];\n  console.log();\n  logger.info(`Creating a new ${selectedTemplate.name} DevDoc documentation site in ${resolvedPath}`);\n  console.log();\n\n  // Create project directory\n  fs.ensureDirSync(resolvedPath);\n\n  // Download template from remote repository (always use starter template)\n  logger.info('Downloading template...');\n  \n  try {\n    // Try to download from remote repository first\n    await downloadTemplate(TEMPLATE_REPO, {\n      dir: resolvedPath,\n      force: true,\n    });\n    logger.success('Downloaded starter template');\n  } catch (downloadError) {\n    // Fall back to local templates (for development or offline usage)\n    logger.debug(`Remote download failed: ${downloadError}`);\n    logger.info('Falling back to local template...');\n    \n    const templateDir = path.join(__dirname, '..', '..', '..', 'templates', 'starter');\n    \n    if (!fs.existsSync(templateDir)) {\n      logger.error('Template \"starter\" not found');\n      logger.debug(`Looked for template at: ${templateDir}`);\n      logger.debug('Remote source: ' + TEMPLATE_REPO);\n      process.exit(1);\n    }\n\n    fs.copySync(templateDir, resolvedPath, { overwrite: true });\n    logger.success('Copied local template');\n  }\n\n  // Update package.json with project name\n  const pkgPath = path.join(resolvedPath, 'package.json');\n  if (fs.existsSync(pkgPath)) {\n    const pkg = fs.readJsonSync(pkgPath);\n    pkg.name = projectName;\n    fs.writeJsonSync(pkgPath, pkg, { spaces: 2 });\n  }\n\n  // Generate docs.json based on template type\n  const docsConfig = generateDocsConfig(projectName, template);\n  const docsPath = path.join(resolvedPath, 'docs.json');\n  fs.writeJsonSync(docsPath, docsConfig, { spaces: 2 });\n  logger.success(`Generated docs.json for ${selectedTemplate.name} template`);\n\n  // Update theme.json with template color\n  const themePath = path.join(resolvedPath, 'theme.json');\n  if (fs.existsSync(themePath)) {\n    const theme = fs.readJsonSync(themePath);\n    theme.colors = {\n      primary: selectedTemplate.color,\n      primaryLight: selectedTemplate.color,\n      primaryDark: selectedTemplate.color,\n    };\n    fs.writeJsonSync(themePath, theme, { spaces: 2 });\n  }\n\n  // Clean up unused files based on template type\n  cleanupUnusedFiles(resolvedPath, template);\n\n  // Create .devdoc.json with project config\n  // For public docs: subdomain will only be reserved when the user actually deploys\n  // For internal docs: no subdomain needed\n  const devdocConfigPath = path.join(resolvedPath, '.devdoc.json');\n  \n  const devdocConfig: Record<string, unknown> = {\n    projectId: `${slug}-${Math.random().toString(36).substring(2, 8)}`,\n    name: formatProjectName(projectName),\n    slug: slug,\n    docType: docType,\n    createdAt: new Date().toISOString(),\n  };\n\n  // Only add subdomain for public docs\n  if (!isInternalDocs && subdomain) {\n    devdocConfig.subdomain = subdomain;\n  }\n\n  fs.writeJsonSync(devdocConfigPath, devdocConfig, { spaces: 2 });\n  logger.success('Created .devdoc.json');\n  console.log();\n  console.log('  Doc Type:', DOC_TYPES[docType].name);\n  if (!isInternalDocs && subdomain) {\n    console.log('  Subdomain:', `${subdomain}.devdoc.sh`);\n    console.log('  Status:', 'Not yet deployed (subdomain will be reserved on first deploy)');\n  } else {\n    console.log('  Status:', 'Internal docs (local development only)');\n  }\n\n  // Initialize git\n  if (options.git !== false) {\n    logger.info('Initializing git repository...');\n    try {\n      execSync('git init', { cwd: resolvedPath, stdio: 'ignore' });\n      execSync('git add -A', { cwd: resolvedPath, stdio: 'ignore' });\n      execSync('git commit -m \"Initial commit from devdoc create\"', {\n        cwd: resolvedPath,\n        stdio: 'ignore',\n      });\n      logger.success('Git repository initialized');\n    } catch {\n      logger.warn('Could not initialize git repository');\n    }\n  }\n\n  // Install dependencies\n  if (options.install !== false) {\n    logger.info('Installing dependencies...');\n    try {\n      const packageManager = getPackageManager();\n      execSync(`${packageManager} install`, {\n        cwd: resolvedPath,\n        stdio: 'inherit',\n      });\n      logger.success('Dependencies installed');\n    } catch {\n      logger.warn('Could not install dependencies');\n    }\n  }\n\n  // Install AI agents - always prompt as part of create flow\n  let aiTool: 'claude' | 'cursor' | 'both' | null = null;\n  \n  const aiChoices = [\n    { value: 'both', label: 'Both - Claude Code and Cursor (recommended)' },\n    { value: 'cursor', label: 'Cursor - Rules for Cursor IDE' },\n    { value: 'claude', label: 'Claude Code - Skills and CLAUDE.md' },\n  ];\n  const aiSelection = await promptSelect('Which AI coding assistant do you use?', aiChoices);\n  aiTool = aiSelection as 'claude' | 'cursor' | 'both';\n\n  if (aiTool) {\n    console.log();\n    logger.info('Setting up AI agent configuration...');\n    const aiResults = installAIAgents(resolvedPath, aiTool);\n    \n    if (aiResults.claudeMd) {\n      logger.success('Created CLAUDE.md');\n    }\n    for (const skill of aiResults.claudeSkills) {\n      logger.success(`Created .claude/skills/${skill}/SKILL.md`);\n    }\n    for (const rule of aiResults.cursorRules) {\n      logger.success(`Created .cursor/rules/${rule}`);\n    }\n  }\n\n  // Success message\n  console.log();\n  logger.success(`Created ${projectName} at ${resolvedPath}`);\n  console.log();\n\n  if (!isInternalDocs && subdomain) {\n    console.log('Your docs will be available at:');\n    console.log(`  https://${subdomain}.devdoc.sh`);\n    console.log();\n    logger.info('Note: The subdomain will be reserved when you run \"devdoc deploy\"');\n    console.log();\n    console.log('Inside that directory, you can run several commands:');\n    console.log();\n    console.log('  npm run dev');\n    console.log('    Starts the development server.');\n    console.log();\n    console.log('  devdoc deploy');\n    console.log('    Deploys and claims your subdomain.');\n    console.log();\n  } else {\n    console.log('This is an internal documentation project for local development.');\n    console.log();\n    console.log('Inside that directory, you can run:');\n    console.log();\n    console.log('  npm run dev');\n    console.log('    Starts the development server at http://localhost:3000');\n    console.log();\n  }\n\n  console.log('We suggest that you begin by typing:');\n  console.log();\n  console.log(`  cd ${projectName}`);\n  console.log('  npm run dev');\n  console.log();\n\n  // Show AI agent quick start tips\n  console.log('AI Agent Quick Start:');\n  if (aiTool === 'claude' || aiTool === 'both') {\n    console.log('  Claude Code: /bootstrap-docs');\n  }\n  if (aiTool === 'cursor' || aiTool === 'both') {\n    console.log('  Cursor: Ask \"generate initial documentation from this repo\"');\n  }\n  console.log();\n\n  // ASCII art banner\n  console.log(`\n  ____              ____             \n |  _ \\\\  _____   __|  _ \\\\  ___   ___ \n | | | |/ _ \\\\ \\\\ / /| | | |/ _ \\\\ / __|\n | |_| |  __/\\\\ V / | |_| | (_) | (__ \n |____/ \\\\___| \\\\_/  |____/ \\\\___/ \\\\___|\n                                      \n  `);\n  console.log('Happy documenting!');\n  console.log();\n}\n"]}
722
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create.js","sourceRoot":"","sources":["../../../src/cli/commands/create.ts"],"names":[],"mappings":"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","sourcesContent":["import { execSync } from 'child_process';\nimport path from 'path';\nimport fs from 'fs-extra';\nimport { downloadTemplate } from 'giget';\nimport { logger } from '../../utils/logger';\nimport { DEFAULT_API_URL } from '../../constants';\n\n// Remote template repository - single starter template\nconst TEMPLATE_REPO = 'github:brainfish-ai/devdoc/templates/starter';\n\n// Available template types (all use the same starter template, just different configs)\nconst TEMPLATES = {\n  basic: {\n    name: 'Basic',\n    description: 'Simple documentation site with guides and pages',\n    color: '#10b981',\n  },\n  openapi: {\n    name: 'OpenAPI',\n    description: 'Documentation with REST API reference (OpenAPI/Swagger)',\n    color: '#10b981',\n  },\n  graphql: {\n    name: 'GraphQL',\n    description: 'Documentation with GraphQL API playground',\n    color: '#e535ab',\n  },\n} as const;\n\ntype TemplateType = keyof typeof TEMPLATES;\n\n// Documentation types\nconst DOC_TYPES = {\n  public: {\n    name: 'Public',\n    description: 'User-facing docs with custom subdomain and deployment',\n  },\n  internal: {\n    name: 'Internal',\n    description: 'Developer docs for local/private use (no subdomain needed)',\n  },\n} as const;\n\ntype DocType = keyof typeof DOC_TYPES;\n\ninterface CreateOptions {\n  template?: TemplateType;\n  docType?: DocType;\n  git?: boolean;\n  install?: boolean;\n  url?: string;\n  subdomain?: string;\n}\n\ninterface CheckSubdomainResponse {\n  available: boolean;\n  error?: string;\n  suggestion?: string;\n}\n\n// Simple prompt helper using readline\nasync function prompt(question: string, defaultValue?: string): Promise<string> {\n  const readline = await import('readline');\n  const rl = readline.createInterface({\n    input: process.stdin,\n    output: process.stdout,\n  });\n\n  return new Promise((resolve) => {\n    const displayQuestion = defaultValue \n      ? `${question} (${defaultValue}): `\n      : `${question}: `;\n    \n    rl.question(displayQuestion, (answer) => {\n      rl.close();\n      resolve(answer.trim() || defaultValue || '');\n    });\n  });\n}\n\nasync function promptSelect(question: string, choices: { value: string; label: string }[]): Promise<string> {\n  console.log(`\\n${question}\\n`);\n  choices.forEach((choice, i) => {\n    console.log(`  ${i + 1}. ${choice.label}`);\n  });\n  console.log();\n  \n  const readline = await import('readline');\n  const rl = readline.createInterface({\n    input: process.stdin,\n    output: process.stdout,\n  });\n\n  return new Promise((resolve) => {\n    rl.question('Enter number: ', (answer) => {\n      rl.close();\n      const index = parseInt(answer.trim(), 10) - 1;\n      if (index >= 0 && index < choices.length) {\n        resolve(choices[index].value);\n      } else {\n        // Default to first choice\n        resolve(choices[0].value);\n      }\n    });\n  });\n}\n\nasync function promptConfirm(question: string, defaultValue = false): Promise<boolean> {\n  const readline = await import('readline');\n  const rl = readline.createInterface({\n    input: process.stdin,\n    output: process.stdout,\n  });\n\n  return new Promise((resolve) => {\n    const hint = defaultValue ? '[Y/n]' : '[y/N]';\n    rl.question(`${question} ${hint}: `, (answer) => {\n      rl.close();\n      const normalized = answer.trim().toLowerCase();\n      if (normalized === '') {\n        resolve(defaultValue);\n      } else {\n        resolve(normalized === 'y' || normalized === 'yes');\n      }\n    });\n  });\n}\n\nfunction validateProjectName(name: string): { valid: boolean; error?: string } {\n  if (!name) {\n    return { valid: false, error: 'Project name is required' };\n  }\n  \n  // Check for valid npm package name\n  if (!/^[a-z0-9][a-z0-9-._]*$/i.test(name)) {\n    return { valid: false, error: 'Invalid project name. Use lowercase letters, numbers, and dashes.' };\n  }\n  \n  return { valid: true };\n}\n\n/**\n * Basic subdomain format validation (server does full validation including blacklist)\n */\nfunction isValidSubdomainFormat(subdomain: string): { valid: boolean; error?: string } {\n  if (!subdomain) {\n    return { valid: false, error: 'Subdomain is required' };\n  }\n  \n  if (subdomain.length < 3) {\n    return { valid: false, error: 'Subdomain must be at least 3 characters' };\n  }\n  \n  if (subdomain.length > 63) {\n    return { valid: false, error: 'Subdomain must be 63 characters or less' };\n  }\n  \n  if (!/^[a-z0-9]([a-z0-9-]*[a-z0-9])?$/.test(subdomain)) {\n    return { valid: false, error: 'Subdomain must start and end with alphanumeric, can contain hyphens' };\n  }\n  \n  if (/--/.test(subdomain)) {\n    return { valid: false, error: 'Subdomain cannot contain consecutive hyphens' };\n  }\n  \n  return { valid: true };\n}\n\n/**\n * Check subdomain availability via API (also validates against server blacklist)\n */\nasync function checkSubdomainAvailability(\n  subdomain: string,\n  apiUrl: string\n): Promise<CheckSubdomainResponse> {\n  try {\n    const response = await fetch(`${apiUrl}/api/subdomains/check`, {\n      method: 'POST',\n      headers: {\n        'Content-Type': 'application/json',\n      },\n      body: JSON.stringify({ subdomain }),\n    });\n    \n    const result = await response.json() as CheckSubdomainResponse;\n    return result;\n  } catch {\n    // If API is unavailable, allow proceeding (will fail at registration if invalid)\n    return { available: true };\n  }\n}\n\nfunction formatProjectName(name: string): string {\n  return name\n    .replace(/-/g, ' ')\n    .replace(/\\b\\w/g, (char) => char.toUpperCase());\n}\n\nfunction getPackageManager(): string {\n  const userAgent = process.env.npm_config_user_agent || '';\n  \n  if (userAgent.startsWith('yarn')) {\n    return 'yarn';\n  }\n  \n  if (userAgent.startsWith('pnpm')) {\n    return 'pnpm';\n  }\n  \n  return 'npm';\n}\n\n/**\n * Generate docs.json configuration based on template type\n */\nfunction generateDocsConfig(projectName: string, templateType: TemplateType): object {\n  const formattedName = formatProjectName(projectName);\n  const template = TEMPLATES[templateType];\n  \n  // Base configuration (shared across all templates)\n  const baseConfig = {\n    $schema: 'https://devdoc.sh/docs.json',\n    name: formattedName,\n    favicon: '/favicon.svg',\n    logo: {\n      light: '/logo.svg',\n      dark: '/logo.svg',\n    },\n    colors: {\n      primary: template.color,\n    },\n    navigation: {\n      tabs: [] as object[],\n      global: {\n        anchors: [\n          {\n            anchor: 'GitHub',\n            href: 'https://github.com/your-org/your-repo',\n            icon: 'github-logo',\n          },\n        ],\n      },\n    },\n  };\n\n  // Documentation tab (always present)\n  const docsTab = {\n    tab: 'Documentation',\n    type: 'docs',\n    groups: [\n      {\n        group: 'Getting Started',\n        icon: 'rocket-launch',\n        pages: ['index', 'quickstart'],\n      },\n      {\n        group: 'Guides',\n        icon: 'book-open',\n        pages: ['guides/overview', 'guides/configuration'],\n      },\n    ],\n  };\n\n  baseConfig.navigation.tabs.push(docsTab);\n\n  // Add API reference tab based on template type\n  if (templateType === 'openapi') {\n    baseConfig.navigation.tabs.push({\n      tab: 'API Reference',\n      type: 'openapi',\n      path: '/api-reference',\n      versions: [\n        { version: 'v1', spec: 'api-reference/openapi.json', default: true },\n      ],\n      groups: [\n        {\n          group: 'Overview',\n          icon: 'book-open',\n          pages: [\n            'api-reference/introduction',\n            'api-reference/authentication',\n            'api-reference/errors',\n          ],\n        },\n      ],\n    });\n\n    // Add API playground config\n    (baseConfig as any).api = {\n      baseUrl: 'https://api.example.com',\n      playground: {\n        mode: 'show',\n      },\n    };\n  } else if (templateType === 'graphql') {\n    baseConfig.navigation.tabs.push({\n      tab: 'GraphQL API',\n      type: 'graphql',\n      path: '/graphql-api',\n      schema: 'api-reference/schema.graphql',\n      endpoint: 'https://api.example.com/graphql',\n      groups: [\n        {\n          group: 'Overview',\n          icon: 'book-open',\n          pages: [\n            'api-reference/introduction',\n            'api-reference/authentication',\n          ],\n        },\n      ],\n    });\n  }\n\n  return baseConfig;\n}\n\n// Claude Code skills to create\nconst CLAUDE_SKILLS = [\n  'bootstrap-docs',\n  'whisk-theme',\n  'migrate-docs',\n  'import-api-spec',\n  'check-docs',\n  'blame-doc',\n  'create-doc',\n  'update-doc',\n  'delete-doc',\n  'commit-doc',\n];\n\n// Cursor rules to create\nconst CURSOR_RULES = [\n  'devdoc.mdc',\n  'devdoc-bootstrap.mdc',\n  'devdoc-whisk-theme.mdc',\n  'devdoc-migrate.mdc',\n  'devdoc-blame.mdc',\n  'devdoc-create.mdc',\n  'devdoc-update.mdc',\n  'devdoc-delete.mdc',\n  'devdoc-commit.mdc',\n];\n\n/**\n * Get the AI agents template directory path\n */\nfunction getAIAgentsDir(): string | null {\n  // Try relative to compiled dist (packages/devdoc/dist/cli/commands -> packages/devdoc/ai-agents)\n  let agentsDir = path.join(__dirname, '..', '..', '..', 'ai-agents');\n  \n  if (fs.existsSync(agentsDir)) {\n    return agentsDir;\n  }\n  \n  // Try devdoc/templates at repo root (development)\n  agentsDir = path.join(__dirname, '..', '..', '..', '..', '..', 'devdoc', 'templates', 'starter');\n  \n  if (fs.existsSync(agentsDir)) {\n    return agentsDir;\n  }\n  \n  return null;\n}\n\n/**\n * Install AI agent configuration files\n */\nfunction installAIAgents(\n  projectPath: string, \n  tool: 'claude' | 'cursor' | 'both'\n): { claudeMd: boolean; claudeSkills: string[]; cursorRules: string[] } {\n  const results = {\n    claudeMd: false,\n    claudeSkills: [] as string[],\n    cursorRules: [] as string[],\n  };\n\n  const agentsDir = getAIAgentsDir();\n  if (!agentsDir) {\n    logger.warn('AI agent templates not found');\n    return results;\n  }\n\n  // Install Claude Code files\n  if (tool === 'claude' || tool === 'both') {\n    // Copy CLAUDE.md\n    const claudeMdSource = path.join(agentsDir, 'CLAUDE.md');\n    const claudeMdDest = path.join(projectPath, 'CLAUDE.md');\n    if (fs.existsSync(claudeMdSource)) {\n      fs.copySync(claudeMdSource, claudeMdDest);\n      results.claudeMd = true;\n    }\n\n    // Copy skills\n    const sourceSkillsDir = path.join(agentsDir, '.claude', 'skills');\n    const destSkillsDir = path.join(projectPath, '.claude', 'skills');\n    \n    if (fs.existsSync(sourceSkillsDir)) {\n      fs.ensureDirSync(destSkillsDir);\n      \n      for (const skill of CLAUDE_SKILLS) {\n        const sourceDir = path.join(sourceSkillsDir, skill);\n        const destDir = path.join(destSkillsDir, skill);\n        \n        if (fs.existsSync(sourceDir)) {\n          fs.copySync(sourceDir, destDir);\n          results.claudeSkills.push(skill);\n        }\n      }\n    }\n  }\n\n  // Install Cursor files\n  if (tool === 'cursor' || tool === 'both') {\n    const sourceRulesDir = path.join(agentsDir, '.cursor', 'rules');\n    const destRulesDir = path.join(projectPath, '.cursor', 'rules');\n    \n    if (fs.existsSync(sourceRulesDir)) {\n      fs.ensureDirSync(destRulesDir);\n      \n      for (const rule of CURSOR_RULES) {\n        const sourcePath = path.join(sourceRulesDir, rule);\n        const destPath = path.join(destRulesDir, rule);\n        \n        if (fs.existsSync(sourcePath)) {\n          fs.copySync(sourcePath, destPath);\n          results.cursorRules.push(rule);\n        }\n      }\n    }\n  }\n\n  return results;\n}\n\n/**\n * Clean up unused API files based on template type\n */\nfunction cleanupUnusedFiles(resolvedPath: string, templateType: TemplateType): void {\n  const apiRefPath = path.join(resolvedPath, 'api-reference');\n  \n  if (templateType === 'basic') {\n    // Remove entire api-reference folder for basic template\n    if (fs.existsSync(apiRefPath)) {\n      fs.removeSync(apiRefPath);\n      logger.debug('Removed api-reference folder (not needed for basic template)');\n    }\n  } else if (templateType === 'openapi') {\n    // Remove GraphQL schema for OpenAPI template\n    const graphqlSchema = path.join(apiRefPath, 'schema.graphql');\n    if (fs.existsSync(graphqlSchema)) {\n      fs.removeSync(graphqlSchema);\n      logger.debug('Removed schema.graphql (not needed for OpenAPI template)');\n    }\n  } else if (templateType === 'graphql') {\n    // Remove OpenAPI spec and errors.mdx for GraphQL template\n    const openapiSpec = path.join(apiRefPath, 'openapi.json');\n    const errorsFile = path.join(apiRefPath, 'errors.mdx');\n    if (fs.existsSync(openapiSpec)) {\n      fs.removeSync(openapiSpec);\n      logger.debug('Removed openapi.json (not needed for GraphQL template)');\n    }\n    if (fs.existsSync(errorsFile)) {\n      fs.removeSync(errorsFile);\n      logger.debug('Removed errors.mdx (not needed for GraphQL template)');\n    }\n  }\n}\n\nexport async function create(projectDirectory: string | undefined, options: CreateOptions): Promise<void> {\n  console.log();\n  logger.info('🐟 Create DevDoc Doc');\n  console.log();\n\n  const apiUrl = options.url || process.env.DEVDOC_API_URL || DEFAULT_API_URL;\n\n  // Get project name if not provided\n  let projectPath = projectDirectory;\n\n  if (!projectPath) {\n    projectPath = await prompt('What is your project named?', 'my-docs');\n    \n    if (!projectPath) {\n      logger.error('Project name is required');\n      process.exit(1);\n    }\n  }\n\n  // Validate project name\n  const validation = validateProjectName(projectPath);\n  if (!validation.valid) {\n    logger.error(validation.error || 'Invalid project name');\n    process.exit(1);\n  }\n\n  // Get doc type selection if not provided\n  let docType: DocType = options.docType || 'public';\n  \n  if (!options.docType) {\n    const docTypeChoices = Object.entries(DOC_TYPES).map(([key, value]) => ({\n      value: key,\n      label: `${value.name} - ${value.description}`,\n    }));\n\n    docType = await promptSelect('What type of documentation are you creating?', docTypeChoices) as DocType;\n  }\n\n  const isInternalDocs = docType === 'internal';\n\n  // Get template selection if not provided\n  let template: TemplateType = options.template || 'basic';\n  \n  if (!options.template) {\n    const templateChoices = Object.entries(TEMPLATES).map(([key, value]) => ({\n      value: key,\n      label: `${value.name} - ${value.description}`,\n    }));\n\n    template = await promptSelect('Which template would you like to use?', templateChoices) as TemplateType;\n  }\n\n  // Resolve full path\n  const resolvedPath = path.resolve(projectPath);\n  const projectName = path.basename(resolvedPath);\n  const slug = projectName.toLowerCase().replace(/[^a-z0-9]+/g, '-').replace(/^-|-$/g, '');\n\n  // Get subdomain - only for public docs\n  let subdomain: string | undefined = options.subdomain;\n  \n  if (!isInternalDocs) {\n    if (!subdomain) {\n      console.log();\n      subdomain = await prompt(`Enter subdomain for your docs (${slug}.devdoc.sh)`, slug);\n      subdomain = subdomain.toLowerCase().replace(/[^a-z0-9-]/g, '-').replace(/^-|-$/g, '');\n    }\n\n    // Validate subdomain format locally\n    const formatCheck = isValidSubdomainFormat(subdomain);\n    if (!formatCheck.valid) {\n      logger.error(formatCheck.error!);\n      process.exit(1);\n    }\n\n    // Check subdomain availability via API (server validates blacklist)\n    // Loop until we find an available subdomain\n    let subdomainAvailable = false;\n    while (!subdomainAvailable) {\n      logger.info(`Checking if ${subdomain}.devdoc.sh is available...`);\n      const availability = await checkSubdomainAvailability(subdomain, apiUrl);\n      \n      if (!availability.available) {\n        console.log();\n        logger.warn(availability.error || `Subdomain \"${subdomain}\" is not available`);\n        \n        const suggestion = availability.suggestion || `${subdomain}-docs`;\n        console.log();\n        logger.info(`Suggestion: ${suggestion}.devdoc.sh`);\n        console.log();\n        \n        // Prompt for new subdomain\n        subdomain = await prompt('Enter a different subdomain', suggestion);\n        subdomain = subdomain.toLowerCase().replace(/[^a-z0-9-]/g, '-').replace(/^-|-$/g, '');\n        \n        // Validate format\n        const formatCheck = isValidSubdomainFormat(subdomain);\n        if (!formatCheck.valid) {\n          logger.error(formatCheck.error!);\n          continue;\n        }\n        \n        console.log();\n      } else {\n        subdomainAvailable = true;\n        logger.success(`✓ ${subdomain}.devdoc.sh is available!`);\n      }\n    }\n  }\n\n  // Check if directory exists\n  if (fs.existsSync(resolvedPath)) {\n    const files = fs.readdirSync(resolvedPath);\n    if (files.length > 0) {\n      const overwrite = await promptConfirm(`Directory ${projectName} is not empty. Continue anyway?`, false);\n      \n      if (!overwrite) {\n        logger.error('Operation cancelled');\n        process.exit(1);\n      }\n    }\n  }\n\n  const selectedTemplate = TEMPLATES[template];\n  console.log();\n  logger.info(`Creating a new ${selectedTemplate.name} DevDoc documentation site in ${resolvedPath}`);\n  console.log();\n\n  // Create project directory\n  fs.ensureDirSync(resolvedPath);\n\n  // Download template from remote repository (always use starter template)\n  logger.info('Downloading template...');\n  \n  try {\n    // Try to download from remote repository first\n    await downloadTemplate(TEMPLATE_REPO, {\n      dir: resolvedPath,\n      force: true,\n    });\n    logger.success('Downloaded starter template');\n  } catch (downloadError) {\n    // Fall back to local templates (for development or offline usage)\n    logger.debug(`Remote download failed: ${downloadError}`);\n    logger.info('Falling back to local template...');\n    \n    const templateDir = path.join(__dirname, '..', '..', '..', 'templates', 'starter');\n    \n    if (!fs.existsSync(templateDir)) {\n      logger.error('Template \"starter\" not found');\n      logger.debug(`Looked for template at: ${templateDir}`);\n      logger.debug('Remote source: ' + TEMPLATE_REPO);\n      process.exit(1);\n    }\n\n    fs.copySync(templateDir, resolvedPath, { overwrite: true });\n    logger.success('Copied local template');\n  }\n\n  // Update package.json with project name\n  const pkgPath = path.join(resolvedPath, 'package.json');\n  if (fs.existsSync(pkgPath)) {\n    const pkg = fs.readJsonSync(pkgPath);\n    pkg.name = projectName;\n    fs.writeJsonSync(pkgPath, pkg, { spaces: 2 });\n  }\n\n  // Generate docs.json based on template type\n  const docsConfig = generateDocsConfig(projectName, template);\n  const docsPath = path.join(resolvedPath, 'docs.json');\n  fs.writeJsonSync(docsPath, docsConfig, { spaces: 2 });\n  logger.success(`Generated docs.json for ${selectedTemplate.name} template`);\n\n  // Update theme.json with template color\n  const themePath = path.join(resolvedPath, 'theme.json');\n  if (fs.existsSync(themePath)) {\n    const theme = fs.readJsonSync(themePath);\n    theme.colors = {\n      primary: selectedTemplate.color,\n      primaryLight: selectedTemplate.color,\n      primaryDark: selectedTemplate.color,\n    };\n    fs.writeJsonSync(themePath, theme, { spaces: 2 });\n  }\n\n  // Clean up unused files based on template type\n  cleanupUnusedFiles(resolvedPath, template);\n\n  // Create .devdoc.json with project config\n  // For public docs: subdomain will only be reserved when the user actually deploys\n  // For internal docs: no subdomain needed\n  const devdocConfigPath = path.join(resolvedPath, '.devdoc.json');\n  \n  const devdocConfig: Record<string, unknown> = {\n    projectId: `${slug}-${Math.random().toString(36).substring(2, 8)}`,\n    name: formatProjectName(projectName),\n    slug: slug,\n    docType: docType,\n    createdAt: new Date().toISOString(),\n  };\n\n  // Only add subdomain for public docs\n  if (!isInternalDocs && subdomain) {\n    devdocConfig.subdomain = subdomain;\n  }\n\n  fs.writeJsonSync(devdocConfigPath, devdocConfig, { spaces: 2 });\n  logger.success('Created .devdoc.json');\n  console.log();\n  console.log('  Doc Type:', DOC_TYPES[docType].name);\n  if (!isInternalDocs && subdomain) {\n    console.log('  Subdomain:', `${subdomain}.devdoc.sh`);\n    console.log('  Status:', 'Not yet deployed (subdomain will be reserved on first deploy)');\n  } else {\n    console.log('  Status:', 'Internal docs (local development only)');\n  }\n\n  // Initialize git\n  if (options.git !== false) {\n    logger.info('Initializing git repository...');\n    try {\n      execSync('git init', { cwd: resolvedPath, stdio: 'ignore' });\n      execSync('git add -A', { cwd: resolvedPath, stdio: 'ignore' });\n      execSync('git commit -m \"Initial commit from devdoc create\"', {\n        cwd: resolvedPath,\n        stdio: 'ignore',\n      });\n      logger.success('Git repository initialized');\n    } catch {\n      logger.warn('Could not initialize git repository');\n    }\n  }\n\n  // Install dependencies\n  if (options.install !== false) {\n    logger.info('Installing dependencies...');\n    try {\n      const packageManager = getPackageManager();\n      execSync(`${packageManager} install`, {\n        cwd: resolvedPath,\n        stdio: 'inherit',\n      });\n      logger.success('Dependencies installed');\n    } catch {\n      logger.warn('Could not install dependencies');\n    }\n  }\n\n  // Install AI agents - always prompt as part of create flow\n  let aiTool: 'claude' | 'cursor' | 'both' | null = null;\n  \n  const aiChoices = [\n    { value: 'both', label: 'Both - Claude Code and Cursor (recommended)' },\n    { value: 'cursor', label: 'Cursor - Rules for Cursor IDE' },\n    { value: 'claude', label: 'Claude Code - Skills and CLAUDE.md' },\n  ];\n  const aiSelection = await promptSelect('Which AI coding assistant do you use?', aiChoices);\n  aiTool = aiSelection as 'claude' | 'cursor' | 'both';\n\n  if (aiTool) {\n    console.log();\n    logger.info('Setting up AI agent configuration...');\n    const aiResults = installAIAgents(resolvedPath, aiTool);\n    \n    if (aiResults.claudeMd) {\n      logger.success('Created CLAUDE.md');\n    }\n    for (const skill of aiResults.claudeSkills) {\n      logger.success(`Created .claude/skills/${skill}/SKILL.md`);\n    }\n    for (const rule of aiResults.cursorRules) {\n      logger.success(`Created .cursor/rules/${rule}`);\n    }\n  }\n\n  // Success message\n  console.log();\n  logger.success(`Created ${projectName} at ${resolvedPath}`);\n  console.log();\n\n  if (!isInternalDocs && subdomain) {\n    console.log('Your docs will be available at:');\n    console.log(`  https://${subdomain}.devdoc.sh`);\n    console.log();\n    logger.info('Note: The subdomain will be reserved when you run \"devdoc deploy\"');\n    console.log();\n    console.log('Inside that directory, you can run several commands:');\n    console.log();\n    console.log('  npm run dev');\n    console.log('    Starts the development server.');\n    console.log();\n    console.log('  devdoc deploy');\n    console.log('    Deploys and claims your subdomain.');\n    console.log();\n  } else {\n    console.log('This is an internal documentation project for local development.');\n    console.log();\n    console.log('Inside that directory, you can run:');\n    console.log();\n    console.log('  npm run dev');\n    console.log('    Starts the development server at http://localhost:3000');\n    console.log();\n  }\n\n  console.log('We suggest that you begin by typing:');\n  console.log();\n  console.log(`  cd ${projectName}`);\n  console.log('  npm run dev');\n  console.log();\n\n  // Show AI agent quick start tips\n  console.log('AI Agent Quick Start:');\n  if (aiTool === 'claude' || aiTool === 'both') {\n    console.log('  Claude Code: /bootstrap-docs');\n  }\n  if (aiTool === 'cursor' || aiTool === 'both') {\n    console.log('  Cursor: Ask \"generate initial documentation from this repo\"');\n  }\n  console.log();\n\n  // ASCII art banner\n  console.log(`\n  ____              ____             \n |  _ \\\\  _____   __|  _ \\\\  ___   ___ \n | | | |/ _ \\\\ \\\\ / /| | | |/ _ \\\\ / __|\n | |_| |  __/\\\\ V / | |_| | (_) | (__ \n |____/ \\\\___| \\\\_/  |____/ \\\\___/ \\\\___|\n                                      \n  `);\n  console.log('Happy documenting!');\n  console.log();\n}\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@brainfish-ai/devdoc",
3
- "version": "0.1.36",
3
+ "version": "0.1.37",
4
4
  "description": "Documentation framework for developers. Write docs in MDX, preview locally, deploy to Brainfish.",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",