91 lines
5.0 KiB
HTML
91 lines
5.0 KiB
HTML
<mat-accordion class="example-headers-align">
|
|
<mat-expansion-panel hideToggle>
|
|
<mat-expansion-panel-header joyrideStep="serverInfoStep" text="Accede a información y opciones de sincronización en el servidor OgBoot.">
|
|
<mat-panel-title> Información en servidor ogBoot </mat-panel-title>
|
|
</mat-expansion-panel-header>
|
|
<div class="example-button-row">
|
|
<button mat-flat-button color="primary" (click)="syncTemplates()" > Sincronizar base de datos</button>
|
|
</div>
|
|
<div class="example-button-row">
|
|
<button mat-flat-button color="accent" (click)="openSubnetInfoDialog()">Ver Información</button>
|
|
</div>
|
|
</mat-expansion-panel>
|
|
</mat-accordion>
|
|
|
|
<div class="header-container">
|
|
<button mat-icon-button color="primary" (click)="iniciarTour()">
|
|
<mat-icon>help</mat-icon>
|
|
</button>
|
|
<h2 class="title" i18n="@@adminPXETitle" joyrideStep="titleStep" text="Desde aquí puedes gestionar las plantillas PXE configuradas en el servidor OgBoot.">Administrar plantillas PXE</h2>
|
|
<div class="pxe-button-row">
|
|
<button mat-flat-button color="primary" (click)="addPxeTemplate()" joyrideStep="addTemplateStep" text="Haz clic para añadir una nueva plantilla PXE.">Añadir plantilla PXE</button>
|
|
</div>
|
|
</div>
|
|
|
|
<mat-divider class="divider"></mat-divider>
|
|
|
|
<div class="search-container">
|
|
<mat-form-field appearance="fill" class="search-string" joyrideStep="searchNameStep" text="Busca plantillas PXE por nombre para localizar rápidamente una plantilla específica.">
|
|
<mat-label i18n="@@searchLabel">Buscar nombre de plantilla</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>
|
|
<mat-form-field appearance="fill" class="search-boolean" joyrideStep="searchSyncStep" text="Filtra para ver solo las plantillas creadas en el servidor OgBoot.">
|
|
<mat-label i18n="@@searchLabel">Creada en ogBoot</mat-label>
|
|
<mat-select [(ngModel)]="filters['synchronized']" (selectionChange)="search()" placeholder="Seleccionar opción">
|
|
<mat-option [value]="''">Todos</mat-option>
|
|
<mat-option [value]="true">Sí</mat-option>
|
|
<mat-option [value]="false">No</mat-option>
|
|
</mat-select>
|
|
</mat-form-field>
|
|
</div>
|
|
|
|
<table mat-table [dataSource]="dataSource" class="mat-elevation-z8" joyrideStep="tableStep" text="Aquí se muestra la lista de plantillas PXE disponibles para administrar.">
|
|
<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 === 'synchronized'">
|
|
<mat-icon [color]="image[column.columnDef] ? 'primary' : 'warn'">
|
|
{{ image[column.columnDef] ? 'check_circle' : 'cancel' }}
|
|
</mat-icon>
|
|
</ng-container>
|
|
|
|
<ng-container *ngIf="column.columnDef !== 'synchronized'">
|
|
{{ 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 template" style="text-align: center;" joyrideStep="actionsStep" text="Gestiona cada plantilla PXE con opciones para ver, editar, eliminar y más.">
|
|
<button mat-icon-button color="info" (click)="showTemplate($event, template)"><mat-icon i18n="@@deleteElementTooltip">visibility</mat-icon></button>
|
|
<button mat-icon-button color="info" [disabled]="template.clientsLength === 0" (click)="editClients($event, template)"><mat-icon i18n="@@deleteElementTooltip">computer</mat-icon></button>
|
|
<button mat-icon-button color="primary" (click)="editPxeTemplate(template)" i18n="@@editImage"><mat-icon>edit</mat-icon></button>
|
|
<button mat-icon-button [matMenuTriggerFor]="menu">
|
|
<mat-icon>menu</mat-icon>
|
|
</button>
|
|
|
|
<mat-menu #menu="matMenu">
|
|
<button mat-menu-item (click)="toggleAction(template, 'create')">Crear en servidor ogBoot</button>
|
|
<button mat-menu-item (click)="addClientsToPxe(template)">Añadir cliente</button>
|
|
<button mat-menu-item (click)="toggleAction(template, 'sync')">Sincronizar base de datos</button>
|
|
<button mat-menu-item (click)="toggleAction(template, 'delete')">Eliminar</button>
|
|
</mat-menu>
|
|
</td>
|
|
</ng-container>
|
|
|
|
<tr mat-header-row *matHeaderRowDef="displayedColumns"></tr>
|
|
<tr mat-row *matRowDef="let row; columns: displayedColumns;"></tr>
|
|
</table>
|
|
|
|
<div class="paginator-container" joyrideStep="paginationStep" text="Navega entre las páginas de plantillas PXE usando el paginador.">
|
|
<mat-paginator [length]="length"
|
|
[pageSize]="itemsPerPage"
|
|
[pageIndex]="page"
|
|
[pageSizeOptions]="pageSizeOptions"
|
|
(page)="onPageChange($event)">
|
|
</mat-paginator>
|
|
</div>
|