tjsj.vue 7.6 KB

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