Correctly disable infinite scroll for reuse
This commit is contained in:
parent
9db2330e4a
commit
0af2a8c5d6
|
@ -1,7 +1,7 @@
|
||||||
import { Injectable } from '@angular/core'
|
import { ComponentRef, Injectable } from '@angular/core'
|
||||||
import { ActivatedRouteSnapshot, DetachedRouteHandle, RouteReuseStrategy } from '@angular/router'
|
import { ActivatedRouteSnapshot, DetachedRouteHandle, RouteReuseStrategy } from '@angular/router'
|
||||||
import { RouterSetting } from './'
|
import { DisableForReuseHook } from './disable-for-reuse-hook'
|
||||||
import { PeerTubeRouterService } from './peertube-router.service'
|
import { PeerTubeRouterService, RouterSetting } from './peertube-router.service'
|
||||||
|
|
||||||
@Injectable()
|
@Injectable()
|
||||||
export class CustomReuseStrategy implements RouteReuseStrategy {
|
export class CustomReuseStrategy implements RouteReuseStrategy {
|
||||||
|
@ -22,9 +22,11 @@ export class CustomReuseStrategy implements RouteReuseStrategy {
|
||||||
const key = this.generateKey(route)
|
const key = this.generateKey(route)
|
||||||
this.recentlyUsed = key
|
this.recentlyUsed = key
|
||||||
|
|
||||||
console.log('Storing component %s to reuse later.', key);
|
console.log('Storing component %s to reuse later.', key)
|
||||||
|
|
||||||
(handle as any).componentRef.instance.disableForReuse()
|
const componentRef = (handle as any).componentRef as ComponentRef<DisableForReuseHook>
|
||||||
|
componentRef.instance.disableForReuse()
|
||||||
|
componentRef.changeDetectorRef.detectChanges()
|
||||||
|
|
||||||
this.storedRouteHandles.set(key, handle)
|
this.storedRouteHandles.set(key, handle)
|
||||||
|
|
||||||
|
|
|
@ -13,6 +13,7 @@ export class InfiniteScrollerDirective implements OnInit, OnDestroy, AfterViewCh
|
||||||
|
|
||||||
// Add angular state in query params to reuse the routed component
|
// Add angular state in query params to reuse the routed component
|
||||||
@Input() setAngularState: boolean
|
@Input() setAngularState: boolean
|
||||||
|
@Input() parentDisabled = false
|
||||||
|
|
||||||
@Output() nearOfBottom = new EventEmitter<void>()
|
@Output() nearOfBottom = new EventEmitter<void>()
|
||||||
|
|
||||||
|
@ -74,7 +75,7 @@ export class InfiniteScrollerDirective implements OnInit, OnDestroy, AfterViewCh
|
||||||
filter(({ current, maximumScroll }) => (current / maximumScroll) > this.decimalLimit)
|
filter(({ current, maximumScroll }) => (current / maximumScroll) > this.decimalLimit)
|
||||||
)
|
)
|
||||||
.subscribe(() => {
|
.subscribe(() => {
|
||||||
if (this.setAngularState) this.setScrollRouteParams()
|
if (this.setAngularState && !this.parentDisabled) this.setScrollRouteParams()
|
||||||
|
|
||||||
this.nearOfBottom.emit()
|
this.nearOfBottom.emit()
|
||||||
})
|
})
|
||||||
|
|
|
@ -40,7 +40,8 @@
|
||||||
|
|
||||||
<div class="no-results" i18n *ngIf="hasDoneFirstQuery && videos.length === 0">No results.</div>
|
<div class="no-results" i18n *ngIf="hasDoneFirstQuery && videos.length === 0">No results.</div>
|
||||||
<div
|
<div
|
||||||
myInfiniteScroller (nearOfBottom)="onNearOfBottom()" [dataObservable]="onDataSubject.asObservable()" [setAngularState]="true"
|
myInfiniteScroller (nearOfBottom)="onNearOfBottom()" [dataObservable]="onDataSubject.asObservable()"
|
||||||
|
[setAngularState]="true" [parentDisabled]="disabled"
|
||||||
class="videos" [ngClass]="{ 'display-as-row': displayAsRow }"
|
class="videos" [ngClass]="{ 'display-as-row': displayAsRow }"
|
||||||
>
|
>
|
||||||
<ng-container *ngFor="let video of videos; trackBy: videoById;">
|
<ng-container *ngFor="let video of videos; trackBy: videoById;">
|
||||||
|
|
|
@ -2,7 +2,8 @@
|
||||||
|
|
||||||
<div
|
<div
|
||||||
class="videos"
|
class="videos"
|
||||||
myInfiniteScroller (nearOfBottom)="onNearOfBottom()" [dataObservable]="onDataSubject.asObservable()" [setAngularState]="true"
|
myInfiniteScroller (nearOfBottom)="onNearOfBottom()" [dataObservable]="onDataSubject.asObservable()"
|
||||||
|
[parentDisabled]="disabled" [setAngularState]="true"
|
||||||
>
|
>
|
||||||
<div class="video" *ngFor="let video of videos; let i = index; trackBy: videoById">
|
<div class="video" *ngFor="let video of videos; let i = index; trackBy: videoById">
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue