Chore: Removed Mat Card from everywhere.

Chore: Removed the Toaster Service.
Chore: Updated to Material Theme 3
This commit is contained in:
2025-07-11 11:30:35 +00:00
parent 5c1c474e93
commit 88a1572747
117 changed files with 2895 additions and 3236 deletions

View File

@ -1,33 +1,28 @@
<mat-card class="flex-auto lg:max-w-[50%]">
<mat-card-header>
<mat-card-title>Regime</mat-card-title>
</mat-card-header>
<mat-card-content>
<form [formGroup]="form" class="flex flex-col">
<div class="row-container">
<mat-form-field class="flex-auto">
<mat-label>Name</mat-label>
<input matInput #nameElement formControlName="name" (keyup.enter)="save()" />
</mat-form-field>
</div>
<div class="row-container">
<mat-form-field class="flex-auto">
<mat-label>Header</mat-label>
<textarea matInput formControlName="header"></textarea>
</mat-form-field>
</div>
<div class="row-container">
<mat-form-field class="flex-auto">
<mat-label>Prefix</mat-label>
<input matInput formControlName="prefix" />
</mat-form-field>
</div>
</form>
</mat-card-content>
<mat-card-actions class="row-container">
<button mat-raised-button [disabled]="item.isFixture" color="primary" class="" (click)="save()">Save</button>
@if (!!item.id) {
<button mat-raised-button [disabled]="item.isFixture" color="warn" (click)="confirmDelete()">Delete</button>
}
</mat-card-actions>
</mat-card>
<h2>Regime</h2>
<form [formGroup]="form" class="flex flex-col">
<div class="row-container">
<mat-form-field class="flex-auto">
<mat-label>Name</mat-label>
<input matInput #nameElement formControlName="name" (keyup.enter)="save()" />
</mat-form-field>
</div>
<div class="row-container">
<mat-form-field class="flex-auto">
<mat-label>Header</mat-label>
<textarea matInput formControlName="header"></textarea>
</mat-form-field>
</div>
<div class="row-container">
<mat-form-field class="flex-auto">
<mat-label>Prefix</mat-label>
<input matInput formControlName="prefix" />
</mat-form-field>
</div>
</form>
<div class="row-container">
<button mat-raised-button [disabled]="item.isFixture" color="primary" class="" (click)="save()">Save</button>
@if (!!item.id) {
<button mat-raised-button [disabled]="item.isFixture" color="warn" (click)="confirmDelete()">Delete</button>
}
</div>

View File

