From 9420c724995018fdcb60a2fc9c08320020c8ecb4 Mon Sep 17 00:00:00 2001 From: Anastasios Date: Fri, 1 Nov 2024 16:30:30 +0400 Subject: [PATCH] fix: manage tokens performance --- .../crypto-asset-item-toggle.tsx | 27 +++++++++++++------ 1 file changed, 19 insertions(+), 8 deletions(-) diff --git a/src/app/components/crypto-asset-item/crypto-asset-item-toggle.tsx b/src/app/components/crypto-asset-item/crypto-asset-item-toggle.tsx index 1c464642d8..f2d897a720 100644 --- a/src/app/components/crypto-asset-item/crypto-asset-item-toggle.tsx +++ b/src/app/components/crypto-asset-item/crypto-asset-item-toggle.tsx @@ -1,4 +1,4 @@ -import { useState } from 'react'; +import { useRef, useState, useTransition } from 'react'; import { useDispatch } from 'react-redux'; import { sanitize } from 'dompurify'; @@ -28,18 +28,29 @@ export function CryptoAssetItemToggle({ const accountIndex = useCurrentAccountIndex(); const dispatch = useDispatch(); - const [isChecked, setIsChecked] = useState(isCheckedByDefault); + const switchRef = useRef(null); + const [_isPending, transition] = useTransition(); function handleSelection(enabled: boolean) { - setIsChecked(enabled); - dispatch( - manageTokensSlice.actions.userTogglesTokenVisibility({ id: assetId, enabled, accountIndex }) - ); + transition(() => { + dispatch( + manageTokensSlice.actions.userTogglesTokenVisibility({ + id: assetId, + enabled, + accountIndex, + }) + ); + }); } const toggle = ( - + @@ -47,7 +58,7 @@ export function CryptoAssetItemToggle({ return ( - handleSelection(!isChecked)} data-testid={sanitize(assetId)}> + switchRef.current?.click()} data-testid={sanitize(assetId)}>