From e0e28194f63935149a52fb5b94570a844b8f2688 Mon Sep 17 00:00:00 2001 From: codytseng Date: Thu, 3 Apr 2025 14:59:27 +0800 Subject: [PATCH] =?UTF-8?q?fix:=20=F0=9F=90=9B?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- src/components/NotificationList/index.tsx | 5 ++++- src/components/ReplyNoteList/index.tsx | 8 +++++++- 2 files changed, 11 insertions(+), 2 deletions(-) diff --git a/src/components/NotificationList/index.tsx b/src/components/NotificationList/index.tsx index 0f179a94..7e2b1f27 100644 --- a/src/components/NotificationList/index.tsx +++ b/src/components/NotificationList/index.tsx @@ -90,7 +90,10 @@ const NotificationList = forwardRef((_, ref) => { onEvents: (events, eosed) => { if (eventCount > events.length) return eventCount = events.length - setNotifications(events.filter((event) => event.pubkey !== pubkey)) + + if (events.length > 0) { + setNotifications(events.filter((event) => event.pubkey !== pubkey)) + } if (eosed) { setRefreshing(false) setUntil(events.length > 0 ? events[events.length - 1].created_at - 1 : undefined) diff --git a/src/components/ReplyNoteList/index.tsx b/src/components/ReplyNoteList/index.tsx index 589f6f85..35e55319 100644 --- a/src/components/ReplyNoteList/index.tsx +++ b/src/components/ReplyNoteList/index.tsx @@ -96,6 +96,7 @@ export default function ReplyNoteList({ const relayUrls = relayList.read.concat(BIG_RELAY_URLS) const seenOn = client.getSeenEventRelayUrls(rootInfo.id) relayUrls.unshift(...seenOn) + let eventCount = 0 const { closer, timelineKey } = await client.subscribeTimeline( relayUrls.slice(0, 5), { @@ -105,7 +106,12 @@ export default function ReplyNoteList({ }, { onEvents: (evts, eosed) => { - setEvents(evts.filter((evt) => isReplyNoteEvent(evt)).reverse()) + if (eventCount > events.length) return + eventCount = events.length + + if (events.length > 0) { + setEvents(evts.filter((evt) => isReplyNoteEvent(evt)).reverse()) + } if (eosed) { setUntil(evts.length >= LIMIT ? evts[evts.length - 1].created_at - 1 : undefined) setLoading(false)