mirror of
https://github.com/Redocly/redoc.git
synced 2024-11-23 17:13:44 +03:00
58 lines
1.4 KiB
TypeScript
58 lines
1.4 KiB
TypeScript
'use strict';
|
|
import { Component, Input, OnInit, ChangeDetectionStrategy } from '@angular/core';
|
|
import { BaseComponent, SpecManager } from '../base';
|
|
import { MenuService } from '../../services/index';
|
|
|
|
@Component({
|
|
selector: 'operations-list',
|
|
templateUrl: './operations-list.html',
|
|
styleUrls: ['./operations-list.css'],
|
|
changeDetection: ChangeDetectionStrategy.OnPush
|
|
})
|
|
export class OperationsList extends BaseComponent implements OnInit {
|
|
@Input() pointer:string;
|
|
|
|
tags:Array<any> = [];
|
|
|
|
constructor(specMgr:SpecManager, private menu: MenuService) {
|
|
super(specMgr);
|
|
}
|
|
|
|
init() {
|
|
let flatMenuItems = this.menu.flatItems;
|
|
this.tags = [];
|
|
let emptyTag = {
|
|
name: '',
|
|
items: []
|
|
};
|
|
flatMenuItems.forEach(menuItem => {
|
|
// skip items that are not bound to swagger tags/operations
|
|
if (!menuItem.metadata) return;
|
|
|
|
if (menuItem.metadata.type === 'tag') {
|
|
this.tags.push({
|
|
...menuItem,
|
|
anchor: this.buildAnchor(menuItem.id)
|
|
});
|
|
}
|
|
if (menuItem.metadata.type === 'operation' && !menuItem.parent) {
|
|
emptyTag.items.push(menuItem);
|
|
}
|
|
});
|
|
if (emptyTag.items.length) this.tags.push(emptyTag);
|
|
}
|
|
|
|
buildAnchor(tagId):string {
|
|
return this.menu.hashFor(tagId,
|
|
{ type: 'tag'});
|
|
}
|
|
|
|
trackByTagName(_, el) {
|
|
return el.name;
|
|
}
|
|
|
|
ngOnInit() {
|
|
this.preinit();
|
|
}
|
|
}
|