mirror of
https://github.com/vector-im/hydrogen-web.git
synced 2025-01-10 20:17:32 +01:00
don't emit an update when the context entry is loaded sync
also load context entries in parallel
This commit is contained in:
parent
3243ce2a90
commit
7197e5427f
@ -258,8 +258,8 @@ export class Timeline {
|
|||||||
this._addLocalRelationsToNewRemoteEntries(newEntries);
|
this._addLocalRelationsToNewRemoteEntries(newEntries);
|
||||||
this._updateEntriesFetchedFromHomeserver(newEntries);
|
this._updateEntriesFetchedFromHomeserver(newEntries);
|
||||||
this._moveEntryToRemoteEntries(newEntries);
|
this._moveEntryToRemoteEntries(newEntries);
|
||||||
this._remoteEntries.setManySorted(newEntries);
|
|
||||||
this._loadContextEntriesWhereNeeded(newEntries);
|
this._loadContextEntriesWhereNeeded(newEntries);
|
||||||
|
this._remoteEntries.setManySorted(newEntries);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -320,21 +320,40 @@ export class Timeline {
|
|||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
const id = entry.contextEventId;
|
const id = entry.contextEventId;
|
||||||
let contextEvent = this._findLoadedEventById(id);
|
// before looking into remoteEntries, check the entries
|
||||||
|
// that about to be added first
|
||||||
|
let contextEvent = entries.find(e => e.id === id);
|
||||||
|
contextEvent = this._findLoadedEventById(id);
|
||||||
|
if (contextEvent) {
|
||||||
|
entry.setContextEntry(contextEvent);
|
||||||
|
// we don't emit an update here, as the add or update
|
||||||
|
// that the callee will emit hasn't been emitted yet.
|
||||||
|
} else {
|
||||||
|
// we don't await here, which is not ideal,
|
||||||
|
// but one of our callers, addEntries, is not async
|
||||||
|
// so there is not much point.
|
||||||
|
// Also, we want to run the entry fetching in parallel.
|
||||||
|
this._loadContextEntryNotInTimeline(entry);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
async _loadContextEntryNotInTimeline(entry) {
|
||||||
|
const id = entry.contextEventId;
|
||||||
|
let contextEvent = await this._getEventFromStorage(id);
|
||||||
if (!contextEvent) {
|
if (!contextEvent) {
|
||||||
contextEvent = await this._getEventFromStorage(id) ?? await this._getEventFromHomeserver(id);
|
contextEvent = await this._getEventFromHomeserver(id);
|
||||||
|
}
|
||||||
if (contextEvent) {
|
if (contextEvent) {
|
||||||
// this entry was created from storage/hs, so it's not tracked by remoteEntries
|
// this entry was created from storage/hs, so it's not tracked by remoteEntries
|
||||||
// we track them here so that we can update reply previews later
|
// we track them here so that we can update reply previews later
|
||||||
this._contextEntriesNotInTimeline.set(id, contextEvent);
|
this._contextEntriesNotInTimeline.set(id, contextEvent);
|
||||||
}
|
|
||||||
}
|
|
||||||
if (contextEvent) {
|
|
||||||
entry.setContextEntry(contextEvent);
|
entry.setContextEntry(contextEvent);
|
||||||
|
// here, we awaited something, so from now on we do have to emit
|
||||||
|
// an update if we set the context entry.
|
||||||
this._emitUpdateForEntry(entry, "contextEntry");
|
this._emitUpdateForEntry(entry, "contextEntry");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Fetches an entry with the given event-id from localEntries, remoteEntries or contextEntriesNotInTimeline.
|
* Fetches an entry with the given event-id from localEntries, remoteEntries or contextEntriesNotInTimeline.
|
||||||
|
Loading…
x
Reference in New Issue
Block a user