forked from mystiq/hydrogen-web
WIP3
This commit is contained in:
parent
206d18f498
commit
cb051ad161
2 changed files with 41 additions and 10 deletions
|
@ -23,6 +23,7 @@ import {PendingEventEntry} from "./entries/PendingEventEntry.js";
|
||||||
import {RoomMember} from "../members/RoomMember.js";
|
import {RoomMember} from "../members/RoomMember.js";
|
||||||
import {PowerLevels} from "./PowerLevels.js";
|
import {PowerLevels} from "./PowerLevels.js";
|
||||||
import {getRelationFromContent, getRelation, ANNOTATION_RELATION_TYPE} from "./relations.js";
|
import {getRelationFromContent, getRelation, ANNOTATION_RELATION_TYPE} from "./relations.js";
|
||||||
|
import {REDACTION_TYPE} from "../common.js";
|
||||||
|
|
||||||
export class Timeline {
|
export class Timeline {
|
||||||
constructor({roomId, storage, closeCallback, fragmentIdComparer, pendingEvents, clock}) {
|
constructor({roomId, storage, closeCallback, fragmentIdComparer, pendingEvents, clock}) {
|
||||||
|
@ -125,6 +126,11 @@ export class Timeline {
|
||||||
return params;
|
return params;
|
||||||
});
|
});
|
||||||
if (redactedEntry) {
|
if (redactedEntry) {
|
||||||
|
this._addLocallyRedactedRelationToTarget(redactedEntry);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
_addLocallyRedactedRelationToTarget(redactedEntry) {
|
||||||
const redactedRelation = getRelationFromContent(redactedEntry.content);
|
const redactedRelation = getRelationFromContent(redactedEntry.content);
|
||||||
if (redactedRelation?.event_id) {
|
if (redactedRelation?.event_id) {
|
||||||
const found = this._remoteEntries.findAndUpdate(
|
const found = this._remoteEntries.findAndUpdate(
|
||||||
|
@ -133,7 +139,6 @@ export class Timeline {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
_onRemovePendingEvent(pee) {
|
_onRemovePendingEvent(pee) {
|
||||||
let unredactedEntry;
|
let unredactedEntry;
|
||||||
|
@ -180,7 +185,6 @@ export class Timeline {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
async getOwnAnnotationEntry(targetId, key) {
|
async getOwnAnnotationEntry(targetId, key) {
|
||||||
const txn = await this._storage.readWriteTxn([
|
const txn = await this._storage.readWriteTxn([
|
||||||
this._storage.storeNames.timelineEvents,
|
this._storage.storeNames.timelineEvents,
|
||||||
|
@ -227,9 +231,33 @@ export class Timeline {
|
||||||
for (const pee of this._localEntries) {
|
for (const pee of this._localEntries) {
|
||||||
// this will work because we set relatedEventId when removing remote echos
|
// this will work because we set relatedEventId when removing remote echos
|
||||||
if (pee.relatedEventId) {
|
if (pee.relatedEventId) {
|
||||||
|
|
||||||
|
|
||||||
const relationTarget = entries.find(e => e.id === pee.relatedEventId);
|
const relationTarget = entries.find(e => e.id === pee.relatedEventId);
|
||||||
|
if (relationTarget) {
|
||||||
|
const wasRedacted = relationTarget.isRedacted;
|
||||||
// no need to emit here as this entry is about to be added
|
// no need to emit here as this entry is about to be added
|
||||||
relationTarget?.addLocalRelation(pee);
|
relationTarget.addLocalRelation(pee);
|
||||||
|
if (!wasRedacted && relationTarget.isRedacted) {
|
||||||
|
this._addLocallyRedactedRelationToTarget(relationTarget);
|
||||||
|
}
|
||||||
|
} else if (pee.eventType === REDACTION_TYPE) {
|
||||||
|
// if pee is a redaction, we need to lookup the event it is redacting,
|
||||||
|
// and see if that is a relation of one of the entries
|
||||||
|
const redactedEntry = this.getByEventId(pee.relatedEventId);
|
||||||
|
if (redactedEntry) {
|
||||||
|
const relation = getRelation(redactedEntry);
|
||||||
|
if (relation) {
|
||||||
|
const redactedRelationTarget = entries.find(e => e.id === relation.event_id);
|
||||||
|
redactedRelationTarget?.addLocalRelation(redactedEntry);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
// TODO: errors are swallowed here
|
||||||
|
// console.log(`could not find target for pee ${pee.relatedEventId} ` + entries.filter(e => !["m.reaction", "m.room.redaction"].includes(e.eventType)).map(e => `${e.id}: ${e.content?.body}`).join(","));
|
||||||
|
// console.log(`could not find target for pee ${pee.relatedEventId} ` + entries.filter(e => "m.reaction" === e.eventType).map(e => `${e.id}: ${getRelation(e)?.key}`).join(","));
|
||||||
|
// console.log(`could not find target for pee ${pee.relatedEventId} ` + entries.map(e => `${e.id}: ${e._eventEntry.key.substr(e._eventEntry.key.lastIndexOf("|") + 1)}`).join(","));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -103,6 +103,8 @@ export function createFetchRequest(createTimeout, serviceWorkerHandler) {
|
||||||
}
|
}
|
||||||
options.headers = fetchHeaders;
|
options.headers = fetchHeaders;
|
||||||
}
|
}
|
||||||
|
const promise = Promise.reject(new ConnectionError());
|
||||||
|
/*
|
||||||
const promise = fetch(url, options).then(async response => {
|
const promise = fetch(url, options).then(async response => {
|
||||||
const {status} = response;
|
const {status} = response;
|
||||||
let body;
|
let body;
|
||||||
|
@ -135,6 +137,7 @@ export function createFetchRequest(createTimeout, serviceWorkerHandler) {
|
||||||
}
|
}
|
||||||
throw err;
|
throw err;
|
||||||
});
|
});
|
||||||
|
*/
|
||||||
const result = new RequestResult(promise, controller);
|
const result = new RequestResult(promise, controller);
|
||||||
|
|
||||||
if (timeout) {
|
if (timeout) {
|
||||||
|
|
Loading…
Reference in a new issue