ngx-admin-lte
Version:
AdminLTE theme for angular
53 lines (41 loc) • 1.8 kB
text/typescript
// based on https://github.com/ng-book/angular2-rxjs-chat/blob/master/app/ts/services/MessagesService.ts
import { User } from '../models/user';
import { Message } from '../models/message';
import { Injectable } from '@angular/core';
import { Observable, Subject, ReplaySubject } from 'rxjs/Rx';
const initialMessages: Message[] = [];
type IMessagesOperation = (messages: Message[]) => Message[];
()
export class MessagesService {
private messagesList: Message[] = [];
// a stream that publishes new messages only once
public newMessages: Subject<Message> = new Subject<Message>();
// `messages` is a stream that emits an array of the most up to date messages
public messages: ReplaySubject<Message[]> = new ReplaySubject<Message[]>(1);
// `updates` receives _operations_ to be applied to our `messages`
// it's a way we can perform changes on *all* messages (that are currently
// stored in `messages`)
public updates: Subject<any> = new Subject<any>();
// action streams
public create: Subject<Message> = new Subject<Message>();
// public markThreadAsRead: Subject<any> = new Subject<any>();
constructor() {
// recois des operation, et les fais sur la liste interne, puis diffuse le resultat sur messages
this.updates.subscribe((ope) => {
this.messagesList = ope(this.messagesList);
console.log(this.messagesList);
this.messages.next(this.messagesList);
});
this.newMessages
.map(function(message: Message): IMessagesOperation {
return (messages: Message[]) => {
return messages.concat(message);
};
})
.subscribe(this.updates);
}
// an imperative function call to this action stream
public addMessage(message: Message): void {
this.newMessages.next(message);
}
}