mirror of
https://github.com/Redocly/redoc.git
synced 2024-11-24 09:33:44 +03:00
Merge branch 'master' into releases
This commit is contained in:
commit
01914226ab
|
@ -47,6 +47,10 @@ $sub-schema-offset: ($bullet-size/2) + $bullet-margin;
|
||||||
width: 75%;
|
width: 75%;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.param-range {
|
||||||
|
color: rgba($primary-color, .7);
|
||||||
|
}
|
||||||
|
|
||||||
.param-description {
|
.param-description {
|
||||||
font-size: 13px;
|
font-size: 13px;
|
||||||
}
|
}
|
||||||
|
|
|
@ -11,7 +11,9 @@
|
||||||
<td class="param-info">
|
<td class="param-info">
|
||||||
<div>
|
<div>
|
||||||
<span class="param-type {{prop.type}}" [ngClass]="{'with-hint': prop._displayTypeHint}"
|
<span class="param-type {{prop.type}}" [ngClass]="{'with-hint': prop._displayTypeHint}"
|
||||||
title="{{prop._displayTypeHint}}"> {{prop._displayType}} {{prop._displayFormat}}</span>
|
title="{{prop._displayTypeHint}}"> {{prop._displayType}} {{prop._displayFormat}}
|
||||||
|
<span class="param-range" *ngIf="prop._range"> {{prop._range}} </span>
|
||||||
|
</span>
|
||||||
<span *ngIf="prop.required" class="param-required">Required</span>
|
<span *ngIf="prop.required" class="param-required">Required</span>
|
||||||
<div *ngIf="prop.enum" class="param-enum">
|
<div *ngIf="prop.enum" class="param-enum">
|
||||||
<span *ngFor="#enumItem of prop.enum" class="enum-value {{enumItem.type}}"> {{enumItem.val | json}} </span>
|
<span *ngFor="#enumItem of prop.enum" class="enum-value {{enumItem.type}}"> {{enumItem.val | json}} </span>
|
||||||
|
|
|
@ -71,11 +71,13 @@ export default class JsonSchema extends BaseComponent {
|
||||||
|
|
||||||
let discriminatorFieldIdx = -1;
|
let discriminatorFieldIdx = -1;
|
||||||
let props = Object.keys(schema.properties).map((prop, idx) => {
|
let props = Object.keys(schema.properties).map((prop, idx) => {
|
||||||
let propData = schema.properties[prop];
|
let propertySchema = schema.properties[prop];
|
||||||
let propPointer = JsonPointer.join(this.pointer, ['properties', prop]);
|
let propPointer = JsonPointer.join(this.pointer, ['properties', prop]);
|
||||||
propData = JsonSchema.injectPropData(propData, prop, propPointer, this.requiredMap, schema);
|
propertySchema = JsonSchema.injectPropertyData(propertySchema, prop, propPointer);
|
||||||
if (propData.isDiscriminator) discriminatorFieldIdx = idx;
|
propertySchema.required = !!this.requiredMap[prop];
|
||||||
return propData;
|
propertySchema.isDiscriminator = (schema.discriminator === prop);
|
||||||
|
if (propertySchema.isDiscriminator) discriminatorFieldIdx = idx;
|
||||||
|
return propertySchema;
|
||||||
});
|
});
|
||||||
// Move discriminator field to the end of properties list
|
// Move discriminator field to the end of properties list
|
||||||
if (discriminatorFieldIdx > -1) {
|
if (discriminatorFieldIdx > -1) {
|
||||||
|
@ -85,49 +87,104 @@ export default class JsonSchema extends BaseComponent {
|
||||||
this.data.properties = props;
|
this.data.properties = props;
|
||||||
}
|
}
|
||||||
|
|
||||||
static injectPropData(propData, propName, propPointer, requiredMap, schema) {
|
static injectPropertyData(propertySchema, propertyName, propPointer) {
|
||||||
let propEnum;
|
propertySchema = Object.assign({}, propertySchema);
|
||||||
|
|
||||||
propData = Object.assign({}, propData);
|
propertySchema._name = propertyName;
|
||||||
propData._name = propName;
|
runInjectors(propertySchema, propertySchema, propPointer);
|
||||||
propData.required = propData.required || (requiredMap && requiredMap[propName]);
|
|
||||||
propData._displayType = propData.type;
|
|
||||||
propData.isDiscriminator = (schema && schema.discriminator === propName);
|
|
||||||
propEnum = propData.enum;
|
|
||||||
if (propData.type === 'array') {
|
|
||||||
let itemType = propData.items.type;
|
|
||||||
let itemFormat = propData.items.format;
|
|
||||||
propEnum = propData.items.enum;
|
|
||||||
if (itemType === 'object' || !itemType) {
|
|
||||||
itemType = propData.items.title || 'object';
|
|
||||||
propData._pointer = propData.items._pointer
|
|
||||||
|| JsonPointer.join(propPointer, ['items']);
|
|
||||||
}
|
|
||||||
propData._displayType = `${itemType}`;
|
|
||||||
propData.format = itemFormat;
|
|
||||||
propData._isArray = true;
|
|
||||||
propData.type = 'array ' + propData.items.type;
|
|
||||||
} else if (propData.type === 'object' && propData.properties) {
|
|
||||||
propData._displayType = propData.title || 'object';
|
|
||||||
} else if (!propData.type) {
|
|
||||||
propData._displayType = '< * >';
|
|
||||||
propData._displayTypeHint = 'This field may contain data of any type';
|
|
||||||
} else {
|
|
||||||
// here we are sure that property has simple type (integer, string, object withou properties)
|
|
||||||
// delete pointer for simple types to not show it as subschema
|
|
||||||
if (propData._pointer) {
|
|
||||||
propData._pointer = undefined;
|
|
||||||
propData._displayType = propData.title ? `${propData.title} (${propData.type})` : propData.type;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (propData.format) propData._displayFormat = `<${propData.format}>`;
|
return propertySchema;
|
||||||
if (propEnum) {
|
|
||||||
propData.enum = propEnum.map((value) => {
|
|
||||||
return {val: value, type: typeof value};
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
return propData;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function runInjectors(injectTo, propertySchema, propertyPointer) {
|
||||||
|
for (var injName in injectors) {
|
||||||
|
let injector = injectors[injName];
|
||||||
|
if (injector.check(propertySchema)) {
|
||||||
|
injector.inject(injectTo, propertySchema, propertyPointer);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
const injectors = {
|
||||||
|
general: {
|
||||||
|
check: () => true,
|
||||||
|
inject: (injectTo, propertySchema) => {
|
||||||
|
injectTo._displayType = propertySchema.type;
|
||||||
|
if (propertySchema.format) injectTo._displayFormat = `<${propertySchema.format}>`;
|
||||||
|
if (propertySchema.enum) {
|
||||||
|
injectTo.enum = propertySchema.enum.map((value) => {
|
||||||
|
return {val: value, type: typeof value};
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
array: {
|
||||||
|
check: (propertySchema) => {
|
||||||
|
return propertySchema.type === 'array';
|
||||||
|
},
|
||||||
|
inject: (injectTo, propertySchema = injectTo, propPointer) => {
|
||||||
|
injectTo._isArray = true;
|
||||||
|
injectTo._pointer = propertySchema.items._pointer
|
||||||
|
|| JsonPointer.join(propertySchema._pointer || propPointer, ['items']);
|
||||||
|
|
||||||
|
runInjectors(injectTo, propertySchema.items, propPointer);
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
object: {
|
||||||
|
check: (propertySchema) => {
|
||||||
|
return propertySchema.type === 'object' && propertySchema.properties;
|
||||||
|
},
|
||||||
|
inject: (injectTo, propertySchema = injectTo) => {
|
||||||
|
injectTo._displayType = propertySchema.title || 'object';
|
||||||
|
}
|
||||||
|
},
|
||||||
|
noType: {
|
||||||
|
check: (propertySchema) => !propertySchema.type,
|
||||||
|
inject: (injectTo) => {
|
||||||
|
injectTo._displayType = '< * >';
|
||||||
|
injectTo._displayTypeHint = 'This field may contain data of any type';
|
||||||
|
}
|
||||||
|
},
|
||||||
|
|
||||||
|
simpleType: {
|
||||||
|
check: (propertySchema) => {
|
||||||
|
if (propertySchema.type === 'object') {
|
||||||
|
return !propertySchema.properties;
|
||||||
|
}
|
||||||
|
return (propertySchema.type !== 'array') && propertySchema.type;
|
||||||
|
},
|
||||||
|
inject: (injectTo, propertySchema = injectTo) => {
|
||||||
|
if (injectTo._pointer) {
|
||||||
|
injectTo._pointer = undefined;
|
||||||
|
injectTo._displayType = propertySchema.title ?
|
||||||
|
`${propertySchema.title} (${propertySchema.type})` : propertySchema.type;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
integer: {
|
||||||
|
check: (propertySchema) => (propertySchema.type === 'integer' || propertySchema.type === 'number'),
|
||||||
|
inject: (injectTo, propertySchema = injectTo) => {
|
||||||
|
var range = '';
|
||||||
|
if (propertySchema.minimum && propertySchema.maximum) {
|
||||||
|
range += propertySchema.exclusiveMinimum ? '( ' : '[ ';
|
||||||
|
range += propertySchema.minimum;
|
||||||
|
range += ' .. ';
|
||||||
|
range += propertySchema.maximum;
|
||||||
|
range += propertySchema.exclusiveMaximum ? ' )' : ' ]';
|
||||||
|
} else if (propertySchema.maximum) {
|
||||||
|
range += propertySchema.exclusiveMaximum? '< ' : '<= ';
|
||||||
|
range += propertySchema.maximum;
|
||||||
|
} else if (propertySchema.minimum) {
|
||||||
|
range += propertySchema.exclusiveMinimum ? '> ' : '>= ';
|
||||||
|
range += propertySchema.minimum;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (range) {
|
||||||
|
injectTo._range = range;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
|
@ -27,7 +27,7 @@ export default class ParamsList extends BaseComponent {
|
||||||
paramsList = paramsList.map((paramData) => {
|
paramsList = paramsList.map((paramData) => {
|
||||||
let propPointer = paramData._pointer;
|
let propPointer = paramData._pointer;
|
||||||
if (paramData.in === 'body') return paramData;
|
if (paramData.in === 'body') return paramData;
|
||||||
return JsonSchema.injectPropData(paramData, paramData.name, propPointer);
|
return JsonSchema.injectPropertyData(paramData, paramData.name, propPointer);
|
||||||
});
|
});
|
||||||
|
|
||||||
let paramsMap = this.orderParams(paramsList);
|
let paramsMap = this.orderParams(paramsList);
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
{
|
{
|
||||||
"name": "redoc",
|
"name": "redoc",
|
||||||
"description": "Swagger-generated API Reference Documentation",
|
"description": "Swagger-generated API Reference Documentation",
|
||||||
"version": "0.7.3",
|
"version": "0.7.4",
|
||||||
"repository": {
|
"repository": {
|
||||||
"type": "git",
|
"type": "git",
|
||||||
"url": "git://github.com/Rebilly/ReDoc"
|
"url": "git://github.com/Rebilly/ReDoc"
|
||||||
|
|
Loading…
Reference in New Issue
Block a user