From 82206bc9c9bc54088eed76cae13bd665addd8d90 Mon Sep 17 00:00:00 2001 From: Nicolas Constant Date: Sat, 18 Apr 2020 19:09:01 -0400 Subject: [PATCH] status notification added in thread --- .../stream/thread/thread.component.ts | 18 ++++++++++++++++++ 1 file changed, 18 insertions(+) diff --git a/src/app/components/stream/thread/thread.component.ts b/src/app/components/stream/thread/thread.component.ts index be18a022..ef2e17e0 100644 --- a/src/app/components/stream/thread/thread.component.ts +++ b/src/app/components/stream/thread/thread.component.ts @@ -10,6 +10,7 @@ import { AccountInfo } from '../../../states/accounts.state'; import { StatusWrapper } from '../../../models/common.model'; import { StatusComponent } from '../status/status.component'; import scrollIntoView from 'scroll-into-view-if-needed'; +import { UserNotificationService, UserNotification } from '../../../services/user-notification.service'; @Component({ selector: 'app-thread', @@ -50,10 +51,12 @@ export class ThreadComponent implements OnInit, OnDestroy { private deleteStatusSubscription: Subscription; private refreshSubscription: Subscription; private goToTopSubscription: Subscription; + private responseSubscription: Subscription; constructor( private readonly httpClient: HttpClient, private readonly notificationService: NotificationService, + private readonly userNotificationService: UserNotificationService, private readonly toolsService: ToolsService, private readonly mastodonService: MastodonWrapperService) { } @@ -102,6 +105,20 @@ export class ThreadComponent implements OnInit, OnDestroy { }); } }); + + this.responseSubscription = this.userNotificationService.userNotifications.subscribe((userNotifications: UserNotification[]) => { + userNotifications.forEach(x => { + x.mentions.forEach(y => { + if(y.status){ + if(this.statuses.map(z => z.status.id).includes(y.status.in_reply_to_id) && !this.statuses.map(z => z.status.uri).includes(y.status.uri)) { + let cwResult = this.toolsService.checkContentWarning(y.status); + this.statuses.push(new StatusWrapper(y.status, x.account, cwResult.applyCw, cwResult.hide)); + return; + } + } + }); + }); + }); } ngOnDestroy(): void { @@ -110,6 +127,7 @@ export class ThreadComponent implements OnInit, OnDestroy { if (this.deleteStatusSubscription) this.deleteStatusSubscription.unsubscribe(); if (this.refreshSubscription) this.refreshSubscription.unsubscribe(); if (this.goToTopSubscription) this.goToTopSubscription.unsubscribe(); + if (this.responseSubscription) this.responseSubscription.unsubscribe(); } @ViewChild('statusstream') public statustream: ElementRef;