当前位置: 首页 > news >正文

suna工具调用可视化界面实现原理分析(一)

这是一个基于React构建的工具调用侧边面板组件,主要用于展示和管理自动化工具调用流程。以下是代码功能解析及关键组件分析:


一、核心功能模块

  1. 多工具视图切换系统
    • 动态视图加载:通过getToolView函数根据工具名称(如execute-command/web-search)加载对应的工具视图组件
// 根据工具名称选择对应视图组件
switch(normalizedToolName) {case 'execute-command': return <CommandToolView...>case 'browser-click': return <BrowserToolView...>case 'web-search': return <WebSearchToolView...>
}

• 工具类型覆盖:支持15+种工具类型,包括命令行操作、文件操作、网页抓取等,通过专用视图组件提供定制化展示

  1. 执行状态管理
    • 状态标识系统:使用彩色徽章区分执行状态(成功/失败/运行中)
<div className={cn("px-2.5 py-0.5 rounded-full",isSuccess ? "bg-emerald-50" : "bg-red-50"
)}>{isSuccess ? 'Success' : 'Failed'}
</div>

• 流式加载动画:通过useEffect实现动态点状加载指示器,增强长时间操作的反馈

<CircleDashed className="h-3 w-3 animate-spin" />
  1. 响应式导航系统
    • 移动端适配:使用useIsMobile钩子实现布局切换,移动端显示完整按钮,桌面端使用紧凑导航条
{isMobile ? (<Button onClick={navigateToPrevious}>Previous</Button>
) : (<Slider onValueChange={onNavigate} />
)}

• 步进控制器:支持滑动条导航和分步按钮,展示当前步骤位置(Step 3/10)


二、关键组件及其作用

组件名称功能描述技术亮点
ToolCallSidePanel侧边面板容器组件,管理所有子组件的状态和交互动态高度布局、键盘快捷键监听(CMD+I)、跨组件事件通信
CommandToolView命令行工具展示视图,显示命令执行详情ANSI代码解析、终端样式模拟
BrowserToolView浏览器操作视图,展示网页导航/点击等操作记录DOM操作可视化、操作序列回放
WebSearchToolView网络搜索视图,展示搜索关键词和结果摘要搜索结果分页加载、高亮关键词匹配
DataProviderToolView数据接口调用视图,展示API请求/响应数据JSON语法高亮、请求耗时统计
Slider导航滑动条组件,支持快速跳转到指定步骤平滑动画过渡、触摸事件优化
ChevronLeft/Right导航箭头图标组件,提供前后步骤切换功能动态禁用状态、悬停动效
CircleDashed加载状态图标,表示正在执行中的工具调用CSS旋转动画、状态同步更新

三、交互设计亮点

  1. 状态可视化系统
    • 工具图标动态匹配(通过getToolIcon函数)

    • 移动端折叠状态标签,桌面端显示完整工具名称

    • 错误状态红色边框高亮提示

  2. 性能优化措施
    • 使用React.memo优化工具视图渲染性能

    • 流式内容分块加载(isStreaming状态管理)

    • 导航滑动条的防抖处理

  3. 多端兼容方案

    // 响应式宽度设置
    className={cn(isMobile ? "w-full" : "w-[90%] sm:w-[450px]",!isOpen && "translate-x-full"
    )}

    • 移动端全屏显示

    • 桌面端固定宽度(650px最大)

    • 平滑过渡动画


