tjsj.vue 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293
  1. <template>
  2. <div class="knowledge-2">
  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) => { getWt(wpId, true); }">
  9. <el-option v-for="item in wpArray" :key="item.id" :value="item.id" :label="item.name" />
  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" clearable placeholder="请选择" popper-class="select">
  17. <el-option v-for="item in wtArray" :key="item.id" :value="item.id" :label="item.name" />
  18. </el-select>
  19. </div>
  20. </div>
  21. <div class="query-item">
  22. <div class="lable">类型:</div>
  23. <div class="search-input">
  24. <el-select v-model="type" clearable placeholder="请选择" popper-class="select">
  25. <el-option v-for="item in typeArray" :key="item.id" :value="item.id" :label="item.name" />
  26. </el-select>
  27. </div>
  28. </div>
  29. <div class="query-item">
  30. <div class="query-item">
  31. <div class="lable">开始日期:</div>
  32. <div class="search-input">
  33. <el-date-picker
  34. v-model="value1"
  35. @change="BeginChange(value1)"
  36. type="date"
  37. value-format="YYYY-MM-DD"
  38. placeholder="选择日期"
  39. popper-class="date-select"
  40. >
  41. </el-date-picker>
  42. </div>
  43. </div>
  44. <div class="query-item">
  45. <div class="lable">结束日期:</div>
  46. <div class="search-input">
  47. <el-date-picker
  48. v-model="value2"
  49. @change="EndChange(value2)"
  50. type="date"
  51. value-format="YYYY-MM-DD"
  52. placeholder="选择日期"
  53. popper-class="date-select"
  54. >
  55. </el-date-picker>
  56. <div class="unit svg-icon svg-icon-gray">
  57. <svg-icon :svgid="''" />
  58. </div>
  59. </div>
  60. </div>
  61. </div>
  62. </div>
  63. <div class="query-actions" style="margin-right: 1500px">
  64. <button class="btn green" @click="onClickSearch">查询</button>
  65. </div>
  66. </div>
  67. <div>
  68. <ComTable :data="tableData" height="85vh"></ComTable>
  69. </div>
  70. </div>
  71. </template>
  72. <script>
  73. import ComTable from "@com/coms/table/table.vue";
  74. export default {
  75. components: { ComTable },
  76. data() {
  77. return {
  78. value1: "",
  79. value2: "",
  80. wpId: "",
  81. wpName: "",
  82. wtId: "",
  83. type: "",
  84. typeArray: [
  85. {
  86. id: 4,
  87. name: '维护'
  88. },
  89. {
  90. id: 2,
  91. name: '故障'
  92. }],
  93. tableData: {
  94. column: [
  95. {
  96. name: "场站",
  97. field: "wpName",
  98. is_num: true,
  99. is_light: false,
  100. },
  101. {
  102. name: "机组",
  103. field: "wtName",
  104. is_num: false,
  105. is_light: false,
  106. },
  107. {
  108. name: "开始时刻",
  109. field: "stopTime",
  110. is_num: false,
  111. is_light: false,
  112. },
  113. {
  114. name: "结束时刻",
  115. field: "startTime",
  116. is_num: false,
  117. is_light: false,
  118. },
  119. {
  120. name: "停机小时数(h)",
  121. field: "stopHours",
  122. is_num: false,
  123. is_light: false,
  124. },
  125. {
  126. name: "状态",
  127. field: "statusName",
  128. is_num: false,
  129. is_light: false,
  130. },
  131. {
  132. name: "停机类型",
  133. field: "warnDesc",
  134. is_num: false,
  135. is_light: false,
  136. },
  137. {
  138. name: "损失电量(kWh)",
  139. field: "lossPower",
  140. is_num: false,
  141. is_light: false,
  142. },
  143. {
  144. name: "报警信息",
  145. field: "handleWay",
  146. is_num: false,
  147. is_light: false,
  148. },
  149. ],
  150. data: [],
  151. },
  152. };
  153. },
  154. created() {
  155. // this.requestSafeList();
  156. this.value1 = this.getTime(1);
  157. this.value2 = this.getTime(2);
  158. this.getWp();
  159. this.requestSafeList();
  160. },
  161. methods: {
  162. getTime(val) { //时间戳处理,val=1是默认开始时间(当前月第一天),val=2是默认结束时间(今天)
  163. var date = new Date();
  164. var year = date.getFullYear(),
  165. month = date.getMonth() + 1,
  166. day = date.getDate();
  167. month >= 1 && month <= 9 ? (month = '0' + month) : '';
  168. day >= 0 && day <= 9 ? (day = '0' + day) : '';
  169. var begin = year + '-' + month + '-01';
  170. var end = year + '-' + month + '-' + day;
  171. if (val == 1) {
  172. return begin;
  173. } else if (val == 2) {
  174. return end;
  175. }
  176. },
  177. // 获取风场
  178. getWp (reGetWp) {
  179. let that = this;
  180. that.API.requestData({
  181. baseURL: "http://10.155.32.4:9001",
  182. subUrl: "benchmarking/wplist",
  183. success (res) {
  184. console.log(11)
  185. that.wpArray = res.data;
  186. that.wpId = res.data[0].id;
  187. that.wpName = res.data[0].wpName;
  188. that.getWt(that.wpId, reGetWp);
  189. }
  190. });
  191. },
  192. // 获取风机
  193. getWt (wpid, reGetWp) {
  194. let that = this;
  195. if (that.wpId) {
  196. that.API.requestData({
  197. method: "GET",
  198. baseURL: "http://10.155.32.4:9001",
  199. subUrl: "benchmarking/wtList",
  200. data: {
  201. wpid
  202. },
  203. success (res) {
  204. that.wtArray = res.data;
  205. // that.wtId = res.data[0].id;
  206. if (!reGetWp) {
  207. that.getTabData();
  208. }
  209. }
  210. });
  211. }
  212. },
  213. BeginChange(vl) {
  214. this.value1 = vl;
  215. },
  216. EndChange(vl) {
  217. this.value2 = vl;
  218. },
  219. typeChange(vl) {
  220. this.type = vl;
  221. },
  222. // 搜索按钮
  223. onClickSearch() {
  224. this.requestSafeList();
  225. },
  226. // 获取停机事件
  227. requestSafeList() {
  228. let that = this;
  229. let data = {
  230. tablepar: {
  231. pageNum: 1,
  232. pageSize: 1000,
  233. },
  234. beginDate: that.value1,
  235. endDate: that.value2,
  236. wpId: that.wpId,
  237. };
  238. if(that.wtId!='') data.wtId=that.wtId;
  239. if(that.type!='') data.type=that.type;
  240. this.API.requestData({
  241. method: "POST",
  242. baseURL: "http://192.168.10.18:8082",
  243. subUrl: "/event/getShutdownevent",
  244. data,
  245. success(res) {
  246. if (res.code == 200) {
  247. that.tableData.data = [];
  248. let data = res.data.list;
  249. console.log(data);
  250. for (var i = 0; i < data.length; i++) {
  251. let obj = {
  252. wpName: data[i].wpName,
  253. wtName: data[i].wtName,
  254. stopTime: new Date(data[i].stopTime).formatDate("yyyy-MM-dd hh:mm:ss"),
  255. stopHours: data[i].stopHours,
  256. statusName: data[i].statusName,
  257. warnDesc: data[i].warnDesc,
  258. lossPower: data[i].lossPower,
  259. handleWay: data[i].handleWay,
  260. };
  261. if(data[i].startTime) obj.startTime=new Date(data[i].startTime).formatDate("yyyy-MM-dd hh:mm:ss");
  262. that.tableData.data.push(obj);
  263. }
  264. }
  265. },
  266. });
  267. },
  268. },
  269. };
  270. </script>
  271. <style lang="less" scope>
  272. @titleGray: #9ca5a8;
  273. @rowGray: #606769;
  274. @darkBack: #536268;
  275. .knowledge-2 {
  276. .el-select {
  277. width: 200px;
  278. }
  279. .el-input {
  280. width: 200px;
  281. }
  282. }
  283. </style>