mirror of
https://github.com/Redocly/redoc.git
synced 2025-02-11 15:30:33 +03:00
Added responses samples component
This commit is contained in:
parent
c265e724e2
commit
258a64daf8
11
lib/components/ResponsesSamples/responses-samples.css
Normal file
11
lib/components/ResponsesSamples/responses-samples.css
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
header {
|
||||||
|
font-size: 20px;
|
||||||
|
}
|
||||||
|
|
||||||
|
tab, tabs {
|
||||||
|
display: block;
|
||||||
|
}
|
||||||
|
|
||||||
|
schema-sample {
|
||||||
|
display: block;
|
||||||
|
}
|
6
lib/components/ResponsesSamples/responses-samples.html
Normal file
6
lib/components/ResponsesSamples/responses-samples.html
Normal file
|
@ -0,0 +1,6 @@
|
||||||
|
<header> Responses samples </header>
|
||||||
|
<tabs>
|
||||||
|
<tab *ng-for="#response of data.responses" [tab-title]="response.code">
|
||||||
|
<schema-sample pointer="{{response.pointer}}/schema"><schema-sample>
|
||||||
|
</tab>
|
||||||
|
</tabs>
|
44
lib/components/ResponsesSamples/responses-samples.js
Normal file
44
lib/components/ResponsesSamples/responses-samples.js
Normal file
|
@ -0,0 +1,44 @@
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
import {RedocComponent, BaseComponent} from '../base';
|
||||||
|
import {JsonPointer} from '../../utils/JsonPointer';
|
||||||
|
import {Tabs, Tab} from '../../common-components/Tabs/tabs';
|
||||||
|
import {SchemaSample} from '../SchemaSample/schema-sample';
|
||||||
|
|
||||||
|
|
||||||
|
function isNumeric(n) {
|
||||||
|
return (!isNaN(parseFloat(n)) && isFinite(n));
|
||||||
|
}
|
||||||
|
|
||||||
|
@RedocComponent({
|
||||||
|
selector: 'responses-samples',
|
||||||
|
templateUrl: './lib/components/ResponsesSamples/responses-samples.html',
|
||||||
|
styleUrls: ['./lib/components/ResponsesSamples/responses-samples.css'],
|
||||||
|
directives: [SchemaSample, Tabs, Tab]
|
||||||
|
})
|
||||||
|
export class ResponsesSamples extends BaseComponent {
|
||||||
|
constructor(schemaMgr) {
|
||||||
|
super(schemaMgr);
|
||||||
|
}
|
||||||
|
|
||||||
|
prepareModel() {
|
||||||
|
this.data = {};
|
||||||
|
let responses = this.componentSchema;
|
||||||
|
responses = Object.keys(responses).filter(respCode => {
|
||||||
|
// only response-codes and "default"
|
||||||
|
return ( isNumeric(respCode) || (respCode === 'default'));
|
||||||
|
}).map(respCode => {
|
||||||
|
let resp = responses[respCode];
|
||||||
|
resp.pointer = JsonPointer.join(this.pointer, respCode);
|
||||||
|
if (resp.$ref) {
|
||||||
|
let ref = resp.$ref;
|
||||||
|
resp = this.schemaMgr.byPointer(resp.$ref);
|
||||||
|
resp.pointer = ref;
|
||||||
|
}
|
||||||
|
|
||||||
|
resp.code = respCode;
|
||||||
|
return resp;
|
||||||
|
});
|
||||||
|
this.data.responses = responses;
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user