mirror of
https://github.com/Redocly/redoc.git
synced 2025-02-06 13:00:34 +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