File

projects/cobbler-frontend/src/app/items/repository/overview/repository-overview.component.ts

Implements

OnInit OnDestroy

Metadata

Index

Properties
Methods

Constructor

constructor(userService: UserService, cobblerApiService: CobblerApiService, _snackBar: MatSnackBar, router: Router, dialog: MatDialog)
Parameters :
Name Type Optional
userService UserService No
cobblerApiService CobblerApiService No
_snackBar MatSnackBar No
router Router No
dialog MatDialog No

Methods

addRepository
addRepository()
Returns : void
deleteRepository
deleteRepository(uid: string, name: string)
Parameters :
Name Type Optional
uid string No
name string No
Returns : void
ngOnDestroy
ngOnDestroy()
Returns : void
ngOnInit
ngOnInit()
Returns : void
renameRepository
renameRepository(uid: string, name: string)
Parameters :
Name Type Optional
uid string No
name string No
Returns : void
Private retrieveRepositories
retrieveRepositories()
Returns : void
showRepository
showRepository(uid: string, name: string)
Parameters :
Name Type Optional
uid string No
name string No
Returns : void

Properties

dataSource
Type : Array<Repo>
Default value : []
displayedColumns
Type : string[]
Default value : ['name', 'breed', 'mirror_type', 'actions']
Private ngUnsubscribe
Default value : new Subject<void>()
table
Type : MatTable<Repo>
Decorators :
@ViewChild(MatTable)
Public userService
Type : UserService
import { Component, Inject, OnDestroy, OnInit, ViewChild } from '@angular/core';
import { MatButtonModule } from '@angular/material/button';
import { MatDialog } from '@angular/material/dialog';
import { MatIconModule } from '@angular/material/icon';
import { MatMenuModule } from '@angular/material/menu';
import { MatSnackBar } from '@angular/material/snack-bar';
import { MatTable, MatTableModule } from '@angular/material/table';
import { MatTooltipModule } from '@angular/material/tooltip';
import { Router } from '@angular/router';
import { CobblerApiService, Repo } from 'cobbler-api';
import { Subject } from 'rxjs';
import { takeUntil } from 'rxjs/operators';
import { DialogItemRenameComponent } from '../../../common/dialog-item-rename/dialog-item-rename.component';
import { UserService } from '../../../services/user.service';
import Utils from '../../../utils';
import { RepositoryCreateComponent } from '../create/repository-create.component';

@Component({
  selector: 'cobbler-repository-overview',
  standalone: true,
  imports: [
    MatTableModule,
    MatIconModule,
    MatButtonModule,
    MatMenuModule,
    MatTooltipModule,
  ],
  templateUrl: './repository-overview.component.html',
  styleUrl: './repository-overview.component.scss',
})
export class RepositoryOverviewComponent implements OnInit, OnDestroy {
  // Unsubscribe
  private ngUnsubscribe = new Subject<void>();

  // Table
  displayedColumns: string[] = ['name', 'breed', 'mirror_type', 'actions'];
  dataSource: Array<Repo> = [];

  @ViewChild(MatTable) table: MatTable<Repo>;

  constructor(
    public userService: UserService,
    private cobblerApiService: CobblerApiService,
    private _snackBar: MatSnackBar,
    private router: Router,
    @Inject(MatDialog) readonly dialog: MatDialog,
  ) {}

  ngOnInit(): void {
    this.retrieveRepositories();
  }

  ngOnDestroy(): void {
    this.ngUnsubscribe.next();
    this.ngUnsubscribe.complete();
  }

  private retrieveRepositories(): void {
    this.cobblerApiService
      .get_repos()
      .pipe(takeUntil(this.ngUnsubscribe))
      .subscribe({
        next: (value) => {
          this.dataSource = value;
        },
        error: (error) => {
          // HTML encode the error message since it originates from XML
          this._snackBar.open(Utils.toHTML(error.message), 'Close');
        },
      });
  }

  addRepository(): void {
    const dialogRef = this.dialog.open(RepositoryCreateComponent, {
      width: '40%',
    });
    dialogRef.afterClosed().subscribe((result) => {
      if (typeof result === 'string') {
        this.router.navigate(['/items', 'repository', result]);
      }
    });
  }

