-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathcreateResponseSchema.ts
More file actions
104 lines (94 loc) · 3.08 KB
/
createResponseSchema.ts
File metadata and controls
104 lines (94 loc) · 3.08 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
/* ============================================================================
* Copyright (c) Palo Alto Networks
*
* This source code is licensed under the MIT license found in the
* LICENSE file in the root directory of this source tree.
* ========================================================================== */
import { createDescription } from "./createDescription";
// import { createDetails } from "./createDetails";
// import { createDetailsSummary } from "./createDetailsSummary";
import { getRequestBody as getResponseBody } from "./createRequestSchema";
import { create } from "./utils";
import { MediaTypeObject } from "../openapi/types";
// import { createNodes } from "./createSchema";
// import {
// createExampleFromSchema,
// createResponseExample,
// createResponseExamples,
// } from "./createStatusCodes";
interface Props {
style?: any;
title: string;
body: {
content?: {
[key: string]: MediaTypeObject;
};
description?: string;
required?: string[] | boolean;
};
}
export function createResponseSchema({ title, body, ...rest }: Props) {
if (
body === undefined ||
body.content === undefined ||
Object.keys(body).length === 0 ||
Object.keys(body.content).length === 0
) {
return undefined;
}
// Get all MIME types, including vendor-specific
const mimeTypes = Object.keys(body.content);
if (mimeTypes && mimeTypes.length) {
return create("MimeTabs", {
schemaType: "response",
children: mimeTypes.map((mimeType: any) => {
const responseExamples = body.content![mimeType].examples;
const responseExample = body.content![mimeType].example;
const firstBody =
body.content![mimeType].schema ?? body.content![mimeType];
if (
firstBody === undefined &&
responseExample === undefined &&
responseExamples === undefined
) {
return undefined;
}
const responseBody = getResponseBody(firstBody, {
title,
description: body.description
? createDescription(body.description)
: null,
required: false,
});
if (responseBody === undefined) {
return undefined;
}
return create("TabItem", {
label: `${mimeType}`,
value: `${mimeType}`,
children: [
responseBody,
// create("SchemaTabs", {
// TODO: determine if we should persist this
// groupId: "schema-tabs",
// children: [
// firstBody &&
// create("TabItem", {
// label: `${title}`,
// value: `${title}`,
// children: [responseBody],
// }),
// firstBody && createExampleFromSchema(firstBody, mimeType),
// responseExamples &&
// createResponseExamples(responseExamples, mimeType),
// responseExample &&
// createResponseExample(responseExample, mimeType),
// ],
// }),
],
});
}),
});
}
return undefined;
}