docusaurus-theme-openapi-docs 2.0.0-beta.2 → 2.0.0-beta.3
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/index.d.ts +2 -0
- package/lib/index.js +53 -55
- package/lib/markdown/createDescription.d.ts +1 -0
- package/lib/markdown/createDescription.js +8 -11
- package/lib/markdown/schema.d.ts +3 -0
- package/lib/markdown/schema.js +138 -139
- package/lib/markdown/utils.d.ts +8 -0
- package/lib/markdown/utils.js +36 -42
- package/lib/theme/ApiDemoPanel/Accept/index.d.ts +3 -0
- package/lib/theme/ApiDemoPanel/Accept/index.js +26 -20
- package/lib/theme/ApiDemoPanel/Accept/slice.d.ts +11 -0
- package/lib/theme/ApiDemoPanel/Accept/slice.js +8 -17
- package/lib/theme/ApiDemoPanel/ApiCodeBlock/Container/_Container.scss +7 -0
- package/lib/theme/ApiDemoPanel/ApiCodeBlock/Container/index.js +29 -0
- package/lib/theme/ApiDemoPanel/ApiCodeBlock/Content/Element.js +30 -0
- package/lib/theme/ApiDemoPanel/ApiCodeBlock/Content/String.js +131 -0
- package/lib/theme/ApiDemoPanel/ApiCodeBlock/Content/_Content.scss +91 -0
- package/lib/theme/ApiDemoPanel/ApiCodeBlock/CopyButton/_CopyButton.scss +44 -0
- package/lib/theme/ApiDemoPanel/ApiCodeBlock/CopyButton/index.js +74 -0
- package/lib/theme/ApiDemoPanel/ApiCodeBlock/ExitButton/_ExitButton.scss +16 -0
- package/lib/theme/ApiDemoPanel/ApiCodeBlock/ExitButton/index.js +47 -0
- package/lib/theme/ApiDemoPanel/ApiCodeBlock/ExpandButton/_ExpandButton.scss +62 -0
- package/lib/theme/ApiDemoPanel/ApiCodeBlock/ExpandButton/index.js +165 -0
- package/lib/theme/ApiDemoPanel/ApiCodeBlock/Line/_Line.scss +46 -0
- package/lib/theme/ApiDemoPanel/ApiCodeBlock/Line/index.js +47 -0
- package/lib/theme/ApiDemoPanel/ApiCodeBlock/WordWrapButton/_WordWrapButton.scss +10 -0
- package/lib/theme/ApiDemoPanel/ApiCodeBlock/WordWrapButton/index.js +44 -0
- package/lib/theme/ApiDemoPanel/ApiCodeBlock/index.js +40 -0
- package/lib/theme/ApiDemoPanel/Authorization/auth-types.d.ts +3 -0
- package/lib/theme/ApiDemoPanel/Authorization/auth-types.js +4 -10
- package/lib/theme/ApiDemoPanel/Authorization/index.d.ts +3 -0
- package/lib/theme/ApiDemoPanel/Authorization/index.js +134 -84
- package/lib/theme/ApiDemoPanel/Authorization/slice.d.ts +40 -0
- package/lib/theme/ApiDemoPanel/Authorization/slice.js +30 -47
- package/lib/theme/ApiDemoPanel/Body/index.d.ts +10 -0
- package/lib/theme/ApiDemoPanel/Body/index.js +250 -158
- package/lib/theme/ApiDemoPanel/Body/slice.d.ts +82 -0
- package/lib/theme/ApiDemoPanel/Body/slice.js +39 -44
- package/lib/theme/ApiDemoPanel/CodeTabs/_CodeTabs.scss +158 -105
- package/lib/theme/ApiDemoPanel/CodeTabs/index.js +25 -7
- package/lib/theme/ApiDemoPanel/ContentType/index.d.ts +3 -0
- package/lib/theme/ApiDemoPanel/ContentType/index.js +28 -20
- package/lib/theme/ApiDemoPanel/ContentType/slice.d.ts +11 -0
- package/lib/theme/ApiDemoPanel/ContentType/slice.js +8 -17
- package/lib/theme/ApiDemoPanel/Curl/index.d.ts +20 -0
- package/lib/theme/ApiDemoPanel/Curl/index.js +340 -172
- package/lib/theme/ApiDemoPanel/Export/index.d.ts +3 -0
- package/lib/theme/ApiDemoPanel/Export/index.js +44 -34
- package/lib/theme/ApiDemoPanel/FloatingButton/index.d.ts +8 -0
- package/lib/theme/ApiDemoPanel/FloatingButton/index.js +20 -21
- package/lib/theme/ApiDemoPanel/FormFileUpload/index.d.ts +7 -0
- package/lib/theme/ApiDemoPanel/FormFileUpload/index.js +137 -58
- package/lib/theme/ApiDemoPanel/FormItem/_FormItem.scss +11 -2
- package/lib/theme/ApiDemoPanel/FormItem/index.d.ts +10 -0
- package/lib/theme/ApiDemoPanel/FormItem/index.js +34 -29
- package/lib/theme/ApiDemoPanel/FormMultiSelect/_FormMultiSelect.scss +8 -4
- package/lib/theme/ApiDemoPanel/FormMultiSelect/index.d.ts +9 -0
- package/lib/theme/ApiDemoPanel/FormMultiSelect/index.js +32 -25
- package/lib/theme/ApiDemoPanel/FormSelect/_FormSelect.scss +3 -3
- package/lib/theme/ApiDemoPanel/FormSelect/index.d.ts +8 -0
- package/lib/theme/ApiDemoPanel/FormSelect/index.js +24 -22
- package/lib/theme/ApiDemoPanel/FormTextInput/_FormTextInput.scss +24 -5
- package/lib/theme/ApiDemoPanel/FormTextInput/index.d.ts +9 -0
- package/lib/theme/ApiDemoPanel/FormTextInput/index.js +60 -14
- package/lib/theme/ApiDemoPanel/LiveEditor/index.d.ts +6 -0
- package/lib/theme/ApiDemoPanel/LiveEditor/index.js +135 -42
- package/lib/theme/ApiDemoPanel/MethodEndpoint/_MethodEndpoint.scss +16 -0
- package/lib/theme/ApiDemoPanel/MethodEndpoint/index.d.ts +7 -0
- package/lib/theme/ApiDemoPanel/MethodEndpoint/index.js +47 -38
- package/lib/theme/ApiDemoPanel/ParamOptions/ParamFormItems/ParamArrayFormItem.d.ts +6 -0
- package/lib/theme/ApiDemoPanel/ParamOptions/ParamFormItems/ParamArrayFormItem.js +194 -0
- package/lib/theme/ApiDemoPanel/ParamOptions/ParamFormItems/ParamBooleanFormItem.d.ts +6 -0
- package/lib/theme/ApiDemoPanel/ParamOptions/ParamFormItems/ParamBooleanFormItem.js +63 -0
- package/lib/theme/ApiDemoPanel/ParamOptions/ParamFormItems/ParamMultiSelectFormItem.d.ts +6 -0
- package/lib/theme/ApiDemoPanel/ParamOptions/ParamFormItems/ParamMultiSelectFormItem.js +89 -0
- package/lib/theme/ApiDemoPanel/ParamOptions/ParamFormItems/ParamSelectFormItem.d.ts +6 -0
- package/lib/theme/ApiDemoPanel/ParamOptions/ParamFormItems/ParamSelectFormItem.js +63 -0
- package/lib/theme/ApiDemoPanel/ParamOptions/ParamFormItems/ParamTextFormItem.d.ts +6 -0
- package/lib/theme/ApiDemoPanel/ParamOptions/ParamFormItems/ParamTextFormItem.js +38 -0
- package/lib/theme/ApiDemoPanel/ParamOptions/_ParamOptions.scss +9 -28
- package/lib/theme/ApiDemoPanel/ParamOptions/index.d.ts +7 -0
- package/lib/theme/ApiDemoPanel/ParamOptions/index.js +193 -198
- package/lib/theme/ApiDemoPanel/ParamOptions/slice.d.ts +17 -0
- package/lib/theme/ApiDemoPanel/ParamOptions/slice.js +9 -18
- package/lib/theme/ApiDemoPanel/Request/_Request.scss +93 -20
- package/lib/theme/ApiDemoPanel/Request/index.d.ts +6 -0
- package/lib/theme/ApiDemoPanel/Request/index.js +342 -51
- package/lib/theme/ApiDemoPanel/Request/makeRequest.d.ts +4 -0
- package/{lib-next/theme/ApiDemoPanel/Execute → lib/theme/ApiDemoPanel/Request}/makeRequest.js +3 -4
- package/lib/theme/ApiDemoPanel/Response/_Response.scss +54 -0
- package/lib/theme/ApiDemoPanel/Response/index.d.ts +6 -0
- package/lib/theme/ApiDemoPanel/Response/index.js +151 -70
- package/lib/theme/ApiDemoPanel/Response/slice.d.ts +17 -0
- package/lib/theme/ApiDemoPanel/Response/slice.js +25 -30
- package/lib/theme/ApiDemoPanel/SecuritySchemes/index.d.ts +3 -0
- package/lib/theme/ApiDemoPanel/SecuritySchemes/index.js +349 -226
- package/lib/theme/ApiDemoPanel/Server/_Server.scss +10 -0
- package/lib/theme/ApiDemoPanel/Server/index.d.ts +3 -0
- package/lib/theme/ApiDemoPanel/Server/index.js +155 -71
- package/lib/theme/ApiDemoPanel/Server/slice.d.ts +13 -0
- package/lib/theme/ApiDemoPanel/Server/slice.js +15 -22
- package/lib/theme/ApiDemoPanel/buildPostmanRequest.d.ts +20 -0
- package/lib/theme/ApiDemoPanel/buildPostmanRequest.js +136 -154
- package/lib/theme/ApiDemoPanel/index.d.ts +7 -0
- package/lib/theme/ApiDemoPanel/index.js +26 -27
- package/lib/theme/ApiDemoPanel/persistanceMiddleware.d.ts +3 -0
- package/lib/theme/ApiDemoPanel/persistanceMiddleware.js +15 -19
- package/lib/theme/ApiDemoPanel/storage-utils.d.ts +4 -0
- package/lib/theme/ApiDemoPanel/storage-utils.js +14 -13
- package/lib/theme/ApiItem/Layout/index.d.ts +4 -0
- package/lib/theme/ApiItem/Layout/index.js +78 -56
- package/lib/theme/ApiItem/hooks.d.ts +12 -0
- package/lib/theme/ApiItem/hooks.js +5 -10
- package/lib/theme/ApiItem/index.d.ts +4 -0
- package/lib/theme/ApiItem/index.js +136 -115
- package/lib/theme/ApiItem/store.d.ts +46 -0
- package/lib/theme/ApiItem/store.js +44 -34
- package/lib/theme/ApiLogo/index.d.ts +2 -0
- package/lib/theme/ApiLogo/index.js +34 -32
- package/lib/theme/ApiTabs/_ApiTabs.scss +29 -22
- package/lib/theme/ApiTabs/index.js +4 -3
- package/lib/theme/DiscriminatorTabs/_DiscriminatorTabs.scss +16 -13
- package/lib/theme/Markdown/Details/_Details.scss +82 -3
- package/lib/theme/MimeTabs/_MimeTabs.scss +13 -8
- package/lib/theme/ParamsItem/_ParamsItem.scss +23 -8
- package/lib/theme/ParamsItem/index.js +9 -6
- package/lib/theme/SchemaItem/_SchemaItem.scss +46 -11
- package/lib/theme/SchemaItem/index.js +23 -12
- package/lib/theme/SchemaTabs/_SchemaTabs.scss +23 -17
- package/lib/theme/SchemaTabs/index.js +50 -54
- package/lib/theme/styles.scss +41 -4
- package/lib/types.d.ts +157 -0
- package/lib/types.js +8 -1
- package/package.json +13 -21
- package/src/index.ts +31 -40
- package/src/theme/ApiDemoPanel/ApiCodeBlock/Container/_Container.scss +7 -0
- package/src/theme/ApiDemoPanel/ApiCodeBlock/Container/index.js +29 -0
- package/src/theme/ApiDemoPanel/ApiCodeBlock/Content/Element.js +30 -0
- package/src/theme/ApiDemoPanel/ApiCodeBlock/Content/String.js +131 -0
- package/src/theme/ApiDemoPanel/ApiCodeBlock/Content/_Content.scss +91 -0
- package/src/theme/ApiDemoPanel/ApiCodeBlock/CopyButton/_CopyButton.scss +44 -0
- package/src/theme/ApiDemoPanel/ApiCodeBlock/CopyButton/index.js +74 -0
- package/src/theme/ApiDemoPanel/ApiCodeBlock/ExitButton/_ExitButton.scss +16 -0
- package/src/theme/ApiDemoPanel/ApiCodeBlock/ExitButton/index.js +47 -0
- package/src/theme/ApiDemoPanel/ApiCodeBlock/ExpandButton/_ExpandButton.scss +62 -0
- package/src/theme/ApiDemoPanel/ApiCodeBlock/ExpandButton/index.js +165 -0
- package/src/theme/ApiDemoPanel/ApiCodeBlock/Line/_Line.scss +46 -0
- package/src/theme/ApiDemoPanel/ApiCodeBlock/Line/index.js +47 -0
- package/src/theme/ApiDemoPanel/ApiCodeBlock/WordWrapButton/_WordWrapButton.scss +10 -0
- package/src/theme/ApiDemoPanel/ApiCodeBlock/WordWrapButton/index.js +44 -0
- package/src/theme/ApiDemoPanel/ApiCodeBlock/index.js +40 -0
- package/src/theme/ApiDemoPanel/Body/index.tsx +38 -29
- package/src/theme/ApiDemoPanel/CodeTabs/_CodeTabs.scss +158 -105
- package/src/theme/ApiDemoPanel/CodeTabs/index.js +25 -7
- package/src/theme/ApiDemoPanel/Curl/index.tsx +86 -21
- package/src/theme/ApiDemoPanel/FormItem/_FormItem.scss +11 -2
- package/src/theme/ApiDemoPanel/FormItem/index.tsx +9 -11
- package/src/theme/ApiDemoPanel/FormMultiSelect/_FormMultiSelect.scss +8 -4
- package/src/theme/ApiDemoPanel/FormMultiSelect/index.tsx +7 -2
- package/src/theme/ApiDemoPanel/FormSelect/_FormSelect.scss +3 -3
- package/src/theme/ApiDemoPanel/FormTextInput/_FormTextInput.scss +24 -5
- package/src/theme/ApiDemoPanel/FormTextInput/index.tsx +58 -10
- package/src/theme/ApiDemoPanel/LiveEditor/index.tsx +53 -14
- package/src/theme/ApiDemoPanel/MethodEndpoint/_MethodEndpoint.scss +16 -0
- package/src/theme/ApiDemoPanel/MethodEndpoint/index.tsx +12 -9
- package/src/theme/ApiDemoPanel/ParamOptions/ParamFormItems/ParamArrayFormItem.tsx +153 -0
- package/src/theme/ApiDemoPanel/ParamOptions/ParamFormItems/ParamBooleanFormItem.tsx +64 -0
- package/src/theme/ApiDemoPanel/ParamOptions/ParamFormItems/ParamMultiSelectFormItem.tsx +86 -0
- package/src/theme/ApiDemoPanel/ParamOptions/ParamFormItems/ParamSelectFormItem.tsx +65 -0
- package/src/theme/ApiDemoPanel/ParamOptions/ParamFormItems/ParamTextFormItem.tsx +38 -0
- package/src/theme/ApiDemoPanel/ParamOptions/_ParamOptions.scss +9 -28
- package/src/theme/ApiDemoPanel/ParamOptions/index.tsx +8 -196
- package/src/theme/ApiDemoPanel/Request/_Request.scss +93 -20
- package/src/theme/ApiDemoPanel/Request/index.tsx +245 -28
- package/src/theme/ApiDemoPanel/Response/_Response.scss +54 -0
- package/src/theme/ApiDemoPanel/Response/index.tsx +51 -31
- package/src/theme/ApiDemoPanel/SecuritySchemes/index.tsx +5 -3
- package/src/theme/ApiDemoPanel/Server/_Server.scss +10 -0
- package/src/theme/ApiDemoPanel/Server/index.tsx +8 -11
- package/src/theme/ApiDemoPanel/index.tsx +4 -6
- package/src/theme/ApiItem/index.tsx +2 -2
- package/src/theme/ApiTabs/_ApiTabs.scss +29 -22
- package/src/theme/ApiTabs/index.js +4 -3
- package/src/theme/DiscriminatorTabs/_DiscriminatorTabs.scss +16 -13
- package/src/theme/Markdown/Details/_Details.scss +82 -3
- package/src/theme/MimeTabs/_MimeTabs.scss +13 -8
- package/src/theme/ParamsItem/_ParamsItem.scss +23 -8
- package/src/theme/ParamsItem/index.js +9 -6
- package/src/theme/SchemaItem/_SchemaItem.scss +46 -11
- package/src/theme/SchemaItem/index.js +23 -12
- package/src/theme/SchemaTabs/_SchemaTabs.scss +23 -17
- package/src/theme/SchemaTabs/index.js +50 -54
- package/src/theme/styles.scss +41 -4
- package/src/theme-openapi.d.ts +44 -1
- package/tsconfig.json +6 -3
- package/lib/postman-code-generators.d.ts +0 -9
- package/lib/react-magic-dropzone.d.ts +0 -9
- package/lib/theme/ApiDemoPanel/Execute/index.js +0 -155
- package/lib/theme/ApiDemoPanel/Execute/makeRequest.js +0 -181
- package/lib/theme/ApiDemoPanel/postman-collection.d.ts +0 -10
- package/lib/theme/ApiDemoPanel/react-modal.d.ts +0 -8
- package/lib/theme-classic.d.ts +0 -13
- package/lib/theme-openapi.d.ts +0 -234
- package/lib/theme-translations.d.ts +0 -9
- package/lib-next/index.js +0 -68
- package/lib-next/markdown/createDescription.js +0 -13
- package/lib-next/markdown/schema.js +0 -153
- package/lib-next/markdown/utils.js +0 -44
- package/lib-next/postman-code-generators.d.ts +0 -9
- package/lib-next/react-magic-dropzone.d.ts +0 -9
- package/lib-next/theme/ApiDemoPanel/Accept/index.js +0 -30
- package/lib-next/theme/ApiDemoPanel/Accept/slice.js +0 -20
- package/lib-next/theme/ApiDemoPanel/Authorization/auth-types.js +0 -29
- package/lib-next/theme/ApiDemoPanel/Authorization/index.js +0 -142
- package/lib-next/theme/ApiDemoPanel/Authorization/slice.js +0 -99
- package/lib-next/theme/ApiDemoPanel/Body/index.js +0 -328
- package/lib-next/theme/ApiDemoPanel/Body/json2xml.js +0 -43
- package/lib-next/theme/ApiDemoPanel/Body/slice.js +0 -88
- package/lib-next/theme/ApiDemoPanel/CodeTabs/_CodeTabs.scss +0 -238
- package/lib-next/theme/ApiDemoPanel/CodeTabs/index.js +0 -156
- package/lib-next/theme/ApiDemoPanel/ContentType/index.js +0 -30
- package/lib-next/theme/ApiDemoPanel/ContentType/slice.js +0 -20
- package/lib-next/theme/ApiDemoPanel/Curl/index.js +0 -281
- package/lib-next/theme/ApiDemoPanel/Curl/languages.json +0 -1386
- package/lib-next/theme/ApiDemoPanel/Execute/index.js +0 -178
- package/lib-next/theme/ApiDemoPanel/Export/index.js +0 -45
- package/lib-next/theme/ApiDemoPanel/FloatingButton/_FloatingButton.scss +0 -25
- package/lib-next/theme/ApiDemoPanel/FloatingButton/index.js +0 -21
- package/lib-next/theme/ApiDemoPanel/FormFileUpload/_FormFileUpload.scss +0 -72
- package/lib-next/theme/ApiDemoPanel/FormFileUpload/index.js +0 -107
- package/lib-next/theme/ApiDemoPanel/FormItem/_FormItem.scss +0 -12
- package/lib-next/theme/ApiDemoPanel/FormItem/index.js +0 -35
- package/lib-next/theme/ApiDemoPanel/FormMultiSelect/_FormMultiSelect.scss +0 -26
- package/lib-next/theme/ApiDemoPanel/FormMultiSelect/index.js +0 -44
- package/lib-next/theme/ApiDemoPanel/FormSelect/_FormSelect.scss +0 -43
- package/lib-next/theme/ApiDemoPanel/FormSelect/index.js +0 -29
- package/lib-next/theme/ApiDemoPanel/FormTextInput/_FormTextInput.scss +0 -15
- package/lib-next/theme/ApiDemoPanel/FormTextInput/index.js +0 -23
- package/lib-next/theme/ApiDemoPanel/LiveEditor/_LiveEditor.scss +0 -15
- package/lib-next/theme/ApiDemoPanel/LiveEditor/index.js +0 -58
- package/lib-next/theme/ApiDemoPanel/MethodEndpoint/_MethodEndpoint.scss +0 -6
- package/lib-next/theme/ApiDemoPanel/MethodEndpoint/index.js +0 -68
- package/lib-next/theme/ApiDemoPanel/ParamOptions/_ParamOptions.scss +0 -141
- package/lib-next/theme/ApiDemoPanel/ParamOptions/index.js +0 -299
- package/lib-next/theme/ApiDemoPanel/ParamOptions/slice.js +0 -23
- package/lib-next/theme/ApiDemoPanel/Request/_Request.scss +0 -48
- package/lib-next/theme/ApiDemoPanel/Request/index.js +0 -59
- package/lib-next/theme/ApiDemoPanel/Response/_Response.scss +0 -27
- package/lib-next/theme/ApiDemoPanel/Response/index.js +0 -122
- package/lib-next/theme/ApiDemoPanel/Response/slice.js +0 -42
- package/lib-next/theme/ApiDemoPanel/SecuritySchemes/index.js +0 -274
- package/lib-next/theme/ApiDemoPanel/Server/_Server.scss +0 -16
- package/lib-next/theme/ApiDemoPanel/Server/index.js +0 -131
- package/lib-next/theme/ApiDemoPanel/Server/slice.js +0 -28
- package/lib-next/theme/ApiDemoPanel/buildPostmanRequest.js +0 -298
- package/lib-next/theme/ApiDemoPanel/index.js +0 -25
- package/lib-next/theme/ApiDemoPanel/persistanceMiddleware.js +0 -58
- package/lib-next/theme/ApiDemoPanel/postman-collection.d.ts +0 -10
- package/lib-next/theme/ApiDemoPanel/react-modal.d.ts +0 -8
- package/lib-next/theme/ApiDemoPanel/storage-utils.js +0 -33
- package/lib-next/theme/ApiItem/Layout/index.js +0 -68
- package/lib-next/theme/ApiItem/Layout/styles.module.css +0 -17
- package/lib-next/theme/ApiItem/hooks.js +0 -10
- package/lib-next/theme/ApiItem/index.js +0 -150
- package/lib-next/theme/ApiItem/store.js +0 -38
- package/lib-next/theme/ApiLogo/index.js +0 -48
- package/lib-next/theme/ApiTabs/_ApiTabs.scss +0 -133
- package/lib-next/theme/ApiTabs/index.js +0 -191
- package/lib-next/theme/DiscriminatorTabs/_DiscriminatorTabs.scss +0 -94
- package/lib-next/theme/DiscriminatorTabs/index.js +0 -185
- package/lib-next/theme/Markdown/Details/_Details.scss +0 -40
- package/lib-next/theme/MimeTabs/_MimeTabs.scss +0 -64
- package/lib-next/theme/MimeTabs/index.js +0 -221
- package/lib-next/theme/ParamsItem/_ParamsItem.scss +0 -39
- package/lib-next/theme/ParamsItem/index.js +0 -133
- package/lib-next/theme/ResponseSamples/_ResponseSamples.scss +0 -3
- package/lib-next/theme/ResponseSamples/index.js +0 -22
- package/lib-next/theme/SchemaItem/_SchemaItem.scss +0 -53
- package/lib-next/theme/SchemaItem/index.js +0 -112
- package/lib-next/theme/SchemaTabs/_SchemaTabs.scss +0 -58
- package/lib-next/theme/SchemaTabs/index.js +0 -186
- package/lib-next/theme/styles.scss +0 -123
- package/lib-next/theme-classic.d.ts +0 -13
- package/lib-next/theme-openapi.d.ts +0 -234
- package/lib-next/theme-translations.d.ts +0 -9
- package/lib-next/types.js +0 -1
- package/src/theme/ApiDemoPanel/Execute/index.tsx +0 -200
- /package/src/theme/ApiDemoPanel/{Execute → Request}/makeRequest.ts +0 -0
|
@@ -17,6 +17,8 @@ import clsx from "clsx";
|
|
|
17
17
|
|
|
18
18
|
function TabList({
|
|
19
19
|
action,
|
|
20
|
+
currentLanguage,
|
|
21
|
+
includeVariant,
|
|
20
22
|
className,
|
|
21
23
|
block,
|
|
22
24
|
selectedValue,
|
|
@@ -38,10 +40,20 @@ function TabList({
|
|
|
38
40
|
}
|
|
39
41
|
|
|
40
42
|
if (action) {
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
43
|
+
let newLanguage;
|
|
44
|
+
if (currentLanguage && includeVariant) {
|
|
45
|
+
newLanguage = languageSet.filter(
|
|
46
|
+
(lang) => lang.language === currentLanguage
|
|
47
|
+
)[0];
|
|
48
|
+
newLanguage.variant = newTabValue;
|
|
49
|
+
action.setSelectedVariant(newTabValue.toLowerCase());
|
|
50
|
+
} else {
|
|
51
|
+
newLanguage = languageSet.filter(
|
|
52
|
+
(lang) => lang.language === newTabValue
|
|
53
|
+
)[0];
|
|
54
|
+
action.setSelectedVariant(newLanguage.variant.toLowerCase());
|
|
55
|
+
}
|
|
56
|
+
action.setLanguage(newLanguage);
|
|
45
57
|
}
|
|
46
58
|
};
|
|
47
59
|
|
|
@@ -101,7 +113,7 @@ function TabList({
|
|
|
101
113
|
}
|
|
102
114
|
)}
|
|
103
115
|
>
|
|
104
|
-
{label ?? value}
|
|
116
|
+
<span>{label ?? value}</span>
|
|
105
117
|
</li>
|
|
106
118
|
))}
|
|
107
119
|
</ul>
|
|
@@ -122,7 +134,7 @@ function TabContent({ lazy, children, selectedValue }) {
|
|
|
122
134
|
return cloneElement(selectedTabItem, { className: "margin-top--md" });
|
|
123
135
|
}
|
|
124
136
|
return (
|
|
125
|
-
<div className="margin-top--md">
|
|
137
|
+
<div className="margin-top--md openapi-tabs__code-content">
|
|
126
138
|
{children.map((tabItem, i) =>
|
|
127
139
|
cloneElement(tabItem, {
|
|
128
140
|
key: i,
|
|
@@ -135,8 +147,14 @@ function TabContent({ lazy, children, selectedValue }) {
|
|
|
135
147
|
|
|
136
148
|
function TabsComponent(props) {
|
|
137
149
|
const tabs = useTabs(props);
|
|
150
|
+
const { className } = props;
|
|
151
|
+
|
|
138
152
|
return (
|
|
139
|
-
<div
|
|
153
|
+
<div
|
|
154
|
+
className={clsx("tabs-container openapi-tabs__code-container", {
|
|
155
|
+
[className]: className,
|
|
156
|
+
})}
|
|
157
|
+
>
|
|
140
158
|
<TabList {...props} {...tabs} />
|
|
141
159
|
<TabContent {...props} {...tabs} />
|
|
142
160
|
</div>
|
|
@@ -10,18 +10,19 @@ import React, { useState, useEffect } from "react";
|
|
|
10
10
|
import useDocusaurusContext from "@docusaurus/useDocusaurusContext";
|
|
11
11
|
import codegen from "@paloaltonetworks/postman-code-generators";
|
|
12
12
|
import sdk from "@paloaltonetworks/postman-collection";
|
|
13
|
+
import ApiCodeBlock from "@theme/ApiDemoPanel/ApiCodeBlock";
|
|
13
14
|
import buildPostmanRequest from "@theme/ApiDemoPanel/buildPostmanRequest";
|
|
14
15
|
import CodeTabs from "@theme/ApiDemoPanel/CodeTabs";
|
|
15
16
|
import { useTypedSelector } from "@theme/ApiItem/hooks";
|
|
16
|
-
import CodeBlock from "@theme/CodeBlock";
|
|
17
17
|
import merge from "lodash/merge";
|
|
18
18
|
|
|
19
19
|
export interface Language {
|
|
20
|
-
highlight
|
|
20
|
+
highlight: string;
|
|
21
21
|
language: string;
|
|
22
|
-
logoClass
|
|
23
|
-
variant
|
|
24
|
-
|
|
22
|
+
logoClass: string;
|
|
23
|
+
variant: string;
|
|
24
|
+
variants: string[];
|
|
25
|
+
options: { [key: string]: boolean };
|
|
25
26
|
source?: string;
|
|
26
27
|
}
|
|
27
28
|
|
|
@@ -36,6 +37,7 @@ export const languageSet: Language[] = [
|
|
|
36
37
|
trimRequestBody: true,
|
|
37
38
|
},
|
|
38
39
|
variant: "cURL",
|
|
40
|
+
variants: ["curl"],
|
|
39
41
|
},
|
|
40
42
|
{
|
|
41
43
|
highlight: "python",
|
|
@@ -46,6 +48,7 @@ export const languageSet: Language[] = [
|
|
|
46
48
|
trimRequestBody: true,
|
|
47
49
|
},
|
|
48
50
|
variant: "requests",
|
|
51
|
+
variants: ["requests", "http.client"],
|
|
49
52
|
},
|
|
50
53
|
{
|
|
51
54
|
highlight: "go",
|
|
@@ -56,6 +59,7 @@ export const languageSet: Language[] = [
|
|
|
56
59
|
trimRequestBody: true,
|
|
57
60
|
},
|
|
58
61
|
variant: "native",
|
|
62
|
+
variants: ["native"],
|
|
59
63
|
},
|
|
60
64
|
{
|
|
61
65
|
highlight: "javascript",
|
|
@@ -67,6 +71,7 @@ export const languageSet: Language[] = [
|
|
|
67
71
|
trimRequestBody: true,
|
|
68
72
|
},
|
|
69
73
|
variant: "axios",
|
|
74
|
+
variants: ["axios", "native", "request", "unirest"],
|
|
70
75
|
},
|
|
71
76
|
{
|
|
72
77
|
highlight: "ruby",
|
|
@@ -77,6 +82,7 @@ export const languageSet: Language[] = [
|
|
|
77
82
|
trimRequestBody: true,
|
|
78
83
|
},
|
|
79
84
|
variant: "Net::HTTP",
|
|
85
|
+
variants: ["net::http"],
|
|
80
86
|
},
|
|
81
87
|
{
|
|
82
88
|
highlight: "csharp",
|
|
@@ -87,6 +93,7 @@ export const languageSet: Language[] = [
|
|
|
87
93
|
trimRequestBody: true,
|
|
88
94
|
},
|
|
89
95
|
variant: "RestSharp",
|
|
96
|
+
variants: ["restsharp", "httpclient"],
|
|
90
97
|
},
|
|
91
98
|
{
|
|
92
99
|
highlight: "php",
|
|
@@ -97,6 +104,7 @@ export const languageSet: Language[] = [
|
|
|
97
104
|
trimRequestBody: true,
|
|
98
105
|
},
|
|
99
106
|
variant: "cURL",
|
|
107
|
+
variants: ["curl", "guzzle", "pecl_http", "http_request2"],
|
|
100
108
|
},
|
|
101
109
|
{
|
|
102
110
|
highlight: "java",
|
|
@@ -107,6 +115,7 @@ export const languageSet: Language[] = [
|
|
|
107
115
|
trimRequestBody: true,
|
|
108
116
|
},
|
|
109
117
|
variant: "OkHttp",
|
|
118
|
+
variants: ["okhttp", "unirest"],
|
|
110
119
|
},
|
|
111
120
|
{
|
|
112
121
|
highlight: "powershell",
|
|
@@ -117,6 +126,7 @@ export const languageSet: Language[] = [
|
|
|
117
126
|
trimRequestBody: true,
|
|
118
127
|
},
|
|
119
128
|
variant: "RestMethod",
|
|
129
|
+
variants: ["restmethod"],
|
|
120
130
|
},
|
|
121
131
|
];
|
|
122
132
|
|
|
@@ -173,7 +183,7 @@ function Curl({ postman, codeSamples }: Props) {
|
|
|
173
183
|
(lang) =>
|
|
174
184
|
lang.language === localStorage.getItem("docusaurus.tab.code-samples")
|
|
175
185
|
);
|
|
176
|
-
|
|
186
|
+
const [selectedVariant, setSelectedVariant] = useState();
|
|
177
187
|
const [language, setLanguage] = useState(() => {
|
|
178
188
|
// Return first index if only 1 user-defined language exists
|
|
179
189
|
if (mergedLangs.length === 1) {
|
|
@@ -182,7 +192,6 @@ function Curl({ postman, codeSamples }: Props) {
|
|
|
182
192
|
// Fall back to language in localStorage or first user-defined language
|
|
183
193
|
return defaultLang[0] ?? mergedLangs[0];
|
|
184
194
|
});
|
|
185
|
-
|
|
186
195
|
const [codeText, setCodeText] = useState("");
|
|
187
196
|
|
|
188
197
|
useEffect(() => {
|
|
@@ -198,7 +207,6 @@ function Curl({ postman, codeSamples }: Props) {
|
|
|
198
207
|
server,
|
|
199
208
|
auth,
|
|
200
209
|
});
|
|
201
|
-
|
|
202
210
|
codegen.convert(
|
|
203
211
|
language.language,
|
|
204
212
|
language.variant,
|
|
@@ -264,34 +272,91 @@ function Curl({ postman, codeSamples }: Props) {
|
|
|
264
272
|
mergedLangs,
|
|
265
273
|
]);
|
|
266
274
|
|
|
275
|
+
useEffect(() => {
|
|
276
|
+
if (selectedVariant && selectedVariant !== language.variant) {
|
|
277
|
+
const postmanRequest = buildPostmanRequest(postman, {
|
|
278
|
+
queryParams,
|
|
279
|
+
pathParams,
|
|
280
|
+
cookieParams,
|
|
281
|
+
contentType,
|
|
282
|
+
accept,
|
|
283
|
+
headerParams,
|
|
284
|
+
body,
|
|
285
|
+
server,
|
|
286
|
+
auth,
|
|
287
|
+
});
|
|
288
|
+
codegen.convert(
|
|
289
|
+
language.language,
|
|
290
|
+
selectedVariant,
|
|
291
|
+
postmanRequest,
|
|
292
|
+
language.options,
|
|
293
|
+
(error: any, snippet: string) => {
|
|
294
|
+
if (error) {
|
|
295
|
+
return;
|
|
296
|
+
}
|
|
297
|
+
setCodeText(snippet);
|
|
298
|
+
}
|
|
299
|
+
);
|
|
300
|
+
}
|
|
301
|
+
});
|
|
302
|
+
|
|
267
303
|
if (language === undefined) {
|
|
268
304
|
return null;
|
|
269
305
|
}
|
|
270
306
|
|
|
271
307
|
return (
|
|
272
308
|
<>
|
|
273
|
-
<CodeTabs
|
|
309
|
+
<CodeTabs
|
|
310
|
+
groupId="code-samples"
|
|
311
|
+
action={{
|
|
312
|
+
setLanguage: setLanguage,
|
|
313
|
+
setSelectedVariant: setSelectedVariant,
|
|
314
|
+
}}
|
|
315
|
+
lazy
|
|
316
|
+
>
|
|
274
317
|
{mergedLangs.map((lang) => {
|
|
275
318
|
return (
|
|
276
319
|
<CodeTab
|
|
277
320
|
value={lang.language}
|
|
278
|
-
label={
|
|
279
|
-
key={
|
|
280
|
-
lang.variant
|
|
281
|
-
? `${lang.language}-${lang.variant}`
|
|
282
|
-
: lang.language
|
|
283
|
-
}
|
|
321
|
+
label={lang.language}
|
|
322
|
+
key={lang.language}
|
|
284
323
|
attributes={{
|
|
285
324
|
className: `openapi-tabs__code-item--${lang.logoClass}`,
|
|
286
325
|
}}
|
|
287
326
|
>
|
|
288
|
-
<
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
327
|
+
<CodeTabs
|
|
328
|
+
className="openapi-tabs__code-container-inner"
|
|
329
|
+
action={{
|
|
330
|
+
setLanguage: setLanguage,
|
|
331
|
+
setSelectedVariant: setSelectedVariant,
|
|
332
|
+
}}
|
|
333
|
+
includeVariant={true}
|
|
334
|
+
currentLanguage={lang.language}
|
|
335
|
+
defaultValue={selectedVariant}
|
|
336
|
+
lazy
|
|
292
337
|
>
|
|
293
|
-
{
|
|
294
|
-
|
|
338
|
+
{lang.variants.map((variant) => {
|
|
339
|
+
return (
|
|
340
|
+
<CodeTab
|
|
341
|
+
value={variant.toLowerCase()}
|
|
342
|
+
label={variant.toUpperCase()}
|
|
343
|
+
key={`${lang.language}-${lang.variant}`}
|
|
344
|
+
attributes={{
|
|
345
|
+
className: `openapi-tabs__code-item--variant`,
|
|
346
|
+
}}
|
|
347
|
+
>
|
|
348
|
+
{/* @ts-ignore */}
|
|
349
|
+
<ApiCodeBlock
|
|
350
|
+
language={lang.highlight}
|
|
351
|
+
className="openapi-demo__code-block"
|
|
352
|
+
showLineNumbers={true}
|
|
353
|
+
>
|
|
354
|
+
{codeText}
|
|
355
|
+
</ApiCodeBlock>
|
|
356
|
+
</CodeTab>
|
|
357
|
+
);
|
|
358
|
+
})}
|
|
359
|
+
</CodeTabs>
|
|
295
360
|
</CodeTab>
|
|
296
361
|
);
|
|
297
362
|
})}
|
|
@@ -1,12 +1,21 @@
|
|
|
1
1
|
.openapi-demo__form-item {
|
|
2
|
-
|
|
2
|
+
padding: var(--openapi-demo-padding-input);
|
|
3
|
+
font-size: var(--openapi-demo-font-size-input);
|
|
3
4
|
|
|
4
5
|
&:first-child {
|
|
5
6
|
margin-top: 0;
|
|
6
7
|
}
|
|
7
8
|
|
|
8
9
|
.required {
|
|
9
|
-
font-size: var(--ifm-code-font-size);
|
|
10
10
|
color: var(--openapi-required);
|
|
11
11
|
}
|
|
12
12
|
}
|
|
13
|
+
|
|
14
|
+
.openapi-demo__form-item-body-container {
|
|
15
|
+
padding: 0;
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
.openapi-demo__form-item-label {
|
|
19
|
+
font-family: var(--ifm-font-family-monospace);
|
|
20
|
+
font-weight: bold;
|
|
21
|
+
}
|
|
@@ -7,26 +7,24 @@
|
|
|
7
7
|
|
|
8
8
|
import React from "react";
|
|
9
9
|
|
|
10
|
+
import clsx from "clsx";
|
|
11
|
+
|
|
10
12
|
export interface Props {
|
|
11
13
|
label?: string;
|
|
12
14
|
type?: string;
|
|
13
15
|
required?: boolean | undefined;
|
|
14
16
|
children?: React.ReactNode;
|
|
17
|
+
className?: string;
|
|
15
18
|
}
|
|
16
19
|
|
|
17
|
-
function FormItem({ label, type, required, children }: Props) {
|
|
20
|
+
function FormItem({ label, type, required, children, className }: Props) {
|
|
18
21
|
return (
|
|
19
|
-
<div className="openapi-demo__form-item">
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
{required && (
|
|
23
|
-
<span>
|
|
24
|
-
{" "}
|
|
25
|
-
<small>
|
|
26
|
-
<strong className="required"> required</strong>
|
|
27
|
-
</small>
|
|
28
|
-
</span>
|
|
22
|
+
<div className={clsx("openapi-demo__form-item", className)}>
|
|
23
|
+
{label && (
|
|
24
|
+
<label className="openapi-demo__form-item-label">{label}</label>
|
|
29
25
|
)}
|
|
26
|
+
{type && <span style={{ opacity: 0.6 }}> — {type}</span>}
|
|
27
|
+
{required && <span className="openapi-schema__required">required</span>}
|
|
30
28
|
<div>{children}</div>
|
|
31
29
|
</div>
|
|
32
30
|
);
|
|
@@ -1,19 +1,23 @@
|
|
|
1
1
|
.openapi-demo__multi-select-input {
|
|
2
2
|
width: 100%;
|
|
3
3
|
margin-top: calc(var(--ifm-pre-padding) / 2);
|
|
4
|
-
padding:
|
|
4
|
+
padding: 1rem;
|
|
5
5
|
border-radius: 4px;
|
|
6
|
-
border:
|
|
6
|
+
border: 1px solid transparent;
|
|
7
7
|
background-color: var(--openapi-input-background);
|
|
8
8
|
outline: none;
|
|
9
|
-
font-size: var(--
|
|
9
|
+
font-size: var(--openapi-demo-font-size-input);
|
|
10
10
|
color: var(--ifm-pre-color);
|
|
11
11
|
-moz-appearance: none;
|
|
12
12
|
-webkit-appearance: none;
|
|
13
13
|
appearance: none;
|
|
14
14
|
|
|
15
15
|
&:focus {
|
|
16
|
-
border:
|
|
16
|
+
border: 1px solid var(--openapi-input-border);
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
&.error {
|
|
20
|
+
border: 1px solid var(--ifm-color-danger);
|
|
17
21
|
}
|
|
18
22
|
|
|
19
23
|
option {
|
|
@@ -7,13 +7,16 @@
|
|
|
7
7
|
|
|
8
8
|
import React from "react";
|
|
9
9
|
|
|
10
|
+
import clsx from "clsx";
|
|
11
|
+
|
|
10
12
|
export interface Props {
|
|
11
13
|
value?: string;
|
|
12
14
|
options: string[];
|
|
13
15
|
onChange?: React.ChangeEventHandler<HTMLSelectElement>;
|
|
16
|
+
showErrors?: boolean;
|
|
14
17
|
}
|
|
15
18
|
|
|
16
|
-
function FormMultiSelect({ value, options, onChange }: Props) {
|
|
19
|
+
function FormMultiSelect({ value, options, onChange, showErrors }: Props) {
|
|
17
20
|
if (options.length === 0) {
|
|
18
21
|
return null;
|
|
19
22
|
}
|
|
@@ -32,7 +35,9 @@ function FormMultiSelect({ value, options, onChange }: Props) {
|
|
|
32
35
|
return (
|
|
33
36
|
<select
|
|
34
37
|
style={{ height: height }}
|
|
35
|
-
className="openapi-demo__multi-select-input"
|
|
38
|
+
className={clsx("openapi-demo__multi-select-input", {
|
|
39
|
+
error: showErrors,
|
|
40
|
+
})}
|
|
36
41
|
value={value}
|
|
37
42
|
onChange={onChange}
|
|
38
43
|
size={Math.min(6, options.length + 1)}
|
|
@@ -4,7 +4,6 @@ html[data-theme="dark"] .openapi-demo__select-input {
|
|
|
4
4
|
border: none;
|
|
5
5
|
outline: none;
|
|
6
6
|
width: 100%;
|
|
7
|
-
font-size: var(--ifm-code-font-size);
|
|
8
7
|
color: var(--ifm-pre-color);
|
|
9
8
|
|
|
10
9
|
border-radius: 4px;
|
|
@@ -21,12 +20,13 @@ html[data-theme="dark"] .openapi-demo__select-input {
|
|
|
21
20
|
.openapi-demo__select-input {
|
|
22
21
|
width: 100%;
|
|
23
22
|
margin-top: calc(var(--ifm-pre-padding) / 2);
|
|
24
|
-
padding:
|
|
23
|
+
padding: var(--openapi-demo-padding-input);
|
|
25
24
|
border: none;
|
|
26
25
|
outline: none;
|
|
27
26
|
border-radius: 4px;
|
|
28
27
|
background-color: var(--openapi-input-background);
|
|
29
|
-
font-size: var(--
|
|
28
|
+
font-size: var(--openapi-demo-font-size-input);
|
|
29
|
+
font-family: var(--ifm-font-family-monospace);
|
|
30
30
|
color: var(--ifm-pre-color);
|
|
31
31
|
-moz-appearance: none;
|
|
32
32
|
-webkit-appearance: none;
|
|
@@ -1,15 +1,34 @@
|
|
|
1
|
-
.openapi-
|
|
1
|
+
.openapi-demo__form-item-input {
|
|
2
2
|
margin-top: calc(var(--ifm-pre-padding) / 2);
|
|
3
3
|
background-color: var(--openapi-input-background);
|
|
4
|
-
border:
|
|
4
|
+
border: 1px solid transparent;
|
|
5
5
|
outline: none;
|
|
6
6
|
width: 100%;
|
|
7
|
-
font-size: var(--ifm-code-font-size);
|
|
8
7
|
color: var(--ifm-pre-color);
|
|
9
|
-
padding:
|
|
8
|
+
padding: var(--openapi-demo-padding-input);
|
|
10
9
|
border-radius: 4px;
|
|
11
10
|
|
|
11
|
+
&:hover {
|
|
12
|
+
border: 1px solid var(--ifm-toc-border-color);
|
|
13
|
+
}
|
|
14
|
+
|
|
12
15
|
&:focus {
|
|
13
|
-
|
|
16
|
+
border: 1px solid var(--ifm-color-primary);
|
|
17
|
+
box-shadow: none;
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
&.error {
|
|
21
|
+
border: 1px solid var(--openapi-required);
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
.openapi-demo__input-error {
|
|
26
|
+
font-size: var(--openapi-demo-font-size-input);
|
|
27
|
+
color: var(--openapi-required);
|
|
28
|
+
padding-top: var(--openapi-demo-padding-input);
|
|
29
|
+
|
|
30
|
+
&::before {
|
|
31
|
+
display: inline;
|
|
32
|
+
content: "⚠ ";
|
|
14
33
|
}
|
|
15
34
|
}
|
|
@@ -5,8 +5,13 @@
|
|
|
5
5
|
* LICENSE file in the root directory of this source tree.
|
|
6
6
|
* ========================================================================== */
|
|
7
7
|
|
|
8
|
+
// @ts-nocheck
|
|
8
9
|
import React from "react";
|
|
9
10
|
|
|
11
|
+
import { ErrorMessage } from "@hookform/error-message";
|
|
12
|
+
import clsx from "clsx";
|
|
13
|
+
import { useFormContext } from "react-hook-form";
|
|
14
|
+
|
|
10
15
|
export interface Props {
|
|
11
16
|
value?: string;
|
|
12
17
|
placeholder?: string;
|
|
@@ -14,18 +19,61 @@ export interface Props {
|
|
|
14
19
|
onChange?: React.ChangeEventHandler<HTMLInputElement>;
|
|
15
20
|
}
|
|
16
21
|
|
|
17
|
-
function FormTextInput({
|
|
22
|
+
function FormTextInput({
|
|
23
|
+
isRequired,
|
|
24
|
+
value,
|
|
25
|
+
placeholder,
|
|
26
|
+
password,
|
|
27
|
+
onChange,
|
|
28
|
+
paramName,
|
|
29
|
+
}: Props) {
|
|
18
30
|
placeholder = placeholder?.split("\n")[0];
|
|
31
|
+
|
|
32
|
+
const {
|
|
33
|
+
register,
|
|
34
|
+
formState: { errors },
|
|
35
|
+
} = useFormContext();
|
|
36
|
+
|
|
37
|
+
const showErrorMessage = errors?.[paramName]?.message;
|
|
38
|
+
|
|
19
39
|
return (
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
40
|
+
<>
|
|
41
|
+
{paramName ? (
|
|
42
|
+
<input
|
|
43
|
+
{...register(paramName, {
|
|
44
|
+
required: isRequired ? "This field is required" : false,
|
|
45
|
+
})}
|
|
46
|
+
className={clsx("openapi-demo__form-item-input", {
|
|
47
|
+
error: showErrorMessage,
|
|
48
|
+
})}
|
|
49
|
+
type={password ? "password" : "text"}
|
|
50
|
+
placeholder={placeholder}
|
|
51
|
+
title={placeholder}
|
|
52
|
+
value={value}
|
|
53
|
+
onChange={onChange}
|
|
54
|
+
autoComplete="off"
|
|
55
|
+
/>
|
|
56
|
+
) : (
|
|
57
|
+
<input
|
|
58
|
+
className="openapi-demo__form-item-input"
|
|
59
|
+
type={password ? "password" : "text"}
|
|
60
|
+
placeholder={placeholder}
|
|
61
|
+
title={placeholder}
|
|
62
|
+
value={value}
|
|
63
|
+
onChange={onChange}
|
|
64
|
+
autoComplete="off"
|
|
65
|
+
/>
|
|
66
|
+
)}
|
|
67
|
+
{showErrorMessage && (
|
|
68
|
+
<ErrorMessage
|
|
69
|
+
errors={errors}
|
|
70
|
+
name={paramName}
|
|
71
|
+
render={({ message }) => (
|
|
72
|
+
<div className="openapi-demo__input-error">{message}</div>
|
|
73
|
+
)}
|
|
74
|
+
/>
|
|
75
|
+
)}
|
|
76
|
+
</>
|
|
29
77
|
);
|
|
30
78
|
}
|
|
31
79
|
|
|
@@ -9,29 +9,31 @@ import React, { useEffect, useState } from "react";
|
|
|
9
9
|
|
|
10
10
|
import { usePrismTheme } from "@docusaurus/theme-common";
|
|
11
11
|
import useIsBrowser from "@docusaurus/useIsBrowser";
|
|
12
|
+
import { ErrorMessage } from "@hookform/error-message";
|
|
12
13
|
import { setStringRawBody } from "@theme/ApiDemoPanel/Body/slice";
|
|
14
|
+
import clsx from "clsx";
|
|
15
|
+
import { Controller, useFormContext } from "react-hook-form";
|
|
13
16
|
import { LiveProvider, LiveEditor, withLive } from "react-live";
|
|
14
17
|
|
|
15
|
-
function Live({ onEdit }: any) {
|
|
18
|
+
function Live({ onEdit, showErrors }: any) {
|
|
16
19
|
const isBrowser = useIsBrowser();
|
|
17
20
|
const [editorDisabled, setEditorDisabled] = useState(false);
|
|
18
21
|
|
|
19
|
-
// TODO: Temporary solution for disabling tab key
|
|
20
|
-
const handleKeydown = (event: React.KeyboardEvent) => {
|
|
21
|
-
if (event.key === "Tab") {
|
|
22
|
-
event.preventDefault();
|
|
23
|
-
setEditorDisabled(true);
|
|
24
|
-
}
|
|
25
|
-
};
|
|
26
|
-
|
|
27
22
|
return (
|
|
28
|
-
<div
|
|
23
|
+
<div
|
|
24
|
+
onClick={() => setEditorDisabled(false)}
|
|
25
|
+
onBlur={() => setEditorDisabled(true)}
|
|
26
|
+
>
|
|
29
27
|
<LiveEditor
|
|
30
28
|
key={String(isBrowser)}
|
|
31
|
-
className=
|
|
29
|
+
className={clsx({
|
|
30
|
+
"openapi-demo__playground-editor": true,
|
|
31
|
+
"openapi-demo__form-item-input": showErrors,
|
|
32
|
+
error: showErrors,
|
|
33
|
+
})}
|
|
32
34
|
onChange={onEdit}
|
|
33
35
|
disabled={editorDisabled}
|
|
34
|
-
|
|
36
|
+
tabMode="focus"
|
|
35
37
|
/>
|
|
36
38
|
</div>
|
|
37
39
|
);
|
|
@@ -45,6 +47,7 @@ function App({
|
|
|
45
47
|
value,
|
|
46
48
|
language,
|
|
47
49
|
action,
|
|
50
|
+
required: isRequired,
|
|
48
51
|
...props
|
|
49
52
|
}: any): JSX.Element {
|
|
50
53
|
const prismTheme = usePrismTheme();
|
|
@@ -54,8 +57,24 @@ function App({
|
|
|
54
57
|
action(setStringRawBody(code));
|
|
55
58
|
}, [action, code]);
|
|
56
59
|
|
|
60
|
+
const {
|
|
61
|
+
control,
|
|
62
|
+
formState: { errors },
|
|
63
|
+
} = useFormContext();
|
|
64
|
+
|
|
65
|
+
const showErrorMessage = errors?.requestBody;
|
|
66
|
+
|
|
67
|
+
const handleChange = (snippet: string, onChange: any) => {
|
|
68
|
+
setCode(snippet);
|
|
69
|
+
onChange(snippet);
|
|
70
|
+
};
|
|
71
|
+
|
|
57
72
|
return (
|
|
58
|
-
<div
|
|
73
|
+
<div
|
|
74
|
+
className={clsx({
|
|
75
|
+
"openapi-demo__playground-container": true,
|
|
76
|
+
})}
|
|
77
|
+
>
|
|
59
78
|
<LiveProvider
|
|
60
79
|
code={children.replace(/\n$/, "")}
|
|
61
80
|
transformCode={transformCode ?? ((code) => `${code};`)}
|
|
@@ -63,7 +82,27 @@ function App({
|
|
|
63
82
|
language={language}
|
|
64
83
|
{...props}
|
|
65
84
|
>
|
|
66
|
-
<
|
|
85
|
+
<Controller
|
|
86
|
+
control={control}
|
|
87
|
+
rules={{ required: isRequired ? "This field is required" : false }}
|
|
88
|
+
name="requestBody"
|
|
89
|
+
render={({ field: { onChange, name } }) => (
|
|
90
|
+
<LiveComponent
|
|
91
|
+
onEdit={(e: any) => handleChange(e, onChange)}
|
|
92
|
+
name={name}
|
|
93
|
+
showErrors={showErrorMessage}
|
|
94
|
+
/>
|
|
95
|
+
)}
|
|
96
|
+
/>
|
|
97
|
+
{showErrorMessage && (
|
|
98
|
+
<ErrorMessage
|
|
99
|
+
errors={errors}
|
|
100
|
+
name="requestBody"
|
|
101
|
+
render={({ message }) => (
|
|
102
|
+
<div className="openapi-demo__input-error">{message}</div>
|
|
103
|
+
)}
|
|
104
|
+
/>
|
|
105
|
+
)}
|
|
67
106
|
</LiveProvider>
|
|
68
107
|
</div>
|
|
69
108
|
);
|
|
@@ -1,6 +1,22 @@
|
|
|
1
1
|
.openapi__method-endpoint {
|
|
2
|
+
display: flex;
|
|
3
|
+
align-items: center;
|
|
2
4
|
max-width: 100%;
|
|
3
5
|
width: fit-content;
|
|
4
6
|
padding: 0.65rem;
|
|
5
7
|
border: 1px solid var(--ifm-toc-border-color);
|
|
6
8
|
}
|
|
9
|
+
|
|
10
|
+
.openapi__method-endpoint-path {
|
|
11
|
+
margin-bottom: 0;
|
|
12
|
+
margin-left: 0.5rem;
|
|
13
|
+
font-size: 12px;
|
|
14
|
+
font-weight: normal;
|
|
15
|
+
font-family: var(--ifm-font-family-monospace);
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
.openapi__divider {
|
|
19
|
+
width: 100%;
|
|
20
|
+
margin: 1.5rem 0;
|
|
21
|
+
border-bottom: 1px solid var(--ifm-toc-border-color);
|
|
22
|
+
}
|