6.6 KiB
6.6 KiB
ExportRecordManager 统计卡片最终样式总结
🎯 最终实现目标
将 ExportRecordManager 的统计卡片完全对齐到项目中"项目统计"的左右布局样式:左侧统计信息,右侧图标。
📊 参考设计模式
TemplateMatchingResultStatsPanel 的设计模式
// 项目中标准的统计卡片布局
const StatCard = ({ title, value, subtitle, color = 'text-gray-900', icon }) => (
<div className="bg-white rounded-lg shadow-sm border border-gray-200 p-4">
<div className="flex items-center justify-between">
<div>
<p className="text-sm font-medium text-gray-500">{title}</p>
<p className={`text-2xl font-bold ${color}`}>{value}</p>
{subtitle && (
<p className="text-xs text-gray-400 mt-1">{subtitle}</p>
)}
</div>
{icon && (
<div className="text-2xl opacity-60">{icon}</div>
)}
</div>
</div>
);
🔄 样式演进过程
第一版 - 使用 stat-card 类(问题:黑底黑字)
<div className="stat-card primary">
<div className="flex items-center justify-between">
<div>
<div className="text-2xl font-bold text-primary-600">
{statistics.total_exports}
</div>
<div className="text-sm text-gray-600">总导出次数</div>
</div>
<div className="p-3 bg-primary-50 rounded-lg">
<BarChart3 className="w-6 h-6 text-primary-600" />
</div>
</div>
</div>
第二版 - 项目详情页风格(问题:图标位置不对)
<div className="bg-gradient-to-br from-white to-primary-50/30 rounded-xl shadow-sm border border-gray-200/50 p-4 md:p-5 hover:shadow-md transition-all duration-300 hover:-translate-y-1 relative overflow-hidden">
<div className="absolute top-0 right-0 w-16 h-16 bg-gradient-to-br from-primary-100/50 to-primary-200/50 rounded-full -translate-y-8 translate-x-8 opacity-50"></div>
<div className="relative z-10">
<div className="flex items-center justify-between mb-2">
<div className="p-2 bg-primary-100/50 rounded-lg">
<BarChart3 className="w-5 h-5 text-primary-600" />
</div>
</div>
<div className="text-2xl font-bold text-gray-900 mb-1">
{statistics.total_exports}
</div>
<div className="text-sm text-gray-600">总导出次数</div>
</div>
</div>
第三版 - 最终版本(完美对齐)
<div className="bg-white rounded-lg shadow-sm border border-gray-200 p-4">
<div className="flex items-center justify-between">
<div>
<p className="text-sm font-medium text-gray-500">总导出次数</p>
<p className="text-2xl font-bold text-gray-900">
{statistics.total_exports}
</p>
</div>
<div className="text-2xl opacity-60">
<BarChart3 className="w-8 h-8 text-primary-600" />
</div>
</div>
</div>
✨ 最终实现特点
1. 布局结构
- 左右布局:
flex items-center justify-between - 左侧内容: 标题 + 数值 + 副标题(可选)
- 右侧图标: 大尺寸图标,带透明度
2. 样式规范
- 背景:
bg-white纯白背景 - 边框:
border border-gray-200浅灰色边框 - 阴影:
shadow-sm轻微阴影 - 圆角:
rounded-lg标准圆角 - 内边距:
p-4统一内边距
3. 文字层次
- 标题:
text-sm font-medium text-gray-500 - 主数值:
text-2xl font-bold+ 语义化颜色 - 副标题:
text-xs text-gray-400 mt-1
4. 图标设计
- 尺寸:
w-8 h-8较大尺寸 - 透明度:
opacity-60降低视觉权重 - 颜色: 与数值颜色保持一致
📋 四个统计卡片详情
1. 总导出次数
- 颜色:
text-gray-900(中性色) - 图标:
BarChart3(柱状图) - 副标题: 无
2. 成功导出
- 颜色:
text-green-600(成功色) - 图标:
CheckCircle(成功图标) - 副标题: 成功率百分比
3. 失败导出
- 颜色:
text-red-600(错误色) - 图标:
XCircle(失败图标) - 副标题: 失败率百分比
4. 总文件大小
- 颜色:
text-purple-600(紫色) - 图标:
Download(下载图标) - 副标题: 平均文件大小
🎯 增强功能
1. 智能计算
// 成功率计算
{statistics.total_exports > 0 && (
<p className="text-xs text-gray-400 mt-1">
{((statistics.successful_exports / statistics.total_exports) * 100).toFixed(1)}% 成功率
</p>
)}
// 平均文件大小计算
{statistics.total_exports > 0 && (
<p className="text-xs text-gray-400 mt-1">
平均 {formatFileSize(statistics.total_file_size / statistics.total_exports)}
</p>
)}
2. 响应式适配
// 紧凑模式支持
<p className={`${compact ? 'text-xl' : 'text-2xl'} font-bold text-gray-900`}>
{statistics.total_exports}
</p>
✅ 对齐效果验证
视觉一致性
- ✅ 完全匹配: 与 TemplateMatchingResultStatsPanel 样式完全一致
- ✅ 布局结构: 左右布局,左侧信息右侧图标
- ✅ 颜色系统: 使用项目标准的语义化颜色
- ✅ 图标规范: 统一的图标尺寸和透明度
功能增强
- ✅ 数据洞察: 添加成功率、失败率、平均大小等计算
- ✅ 信息层次: 清晰的标题、数值、副标题层次结构
- ✅ 响应式: 支持紧凑模式的尺寸调整
用户体验
- ✅ 熟悉感: 与项目其他统计卡片保持一致的使用体验
- ✅ 可读性: 清晰的文字层次和颜色对比
- ✅ 信息密度: 在有限空间内提供丰富的统计信息
🔧 技术修复
re_export_record 参数修复
同时修复了重新导出功能的参数问题:
// 修复前 - 缺少 newFilePath 参数
await invoke('re_export_record', { recordId });
// 修复后 - 添加文件选择对话框
const { open } = await import('@tauri-apps/plugin-dialog');
const selected = await open({
title: '选择导出路径',
directory: false,
multiple: false,
filters: [
{ name: '剪映项目', extensions: ['json'] },
{ name: '所有文件', extensions: ['*'] }
]
});
if (selected) {
await invoke('re_export_record', {
recordId,
newFilePath: selected
});
}
📝 总结
这次优化成功实现了:
- 样式完全对齐: ExportRecordManager 统计卡片与项目统计保持完全一致的左右布局
- 功能增强: 添加了成功率、失败率、平均文件大小等有价值的统计信息
- 技术修复: 解决了重新导出功能的参数错误问题
- 用户体验: 提供了统一、专业、信息丰富的统计展示
现在 ExportRecordManager 组件完全融入了项目的设计体系,为用户提供了一致且优秀的使用体验。