workOrderStatistics.vue 2.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111
  1. <template>
  2. <moduleEnclosure title="近30天累计工单统计">
  3. <div class="all-container">
  4. <div class="table-container">
  5. <div class="th row">
  6. <div>订单类型</div>
  7. <div>数量</div>
  8. <div>占比</div>
  9. </div>
  10. <div class="td row">
  11. <div>累计安装台数</div>
  12. <div>{{ statsData.azgd || 0 }}</div>
  13. <div>{{ statsData.azgdzb || 0 }}%</div>
  14. </div>
  15. <div class="td row">
  16. <div>累计维修台数</div>
  17. <div>{{ statsData.wxgd || 0 }}</div>
  18. <div>{{ statsData.wxgdzb || 0 }}%</div>
  19. </div>
  20. <div class="td row">
  21. <div>累计清洗台数</div>
  22. <div>{{ statsData.qxgd || 0 }}</div>
  23. <div>{{ statsData.qxgdzb || 0 }}%</div>
  24. </div>
  25. <!-- <div class="td row">
  26. <div>增值服务工单</div>
  27. <div>{{ statsData.zzgd || 0 }}</div>
  28. <div>{{ statsData.zzgdzb || 0 }}%</div>
  29. </div>
  30. <div class="td row">
  31. <div>维保工程工单</div>
  32. <div>{{ statsData.wbgd || 0 }}</div>
  33. <div>{{ statsData.wbgdzb || 0 }}%</div>
  34. </div> -->
  35. </div>
  36. </div>
  37. </moduleEnclosure>
  38. </template>
  39. <script>
  40. import moduleEnclosure from '@/components/moduleEnclosure.vue'
  41. import { getWorkorderStats } from '@/api/bigView.js'
  42. export default {
  43. components: {
  44. moduleEnclosure
  45. },
  46. data() {
  47. return {
  48. statsData: {}
  49. }
  50. },
  51. mounted() {
  52. this.getData()
  53. },
  54. beforeUnmount() {},
  55. methods: {
  56. getData() {
  57. getWorkorderStats().then(res => {
  58. this.statsData = res.data
  59. })
  60. }
  61. }
  62. }
  63. </script>
  64. <style scoped lang="scss">
  65. .all-container {
  66. width: 100%;
  67. height: 100%;
  68. box-sizing: border-box;
  69. padding-top: 12px;
  70. position: relative;
  71. }
  72. .table-container {
  73. height: 100%;
  74. display: flex;
  75. flex-direction: column;
  76. justify-content: space-between;
  77. .row {
  78. display: flex;
  79. align-items: center;
  80. &.th {
  81. font-weight: bold;
  82. color: #26a3ce;
  83. }
  84. &.td {
  85. color: #ffffff;
  86. div:last-child {
  87. color: #e4f824;
  88. }
  89. div:nth-child(1) {
  90. font-size: 12px;
  91. }
  92. }
  93. div {
  94. flex: 1;
  95. font-size: 14px;
  96. &:nth-child(2) {
  97. text-align: center;
  98. }
  99. &:nth-child(3) {
  100. text-align: right;
  101. }
  102. }
  103. }
  104. }
  105. </style>