Skip to content

Sidebars Configuration

Devon edited this page Dec 30, 2024 · 1 revision

SignalWire Documentation Sidebar Configuration Guide

This document explains how sidebars are configured and managed in the SignalWire documentation platform. Consult the Docusaurus Sidebar reference for more information.

Sidebar Configuration Structure

The sidebar configuration is managed through multiple files:

  1. config/sidebarsConfig/index.ts - Main sidebar registration
  2. Individual sidebar configuration files in config/sidebarsConfig/
  3. Auto-generated sidebar files from OpenAPI documentation
  4. Integration through config/presets.js

Main Configuration Integration

Sidebars are integrated into Docusaurus through the config/presets.js configuration:

// config/presets.js
module.exports = [
  [
    "classic",
    ({
      docs: {
        sidebarPath: require.resolve("./sidebarsConfig"),
        // ... other configurations
      },
    }),
  ],
];

Sidebar Types

Our documentation uses several types of sidebars:

  1. Homepage Sidebar - Sidebar for homepage. Shows product overviews and more.
  2. API Reference Sidebars - Auto-generated from OpenAPI specs and manually configured sections
  3. SDK Reference Sidebars - For SDK documentation
  4. Technical Reference Sidebars - For technical specifications

Sidebar Registration Process

Standard Sidebars

Sidebars are registered through a two-step process:

  1. Create a sidebar configuration file in /config/sidebarsConfig/
  2. Import and add the sidebar to index.ts
// config/sidebarsConfig/index.ts
import type { SidebarsConfig } from "@docusaurus/plugin-content-docs";
import productSpecificSidebars from './product-specific-sidebar';
import apiSidebar from './rest-api-sidebar';
// ... other imports

const sidebars: SidebarsConfig = {
  ...productSpecificSidebars,
  ...apiSidebar,
  // ... other sidebars
};

export default sidebars;

OpenAPI Generated Sidebars

For REST API documentation, sidebars are generated alongside the API docs with the OpenAPI Docs plugin.

  1. Plugin generates documentation from OpenAPI specs
  2. Sidebar files are created in specified output directories
  3. Generated sidebars are imported into main REST API configuration
// Example of importing generated sidebar
{
  type: "category",
  label: "REST Endpoints",
  items: require("../../docs/rest/compatibility-api/endpoints/sidebar")
}

Current Sidebar Configurations

1. Product-Specific Sidebars

Location: /config/sidebarsConfig/product-specific-sidebar.ts

  • Handles product documentation navigation
  • Includes sections for Voice, Video, Messaging, etc.
  • Uses a common header generator function
function getProductSidebarHeader(productName: string) {
  return [
    {
      type: "html",
      value: `<div class="menu-html-category-header">${productName}</div>`,
    },
    // ... other header elements
  ];
}

2. REST API Sidebars

Location: /config/sidebarsConfig/rest-api-sidebar.ts

  • Combines manually configured sections with auto-generated content
  • Generated sections include:
    • Compatibility API endpoints
    • SignalWire REST API endpoints (Calling, Chat, Voice, etc.)
  • Plugin configuration specifies output directories:
{
  outputDir: "docs/rest/compatibility-api/endpoints"
}

3. SDK Sidebars

Location:

  • /config/sidebarsConfig/client-sdk-sidebar.ts
  • /config/sidebarsConfig/relay-browser-sidebar.ts
  • /config/sidebarsConfig/relay-realtime-sidebar.ts

Handles SDK documentation navigation including:

  • Browser SDK
  • Realtime SDK
  • Client SDKs
  • Previous SDK versions

4. Technical Reference Sidebars

Location:

  • /config/sidebarsConfig/swml-sidebar.ts
  • /config/sidebarsConfig/call-flow-builder-sidebar.ts

Sidebar Categories

Sidebars can contain several types of items:

  1. Autogenerated Categories
{
  type: "autogenerated",
  dirName: "guides/voice-api"
}
  1. Manual Categories
{
  type: "category",
  label: "Overview",
  items: [/* ... items ... */]
}
  1. Direct Links
{
  type: "link",
  href: "/guides",
  label: "ᐸ Go back to all guides"
}
  1. HTML Elements
{
  type: "html",
  value: `<div class="menu-html-category-header">Voice</div>`
}
  1. Generated Index Pages
{
  type: "category",
  label: "REST Endpoints",
  link: {
    type: "generated-index",
    title: "Available SignalWire REST Endpoints",
    description: "API endpoint documentation",
    slug: "/rest/signalwire-rest/endpoints"
  }
}

Adding New Sidebars

Adding Standard Sidebars

  1. Create a new file in /config/sidebarsConfig/:
// config/sidebarsConfig/new-sidebar.ts
import type { SidebarsConfig } from "@docusaurus/plugin-content-docs";

const newSidebar: SidebarsConfig = {
  newSidebar: [
    {
      type: "category",
      label: "New Section",
      items: [/* ... items ... */]
    }
  ]
};

export default newSidebar;
  1. Import and add to index.ts:
import newSidebar from './new-sidebar';

const sidebars: SidebarsConfig = {
  ...existingSidebars,
  ...newSidebar,
};

Adding OpenAPI Generated Sidebars

  1. Configure the OpenAPI plugin with the output directory
  2. Generate the documentation and sidebar files
  3. Import the generated sidebar into your configuration:
{
  items: require("../../docs/your-api/endpoints/sidebar")
}

Best Practices

  1. Keep sidebar configurations modular and separate
  2. Use consistent naming conventions
  3. Leverage autogeneration where possible
  4. Group related content together
  5. Maintain clear category hierarchies
  6. Use descriptive labels and slugs
  7. Keep OpenAPI specifications and generated docs in sync
  8. Maintain consistent directory structure for generated content

Troubleshooting

If a sidebar isn't working:

  1. Check the sidebar configuration file
  2. Verify the import in index.ts
  3. Ensure the directory structure matches autogenerated paths
  4. Check for duplicate sidebar IDs
  5. Verify the presets configuration
  6. For OpenAPI sidebars:
    • Verify the documentation was generated
    • Check the output directory structure
    • Regenerate documentation if API specs changed