From 5ec239d3abc7f3e96276d1daab44974f01428ca1 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Daphn=C3=A9=20Popin?= Date: Thu, 19 Dec 2024 14:21:19 +0100 Subject: [PATCH] New route + UI to soft delete a tracker --- front/components/trackers/TrackerBuilder.tsx | 65 ++++++++++++- .../spaces/[spaceId]/trackers/[tId]/index.ts | 93 +++++++++++-------- 2 files changed, 118 insertions(+), 40 deletions(-) diff --git a/front/components/trackers/TrackerBuilder.tsx b/front/components/trackers/TrackerBuilder.tsx index 2e8406877b8ac..faf9e0890c644 100644 --- a/front/components/trackers/TrackerBuilder.tsx +++ b/front/components/trackers/TrackerBuilder.tsx @@ -11,6 +11,7 @@ import { useSendNotification, } from "@dust-tt/sparkle"; import type { + APIError, DataSourceViewSelectionConfiguration, DataSourceViewType, SpaceType, @@ -24,9 +25,10 @@ import { TRACKER_FREQUENCIES, } from "@dust-tt/types"; import { useRouter } from "next/router"; -import { useMemo, useState } from "react"; +import { useContext, useMemo, useState } from "react"; import { AdvancedSettings } from "@app/components/assistant_builder/InstructionScreen"; +import { ConfirmContext } from "@app/components/Confirm"; import AppLayout from "@app/components/sparkle/AppLayout"; import { AppLayoutSimpleCloseTitle, @@ -53,10 +55,12 @@ export const TrackerBuilder = ({ initialTrackerId: string | null; }) => { const router = useRouter(); + const confirm = useContext(ConfirmContext); const sendNotification = useSendNotification(); const [edited, setEdited] = useState(false); const [isSubmitting, setIsSubmitting] = useState(false); + const [isDeleting, setIsDeleting] = useState(false); const [showMaintainedDsModal, setShowMaintainedDsModal] = useState(false); const [showWatchedDsModal, setShowWatchedDataSourcesModal] = useState(false); @@ -205,6 +209,54 @@ export const TrackerBuilder = ({ }); }; + const onDelete = async () => { + if (!initialTrackerId) { + // Should never happen. + sendNotification({ + title: "Failed to delete tracker", + description: "Can't delete a tracker that hasn't been created yet.", + type: "error", + }); + return; + } + + if ( + await confirm({ + title: "This can't be undone", + message: "Are you sure you want to delete this tracker?", + validateVariant: "warning", + }) + ) { + setIsDeleting(true); + const res = await fetch( + `/api/w/${owner.sId}/spaces/${globalSpace.sId}/trackers/${initialTrackerId}`, + { + method: "DELETE", + } + ); + if (res.ok) { + setIsDeleting(false); + void router.push(`/w/${owner.sId}/assistant/labs/trackers`); + sendNotification({ + title: "Tracker deleted", + description: "Tracker successfully deleted.", + type: "success", + }); + } else { + setIsDeleting(false); + const err = (await res.json()) as { error: APIError }; + sendNotification({ + title: "Failed to delete tracker", + description: err.error.message, + type: "error", + }); + } + return true; + } else { + return false; + } + }; + const trackableDataSourcesViews = useMemo( () => dataSourceViews.filter( @@ -284,7 +336,16 @@ export const TrackerBuilder = ({
-
+
+ {initialTrackerId && ( +