develop #21
|
@ -1,4 +1,9 @@
|
|||
# Changelog
|
||||
## [0.11.2] - 2025-4-16
|
||||
### Fixed
|
||||
- Se ha corregido un error en la actualizacion del estado de los pcs en la vista tarjetas.
|
||||
|
||||
---
|
||||
## [0.11.1] - 2025-4-16
|
||||
### Improved
|
||||
- Nuevos campos en la tabla de clientes. Tipo de firmware y mac.
|
||||
|
|
|
@ -198,8 +198,8 @@
|
|||
<mat-icon>delete</mat-icon>
|
||||
<span>{{ 'delete' | translate }}</span>
|
||||
</button>
|
||||
<app-execute-command [clientData]="selection.selected" [buttonType]="'menu-item'"
|
||||
[buttonText]="'Ejecutar comandos'" [icon]="'terminal'" [disabled]="selection.selected.length === 0">
|
||||
<app-execute-command [clientData]="selectedNode?.clients || []" [buttonType]="'menu-item'"
|
||||
[buttonText]="'Ejecutar comandos'" [icon]="'terminal'" [disabled]="!((selectedNode?.clients ?? []).length > 0)">
|
||||
</app-execute-command>
|
||||
</mat-menu>
|
||||
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
import { Component, OnInit, OnDestroy, ViewChild, QueryList, ViewChildren } from '@angular/core';
|
||||
import {Component, OnInit, OnDestroy, ViewChild, QueryList, ViewChildren, ChangeDetectorRef} from '@angular/core';
|
||||
import { HttpClient, HttpParams } from '@angular/common/http';
|
||||
import { Router } from '@angular/router';
|
||||
import { MatDialog } from '@angular/material/dialog';
|
||||
|
@ -110,7 +110,8 @@ export class GroupsComponent implements OnInit, OnDestroy {
|
|||
private joyrideService: JoyrideService,
|
||||
private breakpointObserver: BreakpointObserver,
|
||||
private toastr: ToastrService,
|
||||
private configService: ConfigService
|
||||
private configService: ConfigService,
|
||||
private cd: ChangeDetectorRef,
|
||||
) {
|
||||
this.baseUrl = this.configService.apiUrl;
|
||||
this.mercureUrl = this.configService.mercureUrl;
|
||||
|
@ -175,23 +176,35 @@ export class GroupsComponent implements OnInit, OnDestroy {
|
|||
})
|
||||
}
|
||||
|
||||
private updateClientStatus(clientUuid: string, newStatus: string): void {
|
||||
const clientIndex = this.selectedClients.data.findIndex(client => client['@id'] === clientUuid);
|
||||
private updateClientStatus(clientUuid: string, status: string): void {
|
||||
let updated = false;
|
||||
|
||||
if (clientIndex !== -1) {
|
||||
const index = this.arrayClients.findIndex(client => client['@id'] === clientUuid);
|
||||
if (index !== -1) {
|
||||
const updatedClient = {...this.arrayClients[index], status};
|
||||
this.arrayClients = [
|
||||
...this.arrayClients.slice(0, index),
|
||||
updatedClient,
|
||||
...this.arrayClients.slice(index + 1)
|
||||
];
|
||||
updated = true;
|
||||
}
|
||||
|
||||
const tableIndex = this.selectedClients.data.findIndex(client => client['@id'] === clientUuid);
|
||||
|
||||
if (tableIndex !== -1) {
|
||||
const updatedClients = [...this.selectedClients.data];
|
||||
|
||||
updatedClients[clientIndex] = {
|
||||
...updatedClients[clientIndex],
|
||||
status: newStatus
|
||||
updatedClients[tableIndex] = {
|
||||
...updatedClients[tableIndex],
|
||||
status: status
|
||||
};
|
||||
|
||||
this.selectedClients.data = updatedClients;
|
||||
this.arrayClients = updatedClients;
|
||||
}
|
||||
|
||||
console.log(`Estado actualizado para el cliente ${clientUuid}: ${newStatus}`);
|
||||
} else {
|
||||
console.warn(`Cliente con UUID ${clientUuid} no encontrado en la lista.`);
|
||||
if (updated) {
|
||||
this.cd.detectChanges();
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -388,6 +401,9 @@ export class GroupsComponent implements OnInit, OnDestroy {
|
|||
this.http.get<any>(`${this.baseUrl}/clients?organizationalUnit.id=${node.id}&page=${this.page + 1}&itemsPerPage=${this.itemsPerPage}`, { params }).subscribe({
|
||||
next: (response: any) => {
|
||||
this.selectedClients.data = response['hydra:member'];
|
||||
if (this.selectedNode) {
|
||||
this.selectedNode.clients = response['hydra:member'];
|
||||
}
|
||||
this.length = response['hydra:totalItems'];
|
||||
this.arrayClients = this.selectedClients.data;
|
||||
this.hasClients = this.selectedClients.data.length > 0;
|
||||
|
|
|
@ -60,7 +60,7 @@ export class RepositoriesComponent implements OnInit {
|
|||
cell: (repository: any) => `${this.datePipe.transform(repository.createdAt, 'dd/MM/yyyy hh:mm:ss')}`
|
||||
}
|
||||
];
|
||||
isGitModuleInstalled: boolean = true;
|
||||
isGitModuleInstalled: boolean = false;
|
||||
displayedColumns: string[] = ['id', 'name', 'ip', 'user', 'images', 'createdAt', 'actions'];
|
||||
|
||||
constructor(
|
||||
|
|
|
@ -10,7 +10,7 @@
|
|||
</div>
|
||||
<div class="images-button-row">
|
||||
<button class="action-button" (click)="openImageInfoDialog()">Ver Información</button>
|
||||
<button class="action-button" (click)="syncRepository()">Sincronizar base de datos</button>
|
||||
<button disabled class="action-button" (click)="syncRepository()">Sincronizar base de datos</button>
|
||||
<button class="action-button" (click)="importImage()">
|
||||
{{ 'importImageButton' | translate }}
|
||||
</button>
|
||||
|
|
Loading…
Reference in New Issue