feat: 多页面UI打磨 — 设置面板、状态反馈与样式升级
Web Quality / verify (pull_request) Has been cancelled

本次更新对多个功能页面进行了系统性的 UI/UX 打磨,统一了交互模式并补充了缺失的状态反馈。

## 新增功能
- WorkbenchPage: 图片提示词案例区域新增加载骨架屏、错误回退、空数据三种状态展示
- CharacterMixPage: 新增左侧设置面板(驱动提示词、图像检测开关、水印开关),支持清除已上传的人物图/参考视频
- DigitalHumanPage: 新增左侧设置面板(提示词输入、去水印/保留原声开关),支持清除已上传的人像/音频,增加取消生成按钮
- ImageWorkbenchPage / ResolutionUpscalePage: 新增参数设置面板和资产清除交互
- MorePage: 新增页面入口

## UI 优化
- 统一 Toggle 开关组件: 所有设置页面采用一致的 .studio-toggle 交互模式
- 资产清除: 各上传区域新增清除按钮,含二次确认和提示反馈
- 生成按钮: 统一为带图标的 .studio-generate-btn,增加 disabled/loading 状态
- ConversationSidebar / ProjectSidebar: 侧边栏交互细节优化

## 样式升级
- image-workbench.css: 大幅扩展样式 (+1900 行),覆盖设置面板、上传区、结果展示等
- workbench.css: 新增 666 行样式,含骨架屏动画、案例卡片网格、状态占位等
- subtitle-removal.css: 补充设置面板样式
This commit is contained in:
2026-06-10 17:54:45 +08:00
parent 77ffd01a50
commit a6626beb32
15 changed files with 2949 additions and 251 deletions
+46 -22
View File
@@ -2,50 +2,74 @@
display: grid;
grid-template-columns: 1fr 1fr;
gap: 8px;
margin-top: 8px;
margin-top: 0;
}
.subtitle-removal-preset {
display: flex;
flex-direction: column;
display: grid;
grid-template-rows: auto auto 1fr;
justify-items: center;
align-items: center;
gap: 4px;
gap: 6px;
min-width: 0;
min-height: 92px;
padding: 10px 8px;
border: 1.5px solid var(--border-weak, #e5e5e5);
border-radius: 10px;
background: var(--bg-surface, #fff);
border: 1px solid color-mix(in srgb, var(--border-subtle, #333) 82%, white 10%);
border-radius: var(--radius-xs, 8px);
background:
linear-gradient(180deg, rgb(255 255 255 / 0.018), transparent),
var(--bg-inset, #111);
color: var(--fg-muted, #aaa);
cursor: pointer;
transition: border-color 0.15s, background 0.15s;
transition: border-color 0.16s ease, background 0.16s ease, color 0.16s ease, transform 0.16s ease;
}
.subtitle-removal-preset:hover {
border-color: var(--accent, #0d9488);
background: var(--bg-elevated, #f8f8f8);
border-color: color-mix(in srgb, var(--accent, #0d9488) 42%, var(--border-subtle, #333));
background:
linear-gradient(180deg, color-mix(in srgb, var(--accent, #0d9488) 8%, transparent), transparent),
var(--bg-hover, #171717);
color: var(--fg-body, #eee);
transform: translateY(-1px);
}
.subtitle-removal-preset.is-active {
border-color: var(--accent, #0d9488);
background: color-mix(in srgb, var(--accent, #0d9488) 6%, transparent);
border-color: color-mix(in srgb, var(--accent, #0d9488) 72%, transparent);
background: color-mix(in srgb, var(--accent, #0d9488) 13%, var(--bg-inset, #111));
color: var(--accent, #0d9488);
box-shadow: 0 0 0 1px color-mix(in srgb, var(--accent, #0d9488) 8%, transparent) inset;
}
.subtitle-removal-preset strong {
max-width: 100%;
color: var(--fg-body, #eee);
font-size: 12px;
font-weight: 600;
font-weight: 800;
line-height: 1.25;
overflow: hidden;
text-overflow: ellipsis;
white-space: nowrap;
}
.subtitle-removal-preset span {
max-width: 100%;
color: var(--fg-muted, #aaa);
font-size: 11px;
opacity: 0.55;
line-height: 1.35;
opacity: 0.82;
text-align: center;
}
.subtitle-removal-preset__visual {
position: relative;
width: 48px;
height: 32px;
border-radius: 4px;
background: var(--bg-page, #f0f0f0);
border: 1px solid var(--border-weak, #e0e0e0);
width: 54px;
height: 34px;
border: 1px solid color-mix(in srgb, var(--border-subtle, #333) 78%, white 10%);
border-radius: 6px;
background:
linear-gradient(180deg, rgb(255 255 255 / 0.026), transparent),
color-mix(in srgb, var(--bg-elevated, #161616) 92%, black 8%);
box-shadow: 0 1px 0 rgb(255 255 255 / 0.035) inset;
overflow: hidden;
}
@@ -55,9 +79,9 @@
right: 0;
top: var(--region-top);
height: var(--region-height);
background: color-mix(in srgb, var(--accent, #0d9488) 30%, transparent);
border-top: 1.5px dashed var(--accent, #0d9488);
border-bottom: 1.5px dashed var(--accent, #0d9488);
background: color-mix(in srgb, var(--accent, #0d9488) 24%, transparent);
border-top: 1px dashed var(--accent, #0d9488);
border-bottom: 1px dashed var(--accent, #0d9488);
}
.subtitle-removal-preview {