From a4cd40c2f8874daad21bf07793266ea0e65ad62a Mon Sep 17 00:00:00 2001 From: RMidhunSuresh Date: Fri, 5 Nov 2021 17:25:29 +0530 Subject: [PATCH] Keep filling gap until sibling changes --- .../session/room/timeline/tiles/GapTile.js | 18 ++++++++++++++++-- 1 file changed, 16 insertions(+), 2 deletions(-) diff --git a/src/domain/session/room/timeline/tiles/GapTile.js b/src/domain/session/room/timeline/tiles/GapTile.js index 1db2100e..2efe9712 100644 --- a/src/domain/session/room/timeline/tiles/GapTile.js +++ b/src/domain/session/room/timeline/tiles/GapTile.js @@ -23,6 +23,7 @@ export class GapTile extends SimpleTile { this._loading = false; this._error = null; this._isAtTop = true; + this._siblingChanged = false; } async fill() { @@ -42,11 +43,19 @@ export class GapTile extends SimpleTile { this._loading = false; this.emitChange("isLoading"); } + return true; } + return false; } - notifyVisible() { - this.fill(); + async notifyVisible() { + let depth = 0; + let result; + do { + result = await this.fill(); + depth = depth + 1; + } while (depth < 10 && !this._siblingChanged && result && !this.isDisposed) + this._siblingChanged = false; } get isAtTop() { @@ -60,6 +69,11 @@ export class GapTile extends SimpleTile { this._isAtTop = isAtTop; this.emitChange("isAtTop"); } + this._siblingChanged = true; + } + + updateNextSibling() { + this._siblingChanged = true; } updateEntry(entry, params) {