Pages by Operation
You can use the OAOperation
component to render a specific operation.
Creating operations
pages
To generate pages for each operation, create a directory named operations
in the docs
directory. Inside the operations
directory, create a file named [operationId].md
and a file named [operationId].paths.js
.
/docs
├── /operations
│ ├── [operationId].md
│ └── [operationId].paths.js
Paths Loader File
Using the Paths Loader File feature of VitePress, you can use the [operationId].paths.js
file to generate the pages for each operation.
import { usePaths } from 'vitepress-openapi'
import spec from '../public/openapi.json' assert {type: 'json'}
export default {
paths() {
return usePaths({ spec })
.getPathsByVerbs()
.map(({ operationId, summary }) => {
return {
params: {
operationId,
pageTitle: `${summary} - vitepress-openapi`,
},
}
})
},
}
Markdown File
In the [operationId].md
file, you can use the OAOperation
component to render the operation.
If you have configured the OpenAPI Specification using the useOpenapi
composable in your .vitepress/theme/index.[js,ts]
file, you can just pass the operationId
prop to the OAOperation
component, and it will automatically fetch the spec from the global context.
---
aside: false
outline: false
title: vitepress-openapi
---
<script setup lang="ts">
import { useRoute, useData } from 'vitepress'
const route = useRoute()
const { isDark } = useData()
const operationId = route.data.params.operationId
</script>
<OAOperation :operationId="operationId" :isDark="isDark" />
Searching Operations
If you want to make use of search on your site, the default local
search will not work due to https://github.com/vuejs/vitepress/issues/2939
Consider using vitepress-plugin-pagefind, which works with dynamic routes.