docusaurus-theme-openapi-docs 0.0.0-345

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.
Files changed (194) hide show
  1. package/LICENSE +21 -0
  2. package/babel.config.js +35 -0
  3. package/lib/index.js +48 -0
  4. package/lib/markdown/createDescription.js +20 -0
  5. package/lib/markdown/schema.js +121 -0
  6. package/lib/markdown/utils.js +45 -0
  7. package/lib/postman-code-generators.d.ts +9 -0
  8. package/lib/react-magic-dropzone.d.ts +9 -0
  9. package/lib/theme/ApiDemoPanel/Accept/index.js +41 -0
  10. package/lib/theme/ApiDemoPanel/Accept/slice.js +32 -0
  11. package/lib/theme/ApiDemoPanel/Authorization/auth-types.js +32 -0
  12. package/lib/theme/ApiDemoPanel/Authorization/index.js +174 -0
  13. package/lib/theme/ApiDemoPanel/Authorization/slice.js +137 -0
  14. package/lib/theme/ApiDemoPanel/Body/index.js +185 -0
  15. package/lib/theme/ApiDemoPanel/Body/slice.js +105 -0
  16. package/lib/theme/ApiDemoPanel/ContentType/index.js +41 -0
  17. package/lib/theme/ApiDemoPanel/ContentType/slice.js +32 -0
  18. package/lib/theme/ApiDemoPanel/Curl/index.js +235 -0
  19. package/lib/theme/ApiDemoPanel/Curl/styles.module.css +84 -0
  20. package/lib/theme/ApiDemoPanel/Execute/index.js +85 -0
  21. package/lib/theme/ApiDemoPanel/Execute/makeRequest.js +200 -0
  22. package/lib/theme/ApiDemoPanel/FloatingButton/index.js +32 -0
  23. package/lib/theme/ApiDemoPanel/FloatingButton/styles.module.css +26 -0
  24. package/lib/theme/ApiDemoPanel/FormFileUpload/index.js +96 -0
  25. package/lib/theme/ApiDemoPanel/FormFileUpload/styles.module.css +75 -0
  26. package/lib/theme/ApiDemoPanel/FormItem/index.js +35 -0
  27. package/lib/theme/ApiDemoPanel/FormItem/styles.module.css +7 -0
  28. package/lib/theme/ApiDemoPanel/FormMultiSelect/index.js +52 -0
  29. package/lib/theme/ApiDemoPanel/FormMultiSelect/styles.module.css +38 -0
  30. package/lib/theme/ApiDemoPanel/FormSelect/index.js +39 -0
  31. package/lib/theme/ApiDemoPanel/FormSelect/styles.module.css +51 -0
  32. package/lib/theme/ApiDemoPanel/FormTextInput/index.js +30 -0
  33. package/lib/theme/ApiDemoPanel/FormTextInput/styles.module.css +21 -0
  34. package/lib/theme/ApiDemoPanel/MethodEndpoint/index.js +60 -0
  35. package/lib/theme/ApiDemoPanel/ParamOptions/index.js +248 -0
  36. package/lib/theme/ApiDemoPanel/ParamOptions/slice.js +35 -0
  37. package/lib/theme/ApiDemoPanel/ParamOptions/styles.module.css +180 -0
  38. package/lib/theme/ApiDemoPanel/Response/index.js +75 -0
  39. package/lib/theme/ApiDemoPanel/Response/slice.js +37 -0
  40. package/lib/theme/ApiDemoPanel/SecuritySchemes/index.js +51 -0
  41. package/lib/theme/ApiDemoPanel/Server/index.js +109 -0
  42. package/lib/theme/ApiDemoPanel/Server/slice.js +41 -0
  43. package/lib/theme/ApiDemoPanel/Server/styles.module.css +61 -0
  44. package/lib/theme/ApiDemoPanel/VSCode/index.js +252 -0
  45. package/lib/theme/ApiDemoPanel/VSCode/styles.module.css +19 -0
  46. package/lib/theme/ApiDemoPanel/buildPostmanRequest.js +328 -0
  47. package/lib/theme/ApiDemoPanel/hooks.js +20 -0
  48. package/lib/theme/ApiDemoPanel/index.js +132 -0
  49. package/lib/theme/ApiDemoPanel/persistanceMiddleware.js +44 -0
  50. package/lib/theme/ApiDemoPanel/postman-collection.d.ts +10 -0
  51. package/lib/theme/ApiDemoPanel/storage-utils.js +47 -0
  52. package/lib/theme/ApiDemoPanel/store.js +48 -0
  53. package/lib/theme/ApiDemoPanel/styles.module.css +44 -0
  54. package/lib/theme/ApiItem/index.js +160 -0
  55. package/lib/theme/ApiItem/styles.module.css +109 -0
  56. package/lib/theme/ApiTabs/index.js +258 -0
  57. package/lib/theme/ApiTabs/styles.module.css +118 -0
  58. package/lib/theme/ParamsItem/index.js +68 -0
  59. package/lib/theme/ParamsItem/styles.module.css +24 -0
  60. package/lib/theme/SchemaItem/index.js +58 -0
  61. package/lib/theme/SchemaItem/styles.module.css +24 -0
  62. package/lib/theme-classic.d.ts +8 -0
  63. package/lib/theme-openapi.d.ts +48 -0
  64. package/lib/theme-translations.d.ts +9 -0
  65. package/lib/types.js +1 -0
  66. package/lib-next/index.js +38 -0
  67. package/lib-next/markdown/createDescription.js +13 -0
  68. package/lib-next/markdown/schema.js +115 -0
  69. package/lib-next/markdown/utils.js +31 -0
  70. package/lib-next/postman-code-generators.d.ts +9 -0
  71. package/lib-next/react-magic-dropzone.d.ts +9 -0
  72. package/lib-next/theme/ApiDemoPanel/Accept/index.js +33 -0
  73. package/lib-next/theme/ApiDemoPanel/Accept/slice.js +19 -0
  74. package/lib-next/theme/ApiDemoPanel/Authorization/auth-types.js +22 -0
  75. package/lib-next/theme/ApiDemoPanel/Authorization/index.js +203 -0
  76. package/lib-next/theme/ApiDemoPanel/Authorization/slice.js +101 -0
  77. package/lib-next/theme/ApiDemoPanel/Body/index.js +210 -0
  78. package/lib-next/theme/ApiDemoPanel/Body/slice.js +89 -0
  79. package/lib-next/theme/ApiDemoPanel/ContentType/index.js +33 -0
  80. package/lib-next/theme/ApiDemoPanel/ContentType/slice.js +19 -0
  81. package/lib-next/theme/ApiDemoPanel/Curl/index.js +262 -0
  82. package/lib-next/theme/ApiDemoPanel/Curl/styles.module.css +84 -0
  83. package/lib-next/theme/ApiDemoPanel/Execute/index.js +73 -0
  84. package/lib-next/theme/ApiDemoPanel/Execute/makeRequest.js +181 -0
  85. package/lib-next/theme/ApiDemoPanel/FloatingButton/index.js +19 -0
  86. package/lib-next/theme/ApiDemoPanel/FloatingButton/styles.module.css +26 -0
  87. package/lib-next/theme/ApiDemoPanel/FormFileUpload/index.js +112 -0
  88. package/lib-next/theme/ApiDemoPanel/FormFileUpload/styles.module.css +75 -0
  89. package/lib-next/theme/ApiDemoPanel/FormItem/index.js +29 -0
  90. package/lib-next/theme/ApiDemoPanel/FormItem/styles.module.css +7 -0
  91. package/lib-next/theme/ApiDemoPanel/FormMultiSelect/index.js +49 -0
  92. package/lib-next/theme/ApiDemoPanel/FormMultiSelect/styles.module.css +38 -0
  93. package/lib-next/theme/ApiDemoPanel/FormSelect/index.js +28 -0
  94. package/lib-next/theme/ApiDemoPanel/FormSelect/styles.module.css +51 -0
  95. package/lib-next/theme/ApiDemoPanel/FormTextInput/index.js +23 -0
  96. package/lib-next/theme/ApiDemoPanel/FormTextInput/styles.module.css +21 -0
  97. package/lib-next/theme/ApiDemoPanel/MethodEndpoint/index.js +53 -0
  98. package/lib-next/theme/ApiDemoPanel/ParamOptions/index.js +284 -0
  99. package/lib-next/theme/ApiDemoPanel/ParamOptions/slice.js +22 -0
  100. package/lib-next/theme/ApiDemoPanel/ParamOptions/styles.module.css +180 -0
  101. package/lib-next/theme/ApiDemoPanel/Response/index.js +65 -0
  102. package/lib-next/theme/ApiDemoPanel/Response/slice.js +22 -0
  103. package/lib-next/theme/ApiDemoPanel/SecuritySchemes/index.js +48 -0
  104. package/lib-next/theme/ApiDemoPanel/Server/index.js +114 -0
  105. package/lib-next/theme/ApiDemoPanel/Server/slice.js +25 -0
  106. package/lib-next/theme/ApiDemoPanel/Server/styles.module.css +61 -0
  107. package/lib-next/theme/ApiDemoPanel/VSCode/index.js +265 -0
  108. package/lib-next/theme/ApiDemoPanel/VSCode/styles.module.css +19 -0
  109. package/lib-next/theme/ApiDemoPanel/buildPostmanRequest.js +309 -0
  110. package/lib-next/theme/ApiDemoPanel/hooks.js +9 -0
  111. package/lib-next/theme/ApiDemoPanel/index.js +108 -0
  112. package/lib-next/theme/ApiDemoPanel/persistanceMiddleware.js +38 -0
  113. package/lib-next/theme/ApiDemoPanel/postman-collection.d.ts +10 -0
  114. package/lib-next/theme/ApiDemoPanel/storage-utils.js +35 -0
  115. package/lib-next/theme/ApiDemoPanel/store.js +30 -0
  116. package/lib-next/theme/ApiDemoPanel/styles.module.css +44 -0
  117. package/lib-next/theme/ApiItem/index.js +171 -0
  118. package/lib-next/theme/ApiItem/styles.module.css +109 -0
  119. package/lib-next/theme/ApiTabs/index.js +258 -0
  120. package/lib-next/theme/ApiTabs/styles.module.css +118 -0
  121. package/lib-next/theme/ParamsItem/index.js +68 -0
  122. package/lib-next/theme/ParamsItem/styles.module.css +24 -0
  123. package/lib-next/theme/SchemaItem/index.js +58 -0
  124. package/lib-next/theme/SchemaItem/styles.module.css +24 -0
  125. package/lib-next/theme-classic.d.ts +8 -0
  126. package/lib-next/theme-openapi.d.ts +48 -0
  127. package/lib-next/theme-translations.d.ts +9 -0
  128. package/lib-next/types.js +1 -0
  129. package/package.json +74 -0
  130. package/src/index.ts +42 -0
  131. package/src/markdown/createDescription.ts +13 -0
  132. package/src/markdown/schema.ts +115 -0
  133. package/src/markdown/utils.ts +39 -0
  134. package/src/postman-code-generators.d.ts +9 -0
  135. package/src/react-magic-dropzone.d.ts +9 -0
  136. package/src/theme/ApiDemoPanel/Accept/index.tsx +35 -0
  137. package/src/theme/ApiDemoPanel/Accept/slice.ts +29 -0
  138. package/src/theme/ApiDemoPanel/Authorization/auth-types.ts +26 -0
  139. package/src/theme/ApiDemoPanel/Authorization/index.tsx +211 -0
  140. package/src/theme/ApiDemoPanel/Authorization/slice.ts +145 -0
  141. package/src/theme/ApiDemoPanel/Body/index.tsx +218 -0
  142. package/src/theme/ApiDemoPanel/Body/slice.ts +133 -0
  143. package/src/theme/ApiDemoPanel/ContentType/index.tsx +35 -0
  144. package/src/theme/ApiDemoPanel/ContentType/slice.ts +29 -0
  145. package/src/theme/ApiDemoPanel/Curl/index.tsx +278 -0
  146. package/src/theme/ApiDemoPanel/Curl/styles.module.css +84 -0
  147. package/src/theme/ApiDemoPanel/Execute/index.tsx +87 -0
  148. package/src/theme/ApiDemoPanel/Execute/makeRequest.ts +182 -0
  149. package/src/theme/ApiDemoPanel/FloatingButton/index.tsx +27 -0
  150. package/src/theme/ApiDemoPanel/FloatingButton/styles.module.css +26 -0
  151. package/src/theme/ApiDemoPanel/FormFileUpload/index.tsx +115 -0
  152. package/src/theme/ApiDemoPanel/FormFileUpload/styles.module.css +75 -0
  153. package/src/theme/ApiDemoPanel/FormItem/index.tsx +28 -0
  154. package/src/theme/ApiDemoPanel/FormItem/styles.module.css +7 -0
  155. package/src/theme/ApiDemoPanel/FormMultiSelect/index.tsx +54 -0
  156. package/src/theme/ApiDemoPanel/FormMultiSelect/styles.module.css +38 -0
  157. package/src/theme/ApiDemoPanel/FormSelect/index.tsx +36 -0
  158. package/src/theme/ApiDemoPanel/FormSelect/styles.module.css +51 -0
  159. package/src/theme/ApiDemoPanel/FormTextInput/index.tsx +32 -0
  160. package/src/theme/ApiDemoPanel/FormTextInput/styles.module.css +21 -0
  161. package/src/theme/ApiDemoPanel/MethodEndpoint/index.tsx +55 -0
  162. package/src/theme/ApiDemoPanel/ParamOptions/index.tsx +316 -0
  163. package/src/theme/ApiDemoPanel/ParamOptions/slice.ts +37 -0
  164. package/src/theme/ApiDemoPanel/ParamOptions/styles.module.css +180 -0
  165. package/src/theme/ApiDemoPanel/Response/index.tsx +66 -0
  166. package/src/theme/ApiDemoPanel/Response/slice.ts +31 -0
  167. package/src/theme/ApiDemoPanel/SecuritySchemes/index.tsx +49 -0
  168. package/src/theme/ApiDemoPanel/Server/index.tsx +103 -0
  169. package/src/theme/ApiDemoPanel/Server/slice.ts +40 -0
  170. package/src/theme/ApiDemoPanel/Server/styles.module.css +61 -0
  171. package/src/theme/ApiDemoPanel/VSCode/index.tsx +205 -0
  172. package/src/theme/ApiDemoPanel/VSCode/styles.module.css +19 -0
  173. package/src/theme/ApiDemoPanel/buildPostmanRequest.ts +305 -0
  174. package/src/theme/ApiDemoPanel/hooks.ts +13 -0
  175. package/src/theme/ApiDemoPanel/index.tsx +117 -0
  176. package/src/theme/ApiDemoPanel/persistanceMiddleware.ts +46 -0
  177. package/src/theme/ApiDemoPanel/postman-collection.d.ts +10 -0
  178. package/src/theme/ApiDemoPanel/storage-utils.ts +39 -0
  179. package/src/theme/ApiDemoPanel/store.ts +41 -0
  180. package/src/theme/ApiDemoPanel/styles.module.css +44 -0
  181. package/src/theme/ApiItem/index.tsx +171 -0
  182. package/src/theme/ApiItem/styles.module.css +109 -0
  183. package/src/theme/ApiTabs/index.js +258 -0
  184. package/src/theme/ApiTabs/styles.module.css +118 -0
  185. package/src/theme/ParamsItem/index.js +68 -0
  186. package/src/theme/ParamsItem/styles.module.css +24 -0
  187. package/src/theme/SchemaItem/index.js +58 -0
  188. package/src/theme/SchemaItem/styles.module.css +24 -0
  189. package/src/theme-classic.d.ts +8 -0
  190. package/src/theme-openapi.d.ts +48 -0
  191. package/src/theme-translations.d.ts +9 -0
  192. package/src/types.ts +70 -0
  193. package/tsconfig.json +10 -0
  194. package/yarn-error.log +15035 -0