@ -1,14 +1,13 @@
import { AfterViewInit, Component, ElementRef, OnInit, ViewChild, inject } from '@angular/core';
import { FormControl, FormGroup, ReactiveFormsModule } from '@angular/forms';
import { MatButtonModule } from '@angular/material/button';
import { MatCardModule } from '@angular/material/card';
import { MatDialog } from '@angular/material/dialog';
import { MatFormFieldModule } from '@angular/material/form-field';
import { MatInputModule } from '@angular/material/input';
import { MatSnackBar } from '@angular/material/snack-bar';
import { ActivatedRoute, Router } from '@angular/router';
import { Regime } from '../../core/regime';
import { ToasterService } from '../../core/toaster.service';
import { ConfirmDialogComponent } from '../../shared/confirm-dialog/confirm-dialog.component';
import { RegimeService } from '../regime.service';
@ -16,13 +15,13 @@ import { RegimeService } from '../regime.service';
selector: 'app-regime-detail',
templateUrl: './regime-detail.component.html',
styleUrls: ['./regime-detail.component.css'],
imports: [MatButtonModule, MatCardModule, MatFormFieldModule, MatInputModule, ReactiveFormsModule],
imports: [MatButtonModule, MatFormFieldModule, MatInputModule, ReactiveFormsModule],
})
export class RegimeDetailComponent implements OnInit, AfterViewInit {
private route = inject(ActivatedRoute);
private router = inject(Router);
private dialog = inject(MatDialog);
private toaster = inject(ToasterService);
private snackBar = inject(MatSnackBar);
private ser = inject(RegimeService);
@ViewChild('nameElement', { static: true }) nameElement?: ElementRef;
@ -70,11 +69,11 @@ export class RegimeDetailComponent implements OnInit, AfterViewInit {
save() {
this.ser.saveOrUpdate(this.getItem()).subscribe({
next: () => {
this.toaster.show('Success', '');
this.snackBar.open('', 'Success');
this.router.navigateByUrl('/regimes');
},
error: (error) => {
this.toaster.show('Error', error);
this.snackBar.open(error, 'Error');
},
});
}
@ -82,11 +81,11 @@ export class RegimeDetailComponent implements OnInit, AfterViewInit {
delete() {
this.ser.delete(this.item.id as number).subscribe({
next: () => {
this.toaster.show('Success', '');
this.snackBar.open('', 'Success');
this.router.navigateByUrl('/regimes');
},
error: (error) => {
this.toaster.show('Error', error);
this.snackBar.open(error, 'Error');
},
});
}

View File

@ -1,43 +1,37 @@
<mat-card>
<mat-card-header>
<mat-card-title-group>
<mat-card-title>Regimes</mat-card-title>
<a mat-button [routerLink]="['/regimes', 'new']">
<mat-icon>add_box</mat-icon>
Add
</a>
</mat-card-title-group>
</mat-card-header>
<mat-card-content>
<mat-table #table [dataSource]="dataSource" aria-label="Elements">
<!-- Name Column -->
<ng-container matColumnDef="name">
<mat-header-cell *matHeaderCellDef>Name</mat-header-cell>
<mat-cell *matCellDef="let row"
><a [routerLink]="['/regimes', row.id]">{{ row.name }}</a></mat-cell
>
</ng-container>
<h2 class="row-container space-between">
<span>Regimes</span>
<a mat-button [routerLink]="['/regimes', 'new']">
<mat-icon>add_box</mat-icon>
Add
</a>
</h2>
<mat-table #table [dataSource]="dataSource" aria-label="Elements">
<!-- Name Column -->
<ng-container matColumnDef="name">
<mat-header-cell *matHeaderCellDef>Name</mat-header-cell>
<mat-cell *matCellDef="let row"
><a [routerLink]="['/regimes', row.id]">{{ row.name }}</a></mat-cell
>
</ng-container>
<!-- Header Column -->
<ng-container matColumnDef="header">
<mat-header-cell *matHeaderCellDef>Header</mat-header-cell>
<mat-cell *matCellDef="let row">{{ row.header }}</mat-cell>
</ng-container>
<!-- Header Column -->
<ng-container matColumnDef="header">
<mat-header-cell *matHeaderCellDef>Header</mat-header-cell>
<mat-cell *matCellDef="let row">{{ row.header }}</mat-cell>
</ng-container>
<!-- Prefix Column -->
<ng-container matColumnDef="prefix">
<mat-header-cell *matHeaderCellDef>Prefix</mat-header-cell>
<mat-cell *matCellDef="let row">{{ row.prefix }}</mat-cell>
</ng-container>
<!-- Prefix Column -->
<ng-container matColumnDef="prefix">
<mat-header-cell *matHeaderCellDef>Prefix</mat-header-cell>
<mat-cell *matCellDef="let row">{{ row.prefix }}</mat-cell>
</ng-container>
<!-- Is Fixture Column -->
<ng-container matColumnDef="isFixture">
<mat-header-cell *matHeaderCellDef>Is Fixture?</mat-header-cell>
<mat-cell *matCellDef="let row">{{ row.isFixture }}</mat-cell>
</ng-container>
<!-- Is Fixture Column -->
<ng-container matColumnDef="isFixture">
<mat-header-cell *matHeaderCellDef>Is Fixture?</mat-header-cell>
<mat-cell *matCellDef="let row">{{ row.isFixture }}</mat-cell>
</ng-container>
<mat-header-row *matHeaderRowDef="displayedColumns"></mat-header-row>
<mat-row *matRowDef="let row; columns: displayedColumns"></mat-row>
</mat-table>
</mat-card-content>
</mat-card>
<mat-header-row *matHeaderRowDef="displayedColumns"></mat-header-row>
<mat-row *matRowDef="let row; columns: displayedColumns"></mat-row>
</mat-table>

View File

@ -1,6 +1,5 @@
import { Component, OnInit, inject } from '@angular/core';
import { MatButtonModule } from '@angular/material/button';
import { MatCardModule } from '@angular/material/card';
import { MatIconModule } from '@angular/material/icon';
import { MatTableModule } from '@angular/material/table';
import { ActivatedRoute, RouterLink } from '@angular/router';
@ -12,7 +11,7 @@ import { RegimeListDataSource } from './regime-list-datasource';
selector: 'app-regime-list',
templateUrl: './regime-list.component.html',
styleUrls: ['./regime-list.component.css'],
imports: [MatButtonModule, MatCardModule, MatIconModule, MatTableModule, RouterLink],
imports: [MatButtonModule, MatIconModule, MatTableModule, RouterLink],
})
export class RegimeListComponent implements OnInit {
private route = inject(ActivatedRoute);