四、扩展能力分析

  1. 工具类型扩展
    通过新增tool-views目录下的视图组件,可快速接入新工具类型(如新增AIToolView

  2. 状态管理集成
    当前使用props传递状态,可接入Redux/Zustand实现全局状态共享

  3. 数据分析能力
    已包含timestamp时间戳,可扩展执行耗时统计、成功率分析等功能

该组件设计符合现代Web应用开发规范,结合了中提到的富文本编辑器工具栏扩展思路和的React Native工具栏设计理念,实现了企业级工具调用监控系统的核心功能。

相关文章:

suna工具调用可视化界面实现原理分析(一)

这是一个基于React构建的工具调用侧边面板组件&#xff0c;主要用于展示和管理自动化工具调用流程。以下是代码功能解析及关键组件分析&#xff1a; 一、核心功能模块 多工具视图切换系统 • 动态视图加载&#xff1a;通过getToolView函数根据工具名称&#xff08;如execute-c…...

【将你的IDAPython插件迁移到IDA 9.x:核心API变更与升级指南】

文章目录 将你的 IDAPython 插件迁移到 IDA 9.x&#xff1a;核心 API 变更与升级指南为什么 API 会变化&#xff1f;关键不兼容性一&#xff1a;数据库信息访问 (inf_structure)关键不兼容性二&#xff1a;窗口/视图类型判断 (BWN_* 和 form_type)其他可能的 API 变更迁移策略建…...

《Python星球日记》第31天:Django 框架入门

名人说&#xff1a;路漫漫其修远兮&#xff0c;吾将上下而求索。—— 屈原《离骚》 创作者&#xff1a;Code_流苏(CSDN)&#xff08;一个喜欢古诗词和编程的Coder&#x1f60a;&#xff09; 专栏&#xff1a;《Python星球日记》&#xff0c;限时特价订阅中ing 目录 一、Django…...

读《人生道路的选择》有感

读完戴维坎贝尔的《人生道路的选择》&#xff0c;深有感触&#xff0c;虽然只有短短的108也&#xff0c;但作者强调了在复杂的生活环境之中“选择”的重要性。这也是我想要探讨的话题&#xff0c;选择到底会对我们人生产生怎样的影响。 在我们人生当中&#xff0c;确实有许多的…...

opencv+opencv_contrib+cuda和VS2022编译

本文介绍使用OpenCV和OpenCV_Contrib源码及Cuda进行编译的过程&#xff0c;编译过程中会用到OpenCV、OpenCV_Contrib、Toolkit、Cmake、VS2022等工具&#xff0c;最终编译OpenCV的Cuda版本。 一、OpenCV下载地址 OpenCV官网下载地址:https://opencv.org/releases/#&#xff0…...

STC单片机与淘晶驰串口屏通讯例程之01【新建HDMI工程】

大家好,我是『芯知识学堂』的SingleYork,今天笔者给大家一起学习这款“SYK-0806-A2S1”控制板与淘晶驰串口屏通讯的例程,本例使用的是淘晶驰的4.3寸电阻触摸屏TJC4827T143_011R_I_P20,分辨率为480272,详细参数大家可以查看这个屏的手册。 先来看下本例程整体的效果: 那么…...

PE文件结构(导出表)

导出表 什么是导出表&#xff1f; 导出表是PE文件中记录动态链接库&#xff08;DLL&#xff09;对外提供的函数或数据的列表&#xff0c;包含函数名称、序号和内存地址等信息&#xff0c;供其他程序调用 我们写一个dll来查看一下导出函数 int exportFunc1(int a, int b) {ret…...

网络安全自动化:精准把握自动化边界,筑牢企业安全防

在当今数字化时代&#xff0c;网络攻击的威胁日益严峻&#xff0c;企业网络安全的重要性不言而喻。随着海量资产与复杂架构的出现&#xff0c;网络安全自动化成为了众多企业关注的焦点。网络安全维护看似简单的修补系统、删除旧账户、更新软件&#xff0c;在大型企业中却极易变…...

实战设计模式之中介者模式

概述 中介者模式是一种强大且灵活的设计模式&#xff0c;适用于需要优化对象间通信的场景。中介者模式通过引入一个中介对象&#xff0c;来封装一系列对象之间的交互。在没有中介者的情况下&#xff0c;这些对象之间可能会直接相互引用&#xff0c;导致系统中的类紧密耦合&…...

价格识别策略思路

该策略是一种基于价格形态和市场条件的交易算法&#xff0c;旨在通过识别特定的价格模式来生成买入和卖出信号。 价格形态识别 策略的核心在于识别价格的高点和低点形态。通过比较当前周期及其前几个周期的最高价和最低价&#xff0c; 策略定义了一系列条件来判断价格是否形成了…...

Kotlin带接收者的Lambda介绍和应用(封装DialogFragment)

先来看一个具体应用&#xff1a;假设我们有一个App&#xff0c;App中有一个退出应用的按钮&#xff0c;点击该按钮后并不是立即退出&#xff0c;而是先弹出一个对话框&#xff0c;询问用户是否确定要退出&#xff0c;用户点了确定再退出&#xff0c;点取消则不退出&#xff0c;…...

【NLP】32. Transformers (HuggingFace Pipelines 实战)

&#x1f916; Transformers &#xff08;HuggingFace Pipelines 实战&#xff09; 本教程基于 Hugging Face 的 transformers 库&#xff0c;展示如何使用预训练模型完成以下任务&#xff1a; 情感分析&#xff08;Sentiment Analysis&#xff09;文本生成&#xff08;Text …...

[ 设计模式 ] | 单例模式

单例模式是什么&#xff1f;哪两种模式&#xff1f; 单例模式就是一个类型的对象&#xff0c;只有一个&#xff0c;比如说搜索引擎中的索引部分&#xff0c;360安全卫士的桌面悬浮球。 饿汉模式和懒汉模式&#xff1a;饿汉模式是线程安全的&#xff0c;懒汉模式不是线程安全的…...

用网页显示工控仪表

一.起因 现在工控也越来越多的使用web页面来显示电压,电流,温度,转速等物理量.本例使用js控制网页显示速度仪表. 二.代码 <html> <head><script type"text/javascript">var ctx;var px0;var movePoint{x0:0,x1:0};function init(){drawFace();m…...

Spring项目改造Solon版,使用体验,对比

概述 对于Solon有些人可能并不了解&#xff0c;在官方概述中&#xff0c;称其是新一代Java企业级应用开发框架&#xff0c;从零开始构建&#xff0c;有自主的标准规范与开放生态。近16万行代码。 并有更快、更小、更简单的特点 什么样的Java项目用Solon好&#xff1f; 按正常…...

2.CFD 计算过程概述:Fluent在散热计算中的优势

1.主流散热软件 2.电子产品热设计的基本要求 3.失效率与温度之间的关系 4.电子产品热设计的基本要求 5.电子产品必须要做散热设计 6.主动散热与被动散热 7.高效山热方案 8.热交换模型 9.Fluent中传热模型...

【Java ee初阶】多线程(6)

一、阻塞队列 队列的原则&#xff1a;“先进先出”&#xff0c;队列分为普通队列&#xff0c;优先级队列等等。在数据结构中&#xff0c;堆是特殊的完全二叉树&#xff0c;一定不要把堆和二叉搜索树混淆。 阻塞队列是一种特殊的队列&#xff0c;也遵循“先进先出”的原则。 …...

Unity:Surface Effector 2D(表面效应器 2D)

目录 什么是表面效应器 2D&#xff1f; &#x1f3af; 它是做什么的&#xff1f; &#x1f9ea; 从第一性原理解释它是怎么工作的 &#x1f4e6; 重要参数解释 为什么不直接用 Rigidbody&#xff08;刚体&#xff09;来控制运动 &#xff1f; 所以什么时候该用哪个&#…...

Spring 框架的底层原理

Spring 框架的底层原理主要包括以下几个方面&#xff1a; 核心容器&#xff08;IoC 容器&#xff09; IoC&#xff08;控制反转&#xff09;原理 &#xff1a; 依赖注入&#xff08;DI&#xff09; &#xff1a;这是 IoC 的实现方式之一。在传统的程序开发中&#xff0c;程序组…...

【Unity】AssetBundle热更新

1.新建两个预制体&#xff1a; Cube1&#xff1a;GameObject Material1&#xff1a;Material Cube1使用了Material1材质 之后设置打包配置 Cube1的打包配置为custom.ab Material1的打包配置为mat.ab 2.在Asset文件夹下创建Editor文件夹&#xff0c;并在Editor下创建BuildBundle…...

【算法笔记】动态规划基础(二):背包dp

目录 01背包例题状态表示状态计算初始化AC代码 完全背包例题状态表示状态计算初始化TLE代码 多重背包例题状态表示状态计算初始化AC代码 分组背包例题状态表示状态计算初始化AC代码 二维费用背包例题状态表示状态计算初始化AC代码 混合背包问题例题状态表示状态计算初始化TLE代…...

IP属地是我的定位吗?——解析两者区别

在互联网时代&#xff0c;我们经常看到社交媒体、论坛或APP上显示用户的“IP属地”&#xff0c;许多人会疑惑&#xff1a;‌IP属地是不是我的精确定位&#xff1f;它会不会暴露我的隐私&#xff1f;‌ 本文将详细解析IP属地和定位的区别&#xff0c;并解答常见的相关问题&#…...

力扣每日一题1128等价多米诺骨牌对的数量

1128. 等价多米诺骨牌对的数量 题目&#xff1a; 给你一组多米诺骨牌 dominoes 。 形式上&#xff0c;dominoes[i] [a, b] 与 dominoes[j] [c, d] 等价 当且仅当 (a c 且 b d) 或者 (a d 且 b c) 。即一张骨牌可以通过旋转 0 度或 180 度得到另一张多米诺骨牌。 在 0 &l…...

SpringBoot集成CXF框架,实现WebService

SpringBoot官网地址&#xff1a;https://spring.io/projects/spring-ws 1、WebService服务端搭建 Maven依赖 <parent><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-parent</artifactId><version>2.7.17&…...

android-ndk开发(2): macOS 安装 ndk

android-ndk开发(2): macOS 安装 ndk 2025/05/05 1. 概要 对于 android-ndk 在 r23 之前的版本&#xff0c;官方提供了 .zip 文件&#xff0c; 解压即安装。 对于 android-ndk 在 r23 以及之后的版本&#xff0c; 官方只提供了 .dmg 文件&#xff0c; 不能简单的解压完成安…...

科创大赛——知识点复习【c++】——第一篇

目录 输入 一、cin 二、scanf 三、gets 四、getchar 五、fgets 输出 一、cout 二、printf 基本数据类型 一&#xff0c;数据类型有哪些&#xff1f; 二&#xff0c;整型&#xff08;Integer Types&#xff09; 1&#xff0c;修饰符 2&#xff0c;整型数据的数据范…...

硬件工程师面试常见问题(14)

第六十六问&#xff1a;运放--输入偏置电流和输入失调电流 输入偏置电流lb&#xff1a;是由于运放两个输入极都有漏电流的存在。实际的运放,会有电流流入运放的输入端的。那么输入偏置电流就定义这两个电流的平均值。 输入失调电流 Ios&#xff1a;定义为两个差分输入端偏置电…...

Flink流水线任务在线演示

Flink流水线在线演示 1. 登录系统 访问系统登录页面&#xff0c;输入账号密码完成身份验证。 2. 创建任务 入口&#xff1a;通过顶部菜单栏选择 任务开发&#xff0c;或通过快捷入口 快速创建任务。 任务类型&#xff1a;选择 FlinkPipeline。 3. 配置任务 进入配置界面…...

C++笔记之接口`Interface`

C++笔记之接口Interface code review! 一个简洁简短的 C++ 接口实现示例: #include <iostream>// 1. 定义接口(抽象类) class Shape {public:...

css使用aspect-ratio制作4:3和9:16和1:1等等比例布局

文章目录 1. 前言2. 用法2.1 基本语法2.2. 与max-width、max-height等属性结合使用2.3. 动态计算比例 3. 应用场景4. 兼容性和替代方案5. 总结 1. 前言 在网页制作过程中&#xff0c;有时候我们只知道宽度&#xff0c;或者只知道高度&#xff0c;这时候需要制作一个4:3和9:16这…...

深入探索 Apache Spark:从初识到集群运行原理

深入探索 Apache Spark&#xff1a;从初识到集群运行原理 在当今大数据时代&#xff0c;数据如同奔涌的河流&#xff0c;蕴藏着巨大的价值。如何高效地处理和分析这些海量数据&#xff0c;成为各行各业关注的焦点。Apache Spark 正是为此而生的强大引擎&#xff0c;它以其卓越…...

0903Redux改造项目_用户信息_状态管理-react-仿低代码平台项目

文章目录 1 Redux管理用户信息1.1 定义store和reducer1.2 使用useSeletor 2 自定义Hook统一加载用户信息存储Redux3 根据用户登录状态动态跳转页面结语 1 Redux管理用户信息 1.1 定义store和reducer src/store/userReducer.ts代码如下所示&#xff1a; import { createSlice…...

PyTorch_构建线性回归

使用 PyTorch 的 API 来手动构建一个线性回归的假设函数&#xff0c;数据加载器&#xff0c;损失函数&#xff0c;优化方法&#xff0c;绘制训练过程中的损失变化。 数据构建 import torch from sklearn.datasets import make_regression import matplotlib.pyplot as plt i…...

领略算法真谛: 多源bfs

嘿&#xff0c;各位技术潮人&#xff01;好久不见甚是想念。生活就像一场奇妙冒险&#xff0c;而编程就是那把超酷的万能钥匙。此刻&#xff0c;阳光洒在键盘上&#xff0c;灵感在指尖跳跃&#xff0c;让我们抛开一切束缚&#xff0c;给平淡日子加点料&#xff0c;注入满满的pa…...

Linux的web服务器的部署及优化

实验环境的配置 我们依然是要配置本地软件仓库&#xff0c;之前已有详细介绍&#xff0c;然后再次基础上还有如下操作&#xff0c;首先是进入到以下文件进行编辑 编辑内容为下&#xff0c;并且注意自身的网关有没有写错 然后给予权限 再进行下列操作后&#xff0c;就配置完成了…...

ASP.NET Core 请求限速的ActionFilter

文章目录 前言一、实现步骤1&#xff09;创建自定义Action Filter示例1&#xff1a;示例2&#xff1a; 2&#xff09;注册服务3&#xff09;使用 二、实现说明总结 前言 以下是一个基于内存缓存实现的自定义限流Action Filter。 一、实现步骤 1&#xff09;创建自定义Action…...

本地化语音转换工具推荐与使用

软件介绍 Buzz是一款基于OpenAI Whisper技术开发的开源语音转文字工具&#xff0c;支持离线运行和实时语音转换&#xff0c;能够高效完成会议记录、音频转文字等任务。 安装注意事项 在使用Buzz之前需要注意软件的安装设置&#xff0c;由于程序自带较大的模型文件&…...

【心海资源】telegram换U地址完整源码

【心海资源】telegram换U地址完整源码 未测,需要的下载完整的 下载地址&#xff1a;下载地址.txt - 蓝奏云...

神经网络开发实战:从零基础到企业级应用(含CNN、RNN、BP网络代码详解)

简介 神经网络作为深度学习的核心,正在成为现代AI应用的基石。从基础的感知机到复杂的Transformer架构,从图像识别到自然语言处理,神经网络技术的演进推动了人工智能的快速发展。本文将系统介绍神经网络的核心概念、主流模型及其实现原理,并通过三个企业级实战案例(医学图…...

C# WPF 布局

C# 0、WPF 布局 1、ON/OFF按钮 2、textBox 3、ComboBox 4、TabControl 5、Button <Window x:Class"WpfApp5.MainWindow"xmlns"http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x"http://schemas.microsoft.com/winfx/20…...

【PaaS与AI融合】MLOps平台的架构设计

PaaS与AI融合:MLOps平台的架构设计 一、技术背景与发展趋势二、技术架构核心特征1. 全生命周期管理闭环2. 混合编排引擎3. 智能资源调度三、关键技术实现细节1. 持续集成流水线2. 异构资源管理3. 安全治理体系四、行业实践与未来演进典型案例分析发展趋势展望五、架构设计建议…...

硬件工程师面试常见问题(15)

第七十一问&#xff1a;运放增益带宽积解读&#xff08;有待改进&#xff09; 增益带宽积顾名思义&#xff1a;增益&#xff08;就是开环增益&#xff09;与带宽的乘积&#xff1b; 第七十二问&#xff1a;运放输出摆幅 定义&#xff1a;输出摆幅是指输出信号在最大值和最小值…...

SpringMVC——第6章:RESTFul编程风格

一、RESTFul编程风格 1.RESTFul是什么 RESTFul是WEB服务接口的一种设计风格。 RESTFul定义了一组约束条件和规范&#xff0c;可以让WEB服务接口更加简洁、易于理解、易于扩展、安全可靠。 RESTFul对一个WEB服务接口都规定了哪些东西&#xff1f; 对请求的URL格式有约束和规范…...

深度解析:从 GPT-4o“谄媚”到 Deepseek“物理腔”,透视大模型行为模式的底层逻辑与挑战

深度解析&#xff1a;从 GPT-4o“谄媚”到 AI“物理腔”&#xff0c;透视大模型行为模式的底层逻辑与挑战 标签&#xff1a;人工智能, GPT-4o, 大语言模型, AI伦理, 人机交互, 技术思考 大家好&#xff01;最近AI圈最火的“瓜”之一&#xff0c;莫过于OpenAI的GPT-4o模型在一…...

2025 年最新树莓派 Pico 连接 OLED 显示字模汉字详细教程

OLED 概述 OLED&#xff08;Organic Light-Emitting Diode&#xff0c;有机发光二极管&#xff09;是一种基于有机材料的发光技术&#xff0c;通过电流驱动有机薄膜发光&#xff0c;具有自发光、高对比度、柔性可弯曲等特点。 4 针脚 OLED 硬件电路如图所示&#xff0c;GND 接…...

【Ubuntu 安装Docker CE-Jenkins】

安装Docker CE(Ubuntu) Install | Docker Docs官网 使用apt仓库安装 DNS配置(可选) #手动替换 sudo vim /etc/systemd/resolved.conf #典型配置如下 [Resolve] DNS8.8.8.8 DNS114.114.114.114 FallbackDNS1.1.1.1 # 备用 DNS#sed替换 sudo sed -i /^#DNS/ {s/#DNS/DNS8.8.8…...

知识图谱 + 大语言模型:打造更聪明、更可靠的AI大脑 —— 探索 GraphRAG 中文优化与可视化实践

大语言模型&#xff08;LLMs&#xff09;无疑是近年来人工智能领域最耀眼的明星。它们强大的自然语言理解和生成能力&#xff0c;在文本创作、代码生成、对话交互等众多领域展现了惊人的潜力。然而&#xff0c;当前的 LLMs 并非完美无缺&#xff0c;它们常常面临着“幻觉”&…...

三、【LLaMA-Factory实战】模型微调进阶:从LoRA到MoE的技术突破与工程实践

一、引言 在大模型微调领域&#xff0c;选择合适的训练策略直接决定了效率与效果的平衡。LLaMA-Factory深度整合了参数高效微调&#xff08;PEFT&#xff09;、全量微调、混合专家模型&#xff08;MoE&#xff09;等12种训练策略&#xff0c;支持从消费级GPU到多卡集群的全场景…...

Photo-SLAM论文理解、环境搭建、代码理解与实测效果

前言&#xff1a;第一个解耦式Photo-SLAM&#xff0c;亮点和效果。 参考&#xff1a;https://zhuanlan.zhihu.com/p/715311759 全网最细PhotoSLAM的conda环境配置教程&#xff0c;拒绝环境污染&#xff01;&#xff01;-CSDN博客 1. 环境搭建 硬件&#xff1a;RTX 4090D wi…...

解决pycharm检测不到已经装好的conda的pytorch环境

问题 1.找装anaconda的位置&#xff08;我装到了py-anacon下&#xff09; 2.找到下图中的conda.bat 3.pycharm社区版右下角&#xff0c;添加新解释器 4.选conda环境&#xff0c;选择2.中conda.bat的位置&#xff0c;加载环境&#xff0c;使用现有环境&#xff0c;可以看到有选…...