177 lines
5.7 KiB
JavaScript
177 lines
5.7 KiB
JavaScript
import React from "react"
|
|
import PropTypes from "prop-types"
|
|
import swaggerUIConstructor from "./swagger-ui-es-bundle-core"
|
|
|
|
export default class SwaggerUI extends React.Component {
|
|
constructor (props) {
|
|
super(props)
|
|
this.SwaggerUIComponent = null
|
|
this.system = null
|
|
}
|
|
|
|
componentDidMount() {
|
|
const ui = swaggerUIConstructor({
|
|
plugins: this.props.plugins,
|
|
spec: this.props.spec,
|
|
url: this.props.url,
|
|
layout: this.props.layout,
|
|
defaultModelsExpandDepth: this.props.defaultModelsExpandDepth,
|
|
defaultModelRendering: this.props.defaultModelRendering,
|
|
presets: [swaggerUIConstructor.presets.apis,...this.props.presets],
|
|
requestInterceptor: this.requestInterceptor,
|
|
responseInterceptor: this.responseInterceptor,
|
|
onComplete: this.onComplete,
|
|
docExpansion: this.props.docExpansion,
|
|
supportedSubmitMethods: this.props.supportedSubmitMethods,
|
|
queryConfigEnabled: this.props.queryConfigEnabled,
|
|
defaultModelExpandDepth: this.props.defaultModelExpandDepth,
|
|
displayOperationId: this.props.displayOperationId,
|
|
tryItOutEnabled: this.props.tryItOutEnabled,
|
|
displayRequestDuration: this.props.displayRequestDuration,
|
|
requestSnippetsEnabled: this.props.requestSnippetsEnabled,
|
|
requestSnippets: this.props.requestSnippets,
|
|
showMutatedRequest: typeof this.props.showMutatedRequest === "boolean" ? this.props.showMutatedRequest : true,
|
|
deepLinking: typeof this.props.deepLinking === "boolean" ? this.props.deepLinking : false,
|
|
showExtensions: this.props.showExtensions,
|
|
showCommonExtensions: this.props.showCommonExtensions,
|
|
filter: ["boolean", "string"].includes(typeof this.props.filter) ? this.props.filter : false,
|
|
persistAuthorization: this.props.persistAuthorization,
|
|
withCredentials: this.props.withCredentials,
|
|
oauth2RedirectUrl: this.props.oauth2RedirectUrl
|
|
})
|
|
|
|
this.system = ui
|
|
this.SwaggerUIComponent = ui.getComponent("App", "root")
|
|
|
|
this.forceUpdate()
|
|
}
|
|
|
|
render() {
|
|
return this.SwaggerUIComponent ? <this.SwaggerUIComponent /> : null
|
|
}
|
|
|
|
componentDidUpdate(prevProps) {
|
|
const prevStateUrl = this.system.specSelectors.url()
|
|
if(this.props.url !== prevStateUrl || this.props.url !== prevProps.url) {
|
|
// flush current content
|
|
this.system.specActions.updateSpec("")
|
|
|
|
if(this.props.url) {
|
|
// update the internal URL
|
|
this.system.specActions.updateUrl(this.props.url)
|
|
// trigger remote definition fetch
|
|
this.system.specActions.download(this.props.url)
|
|
}
|
|
}
|
|
|
|
const prevStateSpec = this.system.specSelectors.specStr()
|
|
if(this.props.spec && (this.props.spec !== prevStateSpec || this.props.spec !== prevProps.spec)) {
|
|
if(typeof this.props.spec === "object") {
|
|
this.system.specActions.updateSpec(JSON.stringify(this.props.spec))
|
|
} else {
|
|
this.system.specActions.updateSpec(this.props.spec)
|
|
}
|
|
}
|
|
}
|
|
|
|
requestInterceptor = (req) => {
|
|
if (typeof this.props.requestInterceptor === "function") {
|
|
return this.props.requestInterceptor(req)
|
|
}
|
|
return req
|
|
}
|
|
|
|
responseInterceptor = (res) => {
|
|
if (typeof this.props.responseInterceptor === "function") {
|
|
return this.props.responseInterceptor(res)
|
|
}
|
|
return res
|
|
}
|
|
|
|
onComplete = () => {
|
|
if (typeof this.props.onComplete === "function") {
|
|
return this.props.onComplete(this.system)
|
|
}
|
|
}
|
|
}
|
|
|
|
SwaggerUI.propTypes = {
|
|
spec: PropTypes.oneOfType([
|
|
PropTypes.string,
|
|
PropTypes.object,
|
|
]),
|
|
url: PropTypes.string,
|
|
layout: PropTypes.string,
|
|
requestInterceptor: PropTypes.func,
|
|
responseInterceptor: PropTypes.func,
|
|
onComplete: PropTypes.func,
|
|
docExpansion: PropTypes.oneOf(["list", "full", "none"]),
|
|
supportedSubmitMethods: PropTypes.arrayOf(
|
|
PropTypes.oneOf(["get", "put", "post", "delete", "options", "head", "patch", "trace"])
|
|
),
|
|
queryConfigEnabled: PropTypes.bool,
|
|
plugins: PropTypes.oneOfType([
|
|
PropTypes.arrayOf(PropTypes.object),
|
|
PropTypes.arrayOf(PropTypes.func),
|
|
PropTypes.func,
|
|
]),
|
|
displayOperationId: PropTypes.bool,
|
|
showMutatedRequest: PropTypes.bool,
|
|
defaultModelExpandDepth: PropTypes.number,
|
|
defaultModelsExpandDepth: PropTypes.number,
|
|
defaultModelRendering: PropTypes.oneOf(["example", "model"]),
|
|
presets: PropTypes.arrayOf(PropTypes.func),
|
|
deepLinking: PropTypes.bool,
|
|
showExtensions: PropTypes.bool,
|
|
showCommonExtensions: PropTypes.bool,
|
|
filter: PropTypes.oneOfType([
|
|
PropTypes.string,
|
|
PropTypes.bool,
|
|
]),
|
|
requestSnippetsEnabled: PropTypes.bool,
|
|
requestSnippets: PropTypes.object,
|
|
tryItOutEnabled: PropTypes.bool,
|
|
displayRequestDuration: PropTypes.bool,
|
|
persistAuthorization: PropTypes.bool,
|
|
withCredentials: PropTypes.bool,
|
|
oauth2RedirectUrl: PropTypes.string,
|
|
}
|
|
|
|
SwaggerUI.defaultProps = {
|
|
layout: "BaseLayout",
|
|
supportedSubmitMethods: ["get", "put", "post", "delete", "options", "head", "patch", "trace"],
|
|
queryConfigEnabled: false,
|
|
docExpansion: "list",
|
|
defaultModelsExpandDepth: 1,
|
|
defaultModelRendering: "example",
|
|
presets: [],
|
|
deepLinking: false,
|
|
displayRequestDuration: false,
|
|
showExtensions: false,
|
|
showCommonExtensions: false,
|
|
filter: false,
|
|
requestSnippetsEnabled: false,
|
|
requestSnippets: {
|
|
generators: {
|
|
"curl_bash": {
|
|
title: "cURL (bash)",
|
|
syntax: "bash"
|
|
},
|
|
"curl_powershell": {
|
|
title: "cURL (PowerShell)",
|
|
syntax: "powershell"
|
|
},
|
|
"curl_cmd": {
|
|
title: "cURL (CMD)",
|
|
syntax: "bash"
|
|
},
|
|
},
|
|
defaultExpanded: true,
|
|
languages: null, // e.g. only show curl bash = ["curl_bash"]
|
|
},
|
|
persistAuthorization: false,
|
|
}
|
|
|
|
SwaggerUI.presets = swaggerUIConstructor.presets
|
|
SwaggerUI.plugins = swaggerUIConstructor.plugins
|