Newer
Older
import { MatSnackBar } from '@angular/material/snack-bar';
import { Injectable, Component, Inject } from '@angular/core';
import { MAT_SNACK_BAR_DATA } from '@angular/material/snack-bar';
import { Router } from '@angular/router';
@Component({
selector: 'custom-snackbar',
templateUrl: "notification.service.html",
styleUrls: ['notification.service.scss'],
})
export class CustomSnackbarComponent {
constructor(@Inject(MAT_SNACK_BAR_DATA) public data: any) { }
}
@Injectable()
export class NotificationService {
constructor(private router: Router, public snackBar: MatSnackBar) {
success(message: string) {
this.snackBar.openFromComponent(CustomSnackbarComponent, {
duration: 2000,
panelClass: 'success-snackbar',
data: { message: message, icon: 'info-circle' }
});
error(message: string, url: string = null) {
this.snackBar.openFromComponent(CustomSnackbarComponent, {
duration: 4000,
panelClass: 'error-snackbar',
data: { url: url, message: message, icon: 'exclamation-triangle' }
handleErrors(err: any) {
console.log(err);
if (err.status === 401 && this.router.url !== '/home') {
this.router.navigate(['/home']);
} else if (err.status === 0 && err.statusText === 'Unknown Error') {
if (err.error !== undefined) {
if (err.error.errors !== undefined) {
this.error(err.error.errors, err.url);
if (err.status === 403 || err.status === 404) {
this.router.navigate(['/home']);
}
} else if (err.error.exception !== undefined) {
this.error(err.error.exception[0].message, err.url);
} else if(err.error.error !== undefined){
this.error(err.error.error.message, err.url);
this.error(`${err.status} : ${err.statusText}`, err.url);
this.error(err);