]> git.immae.eu Git - github/Chocobozzz/PeerTube.git/blame - client/src/app/shared/buttons/action-dropdown.component.html
add scope tags and aria-labels to instance table (#2866)
[github/Chocobozzz/PeerTube.git] / client / src / app / shared / buttons / action-dropdown.component.html
CommitLineData
9b4241e3 1<div class="dropdown-root" ngbDropdown [placement]="placement" [container]="container" *ngIf="areActionsDisplayed(actions, entry)">
791645e6 2 <div
3a0fb65c 3 class="action-button" [ngClass]="{ small: buttonSize === 'small', grey: theme === 'grey', orange: theme === 'orange', 'button-styled': buttonStyled }"
791645e6
C
4 ngbDropdownToggle role="button"
5 >
3a0fb65c
C
6 <my-global-icon *ngIf="!label && buttonDirection === 'horizontal'" class="more-icon" iconName="more-horizontal"></my-global-icon>
7 <my-global-icon *ngIf="!label && buttonDirection === 'vertical'" class="more-icon" iconName="more-vertical"></my-global-icon>
8
791645e6 9 <span *ngIf="label" class="dropdown-toggle">{{ label }}</span>
eacb25c4
C
10 </div>
11
141b177d 12 <div ngbDropdownMenu class="dropdown-menu">
f97c91f7 13 <ng-container *ngFor="let actions of getActions()">
eacb25c4 14
f97c91f7
C
15 <ng-container *ngFor="let action of actions">
16 <ng-container *ngIf="action.isDisplayed === undefined || action.isDisplayed(entry) === true">
f97c91f7 17
9b82d49d 18 <ng-template #templateActionLabel let-action>
3a0fb65c 19 <my-global-icon *ngIf="action.iconName" [iconName]="action.iconName" [ngClass]="'icon-' + action.iconName"></my-global-icon>
f0ad4710 20
9b82d49d
RK
21 <div class="d-flex flex-column">
22 <span i18n>{{ action.label }}</span>
23 <small class="text-muted" *ngIf="action.description">{{ action.description }}</small>
24 </div>
25 </ng-template>
26
bb152476
RK
27 <a
28 *ngIf="action.linkBuilder && !action.isHeader" [ngClass]="{ 'with-icon': !!action.iconName }"
29 class="dropdown-item" [routerLink]="action.linkBuilder(entry)" [title]="action.title || ''"
30 >
9b82d49d 31 <ng-container *ngTemplateOutlet="templateActionLabel; context:{ $implicit: action }"></ng-container>
3a0fb65c
C
32 </a>
33
34 <span
bb152476
RK
35 *ngIf="!action.linkBuilder && !action.isHeader" [ngClass]="{ 'with-icon': !!action.iconName }"
36 class="custom-action dropdown-item" role="button" [title]="action.title || ''" (click)="action.handler(entry)"
3a0fb65c 37 >
9b82d49d 38 <ng-container *ngTemplateOutlet="templateActionLabel; context:{ $implicit: action }"></ng-container>
f97c91f7 39 </span>
3a0fb65c 40
bb152476
RK
41 <h6
42 *ngIf="!action.linkBuilder && action.isHeader" [ngClass]="{ 'with-icon': !!action.iconName }"
43 class="dropdown-header" role="button" [title]="action.title || ''" (click)="action.handler(entry)"
44 >
45 <ng-container *ngTemplateOutlet="templateActionLabel; context:{ $implicit: action }"></ng-container>
46 </h6>
47
f97c91f7 48 </ng-container>
af5767ff 49 </ng-container>
f97c91f7 50
3a0fb65c 51 <div *ngIf="areActionsDisplayed(actions, entry)" class="dropdown-divider"></div>
f97c91f7 52
141b177d
C
53 </ng-container>
54 </div>
f97c91f7 55</div>