UI: button style unified

This commit is contained in:
qixinbo
2026-03-29 18:00:00 +08:00
parent e30565d931
commit fb4fc7437f
9 changed files with 66 additions and 68 deletions
+1
View File
@@ -366,6 +366,7 @@
"subagents": "Subagents",
"subagentManagement": "Subagent Management",
"manageSubagentsDesc": "Manage subagents for this project",
"createSubagent": "New Subagent",
"addSubagent": "Add Subagent",
"editSubagent": "Edit Subagent",
"subagentName": "Subagent Name",
+1
View File
@@ -367,6 +367,7 @@
"subagents": "智能体编排",
"subagentManagement": "智能体编排",
"manageSubagentsDesc": "管理该项目的子智能体",
"createSubagent": "新建子智能体",
"addSubagent": "添加子智能体",
"editSubagent": "编辑子智能体",
"subagentName": "子智能体名称",
+5 -5
View File
@@ -346,12 +346,12 @@ export function DataSources() {
return (
<div className="h-full flex flex-col bg-background">
<div className="border-b border-border px-8 py-5 flex items-center justify-between">
<div>
<h1 className="text-2xl font-bold text-foreground">{t('dataSourceConfig')}</h1>
<p className="text-sm text-muted-foreground mt-1">{t('manageDataSourceConnections')}</p>
<div className="h-14 px-6 flex items-center justify-between border-b border-border bg-background">
<div className="flex items-center gap-2 text-foreground/80 font-medium">
<Database className="h-5 w-5 text-indigo-500" />
{t('dataSourceConfig')}
</div>
<Button onClick={handleCreate} className="bg-indigo-600 hover:bg-indigo-700 text-primary-foreground gap-2">
<Button onClick={handleCreate} className="h-9 bg-[#ff4d29] hover:bg-[#ff4d29]/90 text-white gap-2 rounded-md px-3">
<Plus className="h-4 w-4" />
{t('newDataSource')}
</Button>
+5 -5
View File
@@ -406,12 +406,12 @@ export function KnowledgeBases() {
return (
<div className="h-full flex flex-col bg-background">
<div className="border-b border-border px-8 py-5 flex items-center justify-between">
<div>
<h1 className="text-2xl font-bold text-foreground">{t('knowledgeBases')}</h1>
<p className="text-sm text-muted-foreground mt-1">{t('knowledgeBaseSettingsDesc', 'Manage knowledge bases and their documents')}</p>
<div className="h-14 px-6 flex items-center justify-between border-b border-border bg-background">
<div className="flex items-center gap-2 text-foreground/80 font-medium">
<BookOpen className="h-5 w-5 text-indigo-500" />
{t('knowledgeBases')}
</div>
<Button onClick={handleCreateKb} className="bg-indigo-600 hover:bg-indigo-700 text-primary-foreground gap-2" disabled={!currentProject}>
<Button onClick={handleCreateKb} className="h-9 bg-[#ff4d29] hover:bg-[#ff4d29]/90 text-white gap-2 rounded-md px-3" disabled={!currentProject}>
<Plus className="h-4 w-4" />
{t('createKnowledgeBase', 'New Knowledge Base')}
</Button>
+1 -1
View File
@@ -217,7 +217,7 @@ export function ModelConfigs() {
<Button variant="outline" size="icon" className="h-8 w-8 text-muted-foreground" onClick={fetchConfigs}>
<RefreshCw className="h-4 w-4" />
</Button>
<Button className="h-8 px-3 bg-indigo-600 hover:bg-indigo-700 text-primary-foreground text-sm" onClick={openCreate}>
<Button className="h-9 px-3 bg-[#ff4d29] hover:bg-[#ff4d29]/90 text-white text-sm rounded-md" onClick={openCreate}>
<Plus className="h-4 w-4 mr-1" />{t('addModel')}</Button>
</div>
</div>
+3 -2
View File
@@ -82,8 +82,9 @@ export function Projects() {
<Button onClick={() => {
setFormData({ name: '', description: '' });
setIsCreateDialogOpen(true);
}} size="sm" className="gap-2">
<Plus className="h-4 w-4" />{t('newProject')}</Button>
}} className="h-9 gap-2 bg-[#ff4d29] hover:bg-[#ff4d29]/90 text-white rounded-md px-3">
<Plus className="h-4 w-4" />{t('newProject')}
</Button>
</div>
<div className="flex-1 p-6 overflow-auto">
+43 -46
View File
@@ -286,53 +286,50 @@ export function Skills() {
return (
<div className="h-full flex flex-col bg-background overflow-hidden">
<div className="border-b border-border px-8 pt-5 pr-24 bg-background shrink-0">
<div className="flex items-center justify-between mb-4">
<div>
<h1 className="text-2xl font-bold text-foreground flex items-center gap-2">
< Wand2 className="h-6 w-6 text-indigo-500" />{t('skillsRepository')}</h1>
<p className="text-sm text-muted-foreground mt-1">{t('manageAiSkillsDesc')}</p>
</div>
<div className="flex gap-3">
{activeTab === 'skills' ? (
<>
<input
type="file"
ref={fileInputRef}
onChange={handleFileUpload}
className="hidden"
accept=".md,.zip,.tar.gz,.tgz"
/>
<Button
className="bg-indigo-600 hover:bg-indigo-700 text-primary-foreground gap-2"
onClick={() => fileInputRef.current?.click()}
>
<Upload className="h-4 w-4" />{t('uploadSkill')}
</Button>
</>
) : (
<Button
className="bg-indigo-600 hover:bg-indigo-700 text-primary-foreground gap-2"
onClick={() => setIsMcpDialogOpen(true)}
>
<Plus className="h-4 w-4" />{t('addMcpServer')}
</Button>
)}
</div>
<div className="h-14 px-6 flex items-center justify-between border-b border-border bg-background">
<div className="flex items-center gap-2 text-foreground/80 font-medium">
<Wand2 className="h-5 w-5 text-indigo-500" />
{t('skillsRepository')}
</div>
<div className="flex gap-6">
<button
className={`pb-3 text-sm font-medium border-b-2 transition-colors ${activeTab === 'skills' ? 'border-indigo-600 text-indigo-600' : 'border-transparent text-muted-foreground hover:text-foreground/80'}`}
onClick={() => setActiveTab('skills')}
>
{t('skills')}
</button>
<button
className={`pb-3 text-sm font-medium border-b-2 transition-colors ${activeTab === 'mcp' ? 'border-indigo-600 text-indigo-600' : 'border-transparent text-muted-foreground hover:text-foreground/80'}`}
onClick={() => setActiveTab('mcp')}
>
{t('mcpConfig')}
</button>
<div className="flex items-center gap-3">
<div className="flex bg-muted/50 rounded-lg p-1">
<button
className={`px-3 py-1 text-sm font-medium rounded-md transition-colors ${activeTab === 'skills' ? 'bg-background shadow-sm text-foreground' : 'text-muted-foreground hover:text-foreground/80'}`}
onClick={() => setActiveTab('skills')}
>
{t('skills')}
</button>
<button
className={`px-3 py-1 text-sm font-medium rounded-md transition-colors ${activeTab === 'mcp' ? 'bg-background shadow-sm text-foreground' : 'text-muted-foreground hover:text-foreground/80'}`}
onClick={() => setActiveTab('mcp')}
>
{t('mcpConfig')}
</button>
</div>
{activeTab === 'skills' ? (
<>
<input
type="file"
ref={fileInputRef}
onChange={handleFileUpload}
className="hidden"
accept=".md,.zip,.tar.gz,.tgz"
/>
<Button
className="h-9 bg-[#ff4d29] hover:bg-[#ff4d29]/90 text-white gap-2 rounded-md px-3"
onClick={() => fileInputRef.current?.click()}
>
<Upload className="h-4 w-4" />{t('uploadSkill')}
</Button>
</>
) : (
<Button
className="h-9 bg-[#ff4d29] hover:bg-[#ff4d29]/90 text-white gap-2 rounded-md px-3"
onClick={() => setIsMcpDialogOpen(true)}
>
<Plus className="h-4 w-4" />{t('addMcpServer')}
</Button>
)}
</div>
</div>
+6 -8
View File
@@ -130,22 +130,20 @@ export function Subagents() {
return (
<div className="h-full flex flex-col bg-background overflow-hidden">
<div className="border-b border-border px-8 pt-5 pb-5 bg-background shrink-0 flex items-center justify-between">
<div>
<h1 className="text-2xl font-bold text-foreground flex items-center gap-2">
<Bot className="h-6 w-6 text-indigo-500" />{t('subagentManagement', 'Subagent Management')}
</h1>
<p className="text-sm text-muted-foreground mt-1">{t('manageSubagentsDesc', 'Manage subagents for this project')}</p>
<div className="h-14 px-6 flex items-center justify-between border-b border-border bg-background shrink-0">
<div className="flex items-center gap-2 text-foreground/80 font-medium">
<Bot className="h-5 w-5 text-indigo-500" />
{t('subagentManagement', 'Subagent Management')}
</div>
<Button
className="bg-indigo-600 hover:bg-indigo-700 text-primary-foreground gap-2"
className="h-9 bg-[#ff4d29] hover:bg-[#ff4d29]/90 text-white gap-2 rounded-md px-3"
onClick={() => {
setEditingSubagent(null);
setNewSubagent({ name: '', description: '', model: '', instructions: '', status: 'active' });
setIsDialogOpen(true);
}}
>
<Plus className="h-4 w-4" />{t('addSubagent', 'Add Subagent')}
<Plus className="h-4 w-4" />{t('createSubagent', 'New Subagent')}
</Button>
</div>
+1 -1
View File
@@ -121,7 +121,7 @@ export function Users() {
{t('userManagement')}
</div>
<Dialog open={isDialogOpen} onOpenChange={setIsDialogOpen}>
<DialogTrigger className="inline-flex items-center justify-center gap-1.5 whitespace-nowrap text-sm font-medium ring-offset-background transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50 h-8 bg-indigo-600 hover:bg-indigo-700 text-primary-foreground rounded-md px-3" onClick={() => handleOpenDialog()}>
<DialogTrigger className="inline-flex items-center justify-center gap-2 whitespace-nowrap text-sm font-medium ring-offset-background transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50 h-9 bg-[#ff4d29] hover:bg-[#ff4d29]/90 text-white rounded-md px-3" onClick={() => handleOpenDialog()}>
<Plus className="h-4 w-4" />
{t('addUser')}
</DialogTrigger>