ReceivablePriceRank.vue 2.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899
  1. <!-- 回款金额排行 -->
  2. <template>
  3. <!-- 柱状图 -->
  4. <el-card shadow="never">
  5. <el-skeleton :loading="loading" animated>
  6. <Echart :height="500" :options="echartsOption" />
  7. </el-skeleton>
  8. </el-card>
  9. <!-- 排行列表 -->
  10. <el-card shadow="never" class="mt-16px">
  11. <el-table v-loading="loading" :data="list">
  12. <el-table-column label="公司排名" align="center" type="index" width="80" />
  13. <el-table-column label="签订人" align="center" prop="nickname" min-width="200" />
  14. <el-table-column label="部门" align="center" prop="deptName" min-width="200" />
  15. <el-table-column label="回款金额(元)" align="center" prop="count" min-width="200" />
  16. </el-table>
  17. </el-card>
  18. </template>
  19. <script setup lang="ts">
  20. import { RankApi, BiRankRespVO } from '@/api/crm/bi/rank'
  21. import { EChartsOption } from 'echarts'
  22. import { clone } from 'unocss'
  23. defineOptions({ name: 'ReceivablePriceRank' })
  24. const props = defineProps<{ queryParams: any }>() // 搜索参数
  25. const loading = ref(false) // 加载中
  26. const list = ref<BiRankRespVO[]>([]) // 列表的数据
  27. /** 柱状图配置:横向 */
  28. const echartsOption = reactive<EChartsOption>({
  29. dataset: {
  30. dimensions: ['nickname', 'count'],
  31. source: []
  32. },
  33. grid: {
  34. left: 20,
  35. right: 20,
  36. bottom: 20,
  37. containLabel: true
  38. },
  39. legend: {
  40. top: 50
  41. },
  42. series: [
  43. {
  44. name: '回款金额排行',
  45. type: 'bar'
  46. }
  47. ],
  48. toolbox: {
  49. feature: {
  50. dataZoom: {
  51. yAxisIndex: false // 数据区域缩放:Y 轴不缩放
  52. },
  53. brush: {
  54. type: ['lineX', 'clear'] // 区域缩放按钮、还原按钮
  55. },
  56. saveAsImage: { show: true, name: '回款金额排行' } // 保存为图片
  57. }
  58. },
  59. tooltip: {
  60. trigger: 'axis',
  61. axisPointer: {
  62. type: 'shadow'
  63. }
  64. },
  65. xAxis: {
  66. type: 'value',
  67. name: '回款金额(元)'
  68. },
  69. yAxis: {
  70. type: 'category',
  71. name: '签订人',
  72. nameGap: 30
  73. }
  74. }) as EChartsOption
  75. /** 获取回款金额排行 */
  76. const loadData = async () => {
  77. // 1. 加载排行数据
  78. loading.value = true
  79. const rankingList = await RankApi.getReceivablePriceRank(props.queryParams)
  80. // 2.1 更新 Echarts 数据
  81. if (echartsOption.dataset && echartsOption.dataset['source']) {
  82. echartsOption.dataset['source'] = clone(rankingList).reverse()
  83. }
  84. // 2.2 更新列表数据
  85. list.value = rankingList
  86. loading.value = false
  87. }
  88. defineExpose({ loadData })
  89. /** 初始化 */
  90. onMounted(() => {
  91. loadData()
  92. })
  93. </script>