docusaurus-plugin-openapi-docs 2.0.0-beta.5 → 2.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -25,9 +25,39 @@ Key Features:
25
25
  - **Compatible:** Works with Swagger 2.0 and OpenAPI 3.0.
26
26
  - **Fast:** Convert large OpenAPI specs into MDX docs in seconds. 🔥
27
27
  - **Stylish:** Based on the same [Infima styling framework](https://infima.dev/) that powers the Docusaurus UI.
28
- - **Capable:** Supports single, multi and _even micro_ OpenAPI specs.
28
+ - **Flexible:** Supports single, multi and _even micro_ OpenAPI specs.
29
29
 
30
- ## Installation
30
+ ## Compatibility Matrix
31
+
32
+ | Docusaurus OpenAPI Docs | Docusaurus |
33
+ | ----------------------- | --------------- |
34
+ | 2.0.x (current) | `2.4.1 - 2.4.3` |
35
+ | 1.7.3 (legacy) | `2.0.1 - 2.2.0` |
36
+
37
+ ## Bootstrapping from Template (new Docusaurus site)
38
+
39
+ Run the following to bootstrap a Docsaurus v2 site (classic theme) with `docusaurus-openapi-docs`:
40
+
41
+ ```bash
42
+ npx create-docusaurus@2.4.3 my-website --package-manager yarn
43
+ ```
44
+
45
+ > When prompted to select a template choose `Git repository`.
46
+
47
+ Template Repository URL:
48
+
49
+ ```bash
50
+ https://github.com/PaloAltoNetworks/docusaurus-template-openapi-docs.git
51
+ ```
52
+
53
+ > When asked how the template repo should be cloned choose "copy" (unless you know better).
54
+
55
+ ```bash
56
+ cd my-website
57
+ yarn start
58
+ ```
59
+
60
+ ## Installation (existing Docusaurus site)
31
61
 
32
62
  Plugin:
33
63
 
@@ -43,51 +73,48 @@ yarn add docusaurus-theme-openapi-docs
43
73
 
44
74
  ## Configuring `docusaurus.config.js` (Plugin and theme usage)
45
75
 
46
- Here is an example of properly configuring your `docusaurus.config.js` file for `docusaurus-plugin-openapi-docs` and `docusaurus-theme-openapi-docs` usage.
76
+ Here is an example of properly configuring `docusaurus.config.js` file for `docusaurus-plugin-openapi-docs` and `docusaurus-theme-openapi-docs` usage.
47
77
 
48
78
  ```js
49
79
  // docusaurus.config.js
50
80
 
51
81
  {
52
82
  presets: [
53
- [
54
- "classic",
55
- /** @type {import('@docusaurus/preset-classic').Options} */
56
- ({
57
- docs: {
58
- sidebarPath: require.resolve("./sidebars.js"),
59
- // Please change this to your repo.
60
- // Remove this to remove the "edit this page" links.
61
- editUrl:
62
- "https://github.com/facebook/docusaurus/tree/main/packages/create-docusaurus/templates/shared/",
63
- docLayoutComponent: "@theme/DocPage",
64
- docItemComponent: "@theme/ApiItem" // Derived from docusaurus-theme-openapi-docs
65
- },
66
- blog: {
67
- showReadingTime: true,
68
- // Please change this to your repo.
69
- // Remove this to remove the "edit this page" links.
70
- editUrl:
71
- "https://github.com/facebook/docusaurus/tree/main/packages/create-docusaurus/templates/shared/"
72
- },
73
- theme: {
74
- customCss: require.resolve("./src/css/custom.css")
75
- }
76
- })
77
- ]
78
- ],
83
+ [
84
+ "classic",
85
+ /** @type {import('@docusaurus/preset-classic').Options} */
86
+ ({
87
+ docs: {
88
+ sidebarPath: require.resolve("./sidebars.js"),
89
+ editUrl:
90
+ "https://github.com/facebook/docusaurus/tree/main/packages/create-docusaurus/templates/shared/",
91
+ docLayoutComponent: "@theme/DocPage",
92
+ docItemComponent: "@theme/ApiItem" // derived from docusaurus-theme-openapi-docs
93
+ },
94
+ blog: {
95
+ showReadingTime: true,
96
+ editUrl:
97
+ "https://github.com/facebook/docusaurus/tree/main/packages/create-docusaurus/templates/shared/"
98
+ },
99
+ theme: {
100
+ customCss: require.resolve("./src/css/custom.css")
101
+ }
102
+ })
103
+ ]
104
+ ],
79
105
 
80
106
  plugins: [
107
+ [
81
108
  'docusaurus-plugin-openapi-docs',
82
109
  {
83
- id: "apiDocs",
84
- docsPluginId: "classic",
110
+ id: "api", // plugin id
111
+ docsPluginId: "classic", // id of plugin-content-docs or preset for rendering docs
85
112
  config: {
86
- petstore: { // Note: petstore key is treated as the <id> and can be used to specify an API doc instance when using CLI commands
87
- specPath: "examples/petstore.yaml", // Path to designated spec file
88
- outputDir: "api/petstore", // Output directory for generated .mdx docs
89
- sidebarOptions: {
90
- groupPathsBy: "tag",
113
+ petstore: { // the <id> referenced when running CLI commands
114
+ specPath: "examples/petstore.yaml", // path to OpenAPI spec, URLs supported
115
+ outputDir: "api/petstore", // output directory for generated files
116
+ sidebarOptions: { // optional, instructs plugin to generate sidebar.js
117
+ groupPathsBy: "tag", // group sidebar items by operation "tag"
91
118
  },
92
119
  },
93
120
  burgers: {
@@ -98,7 +125,7 @@ Here is an example of properly configuring your `docusaurus.config.js` file for
98
125
  },
99
126
  ]
100
127
  ],
101
- themes: ["docusaurus-theme-openapi-docs"] // Allows use of @theme/ApiItem and other components
128
+ themes: ["docusaurus-theme-openapi-docs"], // export theme components
102
129
  }
103
130
  ```
104
131
 
@@ -110,37 +137,38 @@ The `docusaurus-plugin-openapi-docs` plugin can be configured with the following
110
137
 
111
138
  | Name | Type | Default | Description |
112
139
  | -------------- | -------- | ------- | ---------------------------------------------------------------------------------------------------------------------------------------------------- |
113
- | `id` | `string` | `null` | A unique document id. |
140
+ | `id` | `string` | `null` | A unique plugin id. |
114
141
  | `docsPluginId` | `string` | `null` | The ID associated with the `plugin-content-docs` or `preset` instance used to render the OpenAPI docs (e.g. "your-plugin-id", "classic", "default"). |
115
142
 
116
143
  ### config
117
144
 
118
145
  `config` can be configured with the following options:
119
146
 
120
- | Name | Type | Default | Description |
121
- | ---------------- | --------- | ------- | --------------------------------------------------------------------------------------------------------------------------- |
122
- | `specPath` | `string` | `null` | Designated URL or path to the source of an OpenAPI specification file or directory of multiple OpenAPI specification files. |
123
- | `ouputDir` | `string` | `null` | Desired output path for generated MDX files. |
124
- | `proxy` | `string` | `null` | _Optional:_ Proxy URL to prepend to base URL when performing API requests from browser. |
125
- | `template` | `string` | `null` | _Optional:_ Customize MDX content with a desired template. |
126
- | `downloadUrl` | `string` | `null` | _Optional:_ Designated URL for downloading OpenAPI specification. (requires `info` section/doc) |
127
- | `hideSendButton` | `boolean` | `null` | _Optional:_ If set to `true`, hides the "Send API Request" button in API demo panel |
128
- | `showExtensions` | `boolean` | `null` | _Optional:_ If set to `true`, renders operation-level vendor-extensions in description. |
129
- | `sidebarOptions` | `object` | `null` | _Optional:_ Set of options for sidebar configuration. See below for a list of supported options. |
130
- | `version` | `string` | `null` | _Optional:_ Version assigned to single or micro-spec API specified in `specPath`. |
131
- | `label` | `string` | `null` | _Optional:_ Version label used when generating version selector dropdown menu. |
132
- | `baseUrl` | `string` | `null` | _Optional:_ Version base URL used when generating version selector dropdown menu. |
133
- | `versions` | `object` | `null` | _Optional:_ Set of options for versioning configuration. See below for a list of supported options. |
147
+ | Name | Type | Default | Description |
148
+ | -------------------- | --------- | ------- | ----------------------------------------------------------------------------------------------------------------------------------------------- |
149
+ | `specPath` | `string` | `null` | Designated URL or path to the source of an OpenAPI specification file or directory of multiple OpenAPI specification files. |
150
+ | `ouputDir` | `string` | `null` | Desired output path for generated MDX files. |
151
+ | `proxy` | `string` | `null` | _Optional:_ Proxy URL to prepend to base URL when performing API requests from browser. |
152
+ | `template` | `string` | `null` | _Optional:_ Customize MDX content with a desired template. |
153
+ | `downloadUrl` | `string` | `null` | _Optional:_ Designated URL for downloading OpenAPI specification. (requires `info` section/doc) |
154
+ | `hideSendButton` | `boolean` | `null` | _Optional:_ If set to `true`, hides the "Send API Request" button in API demo panel |
155
+ | `showExtensions` | `boolean` | `null` | _Optional:_ If set to `true`, renders operation-level vendor-extensions in description. |
156
+ | `sidebarOptions` | `object` | `null` | _Optional:_ Set of options for sidebar configuration. See below for a list of supported options. |
157
+ | `version` | `string` | `null` | _Optional:_ Version assigned to single or micro-spec API specified in `specPath`. |
158
+ | `label` | `string` | `null` | _Optional:_ Version label used when generating version selector dropdown menu. |
159
+ | `baseUrl` | `string` | `null` | _Optional:_ Version base URL used when generating version selector dropdown menu. |
160
+ | `versions` | `object` | `null` | _Optional:_ Set of options for versioning configuration. See below for a list of supported options. |
161
+ | `markdownGenerators` | `object` | `null` | _Optional:_ Customize MDX content with a set of options for specifying markdown generator functions. See below for a list of supported options. |
134
162
 
135
163
  `sidebarOptions` can be configured with the following options:
136
164
 
137
- | Name | Type | Default | Description |
138
- | -------------------- | --------- | ------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
139
- | `groupPathsBy` | `string` | `null` | Organize and group sidebar slice by specified option. Note: Currently, `groupPathsBy` only contains support for grouping by `tag`. |
140
- | `categoryLinkSource` | `string` | `null` | Defines what source to use for rendering category pages when grouping paths by tag. By default, pages are not created for categories, only groups that can be expanded/collapsed. <br/><br/>The supported options are as follows: <br/><br/> `auto`: Sets the category link config type to `generated-index`, building an index page with links to each page in the group.<br/><br/> `tag`: Sets the category link config type to `generated-index` and uses the tag description at the top of the page. <br/><br/>`info`: Sets the category link config type to `doc` and renders the `info` section as the category link (recommended only for multi/micro-spec scenarios). |
141
- | `sidebarCollapsible` | `boolean` | `true` | Whether sidebar categories are collapsible by default. |
142
- | `sidebarCollapsed` | `boolean` | `true` | Whether sidebar categories are collapsed by default. |
143
- | `customProps` | `object` | `null` | Additional props for customizing a sidebar item. |
165
+ | Name | Type | Default | Description |
166
+ | -------------------- | --------- | ------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
167
+ | `groupPathsBy` | `string` | `null` | Organize and group sidebar slice by specified option. Note: Currently, `groupPathsBy` only contains support for grouping by `tag`. |
168
+ | `categoryLinkSource` | `string` | `null` | Defines what source to use for rendering category link pages when grouping paths by tag. <br/><br/>The supported options are as follows: <br/><br/> `tag`: Sets the category link config type to `generated-index` and uses the tag description as the link config description. <br/><br/>`info`: Sets the category link config type to `doc` and renders the `info` section as the category link (recommended only for multi/micro-spec scenarios). <br/><br/>`none`: Does not create pages for categories, only groups that can be expanded/collapsed. |
169
+ | `sidebarCollapsible` | `boolean` | `true` | Whether sidebar categories are collapsible by default. |
170
+ | `sidebarCollapsed` | `boolean` | `true` | Whether sidebar categories are collapsed by default. |
171
+ | `customProps` | `object` | `null` | Additional props for customizing a sidebar item. |
144
172
 
145
173
  > You may optionally configure a `sidebarOptions`. In doing so, an individual `sidebar.js` slice with the configured options will be generated within the respective `outputDir`.
146
174
 
@@ -155,6 +183,16 @@ The `docusaurus-plugin-openapi-docs` plugin can be configured with the following
155
183
 
156
184
  > All versions will automatically inherit `sidebarOptions` from the parent/base config.
157
185
 
186
+ ### markdownGenerators
187
+
188
+ `markdownGenerators` can be configured with the following options:
189
+
190
+ | Name | Type | Default | Description |
191
+ | ------------------ | ---------- | ------- | ------------------------------------------------------------------------------------------------------------------------------------------ |
192
+ | `createApiPageMD` | `function` | `null` | _Optional:_ Returns a string of the raw markdown body for API pages.<br/><br/>**Function type:** `(pageData: ApiPageMetadata) => string` |
193
+ | `createInfoPageMD` | `function` | `null` | _Optional:_ Returns a string of the raw markdown body for info pages.<br/><br/>**Function type:** `(pageData: InfoPageMetadata) => string` |
194
+ | `createTagPageMD` | `function` | `null` | _Optional:_ Returns a string of the raw markdown body for tag pages.<br/><br/>**Function type:** `(pageData: TagPageMetadata) => string` |
195
+
158
196
  ## CLI Usage
159
197
 
160
198
  ```bash
@@ -245,29 +283,6 @@ yarn docusaurus gen-api-docs:version petstore:all
245
283
 
246
284
  > Substitue `all` with a specific version ID to generate/clean a specific version. Generating for `all` or a specific version ID will automatically update the `versions.json` file.
247
285
 
248
- ## Installing from Template
249
-
250
- Run the following to bootstrap a Docsaurus v2 site (classic theme) with `docusaurus-openapi-docs`:
251
-
252
- ```bash
253
- npx create-docusaurus@2.0.1 my-website --package-manager yarn
254
- ```
255
-
256
- > When prompted to select a template choose `Git repository`.
257
-
258
- Template Repository URL:
259
-
260
- ```bash
261
- https://github.com/PaloAltoNetworks/docusaurus-template-openapi-docs.git
262
- ```
263
-
264
- > When asked how the template repo should be cloned choose "copy" (unless you know better).
265
-
266
- ```bash
267
- cd my-website
268
- yarn
269
- ```
270
-
271
286
  ## Developer Quick Start
272
287
 
273
288
  > Looking to make a contribution? Make sure to checkout out our contributing guide.
package/lib/index.js CHANGED
@@ -77,7 +77,8 @@ function pluginOpenAPIDocs(context, options) {
77
77
  let docRouteBasePath = docData ? docData.routeBasePath : undefined;
78
78
  let docPath = docData ? (docData.path ? docData.path : "docs") : undefined;
79
79
  async function generateApiDocs(options, pluginId) {
80
- let { specPath, outputDir, template, downloadUrl, sidebarOptions } = options;
80
+ var _a, _b, _c;
81
+ let { specPath, outputDir, template, markdownGenerators, downloadUrl, sidebarOptions, } = options;
81
82
  // Remove trailing slash before proceeding
82
83
  outputDir = outputDir.replace(/\/$/, "");
83
84
  // Override docPath if pluginId provided
@@ -194,12 +195,21 @@ import {useCurrentSidebarCategory} from '@docusaurus/theme-common';
194
195
  <DocCardList items={useCurrentSidebarCategory().items}/>
195
196
  \`\`\`
196
197
  `;
198
+ const apiPageGenerator = (_a = markdownGenerators === null || markdownGenerators === void 0 ? void 0 : markdownGenerators.createApiPageMD) !== null && _a !== void 0 ? _a : markdown_1.createApiPageMD;
199
+ const infoPageGenerator = (_b = markdownGenerators === null || markdownGenerators === void 0 ? void 0 : markdownGenerators.createInfoPageMD) !== null && _b !== void 0 ? _b : markdown_1.createInfoPageMD;
200
+ const tagPageGenerator = (_c = markdownGenerators === null || markdownGenerators === void 0 ? void 0 : markdownGenerators.createTagPageMD) !== null && _c !== void 0 ? _c : markdown_1.createTagPageMD;
197
201
  loadedApi.map(async (item) => {
198
202
  if (item.type === "info") {
199
203
  if (downloadUrl && isURL(downloadUrl)) {
200
204
  item.downloadUrl = downloadUrl;
201
205
  }
202
206
  }
207
+ const markdown = item.type === "api"
208
+ ? apiPageGenerator(item)
209
+ : item.type === "info"
210
+ ? infoPageGenerator(item)
211
+ : tagPageGenerator(item);
212
+ item.markdown = markdown;
203
213
  if (item.type === "api") {
204
214
  // opportunity to compress JSON
205
215
  // const serialize = (o: any) => {
@@ -220,12 +230,6 @@ import {useCurrentSidebarCategory} from '@docusaurus/theme-common';
220
230
  if (item.infoId)
221
231
  item.infoPath = infoBasePath;
222
232
  }
223
- const markdown = item.type === "api"
224
- ? (0, markdown_1.createApiPageMD)(item)
225
- : item.type === "info"
226
- ? (0, markdown_1.createInfoPageMD)(item)
227
- : (0, markdown_1.createTagPageMD)(item);
228
- item.markdown = markdown;
229
233
  const view = (0, mustache_1.render)(mdTemplate, item);
230
234
  const utils = (0, mustache_1.render)(infoMdTemplate, item);
231
235
  // eslint-disable-next-line testing-library/render-result-naming-convention
package/lib/options.js CHANGED
@@ -15,6 +15,11 @@ const sidebarOptions = utils_validation_1.Joi.object({
15
15
  sidebarCollapsible: utils_validation_1.Joi.boolean(),
16
16
  sidebarCollapsed: utils_validation_1.Joi.boolean(),
17
17
  });
18
+ const markdownGenerators = utils_validation_1.Joi.object({
19
+ createApiPageMD: utils_validation_1.Joi.function(),
20
+ createInfoPageMD: utils_validation_1.Joi.function(),
21
+ createTagPageMD: utils_validation_1.Joi.function(),
22
+ });
18
23
  exports.OptionsSchema = utils_validation_1.Joi.object({
19
24
  id: utils_validation_1.Joi.string().required(),
20
25
  docsPluginId: utils_validation_1.Joi.string().required(),
@@ -28,6 +33,7 @@ exports.OptionsSchema = utils_validation_1.Joi.object({
28
33
  hideSendButton: utils_validation_1.Joi.boolean(),
29
34
  showExtensions: utils_validation_1.Joi.boolean(),
30
35
  sidebarOptions: sidebarOptions,
36
+ markdownGenerators: markdownGenerators,
31
37
  version: utils_validation_1.Joi.string().when("versions", {
32
38
  is: utils_validation_1.Joi.exist(),
33
39
  then: utils_validation_1.Joi.required(),
package/lib/types.d.ts CHANGED
@@ -23,6 +23,12 @@ export interface APIOptions {
23
23
  [key: string]: APIVersionOptions;
24
24
  };
25
25
  proxy?: string;
26
+ markdownGenerators?: MarkdownGenerator;
27
+ }
28
+ export interface MarkdownGenerator {
29
+ createApiPageMD?: (pageData: ApiPageMetadata) => string;
30
+ createInfoPageMD?: (pageData: InfoPageMetadata) => string;
31
+ createTagPageMD?: (pageData: TagPageMetadata) => string;
26
32
  }
27
33
  export interface SidebarOptions {
28
34
  groupPathsBy?: string;
package/package.json CHANGED
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "name": "docusaurus-plugin-openapi-docs",
3
3
  "description": "OpenAPI plugin for Docusaurus.",
4
- "version": "2.0.0-beta.5",
4
+ "version": "2.0.0",
5
5
  "license": "MIT",
6
6
  "keywords": [
7
7
  "openapi",
@@ -28,7 +28,7 @@
28
28
  "watch": "tsc --watch"
29
29
  },
30
30
  "devDependencies": {
31
- "@docusaurus/types": ">=2.3.0 <2.5.0",
31
+ "@docusaurus/types": ">=2.4.1 <=2.4.3",
32
32
  "@types/fs-extra": "^9.0.13",
33
33
  "@types/json-pointer": "^1.0.31",
34
34
  "@types/json-schema": "^7.0.9",
@@ -37,9 +37,9 @@
37
37
  },
38
38
  "dependencies": {
39
39
  "@apidevtools/json-schema-ref-parser": "^10.1.0",
40
- "@docusaurus/plugin-content-docs": ">=2.3.0 <2.5.0",
41
- "@docusaurus/utils": ">=2.3.0 <2.5.0",
42
- "@docusaurus/utils-validation": ">=2.3.0 <2.5.0",
40
+ "@docusaurus/plugin-content-docs": ">=2.4.1 <=2.4.3",
41
+ "@docusaurus/utils": ">=2.4.1 <=2.4.3",
42
+ "@docusaurus/utils-validation": ">=2.4.1 <=2.4.3",
43
43
  "@paloaltonetworks/openapi-to-postmanv2": "3.1.0-hotfix.1",
44
44
  "@paloaltonetworks/postman-collection": "^4.1.0",
45
45
  "@redocly/openapi-core": "^1.0.0-beta.125",
@@ -55,10 +55,10 @@
55
55
  "xml-formatter": "^2.6.1"
56
56
  },
57
57
  "peerDependencies": {
58
- "react": "^16.8.4 || ^17.0.0"
58
+ "react": "^16.8.4 || ^17.0.0 || ^18.0.0"
59
59
  },
60
60
  "engines": {
61
61
  "node": ">=14"
62
62
  },
63
- "gitHead": "357d6a5bceaab56924e405b92dec1a3861a23f4f"
63
+ "gitHead": "ec57fe9cac964cff00f5433fb829ce2d6219da7e"
64
64
  }
package/src/index.ts CHANGED
@@ -92,8 +92,14 @@ export default function pluginOpenAPIDocs(
92
92
  let docPath = docData ? (docData.path ? docData.path : "docs") : undefined;
93
93
 
94
94
  async function generateApiDocs(options: APIOptions, pluginId: any) {
95
- let { specPath, outputDir, template, downloadUrl, sidebarOptions } =
96
- options;
95
+ let {
96
+ specPath,
97
+ outputDir,
98
+ template,
99
+ markdownGenerators,
100
+ downloadUrl,
101
+ sidebarOptions,
102
+ } = options;
97
103
 
98
104
  // Remove trailing slash before proceeding
99
105
  outputDir = outputDir.replace(/\/$/, "");
@@ -238,12 +244,26 @@ import {useCurrentSidebarCategory} from '@docusaurus/theme-common';
238
244
  \`\`\`
239
245
  `;
240
246
 
247
+ const apiPageGenerator =
248
+ markdownGenerators?.createApiPageMD ?? createApiPageMD;
249
+ const infoPageGenerator =
250
+ markdownGenerators?.createInfoPageMD ?? createInfoPageMD;
251
+ const tagPageGenerator =
252
+ markdownGenerators?.createTagPageMD ?? createTagPageMD;
253
+
241
254
  loadedApi.map(async (item) => {
242
255
  if (item.type === "info") {
243
256
  if (downloadUrl && isURL(downloadUrl)) {
244
257
  item.downloadUrl = downloadUrl;
245
258
  }
246
259
  }
260
+ const markdown =
261
+ item.type === "api"
262
+ ? apiPageGenerator(item)
263
+ : item.type === "info"
264
+ ? infoPageGenerator(item)
265
+ : tagPageGenerator(item);
266
+ item.markdown = markdown;
247
267
  if (item.type === "api") {
248
268
  // opportunity to compress JSON
249
269
  // const serialize = (o: any) => {
@@ -263,13 +283,6 @@ import {useCurrentSidebarCategory} from '@docusaurus/theme-common';
263
283
  }
264
284
  if (item.infoId) item.infoPath = infoBasePath;
265
285
  }
266
- const markdown =
267
- item.type === "api"
268
- ? createApiPageMD(item)
269
- : item.type === "info"
270
- ? createInfoPageMD(item)
271
- : createTagPageMD(item);
272
- item.markdown = markdown;
273
286
 
274
287
  const view = render(mdTemplate, item);
275
288
  const utils = render(infoMdTemplate, item);
package/src/options.ts CHANGED
@@ -15,6 +15,12 @@ const sidebarOptions = Joi.object({
15
15
  sidebarCollapsed: Joi.boolean(),
16
16
  });
17
17
 
18
+ const markdownGenerators = Joi.object({
19
+ createApiPageMD: Joi.function(),
20
+ createInfoPageMD: Joi.function(),
21
+ createTagPageMD: Joi.function(),
22
+ });
23
+
18
24
  export const OptionsSchema = Joi.object({
19
25
  id: Joi.string().required(),
20
26
  docsPluginId: Joi.string().required(),
@@ -30,6 +36,7 @@ export const OptionsSchema = Joi.object({
30
36
  hideSendButton: Joi.boolean(),
31
37
  showExtensions: Joi.boolean(),
32
38
  sidebarOptions: sidebarOptions,
39
+ markdownGenerators: markdownGenerators,
33
40
  version: Joi.string().when("versions", {
34
41
  is: Joi.exist(),
35
42
  then: Joi.required(),
package/src/types.ts CHANGED
@@ -43,6 +43,13 @@ export interface APIOptions {
43
43
  [key: string]: APIVersionOptions;
44
44
  };
45
45
  proxy?: string;
46
+ markdownGenerators?: MarkdownGenerator;
47
+ }
48
+
49
+ export interface MarkdownGenerator {
50
+ createApiPageMD?: (pageData: ApiPageMetadata) => string;
51
+ createInfoPageMD?: (pageData: InfoPageMetadata) => string;
52
+ createTagPageMD?: (pageData: TagPageMetadata) => string;
46
53
  }
47
54
 
48
55
  export interface SidebarOptions {