Feature: Delete Employee - function created
This commit is contained in:
parent
c43d73aadb
commit
9d3be76744
6 changed files with 85 additions and 2 deletions
8
src/app/delete-model/DeleteModalData.d.ts
vendored
Normal file
8
src/app/delete-model/DeleteModalData.d.ts
vendored
Normal file
|
@ -0,0 +1,8 @@
|
||||||
|
interface DeleteModalData {
|
||||||
|
title: string,
|
||||||
|
description: string,
|
||||||
|
cancel: string,
|
||||||
|
ok: string,
|
||||||
|
}
|
||||||
|
|
||||||
|
export default DeleteModalData;
|
8
src/app/delete-model/delete-model.component.html
Normal file
8
src/app/delete-model/delete-model.component.html
Normal file
|
@ -0,0 +1,8 @@
|
||||||
|
<h2 mat-dialog-title>{{ data.title}}</h2>
|
||||||
|
<mat-dialog-content>
|
||||||
|
<p>{{data.description}}</p>
|
||||||
|
</mat-dialog-content>
|
||||||
|
<mat-dialog-actions class="delete-modal">
|
||||||
|
<button mat-flat-button [mat-dialog-close]="false">{{data.cancel}}</button>
|
||||||
|
<button mat-flat-button [mat-dialog-close]="true" class="warn">{{data.ok}}</button>
|
||||||
|
</mat-dialog-actions>
|
4
src/app/delete-model/delete-model.component.scss
Normal file
4
src/app/delete-model/delete-model.component.scss
Normal file
|
@ -0,0 +1,4 @@
|
||||||
|
.delete-modal {
|
||||||
|
display: flex;
|
||||||
|
justify-content: space-between;
|
||||||
|
}
|
32
src/app/delete-model/delete-model.component.ts
Normal file
32
src/app/delete-model/delete-model.component.ts
Normal file
|
@ -0,0 +1,32 @@
|
||||||
|
import {Component, Inject} from '@angular/core';
|
||||||
|
import {MatButton} from '@angular/material/button';
|
||||||
|
import {
|
||||||
|
MAT_DIALOG_DATA,
|
||||||
|
MatDialogActions, MatDialogClose,
|
||||||
|
MatDialogContent,
|
||||||
|
MatDialogTitle
|
||||||
|
} from '@angular/material/dialog';
|
||||||
|
import DeleteModalData from '@app/delete-model/DeleteModalData';
|
||||||
|
|
||||||
|
@Component({
|
||||||
|
selector: 'app-delete-model',
|
||||||
|
imports: [
|
||||||
|
MatDialogContent,
|
||||||
|
MatDialogActions,
|
||||||
|
MatDialogTitle,
|
||||||
|
MatButton,
|
||||||
|
MatDialogClose
|
||||||
|
],
|
||||||
|
templateUrl: './delete-model.component.html',
|
||||||
|
styleUrl: './delete-model.component.scss'
|
||||||
|
})
|
||||||
|
export class DeleteModelComponent {
|
||||||
|
|
||||||
|
constructor(
|
||||||
|
@Inject(MAT_DIALOG_DATA) protected data: DeleteModalData,
|
||||||
|
) {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
|
@ -48,7 +48,7 @@
|
||||||
<button mat-mini-fab class="shadowless" routerLink="employee/{{employee.id}}">
|
<button mat-mini-fab class="shadowless" routerLink="employee/{{employee.id}}">
|
||||||
<mat-icon>edit</mat-icon>
|
<mat-icon>edit</mat-icon>
|
||||||
</button>
|
</button>
|
||||||
<button mat-mini-fab class="shadowless warn">
|
<button mat-mini-fab class="shadowless warn" (click)="onDelete(employee)">
|
||||||
<mat-icon>delete</mat-icon>
|
<mat-icon>delete</mat-icon>
|
||||||
</button>
|
</button>
|
||||||
</td>
|
</td>
|
||||||
|
|
|
@ -2,14 +2,17 @@ import {AsyncPipe} from '@angular/common';
|
||||||
import {Component} from '@angular/core';
|
import {Component} from '@angular/core';
|
||||||
import {ReactiveFormsModule} from '@angular/forms';
|
import {ReactiveFormsModule} from '@angular/forms';
|
||||||
import {MatButtonModule} from '@angular/material/button';
|
import {MatButtonModule} from '@angular/material/button';
|
||||||
|
import {MatDialog} from '@angular/material/dialog';
|
||||||
import {MatFormFieldModule} from '@angular/material/form-field';
|
import {MatFormFieldModule} from '@angular/material/form-field';
|
||||||
import {MatIcon} from '@angular/material/icon';
|
import {MatIcon} from '@angular/material/icon';
|
||||||
import {MatInputModule} from '@angular/material/input';
|
import {MatInputModule} from '@angular/material/input';
|
||||||
import {MatSelectModule} from '@angular/material/select';
|
import {MatSelectModule} from '@angular/material/select';
|
||||||
import {MatTableDataSource, MatTableModule} from '@angular/material/table';
|
import {MatTableDataSource, MatTableModule} from '@angular/material/table';
|
||||||
import {RouterLink} from '@angular/router';
|
import {RouterLink} from '@angular/router';
|
||||||
|
import {DeleteModelComponent} from '@app/delete-model/delete-model.component';
|
||||||
import {AuthService} from '@core/auth/auth.service';
|
import {AuthService} from '@core/auth/auth.service';
|
||||||
import {Employee, EmployeeService, Qualification, QualificationService} from '@core/ems';
|
import {Employee, EmployeeService, Qualification, QualificationService} from '@core/ems';
|
||||||
|
import {NotificationService, NotificationType} from '@core/notification/notification.service';
|
||||||
import {Observable} from 'rxjs';
|
import {Observable} from 'rxjs';
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
|
@ -27,7 +30,9 @@ export class DashboardComponent {
|
||||||
constructor(
|
constructor(
|
||||||
protected auth: AuthService,
|
protected auth: AuthService,
|
||||||
private employeeService: EmployeeService,
|
private employeeService: EmployeeService,
|
||||||
private qualificationService: QualificationService
|
private qualificationService: QualificationService,
|
||||||
|
private dialog: MatDialog,
|
||||||
|
private notifications: NotificationService
|
||||||
) {
|
) {
|
||||||
this.$qualifications= this.qualificationService.getAllQualifications();
|
this.$qualifications= this.qualificationService.getAllQualifications();
|
||||||
this.employeeService.getAllEmployees().subscribe((employees) => {
|
this.employeeService.getAllEmployees().subscribe((employees) => {
|
||||||
|
@ -35,4 +40,30 @@ export class DashboardComponent {
|
||||||
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
onDelete(employee: Employee){
|
||||||
|
const dialogRef = this.dialog.open(DeleteModelComponent, {
|
||||||
|
data:{
|
||||||
|
title:`Delete ${employee.firstName} ${employee.lastName}`,
|
||||||
|
description: `Do you really want to delete ${employee.firstName} ${employee.lastName}?`,
|
||||||
|
cancel: 'No',
|
||||||
|
ok: 'Yes',
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
dialogRef.afterClosed().subscribe((accepted:boolean) => {
|
||||||
|
if (!accepted){
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
this.employeeService.deleteEmployee({id:employee.id}).subscribe(()=> {
|
||||||
|
const data = this.employeeDataSource.data;
|
||||||
|
const i = data.indexOf(employee);
|
||||||
|
if (i != -1){
|
||||||
|
data.splice(i, 1);
|
||||||
|
this.employeeDataSource.data = data;
|
||||||
|
}
|
||||||
|
this.notifications.publish(`Deleted ${employee.firstName} ${employee.lastName}`, NotificationType.Information);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue