gfgj.vue 5.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220
  1. <template>
  2. <div>
  3. <div class="query mg-b-8">
  4. <div class="query-items">
  5. <div class="query-item">
  6. <div class="lable">光伏:</div>
  7. <div class="search-input">
  8. <el-select v-model="wpId" clearable placeholder="请选择" popper-class="select" @change=" (wpId) => { Windturbines(); } ">
  9. <el-option v-for="item in ChangZhan" :key="item.id" :value="item.id" :label="item.name"></el-option>
  10. </el-select>
  11. </div>
  12. </div>
  13. <div class="query-item">
  14. <div class="lable">机组:</div>
  15. <div class="search-input">
  16. <el-select v-model="wtId" placeholder="请选择" popper-class="select">
  17. <el-option v-for="item in windturbines" :key="item.id" :label="item.name" :value="item.id">
  18. </el-option>
  19. </el-select>
  20. </div>
  21. </div>
  22. <div class="query-item">
  23. <div class="lable">描述:</div>
  24. <div class="search-input">
  25. <el-input v-model="alarmDesc" placeholder="报警描述"></el-input>
  26. </div>
  27. </div>
  28. <div class="query-item">
  29. <div class="lable">开始日期:</div>
  30. <div class="search-input">
  31. <el-date-picker v-model="startDate" type="datetime" placeholder="开始日期"
  32. popper-class="date-select" value-format="YYYY-MM-DD HH:mm:ss"></el-date-picker>
  33. </div>
  34. </div>
  35. <div class="query-item">
  36. <div class="lable">结束日期:</div>
  37. <div class="search-input">
  38. <el-date-picker v-model="endDate" type="datetime" placeholder="开始日期" popper-class="date-select"
  39. value-format="YYYY-MM-DD HH:mm:ss"></el-date-picker>
  40. </div>
  41. </div>
  42. <div class="query-actions">
  43. <button class="btn green" @click="getTable()">查询</button>
  44. <button class="btn green" @click="exportExcel()">导出</button>
  45. </div>
  46. </div>
  47. </div>
  48. <div class="table-box">
  49. <div class="title">光伏告警</div>
  50. <ComTable ref="curRef" :data="tableData" :pageSize="20" @onPagging="onChangePage" @sizeChange="sizeChange"
  51. @pageClick="pageClick" height="68vh" v-loading="tableLoading" element-loading-text="拼命加载中.."
  52. element-loading-background="rgba(0, 0, 0, 0.8)"></ComTable>
  53. </div>
  54. </div>
  55. </template>
  56. <script>
  57. import ComTable from "@/components/coms/table/table.vue";
  58. export default {
  59. components: {
  60. ComTable
  61. },
  62. data() {
  63. let that = this;
  64. return {
  65. waitAjax:true,//等待执行完了再加载table
  66. ChangZhan: [],
  67. wpId: "",
  68. wtId: "",
  69. windturbines: [],
  70. alarmDesc: "",
  71. startDate: "",
  72. endDate: "",
  73. tableLoading: true,
  74. pageIndex: 1,
  75. pageSize: 20,
  76. tableData: {
  77. column: [{
  78. name: "场站",
  79. field: "stationName",
  80. is_num: false,
  81. is_light: false,
  82. id: "id",
  83. },
  84. {
  85. name: "机组",
  86. field: "windturbineName",
  87. is_num: false,
  88. is_light: false,
  89. id: "id",
  90. },
  91. {
  92. name: "报警时间",
  93. field: "alertTime",
  94. is_num: false,
  95. is_light: false,
  96. id: "id",
  97. },
  98. {
  99. name: "报警描述",
  100. field: "alertText",
  101. is_num: false,
  102. is_light: false,
  103. id: "id",
  104. },
  105. {
  106. name: "报警类别",
  107. field: "category2",
  108. is_num: false,
  109. is_light: false,
  110. id: "id",
  111. },
  112. {
  113. name: "报警等级",
  114. field: "messageType",
  115. is_num: false,
  116. is_light: false,
  117. sortable: true,
  118. id: "id",
  119. },
  120. ],
  121. data: [],
  122. currentPageTotal: 0,
  123. },
  124. };
  125. },
  126. created() {
  127. let end = new Date();
  128. let start = new Date(end.getTime() - 1 * 24 * 60 * 60 * 1000);
  129. this.endDate = end.formatDate("yyyy-MM-dd hh:mm:ss");
  130. this.startDate = start.formatDate("yyyy-MM-dd hh:mm:ss");
  131. this.ChangZhanVal();
  132. },
  133. methods: {
  134. // 场站
  135. ChangZhanVal() {
  136. var that = this;
  137. that.API.requestData({
  138. method: "GET",
  139. baseURL: "http://10.155.32.4:9001/benchmarking/wpgflist",
  140. success(res) {
  141. that.ChangZhan = res.data;
  142. that.wpId = res.data[0].id;
  143. that.Windturbines(that.wpId)
  144. if(that.waitAjax){
  145. that.getTable();
  146. that.waitAjax=false;
  147. }
  148. },
  149. });
  150. },
  151. Windturbines(wpId) {
  152. let that = this;
  153. that.API.requestData({
  154. method: "GET",
  155. baseURL: "http://10.155.32.4:8082/",
  156. subUrl: "powercompare/windturbineAjax",
  157. data: {
  158. wpId: wpId
  159. },
  160. success(res) {
  161. that.windturbines = res.data;
  162. that.windturbines.unshift({
  163. id: "",
  164. name: "请选择"
  165. });
  166. },
  167. });
  168. },
  169. getTable() {
  170. let that = this;
  171. this.tableLoading = true;
  172. this.API.requestData({
  173. timeout: 30000,
  174. method: "GET",
  175. baseURL: "http://192.168.1.18:8075/",
  176. subUrl: "alarm/history/page2",
  177. data: {
  178. category1: "GF",
  179. stationid: this.wpId,
  180. starttime: this.startDate,
  181. endtime: this.endDate,
  182. keyword: this.alarmDesc,
  183. windturbineid: this.wtId,
  184. pagenum: this.pageIndex,
  185. pagesize: this.pageSize,
  186. },
  187. success(res) {
  188. if (res.data) {
  189. that.tableData.data = res.data.records;
  190. that.tableData.total = res.data.total;
  191. console.log(that.tableData)
  192. } else {
  193. that.tableData.data = [];
  194. that.tableData.total = 0;
  195. }
  196. that.tableLoading = false;
  197. },
  198. });
  199. },
  200. onChangePage(params) {
  201. this.pageIndex = params.pageIndex;
  202. this.pageSize = params.pageSize;
  203. this.getTable();
  204. },
  205. exportExcel() {
  206. let excelData = this.BASE.deepCopy(this.tableData);
  207. this.BASE.exportExcel(excelData, "光伏告警");
  208. },
  209. },
  210. };
  211. </script>
  212. <style lang="less">
  213. .title {
  214. background: rgba(255, 255, 255, 0.1);
  215. margin-bottom: 8px;
  216. padding: 1vh;
  217. }
  218. </style>