docusaurus-theme-openapi-docs 1.2.1 → 1.3.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/lib/theme/ApiDemoPanel/Accept/index.js +1 -1
- package/lib/theme/ApiDemoPanel/Authorization/index.js +2 -2
- package/lib/theme/ApiDemoPanel/Body/index.js +104 -9
- package/lib/theme/ApiDemoPanel/ContentType/index.js +1 -1
- package/lib/theme/ApiDemoPanel/Curl/index.js +2 -2
- package/lib/theme/ApiDemoPanel/Execute/index.js +1 -1
- package/lib/theme/ApiDemoPanel/FloatingButton/styles.module.css +2 -3
- package/lib/theme/ApiDemoPanel/ParamOptions/index.js +1 -1
- package/lib/theme/ApiDemoPanel/Request/index.js +5 -2
- package/lib/theme/ApiDemoPanel/Request/styles.module.css +1 -0
- package/lib/theme/ApiDemoPanel/Response/index.js +1 -1
- package/lib/theme/ApiDemoPanel/SecuritySchemes/index.js +1 -1
- package/lib/theme/ApiDemoPanel/Server/index.js +52 -34
- package/lib/theme/ApiDemoPanel/Server/slice.js +3 -2
- package/lib/theme/ApiDemoPanel/Server/styles.module.css +0 -1
- package/lib/theme/ApiDemoPanel/index.js +8 -75
- package/lib/theme/ApiDemoPanel/persistanceMiddleware.js +22 -0
- package/lib/theme/ApiItem/Layout/styles.module.css +11 -3
- package/lib/theme/{ApiDemoPanel → ApiItem}/hooks.js +0 -0
- package/lib/theme/ApiItem/index.js +101 -22
- package/lib/theme/{ApiDemoPanel → ApiItem}/store.js +7 -7
- package/lib/theme/MimeTabs/index.js +29 -1
- package/lib/theme/MimeTabs/styles.module.css +1 -0
- package/lib/theme/SchemaTabs/index.js +4 -1
- package/lib-next/theme/ApiDemoPanel/Accept/index.js +1 -1
- package/lib-next/theme/ApiDemoPanel/Authorization/index.js +1 -1
- package/lib-next/theme/ApiDemoPanel/Body/index.js +114 -7
- package/lib-next/theme/ApiDemoPanel/ContentType/index.js +1 -1
- package/lib-next/theme/ApiDemoPanel/Curl/index.js +1 -1
- package/lib-next/theme/ApiDemoPanel/Execute/index.js +1 -1
- package/lib-next/theme/ApiDemoPanel/FloatingButton/styles.module.css +2 -3
- package/lib-next/theme/ApiDemoPanel/ParamOptions/index.js +1 -1
- package/lib-next/theme/ApiDemoPanel/Request/index.js +3 -1
- package/lib-next/theme/ApiDemoPanel/Request/styles.module.css +1 -0
- package/lib-next/theme/ApiDemoPanel/Response/index.js +1 -1
- package/lib-next/theme/ApiDemoPanel/SecuritySchemes/index.js +1 -1
- package/lib-next/theme/ApiDemoPanel/Server/index.js +76 -50
- package/lib-next/theme/ApiDemoPanel/Server/slice.js +5 -3
- package/lib-next/theme/ApiDemoPanel/Server/styles.module.css +0 -1
- package/lib-next/theme/ApiDemoPanel/index.js +7 -71
- package/lib-next/theme/ApiDemoPanel/persistanceMiddleware.js +20 -0
- package/lib-next/theme/ApiItem/Layout/styles.module.css +11 -3
- package/lib-next/theme/{ApiDemoPanel → ApiItem}/hooks.js +0 -0
- package/lib-next/theme/ApiItem/index.js +104 -26
- package/lib-next/theme/{ApiDemoPanel → ApiItem}/store.js +7 -7
- package/lib-next/theme/MimeTabs/index.js +29 -1
- package/lib-next/theme/MimeTabs/styles.module.css +1 -0
- package/lib-next/theme/SchemaTabs/index.js +4 -1
- package/package.json +3 -3
- package/src/theme/ApiDemoPanel/Accept/index.tsx +1 -1
- package/src/theme/ApiDemoPanel/Authorization/index.tsx +1 -1
- package/src/theme/ApiDemoPanel/Body/index.tsx +107 -7
- package/src/theme/ApiDemoPanel/ContentType/index.tsx +1 -1
- package/src/theme/ApiDemoPanel/Curl/index.tsx +1 -1
- package/src/theme/ApiDemoPanel/Execute/index.tsx +1 -1
- package/src/theme/ApiDemoPanel/FloatingButton/styles.module.css +2 -3
- package/src/theme/ApiDemoPanel/ParamOptions/index.tsx +1 -1
- package/src/theme/ApiDemoPanel/Request/index.tsx +3 -1
- package/src/theme/ApiDemoPanel/Request/styles.module.css +1 -0
- package/src/theme/ApiDemoPanel/Response/index.tsx +1 -1
- package/src/theme/ApiDemoPanel/SecuritySchemes/index.tsx +1 -1
- package/src/theme/ApiDemoPanel/Server/index.tsx +71 -43
- package/src/theme/ApiDemoPanel/Server/slice.ts +6 -7
- package/src/theme/ApiDemoPanel/Server/styles.module.css +0 -1
- package/src/theme/ApiDemoPanel/index.tsx +10 -75
- package/src/theme/ApiDemoPanel/persistanceMiddleware.ts +21 -1
- package/src/theme/ApiItem/Layout/styles.module.css +11 -3
- package/src/theme/{ApiDemoPanel → ApiItem}/hooks.ts +0 -0
- package/src/theme/ApiItem/index.tsx +103 -27
- package/src/theme/{ApiDemoPanel → ApiItem}/store.ts +7 -7
- package/src/theme/MimeTabs/index.js +29 -1
- package/src/theme/MimeTabs/styles.module.css +1 -0
- package/src/theme/SchemaTabs/index.js +4 -1
|
@@ -7,14 +7,14 @@ exports.default = void 0;
|
|
|
7
7
|
|
|
8
8
|
var _react = _interopRequireDefault(require("react"));
|
|
9
9
|
|
|
10
|
+
var _hooks = require("../../ApiItem/hooks");
|
|
11
|
+
|
|
10
12
|
var _FormItem = _interopRequireDefault(require("../FormItem"));
|
|
11
13
|
|
|
12
14
|
var _FormSelect = _interopRequireDefault(require("../FormSelect"));
|
|
13
15
|
|
|
14
16
|
var _FormTextInput = _interopRequireDefault(require("../FormTextInput"));
|
|
15
17
|
|
|
16
|
-
var _hooks = require("../hooks");
|
|
17
|
-
|
|
18
18
|
var _slice = require("./slice");
|
|
19
19
|
|
|
20
20
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
@@ -7,14 +7,18 @@ exports.default = void 0;
|
|
|
7
7
|
|
|
8
8
|
var _react = _interopRequireDefault(require("react"));
|
|
9
9
|
|
|
10
|
+
var _TabItem = _interopRequireDefault(require("@theme/TabItem"));
|
|
11
|
+
|
|
10
12
|
var _xmlFormatter = _interopRequireDefault(require("xml-formatter"));
|
|
11
13
|
|
|
14
|
+
var _hooks = require("../../ApiItem/hooks");
|
|
15
|
+
|
|
16
|
+
var _SchemaTabs = _interopRequireDefault(require("../../SchemaTabs"));
|
|
17
|
+
|
|
12
18
|
var _ContentType = _interopRequireDefault(require("../ContentType"));
|
|
13
19
|
|
|
14
20
|
var _FormSelect = _interopRequireDefault(require("../FormSelect"));
|
|
15
21
|
|
|
16
|
-
var _hooks = require("../hooks");
|
|
17
|
-
|
|
18
22
|
var _LiveEditor = _interopRequireDefault(require("../LiveEditor"));
|
|
19
23
|
|
|
20
24
|
var _FormFileUpload = _interopRequireDefault(require("./../FormFileUpload"));
|
|
@@ -36,6 +40,7 @@ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { de
|
|
|
36
40
|
* LICENSE file in the root directory of this source tree.
|
|
37
41
|
* ========================================================================== */
|
|
38
42
|
// @ts-ignore
|
|
43
|
+
// @ts-ignore
|
|
39
44
|
function BodyWrap({
|
|
40
45
|
requestBodyMetadata,
|
|
41
46
|
jsonRequestBodyExample
|
|
@@ -58,7 +63,7 @@ function Body({
|
|
|
58
63
|
requestBodyMetadata,
|
|
59
64
|
jsonRequestBodyExample
|
|
60
65
|
}) {
|
|
61
|
-
var _requestBodyMetadata$, _requestBodyMetadata$2;
|
|
66
|
+
var _requestBodyMetadata$, _requestBodyMetadata$2, _requestBodyMetadata$3, _requestBodyMetadata$4, _requestBodyMetadata$5, _requestBodyMetadata$6;
|
|
62
67
|
|
|
63
68
|
const contentType = (0, _hooks.useTypedSelector)(state => state.contentType.value);
|
|
64
69
|
const required = requestBodyMetadata === null || requestBodyMetadata === void 0 ? void 0 : requestBodyMetadata.required;
|
|
@@ -82,6 +87,8 @@ function Body({
|
|
|
82
87
|
// - application/x-www-form-urlencoded
|
|
83
88
|
|
|
84
89
|
const schema = requestBodyMetadata === null || requestBodyMetadata === void 0 ? void 0 : (_requestBodyMetadata$ = requestBodyMetadata.content) === null || _requestBodyMetadata$ === void 0 ? void 0 : (_requestBodyMetadata$2 = _requestBodyMetadata$[contentType]) === null || _requestBodyMetadata$2 === void 0 ? void 0 : _requestBodyMetadata$2.schema;
|
|
90
|
+
const example = requestBodyMetadata === null || requestBodyMetadata === void 0 ? void 0 : (_requestBodyMetadata$3 = requestBodyMetadata.content) === null || _requestBodyMetadata$3 === void 0 ? void 0 : (_requestBodyMetadata$4 = _requestBodyMetadata$3[contentType]) === null || _requestBodyMetadata$4 === void 0 ? void 0 : _requestBodyMetadata$4.example;
|
|
91
|
+
const examples = requestBodyMetadata === null || requestBodyMetadata === void 0 ? void 0 : (_requestBodyMetadata$5 = requestBodyMetadata.content) === null || _requestBodyMetadata$5 === void 0 ? void 0 : (_requestBodyMetadata$6 = _requestBodyMetadata$5[contentType]) === null || _requestBodyMetadata$6 === void 0 ? void 0 : _requestBodyMetadata$6.examples;
|
|
85
92
|
|
|
86
93
|
if ((schema === null || schema === void 0 ? void 0 : schema.format) === "binary") {
|
|
87
94
|
return <_FormItem.default label="Body" required={required}>
|
|
@@ -161,35 +168,123 @@ function Body({
|
|
|
161
168
|
}
|
|
162
169
|
|
|
163
170
|
let language = "plaintext";
|
|
164
|
-
let
|
|
171
|
+
let defaultBody = ""; //"body content";
|
|
172
|
+
|
|
173
|
+
let exampleBody;
|
|
174
|
+
let examplesBodies = [];
|
|
165
175
|
|
|
166
176
|
if (contentType === "application/json" || contentType.endsWith("+json")) {
|
|
167
177
|
if (jsonRequestBodyExample) {
|
|
168
|
-
|
|
178
|
+
defaultBody = JSON.stringify(jsonRequestBodyExample, null, 2);
|
|
179
|
+
}
|
|
180
|
+
|
|
181
|
+
if (example) {
|
|
182
|
+
exampleBody = JSON.stringify(example, null, 2);
|
|
183
|
+
}
|
|
184
|
+
|
|
185
|
+
if (examples) {
|
|
186
|
+
for (const [key, example] of Object.entries(examples)) {
|
|
187
|
+
examplesBodies.push({
|
|
188
|
+
label: key,
|
|
189
|
+
body: JSON.stringify(example.value, null, 2),
|
|
190
|
+
summary: example.summary
|
|
191
|
+
});
|
|
192
|
+
}
|
|
169
193
|
}
|
|
170
194
|
|
|
171
195
|
language = "json";
|
|
172
196
|
}
|
|
173
197
|
|
|
174
|
-
if (contentType === "application/xml") {
|
|
198
|
+
if (contentType === "application/xml" || contentType.endsWith("+xml")) {
|
|
175
199
|
if (jsonRequestBodyExample) {
|
|
176
200
|
try {
|
|
177
|
-
|
|
201
|
+
defaultBody = (0, _xmlFormatter.default)((0, _json2xml.default)(jsonRequestBodyExample, ""), {
|
|
202
|
+
indentation: " ",
|
|
203
|
+
lineSeparator: "\n",
|
|
204
|
+
collapseContent: true
|
|
205
|
+
});
|
|
206
|
+
} catch {
|
|
207
|
+
defaultBody = (0, _json2xml.default)(jsonRequestBodyExample);
|
|
208
|
+
}
|
|
209
|
+
}
|
|
210
|
+
|
|
211
|
+
if (example) {
|
|
212
|
+
try {
|
|
213
|
+
exampleBody = (0, _xmlFormatter.default)((0, _json2xml.default)(example, ""), {
|
|
178
214
|
indentation: " ",
|
|
179
215
|
lineSeparator: "\n",
|
|
180
216
|
collapseContent: true
|
|
181
217
|
});
|
|
182
218
|
} catch {
|
|
183
|
-
|
|
219
|
+
exampleBody = (0, _json2xml.default)(example);
|
|
220
|
+
}
|
|
221
|
+
}
|
|
222
|
+
|
|
223
|
+
if (examples) {
|
|
224
|
+
for (const [key, example] of Object.entries(examples)) {
|
|
225
|
+
let formattedXmlBody;
|
|
226
|
+
|
|
227
|
+
try {
|
|
228
|
+
formattedXmlBody = (0, _xmlFormatter.default)(example.value, {
|
|
229
|
+
indentation: " ",
|
|
230
|
+
lineSeparator: "\n",
|
|
231
|
+
collapseContent: true
|
|
232
|
+
});
|
|
233
|
+
} catch {
|
|
234
|
+
formattedXmlBody = example.value;
|
|
235
|
+
}
|
|
236
|
+
|
|
237
|
+
examplesBodies.push({
|
|
238
|
+
label: key,
|
|
239
|
+
body: formattedXmlBody,
|
|
240
|
+
summary: example.summary
|
|
241
|
+
});
|
|
184
242
|
}
|
|
185
243
|
}
|
|
186
244
|
|
|
187
245
|
language = "xml";
|
|
188
246
|
}
|
|
189
247
|
|
|
248
|
+
if (exampleBody) {
|
|
249
|
+
return <_FormItem.default label="Body" required={required}>
|
|
250
|
+
<_SchemaTabs.default lazy>
|
|
251
|
+
<_TabItem.default label="Default" value="default" default>
|
|
252
|
+
<_LiveEditor.default action={dispatch} language={language}>
|
|
253
|
+
{defaultBody}
|
|
254
|
+
</_LiveEditor.default>
|
|
255
|
+
</_TabItem.default>
|
|
256
|
+
<_TabItem.default label="Example" value="example">
|
|
257
|
+
{exampleBody && <_LiveEditor.default action={dispatch} language={language}>
|
|
258
|
+
{exampleBody}
|
|
259
|
+
</_LiveEditor.default>}
|
|
260
|
+
</_TabItem.default>
|
|
261
|
+
</_SchemaTabs.default>
|
|
262
|
+
</_FormItem.default>;
|
|
263
|
+
}
|
|
264
|
+
|
|
265
|
+
if (examplesBodies && examplesBodies.length > 0) {
|
|
266
|
+
return <_FormItem.default label="Body" required={required}>
|
|
267
|
+
<_SchemaTabs.default lazy>
|
|
268
|
+
<_TabItem.default label="Default" value="default" default>
|
|
269
|
+
<_LiveEditor.default action={dispatch} language={language}>
|
|
270
|
+
{defaultBody}
|
|
271
|
+
</_LiveEditor.default>
|
|
272
|
+
</_TabItem.default>
|
|
273
|
+
{examplesBodies.map(example => {
|
|
274
|
+
return <_TabItem.default label={example.label} value={example.label} key={example.label}>
|
|
275
|
+
{example.summary && <p>{example.summary}</p>}
|
|
276
|
+
{example.body && <_LiveEditor.default action={dispatch} language={language}>
|
|
277
|
+
{example.body}
|
|
278
|
+
</_LiveEditor.default>}
|
|
279
|
+
</_TabItem.default>;
|
|
280
|
+
})}
|
|
281
|
+
</_SchemaTabs.default>
|
|
282
|
+
</_FormItem.default>;
|
|
283
|
+
}
|
|
284
|
+
|
|
190
285
|
return <_FormItem.default label="Body" required={required}>
|
|
191
286
|
<_LiveEditor.default action={dispatch} language={language}>
|
|
192
|
-
{
|
|
287
|
+
{defaultBody}
|
|
193
288
|
</_LiveEditor.default>
|
|
194
289
|
</_FormItem.default>;
|
|
195
290
|
}
|
|
@@ -15,9 +15,9 @@ var _CodeBlock = _interopRequireDefault(require("@theme/CodeBlock"));
|
|
|
15
15
|
|
|
16
16
|
var _clsx = _interopRequireDefault(require("clsx"));
|
|
17
17
|
|
|
18
|
-
var
|
|
18
|
+
var _hooks = require("../../ApiItem/hooks");
|
|
19
19
|
|
|
20
|
-
var
|
|
20
|
+
var _CodeTabs = _interopRequireDefault(require("../CodeTabs"));
|
|
21
21
|
|
|
22
22
|
var _buildPostmanRequest = _interopRequireDefault(require("./../buildPostmanRequest"));
|
|
23
23
|
|
|
@@ -9,7 +9,7 @@ var _react = _interopRequireDefault(require("react"));
|
|
|
9
9
|
|
|
10
10
|
var _reactModal = _interopRequireDefault(require("react-modal"));
|
|
11
11
|
|
|
12
|
-
var _hooks = require("
|
|
12
|
+
var _hooks = require("../../ApiItem/hooks");
|
|
13
13
|
|
|
14
14
|
var _slice = require("../Response/slice");
|
|
15
15
|
|
|
@@ -4,10 +4,10 @@
|
|
|
4
4
|
|
|
5
5
|
.floatingButton button {
|
|
6
6
|
position: relative;
|
|
7
|
-
background:
|
|
7
|
+
background: var(--ifm-color-emphasis-900);
|
|
8
8
|
border: none;
|
|
9
9
|
border-radius: var(--ifm-global-radius);
|
|
10
|
-
color: var(--ifm-color-
|
|
10
|
+
color: var(--ifm-color-emphasis-100);
|
|
11
11
|
cursor: pointer;
|
|
12
12
|
padding: 0.4rem 0.5rem;
|
|
13
13
|
opacity: 0;
|
|
@@ -15,7 +15,6 @@
|
|
|
15
15
|
transition: opacity 0.2s ease-in-out, visibility 0.2s ease-in-out,
|
|
16
16
|
bottom 0.2s ease-in-out;
|
|
17
17
|
position: absolute;
|
|
18
|
-
top: calc(var(--ifm-pre-padding) / 2);
|
|
19
18
|
right: calc(var(--ifm-pre-padding) / 2);
|
|
20
19
|
}
|
|
21
20
|
|
|
@@ -9,7 +9,7 @@ var _react = _interopRequireWildcard(require("react"));
|
|
|
9
9
|
|
|
10
10
|
var _toolkit = require("@reduxjs/toolkit");
|
|
11
11
|
|
|
12
|
-
var _hooks = require("
|
|
12
|
+
var _hooks = require("../../ApiItem/hooks");
|
|
13
13
|
|
|
14
14
|
var _FormItem = _interopRequireDefault(require("./../FormItem"));
|
|
15
15
|
|
|
@@ -11,6 +11,8 @@ var _useDocusaurusContext = _interopRequireDefault(require("@docusaurus/useDocus
|
|
|
11
11
|
|
|
12
12
|
var _postmanCollection = _interopRequireDefault(require("@paloaltonetworks/postman-collection"));
|
|
13
13
|
|
|
14
|
+
var _hooks = require("../../ApiItem/hooks");
|
|
15
|
+
|
|
14
16
|
var _Accept = _interopRequireDefault(require("../Accept"));
|
|
15
17
|
|
|
16
18
|
var _Authorization = _interopRequireDefault(require("../Authorization"));
|
|
@@ -19,10 +21,10 @@ var _Body = _interopRequireDefault(require("../Body"));
|
|
|
19
21
|
|
|
20
22
|
var _Execute = _interopRequireDefault(require("../Execute"));
|
|
21
23
|
|
|
22
|
-
var _hooks = require("../hooks");
|
|
23
|
-
|
|
24
24
|
var _ParamOptions = _interopRequireDefault(require("../ParamOptions"));
|
|
25
25
|
|
|
26
|
+
var _Server = _interopRequireDefault(require("../Server"));
|
|
27
|
+
|
|
26
28
|
var _stylesModule = _interopRequireDefault(require("./styles.module.css"));
|
|
27
29
|
|
|
28
30
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
@@ -65,6 +67,7 @@ function Request({
|
|
|
65
67
|
</div>
|
|
66
68
|
</summary>
|
|
67
69
|
<div className={_stylesModule.default.optionsPanel}>
|
|
70
|
+
<_Server.default />
|
|
68
71
|
<_Authorization.default />
|
|
69
72
|
<_ParamOptions.default />
|
|
70
73
|
<_Body.default jsonRequestBodyExample={item.jsonRequestBodyExample} requestBodyMetadata={item.requestBody} />
|
|
@@ -9,7 +9,7 @@ var _react = _interopRequireDefault(require("react"));
|
|
|
9
9
|
|
|
10
10
|
var _Link = _interopRequireDefault(require("@docusaurus/Link"));
|
|
11
11
|
|
|
12
|
-
var _hooks = require("
|
|
12
|
+
var _hooks = require("../../ApiItem/hooks");
|
|
13
13
|
|
|
14
14
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
15
15
|
|
|
@@ -7,9 +7,9 @@ exports.default = void 0;
|
|
|
7
7
|
|
|
8
8
|
var _react = _interopRequireWildcard(require("react"));
|
|
9
9
|
|
|
10
|
-
var
|
|
10
|
+
var _hooks = require("../../ApiItem/hooks");
|
|
11
11
|
|
|
12
|
-
var
|
|
12
|
+
var _FloatingButton = _interopRequireDefault(require("../FloatingButton"));
|
|
13
13
|
|
|
14
14
|
var _FormItem = _interopRequireDefault(require("./../FormItem"));
|
|
15
15
|
|
|
@@ -47,6 +47,21 @@ function Server() {
|
|
|
47
47
|
return null;
|
|
48
48
|
}
|
|
49
49
|
|
|
50
|
+
if (!value) {
|
|
51
|
+
const defaultOption = options[0];
|
|
52
|
+
dispatch((0, _slice.setServer)(JSON.stringify(defaultOption)));
|
|
53
|
+
} // Default to first option when existing server state is mismatched
|
|
54
|
+
|
|
55
|
+
|
|
56
|
+
if (value) {
|
|
57
|
+
const urlExists = options.find(s => s.url === value.url);
|
|
58
|
+
|
|
59
|
+
if (!urlExists) {
|
|
60
|
+
const defaultOption = options[0];
|
|
61
|
+
dispatch((0, _slice.setServer)(JSON.stringify(defaultOption)));
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
|
|
50
65
|
if (!isEditing) {
|
|
51
66
|
let url = "";
|
|
52
67
|
|
|
@@ -63,46 +78,49 @@ function Server() {
|
|
|
63
78
|
}
|
|
64
79
|
|
|
65
80
|
return <_FloatingButton.default onClick={() => setIsEditing(true)} label="Edit">
|
|
66
|
-
<
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
81
|
+
<_FormItem.default label="Base URL">
|
|
82
|
+
<pre style={{
|
|
83
|
+
background: "var(--openapi-card-background-color)",
|
|
84
|
+
paddingLeft: "0px"
|
|
85
|
+
}}>
|
|
86
|
+
<code title={url}>{url}</code>
|
|
87
|
+
</pre>
|
|
88
|
+
</_FormItem.default>
|
|
72
89
|
</_FloatingButton.default>;
|
|
73
90
|
}
|
|
74
91
|
|
|
75
92
|
return <div className={_stylesModule.default.optionsPanel}>
|
|
76
|
-
<
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
93
|
+
<_FloatingButton.default onClick={() => setIsEditing(false)} label="Hide">
|
|
94
|
+
<_FormItem.default label="Base URL">
|
|
95
|
+
<_FormSelect.default options={options.map(s => s.url)} onChange={e => {
|
|
96
|
+
dispatch((0, _slice.setServer)(JSON.stringify(options.filter(s => s.url === e.target.value)[0])));
|
|
97
|
+
}} value={value === null || value === void 0 ? void 0 : value.url} />
|
|
98
|
+
<small>{value === null || value === void 0 ? void 0 : value.description}</small>
|
|
99
|
+
</_FormItem.default>
|
|
100
|
+
{(value === null || value === void 0 ? void 0 : value.variables) && Object.keys(value.variables).map(key => {
|
|
101
|
+
var _value$variables2, _value$variables3, _value$variables4;
|
|
102
|
+
|
|
103
|
+
if (((_value$variables2 = value.variables) === null || _value$variables2 === void 0 ? void 0 : _value$variables2[key].enum) !== undefined) {
|
|
104
|
+
return <_FormItem.default label={key}>
|
|
105
|
+
<_FormSelect.default options={value.variables[key].enum} onChange={e => {
|
|
106
|
+
dispatch((0, _slice.setServerVariable)(JSON.stringify({
|
|
107
|
+
key,
|
|
108
|
+
value: e.target.value
|
|
109
|
+
})));
|
|
110
|
+
}} value={value === null || value === void 0 ? void 0 : value.variables[key].default} />
|
|
111
|
+
</_FormItem.default>;
|
|
112
|
+
}
|
|
113
|
+
|
|
87
114
|
return <_FormItem.default label={key}>
|
|
88
|
-
<
|
|
89
|
-
dispatch((0, _slice.setServerVariable)({
|
|
115
|
+
<_FormTextInput.default placeholder={(_value$variables3 = value.variables) === null || _value$variables3 === void 0 ? void 0 : _value$variables3[key].default} onChange={e => {
|
|
116
|
+
dispatch((0, _slice.setServerVariable)(JSON.stringify({
|
|
90
117
|
key,
|
|
91
118
|
value: e.target.value
|
|
92
|
-
}));
|
|
93
|
-
}} />
|
|
119
|
+
})));
|
|
120
|
+
}} value={value === null || value === void 0 ? void 0 : (_value$variables4 = value.variables) === null || _value$variables4 === void 0 ? void 0 : _value$variables4[key].default} />
|
|
94
121
|
</_FormItem.default>;
|
|
95
|
-
}
|
|
96
|
-
|
|
97
|
-
return <_FormItem.default label={key}>
|
|
98
|
-
<_FormTextInput.default placeholder={(_value$variables3 = value.variables) === null || _value$variables3 === void 0 ? void 0 : _value$variables3[key].default} onChange={e => {
|
|
99
|
-
dispatch((0, _slice.setServerVariable)({
|
|
100
|
-
key,
|
|
101
|
-
value: e.target.value
|
|
102
|
-
}));
|
|
103
|
-
}} />
|
|
104
|
-
</_FormItem.default>;
|
|
105
|
-
})}
|
|
122
|
+
})}
|
|
123
|
+
</_FloatingButton.default>
|
|
106
124
|
</div>;
|
|
107
125
|
}
|
|
108
126
|
|
|
@@ -19,13 +19,14 @@ const slice = (0, _toolkit.createSlice)({
|
|
|
19
19
|
initialState,
|
|
20
20
|
reducers: {
|
|
21
21
|
setServer: (state, action) => {
|
|
22
|
-
state.value = state.options.find(s => s.url === action.payload);
|
|
22
|
+
state.value = state.options.find(s => s.url === JSON.parse(action.payload).url);
|
|
23
23
|
},
|
|
24
24
|
setServerVariable: (state, action) => {
|
|
25
25
|
var _state$value;
|
|
26
26
|
|
|
27
27
|
if ((_state$value = state.value) !== null && _state$value !== void 0 && _state$value.variables) {
|
|
28
|
-
|
|
28
|
+
const parsedPayload = JSON.parse(action.payload);
|
|
29
|
+
state.value.variables[parsedPayload.key].default = parsedPayload.value;
|
|
29
30
|
}
|
|
30
31
|
}
|
|
31
32
|
}
|
|
@@ -7,30 +7,18 @@ exports.default = void 0;
|
|
|
7
7
|
|
|
8
8
|
var _react = _interopRequireDefault(require("react"));
|
|
9
9
|
|
|
10
|
-
var _useDocusaurusContext = _interopRequireDefault(require("@docusaurus/useDocusaurusContext"));
|
|
11
|
-
|
|
12
10
|
var _postmanCollection = _interopRequireDefault(require("@paloaltonetworks/postman-collection"));
|
|
13
11
|
|
|
14
|
-
var _reactRedux = require("react-redux");
|
|
15
|
-
|
|
16
|
-
var _slice = require("./Authorization/slice");
|
|
17
|
-
|
|
18
12
|
var _Curl = _interopRequireDefault(require("./Curl"));
|
|
19
13
|
|
|
20
14
|
var _MethodEndpoint = _interopRequireDefault(require("./MethodEndpoint"));
|
|
21
15
|
|
|
22
|
-
var _persistanceMiddleware = require("./persistanceMiddleware");
|
|
23
|
-
|
|
24
16
|
var _Request = _interopRequireDefault(require("./Request"));
|
|
25
17
|
|
|
26
18
|
var _Response = _interopRequireDefault(require("./Response"));
|
|
27
19
|
|
|
28
20
|
var _SecuritySchemes = _interopRequireDefault(require("./SecuritySchemes"));
|
|
29
21
|
|
|
30
|
-
var _Server = _interopRequireDefault(require("./Server"));
|
|
31
|
-
|
|
32
|
-
var _store = require("./store");
|
|
33
|
-
|
|
34
22
|
var _stylesModule = _interopRequireDefault(require("./styles.module.css"));
|
|
35
23
|
|
|
36
24
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
@@ -45,75 +33,20 @@ function ApiDemoPanel({
|
|
|
45
33
|
item,
|
|
46
34
|
infoPath
|
|
47
35
|
}) {
|
|
48
|
-
var
|
|
36
|
+
var _xCodeSamples;
|
|
49
37
|
|
|
50
|
-
const {
|
|
51
|
-
siteConfig
|
|
52
|
-
} = (0, _useDocusaurusContext.default)();
|
|
53
|
-
const themeConfig = siteConfig.themeConfig;
|
|
54
|
-
const options = themeConfig.api;
|
|
55
38
|
const postman = new _postmanCollection.default.Request(item.postman);
|
|
56
|
-
const acceptArray = Array.from(new Set(Object.values((_item$responses = item.responses) !== null && _item$responses !== void 0 ? _item$responses : {}).map(response => {
|
|
57
|
-
var _response$content;
|
|
58
|
-
|
|
59
|
-
return Object.keys((_response$content = response.content) !== null && _response$content !== void 0 ? _response$content : {});
|
|
60
|
-
}).flat()));
|
|
61
|
-
const content = (_item$requestBody$con = (_item$requestBody = item.requestBody) === null || _item$requestBody === void 0 ? void 0 : _item$requestBody.content) !== null && _item$requestBody$con !== void 0 ? _item$requestBody$con : {};
|
|
62
|
-
const contentTypeArray = Object.keys(content);
|
|
63
|
-
const servers = (_item$servers = item.servers) !== null && _item$servers !== void 0 ? _item$servers : [];
|
|
64
|
-
const params = {
|
|
65
|
-
path: [],
|
|
66
|
-
query: [],
|
|
67
|
-
header: [],
|
|
68
|
-
cookie: []
|
|
69
|
-
};
|
|
70
|
-
(_item$parameters = item.parameters) === null || _item$parameters === void 0 ? void 0 : _item$parameters.forEach(param => {
|
|
71
|
-
const paramType = param.in;
|
|
72
|
-
const paramsArray = params[paramType];
|
|
73
|
-
paramsArray.push(param);
|
|
74
|
-
});
|
|
75
|
-
const auth = (0, _slice.createAuth)({
|
|
76
|
-
security: item.security,
|
|
77
|
-
securitySchemes: item.securitySchemes,
|
|
78
|
-
options
|
|
79
|
-
});
|
|
80
|
-
const persistanceMiddleware = (0, _persistanceMiddleware.createPersistanceMiddleware)(options);
|
|
81
|
-
const store2 = (0, _store.createStoreWithState)({
|
|
82
|
-
accept: {
|
|
83
|
-
value: acceptArray[0],
|
|
84
|
-
options: acceptArray
|
|
85
|
-
},
|
|
86
|
-
contentType: {
|
|
87
|
-
value: contentTypeArray[0],
|
|
88
|
-
options: contentTypeArray
|
|
89
|
-
},
|
|
90
|
-
server: {
|
|
91
|
-
value: servers[0],
|
|
92
|
-
options: servers
|
|
93
|
-
},
|
|
94
|
-
response: {
|
|
95
|
-
value: undefined
|
|
96
|
-
},
|
|
97
|
-
body: {
|
|
98
|
-
type: "empty"
|
|
99
|
-
},
|
|
100
|
-
params,
|
|
101
|
-
auth
|
|
102
|
-
}, [persistanceMiddleware]);
|
|
103
39
|
const {
|
|
104
40
|
path,
|
|
105
41
|
method
|
|
106
42
|
} = item;
|
|
107
|
-
return <
|
|
108
|
-
<
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
<_Curl.default postman={postman} codeSamples={(_xCodeSamples = item["x-code-samples"]) !== null && _xCodeSamples !== void 0 ? _xCodeSamples : []} />
|
|
115
|
-
</div>
|
|
116
|
-
</_reactRedux.Provider>;
|
|
43
|
+
return <div className={_stylesModule.default.apiDemoPanelContainer}>
|
|
44
|
+
<_MethodEndpoint.default method={method} path={path} />
|
|
45
|
+
<_SecuritySchemes.default infoPath={infoPath} />
|
|
46
|
+
<_Request.default item={item} />
|
|
47
|
+
<_Response.default />
|
|
48
|
+
<_Curl.default postman={postman} codeSamples={(_xCodeSamples = item["x-code-samples"]) !== null && _xCodeSamples !== void 0 ? _xCodeSamples : []} />
|
|
49
|
+
</div>;
|
|
117
50
|
}
|
|
118
51
|
|
|
119
52
|
var _default = ApiDemoPanel;
|
|
@@ -37,6 +37,28 @@ function createPersistanceMiddleware(options) {
|
|
|
37
37
|
}
|
|
38
38
|
}
|
|
39
39
|
|
|
40
|
+
if (action.type === "contentType/setContentType") {
|
|
41
|
+
storage.setItem("contentType", action.payload);
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
if (action.type === "accept/setAccept") {
|
|
45
|
+
storage.setItem("accept", action.payload);
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
if (action.type === "server/setServer") {
|
|
49
|
+
storage.setItem("server", action.payload);
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
if (action.type === "server/setServerVariable") {
|
|
53
|
+
var _storage$getItem;
|
|
54
|
+
|
|
55
|
+
const server = (_storage$getItem = storage.getItem("server")) !== null && _storage$getItem !== void 0 ? _storage$getItem : "{}";
|
|
56
|
+
const variables = JSON.parse(action.payload);
|
|
57
|
+
let serverObject = JSON.parse(server);
|
|
58
|
+
serverObject.variables[variables.key].default = variables.value;
|
|
59
|
+
storage.setItem("server", JSON.stringify(serverObject));
|
|
60
|
+
}
|
|
61
|
+
|
|
40
62
|
return result;
|
|
41
63
|
};
|
|
42
64
|
|
|
@@ -154,12 +154,15 @@
|
|
|
154
154
|
margin-bottom: 0;
|
|
155
155
|
}
|
|
156
156
|
|
|
157
|
-
:global(
|
|
157
|
+
:global([class^="paramsItem"]::before),
|
|
158
|
+
:global([class^="schemaItem"]::before) {
|
|
158
159
|
position: absolute;
|
|
159
160
|
top: 10px;
|
|
160
161
|
left: 0;
|
|
161
|
-
width: 0.7rem;
|
|
162
|
-
|
|
162
|
+
width: 0.7rem;
|
|
163
|
+
/* width of horizontal line */
|
|
164
|
+
height: 0.5rem;
|
|
165
|
+
/* vertical position of line */
|
|
163
166
|
vertical-align: top;
|
|
164
167
|
border-bottom: thin solid var(--ifm-color-gray-500);
|
|
165
168
|
content: "";
|
|
@@ -410,3 +413,8 @@
|
|
|
410
413
|
max-height: 500px;
|
|
411
414
|
overflow: auto;
|
|
412
415
|
}
|
|
416
|
+
|
|
417
|
+
/* Prism code styles */
|
|
418
|
+
:global(.prism-code.language-json) {
|
|
419
|
+
white-space: pre !important;
|
|
420
|
+
}
|
|
File without changes
|