feat: provide Topbar Logo as a wrappable component (#7521)

* docs(logo): added logo replace docs

Co-authored-by: Tim Lai <timothy.lai@gmail.com>
This commit is contained in:
Mahtis Michel
2022-07-18 22:55:26 +02:00
committed by GitHub
parent 0d5227bb5d
commit 878e848b9b
4 changed files with 28 additions and 3 deletions

View File

@@ -41,6 +41,21 @@ const MultiplePhraseFilterPlugin = function() {
}
}
```
### Logo component
While using the Standalone Preset the SwaggerUI logo is rendered in the Top Bar.
The logo can be exchanged by replacing the `Logo` component via the plugin api:
```jsx
import React from "react";
const MyLogoPlugin = {
components: {
Logo: () => (
<img alt="My Logo" height="40" src=""/>
)
}
}
```
### JSON Schema components
In swagger there are so called JSON Schema components. These are used to render inputs for parameters and components of request bodies with `application/x-www-form-urlencoded` or `multipart/*` media-type.

View File

@@ -1,9 +1,11 @@
import Topbar from "./topbar"
import Logo from "./logo"
export default function () {
return {
components: {
Topbar
Topbar,
Logo
}
}
}

View File

@@ -0,0 +1,8 @@
import React from "react"
import SwaggerUILogo from "./logo_small.svg"
export const Logo = () => (
<img height="40" src={ SwaggerUILogo } alt="Swagger UI"/>
)
export default Logo

View File

@@ -2,7 +2,6 @@ import React, { cloneElement } from "react"
import PropTypes from "prop-types"
//import "./topbar.less"
import Logo from "./logo_small.svg"
import {parseSearch, serializeSearch} from "../../core/utils"
export default class Topbar extends React.Component {
@@ -113,6 +112,7 @@ export default class Topbar extends React.Component {
let { getComponent, specSelectors, getConfigs } = this.props
const Button = getComponent("Button")
const Link = getComponent("Link")
const Logo = getComponent("Logo")
let isLoading = specSelectors.loadingStatus() === "loading"
let isFailed = specSelectors.loadingStatus() === "failed"
@@ -150,7 +150,7 @@ export default class Topbar extends React.Component {
<div className="wrapper">
<div className="topbar-wrapper">
<Link>
<img height="40" src={ Logo } alt="Swagger UI"/>
<Logo/>
</Link>
<form className="download-url-wrapper" onSubmit={formOnSubmit}>
{control.map((el, i) => cloneElement(el, { key: i }))}