mirror of
https://github.com/paperless-ngx/paperless-ngx.git
synced 2025-04-02 13:45:10 -05:00
toast changes
This commit is contained in:
parent
689b0db1a8
commit
a89eaafed7
@ -66,7 +66,7 @@ export abstract class EditDialogComponent<T extends ObjectWithId> implements OnI
|
|||||||
this.activeModal.close()
|
this.activeModal.close()
|
||||||
this.success.emit(result)
|
this.success.emit(result)
|
||||||
}, error => {
|
}, error => {
|
||||||
this.toastService.showToast(Toast.make("Error", `Could not save ${this.entityName}: ${error.error.name}`))
|
this.toastService.showToast(Toast.makeError(`Could not save ${this.entityName}: ${error.error.name}`))
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1,6 +1,7 @@
|
|||||||
<ngb-toast
|
<ngb-toast
|
||||||
*ngFor="let toast of toasts"
|
*ngFor="let toast of toasts"
|
||||||
[header]="toast.title" [autohide]="true" [delay]="toast.delay"
|
[header]="toast.title" [autohide]="true" [delay]="toast.delay"
|
||||||
|
[class]="toast.classname"
|
||||||
(hide)="toastService.closeToast(toast)">
|
(hide)="toastService.closeToast(toast)">
|
||||||
{{toast.content}}
|
{{toast.content}}
|
||||||
</ngb-toast>
|
</ngb-toast>
|
@ -1,6 +1,7 @@
|
|||||||
import { Component, OnInit } from '@angular/core';
|
import { Component, OnInit } from '@angular/core';
|
||||||
import { FileSystemDirectoryEntry, FileSystemFileEntry, NgxFileDropEntry } from 'ngx-file-drop';
|
import { FileSystemDirectoryEntry, FileSystemFileEntry, NgxFileDropEntry } from 'ngx-file-drop';
|
||||||
import { DocumentService } from 'src/app/services/rest/document.service';
|
import { DocumentService } from 'src/app/services/rest/document.service';
|
||||||
|
import { Toast, ToastService } from 'src/app/services/toast.service';
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
selector: 'app-dashboard',
|
selector: 'app-dashboard',
|
||||||
@ -9,7 +10,7 @@ import { DocumentService } from 'src/app/services/rest/document.service';
|
|||||||
})
|
})
|
||||||
export class DashboardComponent implements OnInit {
|
export class DashboardComponent implements OnInit {
|
||||||
|
|
||||||
constructor(private documentService: DocumentService) { }
|
constructor(private documentService: DocumentService, private toastService: ToastService) { }
|
||||||
|
|
||||||
ngOnInit(): void {
|
ngOnInit(): void {
|
||||||
}
|
}
|
||||||
@ -24,8 +25,6 @@ export class DashboardComponent implements OnInit {
|
|||||||
|
|
||||||
public dropped(files: NgxFileDropEntry[]) {
|
public dropped(files: NgxFileDropEntry[]) {
|
||||||
for (const droppedFile of files) {
|
for (const droppedFile of files) {
|
||||||
|
|
||||||
// Is it a file?
|
|
||||||
if (droppedFile.fileEntry.isFile) {
|
if (droppedFile.fileEntry.isFile) {
|
||||||
const fileEntry = droppedFile.fileEntry as FileSystemFileEntry;
|
const fileEntry = droppedFile.fileEntry as FileSystemFileEntry;
|
||||||
console.log(fileEntry)
|
console.log(fileEntry)
|
||||||
@ -34,9 +33,9 @@ export class DashboardComponent implements OnInit {
|
|||||||
const formData = new FormData()
|
const formData = new FormData()
|
||||||
formData.append('document', file, file.name)
|
formData.append('document', file, file.name)
|
||||||
this.documentService.uploadDocument(formData).subscribe(result => {
|
this.documentService.uploadDocument(formData).subscribe(result => {
|
||||||
console.log(result)
|
this.toastService.showToast(Toast.make("Information", "The document has been uploaded and will be processed by the consumer shortly."))
|
||||||
}, error => {
|
}, error => {
|
||||||
console.error(error)
|
this.toastService.showToast(Toast.makeError("An error has occured while uploading the document. Sorry!"))
|
||||||
})
|
})
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -26,7 +26,7 @@ export class LoginComponent implements OnInit {
|
|||||||
this.auth.login(this.loginForm.value.username, this.loginForm.value.password, this.loginForm.value.rememberMe).subscribe(result => {
|
this.auth.login(this.loginForm.value.username, this.loginForm.value.password, this.loginForm.value.rememberMe).subscribe(result => {
|
||||||
this.router.navigate([''])
|
this.router.navigate([''])
|
||||||
}, (error) => {
|
}, (error) => {
|
||||||
this.toastService.showToast(Toast.make("Error", "result: " + JSON.stringify(error.error)))
|
this.toastService.showToast(Toast.makeError("Unable to log in with provided credentials."))
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
@ -3,15 +3,18 @@ import {
|
|||||||
HttpRequest,
|
HttpRequest,
|
||||||
HttpHandler,
|
HttpHandler,
|
||||||
HttpEvent,
|
HttpEvent,
|
||||||
HttpInterceptor
|
HttpInterceptor,
|
||||||
|
HttpErrorResponse
|
||||||
} from '@angular/common/http';
|
} from '@angular/common/http';
|
||||||
import { Observable } from 'rxjs';
|
import { Observable, throwError } from 'rxjs';
|
||||||
import { AuthService } from './auth.service';
|
import { AuthService } from './auth.service';
|
||||||
|
import { catchError } from 'rxjs/operators';
|
||||||
|
import { Toast, ToastService } from './toast.service';
|
||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
export class AuthInterceptor implements HttpInterceptor {
|
export class AuthInterceptor implements HttpInterceptor {
|
||||||
|
|
||||||
constructor(private authService: AuthService) {}
|
constructor(private authService: AuthService, private toastService: ToastService) {}
|
||||||
|
|
||||||
intercept(request: HttpRequest<unknown>, next: HttpHandler): Observable<HttpEvent<unknown>> {
|
intercept(request: HttpRequest<unknown>, next: HttpHandler): Observable<HttpEvent<unknown>> {
|
||||||
if (this.authService.isAuthenticated()) {
|
if (this.authService.isAuthenticated()) {
|
||||||
@ -21,6 +24,14 @@ export class AuthInterceptor implements HttpInterceptor {
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
return next.handle(request);
|
return next.handle(request).pipe(
|
||||||
|
catchError((error: HttpErrorResponse) => {
|
||||||
|
if (error.status == 401 && this.authService.isAuthenticated()) {
|
||||||
|
this.authService.logout()
|
||||||
|
this.toastService.showToast(Toast.makeError("Your session has expired. Please log in again."))
|
||||||
|
}
|
||||||
|
return throwError(error)
|
||||||
|
})
|
||||||
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1,20 +1,27 @@
|
|||||||
import { Injectable } from '@angular/core';
|
import { Injectable } from '@angular/core';
|
||||||
import { Subject } from 'rxjs';
|
import { Subject, zip } from 'rxjs';
|
||||||
|
|
||||||
export class Toast {
|
export class Toast {
|
||||||
|
|
||||||
static make(title: string, content: string, delay?: number): Toast {
|
static make(title: string, content: string, classname?: string, delay?: number): Toast {
|
||||||
let t = new Toast()
|
let t = new Toast()
|
||||||
t.title = title
|
t.title = title
|
||||||
t.content = content
|
t.content = content
|
||||||
|
t.classname = classname
|
||||||
if (delay) {
|
if (delay) {
|
||||||
t.delay = delay
|
t.delay = delay
|
||||||
}
|
}
|
||||||
return t
|
return t
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static makeError(content: string) {
|
||||||
|
return Toast.make("Error", content, null, 10000)
|
||||||
|
}
|
||||||
|
|
||||||
title: string
|
title: string
|
||||||
|
|
||||||
|
classname: string
|
||||||
|
|
||||||
content: string
|
content: string
|
||||||
|
|
||||||
delay: number = 5000
|
delay: number = 5000
|
||||||
@ -30,23 +37,23 @@ export class ToastService {
|
|||||||
|
|
||||||
private toasts: Toast[] = []
|
private toasts: Toast[] = []
|
||||||
|
|
||||||
private toastSubject: Subject<Toast[]> = new Subject()
|
private toastsSubject: Subject<Toast[]> = new Subject()
|
||||||
|
|
||||||
showToast(toast: Toast) {
|
showToast(toast: Toast) {
|
||||||
this.toasts.push(toast)
|
this.toasts.push(toast)
|
||||||
this.toastSubject.next(this.toasts)
|
this.toastsSubject.next(this.toasts)
|
||||||
}
|
}
|
||||||
|
|
||||||
closeToast(toast: Toast) {
|
closeToast(toast: Toast) {
|
||||||
let index = this.toasts.findIndex(t => t == toast)
|
let index = this.toasts.findIndex(t => t == toast)
|
||||||
if (index > -1) {
|
if (index > -1) {
|
||||||
this.toasts.splice(index, 1)
|
this.toasts.splice(index, 1)
|
||||||
this.toastSubject.next(this.toasts)
|
this.toastsSubject.next(this.toasts)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
getToasts() {
|
getToasts() {
|
||||||
return this.toastSubject
|
return this.toastsSubject
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user