213 lines
6.6 KiB
Markdown
213 lines
6.6 KiB
Markdown
# ExportRecordManager 统计卡片最终样式总结
|
|
|
|
## 🎯 最终实现目标
|
|
将 ExportRecordManager 的统计卡片完全对齐到项目中"项目统计"的左右布局样式:**左侧统计信息,右侧图标**。
|
|
|
|
## 📊 参考设计模式
|
|
|
|
### TemplateMatchingResultStatsPanel 的设计模式
|
|
```tsx
|
|
// 项目中标准的统计卡片布局
|
|
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 类(问题:黑底黑字)
|
|
```tsx
|
|
<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>
|
|
```
|
|
|
|
### 第二版 - 项目详情页风格(问题:图标位置不对)
|
|
```tsx
|
|
<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>
|
|
```
|
|
|
|
### 第三版 - 最终版本(完美对齐)
|
|
```tsx
|
|
<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. 智能计算
|
|
```tsx
|
|
// 成功率计算
|
|
{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. 响应式适配
|
|
```tsx
|
|
// 紧凑模式支持
|
|
<p className={`${compact ? 'text-xl' : 'text-2xl'} font-bold text-gray-900`}>
|
|
{statistics.total_exports}
|
|
</p>
|
|
```
|
|
|
|
## ✅ 对齐效果验证
|
|
|
|
### 视觉一致性
|
|
- ✅ **完全匹配**: 与 TemplateMatchingResultStatsPanel 样式完全一致
|
|
- ✅ **布局结构**: 左右布局,左侧信息右侧图标
|
|
- ✅ **颜色系统**: 使用项目标准的语义化颜色
|
|
- ✅ **图标规范**: 统一的图标尺寸和透明度
|
|
|
|
### 功能增强
|
|
- ✅ **数据洞察**: 添加成功率、失败率、平均大小等计算
|
|
- ✅ **信息层次**: 清晰的标题、数值、副标题层次结构
|
|
- ✅ **响应式**: 支持紧凑模式的尺寸调整
|
|
|
|
### 用户体验
|
|
- ✅ **熟悉感**: 与项目其他统计卡片保持一致的使用体验
|
|
- ✅ **可读性**: 清晰的文字层次和颜色对比
|
|
- ✅ **信息密度**: 在有限空间内提供丰富的统计信息
|
|
|
|
## 🔧 技术修复
|
|
|
|
### re_export_record 参数修复
|
|
同时修复了重新导出功能的参数问题:
|
|
|
|
```tsx
|
|
// 修复前 - 缺少 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
|
|
});
|
|
}
|
|
```
|
|
|
|
## 📝 总结
|
|
|
|
这次优化成功实现了:
|
|
|
|
1. **样式完全对齐**: ExportRecordManager 统计卡片与项目统计保持完全一致的左右布局
|
|
2. **功能增强**: 添加了成功率、失败率、平均文件大小等有价值的统计信息
|
|
3. **技术修复**: 解决了重新导出功能的参数错误问题
|
|
4. **用户体验**: 提供了统一、专业、信息丰富的统计展示
|
|
|
|
现在 ExportRecordManager 组件完全融入了项目的设计体系,为用户提供了一致且优秀的使用体验。
|