documentation/guides/docs/configuration/scalar.config.json.md
The scalar.config.json file is the central configuration file for Docs. It defines your project's metadata, navigation structure, site settings, and deployment options.
You can create a configuration file manually or use the Scalar CLI:
npx @scalar/cli project init
This command creates a scalar.config.json file in your current directory with a basic structure to get you started.
Here is a minimal configuration to get started:
{
"$schema": "https://registry.scalar.com/@scalar/schemas/config",
"scalar": "2.0.0",
"info": {
"title": "My Documentation",
"description": "The best documentation you've read today"
},
"navigation": {
"routes": {
"/": {
"title": "Introduction",
"type": "page",
"filepath": "docs/introduction.md"
}
}
}
}
To get autocomplete and validation in your editor, enable JSON schema downloads in VS Code (or Cursor):
// .vscode/settings.json
{
"json.schemaDownload.enable": true
"json.schemaDownload.trustedDomains": {
"https://registry.scalar.com/": true,
}
}
The $schema property in your configuration file tells the editor where to find the schema:
// scalar.config.json
{
"$schema": "https://registry.scalar.com/@scalar/schemas/config"
}
Your editor will now provide autocomplete suggestions and highlight invalid properties.
| Property | Type | Description |
|---|---|---|
$schema | string | JSON Schema URL for editor autocomplete and validation |
scalar | string | Configuration version. Use "2.0.0" for the latest format |
info | object | Project metadata (title, description) |
navigation | object | Navigation structure (header links, routes, sidebar, tabs). See navigation.md for details |
siteConfig | object | Site-level configuration (domain, theme, head, logo) |
assetsDir | string | Path to the assets directory (relative to repository root) |
Project metadata displayed in various places:
{
"info": {
"title": "My Documentation",
"description": "Comprehensive guides for our API"
}
}
Configure your site's domain, appearance, and custom assets:
{
"siteConfig": {
"subdomain": "acme",
"customDomain": "docs.example.com",
"theme": "purple",
"logo": {
"darkMode": "https://example.com/logo-dark.svg",
"lightMode": "https://example.com/logo-light.svg"
},
"head": {
"scripts": [{ "path": "assets/analytics.js" }],
"styles": [{ "path": "assets/custom.css" }],
"meta": [{ "name": "description", "content": "My docs description" }],
"links": [{ "rel": "icon", "href": "/favicon.png" }]
},
"routing": {
"redirects": [
{ "from": "/old-path", "to": "/new-path" }
]
}
}
}
| Property | Type | Description |
|---|---|---|
theme | string | Visual theme (default, alternate, moon, purple, solarized, bluePlanet, deepSpace, saturn, kepler, mars) |
logo | object | Logo URLs for dark and light modes |
head | object | Custom scripts, styles, meta tags, and links |
routing | object | URL redirects configuration |
subpath | string | URL subpath for multi-project deployments (e.g., /guides, /api) |
For detailed navigation configuration, see Navigation.
Here is a more complete example showing common configuration options:
{
"$schema": "https://registry.scalar.com/@scalar/schemas/config",
"scalar": "2.0.0",
"info": {
"title": "Acme API Documentation",
"description": "Everything you need to integrate with Acme"
},
"assetsDir": "docs/assets",
"siteConfig": {
"subdomain": "acme",
"theme": "default",
"logo": {
"darkMode": "https://example.com/logo-dark.svg",
"lightMode": "https://example.com/logo-light.svg"
},
"head": {
"meta": [
{ "name": "description", "content": "Acme API documentation and guides" }
],
"links": [
{ "rel": "icon", "href": "/favicon.png" }
]
}
},
"navigation": {
"header": [
{ "title": "Dashboard", "url": "https://dashboard.example.com" }
],
"routes": {
"/": {
"type": "group",
"title": "Acme",
"children": {
"": {
"type": "page",
"title": "Introduction",
"filepath": "docs/introduction.md",
"icon": "phosphor/regular/house"
},
"/api": {
"type": "openapi",
"title": "API Reference",
"url": "https://example.com/openapi.yaml",
"icon": "phosphor/regular/notebook"
}
}
}
}
}
}
By default, the scalar.config.json file should be placed in the root of your GitHub repository. If you need to place it in a different location, you can configure the path in the Scalar Dashboard.
You can deploy multiple documentation projects on the same subdomain or custom domain by using the subpath property. Each project lives in its own repository with its own scalar.config.json, but they share the same domain.
For example, you might want to have:
docs.example.com/ — Your main documentationdocs.example.com/guides/ — Tutorial guidesdocs.example.com/api/ — API referenceTo set this up, create a separate repository for each project and configure them with the same subdomain or customDomain but a different subpath:
Repository 1: Main documentation
// scalar.config.json
{
"siteConfig": {
"customDomain": "docs.example.com"
}
}
Repository 2: Guides
// scalar.config.json
{
"siteConfig": {
"customDomain": "docs.example.com",
"subpath": "/guides"
}
}
Repository 3: API reference
// scalar.config.json
{
"siteConfig": {
"customDomain": "docs.example.com",
"subpath": "/api"
}
}
Each repository is deployed independently, but all projects appear under the same domain with their respective subpaths.