From f9442894af34c007c23fb701e9c824cb44adfee0 Mon Sep 17 00:00:00 2001 From: Philippe Rolet Date: Wed, 27 Nov 2024 11:46:41 +0100 Subject: [PATCH] [Favorites] Disable button while updating (#8936) * [Favorites] Disable button while updating Description --- Fixes https://github.com/dust-tt/dust/issues/8933 Risks --- na Deploy --- front * hover full * better hover handling --- front/components/assistant/AssistantActions.tsx | 4 ++-- .../assistant/AssistantDetailsButtonBar.tsx | 12 +++++++++--- front/components/assistant/AssistantDropdownMenu.tsx | 9 +++------ front/lib/swr/assistants.ts | 9 +++++++-- 4 files changed, 21 insertions(+), 13 deletions(-) diff --git a/front/components/assistant/AssistantActions.tsx b/front/components/assistant/AssistantActions.tsx index 112839fbfbf53..a184a4636c255 100644 --- a/front/components/assistant/AssistantActions.tsx +++ b/front/components/assistant/AssistantActions.tsx @@ -21,7 +21,7 @@ export function RemoveAssistantFromFavoritesDialog({ show: boolean; onClose: () => void; }) { - const doUpdate = useUpdateUserFavorite({ + const { updateUserFavorite } = useUpdateUserFavorite({ owner, agentConfigurationId: agentConfiguration.sId, }); @@ -34,7 +34,7 @@ export function RemoveAssistantFromFavoritesDialog({ validateLabel="Remove" validateVariant="warning" onValidate={async () => { - void doUpdate(false); + void updateUserFavorite(false); onClose(); }} > diff --git a/front/components/assistant/AssistantDetailsButtonBar.tsx b/front/components/assistant/AssistantDetailsButtonBar.tsx index dbfefa8f89aae..4caa9167b8e3d 100644 --- a/front/components/assistant/AssistantDetailsButtonBar.tsx +++ b/front/components/assistant/AssistantDetailsButtonBar.tsx @@ -42,7 +42,7 @@ export function AssistantDetailsButtonBar({ const [showDeletionModal, setShowDeletionModal] = useState(false); const router = useRouter(); - const updateUserFavorite = useUpdateUserFavorite({ + const { updateUserFavorite, isUpdatingFavorite } = useUpdateUserFavorite({ owner, agentConfigurationId: agentConfiguration.sId, }); @@ -122,18 +122,24 @@ export function AssistantDetailsButtonBar({
diff --git a/front/components/assistant/AssistantDropdownMenu.tsx b/front/components/assistant/AssistantDropdownMenu.tsx index dc3e64d070df1..89b0a510dd5cd 100644 --- a/front/components/assistant/AssistantDropdownMenu.tsx +++ b/front/components/assistant/AssistantDropdownMenu.tsx @@ -48,13 +48,12 @@ export function AssistantDropdownMenu({ isMoreInfoVisible, showAddRemoveToFavorite = false, }: AssistantDetailsMenuProps) { - const [isUpdatingFavorites, setIsUpdatingFavorite] = useState(false); const [showDeletionModal, setShowDeletionModal] = useState(false); const router = useRouter(); const { user } = useUser(); - const doFavoriteUpdate = useUpdateUserFavorite({ + const { updateUserFavorite, isUpdatingFavorite } = useUpdateUserFavorite({ owner, agentConfigurationId: agentConfiguration.sId, }); @@ -79,9 +78,7 @@ export function AssistantDropdownMenu({ const allowDeletion = canDelete && (isBuilder(owner) || !isAgentWorkspace); const updateFavorite = async (favorite: boolean) => { - setIsUpdatingFavorite(true); - await doFavoriteUpdate(favorite); - setIsUpdatingFavorite(false); + await updateUserFavorite(favorite); }; const dropdownButton = (() => { @@ -163,7 +160,7 @@ export function AssistantDropdownMenu({ { e.stopPropagation(); await updateFavorite(!isFavorite); diff --git a/front/lib/swr/assistants.ts b/front/lib/swr/assistants.ts index 892385c950ef8..7fe23cddd775c 100644 --- a/front/lib/swr/assistants.ts +++ b/front/lib/swr/assistants.ts @@ -6,7 +6,7 @@ import type { LightAgentConfigurationType, LightWorkspaceType, } from "@dust-tt/types"; -import { useCallback, useMemo } from "react"; +import { useCallback, useMemo, useState } from "react"; import type { Fetcher } from "swr"; import { useSWRConfig } from "swr"; @@ -426,8 +426,11 @@ export function useUpdateUserFavorite({ disabled: true, }); + const [isUpdatingFavorite, setIsUpdatingFavorite] = useState(false); + const doUpdate = useCallback( async (userFavorite: boolean) => { + setIsUpdatingFavorite(true); try { const body: PostAgentUserFavoriteRequestBody = { agentId: agentConfigurationId, @@ -471,6 +474,8 @@ export function useUpdateUserFavorite({ type: "error", }); return false; + } finally { + setIsUpdatingFavorite(false); } }, [ @@ -481,5 +486,5 @@ export function useUpdateUserFavorite({ sendNotification, ] ); - return doUpdate; + return { updateUserFavorite: doUpdate, isUpdatingFavorite }; }