PanelGroup.vue 3.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  1. <template>
  2. <el-row :gutter="20" class="panel-group">
  3. <el-col :xs="12" :sm="12" :lg="6" class="card-panel-col">
  4. <div class="card-panel" @click="handleSetLineChartData('newVisitis')">
  5. <div class="card-panel-icon-wrapper icon-people">
  6. <svg-icon icon-class="peoples" class-name="card-panel-icon" />
  7. </div>
  8. <div class="card-panel-description">
  9. <div class="card-panel-text">新增用户</div>
  10. <count-to :start-val="0" :end-val="102400" :duration="2600" class="card-panel-num" />
  11. </div>
  12. </div>
  13. </el-col>
  14. <el-col :xs="12" :sm="12" :lg="6" class="card-panel-col">
  15. <div class="card-panel" @click="handleSetLineChartData('messages')">
  16. <div class="card-panel-icon-wrapper icon-message">
  17. <svg-icon icon-class="message" class-name="card-panel-icon" />
  18. </div>
  19. <div class="card-panel-description">
  20. <div class="card-panel-text">未读信息</div>
  21. <count-to :start-val="0" :end-val="81212" :duration="3000" class="card-panel-num" />
  22. </div>
  23. </div>
  24. </el-col>
  25. <el-col :xs="12" :sm="12" :lg="6" class="card-panel-col">
  26. <div class="card-panel" @click="handleSetLineChartData('purchases')">
  27. <div class="card-panel-icon-wrapper icon-money">
  28. <svg-icon icon-class="money" class-name="card-panel-icon" />
  29. </div>
  30. <div class="card-panel-description">
  31. <div class="card-panel-text">成交金额</div>
  32. <count-to :start-val="0" :end-val="9280" :duration="3200" class="card-panel-num" />
  33. </div>
  34. </div>
  35. </el-col>
  36. <el-col :xs="12" :sm="12" :lg="6" class="card-panel-col">
  37. <div class="card-panel" @click="handleSetLineChartData('shoppings')">
  38. <div class="card-panel-icon-wrapper icon-shopping">
  39. <svg-icon icon-class="shopping" class-name="card-panel-icon" />
  40. </div>
  41. <div class="card-panel-description">
  42. <div class="card-panel-text">购物总量</div>
  43. <count-to :start-val="0" :end-val="13600" :duration="3600" class="card-panel-num" />
  44. </div>
  45. </div>
  46. </el-col>
  47. </el-row>
  48. </template>
  49. <script setup lang="ts" name="PanelGroup">
  50. import CountTo from '_c/CountTo/index.vue'
  51. const emit = defineEmits(['handleSetLineChartData'])
  52. function handleSetLineChartData(type: string) {
  53. emit('handleSetLineChartData', type)
  54. }
  55. </script>
  56. <style lang="less" scoped>
  57. .panel-group {
  58. .card-panel-col {
  59. margin-bottom: 20px;
  60. }
  61. .card-panel {
  62. position: relative;
  63. height: 108px;
  64. overflow: hidden;
  65. font-size: 12px;
  66. color: #666;
  67. cursor: pointer;
  68. background: #fff;
  69. border-color: rgba(0, 0, 0, 0.05);
  70. box-shadow: 4px 4px 40px rgba(0, 0, 0, 0.05);
  71. &:hover {
  72. .card-panel-icon-wrapper {
  73. color: #fff;
  74. }
  75. .icon-people {
  76. background: #40c9c6;
  77. }
  78. .icon-message {
  79. background: #36a3f7;
  80. }
  81. .icon-money {
  82. background: #f4516c;
  83. }
  84. .icon-shopping {
  85. background: #34bfa3;
  86. }
  87. }
  88. .icon-people {
  89. color: #40c9c6;
  90. }
  91. .icon-message {
  92. color: #36a3f7;
  93. }
  94. .icon-money {
  95. color: #f4516c;
  96. }
  97. .icon-shopping {
  98. color: #34bfa3;
  99. }
  100. .card-panel-icon-wrapper {
  101. float: left;
  102. padding: 16px;
  103. margin: 14px 0 0 14px;
  104. border-radius: 6px;
  105. transition: all 0.38s ease-out;
  106. }
  107. .card-panel-icon {
  108. float: left;
  109. font-size: 48px;
  110. }
  111. .card-panel-description {
  112. float: right;
  113. margin: 26px;
  114. margin-left: 0;
  115. font-weight: bold;
  116. .card-panel-text {
  117. margin-bottom: 12px;
  118. font-size: 16px;
  119. line-height: 18px;
  120. color: rgba(0, 0, 0, 0.45);
  121. }
  122. .card-panel-num {
  123. font-size: 20px;
  124. }
  125. }
  126. }
  127. }
  128. </style>