61 lines
2.8 KiB
HTML
61 lines
2.8 KiB
HTML
<div class="header-container">
|
|
<h2 class="title" i18n="@@adminImagesTitle">Administrar calendarios</h2>
|
|
<div class="calendar-button-row">
|
|
<button mat-flat-button color="primary" (click)="addImage()">Añadir calendario</button>
|
|
</div>
|
|
</div>
|
|
<mat-divider class="divider"></mat-divider>
|
|
<div class="search-container">
|
|
<mat-form-field appearance="fill" class="search-string">
|
|
<mat-label i18n="@@searchLabel">Buscar nombre de calendario</mat-label>
|
|
<input matInput placeholder="Búsqueda" [(ngModel)]="filters['name']" (keyup.enter)="search()" i18n-placeholder="@@searchPlaceholder">
|
|
<mat-icon matSuffix>search</mat-icon>
|
|
<mat-hint i18n="@@searchHint">Pulsar 'enter' para buscar</mat-hint>
|
|
</mat-form-field>
|
|
</div>
|
|
|
|
<div *ngIf="loading" class="loading-container">
|
|
<mat-spinner></mat-spinner>
|
|
</div>
|
|
|
|
<div *ngIf="!loading">
|
|
<table mat-table [dataSource]="dataSource" class="mat-elevation-z8">
|
|
<ng-container *ngFor="let column of columns" [matColumnDef]="column.columnDef">
|
|
<th mat-header-cell *matHeaderCellDef> {{ column.header }} </th>
|
|
<td mat-cell *matCellDef="let image" >
|
|
<ng-container *ngIf="column.columnDef === 'isDefault' || column.columnDef === 'installed'">
|
|
<mat-icon [color]="image[column.columnDef] ? 'primary' : 'warn'">
|
|
{{ image[column.columnDef] ? 'check_circle' : 'cancel' }}
|
|
</mat-icon>
|
|
</ng-container>
|
|
|
|
<ng-container *ngIf="column.columnDef !== 'isDefault' && column.columnDef !== 'installed' && column.columnDef !== 'downloadUrl'">
|
|
{{ column.cell(image) }}
|
|
</ng-container>
|
|
</td>
|
|
</ng-container>
|
|
|
|
<ng-container matColumnDef="actions">
|
|
<th mat-header-cell *matHeaderCellDef i18n="@@columnActions" style="text-align: center;">Acciones</th>
|
|
<td mat-cell *matCellDef="let calendar" style="text-align: center;">
|
|
<button mat-icon-button color="primary" (click)="editCalendar(calendar)" i18n="@@editImage"> <mat-icon>edit</mat-icon></button>
|
|
<button *ngIf="!syncUds" mat-icon-button color="primary" (click)="sync(calendar)"><mat-icon>sync</mat-icon></button>
|
|
<button *ngIf="syncUds" mat-icon-button color="primary"><mat-spinner diameter="24"></mat-spinner></button>
|
|
<button mat-icon-button color="warn" (click)="deleteCalendar(calendar)" i18n="@@buttonDelete"><mat-icon>delete</mat-icon></button>
|
|
</td>
|
|
</ng-container>
|
|
|
|
<tr mat-header-row *matHeaderRowDef="displayedColumns"></tr>
|
|
<tr mat-row *matRowDef="let row; columns: displayedColumns;"></tr>
|
|
</table>
|
|
</div>
|
|
|
|
<div class="paginator-container">
|
|
<mat-paginator [length]="length"
|
|
[pageSize]="itemsPerPage"
|
|
[pageIndex]="page"
|
|
[pageSizeOptions]="pageSizeOptions"
|
|
(page)="onPageChange($event)">
|
|
</mat-paginator>
|
|
</div>
|