From 545ee5d21101cdefbb5614377bb4e667b3e92334 Mon Sep 17 00:00:00 2001 From: programminglaboratorys Date: Wed, 2 Oct 2024 17:00:08 +0300 Subject: [PATCH] using useForceUpdater to force re-render --- src/plugins/statusPresets/index.tsx | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/src/plugins/statusPresets/index.tsx b/src/plugins/statusPresets/index.tsx index a3aa022d6..a02c40a44 100644 --- a/src/plugins/statusPresets/index.tsx +++ b/src/plugins/statusPresets/index.tsx @@ -23,6 +23,7 @@ import { getUserSettingLazy } from "@api/UserSettings"; import ErrorBoundary from "@components/ErrorBoundary"; import { Devs } from "@utils/constants"; import { classes } from "@utils/misc"; +import { useForceUpdater } from "@utils/react"; import definePlugin, { OptionType, StartAt } from "@utils/types"; import { findByPropsLazy, findComponentByCodeLazy } from "@webpack"; import { Button, Clickable, Icons, Menu, Toasts, UserStore, useState } from "@webpack/common"; @@ -81,7 +82,7 @@ function StatusIcon({ isHovering, status }: { isHovering: boolean; status: Disco : (status.emojiInfo != null ? :
)}
; } -const RenderStatusMenuItem = ({ status, forceRerender, disabled }: { status: DiscordStatus; forceRerender: () => void; disabled: boolean; }) => { +const RenderStatusMenuItem = ({ status, update, disabled }: { status: DiscordStatus; update: () => void; disabled: boolean; }) => { const [isHovering, setIsHovering] = useState(false); const handleMouseOver = () => { setIsHovering(true); @@ -98,7 +99,7 @@ const RenderStatusMenuItem = ({ status, forceRerender, disabled }: { status: Dis onClick={e => { e.stopPropagation(); settings.store.StatusPresets[status.text] = undefined; // setting to undefined to remove it. - forceRerender(); + update(); }}>
{status.text}
; @@ -106,8 +107,7 @@ const RenderStatusMenuItem = ({ status, forceRerender, disabled }: { status: Dis const StatusSubMenuComponent = () => { - const [, forceUpdate] = useState(0); - const forceRerender = () => forceUpdate(v => v + 1); + const update = useForceUpdater(); return { }}> {Object.entries((settings.store.StatusPresets as { [k: string]: DiscordStatus | undefined; })).map(([index, status]) => status != null ? { action={() => (status.emojiInfo?.id != null && UserStore.getCurrentUser().hasPremiumPerks || status.emojiInfo?.id == null) && setStatus(status)} render={() => } /> : null)}