index.vue 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164
  1. <template>
  2. <div class="app-container">
  3. <el-form :model="queryParams" ref="queryForm" label-width="100px" v-show="showSearch">
  4. <el-row>
  5. <el-col :span="6">
  6. <el-form-item label="告警时间" prop="alarmDateStart">
  7. <el-date-picker v-model="queryParams.alarmDateStart" type="daterange" start-placeholder="开始日期"
  8. end-placeholder="结束日期" format="yyyy-MM-dd" value-format="yyyy-MM-dd" style="width: 100%">
  9. </el-date-picker>
  10. </el-form-item>
  11. </el-col>
  12. <el-col :span="6">
  13. <el-form-item label="告警处理时间" prop="alarmDealDateStart">
  14. <el-date-picker v-model="queryParams.alarmDealDateStart" type="daterange" start-placeholder="开始日期"
  15. end-placeholder="结束日期" format="yyyy-MM-dd" value-format="yyyy-MM-dd" style="width: 100%">
  16. </el-date-picker>
  17. </el-form-item>
  18. </el-col>
  19. <el-col :span="6">
  20. <el-form-item label="告警处理人" prop="alarmDealPeople">
  21. <el-input v-model="queryParams.alarmDealPeople" placeholder="请输入告警处理人" clearable size="small"
  22. @keyup.enter.native="handleQuery" />
  23. </el-form-item>
  24. </el-col>
  25. <el-col :span="6">
  26. <el-form-item label="告警处理结果" prop="alarmDealResult">
  27. <el-select v-model="queryParams.alarmDealResult" placeholder="请选择告警处理结果" clearable style="width: 100%">
  28. <el-option v-for="(item, index) in dealOptions" :key="index.dictValue" :label="item.dictLabel"
  29. :value="item.dictValue" />
  30. </el-select>
  31. </el-form-item>
  32. </el-col>
  33. </el-row>
  34. <el-row v-show="show">
  35. <el-col :span="6">
  36. <el-form-item label="告警位置" prop="alarmLocation">
  37. <el-input v-model="queryParams.alarmLocation" placeholder="请输入告警位置" clearable size="small"
  38. @keyup.enter.native="handleQuery" />
  39. </el-form-item>
  40. </el-col>
  41. <el-col :span="6">
  42. <el-form-item label="设备名" prop="deviceName">
  43. <el-input v-model="queryParams.deviceName" placeholder="请输入设备名" clearable size="small"
  44. @keyup.enter.native="handleQuery" />
  45. </el-form-item>
  46. </el-col>
  47. </el-row>
  48. </el-form>
  49. <div style="display:flex;justify-content: space-between;">
  50. <div>
  51. </div>
  52. <div>
  53. <el-button type="cyan" icon="el-icon-search" size="mini" @click="handleQuery">搜索</el-button>
  54. <el-button icon="el-icon-refresh" size="mini" @click="resetQuery">重置</el-button>
  55. <el-button v-show="show" @click="show = !show" icon="el-icon-arrow-up" size="mini">
  56. 展开
  57. </el-button>
  58. <el-button v-show="!show" @click="show = !show" icon="el-icon-arrow-down" size="mini">
  59. 展开
  60. </el-button>
  61. <right-toolbar style="margin-left: 12px" :showSearch.sync="showSearch" @queryTable="getList"></right-toolbar>
  62. </div>
  63. </div>
  64. <el-table v-loading="loading" :data="list" style="width: 100%;">
  65. <el-table-column label="序号" type="index" width="50" />
  66. <el-table-column v-for="(item, index) in tableOption" :key="index" :label="item.name" :width="item.width"
  67. :prop="item.label" header-align="center" :align="item.align" :fixed="item.fixed" :show-overflow-tooltip="true">
  68. <template slot-scope="scope">
  69. <span v-if="item.label == 'alarmDealResult'">
  70. {{ scope.row.alarmDealResult | dealFormat(dealOptions) }}
  71. </span>
  72. <span v-else-if="item.label == 'deviceState'">
  73. <span>
  74. {{ scope.row.deviceState | deviceFormat(deviceOptions) }}
  75. </span>
  76. </span>
  77. <span v-else>{{ scope.row[item.label] }}</span>
  78. </template>
  79. </el-table-column>
  80. </el-table>
  81. <pagination v-show="total > 0" :total="total" :page.sync="queryParams.pageNum" :limit.sync="queryParams.pageSize" />
  82. </div>
  83. </template>
  84. <script>
  85. import { tableOption } from "./js/index";
  86. import { list } from "@/api/monitor/alrtmList";
  87. import Axios from "axios";
  88. export default {
  89. name: "Online",
  90. data() {
  91. return {
  92. show: false,
  93. tableOption: tableOption,
  94. // 遮罩层
  95. loading: true,
  96. // 总条数
  97. total: 0,
  98. // 表格数据
  99. list: [],
  100. // 查询参数
  101. queryParams: {
  102. pageNum: 1,
  103. pageSize: 10
  104. },
  105. showSearch: true,
  106. dealOptions: [],
  107. deviceOption: [],
  108. };
  109. },
  110. created() {
  111. this.getDicts("alarm_deal_result").then((response) => {
  112. this.dealOptions = response.data;
  113. });
  114. this.getDicts("device_state").then((response) => {
  115. this.deviceOptions = response.data;
  116. });
  117. this.getList();
  118. },
  119. filters: {
  120. dealFormat(row, list) {
  121. let name = ""
  122. list.map((e) => {
  123. if (row == e.dictValue) {
  124. name = e.dictLabel;
  125. }
  126. });
  127. return name;
  128. },
  129. deviceFormat(row, list) {
  130. let name = ""
  131. list.map((e) => {
  132. if (row == e.dictValue) {
  133. name = e.dictLabel;
  134. }
  135. });
  136. return name;
  137. }
  138. },
  139. methods: {
  140. /** 查询登录日志列表 */
  141. getList() {
  142. this.loading = true;
  143. list(this.queryParams).then(response => {
  144. this.list = response.rows;
  145. this.total = response.total;
  146. this.loading = false;
  147. });
  148. },
  149. /** 搜索按钮操作 */
  150. handleQuery() {
  151. this.queryParams.pageNum = 1;
  152. this.getList();
  153. },
  154. /** 重置按钮操作 */
  155. resetQuery() {
  156. this.queryForm = this.$options.data().queryForm
  157. this.handleQuery();
  158. }
  159. }
  160. };
  161. </script>