mirror of
https://github.com/bytedance/deer-flow.git
synced 2026-05-21 23:46:50 +00:00
7de94394d4
* feat: add agent management functionality with creation, editing, and deletion * feat: enhance agent creation and chat experience - Added AgentWelcome component to display agent description on new thread creation. - Improved agent name validation with availability check during agent creation. - Updated NewAgentPage to handle agent creation flow more effectively, including enhanced error handling and user feedback. - Refactored chat components to streamline message handling and improve user experience. - Introduced new bootstrap skill for personalized onboarding conversations, including detailed conversation phases and a structured SOUL.md template. - Updated localization files to reflect new features and error messages. - General code cleanup and optimizations across various components and hooks. * Refactor workspace layout and agent management components - Updated WorkspaceLayout to use useLayoutEffect for sidebar state initialization. - Removed unused AgentFormDialog and related edit functionality from AgentCard. - Introduced ArtifactTrigger component to manage artifact visibility. - Enhanced ChatBox to handle artifact selection and display. - Improved message list rendering logic to avoid loading states. - Updated localization files to remove deprecated keys and add new translations. - Refined hooks for local settings and thread management to improve performance and clarity. - Added temporal awareness guidelines to deep research skill documentation. * feat: refactor chat components and introduce thread management hooks * feat: improve artifact file detail preview logic and clean up console logs * feat: refactor lead agent creation logic and improve logging details * feat: validate agent name format and enhance error handling in agent setup * feat: simplify thread search query by removing unnecessary metadata * feat: update query key in useDeleteThread and useRenameThread for consistency * feat: add isMock parameter to thread and artifact handling for improved testing * fix: reorder import of setup_agent for consistency in builtins module * feat: append mock parameter to thread links in CaseStudySection for testing purposes * fix: update load_agent_soul calls to use cfg.name for improved clarity * fix: update date format in apply_prompt_template for consistency * feat: integrate isMock parameter into artifact content loading for enhanced testing * docs: add license section to SKILL.md for clarity and attribution * feat(agent): enhance model resolution and agent configuration handling * chore: remove unused import of _resolve_model_name from agents * feat(agent): remove unused field * fix(agent): set default value for requested_model_name in _resolve_model_name function * feat(agent): update get_available_tools call to handle optional agent_config and improve middleware function signature --------- Co-authored-by: Willem Jiang <willem.jiang@gmail.com>
100 lines
2.9 KiB
TypeScript
100 lines
2.9 KiB
TypeScript
import { ChevronUpIcon, ListTodoIcon } from "lucide-react";
|
|
import { useState } from "react";
|
|
|
|
import type { Todo } from "@/core/todos";
|
|
import { cn } from "@/lib/utils";
|
|
|
|
import {
|
|
QueueItem,
|
|
QueueItemContent,
|
|
QueueItemIndicator,
|
|
QueueList,
|
|
} from "../ai-elements/queue";
|
|
|
|
export function TodoList({
|
|
className,
|
|
todos,
|
|
collapsed: controlledCollapsed,
|
|
hidden = false,
|
|
onToggle,
|
|
}: {
|
|
className?: string;
|
|
todos: Todo[];
|
|
collapsed?: boolean;
|
|
hidden?: boolean;
|
|
onToggle?: () => void;
|
|
}) {
|
|
const [internalCollapsed, setInternalCollapsed] = useState(true);
|
|
const isControlled = controlledCollapsed !== undefined;
|
|
const collapsed = isControlled ? controlledCollapsed : internalCollapsed;
|
|
|
|
const handleToggle = () => {
|
|
if (isControlled) {
|
|
onToggle?.();
|
|
} else {
|
|
setInternalCollapsed((prev) => !prev);
|
|
}
|
|
};
|
|
|
|
return (
|
|
<div
|
|
className={cn(
|
|
"flex h-fit w-full origin-bottom translate-y-4 flex-col overflow-hidden rounded-t-xl border border-b-0 bg-white backdrop-blur-sm transition-all duration-200 ease-out",
|
|
hidden ? "pointer-events-none translate-y-8 opacity-0" : "",
|
|
className,
|
|
)}
|
|
>
|
|
<header
|
|
className={cn(
|
|
"bg-accent flex min-h-8 shrink-0 cursor-pointer items-center justify-between px-4 text-sm transition-all duration-300 ease-out",
|
|
)}
|
|
onClick={handleToggle}
|
|
>
|
|
<div className="text-muted-foreground">
|
|
<div className="flex items-center justify-center gap-2">
|
|
<ListTodoIcon className="size-4" />
|
|
<div>To-dos</div>
|
|
</div>
|
|
</div>
|
|
<div>
|
|
<ChevronUpIcon
|
|
className={cn(
|
|
"text-muted-foreground size-4 transition-transform duration-300 ease-out",
|
|
collapsed ? "" : "rotate-180",
|
|
)}
|
|
/>
|
|
</div>
|
|
</header>
|
|
<main
|
|
className={cn(
|
|
"bg-accent flex grow px-2 transition-all duration-300 ease-out",
|
|
collapsed ? "h-0 pb-3" : "h-28 pb-4",
|
|
)}
|
|
>
|
|
<QueueList className="bg-background mt-0 w-full rounded-t-xl">
|
|
{todos.map((todo, i) => (
|
|
<QueueItem key={i + (todo.content ?? "")}>
|
|
<div className="flex items-center gap-2">
|
|
<QueueItemIndicator
|
|
className={
|
|
todo.status === "in_progress" ? "bg-primary/70" : ""
|
|
}
|
|
completed={todo.status === "completed"}
|
|
/>
|
|
<QueueItemContent
|
|
className={
|
|
todo.status === "in_progress" ? "text-primary/70" : ""
|
|
}
|
|
completed={todo.status === "completed"}
|
|
>
|
|
{todo.content}
|
|
</QueueItemContent>
|
|
</div>
|
|
</QueueItem>
|
|
))}
|
|
</QueueList>
|
|
</main>
|
|
</div>
|
|
);
|
|
}
|