Use these settings in your docs.json file to control your site’s information architecture and user experience. Modify the navbar, footer, banners, navigation behavior, contextual menus, redirects, and global content variables.
Settings
navigation - required
Type: object
The navigation structure of your content. This is where you define your site’s full page hierarchy using groups, tabs, dropdowns, anchors, and more.
See Navigation for complete documentation on building your navigation structure.
Global navigation elements that appear across all pages and locales. Top-level navigation tabs for organizing major sections. See Tabs . Display name of the tab. Minimum length: 1.
The icon to display. Options:
Font Awesome icon name, if you have the icons.library property set to fontawesome in your docs.json
Lucide icon name, if you have the icons.library property set to lucide in your docs.json
Tabler icon name, if you have the icons.library property set to tabler in your docs.json
URL to an externally hosted icon
Path to an icon file in your project
SVG code wrapped in curly braces
For custom SVG icons:
Convert your SVG using the SVGR converter .
Paste your SVG code into the SVG input field.
Copy the complete <svg>...</svg> element from the JSX output field.
Wrap the JSX-compatible SVG code in curly braces: icon={<svg ...> ... </svg>}.
Adjust height and width as needed.
The Font Awesome icon style. Only used with Font Awesome icons. Options: regular, solid, light, thin, sharp-solid, duotone, brands. Whether to hide this tab by default.
URL or path for the tab destination.
Anchored links that appear prominently in the sidebar. See Anchors . Display name of the anchor. Minimum length: 1.
The icon to display. Options:
Font Awesome icon name, if you have the icons.library property set to fontawesome in your docs.json
Lucide icon name, if you have the icons.library property set to lucide in your docs.json
Tabler icon name, if you have the icons.library property set to tabler in your docs.json
URL to an externally hosted icon
Path to an icon file in your project
SVG code wrapped in curly braces
For custom SVG icons:
Convert your SVG using the SVGR converter .
Paste your SVG code into the SVG input field.
Copy the complete <svg>...</svg> element from the JSX output field.
Wrap the JSX-compatible SVG code in curly braces: icon={<svg ...> ... </svg>}.
Adjust height and width as needed.
The Font Awesome icon style. Only used with Font Awesome icons. Options: regular, solid, light, thin, sharp-solid, duotone, brands. Custom colors for the anchor icon. Anchor color for light mode. Must be a hex code beginning with #.
Anchor color for dark mode. Must be a hex code beginning with #.
Whether to hide this anchor by default.
URL or path for the anchor destination.
Dropdown menus for organizing related content. See Dropdowns . Display name of the dropdown. Minimum length: 1.
The icon to display. Options:
Font Awesome icon name, if you have the icons.library property set to fontawesome in your docs.json
Lucide icon name, if you have the icons.library property set to lucide in your docs.json
Tabler icon name, if you have the icons.library property set to tabler in your docs.json
URL to an externally hosted icon
Path to an icon file in your project
SVG code wrapped in curly braces
For custom SVG icons:
Convert your SVG using the SVGR converter .
Paste your SVG code into the SVG input field.
Copy the complete <svg>...</svg> element from the JSX output field.
Wrap the JSX-compatible SVG code in curly braces: icon={<svg ...> ... </svg>}.
Adjust height and width as needed.
The Font Awesome icon style. Only used with Font Awesome icons. Options: regular, solid, light, thin, sharp-solid, duotone, brands. Whether to hide this dropdown by default.
URL or path for the dropdown destination.
Language switcher configuration for localized sites. See Languages . language
"ar" | "ca" | "cn" | "cs" | "de" | "en" | "es" | "fr" | "he" | "hi" | "hu" | "id" | "it" | "ja" | "jp" | "ko" | "lv" | "nl" | "no" | "pl" | "pt" | "pt-BR" | "ro" | "ru" | "sv" | "tr" | "ua" | "uz" | "vi" | "zh" | "zh-Hans" | "zh-Hant"
required
Language code in ISO 639-1 format.
Whether this is the default language.
Whether to hide this language option by default.
A valid path or external link to this language version of your documentation.
Version switcher configuration for multi-version sites. See Versions . Display name of the version. Minimum length: 1.
Whether this is the default version.
Whether to hide this version by default.
URL or path to this version of your documentation.
Product switcher for sites with multiple products. See Products . Display name of the product.
Description of the product.
The icon to display. Options:
Font Awesome icon name, if you have the icons.library property set to fontawesome in your docs.json
Lucide icon name, if you have the icons.library property set to lucide in your docs.json
Tabler icon name, if you have the icons.library property set to tabler in your docs.json
URL to an externally hosted icon
Path to an icon file in your project
SVG code wrapped in curly braces
For custom SVG icons:
Convert your SVG using the SVGR converter .
Paste your SVG code into the SVG input field.
Copy the complete <svg>...</svg> element from the JSX output field.
Wrap the JSX-compatible SVG code in curly braces: icon={<svg ...> ... </svg>}.
Adjust height and width as needed.
The Font Awesome icon style. Only used with Font Awesome icons. Options: regular, solid, light, thin, sharp-solid, duotone, brands.
Language switcher for multi-language sites. Each entry can include language-specific banner, footer, and navbar configurations in addition to the navigation structure. Show navigation.languages
language
"ar" | "ca" | "cn" | "cs" | "de" | "en" | "es" | "fr" | "he" | "hi" | "id" | "it" | "ja" | "jp" | "ko" | "lv" | "nl" | "no" | "pl" | "pt" | "pt-BR" | "ro" | "ru" | "sv" | "tr" | "uk" | "uz" | "vi" | "zh" | "zh-Hans" | "zh-Hant"
required
Language code in ISO 639-1 format.
Whether this is the default language.
Language-specific banner configuration. Accepts the same options as the top-level banner field. Language-specific footer configuration. Accepts the same options as the top-level footer field. Language-specific navbar configuration. Accepts the same options as the top-level navbar field. Whether to hide this language option by default.
Version switcher for sites with multiple versions . Set to true to make this the default version. If omitted, the first version in the array is the default.
Badge label displayed next to the version in the selector. Use to highlight versions such as "Latest", "Recommended", or "Beta".
Top-level navigation tabs .
Product switcher for sites with multiple products .
Groups for organizing content into sections.
navigation.pages
array of string or object
Individual pages that make up your documentation.
navbar
Type: object
Links and buttons displayed in the top navigation bar.
Links to display in the navbar. Optional link type. Omit for a standard text link. Set to github to link to a GitHub repository and show its star count. Set to discord to link to a Discord server and show its online user count.
Link text. Required when type is not set. Optional for github and discord. If omitted, Mintlify generates the label from API data.
Link destination. Must be a valid external URL. For github, must be a GitHub repository URL. For discord, must be a Discord invite URL.
The icon to display. Options:
Font Awesome icon name, if you have the icons.library property set to fontawesome in your docs.json
Lucide icon name, if you have the icons.library property set to lucide in your docs.json
Tabler icon name, if you have the icons.library property set to tabler in your docs.json
URL to an externally hosted icon
Path to an icon file in your project
SVG code wrapped in curly braces
For custom SVG icons:
Convert your SVG using the SVGR converter .
Paste your SVG code into the SVG input field.
Copy the complete <svg>...</svg> element from the JSX output field.
Wrap the JSX-compatible SVG code in curly braces: icon={<svg ...> ... </svg>}.
Adjust height and width as needed.
The Font Awesome icon style. Only used with Font Awesome icons. Options: regular, solid, light, thin, sharp-solid, duotone, brands.
Primary call-to-action button in the navbar. type
"button" | "github" | "discord"
required
Button style. Choose button for a standard button, github for a GitHub repository link with star count, or discord for a Discord invite with online user count.
Button text. Required when type is button. Optional for github and discord.
Button destination. Must be an external URL. For github, must be a GitHub repository URL. For discord, must be a Discord invite URL.
"navbar" : {
"links" : [
{ "type" : "github" , "href" : "https://github.com/your-org/your-repo" },
{ "label" : "Community" , "href" : "https://example.com/community" }
],
"primary" : {
"type" : "button" ,
"label" : "Get started" ,
"href" : "https://example.com/signup"
}
}
Type: object
Footer content and social media links.
Social media profiles to display in the footer. Each key is a platform name and each value is your profile URL. Valid keys: x, website, facebook, youtube, discord, slack, github, linkedin, instagram, hacker-news, medium, telegram, twitter, x-twitter, earth-americas, bluesky, threads, reddit, podcast "socials" : {
"x" : "https://x.com/yourhandle" ,
"github" : "https://github.com/your-org"
}
Link columns displayed in the footer. Column header title. Minimum length: 1.
Links to display in the column. Link text. Minimum length: 1.
"footer" : {
"socials" : {
"x" : "https://x.com/yourhandle" ,
"github" : "https://github.com/your-org"
},
"links" : [
{
"header" : "Company" ,
"items" : [
{ "label" : "Blog" , "href" : "https://example.com/blog" },
{ "label" : "Careers" , "href" : "https://example.com/careers" }
]
}
]
}
banner
Type: object
A site-wide banner displayed at the top of every page.
The text content displayed in the banner. Supports basic MDX formatting including links, bold, and italic text. Custom components are not supported. "content" : "We just launched something new. [Learn more](https://example.com)"
Whether to show a dismiss button so users can close the banner. Defaults to false.
"banner" : {
"content" : "We just launched something new. [Learn more](https://example.com)" ,
"dismissible" : true
}
interaction
Type: object
Controls user interaction behavior for navigation elements.
Controls automatic navigation when selecting a navigation group. Set to true to automatically navigate to the first page when a group expands. Set to false to only expand or collapse the group without navigating. Leave unset to use the theme’s default behavior.
contextual
Type: object
The contextual menu gives users quick access to AI tools and page actions. It appears in the page header or table of contents sidebar.
The contextual menu is only available on preview and production deployments.
Actions available in the contextual menu. The first option in the array appears as the default action. Built-in options:
"add-mcp" — Add your MCP server to the user’s configuration
"aistudio" — Send the current page to Google AI Studio
"assistant" — Open the AI assistant with the current page as context
"copy" — Copy the current page as Markdown to the clipboard
"chatgpt" — Send the current page to ChatGPT
"claude" — Send the current page to Claude
"cursor" — Install your hosted MCP server in Cursor
"devin" — Send the current page to Devin
"grok" — Send the current page to Grok
"mcp" — Copy your MCP server URL to the clipboard
"perplexity" — Send the current page to Perplexity
"view" — View the current page as Markdown in a new tab
"vscode" — Install your hosted MCP server in VS Code
"windsurf" — Send the current page to Windsurf
Define custom options as objects: Display title for the custom option.
Description text for the custom option.
Icon for the custom option. Supports icon library names, URLs, paths, or SVG code.
Link destination. Can be a URL string or an object with base and optional query parameters. Available placeholder values:
$page — Current page content
$path — Current page path
$mcp — MCP server URL
Where to display the contextual options. Choose header to show them in the top-of-page context menu, or toc to show them in the table of contents sidebar. Defaults to header.
"contextual" : {
"options" : [ "copy" , "view" , "chatgpt" , "claude" ],
"display" : "header"
}
redirects
Type: array of object
Redirects for moved, renamed, or deleted pages. Use these to preserve links when you reorganize your content.
The path to redirect from. Example: /old-page
The path to redirect to. Example: /new-page
If true, issues a permanent redirect (308). If false, issues a temporary redirect (307). Defaults to true.
"redirects" : [
{
"source" : "/old-page" ,
"destination" : "/new-page"
},
{
"source" : "/temp-redirect" ,
"destination" : "/destination" ,
"permanent" : false
}
]
errors
Type: object
Custom error page settings.
Settings for the 404 “Page not found” error page. Whether to automatically redirect to the home page when a page is not found. Defaults to true.
Custom title for the 404 page.
Custom description for the 404 page. Supports MDX formatting including links, bold, and italic text, and custom components.
"errors" : {
"404" : {
"redirect" : false ,
"title" : "Page not found" ,
"description" : "The page you're looking for doesn't exist. [Go home](/)."
}
}
variables
Type: object
Global variables for use throughout your documentation. Mintlify replaces {{variableName}} placeholders with the defined values at build time.
A key-value pair where the key is the variable name and the value is the replacement text.
Variable names can contain alphanumeric characters, hyphens, and periods.
You must define all variables referenced in your content or the build fails.
Mintlify sanitizes values to prevent XSS attacks.
"variables" : {
"version" : "2.0.0" ,
"api-url" : "https://api.example.com"
}
In your content, reference variables with double curly braces:
The current version is { { version } } . Make requests to { {api- url } } .
Type: object
Page-level metadata settings applied globally.
Enable a last-modified date on all pages. When enabled, pages display the date the content was last modified. Defaults to false. You can override this setting on individual pages using the timestamp frontmatter field. See Pages for details.
"metadata" : {
"timestamp" : true
}