From 91912f7cd43992092a49eb539534472a123ea705 Mon Sep 17 00:00:00 2001
From: spring <2396852758@qq.com>
Date: 星期五, 07 三月 2025 10:31:05 +0800
Subject: [PATCH] 搬迁量值溯源计划

---
 src/api/cnas/resourceDemand/quantityTraceabilityPlan.js                       |   38 ++++
 src/views/CNAS/resourceDemand/quantityTraceabilityPlan/index.vue              |  304 +++++++++++++++++++++++++++++++++
 src/layout/components/AppMain.vue                                             |    6 
 src/views/CNAS/resourceDemand/quantityTraceabilityPlan/components/formDia.vue |  148 ++++++++++++++++
 4 files changed, 493 insertions(+), 3 deletions(-)

diff --git a/src/api/cnas/resourceDemand/quantityTraceabilityPlan.js b/src/api/cnas/resourceDemand/quantityTraceabilityPlan.js
new file mode 100644
index 0000000..b6c4b98
--- /dev/null
+++ b/src/api/cnas/resourceDemand/quantityTraceabilityPlan.js
@@ -0,0 +1,38 @@
+import request from "@/utils/request";
+
+// 閲忓�兼函婧愯鍒� 瀵煎嚭
+export function exportOfValueTraceabilityPlan(query) {
+  return request({
+    url: "/feCalibrationSchedule/exportOfValueTraceabilityPlan",
+    method: "get",
+    params: query,
+    responseType: "blob",
+  });
+}
+
+//閲忓�兼函婧愯鍒掓煡璇�
+export function getPageCalibrationSchedule(query) {
+  return request({
+    url: "/feCalibrationSchedule/getPageCalibrationSchedule",
+    method: "get",
+    params: query,
+  });
+}
+
+//鍒犻櫎閲忓�兼函婧愯鍒�
+export function removeCalibrationSchedule(query) {
+  return request({
+    url: "/feCalibrationSchedule/removeCalibrationSchedule",
+    method: "delete",
+    params: query,
+  });
+}
+
+// 閲忓�兼函婧愯鍒掓柊澧炵紪杈�
+export function addCalibrationSchedule(data) {
+  return request({
+    url: "/feCalibrationSchedule/addCalibrationSchedule",
+    method: "post",
+    data: data,
+  });
+}
diff --git a/src/layout/components/AppMain.vue b/src/layout/components/AppMain.vue
index b7865c9..f6b608c 100644
--- a/src/layout/components/AppMain.vue
+++ b/src/layout/components/AppMain.vue
@@ -50,10 +50,10 @@
   width: 100%;
   position: relative;
   overflow: hidden;
-  background: rgb(245, 247, 251);
+  // background: rgb(245, 247, 251);
 }
 
-.fixed-header + .app-main {
+.fixed-header+.app-main {
   padding-top: 50px;
 }
 
@@ -63,7 +63,7 @@
     min-height: calc(100vh - 94px);
   }
 
-  .fixed-header + .app-main {
+  .fixed-header+.app-main {
     padding-top: 84px;
   }
 }
