From a02c33de41647b8453f417aca9180670af4b241c Mon Sep 17 00:00:00 2001
From: liukangdong <898885815@qq.com>
Date: 星期六, 08 二月 2025 15:34:13 +0800
Subject: [PATCH] ll

---
 admin/src/views/operation/record.vue |  168 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 168 insertions(+), 0 deletions(-)

diff --git a/admin/src/views/operation/record.vue b/admin/src/views/operation/record.vue
index e69de29..a7f872b 100644
--- a/admin/src/views/operation/record.vue
+++ b/admin/src/views/operation/record.vue
@@ -0,0 +1,168 @@
+<template>
+  <div class="main_app">
+    <QueryForm v-model="filters" :query-form-config="queryFormConfig" @handleQuery="getList(1)" @clear="clear" />
+    <div class="mt20">
+      <el-button type="primary" @click="handleEdit()" icon="el-icon-plus"
+        v-permissions="['business:ywpatrolline:create']">鏂板缓</el-button>
+      <el-button type="primary" @click="exportExcel" :loading="isWorking.export" v-permissions="['business:ywpatrolline:create']">瀵煎嚭</el-button>
+    </div>
+    <el-table v-loading="loading" :data="list" stripe>
+      <el-table-column prop="realName" label="杩愮淮浜�" min-width="100" show-overflow-tooltip />
+      <el-table-column prop="deviceCode" label="璁惧缂栧彿" min-width="100" show-overflow-tooltip />
+      <el-table-column prop="deviceName" label="璁惧鍚嶇О" min-width="100" show-overflow-tooltip />
+      <el-table-column prop="status" label="璁惧鐘舵��" min-width="100" show-overflow-tooltip>
+        <template slot-scope="{row}">
+          <span v-if="row.status == 0">姝e父</span>
+          <span v-if="row.status == 1">鎹熷潖</span>
+          <span v-if="row.status == 2">鎶ュ簾</span>
+        </template>
+      </el-table-column>
+      <el-table-column prop="content" label="杩愮淮澶囨敞" min-width="100" show-overflow-tooltip />
+      <el-table-column prop="createDate" label="鍒涘缓鏃堕棿" min-width="140" show-overflow-tooltip />
+      <el-table-column label="鎿嶄綔" min-width="120" fixed="right">
+        <template slot-scope="{row}">
+          <el-button type="text" @click="handleDetail(row)" v-permissions="['business:category:update']">鏌ョ湅</el-button>
+        </template>
+      </el-table-column>
+    </el-table>
+    <div class="mt20">
+      <Pagination @size-change="handleSizeChange" @current-change="getList" :pagination="pagination" />
+    </div>
+    <Edit v-if="showEdit" ref="EditRef" @success="getList" @close="showEdit = false" />
+    <Detail ref="DetailRef" />
+  </div>
+</template>
+
+<script>
+import Pagination from '@/components/common/Pagination'
+import QueryForm from '@/components/common/QueryForm'
+import Edit from './components/maintain.vue'
+import Detail from './components/maintainDetail.vue'
+import { fetchList, deleteById, exportExcel } from '@/api/Inspection/deviceRecord'
+import { ywExportExcel } from '@/api/client/staff'
+export default {
+  components: {
+    Pagination,
+    QueryForm,
+    Edit,
+    Detail
+  },
+  data() {
+    return {
+      loading: false,
+      showEdit: false,
+      pagination: {
+        pageSize: 10,
+        page: 1,
+        total: 0
+      },
+      filters: {},
+      list: [],
+      total: 0,
+      queryFormConfig: {
+        formItems: [
+          {
+            filed: 'name',
+            type: 'input',
+            label: '璁惧鍚嶇О',
+            placeholder: '璇疯緭鍏ヨ澶囧悕绉�/缂栫爜'
+          },
+          {
+            filed: 'selTime',
+            type: 'datetimerange',
+            label: '鍒涘缓鏃堕棿'
+          },
+        ],
+        online: true
+      },
+      isWorking: {
+        export: false
+      }
+    }
+  },
+  created() {
+    this.getList()
+  },
+  methods: {
+    getList(page) {
+      const { pagination, filters } = this
+      this.loading = true
+      fetchList({
+        model: {
+          ...filters,
+        },
+        capacity: pagination.pageSize,
+        page: page || pagination.page,
+      }).then(res => {
+        this.loading = false
+        this.list = res.records || []
+        this.list.forEach(item => {
+          item.stautsName = item.status == 0 ? '姝e父' : item.status == 1 ? '鎹熷潖' : '鎶ュ簾'
+        })
+        this.pagination.total = res.total || 0
+      }, () => {
+        this.loading = false
+      })
+    },
+    handleEdit(row) {
+      this.showEdit = true
+      this.$nextTick(() => {
+        this.$refs.EditRef.isShowModal = true
+        if (row && row.id) {
+          this.$refs.EditRef.getDetail(row.id)
+        }
+      })
+    },
+    handleDetail(row) {
+      this.$refs.DetailRef.visible = true
+      this.$refs.DetailRef.getDetail(row.id)
+    },
+    handleDel(row) {
+      let message = `纭鍒犻櫎璇ヨ褰曞悧?`
+      this.$dialog.deleteConfirm(message)
+        .then(() => {
+          this.isWorking.delete = true
+          deleteById(row.id)
+            .then(() => {
+              this.$tip.apiSuccess('鍒犻櫎鎴愬姛')
+              this.getList()
+            })
+        })
+        .catch(() => { })
+    },
+    clear() {
+      this.filters = {}
+      this.pagination.pageSize = 10
+      this.pagination.page = 1
+      this.getList()
+    },
+    handleSizeChange(capacity) {
+      this.pagination.pageSize = capacity
+      this.getList()
+    },
+    exportExcel () {
+      this.$dialog.exportConfirm('纭瀵煎嚭鍚楋紵')
+        .then(() => {
+          this.isWorking.export = true
+          exportExcel({
+            page: this.pagination.page,
+            capacity: 1000000,
+            model: this.filters
+          })
+            .then(response => {
+              this.download(response)
+            })
+            .catch(e => {
+              this.$tip.apiFailed(e)
+            })
+            .finally(() => {
+              this.isWorking.export = false
+            })
+        })
+        .catch(() => {})
+    },
+  }
+}
+</script>
+
+<style></style>

--
Gitblit v1.9.3