Files
omniai-web/src/styles/pages/subtitle-removal.css
T
ludan a6626beb32
Web Quality / verify (pull_request) Has been cancelled
feat: 多页面UI打磨 — 设置面板、状态反馈与样式升级
本次更新对多个功能页面进行了系统性的 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: 补充设置面板样式
2026-06-10 17:54:45 +08:00

160 lines
3.9 KiB
CSS

.subtitle-removal-presets {
display: grid;
grid-template-columns: 1fr 1fr;
gap: 8px;
margin-top: 0;
}
.subtitle-removal-preset {
display: grid;
grid-template-rows: auto auto 1fr;
justify-items: center;
align-items: center;
gap: 6px;
min-width: 0;
min-height: 92px;
padding: 10px 8px;
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.16s ease, background 0.16s ease, color 0.16s ease, transform 0.16s ease;
}
.subtitle-removal-preset:hover {
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: 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: 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;
line-height: 1.35;
opacity: 0.82;
text-align: center;
}
.subtitle-removal-preset__visual {
position: relative;
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;
}
.subtitle-removal-preset__region {
position: absolute;
left: 0;
right: 0;
top: var(--region-top);
height: var(--region-height);
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 {
display: flex;
flex-direction: column;
align-items: center;
gap: 16px;
padding: 24px;
width: 100%;
height: 100%;
overflow: auto;
}
.subtitle-removal-preview__video-wrap {
position: relative;
display: flex;
flex-direction: column;
align-items: center;
max-width: 100%;
}
.subtitle-removal-preview__video-wrap video {
max-width: 100%;
max-height: 40vh;
border-radius: 8px;
}
.subtitle-removal-preview__video-wrap h4 {
margin: 0 0 8px;
font-size: 13px;
opacity: 0.7;
}
.subtitle-removal-preview__region-overlay {
position: absolute;
left: 0;
right: 0;
top: var(--region-top);
height: var(--region-height);
background: rgba(13, 148, 136, 0.15);
border-top: 2px dashed rgba(13, 148, 136, 0.6);
border-bottom: 2px dashed rgba(13, 148, 136, 0.6);
pointer-events: none;
border-radius: 2px;
}
.subtitle-removal-preview__actions {
display: flex;
align-items: center;
gap: 8px;
margin-top: 12px;
}
.subtitle-removal-preview__actions button {
display: inline-flex;
align-items: center;
gap: 4px;
padding: 6px 14px;
border: none;
border-radius: var(--radius-sm, 6px);
background: rgba(0, 0, 0, 0.7);
color: #fff;
font-size: 13px;
cursor: pointer;
transition: background 0.15s;
}
.subtitle-removal-preview__actions button:hover:not(:disabled) {
background: var(--accent, #0d9488);
}
.subtitle-removal-preview__actions button:disabled {
opacity: 0.5;
cursor: not-allowed;
}