-
Notifications
You must be signed in to change notification settings - Fork 10
/
Copy pathswagger-ui.es.js
104 lines (97 loc) · 2.71 KB
/
swagger-ui.es.js
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
import swaggerUiDist from 'swagger-ui-dist';
/**
* Swagger UI Frontend middleware
* @param {object} config Swagger UI Frontend middleware config
* @param {String=} options.title Title of documentation page
* @param {String=} options.path Path of Swagger front page
* @param {String=} options.url URL of Swagger file
* @default options.title nanoexpress - Swagger UI
* @default options.path /docs/
*
* @example
* app.use('/swagger-ui-dist', swaggerUi())
* // or
* app.get('/swagger-ui-dist', swaggerUi())
*/
export default function swaggerUiFrontend(config = {}) {
if (config.title === undefined) {
config.title = 'nanoexpress - Swagger UI';
}
if (config.path === undefined) {
config.path = '/docs';
}
if (config.fsPath === undefined) {
config.fsPath = swaggerUiDist.absolutePath();
}
// eslint-disable-next-line consistent-return
return async function swaggerUiFrontendHandler(req, res) {
if (config.url === undefined) {
config.url = `//${
req.headers !== undefined ? req.headers.host : req.getHeader('host')
}/docs/swagger.json`;
}
if (req.path.indexOf('/swagger-ui') !== -1) {
return res.sendFile(
`${config.fsPath}${req.path.substr(req.path.lastIndexOf('/'))}`
);
}
if (req.path === config.path) {
return res.end(`
<!-- HTML for static distribution bundle build -->
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>${config.title}</title>
<link rel="stylesheet" type="text/css" href="./swagger-ui.css" >
<link rel="icon" type="image/png" href="./favicon-32x32.png" sizes="32x32" />
<link rel="icon" type="image/png" href="./favicon-16x16.png" sizes="16x16" />
<style>
html
{
box-sizing: border-box;
overflow: -moz-scrollbars-vertical;
overflow-y: scroll;
}
*,
*:before,
*:after
{
box-sizing: inherit;
}
body
{
margin:0;
background: #fafafa;
}
</style>
</head>
<body>
<div id="swagger-ui"></div>
<script src="./swagger-ui-bundle.js"> </script>
<script src="./swagger-ui-standalone-preset.js"> </script>
<script>
window.onload = function() {
// Begin Swagger UI call region
const ui = SwaggerUIBundle({
url: window.location.protocol + "${config.url}",
dom_id: '#swagger-ui',
deepLinking: true,
presets: [
SwaggerUIBundle.presets.apis,
SwaggerUIStandalonePreset
],
plugins: [
SwaggerUIBundle.plugins.DownloadUrl
],
layout: "StandaloneLayout"
})
// End Swagger UI call region
window.ui = ui
}
</script>
</body>
</html>`);
}
};
}