Versioning & Localization
Build separate versions or localizations
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:
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
).
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.