PanelGroup.vue 4.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191
  1. <template>
  2. <el-row :gutter="40" class="panel-group">
  3. <el-col :lg="6" :sm="12" :xs="12" class="card-panel-col">
  4. <div class="card-panel">
  5. <div class="card-panel-icon-wrapper icon-people">
  6. <svg-icon class-name="card-panel-icon" icon-class="dev"/>
  7. </div>
  8. <div class="card-panel-description">
  9. <div class="card-panel-text">
  10. 总设备数
  11. </div>
  12. <count-to :duration="3000" :end-val="devNum" :start-val="0" class="card-panel-num"/>
  13. </div>
  14. </div>
  15. </el-col>
  16. <el-col :lg="6" :sm="12" :xs="12" class="card-panel-col">
  17. <div class="card-panel">
  18. <div class="card-panel-icon-wrapper icon-message">
  19. <svg-icon class-name="card-panel-icon" icon-class="uncheck"/>
  20. </div>
  21. <div class="card-panel-description">
  22. <div class="card-panel-text">
  23. 本月未完成计划
  24. </div>
  25. <count-to :duration="3000" :end-val="uncheckPlanNum" :start-val="0" class="card-panel-num"/>
  26. </div>
  27. </div>
  28. </el-col>
  29. <el-col :lg="6" :sm="12" :xs="12" class="card-panel-col">
  30. <div class="card-panel">
  31. <div class="card-panel-icon-wrapper icon-money">
  32. <svg-icon class-name="card-panel-icon" icon-class="checked"/>
  33. </div>
  34. <div class="card-panel-description">
  35. <div class="card-panel-text">
  36. 本月已完成计划
  37. </div>
  38. <count-to :duration="3000" :end-val="checkedPlanNum" :start-val="0" class="card-panel-num"/>
  39. </div>
  40. </div>
  41. </el-col>
  42. <el-col :lg="6" :sm="12" :xs="12" class="card-panel-col">
  43. <div class="card-panel">
  44. <div class="card-panel-icon-wrapper icon-shopping">
  45. <svg-icon class-name="card-panel-icon" icon-class="issue"/>
  46. </div>
  47. <div class="card-panel-description">
  48. <div class="card-panel-text">
  49. 未处理问题数量
  50. </div>
  51. <count-to :duration="3000" :end-val="issueNum" :start-val="0" class="card-panel-num"/>
  52. </div>
  53. </div>
  54. </el-col>
  55. </el-row>
  56. </template>
  57. <script>
  58. import CountTo from 'vue-count-to'
  59. import {getCountNums} from "@/api/patrol";
  60. export default {
  61. components: {
  62. CountTo
  63. },
  64. data() {
  65. return {
  66. devNum: 0,
  67. uncheckPlanNum: 0,
  68. checkedPlanNum: 0,
  69. issueNum: 0,
  70. }
  71. },
  72. created() {
  73. this.devNum = 1000;
  74. this.uncheckPlanNum = 1000;
  75. this.checkedPlanNum = 1000;
  76. this.issueNum = 1000;
  77. },
  78. }
  79. </script>
  80. <style lang="scss" scoped>
  81. .panel-group {
  82. margin-top: 18px;
  83. .card-panel-col {
  84. margin-bottom: 32px;
  85. }
  86. .card-panel {
  87. height: 108px;
  88. cursor: pointer;
  89. font-size: 12px;
  90. position: relative;
  91. overflow: hidden;
  92. color: #666;
  93. background: #fff;
  94. box-shadow: 4px 4px 40px rgba(0, 0, 0, .05);
  95. border-color: rgba(0, 0, 0, .05);
  96. &:hover {
  97. .card-panel-icon-wrapper {
  98. color: #fff;
  99. }
  100. .icon-people {
  101. background: #40c9c6;
  102. }
  103. .icon-message {
  104. background: #36a3f7;
  105. }
  106. .icon-money {
  107. background: #f4516c;
  108. }
  109. .icon-shopping {
  110. background: #34bfa3
  111. }
  112. }
  113. .icon-people {
  114. color: #40c9c6;
  115. }
  116. .icon-message {
  117. color: #36a3f7;
  118. }
  119. .icon-money {
  120. color: #f4516c;
  121. }
  122. .icon-shopping {
  123. color: #34bfa3
  124. }
  125. .card-panel-icon-wrapper {
  126. float: left;
  127. margin: 14px 0 0 14px;
  128. padding: 16px;
  129. transition: all 0.38s ease-out;
  130. border-radius: 6px;
  131. }
  132. .card-panel-icon {
  133. float: left;
  134. font-size: 48px;
  135. }
  136. .card-panel-description {
  137. float: right;
  138. font-weight: bold;
  139. margin: 26px;
  140. margin-left: 0px;
  141. .card-panel-text {
  142. line-height: 18px;
  143. color: rgba(0, 0, 0, 0.45);
  144. font-size: 16px;
  145. margin-bottom: 12px;
  146. }
  147. .card-panel-num {
  148. font-size: 20px;
  149. }
  150. }
  151. }
  152. }
  153. @media (max-width: 550px) {
  154. .card-panel-description {
  155. display: none;
  156. }
  157. .card-panel-icon-wrapper {
  158. float: none !important;
  159. width: 100%;
  160. height: 100%;
  161. margin: 0 !important;
  162. .svg-icon {
  163. display: block;
  164. margin: 14px auto !important;
  165. float: none !important;
  166. }
  167. }
  168. }
  169. </style>