@@ -0,0 +1,235 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = void 0;
7
+
8
+ var _react = _interopRequireWildcard(require("react"));
9
+
10
+ var _useDocusaurusContext = _interopRequireDefault(require("@docusaurus/useDocusaurusContext"));
11
+
12
+ var _postmanCodeGenerators = _interopRequireDefault(require("@paloaltonetworks/postman-code-generators"));
13
+
14
+ var _clsx = _interopRequireDefault(require("clsx"));
15
+
16
+ var _prismReactRenderer = _interopRequireWildcard(require("prism-react-renderer"));
17
+
18
+ var _hooks = require("../hooks");
19
+
20
+ var _buildPostmanRequest = _interopRequireDefault(require("./../buildPostmanRequest"));
21
+
22
+ var _FloatingButton = _interopRequireDefault(require("./../FloatingButton"));
23
+
24
+ var _stylesModule = _interopRequireDefault(require("./styles.module.css"));
25
+
26
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
27
+
28
+ function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
29
+
30
+ function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
31
+
32
+ /* ============================================================================
33
+ * Copyright (c) Palo Alto Networks
34
+ *
35
+ * This source code is licensed under the MIT license found in the
36
+ * LICENSE file in the root directory of this source tree.
37
+ * ========================================================================== */
38
+ const languageSet = [{
39
+ tabName: "cURL",
40
+ highlight: "bash",
41
+ language: "curl",
42
+ variant: "curl",
43
+ options: {
44
+ longFormat: false,
45
+ followRedirect: true,
46
+ trimRequestBody: true
47
+ }
48
+ }, {
49
+ tabName: "Node",
50
+ highlight: "javascript",
51
+ language: "nodejs",
52
+ variant: "axios",
53
+ options: {
54
+ ES6_enabled: true,
55
+ followRedirect: true,
56
+ trimRequestBody: true
57
+ }
58
+ }, {
59
+ tabName: "Go",
60
+ highlight: "go",
61
+ language: "go",
62
+ variant: "native",
63
+ options: {
64
+ followRedirect: true,
65
+ trimRequestBody: true
66
+ }
67
+ }, {
68
+ tabName: "Python",
69
+ highlight: "python",
70
+ language: "python",
71
+ variant: "requests",
72
+ options: {
73
+ followRedirect: true,
74
+ trimRequestBody: true
75
+ }
76
+ }];
77
+ const languageTheme = {
78
+ plain: {
79
+ color: "var(--ifm-code-color)"
80
+ },
81
+ styles: [{
82
+ types: ["inserted", "attr-name"],
83
+ style: {
84
+ color: "var(--openapi-code-green)"
85
+ }
86
+ }, {
87
+ types: ["string", "url"],
88
+ style: {
89
+ color: "var(--openapi-code-green)"
90
+ }
91
+ }, {
92
+ types: ["builtin", "char", "constant", "function"],
93
+ style: {
94
+ color: "var(--openapi-code-blue)"
95
+ }
96
+ }, {
97
+ types: ["punctuation", "operator"],
98
+ style: {
99
+ color: "var(--openapi-code-dim)"
100
+ }
101
+ }, {
102
+ types: ["class-name"],
103
+ style: {
104
+ color: "var(--openapi-code-orange)"
105
+ }
106
+ }, {
107
+ types: ["tag", "arrow", "keyword"],
108
+ style: {
109
+ color: "var(--openapi-code-purple)"
110
+ }
111
+ }, {
112
+ types: ["boolean"],
113
+ style: {
114
+ color: "var(--openapi-code-red)"
115
+ }
116
+ }]
117
+ };
118
+
119
+ function Curl({
120
+ postman,
121
+ codeSamples
122
+ }) {
123
+ var _ref, _siteConfig$themeConf;
124
+
125
+ // TODO: match theme for vscode.
126
+ const {
127
+ siteConfig
128
+ } = (0, _useDocusaurusContext.default)();
129
+ const [copyText, setCopyText] = (0, _react.useState)("Copy");
130
+ const contentType = (0, _hooks.useTypedSelector)(state => state.contentType.value);
131
+ const accept = (0, _hooks.useTypedSelector)(state => state.accept.value);
132
+ const server = (0, _hooks.useTypedSelector)(state => state.server.value);
133
+ const body = (0, _hooks.useTypedSelector)(state => state.body);
134
+ const pathParams = (0, _hooks.useTypedSelector)(state => state.params.path);
135
+ const queryParams = (0, _hooks.useTypedSelector)(state => state.params.query);
136
+ const cookieParams = (0, _hooks.useTypedSelector)(state => state.params.cookie);
137
+ const headerParams = (0, _hooks.useTypedSelector)(state => state.params.header);
138
+ const auth = (0, _hooks.useTypedSelector)(state => state.auth); // TODO
139
+
140
+ const langs = [...((_ref = siteConfig === null || siteConfig === void 0 ? void 0 : (_siteConfig$themeConf = siteConfig.themeConfig) === null || _siteConfig$themeConf === void 0 ? void 0 : _siteConfig$themeConf.languageTabs) !== null && _ref !== void 0 ? _ref : languageSet), ...codeSamples];
141
+ const [language, setLanguage] = (0, _react.useState)(langs[0]);
142
+ const [codeText, setCodeText] = (0, _react.useState)("");
143
+ (0, _react.useEffect)(() => {
144
+ if (language && !!language.options) {
145
+ const postmanRequest = (0, _buildPostmanRequest.default)(postman, {
146
+ queryParams,
147
+ pathParams,
148
+ cookieParams,
149
+ contentType,
150
+ accept,
151
+ headerParams,
152
+ body,
153
+ server,
154
+ auth
155
+ });
156
+
157
+ _postmanCodeGenerators.default.convert(language.language, language.variant, postmanRequest, language.options, (error, snippet) => {
158
+ if (error) {
159
+ return;
160
+ }
161
+
162
+ setCodeText(snippet);
163
+ });
164
+ } else if (language && !!language.source) {
165
+ setCodeText(language.source);
166
+ } else {
167
+ setCodeText("");
168
+ }
169
+ }, [accept, body, contentType, cookieParams, headerParams, language, pathParams, postman, queryParams, server, auth]);
170
+ const ref = (0, _react.useRef)(null);
171
+
172
+ const handleCurlCopy = () => {
173
+ var _ref$current;
174
+
175
+ setCopyText("Copied");
176
+ setTimeout(() => {
177
+ setCopyText("Copy");
178
+ }, 2000);
179
+
180
+ if ((_ref$current = ref.current) !== null && _ref$current !== void 0 && _ref$current.innerText) {
181
+ navigator.clipboard.writeText(ref.current.innerText);
182
+ }
183
+ };
184
+
185
+ if (language === undefined) {
186
+ return null;
187
+ }
188
+
189
+ return <>
190
+ <div className={(0, _clsx.default)(_stylesModule.default.buttonGroup, "api-code-tab-group")}>
191
+ {langs.map(lang => {
192
+ return <button key={lang.tabName || lang.label} className={(0, _clsx.default)(language === lang ? _stylesModule.default.selected : undefined, language === lang ? "api-code-tab--active" : undefined, "api-code-tab")} onClick={() => setLanguage(lang)}>
193
+ {lang.tabName || lang.label}
194
+ </button>;
195
+ })}
196
+ </div>
197
+
198
+ <_prismReactRenderer.default {..._prismReactRenderer.defaultProps} theme={languageTheme} code={codeText} language={language.highlight || language.lang}>
199
+ {({
200
+ className,
201
+ tokens,
202
+ getLineProps,
203
+ getTokenProps
204
+ }) => <_FloatingButton.default onClick={handleCurlCopy} label={copyText}>
205
+ <pre className={className} style={{
206
+ background: "var(--openapi-card-background-color)",
207
+ paddingRight: "60px",
208
+ borderRadius: "2px 2px var(--openapi-card-border-radius) var(--openapi-card-border-radius)"
209
+ }}>
210
+ <code ref={ref}>
211
+ {tokens.map((line, i) => <span {...getLineProps({
212
+ line,
213
+ key: i
214
+ })}>
215
+ {line.map((token, key) => {
216
+ if (token.types.includes("arrow")) {
217
+ token.types = ["arrow"];
218
+ }
219
+
220
+ return <span {...getTokenProps({
221
+ token,
222
+ key
223
+ })} />;
224
+ })}
225
+ {"\n"}
226
+ </span>)}
227
+ </code>
228
+ </pre>
229
+ </_FloatingButton.default>}
230
+ </_prismReactRenderer.default>
231
+ </>;
232
+ }
233
+
234
+ var _default = Curl;
235
+ exports.default = _default;
@@ -0,0 +1,84 @@
1
+ .buttonGroup {
2
+ background: var(--openapi-card-background-color);
3
+ color: var(--ifm-pre-color);
4
+ font-family: var(--ifm-font-family-monospace);
5
+ /* font-size: var(--ifm-code-font-size); */
6
+ /* line-height: var(--ifm-pre-line-height); */
7
+ /* margin-bottom: calc(var(--ifm-spacing-vertical) / 4); */
8
+ margin-bottom: 1px;
9
+ margin-top: 0;
10
+ border-radius: var(--openapi-card-border-radius)
11
+ var(--openapi-card-border-radius) 2px 2px;
12
+ display: flex;
13
+ justify-content: flex-end;
14
+ }
15
+
16
+ .buttonGroup button {
17
+ -webkit-appearance: none;
18
+ -moz-appearance: none;
19
+ appearance: none;
20
+
21
+ cursor: pointer;
22
+ /* font-size: calc(0.875rem * var(--ifm-button-size-multiplier)); */
23
+ /* line-height: 1.5; */
24
+ /* font-weight: var(--ifm-button-font-weight); */
25
+
26
+ /* font-size: var(--ifm-code-font-size); */
27
+ font-size: 13.3333px;
28
+ line-height: var(--ifm-pre-line-height);
29
+ font-weight: var(--ifm-font-weight-semibold);
30
+
31
+ padding: calc(
32
+ var(--ifm-button-padding-vertical) * var(--ifm-button-size-multiplier)
33
+ )
34
+ calc(
35
+ var(--ifm-button-padding-horizontal) * var(--ifm-button-size-multiplier)
36
+ );
37
+
38
+ text-align: center;
39
+
40
+ transition: color var(--ifm-button-transition-duration)
41
+ cubic-bezier(0.08, 0.52, 0.52, 1),
42
+ background var(--ifm-button-transition-duration)
43
+ cubic-bezier(0.08, 0.52, 0.52, 1),
44
+ border-color var(--ifm-button-transition-duration)
45
+ cubic-bezier(0.08, 0.52, 0.52, 1);
46
+ -webkit-user-select: none;
47
+ user-select: none;
48
+ white-space: nowrap;
49
+
50
+ background: transparent;
51
+
52
+ color: var(--ifm-menu-color);
53
+ border: 0px solid transparent;
54
+ /* border-radius: var(--ifm-pre-border-radius); */
55
+
56
+ --margin: 0.25rem;
57
+
58
+ border-radius: calc(var(--margin));
59
+ /* border-radius: 0.25rem; */
60
+
61
+ display: block;
62
+ width: 100%;
63
+
64
+ /* margin: 2px; */
65
+ margin: var(--margin);
66
+ margin-right: 0;
67
+ }
68
+
69
+ .buttonGroup button:last-child {
70
+ margin-right: 0.25rem;
71
+ }
72
+
73
+ .buttonGroup button:hover {
74
+ background: var(--ifm-menu-color-background-active);
75
+ }
76
+
77
+ .buttonGroup button:focus {
78
+ outline: 0;
79
+ }
80
+
81
+ .buttonGroup button.selected {
82
+ background: var(--ifm-menu-color-background-active);
83
+ color: var(--ifm-menu-color-active);
84
+ }
@@ -0,0 +1,85 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = void 0;
7
+
8
+ var _react = _interopRequireDefault(require("react"));
9
+
10
+ var _hooks = require("../hooks");
11
+
12
+ var _slice = require("../Response/slice");
13
+
14
+ var _buildPostmanRequest = _interopRequireDefault(require("./../buildPostmanRequest"));
15
+
16
+ var _makeRequest = _interopRequireDefault(require("./makeRequest"));
17
+
18
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
19
+
20
+ /* ============================================================================
21
+ * Copyright (c) Palo Alto Networks
22
+ *
23
+ * This source code is licensed under the MIT license found in the
24
+ * LICENSE file in the root directory of this source tree.
25
+ * ========================================================================== */
26
+ function validateRequest(params) {
27
+ for (let paramList of Object.values(params)) {
28
+ for (let param of paramList) {
29
+ if (param.required && !param.value) {
30
+ return false;
31
+ }
32
+ }
33
+ }
34
+
35
+ return true;
36
+ }
37
+
38
+ function Execute({
39
+ postman,
40
+ proxy
41
+ }) {
42
+ const pathParams = (0, _hooks.useTypedSelector)(state => state.params.path);
43
+ const queryParams = (0, _hooks.useTypedSelector)(state => state.params.query);
44
+ const cookieParams = (0, _hooks.useTypedSelector)(state => state.params.cookie);
45
+ const headerParams = (0, _hooks.useTypedSelector)(state => state.params.header);
46
+ const contentType = (0, _hooks.useTypedSelector)(state => state.contentType.value);
47
+ const body = (0, _hooks.useTypedSelector)(state => state.body);
48
+ const accept = (0, _hooks.useTypedSelector)(state => state.accept.value);
49
+ const server = (0, _hooks.useTypedSelector)(state => state.server.value);
50
+ const params = (0, _hooks.useTypedSelector)(state => state.params);
51
+ const auth = (0, _hooks.useTypedSelector)(state => state.auth);
52
+ const isValidRequest = validateRequest(params);
53
+ const dispatch = (0, _hooks.useTypedDispatch)();
54
+ const postmanRequest = (0, _buildPostmanRequest.default)(postman, {
55
+ queryParams,
56
+ pathParams,
57
+ cookieParams,
58
+ contentType,
59
+ accept,
60
+ headerParams,
61
+ body,
62
+ server,
63
+ auth
64
+ });
65
+ return <button className="button button--block button--primary" style={{
66
+ height: "48px",
67
+ marginBottom: "var(--ifm-spacing-vertical)"
68
+ }} disabled={!isValidRequest} onClick={async () => {
69
+ dispatch((0, _slice.setResponse)("loading..."));
70
+
71
+ try {
72
+ const res = await (0, _makeRequest.default)(postmanRequest, proxy, body);
73
+ dispatch((0, _slice.setResponse)(res));
74
+ } catch (e) {
75
+ var _e$message;
76
+
77
+ dispatch((0, _slice.setResponse)((_e$message = e.message) !== null && _e$message !== void 0 ? _e$message : "Error fetching."));
78
+ }
79
+ }}>
80
+ Execute
81
+ </button>;
82
+ }
83
+
84
+ var _default = Execute;
85
+ exports.default = _default;
@@ -0,0 +1,200 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = void 0;
7
+
8
+ /* ============================================================================
9
+ * Copyright (c) Palo Alto Networks
10
+ *
11
+ * This source code is licensed under the MIT license found in the
12
+ * LICENSE file in the root directory of this source tree.
13
+ * ========================================================================== */
14
+ async function loadImage(content) {
15
+ return new Promise((accept, reject) => {
16
+ const reader = new FileReader();
17
+
18
+ reader.onabort = () => {
19
+ console.log("file reading was aborted");
20
+ reject();
21
+ };
22
+
23
+ reader.onerror = () => {
24
+ console.log("file reading has failed");
25
+ reject();
26
+ };
27
+
28
+ reader.onload = () => {
29
+ // Do whatever you want with the file contents
30
+ const binaryStr = reader.result;
31
+ accept(binaryStr);
32
+ };
33
+
34
+ reader.readAsArrayBuffer(content);
35
+ });
36
+ }
37
+
38
+ async function makeRequest(request, proxy, _body) {
39
+ var _request$body;
40
+
41
+ const headers = request.toJSON().header;
42
+ let myHeaders = new Headers();
43
+
44
+ if (headers) {
45
+ headers.forEach(header => {
46
+ if (header.key && header.value) {
47
+ myHeaders.append(header.key, header.value);
48
+ }
49
+ });
50
+ } // The following code handles multiple files in the same formdata param.
51
+ // It removes the form data params where the src property is an array of filepath strings
52
+ // Splits that array into different form data params with src set as a single filepath string
53
+ // TODO:
54
+ // if (request.body && request.body.mode === 'formdata') {
55
+ // let formdata = request.body.formdata,
56
+ // formdataArray = [];
57
+ // formdata.members.forEach((param) => {
58
+ // let key = param.key,
59
+ // type = param.type,
60
+ // disabled = param.disabled,
61
+ // contentType = param.contentType;
62
+ // // check if type is file or text
63
+ // if (type === 'file') {
64
+ // // if src is not of type string we check for array(multiple files)
65
+ // if (typeof param.src !== 'string') {
66
+ // // if src is an array(not empty), iterate over it and add files as separate form fields
67
+ // if (Array.isArray(param.src) && param.src.length) {
68
+ // param.src.forEach((filePath) => {
69
+ // addFormParam(
70
+ // formdataArray,
71
+ // key,
72
+ // param.type,
73
+ // filePath,
74
+ // disabled,
75
+ // contentType
76
+ // );
77
+ // });
78
+ // }
79
+ // // if src is not an array or string, or is an empty array, add a placeholder for file path(no files case)
80
+ // else {
81
+ // addFormParam(
82
+ // formdataArray,
83
+ // key,
84
+ // param.type,
85
+ // '/path/to/file',
86
+ // disabled,
87
+ // contentType
88
+ // );
89
+ // }
90
+ // }
91
+ // // if src is string, directly add the param with src as filepath
92
+ // else {
93
+ // addFormParam(
94
+ // formdataArray,
95
+ // key,
96
+ // param.type,
97
+ // param.src,
98
+ // disabled,
99
+ // contentType
100
+ // );
101
+ // }
102
+ // }
103
+ // // if type is text, directly add it to formdata array
104
+ // else {
105
+ // addFormParam(
106
+ // formdataArray,
107
+ // key,
108
+ // param.type,
109
+ // param.value,
110
+ // disabled,
111
+ // contentType
112
+ // );
113
+ // }
114
+ // });
115
+ // request.body.update({
116
+ // mode: 'formdata',
117
+ // formdata: formdataArray,
118
+ // });
119
+ // }
120
+
121
+
122
+ const body = (_request$body = request.body) === null || _request$body === void 0 ? void 0 : _request$body.toJSON();
123
+ let myBody = undefined;
124
+
125
+ if (body !== undefined && Object.keys(body).length > 0) {
126
+ switch (body.mode) {
127
+ case "urlencoded":
128
+ {
129
+ myBody = new URLSearchParams();
130
+
131
+ if (Array.isArray(body.urlencoded)) {
132
+ for (const data of body.urlencoded) {
133
+ if (data.key && data.value) {
134
+ myBody.append(data.key, data.value);
135
+ }
136
+ }
137
+ }
138
+
139
+ break;
140
+ }
141
+
142
+ case "raw":
143
+ {
144
+ var _body$raw;
145
+
146
+ myBody = ((_body$raw = body.raw) !== null && _body$raw !== void 0 ? _body$raw : "").toString();
147
+ break;
148
+ }
149
+
150
+ case "formdata":
151
+ {
152
+ myBody = new FormData();
153
+
154
+ if (Array.isArray(body.formdata)) {
155
+ for (const data of body.formdata) {
156
+ if (data.key && data.value) {
157
+ myBody.append(data.key, data.value);
158
+ }
159
+ }
160
+ }
161
+
162
+ break;
163
+ }
164
+
165
+ case "file":
166
+ {
167
+ var _body$content;
168
+
169
+ if (_body.type === "raw" && ((_body$content = _body.content) === null || _body$content === void 0 ? void 0 : _body$content.type) === "file") {
170
+ myBody = await loadImage(_body.content.value.content);
171
+ }
172
+
173
+ break;
174
+ }
175
+
176
+ default:
177
+ break;
178
+ }
179
+ }
180
+
181
+ const requestOptions = {
182
+ method: request.method,
183
+ headers: myHeaders,
184
+ body: myBody
185
+ };
186
+ let finalUrl = request.url.toString();
187
+
188
+ if (proxy) {
189
+ // Ensure the proxy ends with a slash.
190
+ let normalizedProxy = proxy.replace(/\/$/, "") + "/";
191
+ finalUrl = normalizedProxy + request.url.toString();
192
+ }
193
+
194
+ return await fetch(finalUrl, requestOptions).then(response => {
195
+ return response.text();
196
+ });
197
+ }
198
+
199
+ var _default = makeRequest;
200
+ exports.default = _default;
@@ -0,0 +1,32 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = void 0;
7
+
8
+ var _react = _interopRequireDefault(require("react"));
9
+
10
+ var _stylesModule = _interopRequireDefault(require("./styles.module.css"));
11
+
12
+ function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
13
+
14
+ /* ============================================================================
15
+ * Copyright (c) Palo Alto Networks
16
+ *
17
+ * This source code is licensed under the MIT license found in the
18
+ * LICENSE file in the root directory of this source tree.
19
+ * ========================================================================== */
20
+ function FloatingButton({
21
+ label,
22
+ onClick,
23
+ children
24
+ }) {
25
+ return <div className={_stylesModule.default.floatingButton}>
26
+ {label && <button onClick={onClick}>{label}</button>}
27
+ {children}
28
+ </div>;
29
+ }
30
+
31
+ var _default = FloatingButton;
32
+ exports.default = _default;
@@ -0,0 +1,26 @@
1
+ .floatingButton {
2
+ position: relative;
3
+ }
4
+
5
+ .floatingButton button {
6
+ position: relative;
7
+ background: rgba(25, 26, 27, 0.9);
8
+ border: none;
9
+ border-radius: var(--ifm-global-radius);
10
+ color: var(--ifm-color-white);
11
+ cursor: pointer;
12
+ outline: none;
13
+ padding: 0.4rem 0.5rem;
14
+ opacity: 0;
15
+ visibility: hidden;
16
+ transition: opacity 0.2s ease-in-out, visibility 0.2s ease-in-out,
17
+ bottom 0.2s ease-in-out;
18
+ position: absolute;
19
+ top: calc(var(--ifm-pre-padding) / 2);
20
+ right: calc(var(--ifm-pre-padding) / 2);
21
+ }
22
+
23
+ .floatingButton:hover button {
24
+ visibility: visible;
25
+ opacity: 1;
26
+ }