mirror of
https://git.mirrors.martin98.com/https://github.com/bytedance/deer-flow
synced 2025-08-20 12:29:14 +08:00
feat: add error handling
This commit is contained in:
parent
98494dddbf
commit
f841df834f
33
web/src/app/_components/toaster.tsx
Normal file
33
web/src/app/_components/toaster.tsx
Normal file
@ -0,0 +1,33 @@
|
|||||||
|
// Copyright (c) 2025 Bytedance Ltd. and/or its affiliates
|
||||||
|
// SPDX-License-Identifier: MIT
|
||||||
|
|
||||||
|
"use client";
|
||||||
|
|
||||||
|
import { useTheme } from "next-themes";
|
||||||
|
import { Toaster as Sonner } from "sonner";
|
||||||
|
|
||||||
|
type ToasterProps = React.ComponentProps<typeof Sonner>;
|
||||||
|
|
||||||
|
const Toaster = ({ ...props }: ToasterProps) => {
|
||||||
|
const { resolvedTheme = "dark" } = useTheme();
|
||||||
|
return (
|
||||||
|
<Sonner
|
||||||
|
theme={resolvedTheme as ToasterProps["theme"]}
|
||||||
|
className="toaster group"
|
||||||
|
toastOptions={{
|
||||||
|
classNames: {
|
||||||
|
toast:
|
||||||
|
"group toast group-[.toaster]:bg-background group-[.toaster]:text-foreground group-[.toaster]:border-border group-[.toaster]:shadow-lg",
|
||||||
|
description: "group-[.toast]:text-muted-foreground",
|
||||||
|
actionButton:
|
||||||
|
"group-[.toast]:bg-primary group-[.toast]:text-primary-foreground",
|
||||||
|
cancelButton:
|
||||||
|
"group-[.toast]:bg-muted group-[.toast]:text-muted-foreground",
|
||||||
|
},
|
||||||
|
}}
|
||||||
|
{...props}
|
||||||
|
/>
|
||||||
|
);
|
||||||
|
};
|
||||||
|
|
||||||
|
export { Toaster };
|
@ -6,6 +6,7 @@ import {
|
|||||||
TooltipContent,
|
TooltipContent,
|
||||||
TooltipTrigger,
|
TooltipTrigger,
|
||||||
} from "~/components/ui/tooltip";
|
} from "~/components/ui/tooltip";
|
||||||
|
import { cn } from "~/lib/utils";
|
||||||
|
|
||||||
export function Tooltip({
|
export function Tooltip({
|
||||||
className,
|
className,
|
||||||
@ -25,7 +26,11 @@ export function Tooltip({
|
|||||||
return (
|
return (
|
||||||
<ShadcnTooltip delayDuration={750} open={open}>
|
<ShadcnTooltip delayDuration={750} open={open}>
|
||||||
<TooltipTrigger asChild>{children}</TooltipTrigger>
|
<TooltipTrigger asChild>{children}</TooltipTrigger>
|
||||||
<TooltipContent side={side} sideOffset={sideOffset} className={className}>
|
<TooltipContent
|
||||||
|
side={side}
|
||||||
|
sideOffset={sideOffset}
|
||||||
|
className={cn(className)}
|
||||||
|
>
|
||||||
{title}
|
{title}
|
||||||
</TooltipContent>
|
</TooltipContent>
|
||||||
</ShadcnTooltip>
|
</ShadcnTooltip>
|
||||||
|
@ -9,6 +9,8 @@ import { Geist } from "next/font/google";
|
|||||||
import { ThemeProviderWrapper } from "~/app/_components/theme-provider-wrapper";
|
import { ThemeProviderWrapper } from "~/app/_components/theme-provider-wrapper";
|
||||||
import { TooltipProvider } from "~/components/ui/tooltip";
|
import { TooltipProvider } from "~/components/ui/tooltip";
|
||||||
|
|
||||||
|
import { Toaster } from "./_components/toaster";
|
||||||
|
|
||||||
export const metadata: Metadata = {
|
export const metadata: Metadata = {
|
||||||
title: "🦌 DeerFlow",
|
title: "🦌 DeerFlow",
|
||||||
description:
|
description:
|
||||||
@ -30,6 +32,7 @@ export default function RootLayout({
|
|||||||
<ThemeProviderWrapper>
|
<ThemeProviderWrapper>
|
||||||
<TooltipProvider>{children}</TooltipProvider>
|
<TooltipProvider>{children}</TooltipProvider>
|
||||||
</ThemeProviderWrapper>
|
</ThemeProviderWrapper>
|
||||||
|
<Toaster />
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
);
|
);
|
||||||
|
@ -2,6 +2,7 @@
|
|||||||
// SPDX-License-Identifier: MIT
|
// SPDX-License-Identifier: MIT
|
||||||
|
|
||||||
import { nanoid } from "nanoid";
|
import { nanoid } from "nanoid";
|
||||||
|
import { toast } from "sonner";
|
||||||
import { create } from "zustand";
|
import { create } from "zustand";
|
||||||
|
|
||||||
import { chatStream, generatePodcast } from "../api";
|
import { chatStream, generatePodcast } from "../api";
|
||||||
@ -136,6 +137,7 @@ export async function sendMessage(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
} catch {
|
} catch {
|
||||||
|
toast("An error occurred while generating the response. Please try again.");
|
||||||
// Update message status.
|
// Update message status.
|
||||||
// TODO: const isAborted = (error as Error).name === "AbortError";
|
// TODO: const isAborted = (error as Error).name === "AbortError";
|
||||||
if (messageId != null) {
|
if (messageId != null) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user