2026-06-03 14:59:55 +08:00
|
|
|
|
# 工作台费用统计详情弹窗概念文档
|
|
|
|
|
|
|
|
|
|
|
|
## 功能一句话
|
|
|
|
|
|
|
|
|
|
|
|
在个人工作台的“费用统计”卡片中提供本地弹窗详情,让用户直接查看历史费用分布、单据处理时间和系统操作明细。
|
|
|
|
|
|
|
|
|
|
|
|
## 背景与问题
|
|
|
|
|
|
|
|
|
|
|
|
当前“费用统计”右上角的“查看详情”会进入助手问答,不符合用户期望的“像用户画像一样直接看详情”的操作方式。费用进度区域也存在两个可见性问题:右上角“全部进度”按钮没有实际承载完整列表能力,10 日以上分割标识靠左且不醒目。
|
|
|
|
|
|
|
|
|
|
|
|
本次调整需要让工作台成为个人费用操作的直接入口:用户不离开首页即可理解自己的费用结构、单据流转时间和近期系统动作。
|
|
|
|
|
|
|
|
|
|
|
|
## 目标与非目标
|
|
|
|
|
|
|
|
|
|
|
|
目标:
|
|
|
|
|
|
|
|
|
|
|
|
- 移除“费用进度”右上角的“全部进度”按钮,减少无效操作。
|
|
|
|
|
|
- 将“10日以上”分割标识放在分割线中间,并使用更醒目的主题强调色。
|
|
|
|
|
|
- 将“费用统计”的“查看详情”改为打开详情弹窗。
|
|
|
|
|
|
- 弹窗展示历史报销费用分布、单据处理时间和系统操作详情。
|
|
|
|
|
|
- 数据优先来自 `buildWorkbenchSummary` 已有的当前用户单据汇总,不新增后端接口。
|
|
|
|
|
|
|
|
|
|
|
|
非目标:
|
|
|
|
|
|
|
|
|
|
|
|
- 不新增后端 API。
|
|
|
|
|
|
- 不改变报销单据审批状态计算规则。
|
|
|
|
|
|
- 不替代用户画像详情弹窗。
|
|
|
|
|
|
- 不做复杂图表库接入,避免为了一个工作台弹窗扩大依赖和维护面。
|
|
|
|
|
|
|
|
|
|
|
|
## 用户与场景
|
|
|
|
|
|
|
|
|
|
|
|
主要用户是个人员工和经常处理报销的业务人员。典型场景:
|
|
|
|
|
|
|
|
|
|
|
|
- 在首页查看本月报销情况后,想进一步确认自己的历史费用主要花在哪些类别。
|
|
|
|
|
|
- 想知道近期单据从创建到当前状态大概处理了多久。
|
|
|
|
|
|
- 想复盘系统里最近需要处理或已提醒的费用相关动作。
|
|
|
|
|
|
|
|
|
|
|
|
## 功能能力
|
|
|
|
|
|
|
|
|
|
|
|
### 费用分布
|
|
|
|
|
|
|
2026-06-03 15:31:09 +08:00
|
|
|
|
按单据标题、场景或备注归类费用类型,统计每类金额、单据数量和金额占比。详情区使用项目现有 `DonutChart` 饼图展示费用分布,并通过图例保留金额与占比信息。若数据不足,展示空状态。
|
2026-06-03 14:59:55 +08:00
|
|
|
|
|
|
|
|
|
|
### 处理时间
|
|
|
|
|
|
|
|
|
|
|
|
按单据创建、提交、更新或进度步骤时间推断处理耗时,输出可读的耗时文案,并展示当前状态和节点数量。
|
|
|
|
|
|
|
|
|
|
|
|
### 操作详情
|
|
|
|
|
|
|
|
|
|
|
|
基于待办、通知和进度项生成系统操作明细,帮助用户理解最近有哪些费用动作需要关注。
|
|
|
|
|
|
|
|
|
|
|
|
## 方案设计
|
|
|
|
|
|
|
|
|
|
|
|
前端实现:
|
|
|
|
|
|
|
|
|
|
|
|
- 在 `workbenchSummary.js` 中新增 `expenseStatsDetail` 汇总结构。
|
|
|
|
|
|
- 新增 `ExpenseStatsDetailModal.vue`,复用 Element Plus `ElDialog`、`ElButton`、`ElTag` 的企业后台弹窗体验。
|
2026-06-03 15:31:09 +08:00
|
|
|
|
- 费用分布展示复用现有 `DonutChart`,不手写临时 SVG、Canvas 或 CSS 饼图。
|
2026-06-03 14:59:55 +08:00
|
|
|
|
- 在 `PersonalWorkbench.vue` 中接入弹窗状态,费用统计“查看详情”只打开弹窗。
|
|
|
|
|
|
- 调整 `personal-workbench.css` 中长时间分割标识的居中与强调样式。
|
|
|
|
|
|
|
|
|
|
|
|
数据结构:
|
|
|
|
|
|
|
|
|
|
|
|
```js
|
|
|
|
|
|
expenseStatsDetail: {
|
|
|
|
|
|
distributionRows: [],
|
|
|
|
|
|
processingRows: [],
|
|
|
|
|
|
operationRows: []
|
|
|
|
|
|
}
|
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
|
|
## 算法与公式
|
|
|
|
|
|
|
|
|
|
|
|
费用类型金额占比:
|
|
|
|
|
|
|
|
|
|
|
|
$$
|
|
|
|
|
|
percent_i = \frac{amount_i}{\sum_{k=1}^{n} amount_k} \times 100
|
|
|
|
|
|
$$
|
|
|
|
|
|
|
|
|
|
|
|
单据处理耗时:
|
|
|
|
|
|
|
|
|
|
|
|
$$
|
|
|
|
|
|
duration = latestTime - firstTime
|
|
|
|
|
|
$$
|
|
|
|
|
|
|
|
|
|
|
|
其中 `firstTime` 优先取单据创建时间、提交时间或最早进度步骤时间,`latestTime` 优先取更新时间或最新进度步骤时间。
|
|
|
|
|
|
|
|
|
|
|
|
## 测试方案
|
|
|
|
|
|
|
|
|
|
|
|
- 源码测试确认费用进度不再渲染“全部进度”按钮。
|
|
|
|
|
|
- 源码测试确认“费用统计”的“查看详情”打开弹窗而不是进入助手。
|
|
|
|
|
|
- 单元测试确认 `buildWorkbenchSummary` 能生成费用分布、处理时间和操作明细。
|
2026-06-03 15:31:09 +08:00
|
|
|
|
- 源码测试确认弹窗包含费用分布饼图、处理时间和系统操作详情区块。
|
2026-06-03 14:59:55 +08:00
|
|
|
|
- 运行前端构建验证组件编译通过。
|
|
|
|
|
|
|
|
|
|
|
|
## 指标与验收
|
|
|
|
|
|
|
|
|
|
|
|
- “10日以上”标识位于分割线中间,且使用主题强调色。
|
|
|
|
|
|
- “费用进度”卡片右上角不再出现“全部进度”。
|
|
|
|
|
|
- 点击“费用统计”的“查看详情”打开详情弹窗。
|
2026-06-03 15:31:09 +08:00
|
|
|
|
- 弹窗至少包含费用分布饼图、处理时间、系统操作详情三个信息区。
|
2026-06-03 14:59:55 +08:00
|
|
|
|
- 相关测试与前端构建通过。
|
|
|
|
|
|
|
|
|
|
|
|
## 风险与开放问题
|
|
|
|
|
|
|
|
|
|
|
|
- 当前数据来自工作台前端汇总,历史维度受首页已加载单据范围影响;若后续需要跨年或分页全量统计,应补后端专用接口。
|
|
|
|
|
|
- 单据类型归类依赖标题、场景和备注,属于前端轻量归类;后续可与 ontology 费用类别字段打通。
|
2026-06-03 15:46:51 +08:00
|
|
|
|
|
|
|
|
|
|
## 2026-06-03 饼图呈现修正
|
|
|
|
|
|
|
|
|
|
|
|
费用分布仍复用项目已有 `DonutChart`,但在费用统计详情弹窗内关闭组件自带图例,只保留一个环形饼图入口。费用类型、金额、笔数和占比改为右侧文字明细列表,避免环图主体和双列图例在同一卡片内被误认为出现两个饼图。
|