Fix indexeddb deletes

This commit is contained in:
Jon Staab
2025-11-13 16:39:44 -08:00
parent 2421c02c24
commit b0731503a8
5 changed files with 57 additions and 13 deletions

View File

@@ -1,15 +1,19 @@
<script lang="ts"> <script lang="ts">
import type {TrustedEvent} from "@welshman/util" import type {TrustedEvent} from "@welshman/util"
import {pubkey} from "@welshman/app" import {ManagementMethod} from "@welshman/util"
import {pubkey, manageRelay, repository} from "@welshman/app"
import Code2 from "@assets/icons/code-2.svg?dataurl" import Code2 from "@assets/icons/code-2.svg?dataurl"
import TrashBin2 from "@assets/icons/trash-bin-2.svg?dataurl" import TrashBin2 from "@assets/icons/trash-bin-2.svg?dataurl"
import Danger from "@assets/icons/danger.svg?dataurl" import Danger from "@assets/icons/danger.svg?dataurl"
import Button from "@lib/components/Button.svelte" import Button from "@lib/components/Button.svelte"
import Icon from "@lib/components/Icon.svelte" import Icon from "@lib/components/Icon.svelte"
import Confirm from "@lib/components/Confirm.svelte"
import EventInfo from "@app/components/EventInfo.svelte" import EventInfo from "@app/components/EventInfo.svelte"
import EventReport from "@app/components/EventReport.svelte" import EventReport from "@app/components/EventReport.svelte"
import EventDeleteConfirm from "@app/components/EventDeleteConfirm.svelte" import EventDeleteConfirm from "@app/components/EventDeleteConfirm.svelte"
import {pushModal} from "@app/util/modal" import {pushModal} from "@app/util/modal"
import {pushToast} from "@app/util/toast"
import {deriveUserIsSpaceAdmin} from "@app/core/state"
type Props = { type Props = {
url: string url: string
@@ -19,6 +23,8 @@
const {url, event, onClick}: Props = $props() const {url, event, onClick}: Props = $props()
const userIsAdmin = deriveUserIsSpaceAdmin(url)
const report = () => { const report = () => {
onClick() onClick()
pushModal(EventReport, {url, event}) pushModal(EventReport, {url, event})
@@ -33,6 +39,26 @@
onClick() onClick()
pushModal(EventDeleteConfirm, {url, event}) pushModal(EventDeleteConfirm, {url, event})
} }
const showAdminDelete = () =>
pushModal(Confirm, {
title: `Delete Message`,
message: `Are you sure you want to delete this message from the space?`,
confirm: async () => {
const {error} = await manageRelay(url, {
method: ManagementMethod.BanEvent,
params: [event.id],
})
if (error) {
pushToast({theme: "error", message: error})
} else {
pushToast({message: "Event has successfully been deleted!"})
repository.removeEvent(event.id)
history.back()
}
},
})
</script> </script>
<ul class="menu whitespace-nowrap rounded-box bg-base-100 p-2 shadow-md"> <ul class="menu whitespace-nowrap rounded-box bg-base-100 p-2 shadow-md">
@@ -56,5 +82,13 @@
Report Content Report Content
</Button> </Button>
</li> </li>
{#if $userIsAdmin}
<li>
<Button class="text-error" onclick={showAdminDelete}>
<Icon size={4} icon={TrashBin2} />
Delete Message
</Button>
</li>
{/if}
{/if} {/if}
</ul> </ul>

View File

@@ -80,7 +80,7 @@ const rankEvent = (event: TrustedEvent) => {
const eventsAdapter = { const eventsAdapter = {
name: "events", name: "events",
keyPath: ["id"], keyPath: "id",
init: async (table: IDBTable<TrustedEvent>) => { init: async (table: IDBTable<TrustedEvent>) => {
const initialEvents = await table.getAll() const initialEvents = await table.getAll()
@@ -127,7 +127,7 @@ type TrackerItem = {id: string; relays: string[]}
const trackerAdapter = { const trackerAdapter = {
name: "tracker", name: "tracker",
keyPath: ["id"], keyPath: "id",
init: async (table: IDBTable<TrackerItem>) => { init: async (table: IDBTable<TrackerItem>) => {
const relaysById = new Map<string, Set<string>>() const relaysById = new Map<string, Set<string>>()
@@ -183,7 +183,7 @@ const trackerAdapter = {
const relaysAdapter = { const relaysAdapter = {
name: "relays", name: "relays",
keyPath: ["url"], keyPath: "url",
init: async (table: IDBTable<RelayProfile>) => { init: async (table: IDBTable<RelayProfile>) => {
relays.set(await table.getAll()) relays.set(await table.getAll())
@@ -193,7 +193,7 @@ const relaysAdapter = {
const relayStatsAdapter = { const relayStatsAdapter = {
name: "relayStats", name: "relayStats",
keyPath: ["url"], keyPath: "url",
init: async (table: IDBTable<RelayStats>) => { init: async (table: IDBTable<RelayStats>) => {
relayStats.set(await table.getAll()) relayStats.set(await table.getAll())
@@ -203,7 +203,7 @@ const relayStatsAdapter = {
const handlesAdapter = { const handlesAdapter = {
name: "handles", name: "handles",
keyPath: ["nip05"], keyPath: "nip05",
init: async (table: IDBTable<Handle>) => { init: async (table: IDBTable<Handle>) => {
handles.set(await table.getAll()) handles.set(await table.getAll())
@@ -213,7 +213,7 @@ const handlesAdapter = {
const zappersAdapter = { const zappersAdapter = {
name: "zappers", name: "zappers",
keyPath: ["lnurl"], keyPath: "lnurl",
init: async (table: IDBTable<Zapper>) => { init: async (table: IDBTable<Zapper>) => {
zappers.set(await table.getAll()) zappers.set(await table.getAll())
@@ -225,7 +225,7 @@ type FreshnessItem = {key: string; value: number}
const freshnessAdapter = { const freshnessAdapter = {
name: "freshness", name: "freshness",
keyPath: ["key"], keyPath: "key",
init: async (table: IDBTable<FreshnessItem>) => { init: async (table: IDBTable<FreshnessItem>) => {
const initialRecords = await table.getAll() const initialRecords = await table.getAll()
@@ -241,7 +241,7 @@ type PlaintextItem = {key: string; value: string}
const plaintextAdapter = { const plaintextAdapter = {
name: "plaintext", name: "plaintext",
keyPath: ["key"], keyPath: "key",
init: async (table: IDBTable<PlaintextItem>) => { init: async (table: IDBTable<PlaintextItem>) => {
const initialRecords = await table.getAll() const initialRecords = await table.getAll()
@@ -255,7 +255,7 @@ const plaintextAdapter = {
const wrapManagerAdapter = { const wrapManagerAdapter = {
name: "wrapManager", name: "wrapManager",
keyPath: ["id"], keyPath: "id",
init: async (table: IDBTable<WrapItem>) => { init: async (table: IDBTable<WrapItem>) => {
wrapManager.load(await table.getAll()) wrapManager.load(await table.getAll())

View File

@@ -6,7 +6,7 @@ import type {Maybe} from "@welshman/lib"
export type IDBAdapter = { export type IDBAdapter = {
name: string name: string
keyPath: string[] keyPath: string
init: (table: IDBTable<any>) => Promise<Unsubscriber> init: (table: IDBTable<any>) => Promise<Unsubscriber>
} }

View File

@@ -211,6 +211,7 @@
const seen = new Set() const seen = new Set()
let previousDate let previousDate
let previousKind
let previousPubkey let previousPubkey
let newMessagesSeen = false let newMessagesSeen = false
@@ -247,10 +248,14 @@
id: event.id, id: event.id,
type: "note", type: "note",
value: event, value: event,
showPubkey: date !== previousDate || previousPubkey !== event.pubkey, showPubkey:
date !== previousDate ||
previousPubkey !== event.pubkey ||
[ROOM_ADD_MEMBER, ROOM_REMOVE_MEMBER].includes(previousKind!),
}) })
previousDate = date previousDate = date
previousKind = event.kind
previousPubkey = event.pubkey previousPubkey = event.pubkey
seen.add(event.id) seen.add(event.id)
} }

View File

@@ -136,6 +136,7 @@
const seen = new Set() const seen = new Set()
let previousDate let previousDate
let previousKind
let previousPubkey let previousPubkey
let newMessagesSeen = false let newMessagesSeen = false
@@ -172,10 +173,14 @@
id: event.id, id: event.id,
type: "note", type: "note",
value: event, value: event,
showPubkey: date !== previousDate || previousPubkey !== event.pubkey, showPubkey:
date !== previousDate ||
previousPubkey !== event.pubkey ||
[RELAY_ADD_MEMBER, RELAY_REMOVE_MEMBER].includes(previousKind!),
}) })
previousDate = date previousDate = date
previousKind = event.kind
previousPubkey = event.pubkey previousPubkey = event.pubkey
seen.add(event.id) seen.add(event.id)
} }