  showRepository(uid: string, name: string): void {
    this.router.navigate(['/items', 'repository', name]);
  }

  renameRepository(uid: string, name: string): void {
    const dialogRef = this.dialog.open(DialogItemRenameComponent, {
      data: {
        itemType: 'Repository',
        itemName: name,
        itemUid: uid,
      },
    });

    dialogRef.afterClosed().subscribe((newItemName) => {
      if (newItemName === undefined) {
        // Cancel means we don't need to rename the repository
        return;
      }
      this.cobblerApiService
        .get_repo_handle(name, this.userService.token)
        .pipe(takeUntil(this.ngUnsubscribe))
        .subscribe({
          next: (repoHandle) => {
            this.cobblerApiService
              .rename_repo(repoHandle, newItemName, this.userService.token)
              .pipe(takeUntil(this.ngUnsubscribe))
              .subscribe({
                next: (value) => {
                  this.retrieveRepositories();
                },
                error: (error) => {
                  // HTML encode the error message since it originates from XML
                  this._snackBar.open(Utils.toHTML(error.message), 'Close');
                },
              });
          },
          error: (error) => {
            // HTML encode the error message since it originates from XML
            this._snackBar.open(Utils.toHTML(error.message), 'Close');
          },
        });
    });
  }

  deleteRepository(uid: string, name: string): void {
    this.cobblerApiService
      .remove_repo(name, this.userService.token, false)
      .pipe(takeUntil(this.ngUnsubscribe))
      .subscribe({
        next: (value) => {
          this.retrieveRepositories();
        },
        error: (error) => {
          // HTML encode the error message since it originates from XML
          this._snackBar.open(Utils.toHTML(error.message), 'Close');
        },
      });
  }
}
<div class="title-table">
  <div class="title-row">
    <h1 class="title title-cell-text">REPOSITORIES</h1>
    <span class="title-cell-button">
      <button
        mat-icon-button
        (click)="this.addRepository()"
        matTooltip="Add Repository"
      >
        <mat-icon>add</mat-icon>
      </button></span
    >
  </div>
</div>

<table mat-table [dataSource]="dataSource" class="mat-elevation-z8">
  <!-- Name Column -->
  <ng-container matColumnDef="name">
    <th mat-header-cell *matHeaderCellDef>Name</th>
    <td mat-cell *matCellDef="let element">{{ element.name }}</td>
  </ng-container>

  <!-- Breed Column -->
  <ng-container matColumnDef="breed">
    <th mat-header-cell *matHeaderCellDef>Breed</th>
    <td mat-cell *matCellDef="let element">{{ element.breed }}</td>
  </ng-container>

  <!-- mirror_type Column -->
  <ng-container matColumnDef="mirror_type">
    <th mat-header-cell *matHeaderCellDef>Mirror Type</th>
    <td mat-cell *matCellDef="let element">{{ element.mirror_type }}</td>
  </ng-container>

  <ng-container matColumnDef="actions">
    <th mat-header-cell *matHeaderCellDef></th>
    <td mat-cell *matCellDef="let element">
      <button mat-icon-button [matMenuTriggerFor]="menu">
        <mat-icon>more_vert</mat-icon>
      </button>
      <mat-menu #menu="matMenu">
        <button
          mat-menu-item
          (click)="showRepository(element.uid, element.name)"
        >
          <mat-icon>visibility</mat-icon>
          <span>Show details</span>
        </button>
        <button
          mat-menu-item
          (click)="renameRepository(element.uid, element.name)"
        >
          <mat-icon>edit</mat-icon>
          <span>Rename</span>
        </button>
        <button
          mat-menu-item
          (click)="deleteRepository(element.uid, element.name)"
        >
          <mat-icon>delete</mat-icon>
          <span>Delete</span>
        </button>
      </mat-menu>
    </td>
  </ng-container>

  <tr mat-header-row *matHeaderRowDef="displayedColumns"></tr>
  <tr mat-row *matRowDef="let row; columns: displayedColumns"></tr>
</table>
Legend
Html element
Component
Html element with directive

results matching ""

    No results matching ""