@brainfish-ai/devdoc 0.1.32 → 0.1.33
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.
- package/ai-agents/.claude/skills/bootstrap-docs/SKILL.md +221 -64
- package/ai-agents/.claude/skills/check-docs/SKILL.md +21 -2
- package/ai-agents/.claude/skills/create-doc-page/SKILL.md +242 -25
- package/ai-agents/.claude/skills/docs-from-code/SKILL.md +9 -1
- package/ai-agents/.claude/skills/sync-docs/SKILL.md +36 -2
- package/ai-agents/.cursor/rules/devdoc-bootstrap.mdc +90 -36
- package/ai-agents/.cursor/rules/devdoc-sync.mdc +46 -11
- package/ai-agents/CLAUDE.md +9 -0
- package/dist/cli/commands/ai.d.ts +1 -0
- package/dist/cli/commands/ai.js +100 -35
- package/dist/cli/index.js +3 -2
- package/package.json +1 -1
- package/renderer/components/docs-viewer/sidebar/index.tsx +118 -87
package/dist/cli/index.js
CHANGED
|
@@ -62,8 +62,9 @@ program
|
|
|
62
62
|
.action(check_1.check);
|
|
63
63
|
program
|
|
64
64
|
.command('ai')
|
|
65
|
-
.description('Set up AI agent configuration (Claude Code skills, Cursor rules)')
|
|
65
|
+
.description('Set up or update AI agent configuration (Claude Code skills, Cursor rules)')
|
|
66
66
|
.option('-t, --tool <tool>', 'AI tool to configure (claude, cursor, both)')
|
|
67
|
+
.option('--update', 'Update existing skills/rules to latest version')
|
|
67
68
|
.action(ai_1.ai);
|
|
68
69
|
program
|
|
69
70
|
.command('deploy')
|
|
@@ -142,4 +143,4 @@ domainCmd
|
|
|
142
143
|
.option('-k, --api-key <key>', 'API key for authentication')
|
|
143
144
|
.action(domain_1.domainRemove);
|
|
144
145
|
program.parse(process.argv);
|
|
145
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/cli/index.ts"],"names":[],"mappings":"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","sourcesContent":["import { Command } from 'commander';\nimport { create } from './commands/create';\nimport { init } from './commands/init';\nimport { dev } from './commands/dev';\nimport { build } from './commands/build';\nimport { start } from './commands/start';\nimport { check } from './commands/check';\nimport { deploy } from './commands/deploy';\nimport { listKeys, regenerateKey } from './commands/keys';\nimport { whoami } from './commands/whoami';\nimport { upload, listAssets } from './commands/upload';\nimport { ai } from './commands/ai';\nimport { domainAdd, domainStatus, domainVerify, domainRemove } from './commands/domain';\n\nconst packageJson = require('../../package.json');\n\nconst program = new Command();\n\nprogram\n  .name('devdoc')\n  .description('Documentation framework for developers')\n  .version(packageJson.version);\n\nprogram\n  .command('create [project-directory]')\n  .description('Create a new DevDoc documentation site')\n  .option('-t, --template <type>', 'Template to use (basic, openapi, graphql)')\n  .option('-s, --subdomain <subdomain>', 'Subdomain for your docs (e.g., my-docs.devdoc.sh)')\n  .option('--no-git', 'Skip git initialization')\n  .option('--no-install', 'Skip installing dependencies')\n  .option('--ai [tool]', 'Set up AI agents (claude, cursor, both, or just --ai to choose)')\n  .option('-u, --url <url>', 'API URL (default: https://devdoc.sh)')\n  .action(create);\n\nprogram\n  .command('init')\n  .description('Initialize/register project with Brainfish')\n  .option('-s, --slug <slug>', 'Project slug')\n  .option('--subdomain <subdomain>', 'Subdomain for your docs (e.g., my-docs.devdoc.sh)')\n  .option('-f, --force', 'Overwrite existing .devdoc.json')\n  .option('--ai [tool]', 'Set up AI agents (claude, cursor, both, or just --ai to choose)')\n  .option('-u, --url <url>', 'API URL (default: https://devdoc.sh)')\n  .action(init);\n\nprogram\n  .command('dev')\n  .description('Start development server with hot reload')\n  .option('-p, --port <port>', 'Port to run the server on', '3333')\n  .option('-H, --host <host>', 'Host to bind the server to', 'localhost')\n  .option('-o, --open', 'Open browser automatically', true)\n  .option('--no-open', 'Do not open browser automatically')\n  .action(dev);\n\nprogram\n  .command('build')\n  .description('Build documentation for production')\n  .option('-o, --output <dir>', 'Output directory', 'dist')\n  .action(build);\n\nprogram\n  .command('start')\n  .description('Start production server')\n  .option('-p, --port <port>', 'Port to run the server on', '3000')\n  .action(start);\n\nprogram\n  .command('check')\n  .description('Validate docs.json and MDX files')\n  .action(check);\n\nprogram\n  .command('ai')\n  .description('Set up AI agent configuration (Claude Code skills, Cursor rules)')\n  .option('-t, --tool <tool>', 'AI tool to configure (claude, cursor, both)')\n  .action(ai);\n\nprogram\n  .command('deploy')\n  .description('Deploy documentation to DevDoc platform')\n  .option('-u, --url <url>', 'API URL (default: https://devdoc.sh)')\n  .option('-k, --api-key <key>', 'API key for authentication')\n  .action(deploy);\n\n// Keys management\nconst keysCmd = program\n  .command('keys')\n  .description('Manage API keys for your project');\n\nkeysCmd\n  .command('list')\n  .description('Show current API key info')\n  .option('-u, --url <url>', 'API URL')\n  .action(listKeys);\n\nkeysCmd\n  .command('regenerate')\n  .description('Generate a new API key (invalidates the old one)')\n  .option('-u, --url <url>', 'API URL')\n  .action(regenerateKey);\n\nprogram\n  .command('whoami')\n  .description('Show current project information')\n  .option('-u, --url <url>', 'API URL')\n  .action(whoami);\n\n// Assets management\nconst assetsCmd = program\n  .command('assets')\n  .description('Manage project assets (images, files)');\n\nassetsCmd\n  .command('upload <files...>')\n  .description('Upload assets to storage (max 25MB per file)')\n  .option('-u, --url <url>', 'API URL')\n  .option('-k, --api-key <key>', 'API key for authentication')\n  .action(upload);\n\nassetsCmd\n  .command('list')\n  .description('List uploaded assets')\n  .option('-u, --url <url>', 'API URL')\n  .option('-k, --api-key <key>', 'API key for authentication')\n  .action(listAssets);\n\n// Shortcut for upload\nprogram\n  .command('upload <files...>')\n  .description('Upload assets to storage (shortcut for \"devdoc assets upload\")')\n  .option('-u, --url <url>', 'API URL')\n  .option('-k, --api-key <key>', 'API key for authentication')\n  .action(upload);\n\n// Domain management - custom domains (one per project, free)\nconst domainCmd = program\n  .command('domain')\n  .description('Manage custom domain for your documentation');\n\ndomainCmd\n  .command('add <custom-domain>')\n  .description('Add a custom domain (e.g., docs.example.com)')\n  .option('-u, --url <url>', 'API URL')\n  .option('-k, --api-key <key>', 'API key for authentication')\n  .action(domainAdd);\n\ndomainCmd\n  .command('status')\n  .description('Check custom domain status and DNS configuration')\n  .option('-u, --url <url>', 'API URL')\n  .option('-k, --api-key <key>', 'API key for authentication')\n  .action(domainStatus);\n\ndomainCmd\n  .command('verify')\n  .description('Verify DNS configuration for your custom domain')\n  .option('-u, --url <url>', 'API URL')\n  .option('-k, --api-key <key>', 'API key for authentication')\n  .action(domainVerify);\n\ndomainCmd\n  .command('remove [custom-domain]')\n  .description('Remove custom domain from project')\n  .option('-u, --url <url>', 'API URL')\n  .option('-k, --api-key <key>', 'API key for authentication')\n  .action(domainRemove);\n\nprogram.parse(process.argv);\n"]}
|
|
146
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/cli/index.ts"],"names":[],"mappings":"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","sourcesContent":["import { Command } from 'commander';\nimport { create } from './commands/create';\nimport { init } from './commands/init';\nimport { dev } from './commands/dev';\nimport { build } from './commands/build';\nimport { start } from './commands/start';\nimport { check } from './commands/check';\nimport { deploy } from './commands/deploy';\nimport { listKeys, regenerateKey } from './commands/keys';\nimport { whoami } from './commands/whoami';\nimport { upload, listAssets } from './commands/upload';\nimport { ai } from './commands/ai';\nimport { domainAdd, domainStatus, domainVerify, domainRemove } from './commands/domain';\n\nconst packageJson = require('../../package.json');\n\nconst program = new Command();\n\nprogram\n  .name('devdoc')\n  .description('Documentation framework for developers')\n  .version(packageJson.version);\n\nprogram\n  .command('create [project-directory]')\n  .description('Create a new DevDoc documentation site')\n  .option('-t, --template <type>', 'Template to use (basic, openapi, graphql)')\n  .option('-s, --subdomain <subdomain>', 'Subdomain for your docs (e.g., my-docs.devdoc.sh)')\n  .option('--no-git', 'Skip git initialization')\n  .option('--no-install', 'Skip installing dependencies')\n  .option('--ai [tool]', 'Set up AI agents (claude, cursor, both, or just --ai to choose)')\n  .option('-u, --url <url>', 'API URL (default: https://devdoc.sh)')\n  .action(create);\n\nprogram\n  .command('init')\n  .description('Initialize/register project with Brainfish')\n  .option('-s, --slug <slug>', 'Project slug')\n  .option('--subdomain <subdomain>', 'Subdomain for your docs (e.g., my-docs.devdoc.sh)')\n  .option('-f, --force', 'Overwrite existing .devdoc.json')\n  .option('--ai [tool]', 'Set up AI agents (claude, cursor, both, or just --ai to choose)')\n  .option('-u, --url <url>', 'API URL (default: https://devdoc.sh)')\n  .action(init);\n\nprogram\n  .command('dev')\n  .description('Start development server with hot reload')\n  .option('-p, --port <port>', 'Port to run the server on', '3333')\n  .option('-H, --host <host>', 'Host to bind the server to', 'localhost')\n  .option('-o, --open', 'Open browser automatically', true)\n  .option('--no-open', 'Do not open browser automatically')\n  .action(dev);\n\nprogram\n  .command('build')\n  .description('Build documentation for production')\n  .option('-o, --output <dir>', 'Output directory', 'dist')\n  .action(build);\n\nprogram\n  .command('start')\n  .description('Start production server')\n  .option('-p, --port <port>', 'Port to run the server on', '3000')\n  .action(start);\n\nprogram\n  .command('check')\n  .description('Validate docs.json and MDX files')\n  .action(check);\n\nprogram\n  .command('ai')\n  .description('Set up or update AI agent configuration (Claude Code skills, Cursor rules)')\n  .option('-t, --tool <tool>', 'AI tool to configure (claude, cursor, both)')\n  .option('--update', 'Update existing skills/rules to latest version')\n  .action(ai);\n\nprogram\n  .command('deploy')\n  .description('Deploy documentation to DevDoc platform')\n  .option('-u, --url <url>', 'API URL (default: https://devdoc.sh)')\n  .option('-k, --api-key <key>', 'API key for authentication')\n  .action(deploy);\n\n// Keys management\nconst keysCmd = program\n  .command('keys')\n  .description('Manage API keys for your project');\n\nkeysCmd\n  .command('list')\n  .description('Show current API key info')\n  .option('-u, --url <url>', 'API URL')\n  .action(listKeys);\n\nkeysCmd\n  .command('regenerate')\n  .description('Generate a new API key (invalidates the old one)')\n  .option('-u, --url <url>', 'API URL')\n  .action(regenerateKey);\n\nprogram\n  .command('whoami')\n  .description('Show current project information')\n  .option('-u, --url <url>', 'API URL')\n  .action(whoami);\n\n// Assets management\nconst assetsCmd = program\n  .command('assets')\n  .description('Manage project assets (images, files)');\n\nassetsCmd\n  .command('upload <files...>')\n  .description('Upload assets to storage (max 25MB per file)')\n  .option('-u, --url <url>', 'API URL')\n  .option('-k, --api-key <key>', 'API key for authentication')\n  .action(upload);\n\nassetsCmd\n  .command('list')\n  .description('List uploaded assets')\n  .option('-u, --url <url>', 'API URL')\n  .option('-k, --api-key <key>', 'API key for authentication')\n  .action(listAssets);\n\n// Shortcut for upload\nprogram\n  .command('upload <files...>')\n  .description('Upload assets to storage (shortcut for \"devdoc assets upload\")')\n  .option('-u, --url <url>', 'API URL')\n  .option('-k, --api-key <key>', 'API key for authentication')\n  .action(upload);\n\n// Domain management - custom domains (one per project, free)\nconst domainCmd = program\n  .command('domain')\n  .description('Manage custom domain for your documentation');\n\ndomainCmd\n  .command('add <custom-domain>')\n  .description('Add a custom domain (e.g., docs.example.com)')\n  .option('-u, --url <url>', 'API URL')\n  .option('-k, --api-key <key>', 'API key for authentication')\n  .action(domainAdd);\n\ndomainCmd\n  .command('status')\n  .description('Check custom domain status and DNS configuration')\n  .option('-u, --url <url>', 'API URL')\n  .option('-k, --api-key <key>', 'API key for authentication')\n  .action(domainStatus);\n\ndomainCmd\n  .command('verify')\n  .description('Verify DNS configuration for your custom domain')\n  .option('-u, --url <url>', 'API URL')\n  .option('-k, --api-key <key>', 'API key for authentication')\n  .action(domainVerify);\n\ndomainCmd\n  .command('remove [custom-domain]')\n  .description('Remove custom domain from project')\n  .option('-u, --url <url>', 'API URL')\n  .option('-k, --api-key <key>', 'API key for authentication')\n  .action(domainRemove);\n\nprogram.parse(process.argv);\n"]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
'use client'
|
|
2
2
|
|
|
3
|
-
import { useMemo } from 'react'
|
|
3
|
+
import { useMemo, useEffect, useState } from 'react'
|
|
4
|
+
import { createPortal } from 'react-dom'
|
|
4
5
|
import { X, Spinner } from '@phosphor-icons/react'
|
|
5
6
|
import { Button } from '@/components/ui/button'
|
|
6
7
|
import {
|
|
@@ -54,6 +55,12 @@ export function DocsSidebar({
|
|
|
54
55
|
isVersionLoading,
|
|
55
56
|
}: ApiDocsSidebarProps) {
|
|
56
57
|
const { isMobile, isLeftSidebarOpen, closeLeftSidebar } = useMobile()
|
|
58
|
+
const [mounted, setMounted] = useState(false)
|
|
59
|
+
|
|
60
|
+
// Ensure we're mounted before using portal (for SSR)
|
|
61
|
+
useEffect(() => {
|
|
62
|
+
setMounted(true)
|
|
63
|
+
}, [])
|
|
57
64
|
|
|
58
65
|
// Handle request selection with mobile close
|
|
59
66
|
const handleSelectRequest = (request: BrainfishRESTRequest) => {
|
|
@@ -145,12 +152,96 @@ export function DocsSidebar({
|
|
|
145
152
|
)
|
|
146
153
|
}
|
|
147
154
|
|
|
148
|
-
|
|
155
|
+
// Sidebar content component (shared between mobile and desktop)
|
|
156
|
+
const sidebarContent = (
|
|
157
|
+
<>
|
|
158
|
+
{/* Mobile close button */}
|
|
159
|
+
{isMobile && (
|
|
160
|
+
<div className="px-4 h-[41px] flex items-center justify-end border-b border-sidebar-border shrink-0">
|
|
161
|
+
<Button
|
|
162
|
+
variant="ghost"
|
|
163
|
+
size="icon"
|
|
164
|
+
onClick={closeLeftSidebar}
|
|
165
|
+
className="h-7 w-7 lg:hidden"
|
|
166
|
+
>
|
|
167
|
+
<X className="h-4 w-4" weight="bold" />
|
|
168
|
+
</Button>
|
|
169
|
+
</div>
|
|
170
|
+
)}
|
|
171
|
+
|
|
172
|
+
{/* API Version Selector - Only show when multiple versions exist and on API Reference tab */}
|
|
173
|
+
{activeTab === 'api-reference' && apiVersions && apiVersions.length > 1 && (
|
|
174
|
+
<div className="docs-sidebar-version-selector px-4 py-3 border-b border-sidebar-border shrink-0">
|
|
175
|
+
<div className="flex items-center justify-between mb-1.5">
|
|
176
|
+
<label className="docs-sidebar-version-label text-xs font-medium text-muted-foreground">
|
|
177
|
+
API Version
|
|
178
|
+
</label>
|
|
179
|
+
{isVersionLoading && (
|
|
180
|
+
<Spinner className="h-3 w-3 animate-spin text-muted-foreground" />
|
|
181
|
+
)}
|
|
182
|
+
</div>
|
|
183
|
+
<Select
|
|
184
|
+
value={selectedApiVersion || apiVersions.find(v => v.default)?.version || apiVersions[0]?.version}
|
|
185
|
+
onValueChange={(value) => onApiVersionChange?.(value)}
|
|
186
|
+
disabled={isVersionLoading}
|
|
187
|
+
>
|
|
188
|
+
<SelectTrigger className={cn("docs-sidebar-version-trigger w-full h-9 text-sm", isVersionLoading && "opacity-50")}>
|
|
189
|
+
<SelectValue placeholder="Select version" />
|
|
190
|
+
</SelectTrigger>
|
|
191
|
+
<SelectContent>
|
|
192
|
+
{apiVersions.map((v) => (
|
|
193
|
+
<SelectItem key={v.version} value={v.version}>
|
|
194
|
+
{v.version}
|
|
195
|
+
{v.default && <span className="ml-2 text-xs text-muted-foreground">(latest)</span>}
|
|
196
|
+
</SelectItem>
|
|
197
|
+
))}
|
|
198
|
+
</SelectContent>
|
|
199
|
+
</Select>
|
|
200
|
+
</div>
|
|
201
|
+
)}
|
|
202
|
+
|
|
203
|
+
{/* Scrollable content with sliding indicator */}
|
|
204
|
+
<SlidingIndicatorProvider className="docs-sidebar-content flex-1 overflow-y-auto overflow-x-hidden custom-scroll">
|
|
205
|
+
{/* Documentation Pages Section (from docs.json groups) */}
|
|
206
|
+
{docGroups.length > 0 && (
|
|
207
|
+
<>
|
|
208
|
+
{docGroups.map((group, index) => (
|
|
209
|
+
<SidebarSection
|
|
210
|
+
key={group.id}
|
|
211
|
+
title={group.title}
|
|
212
|
+
icon={group.icon}
|
|
213
|
+
className={index > 0 ? '' : ''}
|
|
214
|
+
>
|
|
215
|
+
{group.pages.map(renderDocPage)}
|
|
216
|
+
</SidebarSection>
|
|
217
|
+
))}
|
|
218
|
+
</>
|
|
219
|
+
)}
|
|
220
|
+
|
|
221
|
+
{/* Endpoints Section */}
|
|
222
|
+
{(collection.folders.length > 0 || collection.requests.length > 0) && (
|
|
223
|
+
<SidebarSection
|
|
224
|
+
title="Endpoints"
|
|
225
|
+
className={docGroups.length > 0 ? 'border-t border-sidebar-border' : ''}
|
|
226
|
+
>
|
|
227
|
+
<CollectionTree
|
|
228
|
+
collection={collection}
|
|
229
|
+
selectedRequest={selectedRequest}
|
|
230
|
+
onSelectRequest={handleSelectRequest}
|
|
231
|
+
/>
|
|
232
|
+
</SidebarSection>
|
|
233
|
+
)}
|
|
234
|
+
</SlidingIndicatorProvider>
|
|
235
|
+
</>
|
|
236
|
+
)
|
|
237
|
+
|
|
238
|
+
// Mobile sidebar rendered via portal to escape stacking context
|
|
239
|
+
const mobileSidebar = mounted && isMobile ? createPortal(
|
|
149
240
|
<>
|
|
150
241
|
{/* Mobile overlay backdrop */}
|
|
151
|
-
{
|
|
242
|
+
{isLeftSidebarOpen && (
|
|
152
243
|
<div
|
|
153
|
-
className="docs-sidebar-overlay fixed inset-0 bg-black/50 z-
|
|
244
|
+
className="docs-sidebar-overlay fixed inset-0 bg-black/50 z-[55] lg:hidden"
|
|
154
245
|
onClick={closeLeftSidebar}
|
|
155
246
|
/>
|
|
156
247
|
)}
|
|
@@ -158,94 +249,34 @@ export function DocsSidebar({
|
|
|
158
249
|
<aside
|
|
159
250
|
className={cn(
|
|
160
251
|
"docs-sidebar flex flex-col border-r border-sidebar-border overflow-hidden bg-muted dark:bg-background",
|
|
161
|
-
|
|
162
|
-
"lg:relative lg:w-72 lg:h-full",
|
|
163
|
-
// Mobile: drawer behavior
|
|
164
|
-
"fixed inset-y-0 left-0 z-50 w-[280px] h-full",
|
|
252
|
+
"fixed inset-y-0 left-0 z-[60] w-[280px] h-full",
|
|
165
253
|
"transform transition-transform duration-300 ease-in-out",
|
|
166
|
-
"
|
|
167
|
-
|
|
168
|
-
isMobile && isLeftSidebarOpen && "translate-x-0"
|
|
254
|
+
!isLeftSidebarOpen && "-translate-x-full",
|
|
255
|
+
isLeftSidebarOpen && "translate-x-0"
|
|
169
256
|
)}
|
|
170
257
|
>
|
|
171
|
-
{
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
size="icon"
|
|
177
|
-
onClick={closeLeftSidebar}
|
|
178
|
-
className="h-7 w-7 lg:hidden"
|
|
179
|
-
>
|
|
180
|
-
<X className="h-4 w-4" weight="bold" />
|
|
181
|
-
</Button>
|
|
182
|
-
</div>
|
|
183
|
-
)}
|
|
184
|
-
|
|
185
|
-
{/* API Version Selector - Only show when multiple versions exist and on API Reference tab */}
|
|
186
|
-
{activeTab === 'api-reference' && apiVersions && apiVersions.length > 1 && (
|
|
187
|
-
<div className="docs-sidebar-version-selector px-4 py-3 border-b border-sidebar-border shrink-0">
|
|
188
|
-
<div className="flex items-center justify-between mb-1.5">
|
|
189
|
-
<label className="docs-sidebar-version-label text-xs font-medium text-muted-foreground">
|
|
190
|
-
API Version
|
|
191
|
-
</label>
|
|
192
|
-
{isVersionLoading && (
|
|
193
|
-
<Spinner className="h-3 w-3 animate-spin text-muted-foreground" />
|
|
194
|
-
)}
|
|
195
|
-
</div>
|
|
196
|
-
<Select
|
|
197
|
-
value={selectedApiVersion || apiVersions.find(v => v.default)?.version || apiVersions[0]?.version}
|
|
198
|
-
onValueChange={(value) => onApiVersionChange?.(value)}
|
|
199
|
-
disabled={isVersionLoading}
|
|
200
|
-
>
|
|
201
|
-
<SelectTrigger className={cn("docs-sidebar-version-trigger w-full h-9 text-sm", isVersionLoading && "opacity-50")}>
|
|
202
|
-
<SelectValue placeholder="Select version" />
|
|
203
|
-
</SelectTrigger>
|
|
204
|
-
<SelectContent>
|
|
205
|
-
{apiVersions.map((v) => (
|
|
206
|
-
<SelectItem key={v.version} value={v.version}>
|
|
207
|
-
{v.version}
|
|
208
|
-
{v.default && <span className="ml-2 text-xs text-muted-foreground">(latest)</span>}
|
|
209
|
-
</SelectItem>
|
|
210
|
-
))}
|
|
211
|
-
</SelectContent>
|
|
212
|
-
</Select>
|
|
213
|
-
</div>
|
|
214
|
-
)}
|
|
258
|
+
{sidebarContent}
|
|
259
|
+
</aside>
|
|
260
|
+
</>,
|
|
261
|
+
document.body
|
|
262
|
+
) : null
|
|
215
263
|
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
>
|
|
228
|
-
{group.pages.map(renderDocPage)}
|
|
229
|
-
</SidebarSection>
|
|
230
|
-
))}
|
|
231
|
-
</>
|
|
232
|
-
)}
|
|
264
|
+
// Desktop sidebar rendered in place
|
|
265
|
+
const desktopSidebar = !isMobile ? (
|
|
266
|
+
<aside
|
|
267
|
+
className={cn(
|
|
268
|
+
"docs-sidebar flex flex-col border-r border-sidebar-border overflow-hidden bg-muted dark:bg-background",
|
|
269
|
+
"relative w-72 h-full"
|
|
270
|
+
)}
|
|
271
|
+
>
|
|
272
|
+
{sidebarContent}
|
|
273
|
+
</aside>
|
|
274
|
+
) : null
|
|
233
275
|
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
className={docGroups.length > 0 ? 'border-t border-sidebar-border' : ''}
|
|
239
|
-
>
|
|
240
|
-
<CollectionTree
|
|
241
|
-
collection={collection}
|
|
242
|
-
selectedRequest={selectedRequest}
|
|
243
|
-
onSelectRequest={handleSelectRequest}
|
|
244
|
-
/>
|
|
245
|
-
</SidebarSection>
|
|
246
|
-
)}
|
|
247
|
-
</SlidingIndicatorProvider>
|
|
248
|
-
</aside>
|
|
276
|
+
return (
|
|
277
|
+
<>
|
|
278
|
+
{mobileSidebar}
|
|
279
|
+
{desktopSidebar}
|
|
249
280
|
</>
|
|
250
281
|
)
|
|
251
282
|
}
|