Call assignment details from new route after a route change.

Make private.
This commit is contained in:
Jochen Winzer 2020-11-04 09:27:56 +01:00
parent 866acfe7f5
commit 513f1477af
2 changed files with 36 additions and 5 deletions

View File

@ -1,11 +1,11 @@
import { Component, OnInit } from '@angular/core'; import { Component, OnDestroy, OnInit } from '@angular/core';
import { FormBuilder, FormGroup, Validators } from '@angular/forms'; import { FormBuilder, FormGroup, Validators } from '@angular/forms';
import { MatSnackBar } from '@angular/material/snack-bar'; import { MatSnackBar } from '@angular/material/snack-bar';
import { Title } from '@angular/platform-browser'; import { Title } from '@angular/platform-browser';
import { ActivatedRoute, Router } from '@angular/router'; import { ActivatedRoute, NavigationEnd, Router } from '@angular/router';
import { TranslateService } from '@ngx-translate/core'; import { TranslateService } from '@ngx-translate/core';
import { BehaviorSubject } from 'rxjs'; import { BehaviorSubject, Subscription } from 'rxjs';
import { OperatorService, Permission } from 'app/core/core-services/operator.service'; import { OperatorService, Permission } from 'app/core/core-services/operator.service';
import { ItemRepositoryService } from 'app/core/repositories/agenda/item-repository.service'; import { ItemRepositoryService } from 'app/core/repositories/agenda/item-repository.service';
@ -36,7 +36,7 @@ import { ViewAssignmentRelatedUser } from '../../models/view-assignment-related-
templateUrl: './assignment-detail.component.html', templateUrl: './assignment-detail.component.html',
styleUrls: ['./assignment-detail.component.scss'] styleUrls: ['./assignment-detail.component.scss']
}) })
export class AssignmentDetailComponent extends BaseViewComponentDirective implements OnInit { export class AssignmentDetailComponent extends BaseViewComponentDirective implements OnInit, OnDestroy {
/** /**
* Determines if the assignment is new * Determines if the assignment is new
*/ */
@ -143,6 +143,13 @@ export class AssignmentDetailComponent extends BaseViewComponentDirective implem
return this.agendaObserver.getValue().length > 0; return this.agendaObserver.getValue().length > 0;
} }
/**
* Hold the subscription to the navigation.
* This cannot go into the subscription-list, since it should
* only get destroyed using ngOnDestroy routine and not on route changes.
*/
private navigationSubscription: Subscription;
/** /**
* Constructor. Build forms and subscribe to needed configs and updates * Constructor. Build forms and subscribe to needed configs and updates
* *
@ -210,12 +217,36 @@ export class AssignmentDetailComponent extends BaseViewComponentDirective implem
* Init data * Init data
*/ */
public ngOnInit(): void { public ngOnInit(): void {
this.observeRoute();
this.getAssignmentByUrl(); this.getAssignmentByUrl();
this.agendaObserver = this.itemRepo.getViewModelListBehaviorSubject(); this.agendaObserver = this.itemRepo.getViewModelListBehaviorSubject();
this.tagsObserver = this.tagRepo.getViewModelListBehaviorSubject(); this.tagsObserver = this.tagRepo.getViewModelListBehaviorSubject();
this.mediafilesObserver = this.mediafileRepo.getViewModelListBehaviorSubject(); this.mediafilesObserver = this.mediafileRepo.getViewModelListBehaviorSubject();
} }
/**
* Called during view destruction.
*/
public ngOnDestroy(): void {
if (this.navigationSubscription) {
this.navigationSubscription.unsubscribe();
}
super.ngOnDestroy();
}
/**
* Observes the route for events. Calls to clean all subs if the route changes.
* Calls the assignment details from the new route.
*/
private observeRoute(): void {
this.navigationSubscription = this.router.events.subscribe(navEvent => {
if (navEvent instanceof NavigationEnd) {
this.cleanSubjects();
this.getAssignmentByUrl();
}
});
}
/** /**
* Permission check for interactions. * Permission check for interactions.
* *

View File

@ -606,7 +606,7 @@ export class MotionDetailComponent extends BaseViewComponentDirective implements
* Observes the route for events. Calls to clean all subs if the route changes. * Observes the route for events. Calls to clean all subs if the route changes.
* Calls the motion details from the new route * Calls the motion details from the new route
*/ */
public observeRoute(): void { private observeRoute(): void {
this.navigationSubscription = this.router.events.subscribe(navEvent => { this.navigationSubscription = this.router.events.subscribe(navEvent => {
if (navEvent instanceof NavigationEnd) { if (navEvent instanceof NavigationEnd) {
this.cleanSubjects(); this.cleanSubjects();