Mintlify supports versioning or localization. You can use one or the other, not both.

These guides will assume v1 pages are in a folder named v1, v2 pages are in a folder named v2, and so on. While this method of structuring your files isn’t strictly necessary, it’s a great way to keep your files organized.

Versioning

Setup

Add "versions": ["v2", "v1"] to your mint.json file where v1 and v2 are the names of your versions. You can put any number of versions in this array. The first version from the array serves as the default version.

If you would like to specify a default version, you can do so like this:

"versions": [
  {
    "name": "version-name",
    "default": true
  }
]

The versions dropdown will show your versions in the order you include them in mint.json.

Versioning Groups and Pages

The best way to specify page versions is by adding a version value to a group in the navigation. When you specify the version of a group, that version is applied to all pages within that group.

You can also specify the version of a single page in the page metadata. Versions on individual pages always take precedence.

While it is possible to nest versioned groups within versioned groups, it is not recommended. If you do take this approach, the more deeply-nested version takes precedence.

Versioning Tabs and Anchors

You can hide a tab or anchor based on a version. This is useful if you have links that are only relevant in one version. Importantly, this does not apply the version to the pages within that anchor.

In mint.json, simply add version to your tab or anchor. Tabs and anchors without a specified version are shown in every version.

Sharing Between Versions

Not all content has to be hidden though! Any content without a specified version appears in every version so you don’t have to duplicate content!

When using localization with versioning, each version can have its own set of translations. This means you can have different language versions for different API versions, giving you full flexibility in managing both versioned and localized content.

Troubleshooting

Common errors and how to fix them

Localization

Setup

"versions" in your mint.json can be leveraged to create different language versions by adding a locale value to the version. The first localization from the array serves as the default localization.

We currently support localization in English (en), Chinese (cn), Spanish (es), French (fr), Japanese (jp), Portuguese (pt), and German (de).

mint.json example
"versions": [
  {
    "name": "English",
    "locale": "en",
  },
  {
    "name": "French",
    "locale": "fr",
  },
  {
    "name": "Spanish",
    "locale": "es"
  }
]

The versions dropdown will show your localizations in the order you include them in the mint.json.

Once setup, the rest of localization is handled by the versioning setup described above.