index.vue 9.0 KB

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