mirror of
https://github.com/vector-im/hydrogen-web.git
synced 2025-01-11 04:27:40 +01:00
Fix many small issues from before I ran the code
This commit is contained in:
parent
8592fcf8c7
commit
e06abcc399
@ -112,11 +112,11 @@ export class Room extends BaseRoom {
|
||||
|
||||
async fetchContext(eventId, log = null) {
|
||||
const response = await this._hsApi.context(this._roomId, eventId, {}, {log}).response();
|
||||
await this._fetchEvents(response, async (txn, gapWriter) => {
|
||||
await this._fetchEvents(async (txn, gapWriter) => {
|
||||
// Just in case we somehow receive remote echoes during event fetch
|
||||
const beforeExtra = await this._writeGapFill(response.events_before, txn, log);
|
||||
const afterExtra = await this._writeGapFill(response.events_after, txn, log);
|
||||
beforeExtra.append(...afterExtra);
|
||||
beforeExtra.push(...afterExtra);
|
||||
const gapResult = await gapWriter.writeContext(response, txn, log);
|
||||
return { extraGapFillChanges: beforeExtra, gapResult };
|
||||
}, log);
|
||||
|
@ -16,6 +16,7 @@ limitations under the License.
|
||||
|
||||
import {EventKey} from "../EventKey";
|
||||
import {EventEntry} from "../entries/EventEntry.js";
|
||||
import {FragmentBoundaryEntry} from "../entries/FragmentBoundaryEntry.js";
|
||||
import {createEventEntry, directionalAppend} from "./common.js";
|
||||
import {RoomMember, EVENT_TYPE as MEMBER_EVENT_TYPE} from "../../members/RoomMember.js";
|
||||
|
||||
@ -232,7 +233,7 @@ export class GapWriter {
|
||||
return { entries: [], updatedEntries: [], fragments: [] }
|
||||
}
|
||||
|
||||
const maxFragmentKey = await tnx.timelineFragments.getMaxFragmentId(this._roomId);
|
||||
const maxFragmentKey = await txn.timelineFragments.getMaxFragmentId(this._roomId);
|
||||
const newFragment = {
|
||||
roomId: this._roomId,
|
||||
id: maxFragmentKey + 1,
|
||||
@ -244,11 +245,11 @@ export class GapWriter {
|
||||
const eventKey = EventKey.defaultFragmentKey(newFragment.id);
|
||||
|
||||
const startEntry = FragmentBoundaryEntry.start(newFragment, this._fragmentIdComparer);
|
||||
const startFill = this._storeAndUpdate(startEntry, eventsBefore, eventKey, start, state, txn, log);
|
||||
const startFill = await this._storeAndUpdate(startEntry, eventsBefore, eventKey, start, state, txn, log);
|
||||
|
||||
eventsAfter.unshift(event);
|
||||
const endEntry = FragmentBoundaryEntry.end(newFragment, this._fragmentIdComparer);
|
||||
const endFill = this._storeAndUpdate(endEntry, eventsAfter, eventKey, end, state, txn, log);
|
||||
const endFill = await this._storeAndUpdate(endEntry, eventsAfter, eventKey, end, state, txn, log);
|
||||
|
||||
// Both startFill and endFill are throwaway objects, so we
|
||||
// may as well modify one of them in-place instead of returning a third.
|
||||
|
Loading…
x
Reference in New Issue
Block a user