mirror of
				https://github.com/Redocly/redoc.git
				synced 2025-11-04 09:47:31 +03:00 
			
		
		
		
	
		
			
				
	
	
		
			108 lines
		
	
	
		
			5.5 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
			
		
		
	
	
			108 lines
		
	
	
		
			5.5 KiB
		
	
	
	
		
			HTML
		
	
	
	
	
	
<ng-container [ngSwitch]="schema._widgetType">
 | 
						|
  <ng-template ngSwitchCase="file">
 | 
						|
    <span class="param-wrap">
 | 
						|
      <span class="param-type-file">file</span>
 | 
						|
      <div *ngIf="schema._produces && !isRequestSchema" class="file produces">
 | 
						|
        <ul>
 | 
						|
          <li *ngFor="let type of schema._produces">{{type}}</li>
 | 
						|
        </ul>
 | 
						|
      </div>
 | 
						|
      <div *ngIf="schema._consumes && isRequestSchema" class="file consume">
 | 
						|
        <ul>
 | 
						|
          <li *ngFor="let type of schema._consumes">{{type}}</li>
 | 
						|
        </ul>
 | 
						|
      </div>
 | 
						|
    </span>
 | 
						|
  </ng-template>
 | 
						|
  <ng-template ngSwitchCase="trivial">
 | 
						|
    <span class="param-wrap">
 | 
						|
      <span class="param-type param-type-trivial {{schema.type}}"
 | 
						|
        [ngClass]="{'with-hint': schema._displayTypeHint, 'array': _isArray}"
 | 
						|
        title="{{schema._displayTypeHint}}">{{schema._displayType}} {{schema._displayFormat}}
 | 
						|
        <span class="param-range" *ngIf="schema._range"> {{schema._range}} </span>
 | 
						|
      </span>
 | 
						|
      <span *ngIf="schema['x-nullable']" class="param-nullable">Nullable</span>
 | 
						|
      <div *ngIf="schema.enum" class="param-enum">
 | 
						|
        <span *ngFor="let enumItem of schema.enum" class="param-enum-value {{enumItem.type}}"> {{enumItem.val | json}} </span>
 | 
						|
      </div>
 | 
						|
      <span *ngIf="schema.pattern" class="param-pattern">{{schema.pattern}}</span>
 | 
						|
    </span>
 | 
						|
  </ng-template>
 | 
						|
  <ng-template ngSwitchCase="tuple">
 | 
						|
    <div class="params-wrap params-array array-tuple">
 | 
						|
      <ng-template ngFor [ngForOf]="schema.items" let-item="$implicit" let-idx="index" [ngForTrackBy]="trackByIdx">
 | 
						|
        <div class="tuple-item">
 | 
						|
          <span class="tuple-item-index"> [{{idx}}]: </span>
 | 
						|
          <json-schema class="nested-schema" [pointer]="item._pointer"
 | 
						|
          [absolutePointer]="item._pointer"
 | 
						|
          [nestOdd]="!nestOdd" [isRequestSchema]="isRequestSchema">
 | 
						|
          </json-schema>
 | 
						|
        </div>
 | 
						|
      </ng-template>
 | 
						|
    </div>
 | 
						|
  </ng-template>
 | 
						|
  <ng-template ngSwitchCase="array">
 | 
						|
    <json-schema class="nested-schema" [pointer]="schema._pointer"
 | 
						|
    [nestOdd]="!nestOdd" [isRequestSchema]="isRequestSchema"> </json-schema>
 | 
						|
  </ng-template>
 | 
						|
  <ng-template ngSwitchCase="object">
 | 
						|
    <table class="params-wrap" [ngClass]="{'params-array': _isArray}">
 | 
						|
      <!-- <caption> {{_displayType}} </caption> -->
 | 
						|
      <ng-template ngFor [ngForOf]="properties" let-prop="$implicit" let-last="last" [ngForTrackBy]="trackByName">
 | 
						|
        <tr class="param"
 | 
						|
            [class.last]="last"
 | 
						|
            [class.discriminator] = "prop.isDiscriminator"
 | 
						|
            [class.complex] = "prop._pointer"
 | 
						|
            [class.additional] = "prop._additional"
 | 
						|
            [class.expanded] = "subSchema.open">
 | 
						|
          <td class="param-name">
 | 
						|
            <span class="param-name-wrap" (click)="subSchema.toggle()">
 | 
						|
              <span class="param-name-content">
 | 
						|
                {{prop.name}}
 | 
						|
                <span class="param-name-enumvalue" [hidden]="!prop._enumItem"> {{prop._enumItem?.val | json}} </span>
 | 
						|
              </span>
 | 
						|
              <svg *ngIf="prop._pointer" xmlns="http://www.w3.org/2000/svg" version="1.1" x="0" y="0" viewBox="0 0 24 24" xml:space="preserve">
 | 
						|
                <polygon points="17.3 8.3 12 13.6 6.7 8.3 5.3 9.7 12 16.4 18.7 9.7 "/>
 | 
						|
              </svg>
 | 
						|
            </span>
 | 
						|
          </td>
 | 
						|
          <td class="param-info">
 | 
						|
            <div>
 | 
						|
              <span class="param-type {{prop.type}}" [ngClass]="{'with-hint': prop._displayTypeHint, 'tuple': prop._isTuple, 'array': (prop._isArray || prop.type == 'array')}"
 | 
						|
              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['x-nullable']" class="param-nullable">Nullable</span>
 | 
						|
              <div class="param-default" *ngIf="prop.default != null">
 | 
						|
                <span class="param-default-value">{{prop.default | json}}</span>
 | 
						|
              </div>
 | 
						|
              <div *ngIf="prop.enum && !prop.isDiscriminator" class="param-enum">
 | 
						|
                <span *ngFor="let enumItem of prop.enum" class="param-enum-value {{enumItem.type}}"> {{enumItem.val | json}} </span>
 | 
						|
              </div>
 | 
						|
              <span *ngIf="prop.pattern" class="param-pattern">{{prop.pattern}}</span>
 | 
						|
            </div>
 | 
						|
            <div class="param-description" [innerHtml]="prop.description | marked"></div>
 | 
						|
            <div class="discriminator-info" *ngIf="prop.isDiscriminator && descendants.length">
 | 
						|
              <drop-down (change)="selectDescendantByIdx($event)" [active]="activeDescendant.idx">
 | 
						|
                <option *ngFor="let descendant of descendants; let i=index"
 | 
						|
                [value]="i" [attr.selected]="descendant.active ? '' : null" >{{descendant.name}}</option>
 | 
						|
              </drop-down>
 | 
						|
            </div>
 | 
						|
          </td>
 | 
						|
        </tr>
 | 
						|
        <tr class="param-schema" [ngClass]="{'last': last}" [hidden]="!prop._pointer">
 | 
						|
          <td colspan="2">
 | 
						|
            <zippy [attr.disabled]="prop.name" #subSchema title="Expand" [headless]="true" (openChange)="lazySchema.load()" [(open)]="prop.expanded">
 | 
						|
              <json-schema-lazy #lazySchema [auto]="prop.expanded" class="nested-schema" [pointer]="prop._pointer"
 | 
						|
              [nestOdd]="!nestOdd" [isRequestSchema]="isRequestSchema" absolutePointer="{{absolutePointer}}/properties/{{prop.name}}">
 | 
						|
              </json-schema-lazy>
 | 
						|
            </zippy>
 | 
						|
          </td>
 | 
						|
        </tr>
 | 
						|
      </ng-template>
 | 
						|
    </table>
 | 
						|
  </ng-template>
 | 
						|
 | 
						|
</ng-container>
 |