From 0405134e4629411cd4b8ba2e6056b8b99a4fd87c Mon Sep 17 00:00:00 2001 From: MoritzWeber Date: Mon, 23 Sep 2024 14:46:44 +0200 Subject: [PATCH] feat: Trigger feedback dialog after login --- frontend/src/app/app.component.ts | 18 ++---------------- .../auth-redirect/auth-redirect.component.ts | 3 +++ .../app/sessions/feedback/feedback.service.ts | 11 ++++++++++- 3 files changed, 15 insertions(+), 17 deletions(-) diff --git a/frontend/src/app/app.component.ts b/frontend/src/app/app.component.ts index 8f64b98d1..9fe75cc13 100644 --- a/frontend/src/app/app.component.ts +++ b/frontend/src/app/app.component.ts @@ -3,7 +3,7 @@ * SPDX-License-Identifier: Apache-2.0 */ import { NgIf, NgClass, AsyncPipe } from '@angular/common'; -import { AfterViewInit, Component, OnInit, ViewChild } from '@angular/core'; +import { AfterViewInit, Component, ViewChild } from '@angular/core'; import { MatSidenav, MatDrawerContainer, @@ -18,7 +18,6 @@ import { HeaderComponent } from './general/header/header.component'; import { NavBarMenuComponent } from './general/nav-bar-menu/nav-bar-menu.component'; import { NoticeComponent } from './general/notice/notice.component'; import { PageLayoutService } from './page-layout/page-layout.service'; -import { AuthenticationWrapperService } from './services/auth/auth.service'; import { FeedbackWrapperService } from './sessions/feedback/feedback.service'; import { FullscreenService } from './sessions/service/fullscreen.service'; @@ -41,31 +40,18 @@ import { FullscreenService } from './sessions/service/fullscreen.service'; AsyncPipe, ], }) -export class AppComponent implements OnInit, AfterViewInit { +export class AppComponent implements AfterViewInit { constructor( public pageLayoutService: PageLayoutService, public fullscreenService: FullscreenService, private navBarService: NavBarService, private feedbackService: FeedbackWrapperService, - private authService: AuthenticationWrapperService, ) { slugify.extend({ '.': '-' }); } @ViewChild('sidenav') private sidenav?: MatSidenav; - async ngOnInit() { - this.feedbackService.loadFeedbackConfig().subscribe(() => { - if ( - this.feedbackService.shouldShowIntervalPrompt() && - this.authService.isLoggedIn() - ) { - this.feedbackService.showDialog([], 'On interval'); - this.feedbackService.saveFeedbackPromptDate(); - } - }); - } - ngAfterViewInit(): void { this.navBarService.sidenav = this.sidenav; } diff --git a/frontend/src/app/general/auth/auth-redirect/auth-redirect.component.ts b/frontend/src/app/general/auth/auth-redirect/auth-redirect.component.ts index c6326f86c..936573661 100644 --- a/frontend/src/app/general/auth/auth-redirect/auth-redirect.component.ts +++ b/frontend/src/app/general/auth/auth-redirect/auth-redirect.component.ts @@ -8,6 +8,7 @@ import { ToastService } from 'src/app/helpers/toast/toast.service'; import { AuthenticationService } from 'src/app/openapi'; import { AuthenticationWrapperService } from 'src/app/services/auth/auth.service'; import { OwnUserWrapperService } from 'src/app/services/user/user.service'; +import { FeedbackWrapperService } from 'src/app/sessions/feedback/feedback.service'; @Component({ selector: 'app-auth-redirect', @@ -22,6 +23,7 @@ export class AuthRedirectComponent implements OnInit { private authenticationService: AuthenticationService, private userService: OwnUserWrapperService, private router: Router, + private feedbackService: FeedbackWrapperService, ) {} ngOnInit(): void { @@ -78,6 +80,7 @@ export class AuthRedirectComponent implements OnInit { next: () => { localStorage.setItem(this.authService.LOGGED_IN_KEY, 'true'); this.userService.updateOwnUser(); + this.feedbackService.triggerFeedbackPrompt(); this.router.navigateByUrl(redirectTo); }, error: () => this.redirectToLogin(), diff --git a/frontend/src/app/sessions/feedback/feedback.service.ts b/frontend/src/app/sessions/feedback/feedback.service.ts index b72f69e95..532764fb4 100644 --- a/frontend/src/app/sessions/feedback/feedback.service.ts +++ b/frontend/src/app/sessions/feedback/feedback.service.ts @@ -5,6 +5,7 @@ import { Injectable } from '@angular/core'; import { MatDialog } from '@angular/material/dialog'; import { BehaviorSubject, Observable, tap } from 'rxjs'; +import { AuthenticationWrapperService } from 'src/app/services/auth/auth.service'; import { FeedbackConfigurationOutput, FeedbackService as OpenAPIFeedbackService, @@ -19,8 +20,9 @@ export class FeedbackWrapperService { constructor( private feedbackService: OpenAPIFeedbackService, public dialog: MatDialog, + private authService: AuthenticationWrapperService, ) { - this.loadFeedbackConfig().subscribe(); + this.loadFeedbackConfig().subscribe(() => this.triggerFeedbackPrompt()); } private _feedbackConfig = new BehaviorSubject< @@ -35,6 +37,13 @@ export class FeedbackWrapperService { .pipe(tap((feedbackConf) => this._feedbackConfig.next(feedbackConf))); } + triggerFeedbackPrompt(): void { + if (this.shouldShowIntervalPrompt() && this.authService.isLoggedIn()) { + this.showDialog([], 'On interval'); + this.saveFeedbackPromptDate(); + } + } + public showDialog(sessions: Session[], trigger: string) { this.dialog.open(FeedbackDialogComponent, { data: { sessions, trigger },