diff --git a/src/views/CNAS/resourceDemand/quantityTraceabilityPlan/components/formDia.vue b/src/views/CNAS/resourceDemand/quantityTraceabilityPlan/components/formDia.vue
new file mode 100644
index 0000000..55241da
--- /dev/null
+++ b/src/views/CNAS/resourceDemand/quantityTraceabilityPlan/components/formDia.vue
@@ -0,0 +1,148 @@
+<template>
+  <div>
+    <el-dialog v-loading="diaLoading" :close-on-click-modal="false" :close-on-press-escape="false"
+      :visible.sync="formDia" title="閲忓�兼函婧愯鍒�" width="80%" @close="closeFormDia">
+      <el-form ref="form" :model="form" :rules="rules" label-position="right" label-width="auto">
+        <el-row :gutter="20">
+          <el-col :span="12">
+            <el-form-item label="浠櫒鍚嶇О" prop="instrumentName">
+              <el-input v-model="form.instrumentName" clearable size="small"></el-input>
+            </el-form-item>
+          </el-col>
+          <el-col :span="12">
+            <el-form-item label="瑙勬牸鍨嬪彿" prop="model">
+              <el-input v-model="form.model" clearable size="small"></el-input>
+            </el-form-item>
+          </el-col>
+          <el-col :span="12">
+            <el-form-item label="绠$悊缂栧彿" prop="managementNumber">
+              <el-input v-model="form.managementNumber" clearable size="small"></el-input>
+            </el-form-item>
+          </el-col>
+          <el-col :span="12">
+            <el-form-item label="鎶�鏈寚鏍�" prop="technicalIndicators">
+              <el-input v-model="form.technicalIndicators" clearable size="small"></el-input>
+            </el-form-item>
+          </el-col>
+          <el-col :span="12">
+            <el-form-item label="妫�瀹氬懆鏈�" prop="verificationCyde">
+              <el-input v-model="form.verificationCyde" clearable size="small"></el-input>
+            </el-form-item>
+          </el-col>
+          <el-col :span="12">
+            <el-form-item label="妫�瀹氬崟浣�" prop="verificationUnit">
+              <el-input v-model="form.verificationUnit" clearable size="small"></el-input>
+            </el-form-item>
+          </el-col>
+          <el-col :span="12">
+            <el-form-item label="鏈�杩戞瀹氭棩鏈�" prop="recentlyTime">
+              <el-date-picker v-model="form.recentlyTime" clearable format="yyyy-MM-dd HH:mm:ss" placeholder="閫夋嫨鏃ユ湡"
+                size="small" style="width: 100%" type="datetime" value-format="yyyy-MM-dd HH:mm:ss">
+              </el-date-picker>
+            </el-form-item>
+          </el-col>
+          <el-col :span="12">
+            <el-form-item label="璁″垝涓嬫妫�瀹氭棩鏈�" prop="nextTime">
+              <el-date-picker v-model="form.nextTime" clearable format="yyyy-MM-dd HH:mm:ss" placeholder="閫夋嫨鏃ユ湡"
+                size="small" style="width: 100%" type="datetime" value-format="yyyy-MM-dd HH:mm:ss">
+              </el-date-picker>
+            </el-form-item>
+          </el-col>
+          <el-col :span="24">
+            <el-form-item label="澶囨敞" prop="remark">
+              <el-input v-model="form.remark" clearable size="small"></el-input>
+            </el-form-item>
+          </el-col>
+        </el-row>
+      </el-form>
+      <span slot="footer" class="dialog-footer">
+        <el-button @click="closeFormDia">鍙� 娑�</el-button>
+        <el-button :loading="loading" type="primary" @click="handleEdit">鎻� 浜�</el-button>
+      </span>
+    </el-dialog>
+  </div>
+</template>
+
+<script>
+import {
+  addCalibrationSchedule,
+} from '@/api/cnas/resourceDemand/quantityTraceabilityPlan.js'
+export default {
+  name: "formDia",
+  // import 寮曞叆鐨勭粍浠堕渶瑕佹敞鍏ュ埌瀵硅薄涓墠鑳戒娇鐢�
+  components: {},
+  data() {
+    // 杩欓噷瀛樻斁鏁版嵁
+    return {
+      formDia: false,
+      diaLoading: false,
+      loading: false,
+      form: {
+        instrumentName: '',
+        model: '',
+        managementNumber: '',
+        technicalIndicators: '',
+        verificationCyde: '',
+        verificationUnit: '',
+        recentlyTime: '',
+        nextTime: '',
+        remark: '',
+        id: '',
+      },
+      rules: {
+        instrumentName: [{ required: true, message: '璇峰~鍐欎华鍣ㄥ悕绉�', trigger: 'blur' }],
+        model: [{ required: true, message: '璇峰~鍐欒鏍煎瀷鍙�', trigger: 'blur' }],
+        managementNumber: [{ required: true, message: '璇峰~鍐欑鐞嗙紪鍙�', trigger: 'blur' }],
+        technicalIndicators: [{ required: true, message: '璇峰~鍐欐妧鏈寚鏍�', trigger: 'blur' }],
+        verificationCyde: [{ required: true, message: '璇峰~鍐欐瀹氬懆鏈�', trigger: 'blur' }],
+        verificationUnit: [{ required: true, message: '璇峰~鍐欐瀹氬崟浣�', trigger: 'blur' }],
+        recentlyTime: [{ required: true, message: '璇烽�夋嫨鏈�杩戞瀹氭棩鏈�', trigger: 'change' }],
+        nextTime: [{ required: true, message: '璇烽�夋嫨璁″垝涓嬫妫�瀹氭棩鏈�', trigger: 'change' }],
+      },
+      operationType: '',
+    }
+  },
+  mounted() {
+
+  },
+  // 鏂规硶闆嗗悎
+  methods: {
+    // 鎵撳紑寮规
+    openDia(type, row) {
+      this.formDia = true
+      this.operationType = type
+      if (type !== 'add') {
+        this.form = row
+      }
+    },
+    // 鎻愪氦寮规鏁版嵁
+    handleEdit() {
+      this.$refs['form'].validate((valid) => {
+        if (valid) {
+          this.loading = true
+          const internalReport = this.HaveJson(this.form)
+          addCalibrationSchedule(internalReport).then(res => {
+            this.loading = false
+            if (res.code === 201) return
+            this.$message.success('鎿嶄綔鎴愬姛')
+            this.closeFormDia()
+          }).catch(err => {
+            console.log('err---', err);
+            this.loading = false
+          })
+        } else {
+          console.log('error submit!!');
+          return false;
+        }
+      });
+    },
+    closeFormDia() {
+      this.$refs.form.resetFields();
+      this.formDia = false
+      this.$emit('closeFormDia')
+    },
+  },
+}
+</script>
+
+<style scoped></style>
diff --git a/src/views/CNAS/resourceDemand/quantityTraceabilityPlan/index.vue b/src/views/CNAS/resourceDemand/quantityTraceabilityPlan/index.vue
new file mode 100644
index 0000000..3e3f0e8
--- /dev/null
+++ b/src/views/CNAS/resourceDemand/quantityTraceabilityPlan/index.vue
@@ -0,0 +1,304 @@
+<template>
+  <div>
+    <div>
+      <div class="search-background">
+        <span class="search-group">
+          <span style="width: 120px">浠櫒鍚嶇О锛�</span>
+          <el-input v-model="searchForm.instrumentName" clearable size="small"></el-input>
+        </span>
+        <span class="search-group">
+          <span style="width: 120px">绠$悊缂栧彿锛�</span>
+          <el-input v-model="searchForm.managementNumber" clearable size="small"></el-input>
+        </span>
+        <span class="search-group">
+          <el-button size="medium" @click="resetSearchForm">閲� 缃�</el-button>
+          <el-button size="medium" type="primary" @click="searchList">鏌� 璇�</el-button>
+        </span>
+        <div class="btn">
+          <el-button size="medium" @click="exportFun">瀵� 鍑�</el-button>
+          <el-button size="medium" @click="uploadDia = true">瀵� 鍏�</el-button>
+          <el-button size="medium" type="primary" @click="openFormDia('add')">鏂� 澧�</el-button>
+        </div>
+      </div>
+      <div class="table">
+        <div>
+          <TableCard :showForm="false" :showTitle="false">
+            <template v-slot:table>
+              <limsTable :column="tableColumn" :height="'calc(100vh - 17em)'" :table-data="tableData"
+                :table-loading="tableLoading" style="padding: 0 15px;margin-bottom: 16px" :page="page"
+                @pagination="pagination">
+              </limsTable>
+            </template>
+          </TableCard>
+        </div>
+      </div>
+    </div>
+    <form-dia v-if="formDia" ref="formDia" @closeFormDia="closeFormDia"></form-dia>
+    <el-dialog :visible.sync="uploadDia" title="鏁版嵁瀵煎叆" width="500px">
+      <div style="margin: 0 auto;">
+        <el-upload ref="upload" :action="javaApi + '/feCalibrationSchedule/importOfValueTraceabilityPlan'"
+          :auto-upload="false" :before-upload="beforeUpload" :file-list="fileList" :headers="uploadHeader" :limit="1"
+          :on-error="onError" :on-success="onSuccess" accept=".xlsx" drag name="file">
+          <i class="el-icon-upload"></i>
+          <div class="el-upload__text">灏嗘枃浠舵嫋鍒版澶勶紝鎴�<em>鐐瑰嚮涓婁紶</em></div>
+        </el-upload>
+      </div>
+      <span slot="footer" class="dialog-footer">
+        <el-button @click="uploadDia = false">鍙� 娑�</el-button>
+        <el-button :loading="uploading" type="primary" @click="submitUpload()">涓� 浼�</el-button>
+      </span>
+    </el-dialog>
+  </div>
+</template>
+
+<script>
+import TableCard from '@/components/TableCard/index.vue';
+import limsTable from "@/components/Table/lims-table.vue";
+import FormDia from './components/formDia.vue';
+import {
+  exportOfValueTraceabilityPlan,
+  getPageCalibrationSchedule,
+  removeCalibrationSchedule,
+} from '@/api/cnas/resourceDemand/quantityTraceabilityPlan.js'
+
+export default {
+  name: 'a6-quantity-value-traceability-plan',
+  // import 寮曞叆鐨勭粍浠堕渶瑕佹敞鍏ュ埌瀵硅薄涓墠鑳戒娇鐢�
+  components: { FormDia, limsTable, TableCard },
+  data() {
+    // 杩欓噷瀛樻斁鏁版嵁
+    return {
+      outLoading: false,
+      searchForm: {
+        instrumentName: '',
+        managementNumber: '',
+      },
+      tableColumn: [
+        {
+          label: '浠櫒鍚嶇О',
+          prop: 'instrumentName',
+          minWidth: '120'
+        },
+        {
+          label: '瑙勬牸鍨嬪彿',
+          prop: 'model',
+          minWidth: '100'
+        },
+        {
+          label: '绠$悊缂栧彿',
+          prop: 'managementNumber',
+          minWidth: '100'
+        },
+        {
+          label: '鎶�鏈寚鏍�',
+          prop: 'technicalIndicators',
+          minWidth: '100'
+        },
+        {
+          label: '妫�瀹氬懆鏈�',
+          prop: 'verificationCyde',
+          minWidth: '100'
+        },
+        {
+          label: '妫�瀹氬崟浣�',
+          prop: 'verificationUnit',
+          minWidth: '100'
+        },
+        {
+          label: '鏈�杩戞瀹氭棩鏈�',
+          prop: 'recentlyTime',
+          minWidth: '100'
+        },
+        {
+          label: '璁″垝涓嬫妫�瀹氭棩鏈�',
+          prop: 'nextTime',
+          minWidth: '100'
+        },
+        {
+          label: '澶囨敞',
+          prop: 'remark',
+          minWidth: '100'
+        },
+        {
+          dataType: 'action',
+          fixed: 'right',
+          minWidth: '180',
+          label: '鎿嶄綔',
+          operation: [
+            {
+              name: '缂栬緫',
+              type: 'text',
+              clickFun: (row) => {
+                this.openFormDia('edit', row);
+              },
+            },
+            {
+              name: '鍒犻櫎',
+              type: 'text',
+              color: '#f56c6c',
+              clickFun: (row) => {
+                this.delPlan(row)
+              },
+            }
+          ]
+        }
+      ],
+      tableData: [],
+      tableLoading: false,
+      uploadDia: false,
+      uploading: false,
+      page: {
+        size: 20,
+        current: 1,
+        total: 0,
+      },
+      formDia: false,
+      fileList: [],
+    };
+  },
+  mounted() {
+    this.searchList()
+  },
+  // 鏂规硶闆嗗悎
+  methods: {
+    beforeUpload(file, fileList) {
+      if (file.type != 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet') {
+        this.$message.error('涓婁紶鏂囦欢鏍煎紡涓嶆纭�');
+        this.$refs.upload.clearFiles()
+        return false;
+      }
+    },
+    submitUpload() {
+      if (this.$refs.upload.uploadFiles.length == 0) {
+        this.$message.error('鏈�夋嫨鏂囦欢')
+        return
+      }
+      this.uploading = true
+      this.$refs.upload.submit();
+      this.uploading = false
+    },
+    onError(err, file, fileList) {
+      this.$message.error('涓婁紶澶辫触')
+      this.$refs.upload.clearFiles()
+      this.uploading = false
+    },
+    onSuccess(response, file, fileList) {
+      this.$refs.upload.clearFiles()
+      this.uploadDia = false
+      this.uploading = false
+      if (response.code == 201) {
+        this.$message.error(response.message)
+        return
+      }
+      this.$message.success('涓婁紶鎴愬姛')
+      this.standardList = []
+      this.productList = []
+      this.searchList()
+    },
+    // 瀵煎嚭
+    exportFun() {
+      this.outLoading = true
+      exportOfValueTraceabilityPlan({
+        instrumentName: this.searchForm.instrumentName,
+        managementNumber: this.searchForm.managementNumber,
+      }).then(res => {
+        this.outLoading = false
+        const blob = new Blob([res], { type: 'application/octet-stream' });
+        this.$download.saveAs(blob, '閲忓�兼函婧愯鍒�.xlsx')
+      }).finally(() => {
+        this.outLoading = false
+      })
+    },
+    // 鏌ヨ鍒楄〃
+    searchList() {
+      this.tableLoading = true
+      getPageCalibrationSchedule({
+        ...this.searchForm,
+        ...this.page
+      }).then(res => {
+        this.tableLoading = false
+        if (res.code === 201) return
+        this.tableData = res.data.records
+        this.page.total = res.data.total
+      }).catch(err => {
+        console.log('err---', err);
+        this.tableLoading = false
+      })
+    },
+    // 鍒犻櫎
+    delPlan(row) {
+      this.$confirm('姝ゆ搷浣滃皢姘镐箙鍒犻櫎璇ユ暟鎹�, 鏄惁缁х画?', '鎻愮ず', {
+        confirmButtonText: '纭畾',
+        cancelButtonText: '鍙栨秷',
+        type: 'warning'
+      }).then(() => {
+        this.tableLoading = true
+        removeCalibrationSchedule({ id: row.id }).then(res => {
+          this.tableLoading = false
+          if (res.code === 201) return
+          this.$message.success('鍒犻櫎鎴愬姛')
+          this.searchList()
+        }).catch(err => {
+          this.tableLoading = false
+          console.log('err---', err);
+        })
+      }).catch(() => {
+        this.$message({
+          type: 'info',
+          message: '宸插彇娑堝垹闄�'
+        });
+      });
+    },
+    // 閲嶇疆鏌ヨ鏉′欢
+    resetSearchForm() {
+      this.searchForm.instrumentName = '';
+      this.searchForm.managementNumber = '';
+      this.searchList()
+    },
+    // 鏂板锛岀紪杈戯紝鎵瑰噯寮规
+    openFormDia(type, row) {
+      this.formDia = true
+      this.$nextTick(() => {
+        this.$refs.formDia.openDia(type, row)
+      })
+    },
+    closeFormDia() {
+      this.formDia = false
+      this.searchList()
+    },
+    // 鍒嗛〉
+    pagination({ page, limit }) {
+      this.page.current = page;
+      this.page.size = limit;
+      this.searchList();
+    },
+  }
+};
+</script>
+
+<style scoped>
+.search-background {
+  width: 100%;
+  height: 80px;
+  line-height: 80px;
+  background-color: #ffffff;
+  display: flex;
+  position: relative;
+}
+
+.search-group {
+  display: flex;
+  align-items: center;
+  margin: 0 20px;
+}
+
+.table {
+  background-color: #ffffff;
+}
+
+.btn {
+  position: absolute;
+  right: 20px;
+  top: 16px;
+}
+</style>

--
Gitblit v1.9.3