report.vue 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186
  1. <!-- -->
  2. <template>
  3. <div
  4. class="chart-template"
  5. >
  6. <p>机构统计</p>
  7. <div>
  8. <div class="content">
  9. <span> 行社 56 </span>
  10. <span> 营业网点 2968 </span>
  11. <span> 离行 1202 </span>
  12. <span> 监控中心 100 </span>
  13. </div>
  14. <div class="content">
  15. <span> 达标数 3000 </span>
  16. <span> GA38-2021 2000 </span>
  17. <span> GA38-2015 1000 </span>
  18. </div>
  19. <div class="content">
  20. <span> 业务库 2101 </span>
  21. <span> 一类库 300 </span>
  22. <span> 二类库 457 </span>
  23. <span> 三类库 400 </span>
  24. <span> 四类库 557 </span>
  25. </div>
  26. <div class="content">
  27. <span> 自助银行 4000 </span>
  28. <span> 离行式自助银行 2100 </span>
  29. <span> 在行式自助银行 1900 </span>
  30. </div>
  31. </div>
  32. <!-- <div id="commAlarmEvent_Chart"></div> -->
  33. </div>
  34. </template>
  35. <script>
  36. import "./../../board.scss";
  37. import * as echarts from "echarts";
  38. import {
  39. findMaxIndex,
  40. getChartDOMSize,
  41. getNextPeriod,
  42. getPeriodText,
  43. } from "../../utils.js";
  44. const types = [
  45. {
  46. text: "今天",
  47. value: "0",
  48. },
  49. {
  50. text: "近7天",
  51. value: "1",
  52. },
  53. {
  54. text: "近30天",
  55. value: "2",
  56. },
  57. {
  58. text: "近90天",
  59. value: "3",
  60. },
  61. {
  62. text: "本年",
  63. value: "4",
  64. },
  65. ];
  66. export default {
  67. props: ["orgId"],
  68. data() {
  69. return {
  70. data: {
  71. safetyCheck: {},
  72. edu: {},
  73. drill: {},
  74. monitor: {},
  75. visit: {},
  76. },
  77. activeName: types[0].value,
  78. };
  79. },
  80. components: {},
  81. computed: {},
  82. watch: {
  83. orgId: {
  84. deep: true,
  85. handler(val) {
  86. this.resetTimer();
  87. this.getData();
  88. },
  89. },
  90. },
  91. created() {
  92. this.types = types;
  93. this.maxDisplay = 16;
  94. this.refreshTime = 1 * 10 * 1000;
  95. this.isMouseOver = false;
  96. },
  97. async mounted() {
  98. window.addEventListener("resize", this.windowResize);
  99. },
  100. beforeDestroy() {
  101. this.timer && clearInterval(this.timer);
  102. this.timer = null;
  103. window.removeEventListener("resize", this.windowResize);
  104. },
  105. methods: {
  106. handleClick() {
  107. this.resetTimer();
  108. this.getData();
  109. },
  110. handleMouseEnter() {
  111. this.isMouseOver = true;
  112. },
  113. handleMouseLeave() {
  114. this.isMouseOver = false;
  115. },
  116. async getData() {
  117. let bs = parseInt(this.activeName) + 1;
  118. this.data = {
  119. safetyCheck: {
  120. all: 18 * bs,
  121. completed: 16 * bs,
  122. },
  123. edu: { all: 2 * bs, completed: 1 * bs },
  124. drill: { all: 3 * bs, completed: 2 * bs },
  125. monitor: { all: 66 * bs, completed: 65 * bs },
  126. visit: {
  127. times: 5 * bs,
  128. personCount: 6 * bs,
  129. accompanyCount: 2 * bs,
  130. },
  131. };
  132. },
  133. windowResize() {
  134. this.myChart && this.myChart.resize();
  135. },
  136. resetTimer() {
  137. this.timer && clearInterval(this.timer);
  138. this.timer = setInterval(() => {
  139. if (this.isMouseOver) {
  140. return;
  141. }
  142. this.activeName = getNextPeriod(this.types, this.activeName);
  143. this.getData();
  144. }, this.refreshTime);
  145. },
  146. },
  147. };
  148. </script>
  149. <style lang="scss" scope>
  150. .content {
  151. display: flex;
  152. margin-bottom: 20px;
  153. margin-left: 5px;
  154. margin-right: 5px;
  155. border: solid 1px #b8bdc088;
  156. & > span {
  157. margin-right: 10px;
  158. padding-top: 5px;
  159. padding-bottom: 5px;
  160. height: 30px;
  161. color: rgb(245, 245, 245);
  162. font-size: 14px;
  163. }
  164. & > span:first-child {
  165. width: 100px;
  166. background-color: #b8bdc088;
  167. text-align: center;
  168. }
  169. }
  170. </style>