ContractPriceRank.vue 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105
  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
  16. label="合同金额(元)"
  17. align="center"
  18. prop="count"
  19. min-width="200"
  20. :formatter="erpPriceTableColumnFormatter"
  21. />
  22. </el-table>
  23. </el-card>
  24. </template>
  25. <script setup lang="ts">
  26. import { StatisticsRankApi, StatisticsRankRespVO } from '@/api/crm/statistics/rank'
  27. import { EChartsOption } from 'echarts'
  28. import { clone } from 'lodash-es'
  29. import { erpPriceTableColumnFormatter } from '@/utils'
  30. defineOptions({ name: 'ContractPriceRank' })
  31. const props = defineProps<{ queryParams: any }>() // 搜索参数
  32. const loading = ref(false) // 加载中
  33. const list = ref<StatisticsRankRespVO[]>([]) // 列表的数据
  34. /** 柱状图配置:横向 */
  35. const echartsOption = reactive<EChartsOption>({
  36. dataset: {
  37. dimensions: ['nickname', 'count'],
  38. source: []
  39. },
  40. grid: {
  41. left: 20,
  42. right: 20,
  43. bottom: 20,
  44. containLabel: true
  45. },
  46. legend: {
  47. top: 50
  48. },
  49. series: [
  50. {
  51. name: '合同金额排行',
  52. type: 'bar'
  53. }
  54. ],
  55. toolbox: {
  56. feature: {
  57. dataZoom: {
  58. yAxisIndex: false // 数据区域缩放:Y 轴不缩放
  59. },
  60. brush: {
  61. type: ['lineX', 'clear'] // 区域缩放按钮、还原按钮
  62. },
  63. saveAsImage: { show: true, name: '合同金额排行' } // 保存为图片
  64. }
  65. },
  66. tooltip: {
  67. trigger: 'axis',
  68. axisPointer: {
  69. type: 'shadow'
  70. }
  71. },
  72. xAxis: {
  73. type: 'value',
  74. name: '合同金额(元)'
  75. },
  76. yAxis: {
  77. type: 'category',
  78. name: '签订人'
  79. }
  80. }) as EChartsOption
  81. /** 获取合同金额排行 */
  82. const loadData = async () => {
  83. // 1. 加载排行数据
  84. loading.value = true
  85. const rankingList = await StatisticsRankApi.getContractPriceRank(props.queryParams)
  86. // 2.1 更新 Echarts 数据
  87. if (echartsOption.dataset && echartsOption.dataset['source']) {
  88. echartsOption.dataset['source'] = clone(rankingList).reverse()
  89. }
  90. // 2.2 更新列表数据
  91. list.value = rankingList
  92. loading.value = false
  93. }
  94. defineExpose({ loadData })
  95. /** 初始化 */
  96. onMounted(() => {
  97. loadData()
  98. })
  99. </script>