mirror of
https://github.com/DSpace/dspace-angular.git
synced 2025-10-14 21:43:04 +00:00
starting with redux
This commit is contained in:
@@ -1,65 +1,116 @@
|
||||
import {Injectable, EventEmitter} from '@angular/core';
|
||||
import {Subject} from 'rxjs/Subject';
|
||||
import {NotificationEvent} from './interfaces/notification-event.type';
|
||||
import {Notification} from './interfaces/notification.type';
|
||||
import {Icons, defaultIcons} from './interfaces/icons';
|
||||
import { Injectable, EventEmitter } from '@angular/core';
|
||||
import { Subject } from 'rxjs/Subject';
|
||||
import { NotificationEvent } from './interfaces/notification-event.type';
|
||||
import { INotification, Notification } from './models/notification.model';
|
||||
// import {Icons, defaultIcons} from './interfaces/icons';
|
||||
import { NotificationType } from './models/notification-type';
|
||||
import { NotificationOptions } from './models/notification-options.model';
|
||||
import * as _ from 'lodash';
|
||||
import { Store } from '@ngrx/store';
|
||||
import {
|
||||
NewNotificationAction, NewNotificationWithTimerAction, RemoveAllNotificationsAction,
|
||||
RemoveNotificationAction
|
||||
} from './notifications.actions';
|
||||
|
||||
@Injectable()
|
||||
export class NotificationsService {
|
||||
|
||||
public emitter = new Subject<NotificationEvent>();
|
||||
public icons: Icons = defaultIcons;
|
||||
// public emitter = new Subject<NotificationEvent>();
|
||||
// public icons: Icons = defaultIcons;
|
||||
constructor(private store: Store<Notification>) {
|
||||
|
||||
set(notification: Notification, to: boolean): Notification {
|
||||
notification.id = notification.override && notification.override.id ? notification.override.id : Math.random().toString(36).substring(3);
|
||||
notification.click = new EventEmitter<{}>();
|
||||
notification.timeoutEnd = new EventEmitter<{}>();
|
||||
}
|
||||
|
||||
this.emitter.next({command: 'set', notification: notification, add: to});
|
||||
return notification;
|
||||
};
|
||||
// private set(notification: Notification, to: boolean): Notification {
|
||||
// notification.id = notification.override && notification.override.id ? notification.override.id : Math.random().toString(36).substring(3);
|
||||
// notification.click = new EventEmitter<{}>();
|
||||
// notification.timeoutEnd = new EventEmitter<{}>();
|
||||
//
|
||||
// this.emitter.next({command: 'set', notification: notification, add: to});
|
||||
// return notification;
|
||||
// };
|
||||
|
||||
success(title: any = '', content: any = '', override?: any): Notification {
|
||||
return this.set({title: title, content: content || '', type: NotificationType.Success, override: override}, true);
|
||||
private add(notification: Notification) {
|
||||
let notificationAction;
|
||||
if (notification.options.timeOut > 0) {
|
||||
notificationAction = new NewNotificationWithTimerAction(notification);
|
||||
} else {
|
||||
notificationAction = new NewNotificationAction(notification);
|
||||
}
|
||||
this.store.dispatch(notificationAction);
|
||||
}
|
||||
|
||||
// error(title: any = '', content: any = '', override?: any): Notification {
|
||||
// return this.set({title: title, content: content || '', type: NotificationType.Error, override: override}, true);
|
||||
// }
|
||||
success(title: any = '', content: any = '', options = new NotificationOptions()): Notification {
|
||||
const notification = new Notification(_.uniqueId(), NotificationType.Success, title, content, options);
|
||||
this.add(notification);
|
||||
return notification;
|
||||
}
|
||||
|
||||
danger(title: any = '', content: any = '', override?: any): Notification {
|
||||
return this.set({title: title, content: content || '', type: NotificationType.Danger, override: override}, true);
|
||||
}
|
||||
// error(title: any = '', content: any = '', override?: any): Notification {
|
||||
// return this.set({title: title, content: content || '', type: NotificationType.Error, override: override}, true);
|
||||
// }
|
||||
|
||||
info(title: any = '', content: any = '', override?: any): Notification {
|
||||
return this.set({title: title, content: content || '', type: NotificationType.Info, override: override}, true);
|
||||
}
|
||||
danger(title: any = '', content: any = '', options = new NotificationOptions()): Notification {
|
||||
const notification = new Notification(_.uniqueId(), NotificationType.Danger, title, content, options);
|
||||
this.add(notification);
|
||||
return notification;
|
||||
}
|
||||
|
||||
warn(title: any = '', content: any = '', override?: any): Notification {
|
||||
return this.set({title: title, content: content || '', type: NotificationType.Warning, override: override}, true);
|
||||
}
|
||||
info(title: any = '', content: any = '', options = new NotificationOptions()): Notification {
|
||||
const notification = new Notification(_.uniqueId(), NotificationType.Info, title, content, options);
|
||||
this.add(notification);
|
||||
return notification;
|
||||
}
|
||||
|
||||
// bare(title: any = '', content: any = '', override?: any): Notification {
|
||||
// return this.set({title: title, content: content || '', type: 'bare', icon: 'bare', override: override}, true);
|
||||
// }
|
||||
warning(title: any = '', content: any = '', options = new NotificationOptions()): Notification {
|
||||
const notification = new Notification(_.uniqueId(), NotificationType.Warning, title, content, options);
|
||||
this.add(notification);
|
||||
return notification;
|
||||
}
|
||||
|
||||
// With type method
|
||||
create(title: any = '', content: any = '', type = 'success', override?: any): Notification {
|
||||
return this.set({title: title, content: content, type: type, icon: (this.icons as any)[type], override: override}, true);
|
||||
}
|
||||
// bare(title: any = '', content: any = '', override?: any): Notification {
|
||||
// return this.set({title: title, content: content || '', type: 'bare', icon: 'bare', override: override}, true);
|
||||
// }
|
||||
|
||||
// HTML Notification method
|
||||
html(html: any, type = 'success', override?: any, icon = 'bare'): Notification {
|
||||
return this.set({html: html, type: type, icon: (this.icons as any)[icon], override: override}, true);
|
||||
}
|
||||
// With type method
|
||||
// create(title: any = '', content: any = '', type = 'success'): Notification {
|
||||
// return this.set({
|
||||
// title: title,
|
||||
// content: content,
|
||||
// type: type,
|
||||
// icon: (this.icons as any)[type],
|
||||
// override: override
|
||||
// }, true);
|
||||
// }
|
||||
|
||||
// HTML Notification method
|
||||
// html(html: any, type = 'success', override?: any, icon = 'bare'): Notification {
|
||||
// return this.set({html: html, type: type, icon: (this.icons as any)[icon], override: override}, true);
|
||||
// }
|
||||
|
||||
html(html: any, type = NotificationType.Success, options = new NotificationOptions()): Notification {
|
||||
const notification = new Notification(_.uniqueId(), type, null, null, options);
|
||||
notification.html = html;
|
||||
this.add(notification);
|
||||
return notification;
|
||||
}
|
||||
|
||||
// Remove all notifications method
|
||||
// remove(id?: string): void {
|
||||
// if (id) {
|
||||
// this.emitter.next({command: 'clean', id: id});
|
||||
// } else {
|
||||
// this.emitter.next({command: 'cleanAll'});
|
||||
// }
|
||||
// }
|
||||
remove(notification: INotification) {
|
||||
const actionRemove = new RemoveNotificationAction(notification.id);
|
||||
this.store.dispatch(actionRemove);
|
||||
}
|
||||
|
||||
removeAll() {
|
||||
const actionRemoveAll = new RemoveAllNotificationsAction();
|
||||
this.store.dispatch(actionRemoveAll);
|
||||
}
|
||||
|
||||
// Remove all notifications method
|
||||
remove(id?: string): void {
|
||||
if (id) {
|
||||
this.emitter.next({command: 'clean', id: id});
|
||||
} else {
|
||||
this.emitter.next({command: 'cleanAll'});
|
||||
}
|
||||
}
|
||||
}
|
||||
|
Reference in New Issue
Block a user