Customize API Reference layout
When you include an API in your docs.yml
file, you can customize how the endpoints and sections are displayed in the sidebar navigation. By default, the reference will generate a navigation hierarchy based on the structure of the API spec, but several customizations can be configured.
API Sections
If you are using an OpenAPI Specification, sections are created based on the tags
property, converted to lowerCamelCase
convention (e.g., createUser). If you are using a Fern Definition, sections are created based on the service
file names.
If you would like to only display a subset of endpoints, read more about the Audiences property for OpenAPI Specifications or Fern Definitions.
Ordering the API Reference
Alphabetizing endpoints and sections
To sort all sections and endpoints alphabetically, unless explicitly ordered in layout
, set alphabetized
to true
.
Ordering top-level sections
The layout
option allows you to specify the order of sub-packages, sections, endpoints, and pages at the top level of your API Reference.
OpenAPI Specification
Fern Definition
data:image/s3,"s3://crabby-images/30f24/30f24a5768f8fc3b8c015e8c66c100a7d6908c11" alt="Ordered API Reference"
Ordering section contents
Adding a :
after the section name allows you to specify the order of its nested sub-packages and endpoints.
Referencing Endpoints
To reference an endpoint, you can use either:
METHOD /path/name
(best for OpenAPI Specification)serviceName.endpointName
(best for Fern Definition)
OpenAPI Specification
Fern Definition
You can reference an endpoint using the format METHOD /path
.
data:image/s3,"s3://crabby-images/9c1ae/9c1ae4c16a94d1f789bb41bef74223ac430460a4" alt="Content ordered in the API Reference"
Customizing the API Reference
Flattening sections
To remove the API Reference title and display the section contents, set flattened
to true
.
data:image/s3,"s3://crabby-images/093b4/093b410054d0c92d9210e85497633ec8051bbf32" alt="Flattened API Reference"
Styling endpoints
To customize the display of an endpoint, you can add a title
. You can also use slug
to customize the endpoint URL.
OpenAPI Specification
Fern Definition
data:image/s3,"s3://crabby-images/7e911/7e911c71fe8d91179173744bae03bd286bc925f5" alt="Setting an endpoint title"
Hiding endpoints
You can hide an endpoint from the API reference by setting hidden
to true
. The endpoint will still be accessible at its URL.
OpenAPI Specification
Fern Definition
Fully hidden endpoints
For best results, API References with hidden endpoints should use the paginated: true
configuration to avoid discovering endpoints from long-scrolling.
Adding custom sections
You can add arbitrary folders in the sidebar by adding a section
to your API Reference layout. A section can comprise entire groups of endpoints, individual endpoints, or even just Markdown pages. Sections can be customized by adding properties like a icon
, summary
, slug
(or skip-slug
), and contents
.
OpenAPI Specification
Fern Definition
data:image/s3,"s3://crabby-images/6677c/6677c525863b1dc5e2773c5825627a7609c49a1d" alt="Custom section in the API Reference"
Adding a section overview
The summary
property allows you to add an .md
or .mdx
page as an overview of the API Reference or a section.
data:image/s3,"s3://crabby-images/4a28b/4a28bd6f16060c0c1b620b399de9326bc22104c1" alt="API Reference with a summary page"
Adding pages and links
You can add regular pages and external links within your API Reference.
Disable long-scrolling
By default, the API Reference renders all endpoints on a single page (long-scrolling). To create separate pages for each endpoint, set paginated: true
.