Add abort to thunk

This commit is contained in:
Jon Staab
2024-10-16 12:07:57 -07:00
parent ac3c2e7d0b
commit f7e570d868
5 changed files with 66 additions and 14 deletions
+2
View File
@@ -116,6 +116,8 @@ export const SEEN_CONTEXT = 10116
export const SEEN_CONVERSATION = 10117
export const LIGHTNING_PUB_RPC = 21000
export const CLIENT_AUTH = 22242
export const AUTH_JOIN = 28934
export const AUTH_INVITE = 28935
export const WALLET_INFO = 13194
export const WALLET_REQUEST = 23194
export const WALLET_RESPONSE = 23195
+32 -4
View File
@@ -80,6 +80,31 @@ export class Repository<E extends HashedEvent = TrustedEvent> extends Emitter {
return duplicate && duplicate.created_at >= event.created_at
}
removeEvent = (idOrAddress: string) => {
const event = this.getEvent(idOrAddress)
if (event) {
this.eventsById.delete(event.id)
if (isUnwrappedEvent(event)) {
this.eventsByWrap.delete(event.wrap.id)
}
this.eventsByAddress.delete(getAddress(event))
for (const [k, v] of event.tags) {
if (k.length === 1) {
this._updateIndex(this.eventsByTag, `${k}:${v}`, undefined, event)
}
}
this._updateIndex(this.eventsByDay, getDay(event.created_at), undefined, event)
this._updateIndex(this.eventsByAuthor, event.pubkey, undefined, event)
this.emit('update', {added: [], removed: [event.id]})
}
}
query = (filters: Filter[], {includeDeleted = false} = {}) => {
const result: E[][] = []
for (let filter of filters) {
@@ -215,14 +240,17 @@ export class Repository<E extends HashedEvent = TrustedEvent> extends Emitter {
// Utilities
_updateIndex<K>(m: Map<K, E[]>, k: K, e: E, duplicate?: E) {
_updateIndex<K>(m: Map<K, E[]>, k: K, add?: E, remove?: E) {
let a = m.get(k) || []
if (duplicate) {
a = a.filter((x: E) => x !== duplicate)
if (remove) {
a = a.filter((x: E) => x !== remove)
}
if (add) {
a.push(add)
}
a.push(e)
m.set(k, a)
}
}