ztzhjl.vue 6.8 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"
  9. @change="(wpId) => { getWt(wpId, true); }">
  10. <el-option v-for="item in wpArray" :key="item.id" :value="item.id" :label="item.name" />
  11. </el-select>
  12. </div>
  13. </div>
  14. <div class="query-item">
  15. <div class="lable">风机:</div>
  16. <div class="search-input">
  17. <el-select v-model="wtId" clearable placeholder="请选择" popper-class="select">
  18. <el-option v-for="item in wtArray" :key="item.id" :value="item.id" :label="item.name" />
  19. </el-select>
  20. </div>
  21. </div>
  22. <div class="query-item">
  23. <div class="lable">类型:</div>
  24. <div class="search-input">
  25. <el-select v-model="type" clearable placeholder="请选择" popper-class="select">
  26. <el-option v-for="item in typeArray" :key="item.id" :value="item.id" :label="item.name" />
  27. </el-select>
  28. </div>
  29. </div>
  30. <div class="query-item">
  31. <div class="query-item">
  32. <div class="lable">开始日期:</div>
  33. <div class="search-input">
  34. <el-date-picker v-model="value1" @change="BeginChange(value1)" type="date"
  35. value-format="YYYY-MM-DD" placeholder="选择日期" popper-class="date-select">
  36. </el-date-picker>
  37. </div>
  38. </div>
  39. <div class="query-item">
  40. <div class="lable">结束日期:</div>
  41. <div class="search-input">
  42. <el-date-picker v-model="value2" @change="EndChange(value2)" type="date"
  43. value-format="YYYY-MM-DD" placeholder="选择日期" popper-class="date-select">
  44. </el-date-picker>
  45. <div class="unit svg-icon svg-icon-gray">
  46. <svg-icon :svgid="''" />
  47. </div>
  48. </div>
  49. </div>
  50. </div>
  51. </div>
  52. <div class="query-actions" style="margin-right: 1500px">
  53. <button class="btn green" @click="onClickSearch">查询</button>
  54. <button class="btn green" @click="exportCsv">导出</button>
  55. </div>
  56. </div>
  57. <el-row :type="'flex'" class="content">
  58. <el-col :span="12">
  59. <ComTable :data="tableData" height="85vh"></ComTable>
  60. </el-col>
  61. <el-col :span="12">
  62. </el-col>
  63. </el-row>
  64. </div>
  65. </template>
  66. <script>
  67. import ComTable from "@com/coms/table/table.vue";
  68. import Papa from 'papaparse';
  69. export default {
  70. components: {
  71. ComTable,
  72. Papa
  73. },
  74. data() {
  75. return {
  76. value1: "",
  77. value2: "",
  78. wpId: "",
  79. wpArray: [],
  80. wpName: "",
  81. wtId: "",
  82. type: "",
  83. typeArray: [
  84. {
  85. id: 4,
  86. name: '维护'
  87. },
  88. {
  89. id: 2,
  90. name: '故障'
  91. }
  92. ],
  93. tableData: {
  94. column: [{
  95. name: "编号",
  96. field: "index",
  97. is_num: false,
  98. is_light: false,
  99. },
  100. {
  101. name: "转换时间",
  102. field: "time",
  103. is_num: false,
  104. is_light: false,
  105. },
  106. {
  107. name: "转换前类型",
  108. field: "qType",
  109. is_num: false,
  110. is_light: false,
  111. },
  112. {
  113. name: "转换后类型",
  114. field: "hType",
  115. is_num: false,
  116. is_light: false,
  117. }, {
  118. name: "关联风机",
  119. field: "glfj",
  120. is_num: false,
  121. is_light: false,
  122. }
  123. ],
  124. data: [],
  125. },
  126. };
  127. },
  128. created() {
  129. // this.requestSafeList();
  130. this.value1 = new Date((new Date().getTime() - 3600 * 1000 * 24)).formatDate("yyyy-MM-dd");
  131. this.value2 = this.getTime(2);
  132. this.getWp();
  133. this.requestSafeList();
  134. },
  135. methods: {
  136. exportCsv() {
  137. var csv = Papa.unparse(this.tableData);
  138. //定义文件内容,类型必须为Blob 否则createObjectURL会报错
  139. let content = new Blob([csv]);
  140. //生成url对象
  141. let urlObject = window.URL || window.webkitURL || window;
  142. let url = urlObject.createObjectURL(content);
  143. //生成<a></a>DOM元素
  144. let el = document.createElement("a");
  145. //链接赋值
  146. el.href = url;
  147. el.download = "文件导出.cvs";
  148. //必须点击否则不会下载
  149. el.click();
  150. //移除链接释放资源
  151. urlObject.revokeObjectURL(url);
  152. },
  153. getTime(val) { //时间戳处理,val=1是默认开始时间(当前月第一天),val=2是默认结束时间(今天)
  154. var date = new Date();
  155. var year = date.getFullYear(),
  156. month = date.getMonth() + 1,
  157. day = date.getDate();
  158. month >= 1 && month <= 9 ? (month = '0' + month) : '';
  159. day >= 0 && day <= 9 ? (day = '0' + day) : '';
  160. var begin = year + '-' + month + '-01';
  161. var end = year + '-' + month + '-' + day;
  162. if (val == 1) {
  163. return begin;
  164. } else if (val == 2) {
  165. return end;
  166. }
  167. },
  168. // 获取风场
  169. getWp(reGetWp) {
  170. let that = this;
  171. that.API.requestData({
  172. baseURL: "http://10.155.32.4:9001",
  173. subUrl: "benchmarking/wplist",
  174. success(res) {
  175. that.wpArray = res.data;
  176. that.wpId = res.data[0].id;
  177. that.wpName = res.data[0].wpName;
  178. that.getWt(that.wpId, reGetWp);
  179. }
  180. });
  181. },
  182. // 获取风机
  183. getWt(wpid, reGetWp) {
  184. let that = this;
  185. if (that.wpId) {
  186. that.API.requestData({
  187. method: "GET",
  188. baseURL: "http://10.155.32.4:9001",
  189. subUrl: "benchmarking/wtList",
  190. data: {
  191. wpid
  192. },
  193. success(res) {
  194. that.wtArray = res.data;
  195. // that.wtId = res.data[0].id;
  196. }
  197. });
  198. }
  199. },
  200. BeginChange(vl) {
  201. this.value1 = vl;
  202. },
  203. EndChange(vl) {
  204. this.value2 = vl;
  205. },
  206. typeChange(vl) {
  207. this.type = vl;
  208. },
  209. // 搜索按钮
  210. onClickSearch() {
  211. this.requestSafeList();
  212. },
  213. // 获取停机事件
  214. requestSafeList() {
  215. let that = this;
  216. let data = {
  217. tablepar: {
  218. pageNum: 1,
  219. pageSize: 1000,
  220. },
  221. beginDate: that.value1,
  222. endDate: that.value2,
  223. wpId: that.wpId,
  224. };
  225. if (that.wtId != '') data.wtId = that.wtId;
  226. if (that.type != '') data.type = that.type;
  227. this.API.requestData({
  228. method: "POST",
  229. subUrl: "/event/getShutdownevent",
  230. data,
  231. success(res) {
  232. if (res.code == 200) {
  233. that.tableData.data = [];
  234. if (res.data.list.length) {
  235. let data = res.data.list;
  236. // for (var i = 0; i < data.length; i++) {
  237. // let obj = {
  238. // index: i,
  239. // time: data[i].,
  240. // qType: data[i].,
  241. // hType: new Date(data[i].stopTime).formatDate("yyyy-MM-dd hh:mm:ss"),
  242. // glfj: data[i].,
  243. // };
  244. // if (data[i].startTime) obj.startTime = new Date(data[i].startTime).formatDate(
  245. // "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>