From 1f1cc2740ef598c8925edc0f66bf40113d2044a7 Mon Sep 17 00:00:00 2001
From: chenrui <1187576398@qq.com>
Date: 星期四, 27 二月 2025 14:54:11 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/dev' into dev

---
 src/api/cnas/systemManagement/documentControl.js                                                    |    2 
 src/views/CNAS/resourceDemand/standardMaterialAccept/component/AddRecord.vue                        |  336 +++++++--
 src/views/system/role/index.vue                                                                     |  277 +++----
 src/views/CNAS/process/sampleDisposal/index.vue                                                     |  609 ++++++++++++++++++
 src/views/CNAS/systemManagement/measuresDealRisks/components/hazardIdentificationRiskAssessment.vue |    4 
 src/views/CNAS/systemManagement/documentControl/components/FileList.vue                             |   25 
 src/views/CNAS/personnel/personnelOverview/index.vue                                                |  201 ++++++
 src/api/cnas/resourceDemand/standardMaterialAccept/standardMaterialAccept.js                        |   27 
 src/views/CNAS/systemManagement/documentControl/components/ControlledFileApplication.vue            |   29 
 src/utils/file.js                                                                                   |   69 +
 src/views/business/inspectionTask/index.vue                                                         |   12 
 src/components/UpPdfStamp/index.vue                                                                 |    4 
 /dev/null                                                                                           |  198 ------
 src/views/system/menu/index.vue                                                                     |    8 
 src/api/cnas/personnel/personnelOverview.js                                                         |    9 
 src/assets/images/renyuan-title.svg                                                                 |   11 
 src/views/CNAS/systemManagement/measuresDealRisks/components/listRiskAnalysisControlPlans.vue       |    2 
 package.json                                                                                        |    1 
 src/api/cnas/process/sampleDisposal.js                                                              |   74 ++
 src/views/CNAS/resourceDemand/standardMaterialAccept/index.vue                                      |   71 -
 src/views/performance/class/index.vue                                                               |    2 
 src/views/CNAS/systemManagement/correctiveAction/index.vue                                          |    4 
 22 files changed, 1,426 insertions(+), 549 deletions(-)

diff --git a/package.json b/package.json
index a4ff793..2b89237 100644
--- a/package.json
+++ b/package.json
@@ -55,6 +55,7 @@
     "jspdf": "^3.0.0",
     "mammoth": "^1.9.0",
     "nprogress": "0.2.0",
+    "pako": "^2.1.0",
     "print-js": "^1.6.0",
     "quill": "2.0.2",
     "screenfull": "5.0.2",
diff --git a/src/api/cnas/personnel/personnelOverview.js b/src/api/cnas/personnel/personnelOverview.js
new file mode 100644
index 0000000..6afa9a1
--- /dev/null
+++ b/src/api/cnas/personnel/personnelOverview.js
@@ -0,0 +1,9 @@
+import request from '@/utils/request'
+
+export function selectPersonnelOverview(query) {
+  return request({
+    url: '/user/selectPersonnelOverview',
+    method: 'get',
+    params: query
+  })
+}
diff --git a/src/api/cnas/process/sampleDisposal.js b/src/api/cnas/process/sampleDisposal.js
new file mode 100644
index 0000000..a763edd
--- /dev/null
+++ b/src/api/cnas/process/sampleDisposal.js
@@ -0,0 +1,74 @@
+// 妫�娴嬫垨鏍″噯鐗╁搧鐨勫缃�
+import request from "@/utils/request";
+
+// 淇敼
+export function doProcessDeal(data) {
+  return request({
+    url: "/processDeal/doProcessDeal",
+    method: "post",
+    data: data,
+  });
+}
+
+// 鏂板
+export function addProcessDeal(data) {
+  return request({
+    url: "/processDeal/addProcessDeal",
+    method: "post",
+    data: data,
+  });
+}
+
+// 鎻愪氦鍘嗗彶  浼犲弬id
+export function submitProcessTotaldeal(data) {
+  return request({
+    url: "/processTotaldeal/submitProcessTotaldeal",
+    method: "post",
+    data: data,
+  });
+}
+
+//鏌ヨ璇︽儏  鍒嗛〉鏌ヨ閲岄潰totaldealId  浼犲弬鍘嗗彶鐨刬d
+export function pageProcessDeal(query) {
+  return request({
+    url: "/processDeal/pageProcessDeal",
+    method: "get",
+    params: query,
+  });
+}
+
+// 瀹℃牳  浼犲弬id鍜岄�氳繃涓嶉�氳繃state(涓枃)
+export function checkProcessTotaldeal(data) {
+  return request({
+    url: "/processTotaldeal/checkProcessTotaldeal",
+    method: "post",
+    data: data,
+  });
+}
+
+// 鎵瑰噯  浼犲弬id鍜岄�氳繃涓嶉�氳繃state(涓枃)
+export function ratifyProcessTotaldeal(data) {
+  return request({
+    url: "/processTotaldeal/ratifyProcessTotaldeal",
+    method: "post",
+    data: data,
+  });
+}
+
+//鍒犻櫎
+export function delProcessDeal(query) {
+  return request({
+    url: "/processDeal/delProcessDeal",
+    method: "delete",
+    params: query,
+  });
+}
+
+//鏌ョ湅鍘嗗彶
+export function pageProcessTotaldeal(query) {
+  return request({
+    url: "/processTotaldeal/pageProcessTotaldeal",
+    method: "get",
+    params: query,
+  });
+}
diff --git a/src/api/cnas/resourceDemand/standardMaterialAccept/standardMaterialAccept.js b/src/api/cnas/resourceDemand/standardMaterialAccept/standardMaterialAccept.js
index 010c461..e9a0a7a 100644
--- a/src/api/cnas/resourceDemand/standardMaterialAccept/standardMaterialAccept.js
+++ b/src/api/cnas/resourceDemand/standardMaterialAccept/standardMaterialAccept.js
@@ -15,10 +15,18 @@
     data: query
   })
 }
-
+// 鏂板楠屾敹
 export function addAcceptance(query) {
   return request({
     url: '/feStandardSubstanceAcceptance/addAcceptance',
+    method: 'post',
+    data: query
+  })
+}
+// 淇敼楠屾敹
+export function updateAcceptance(query) {
+  return request({
+    url: '/feStandardSubstanceAcceptance/updateAcceptance',
     method: 'post',
     data: query
   })
@@ -34,6 +42,23 @@
     params: query
   })
 }
+// 鏍囧噯鐗╄川楠屾敹鏌ョ湅璇︽儏
+export function getAcceptanceDetails(query) {
+  return request({
+    url: '/feStandardSubstanceAcceptance/getAcceptanceDetails',
+    method: 'get',
+    params: query
+  })
+}
+// 鏍囧噯鐗╄川楠屾敹瀵煎嚭
+export function exportFeStandardSubstanceAcceptance(query) {
+  return request({
+    url: '/feStandardSubstanceAcceptance/exportFeStandardSubstanceAcceptance',
+    method: 'get',
+    params: query,
+    responseType: "blob"
+  })
+}
 
 
 
diff --git a/src/api/cnas/systemManagement/documentControl.js b/src/api/cnas/systemManagement/documentControl.js
index 3fc97b7..9a322b4 100644
--- a/src/api/cnas/systemManagement/documentControl.js
+++ b/src/api/cnas/systemManagement/documentControl.js
@@ -120,7 +120,7 @@
   return request({
     url: "/manageDocumentIssueRecycle/addManageDocumentIssueRecycle",
     method: "post",
-    responseType: "blob",
+    headers: { "Content-Type": "application/x-www-form-urlencoded" },
     data: data,
   });
 }
diff --git a/src/assets/images/renyuan-title.svg b/src/assets/images/renyuan-title.svg
new file mode 100644
index 0000000..c69691f
--- /dev/null
+++ b/src/assets/images/renyuan-title.svg
@@ -0,0 +1,11 @@
+<svg width="148" height="21" viewBox="0 0 148 21" fill="none" xmlns="http://www.w3.org/2000/svg">
+<path fill-rule="evenodd" clip-rule="evenodd" d="M7.00437 5.75531V0.0625L0.772461 5.75531H7.00437Z" fill="#B26F00"/>
+<path fill-rule="evenodd" clip-rule="evenodd" d="M141.709 5.75531V0.0625L147.941 5.75531H141.709Z" fill="#B26F00"/>
+<path d="M6.97192 2.0625C6.97192 0.957931 7.86735 0.0625 8.97192 0.0625H139.676C140.781 0.0625 141.676 0.957931 141.676 2.0625V12.0625C141.676 16.4808 138.095 20.0625 133.676 20.0625H14.9719C10.5537 20.0625 6.97192 16.4808 6.97192 12.0625V2.0625Z" fill="url(#paint0_linear_2026_4)"/>
+<defs>
+<linearGradient id="paint0_linear_2026_4" x1="6.97192" y1="0.0625" x2="6.97192" y2="20.0625" gradientUnits="userSpaceOnUse">
+<stop stop-color="#F9C76F"/>
+<stop offset="1" stop-color="#FEB42F"/>
+</linearGradient>
+</defs>
+</svg>
diff --git a/src/components/UpPdfStamp/index.vue b/src/components/UpPdfStamp/index.vue
index e348eab..9b8fe8c 100644
--- a/src/components/UpPdfStamp/index.vue
+++ b/src/components/UpPdfStamp/index.vue
@@ -12,6 +12,7 @@
 
 <script>
 import jsPDF from "jspdf";
+import file from '@/utils/file.js'
 export default {
   props: ['isUpFile'],
   data() {
@@ -142,8 +143,7 @@
       }
       const pdf = new jsPDF("p", "mm", "a4");
       for (let i = 0; i < this.contextList.length; i++) {
-        console.log(2222, this.contextList.length, this.$refs.pdfCanvas[i])
-        const imgData = this.$refs.pdfCanvas[i].toDataURL('image/jpeg', 1.0);
+        const imgData = this.$refs.pdfCanvas[i].toDataURL('image/jpeg', 0.7);
         const pdfWidth = pdf.internal.pageSize.getWidth();
         const pdfHeight = (this.$refs.pdfCanvas[i].height * pdfWidth) / this.$refs.pdfCanvas[i].width;
         pdf.addImage(imgData, "JPEG", 0, 0, pdfWidth, pdfHeight); // 灏嗗浘鐗囨坊鍔犲埌 PDF
diff --git a/src/utils/file.js b/src/utils/file.js
index c3a3e7b..9c7e99e 100644
--- a/src/utils/file.js
+++ b/src/utils/file.js
@@ -1,48 +1,55 @@
-import { convertToHtml } from 'mammoth';
-import Vue from 'vue'
+import { convertToHtml } from "mammoth";
+import pako from "pako";
+import Vue from "vue";
 
 export default {
   async convertFileToHtml(url) {
     var xhr = new XMLHttpRequest();
-    xhr.open('GET', Vue.prototype.javaApi+url, true);//鑾峰彇鏂囦欢娴佺殑鎺ュ彛
+    xhr.open("GET", Vue.prototype.javaApi + url, true); //鑾峰彇鏂囦欢娴佺殑鎺ュ彛
     xhr.send();
-    xhr.responseType = "blob";//涓嶈兘婕�
+    xhr.responseType = "blob"; //涓嶈兘婕�
     let xhrPromise = new Promise((resolve, reject) => {
       xhr.onload = async function () {
         if (this.status === 200) {
           // 杩斿洖鐨勬枃浠舵祦锛岃浆鎹㈡垚blob瀵硅薄
-          var blob = new Blob([this.response],{ type:'application/vnd.openxmlformats-officedocument.wordprocessingml.document' });
+          var blob = new Blob([this.response], {
+            type: "application/vnd.openxmlformats-officedocument.wordprocessingml.document",
+          });
           // 浣跨敤mammoth灏哤ord杞崲涓篐TML
           let reader = new FileReader();
           reader.readAsArrayBuffer(blob);
           let htmlContentPromise = new Promise((resolve, reject) => {
             reader.onload = async function () {
               var arrayBuffer = xhr.response; //arrayBuffer
-              const result = await convertToHtml({ arrayBuffer: arrayBuffer })
-              let html = result.value.replace(/飪�/g, '')
-              .replace('<h1>', '<h1 style="text-align: center;">')
-              .replace(/<table>/g, '<table style="border-collapse: collapse;border: 1px solid #000;">')
-              .replace(/<tr>/g, '<tr style="height: 30px;">')
-              .replace(/<td>/g, '<td style="border: 1px solid #000;">')
-              .replace(/<p>/g, '<p style="text-indent: 2em;">')
-              .replace(/<a [^>]*>/g, "")
-              .replace(/<\/a>/g, "")
+              const result = await convertToHtml({ arrayBuffer: arrayBuffer });
+              let html = result.value
+                .replace(/飪�/g, "")
+                .replace("<h1>", '<h1 style="text-align: center;">')
+                .replace(
+                  /<table>/g,
+                  '<table style="border-collapse: collapse;border: 1px solid #000;">'
+                )
+                .replace(/<tr>/g, '<tr style="height: 30px;">')
+                .replace(/<td>/g, '<td style="border: 1px solid #000;">')
+                .replace(/<p>/g, '<p style="text-indent: 2em;">')
+                .replace(/<a [^>]*>/g, "")
+                .replace(/<\/a>/g, "");
               // .replace(/em/g, "cm");
-              resolve(html)
+              resolve(html);
             };
-          })
-          resolve(await htmlContentPromise)
+          });
+          resolve(await htmlContentPromise);
         }
-
-      }
-    })
-    return await xhrPromise
+      };
+    });
+    return await xhrPromise;
   },
-  downloadIamge(imgsrc, name) {//涓嬭浇鍥剧墖鍦板潃鍜屽浘鐗囧悕
+  downloadIamge(imgsrc, name) {
+    //涓嬭浇鍥剧墖鍦板潃鍜屽浘鐗囧悕
     var image = new Image();
     // 瑙e喅璺ㄥ煙 Canvas 姹℃煋闂
     image.setAttribute("crossOrigin", "anonymous");
-    image.onload = function() {
+    image.onload = function () {
       var canvas = document.createElement("canvas");
       canvas.width = image.width;
       canvas.height = image.height;
@@ -57,5 +64,19 @@
       a.dispatchEvent(event); // 瑙﹀彂a鐨勫崟鍑讳簨浠�
     };
     image.src = imgsrc;
-  }
+  },
+  // 鍘嬬缉blob
+  compressBlob(blob) {
+    const reader = new FileReader();
+    reader.readAsArrayBuffer(blob);
+    return new Promise((resolve) => {
+      reader.onload = () => {
+        const arrayBuffer = reader.result;
+        const uint8Array = new Uint8Array(arrayBuffer);
+        const compressedData = pako.deflate(uint8Array);
+        const compressedBlob = new Blob([compressedData], { type: blob.type });
+        resolve(compressedBlob);
+      };
+    });
+  },
 };
diff --git a/src/views/CNAS/personnel/personnelOverview/index.vue b/src/views/CNAS/personnel/personnelOverview/index.vue
new file mode 100644
index 0000000..c5c8da2
--- /dev/null
+++ b/src/views/CNAS/personnel/personnelOverview/index.vue
@@ -0,0 +1,201 @@
+<template>
+  <div class="capacity-scope">
+    <div>
+      <el-form :model="entity" ref="entity" size="small" :inline="true">
+        <el-form-item label="浜哄憳鍚嶇О">
+          <el-input v-model="entity.name" clearable></el-input>
+        </el-form-item>
+        <el-form-item>
+          <el-button @click="refresh">閲� 缃�</el-button>
+          <el-button type="primary" @click="currentPage= 1,list=[],finishLoding = false,keyMap = {},refreshTable()">鏌� 璇�</el-button>
+        </el-form-item>
+      </el-form>
+    </div>
+    <div class="table" v-loading="loading">
+      <scroll-pagination @load="refreshTable" :finishLoding="finishLoding" :list="list" v-if="list.length>0||loading">
+        <ul class="card">
+          <li v-for="(m,i) in list" :key="i">
+            <el-image style="width: 80px;height: 112px;" :src="javaApi+'/img/'+m.pictureUrl">
+              <div slot="error" class="image-error" style="width: 79px;
+            height: 110px;
+            display: flex;
+            align-items: center;
+            justify-content: center;
+            border: 1px solid #EEEEEE;">
+                <i class="el-icon-picture-outline" style="font-size:30px;color:#666666;"></i>
+              </div>
+            </el-image>
+            <el-image style="width: 195px;
+            height: 112px;" :src="javaApi+'/img/'+m.signatureUrl">
+              <div slot="error" class="image-error" style="width: 194px;
+            height: 110px;
+            display: flex;
+            align-items: center;
+            justify-content: center;
+            border: 1px solid #EEEEEE;">
+                <i class="el-icon-picture-outline" style="font-size:30px;color:#666666;"></i>
+              </div>
+            </el-image>
+            <div class="title">{{ m.name }}</div>
+          </li>
+        </ul>
+      </scroll-pagination>
+      <div v-if="list.length<1&&!loading" style="color:#909399;font-size:14px;text-align: center;margin-top:200px" >鏆傛棤鏁版嵁</div>
+    </div>
+  </div>
+</template>
+
+<script>
+import ScrollPagination from '@/components/index/scroll-paging.vue'
+import {selectUserCondition} from "@/api/business/inspectionTask";
+export default {
+  components: {
+    ScrollPagination
+  },
+  data() {
+    return {
+      entity:{
+        name: null,
+        status: 0,
+      },
+      list:[],
+      currentPage: 1, // 褰撳墠椤�
+      pageSize: 16, // 涓�椤�16鏉�
+      total: '',
+      loading: true, // 缁勪欢loading鐨勫睍绀�,榛樿涓簍rue
+      finishLoding: false, // 鍔犺浇瀹屾垚锛屾樉绀哄凡缁忔病鏈夋洿澶氫簡
+      keyMap: {}
+    }
+  },
+  created() {
+    this.keyMap = {};
+    this.currentPage = 1;
+    this.list = [];
+    this.refreshTable();
+  },
+  methods: {
+    refreshTable() {
+      const key = `_${this.currentPage}`
+      const value = this.keyMap[key]
+      // 濡傛灉value瀛樺湪锛岃〃绀虹紦瀛樻湁鍊硷紝閭d箞闃绘璇锋眰
+      if(value) {
+        return
+      }
+      // value涓嶅瓨鍦紝琛ㄧず绗竴娆¤姹�,璁剧疆鍗犱綅
+      this.keyMap[key] = 'temp'
+      if(this.currentPage==1){
+        this.loading = true
+      }
+      selectUserCondition({...this.entity}).then(res => {
+        this.total = res.data.length
+        let list = res.data
+        if(list.length==0){
+          this.finishLoding = true;
+        }else{
+          if(list.length<this.pageSize){
+            this.finishLoding = true;
+          }
+          this.list = this.list.concat(list)
+          if(this.total==this.list.length){
+            this.finishLoding = true;
+          }
+          this.currentPage++;
+        }
+        this.loading = false
+      }).catch(err => {
+        this.loading = false
+      })
+    },
+    refresh() {
+      this.keyMap = {};
+      this.currentPage= 1;
+      this.list=[];
+      this.finishLoding = false;
+      this.entity={
+        name: null,
+        state:1,
+        orderBy: {field: "id", order: "asc"}
+      };
+      this.refreshTable()
+    },
+    // 婊氬姩瑙﹀簳鍔犺浇
+    scrollFn() {
+      let clientHeight = document.documentElement.clientHeight - 18; //鍙鍖哄煙
+      let scrollHeight = document.body.scrollHeight; // 婊氬姩鏂囨。楂樺害
+      let scrollTop = parseInt(document.documentElement.scrollTop); // 宸叉粴鍔ㄧ殑楂樺害
+      let height = 300;
+      if (
+        scrollTop + clientHeight >= scrollHeight - height &&
+        scrollHeight != 0
+      ) {
+        if (!this.finishLoding&&this.currentPage*this.pageSize<this.total) {
+          this.currentPage = this.currentPage + 1;
+          this.refreshTable();
+        }
+      } else {
+        return false;
+      }
+    },
+    throttle(fn, wait) {
+      // 灏佽鍑芥暟杩涜鑺傛祦
+      var timer = null;
+      return function () {
+        var context = this;
+        var args = arguments;
+        if (!timer) {
+          timer = setTimeout(function () {
+            fn.apply(context, args);
+            timer = null;
+          }, wait);
+        }
+      };
+    },
+  },
+  destroyed() {
+    window.removeEventListener("scroll", this.throttle(), false);
+  },
+}
+</script>
+<style scoped>
+.table {
+  width: 100%;
+  height: calc(100% - 60px - 80px - 10px - 40px);
+  overflow-y: auto;
+}
+
+.card {
+  list-style-type: none;
+  display: grid;
+  grid-template-columns: repeat(auto-fit, 314px);
+  /* justify-content: center; */
+  grid-gap: 16px;
+  min-height: 200px;
+  padding-left: 0 !important;
+}
+.card li{
+  width: 320px;
+  border-radius: 8px 8px 8px 8px;
+  box-shadow: 4px 4px 8px 0px rgba(51,51,51,0.04);
+  border: 1px solid #EEEEEE;
+  margin: 0 !important;
+  display: flex;
+  align-items: center;
+  justify-content: space-between;
+  box-sizing: border-box;
+  padding: 26px 16px 16px;
+  font-size: 14px;
+  position: relative;
+}
+li .title{
+  width: 147px;
+  height: 20px;
+  background: url(~@/assets/images/renyuan-title.svg) no-repeat;
+  position: absolute;
+  top: -6px;
+  left: 50%;
+  transform: translateX(-50%);
+  text-align: center;
+  line-height: 20px;
+  color: #fff;
+}
+</style>
diff --git a/src/views/CNAS/process/sampleDisposal/index.vue b/src/views/CNAS/process/sampleDisposal/index.vue
new file mode 100644
index 0000000..0d12c66
--- /dev/null
+++ b/src/views/CNAS/process/sampleDisposal/index.vue
@@ -0,0 +1,609 @@
+<template>
+  <div class="sample-disposal">
+    <el-tabs type="border-card" v-model="activeName" style="height: 100%;" @tab-click="queryParams.totaldealId = ''">
+      <el-tab-pane label="濉啓" name="濉啓" style="height: 100%;" :key="1">
+        <el-button size="small" type="primary" @click="handleAdd0" style="margin-left: 20px;">鏂板</el-button>
+        <div class="table" style="height: calc(100% - 200px)" v-if="activeName == '濉啓'">
+          <lims-table :tableData="tableData" :column="column" :tableLoading="tableLoading"
+            :height="'calc(100vh - 290px)'" :page="page" @pagination="pagination"></lims-table>
+        </div>
+      </el-tab-pane>
+      <el-tab-pane label="鍘嗗彶璁板綍" name="鍘嗗彶璁板綍" style="height: 100%;" :key="2">
+        <div class="search">
+          <div class="search_thing">
+            <div class="search_label">骞存湀锛�</div>
+            <div class="search_input">
+              <el-date-picker v-model="queryParams0.month" type="month" placeholder="閫夋嫨鏈�" format="yyyy-MM"
+                value-format="yyyy-MM" size="small" @change="refreshTable()">
+              </el-date-picker>
+            </div>
+          </div>
+          <div class="search_thing" style="padding-left: 30px;">
+            <el-button size="small" @click="refresh()">閲� 缃�</el-button>
+            <el-button size="small" type="primary" @click="refreshTable()">鏌� 璇�</el-button>
+          </div>
+        </div>
+        <div class="table">
+          <lims-table :tableData="tableData0" :column="column0" :tableLoading="tableLoading"
+            :height="'calc(100vh - 300px)'" :page="page0" @pagination="pagination0"></lims-table>
+        </div>
+      </el-tab-pane>
+    </el-tabs>
+    <!-- 鏂板鏍峰搧 -->
+    <el-dialog :title="title" :visible.sync="addDialogVisible" width="400px">
+      <el-row>
+        <el-col :span="24" style="margin-bottom: 16px;">
+          <div class="search_thing">
+            <div class="search_label">鏍峰搧鍚嶇О锛�</div>
+            <div class="search_input"><el-input size="small" placeholder="璇疯緭鍏�" clearable
+                v-model="addInfo.sampleName"></el-input></div>
+          </div>
+        </el-col>
+        <el-col :span="24" style="margin-bottom: 16px;">
+          <div class="search_thing">
+            <div class="search_label">鏍峰搧缂栧彿锛�</div>
+            <div class="search_input"><el-input size="small" placeholder="璇疯緭鍏�" clearable
+                v-model="addInfo.sampleCode"></el-input></div>
+          </div>
+        </el-col>
+        <el-col :span="24" style="margin-bottom: 16px;">
+          <div class="search_thing">
+            <div class="search_label">渚涙牱鍗曚綅锛�</div>
+            <div class="search_input">
+              <el-select v-model="addInfo.sampleSupplier" size="small">
+                <el-option :label="item.company" :value="item.company" v-for="(item, index) in customPageList"
+                  :key="item.id"></el-option>
+              </el-select>
+            </div>
+          </div>
+        </el-col>
+        <el-col :span="24" style="margin-bottom: 16px;">
+          <div class="search_thing">
+            <div class="search_label">鏁伴噺锛�</div>
+            <div class="search_input"><el-input size="small" placeholder="璇疯緭鍏�" clearable
+                v-model="addInfo.num"></el-input>
+            </div>
+          </div>
+        </el-col>
+        <el-col :span="24" style="margin-bottom: 16px;">
+          <div class="search_thing">
+            <div class="search_label">澶勭悊鏂瑰紡锛�</div>
+            <div class="search_input"><el-input size="small" placeholder="璇疯緭鍏�" clearable
+                v-model="addInfo.dealMethod"></el-input></div>
+          </div>
+        </el-col>
+        <el-col :span="24" style="margin-bottom: 16px;">
+          <div class="search_thing">
+            <div class="search_label">鏃堕棿锛�</div>
+            <div class="search_input">
+              <el-date-picker v-model="addInfo.dealTime" type="date" size="small" placeholder="閫夋嫨鏃ユ湡" format="yyyy-MM-dd"
+                value-format="yyyy-MM-dd" style="width: 100%;">
+              </el-date-picker>
+            </div>
+          </div>
+        </el-col>
+      </el-row>
+      <span slot="footer" class="dialog-footer">
+        <el-button @click="addDialogVisible = false">鍙� 娑�</el-button>
+        <el-button type="primary" @click="submitAdd" :loading="addLoading">纭� 瀹�</el-button>
+      </span>
+    </el-dialog>
+    <!-- 璇︽儏/涓嬭浇/瀹℃牳/鎵瑰噯 -->
+    <el-dialog :title="title0" :visible.sync="lookDialogVisible" width="800px" :class="{ downPdf: title0 == '涓嬭浇' }"
+      :modal="title0 != '涓嬭浇'" top="5vh">
+      <filePreview v-if="lookDialogVisible" :fileUrl="javaApi + '/word/' + currentInfo.url" :currentFile="{}"
+        style="max-height: 70vh;overflow-y: auto;" />
+      <span slot="footer" class="dialog-footer" v-if="title0 == '瀹℃牳' || title0 == '鎵瑰噯'">
+        <el-button @click="submitCheck('涓嶉�氳繃')" :loading="noCheckLoading">涓嶉�氳繃</el-button>
+        <el-button type="primary" @click="submitCheck('閫氳繃')" :loading="checkLoading">閫� 杩�</el-button>
+      </span>
+    </el-dialog>
+  </div>
+</template>
+
+<script>
+import limsTable from "@/components/Table/lims-table.vue";
+import filePreview from "@/components/Preview/filePreview.vue";
+import { selectCustomPageList } from "@/api/system/customer";
+import {
+  doProcessDeal,
+  addProcessDeal,
+  submitProcessTotaldeal,
+  pageProcessDeal,
+  checkProcessTotaldeal,
+  ratifyProcessTotaldeal,
+  delProcessDeal,
+  pageProcessTotaldeal,
+} from "@/api/cnas/process/sampleDisposal";
+export default {
+  components: {
+    limsTable,
+    filePreview,
+  },
+  name: "SampleDisposal",
+  data() {
+    return {
+      activeName: '濉啓',
+      title: '鏂板',
+      addDialogVisible: false,
+      addLoading: false,
+      outLoading: false,
+      editDialogVisible: false,
+      lookDialogVisible: false,
+      title0: '鏌ョ湅',
+      noCheckLoading: false,
+      checkLoading: false,
+      // 鍘嗗彶鍒楄〃
+      addInfo: {},//鏂板鏍峰搧
+      customPageList: [],
+      currentInfo: {
+        arr: []
+      },//鏌ョ湅鐨勮鎯�
+      outPower: false,
+      addPower: false,
+      queryParams: {},
+      tableData: [],
+      column: [
+        { label: "鏍峰搧鍚嶇О", prop: "sampleName" },
+        { label: "鏍峰搧缂栧彿", prop: "sampleCode" },
+        { label: "渚涙牱鍗曚綅", prop: "sampleSupplier" },
+        { label: "鏁伴噺", prop: "num" },
+        { label: "澶勭悊鏂瑰紡", prop: "dealMethod" },
+        { label: "鏃堕棿", prop: "dealTime" },
+        {
+          dataType: "action",
+          fixed: "right",
+          label: "鎿嶄綔",
+          operation: [
+            {
+              name: "缂栬緫",
+              type: "text",
+              clickFun: (row) => {
+                this.handleAdd0(row);
+              },
+            },
+            {
+              name: "鍒犻櫎",
+              type: "text",
+              clickFun: (row) => {
+                this.handleDelete(row);
+              },
+            },
+          ],
+        },
+      ],
+      page: {
+        total: 0,
+        size: 10,
+        current: 0,
+      },
+      tableLoading: false,
+      queryParams0: {},
+      tableData0: [],
+      column0: [
+        { label: "鏈堜唤", prop: "month" },
+        { label: "鎬绘暟閲�", prop: "totalNum" },
+        { label: "鎻愪氦浜�", prop: "submitUserName" },
+        { label: "瀹℃牳浜�", prop: "examineUserName" },
+        { label: "鎵瑰噯浜�", prop: "ratifyUserName" },
+        {
+          dataType: "action",
+          fixed: "right",
+          label: "鎿嶄綔",
+          operation: [
+            {
+              name: "鏌ョ湅",
+              type: "text",
+              clickFun: (row) => {
+                this.handleLook(row);
+              },
+            },
+            {
+              name: "涓嬭浇",
+              type: "text",
+              clickFun: (row) => {
+                this.handleDown0(row);
+              },
+              disabled: (row) => {
+                return !row.url
+              }
+            },
+            {
+              name: "鎻愪氦",
+              type: "text",
+              clickFun: (row) => {
+                this.handleSubmit(row);
+              },
+              disabled: (row) => {
+                return !!row.submitState && row.submitState != '寰呮彁浜�'
+              }
+            },
+            {
+              name: "瀹℃牳",
+              type: "text",
+              clickFun: (row) => {
+                this.handleCheck(row);
+              },
+              disabled: (row) => {
+                return row.examineState == '閫氳繃' || row.submitState == '寰呮彁浜�'
+              }
+            },
+            {
+              name: "鎵瑰噯",
+              type: "text",
+              clickFun: (row) => {
+                this.handleApproval(row);
+              },
+              disabled: (row) => {
+                return row.ratifyState == '閫氳繃' || row.submitState == '寰呮彁浜�'
+              }
+            },
+          ],
+        },
+      ],
+      page0: {
+        total: 0,
+        size: 10,
+        current: 0,
+      },
+    };
+  },
+  mounted() {
+    // this.entityCopy = this.HaveJson(this.componentData.entity);
+    this.getCustomPageList()
+    this.getList()
+    this.getList0()
+  },
+  methods: {
+    getPower() {
+      let power = JSON.parse(sessionStorage.getItem('power'))
+      let add = false
+      let out = false
+      let submitProcessTotaldeal = false
+      let checkProcessTotaldeal = false
+      let ratifyProcessTotaldeal = false
+      for (var i = 0; i < power.length; i++) {
+        if (power[i].menuMethod == 'addProcessDeal') {
+          add = true
+        }
+        // if (power[i].menuMethod == 'exportProcessEvaluate') {
+        //   out = true
+        // }
+        if (power[i].menuMethod == 'submitProcessTotaldeal') {
+          submitProcessTotaldeal = true
+        }
+        if (power[i].menuMethod == 'checkProcessTotaldeal') {
+          checkProcessTotaldeal = true
+        }
+        if (power[i].menuMethod == 'ratifyProcessTotaldeal') {
+          ratifyProcessTotaldeal = true
+        }
+      }
+      if (!ratifyProcessTotaldeal) {
+        this.componentData.do.splice(4, 1)
+      }
+      if (!checkProcessTotaldeal) {
+        this.componentData.do.splice(3, 1)
+      }
+      if (!submitProcessTotaldeal) {
+        this.componentData.do.splice(2, 1)
+      }
+      if (!add) {
+        this.componentData0.do.splice(1, 1)
+        this.componentData0.do.splice(0, 1)
+      }
+      this.addPower = add
+    },
+    // 鑾峰彇閫佹牱鍗曚綅鍒楄〃
+    getCustomPageList() {
+      selectCustomPageList({
+        current: -1,
+        size: -1
+      }).then(res => {
+        this.customPageList = res.data.body.records
+      }).catch(err => { });
+    },
+    handleDown() { },
+    getList() {
+      this.tableLoading = true;
+      let param = { ...this.queryParams, ...this.page };
+      delete param.total;
+      pageProcessDeal({ ...param })
+        .then((res) => {
+          this.tableLoading = false;
+          if (res.code === 200) {
+            this.tableData = res.data.records;
+            this.page.total = res.data.total;
+          }
+        })
+        .catch((err) => {
+          this.tableLoading = false;
+        });
+    },
+    pagination({ page, limit }) {
+      this.page.current = page;
+      this.page.size = limit;
+      this.getList();
+    },
+    refresh() {
+      this.queryParams0 = {};
+      this.page0.current = 1;
+      this.getList0();
+    },
+    refreshTable() {
+      this.page0.current = 1;
+      this.getList0();
+    },
+    getList0() {
+      this.tableLoading = true;
+      let param = { ...this.queryParams0, ...this.page };
+      delete param.total;
+      pageProcessTotaldeal({ ...param })
+        .then((res) => {
+          this.tableLoading = false;
+          if (res.code === 200) {
+            this.tableData0 = res.data.records;
+            this.page0.total = res.data.total;
+          }
+        })
+        .catch((err) => {
+          this.tableLoading = false;
+        });
+    },
+    pagination0({ page, limit }) {
+      this.page0.current = page;
+      this.page0.size = limit;
+      this.getList0();
+    },
+    // 濉啓
+    // handleAdd(row){
+    //   this.componentData0.entity.totaldealId = row.id
+    //   this.editDialogVisible = true
+    // },
+    // 鎵撳紑鏂板鐣岄潰
+    handleAdd0(row) {
+      if (row) {
+        this.addInfo = this.HaveJson(row)
+        this.title = '缂栬緫'
+      } else {
+        this.title = '鏂板'
+        this.addInfo = {}
+      }
+      this.addDialogVisible = true
+    },
+    // 鎻愪氦鏂板
+    submitAdd() {
+      if (this.addInfo.id) {
+        // 缂栬緫
+        this.addLoading = true
+        doProcessDeal({
+          totaldealId: this.queryParams.totaldealId,
+          ...this.addInfo
+        }).then(res => {
+          this.addLoading = false
+          if (res.code === 201) return
+          this.addDialogVisible = false
+          this.$message({
+            type: 'success',
+            message: '缂栬緫鎴愬姛!'
+          });
+          this.page.current = 0;
+          this.getList();
+        }).catch(err => { });
+      } else {
+        // 鏂板
+        this.addLoading = true
+        addProcessDeal({
+          totaldealId: this.queryParams.totaldealId,
+          ...this.addInfo
+        }).then(res => {
+          this.addLoading = false
+          if (res.code === 201) return
+          this.addDialogVisible = false
+          this.$message({
+            type: 'success',
+            message: '鏂板鎴愬姛!'
+          });
+          this.page.current = 0;
+          this.getList();
+        }).catch(err => { });
+      }
+    },
+    // 鎻愪氦
+    handleSubmit(row) {
+      this.$confirm('鏄惁鎻愪氦 ' + row.month + ' 鏈堜唤鐨勬暟鎹�', '鎻愪氦', {
+        confirmButtonText: '纭畾',
+        cancelButtonText: '鍙栨秷',
+        type: 'warning'
+      }).then(() => {
+        submitProcessTotaldeal({
+          id: row.id
+        }).then(res => {
+          if (res.code === 201) return
+          this.$message({
+            type: 'success',
+            message: '鎻愪氦鎴愬姛!'
+          });
+          this.refreshTable()
+        }).catch(err => { });
+      })
+    },
+    // 鏌ョ湅
+    handleLook(row) {
+      // console.log(row)
+      // this.title0 = '鏌ョ湅'
+      // this.commonFun(row)
+      this.activeName = '濉啓'
+      this.queryParams.totaldealId = row.id
+      this.$nextTick(() => {
+        this.page.current = 0;
+        this.getList();
+      })
+    },
+    commonFun(row, callbanck) {
+      this.currentInfo = row
+      this.queryParams.totaldealId = row.id
+      pageProcessDeal({
+        current: -1,
+        size: -1, ...this.queryParams
+      }).then(res => {
+        this.lookDialogVisible = true
+        this.currentInfo.arr = res.data.records
+        if (callbanck) {
+          callbanck()
+        }
+      }).catch(err => { });
+    },
+    // 瀹℃牳
+    handleCheck(row) {
+      this.title0 = '瀹℃牳'
+      this.commonFun(row)
+    },
+    // 鎵瑰噯
+    handleApproval(row) {
+      this.title0 = '鎵瑰噯'
+      this.commonFun(row)
+    },
+    // 鎻愪氦瀹℃牳/鎵瑰噯
+    submitCheck(state) {
+      if (state == '閫氳繃') {
+        this.checkLoading = true
+      } else {
+        this.noCheckLoading = true
+      }
+      if (this.title0 == '瀹℃牳') {
+        checkProcessTotaldeal({
+          id: this.currentInfo.id,
+          state: state
+        }).then(res => {
+          this.checkLoading = false
+          this.noCheckLoading = false
+          if (res.code === 201) return
+          this.$message({
+            type: 'success',
+            message: '鎿嶄綔鎴愬姛!'
+          });
+          this.refreshTable()
+          this.lookDialogVisible = false
+        }).catch(err => { });
+      } else if (this.title0 == '鎵瑰噯') {
+        ratifyProcessTotaldeal({
+          id: this.currentInfo.id,
+          state: state
+        }).then(res => {
+          this.checkLoading = false
+          this.noCheckLoading = false
+          if (res.code === 201) return
+          this.$message({
+            type: 'success',
+            message: '鎿嶄綔鎴愬姛!'
+          });
+          this.refreshTable()
+          this.lookDialogVisible = false
+        }).catch(err => { });
+      }
+    },
+    // 瀵煎嚭璇︽儏
+    handleDown0(row) {
+      // 鍚庣涓嬭浇
+      let url = this.javaApi + '/word/' + row.url
+      this.$download.saveAs(url, row.month + ' 鏍峰搧澶勭悊鐢宠琛�');
+    },
+    handleDelete(row) {
+      this.$confirm("鏄惁鍒犻櫎璇ユ潯鏁版嵁?", "鎻愮ず", {
+        confirmButtonText: "纭畾",
+        cancelButtonText: "鍙栨秷",
+        type: "warning",
+      })
+        .then(() => {
+          delProcessDeal({ id: row.id }).then((res) => {
+            if (res.code == 201) return;
+            this.$message.success("鍒犻櫎鎴愬姛");
+            this.refresh();
+          });
+        })
+        .catch(() => { });
+    },
+  },
+}
+</script>
+
+<style scoped>
+.title {
+  height: 60px;
+  line-height: 60px;
+}
+
+.search {
+  background-color: #fff;
+  height: 40px;
+  display: flex;
+  align-items: center;
+  position: relative;
+}
+
+.search_thing {
+  width: 350px;
+  display: flex;
+  align-items: center;
+}
+
+.search_label {
+  width: 110px;
+  font-size: 14px;
+  text-align: right;
+}
+
+.search_input {
+  width: calc(100% - 110px);
+}
+
+.table {
+  background-color: #fff;
+  height: calc(100% - 60px - 140px);
+  padding: 20px;
+}
+
+.downPdf {
+  opacity: 0 !important;
+}
+
+.tables {
+  table-layout: fixed;
+  width: 100%;
+}
+
+.tables td {
+  height: 40px;
+  width: 100px;
+  text-align: center;
+  font-size: 14px;
+  word-wrap: break-word;
+  white-space: normal;
+}
+
+.en {
+  font-size: 12px;
+  word-break: break-word;
+  /* 鑷姩鏂 */
+  overflow-wrap: break-word;
+  /* 闃叉婧㈠嚭 */
+  white-space: normal;
+  /* 榛樿鎹㈣ */
+}
+
+.user-info {
+  display: flex;
+  align-items: center;
+  justify-content: space-evenly;
+  margin-top: 20px;
+}
+
+.user-info .el-button {
+  margin: 0;
+}
+
+>>>.el-tabs__content {
+  height: 100%;
+}
+</style>
diff --git a/src/views/CNAS/resourceDemand/standardMaterialAccept/component/AddRecord.vue b/src/views/CNAS/resourceDemand/standardMaterialAccept/component/AddRecord.vue
index bd776c7..dc48446 100644
--- a/src/views/CNAS/resourceDemand/standardMaterialAccept/component/AddRecord.vue
+++ b/src/views/CNAS/resourceDemand/standardMaterialAccept/component/AddRecord.vue
@@ -1,103 +1,261 @@
 <template>
-    <el-dialog :visible.sync="dialogVisible" title="鏍囧噯鐗╄川楠屾敹璁板綍" width="70%">
-       <el-steps :active="currentStep" finish-status="success">
-            <el-step class="cursor-pointer" v-for="(item, index) in steps" :key="index" :title="item">
-            </el-step>
-        </el-steps>
-        <el-form :model="model" label-width="140px" size="small">
-            <Step1 :model.sync="model"></Step1>
-        </el-form>
-        <span slot="footer" class="dialog-footer">
-            <el-button @click="dialogVisible = false">鍙� 娑�</el-button>
-            <el-button type="primary" @click="submit">淇� 瀛�</el-button>
-        </span>
-    </el-dialog>
+  <el-dialog :visible.sync="dialogVisible" title="鏍囧噯鐗╄川楠屾敹璁板綍" width="72%" v-loading="loading">
+    <el-form :model="acceptance" ref="acceptance" label-width="140px" size="small">
+      <el-col :span="12">
+        <el-form-item label="鍘傚浠h〃" prop="producer">
+          <el-input v-model="acceptance.producer"></el-input>
+        </el-form-item>
+      </el-col>
+      <el-col :span="12">
+        <el-form-item label="鐩稿叧闄勪欢" prop="file">
+          <div class="table-between">
+            <el-input v-model="acceptance.file" style="width: 80%;" disabled></el-input>
+            <el-upload
+              ref="upload"
+              style="float: right;"
+              :headers="uploadHeader"
+              :action="action"
+              :show-file-list="false"
+              :on-success="onSuccess"
+            >
+              <el-button type="primary">
+                闄勪欢涓婁紶
+              </el-button>
+            </el-upload>
+          </div>
+        </el-form-item>
+      </el-col>
+      <el-col :span="12">
+        <el-form-item label="鎺ユ敹浜�" prop="recipient">
+          <el-input v-model="acceptance.recipient"></el-input>
+        </el-form-item>
+      </el-col>
+      <el-col :span="12">
+        <el-form-item label="鎺ュ彈绛惧瓧" prop="signature">
+          <el-input v-model="acceptance.signature"></el-input>
+        </el-form-item>
+      </el-col>
+      <el-col :span="12">
+        <el-form-item label="楠屾敹鎯呭喌" prop="situation">
+          <el-input v-model="acceptance.situation"></el-input>
+        </el-form-item>
+      </el-col>
+      <el-col :span="12">
+        <el-form-item label="瀹夎璋冭瘯鎯呭喌" prop="installation">
+          <el-input v-model="acceptance.installation"></el-input>
+        </el-form-item>
+      </el-col>
+      <el-col :span="12">
+        <el-form-item label="娓呭崟" prop="substanceId"
+                      :rule="[{ required: true, message: '璇烽�夋嫨娓呭崟', trigger: 'change' }]">
+          <el-select v-model="acceptance.substanceId" placeholder="璇烽�夋嫨" style="width: 100%">
+            <el-option
+              v-for="item in options"
+              :key="item.value"
+              :label="item.name"
+              :value="item.id">
+            </el-option>
+          </el-select>
+        </el-form-item>
+      </el-col>
+      <el-col :span="12">
+        <el-form-item label="鍒拌揣鏃ユ湡" prop="arriveDate">
+          <el-date-picker
+            v-model="acceptance.arriveDate"
+            align="right"
+            type="date"
+            placeholder="閫夋嫨鏃ユ湡"
+            style="width: 100%"
+            value-format="yyyy-MM-dd"
+          >
+          </el-date-picker>
+        </el-form-item>
+      </el-col>
+      <el-col :span="12">
+        <el-form-item label="缁翠慨鍗曚綅" prop="maintenanceUnit">
+          <el-input v-model="acceptance.maintenanceUnit"></el-input>
+        </el-form-item>
+      </el-col>
+      <el-col :span="24">
+        <el-form-item label="澶囦欢纭">
+          <el-button type="primary" style="float: right;" @click="addSpareTable">澧炲姞琛�</el-button>
+        </el-form-item>
+      </el-col>
+      <el-col :span="24">
+        <lims-table :tableData="list" :column="spareColumns" height="300">
+          <template slot="name" slot-scope="{ row, index }">
+            <el-input v-if="row.isEdit" size="small" v-model="row.name"></el-input>
+            <span v-else>{{ row.name }}</span>
+          </template>
+          <template slot="number" slot-scope="{ row, index }">
+            <el-input v-if="row.isEdit" size="small" v-model="row.number"></el-input>
+            <span v-else>{{ row.number }}</span>
+          </template>
+          <template slot="action" slot-scope="{ row, index }">
+            <div v-if="row.isEdit">
+              <el-button type="text" @click="save(index)">淇濆瓨</el-button>
+              <el-button type="text">鍙栨秷</el-button>
+            </div>
+            <div v-else>
+              <el-button type="text" @click="edit(index)">淇敼</el-button>
+            </div>
+          </template>
+        </lims-table>
+      </el-col>
+    </el-form>
+    <span slot="footer" class="dialog-footer">
+      <el-button @click="closeDialog">鍙� 娑�</el-button>
+      <el-button type="primary" :loading="submitLoading" @click="submit">淇� 瀛�</el-button>
+    </span>
+  </el-dialog>
 </template>
 
 <script>
-import Step1 from './Step1.vue'
+import limsTable from "@/components/Table/lims-table.vue";
+import {
+  addAcceptance, getAcceptanceDetails,
+  getStandardSubstanceAll,
+  updateAcceptance
+} from "@/api/cnas/resourceDemand/standardMaterialAccept/standardMaterialAccept";
 export default {
-    components: {
-        Step1
-    },
-    data() {
-        return {
-            dialogVisible: false,
-            currentStep: 0, // 姝ラ鏉℃樉绀虹鍑犳
-            steps: ['鎻愪氦', '寮�绠遍獙鏀跺鏍�', '瀹夎楠屾敹妫�鏌�', '瀹夎楠屾敹澶嶆牳', '楠屾敹鏍告煡', '楠屾敹鏍告煡瀹℃牳'],
-            model: {
-                acceptance: {
-                    id: undefined,
-                    producer: undefined, // 鍘傚浠h〃
-                    file: undefined,   // 鐩稿叧闄勪欢
-                    recipient: undefined,   // 鎺ユ敹浜�
-                    signature: undefined,   // 鎺ュ彈绛惧瓧
-                    situation: undefined,   // 楠屾敹鎯呭喌
-                    installation: undefined,    // 瀹夎璋冭瘯鎯呭喌
-                    substanceId: undefined, // 娓呭崟
-                    arriveDate: undefined,   // 鍒拌揣鏃ユ湡
-                    maintenanceUnit: undefined,   // 缁翠慨鍗曚綅
-                },
-                list: []
-            }
+  components: {
+    limsTable,
+  },
+  data() {
+    return {
+      dialogVisible: false,
+      loading: false,
+      submitLoading: false,
+      acceptance: {
+        id: undefined,
+        producer: undefined, // 鍘傚浠h〃
+        file: undefined,   // 鐩稿叧闄勪欢
+        recipient: undefined,   // 鎺ユ敹浜�
+        signature: undefined,   // 鎺ュ彈绛惧瓧
+        situation: undefined,   // 楠屾敹鎯呭喌
+        installation: undefined,    // 瀹夎璋冭瘯鎯呭喌
+        substanceId: undefined, // 娓呭崟
+        arriveDate: undefined,   // 鍒拌揣鏃ユ湡
+        maintenanceUnit: undefined,   // 缁翠慨鍗曚綅
+        list: [],
+      },
+      list: [],
+      spareColumns: [
+        {
+          label: "鍚嶇О",
+          prop: "name",
+          align: "center",
+          dataType: "slot",
+          slot: "name",
+        }, {
+          label: "鏁伴噺",
+          prop: "number",
+          align: "center",
+          dataType: "slot",
+          slot: "number",
+        }, {
+          label: "鎿嶄綔",
+          align: "center",
+          dataType: "slot",
+          slot: "action",
+          width: 150
         }
-    },
-    watch: {
-        model(newVal) {
-            this.model = newVal
-        }
-    },
-    methods: {
-        clearForm() {
-            this.model.acceptance.id = undefined
-            this.model.acceptance.producer = undefined
-            this.model.acceptance.file = undefined
-            this.model.acceptance.recipient = undefined
-            this.model.acceptance.signature = undefined
-            this.model.acceptance.situation = undefined
-            this.model.acceptance.installation = undefined
-            this.model.acceptance.substanceId = undefined
-            this.model.acceptance.arriveDate = undefined
-            this.model.acceptance.maintenanceUnit = undefined
-            this.model.list = []
-        },
-        openDialog(form) {
-            console.log(form)
-            if(form) {
-                this.model.acceptance.id = form.acceptance.id
-                this.model.acceptance.producer = form.acceptance.producer
-                this.model.acceptance.file = form.acceptance.file
-                this.model.acceptance.recipient = form.acceptance.recipient
-                this.model.acceptance.signature = form.acceptance.signature
-                this.model.acceptance.situation = form.acceptance.situation
-                this.model.acceptance.installation = form.acceptance.installation
-                this.model.acceptance.substanceId = form.acceptance.substanceId
-                this.model.acceptance.arriveDate = form.acceptance.arriveDate
-                this.model.acceptance.maintenanceUnit = form.acceptance.maintenanceUnit
-                this.model.list = form.list
-            } else {
-                this.clearForm()
-            }
-            this.dialogVisible = true
-        },
-        closeDialog() {
-            this.dialogVisible = false
-        },
-        submit() {
-          if (!this.model.acceptance.substanceId) {
-            this.$message.warning('璇烽�夋嫨娓呭崟')
-            return
-          }
-            this.$emit('submit', this.model)
-            this.closeDialog()
-        }
+      ],
+      options: []
     }
+  },
+  mounted() {
+    this.getStand()
+  },
+  methods: {
+    openDialog(id) {
+      if(id) {
+        this.getDetail(id)
+      } else {
+        this.clearForm()
+      }
+      this.dialogVisible = true
+    },
+    getDetail(id) {
+      this.loading = true
+      getAcceptanceDetails({id: id}).then(res => {
+        this.acceptance = res.data.acceptance
+        this.list = res.data.list
+        this.loading = false
+      }).catch(err => {
+        this.loading = false
+      })
+    },
+    getStand() {
+      getStandardSubstanceAll().then(res => {
+        this.options = res.data
+      })
+    },
+    addSpareTable() {
+      this.list.push({
+        acceptanceId: this.acceptance.id,
+        name: '',
+        number: '',
+        isEdit: true
+      })
+    },
+    onSuccess(response) {
+      this.acceptance.file = response.data
+    },
+    save(index) {
+      this.$set(this.list[index], 'isEdit', false)
+    },
+    edit(index) {
+      this.$set(this.list[index], 'isEdit', true)
+    },
+    clearForm() {
+      this.list = []
+      this.resetForm('acceptance')
+    },
+    closeDialog() {
+      this.clearForm()
+      this.resetForm('acceptance')
+      this.dialogVisible = false
+    },
+    submit() {
+      if (!this.acceptance.substanceId) {
+        this.$message.warning('璇烽�夋嫨娓呭崟')
+        return
+      }
+      this.acceptance.list = this.HaveJson(this.list)
+      this.submitLoading = true
+      if(this.acceptance.id) {
+        updateAcceptance({acceptance: this.acceptance, list: this.list}).then(res => {
+          this.$message.success('缂栬緫鎴愬姛')
+          this.submitLoading = false
+          this.closeDialog()
+          this.$emit('submit')
+        }).catch((e) => {
+          this.submitLoading = false
+        })
+      } else {
+        addAcceptance({acceptance: this.acceptance, list: this.list}).then(res => {
+          this.$message.success('鏂板鎴愬姛')
+          this.closeDialog()
+          this.$emit('submit')
+        }).catch((e) => {
+          this.submitLoading = false
+        })
+      }
+    },
+  },
+  computed: {
+    action() {
+      return this.javaApi + '/personBasicInfo/saveCNASFile'
+    }
+  },
 }
 
 </script>
 
 <style scoped>
-.cursor-pointer {
-    cursor: pointer;
+>>>.el-dialog__body {
+  height: 580px;
+  overflow-y: auto;
 }
 </style>
diff --git a/src/views/CNAS/resourceDemand/standardMaterialAccept/component/Step1.vue b/src/views/CNAS/resourceDemand/standardMaterialAccept/component/Step1.vue
deleted file mode 100644
index 967c41b..0000000
--- a/src/views/CNAS/resourceDemand/standardMaterialAccept/component/Step1.vue
+++ /dev/null
@@ -1,198 +0,0 @@
-<template>
-  <el-card class="card">
-    <el-col :span="12">
-      <el-form-item label="鍘傚浠h〃">
-        <el-input v-model="model.acceptance.producer"></el-input>
-      </el-form-item>
-    </el-col>
-    <el-col :span="12">
-      <el-form-item label="鐩稿叧闄勪欢">
-        <div class="table-between">
-          <el-input v-model="model.acceptance.file" style="width: 82%;"></el-input>
-          <el-upload
-            ref="upload"
-            style="float: left; margin: 0 12px 0 20px;"
-            :action="action"
-            :show-file-list="false"
-            :on-success="onSuccess"
-          >
-            <el-button type="primary">
-              闄勪欢涓婁紶
-            </el-button>
-          </el-upload>
-        </div>
-      </el-form-item>
-    </el-col>
-    <el-col :span="12">
-      <el-form-item label="鎺ユ敹浜�">
-        <el-input v-model="model.acceptance.recipient"></el-input>
-      </el-form-item>
-    </el-col>
-    <el-col :span="12">
-      <el-form-item label="鎺ュ彈绛惧瓧">
-        <el-input v-model="model.acceptance.signature"></el-input>
-      </el-form-item>
-    </el-col>
-    <el-col :span="12">
-      <el-form-item label="楠屾敹鎯呭喌">
-        <el-input v-model="model.acceptance.situation"></el-input>
-      </el-form-item>
-    </el-col>
-    <el-col :span="12">
-      <el-form-item label="瀹夎璋冭瘯鎯呭喌">
-        <el-input v-model="model.acceptance.installation"></el-input>
-      </el-form-item>
-    </el-col>
-    <el-col :span="12">
-      <el-form-item label="娓呭崟" prop="substanceId" required>
-        <el-select v-model="model.acceptance.substanceId" placeholder="璇烽�夋嫨" style="width: 100%">
-          <el-option
-            v-for="item in options"
-            :key="item.value"
-            :label="item.name"
-            :value="item.id">
-          </el-option>
-        </el-select>
-      </el-form-item>
-    </el-col>
-    <el-col :span="12">
-      <el-form-item label="鍒拌揣鏃ユ湡">
-        <el-date-picker
-          v-model="model.acceptance.arriveDate"
-          align="right"
-          type="date"
-          placeholder="閫夋嫨鏃ユ湡"
-          style="width: 100%"
-          value-format="yyyy-MM-dd"
-        >
-        </el-date-picker>
-      </el-form-item>
-    </el-col>
-    <el-col :span="12">
-      <el-form-item label="缁翠慨鍗曚綅">
-        <el-input v-model="model.acceptance.maintenanceUnit"></el-input>
-      </el-form-item>
-    </el-col>
-    <el-col :span="24">
-      <el-form-item label="澶囦欢纭">
-        <el-button type="primary" style="float: right;" @click="addSpareTable">澧炲姞琛�</el-button>
-      </el-form-item>
-    </el-col>
-    <el-col :span="24">
-      <el-form-item>
-        <lims-table :tableData="model.list" :column="spareColumns" :height="'calc(100vh - 250px)'">
-          <template slot="name" slot-scope="{ row, index }">
-            <el-input v-if="row.isEdit" size="small" v-model="row.name"></el-input>
-            <span v-else>{{ row.name }}</span>
-          </template>
-          <template slot="number" slot-scope="{ row, index }">
-            <el-input v-if="row.isEdit" size="small" v-model="row.number"></el-input>
-            <span v-else>{{ row.number }}</span>
-          </template>
-          <template slot="action" slot-scope="{ row, index }">
-            <div v-if="row.isEdit">
-              <el-button type="text" @click="save(index)">淇濆瓨</el-button>
-              <el-button type="text">鍙栨秷</el-button>
-            </div>
-            <div v-else>
-              <el-button type="text" @click="edit(index)">淇敼</el-button>
-            </div>
-          </template>
-        </lims-table>
-      </el-form-item>
-    </el-col>
-  </el-card>
-</template>
-
-<script>
-// import { getStandardSubstanceAll } from "@/assets/api/api";
-import axios from 'axios';
-import limsTable from '@/components/Table/lims-table.vue'
-import {
-  getStandardSubstanceAll
-} from '@/api/cnas/resourceDemand/standardMaterialAccept/standardMaterialAccept'
-
-export default {
-  components: {
-    limsTable
-  },
-  props: {
-    model: {
-      type: Object,
-      default: () => {}
-    }
-  },
-  data() {
-    return {
-      spareColumns: [
-        {
-          label: "鍚嶇О",
-          prop: "name",
-          align: "center",
-          dataType: "slot",
-          slot: "name",
-        }, {
-          label: "鏁伴噺",
-          prop: "number",
-          align: "center",
-          dataType: "slot",
-          slot: "number",
-        }, {
-          label: "鎿嶄綔",
-          align: "center",
-          dataType: "slot",
-          slot: "action",
-          width: 150
-        }
-      ],
-      options: []
-    }
-  },
-  computed: {
-    action() {
-     return `${this.javaApi}/personBasicInfo/saveCNASFile`
-    }
-  },
-  mounted() {
-    this.getStand()
-  },
-  methods: {
-    async getStand() {
-      getStandardSubstanceAll().then(res => {
-        this.options = res.data
-      })
-    },
-    addSpareTable() {
-      this.model.list.push({
-        acceptanceId: this.model.acceptance.id,
-        name: '',
-        number: '',
-        isEdit: true
-      })
-    },
-    onSuccess(response) {
-      this.model.acceptance.file = response.data
-      this.$emit('update:model', this.model)
-    },
-    save(index) {
-      this.model.list[index].isEdit = false
-      this.$emit('update:model', this.model)
-    },
-    edit(index) {
-      this.model.list[index].isEdit = true
-    }
-  }
-}
-</script>
-
-<style scoped>
-.card {
-  margin-top: 1em;
-  height: 56vh;
-  overflow-y: scroll;
-}
-.table-between {
-  display: flex;
-  justify-content: space-between;
-}
-</style>
diff --git a/src/views/CNAS/resourceDemand/standardMaterialAccept/index.vue b/src/views/CNAS/resourceDemand/standardMaterialAccept/index.vue
index 241a3c0..fe9ee04 100644
--- a/src/views/CNAS/resourceDemand/standardMaterialAccept/index.vue
+++ b/src/views/CNAS/resourceDemand/standardMaterialAccept/index.vue
@@ -19,24 +19,21 @@
     </div>
     <div class="table">
       <lims-table :tableData="tableData" :column="columns" :height="'calc(100vh - 250px)'" @pagination="pagination"
-        :page="page" :tableLoading="tableLoading"></lims-table>
+        :page="page" :tableLoading="tableLoading">
+        <template slot="action" slot-scope="{ row }">
+          <el-button type="text" @click="edit(row)">缂栬緫</el-button>
+        </template>
+      </lims-table>
     </div>
-    <AddRecord ref="addRecordRef" @submit="submit"></AddRecord>
+    <AddRecord ref="addRecordRef" v-if="addRecordRef" @submit="submit"></AddRecord>
   </div>
 </template>
 
 <script>
-// import axios from "axios";
-// import { getPageAcceptance, addAcceptance, updateAcceptance, getAcceptanceDetails, exportAcceptance } from "@/assets/api/api";
-// import ZTTable from '@/components/caorui/ZTTable/index.vue';
-// import AddRecord from './components/AddRecord.vue';
-
 import limsTable from '@/components/Table/lims-table.vue'
 import AddRecord from './component/AddRecord.vue';
 import {
-  getPageAcceptance,
-  updateAcceptanc,
-  addAcceptance
+  getPageAcceptance, getAcceptanceDetails, exportFeStandardSubstanceAcceptance, updateAcceptance, addAcceptance
 } from '@/api/cnas/resourceDemand/standardMaterialAccept/standardMaterialAccept'
 export default {
   components: {
@@ -48,6 +45,7 @@
       form: {
         search: undefined
       },
+      addRecordRef: false,
       columns: [
         {
           label: "鍑哄満缂栧彿",
@@ -114,56 +112,39 @@
     this.getTableData()
   },
   methods: {
-    async getTableData() {
-      const res = await getPageAcceptance(this.form);
-      if (res.code === 200) {
+    getTableData() {
+      getPageAcceptance(this.form).then(res => {
         this.tableData = res.data.records;
         this.page.total = res.data.total;
-      }
-
+      })
     },
     openDialog() {
-      this.$refs.addRecordRef.openDialog()
-    },
-    async submit(form) {
-
-      const { code } = await form.acceptance.id ? updateAcceptanc(this.form) : addAcceptance((this.form));
-      if (code == 200) {
-        this.$message.success(`${form.acceptance.id ? '缂栬緫' : '娣诲姞'}鎴愬姛`)
-        this.getTableData()
-      }
-    },
-    async edit(row) {
-      const res = await this.getDetail(row.id)
-      this.$refs.addRecordRef.openDialog({
-        acceptance: res.acceptance,
-        list: res.list
+      this.addRecordRef = true;
+      this.$nextTick(() => {
+        this.$refs.addRecordRef.openDialog()
       })
     },
-    async getDetail(id) {
-      const { code, data } = await axios({
-        method: 'get',
-        url: getAcceptanceDetails,
-        params: { id }
+    submit() {
+      this.addRecordRef = false;
+      this.getTableData()
+    },
+    edit(row) {
+      this.addRecordRef = true;
+      this.$nextTick(() => {
+        this.$refs.addRecordRef.openDialog(row.id)
       })
-      if (code == 200) {
-        return data;
-      }
     },
     reset() {
       this.form.search = undefined
       this.getTableData()
     },
     async exportExcel() {
-      const res = await axios({
-        method: "get",
-        url: `${exportAcceptance}`,
-        responseType: "blob"
+      exportFeStandardSubstanceAcceptance().then(res => {
+        const blob = new Blob([res], { type: 'application/octet-stream' });
+        this.$download.saveAs(blob, '鏍囧噯鐗╄川楠屾敹.xlsx');
+        this.$message.success('瀵煎嚭鎴愬姛')
       })
-      const blob = new Blob([res], { type: 'application/octet-stream' });
-      this.$download.saveAs(blob, '鏍囧噯鐗╄川楠屾敹.xlsx');
     },
-
     // 鍒嗛〉鍒囨崲
     pagination(page) {
       this.page.size = page.limit
diff --git a/src/views/CNAS/systemManagement/correctiveAction/index.vue b/src/views/CNAS/systemManagement/correctiveAction/index.vue
index 6e92fbd..bb41fae 100644
--- a/src/views/CNAS/systemManagement/correctiveAction/index.vue
+++ b/src/views/CNAS/systemManagement/correctiveAction/index.vue
@@ -109,8 +109,8 @@
       page: {
         size: 20,
         current: 1,
+        total: 0,
       },
-      total: 0,
       correctiveInfo: false,
       viewTestRecordDialog: false,
     };
@@ -131,7 +131,7 @@
         this.tableLoading = false
         if (res.code === 201) return
         this.tableData = res.data.records
-        this.total = res.data.total
+        this.page.total = res.data.total
       }).catch(err => {
         console.log('err---', err);
         this.tableLoading = false
diff --git a/src/views/CNAS/systemManagement/documentControl/components/ControlledFileApplication.vue b/src/views/CNAS/systemManagement/documentControl/components/ControlledFileApplication.vue
index 81b5f6a..1a25201 100644
--- a/src/views/CNAS/systemManagement/documentControl/components/ControlledFileApplication.vue
+++ b/src/views/CNAS/systemManagement/documentControl/components/ControlledFileApplication.vue
@@ -470,18 +470,25 @@
       formData.append('state', this.type); // 鏂囦欢鍚嶅瓧娈�
       formData.append('writer', this.currentInfo.writer); // 鏂囦欢鍚嶅瓧娈�
 
-      let res = await checkManageDocumentControlled(formData)
-      this.checkLoading = false
-      this.noCheckLoading = false
-      if (res.code == 200) {
-        this.$message({ message: '鎿嶄綔鎴愬姛', type: 'success' });
-        this.checkDialogVisible = false;
-        this.refreshTable()
-        return true
-      } else {
-        this.$message({ message: '鎿嶄綔澶辫触', type: 'error' });
-        return false
+      try {
+        let res = await checkManageDocumentControlled(formData)
+        this.checkLoading = false
+        this.noCheckLoading = false
+        if (res.code == 200) {
+          this.$message({ message: '鎿嶄綔鎴愬姛', type: 'success' });
+          this.checkDialogVisible = false;
+          this.refreshTable()
+          return true
+        } else {
+          this.$message({ message: '鎿嶄綔澶辫触', type: 'error' });
+          return false
+        }
+      } catch (e) {
+        this.checkLoading = false
+        this.noCheckLoading = false
       }
+
+
     },
     handleCheckSub(type) {
       this.type = type
diff --git a/src/views/CNAS/systemManagement/documentControl/components/FileList.vue b/src/views/CNAS/systemManagement/documentControl/components/FileList.vue
index 7a88db6..765c0d3 100644
--- a/src/views/CNAS/systemManagement/documentControl/components/FileList.vue
+++ b/src/views/CNAS/systemManagement/documentControl/components/FileList.vue
@@ -334,17 +334,22 @@
       formData.append('file', pdfBlob, fileName); // 鏂囦欢瀛楁
       formData.append('id', this.currentInfo.id); // 鏂囦欢鍚嶅瓧娈�
 
-      let res = await uploadFileManageDocumentList(formData)
-      this.addLoading = false
-      if (res.code == 200) {
-        this.$message({ message: '涓婁紶鎴愬姛', type: 'success' });
-        this.addDialogVisible = false;
-        this.refreshTable()
-        return true
-      } else {
-        this.$message({ message: '涓婁紶澶辫触', type: 'error' });
-        return false
+      try {
+        let res = await uploadFileManageDocumentList(formData)
+        this.addLoading = false
+        if (res.code == 200) {
+          this.$message({ message: '涓婁紶鎴愬姛', type: 'success' });
+          this.addDialogVisible = false;
+          this.refreshTable()
+          return true
+        } else {
+          this.$message({ message: '涓婁紶澶辫触', type: 'error' });
+          return false
+        }
+      } catch (e) {
+        this.addLoading = false
       }
+
     },
     handleDelete(row) {
       this.$confirm("鏄惁鍒犻櫎璇ユ潯鏁版嵁?", "鎻愮ず", {
diff --git a/src/views/CNAS/systemManagement/measuresDealRisks/components/hazardIdentificationRiskAssessment.vue b/src/views/CNAS/systemManagement/measuresDealRisks/components/hazardIdentificationRiskAssessment.vue
index 07629ec..b0c63c5 100644
--- a/src/views/CNAS/systemManagement/measuresDealRisks/components/hazardIdentificationRiskAssessment.vue
+++ b/src/views/CNAS/systemManagement/measuresDealRisks/components/hazardIdentificationRiskAssessment.vue
@@ -13,7 +13,7 @@
         <el-button size="small" @click="openDownloadDia">瀵煎嚭</el-button>
       </div>
     </div>
-    <el-table :data="tableData" style="width: 100%" height="calc(100vh - 18em)">
+    <el-table :data="tableData" style="width: 100%" height="calc(100vh - 18em)" key="table1">
       <el-table-column type="index" label="搴忓彿" width="120">
         <template v-slot="scope">
           <span>{{ (page.current - 1) * page.size + scope.$index + 1 }}</span>
@@ -142,7 +142,7 @@
       page: {
         total: 0,
         size: 10,
-        current: 0,
+        current: 1,
       },
       tableData: [],
       loading: false
diff --git a/src/views/CNAS/systemManagement/measuresDealRisks/components/listRiskAnalysisControlPlans.vue b/src/views/CNAS/systemManagement/measuresDealRisks/components/listRiskAnalysisControlPlans.vue
index 33adb1f..ca6e916 100644
--- a/src/views/CNAS/systemManagement/measuresDealRisks/components/listRiskAnalysisControlPlans.vue
+++ b/src/views/CNAS/systemManagement/measuresDealRisks/components/listRiskAnalysisControlPlans.vue
@@ -13,7 +13,7 @@
         <el-button size="small" @click="openDownloadDia">瀵煎嚭</el-button>
       </div>
     </div>
-    <el-table :data="tableData" style="width: 100%" height="calc(100vh - 18em)">
+    <el-table :data="tableData" style="width: 100%" height="calc(100vh - 18em)" key="table0">
       <el-table-column type="index" label="搴忓彿" width="120">
         <template v-slot="scope">
           <span>{{ (search.current - 1) * search.size + scope.$index + 1 }}</span>
diff --git a/src/views/business/inspectionTask/index.vue b/src/views/business/inspectionTask/index.vue
index 600e362..e10d812 100644
--- a/src/views/business/inspectionTask/index.vue
+++ b/src/views/business/inspectionTask/index.vue
@@ -518,10 +518,18 @@
           prop: "insResult",
           dataType: "tag",
           formatData: (params) => {
-            return this.insResultList.find((m) => m.value == params).label;
+            let obj = this.insResultList.find((m) => m.value == params)
+            if (obj) {
+              return this.insResultList.find((m) => m.value == params).label;
+            } else {
+              return ''
+            }
           },
           formatType: (params) => {
-            return this.insResultList.find((m) => m.value == params).type;
+            let obj = this.insResultList.find((m) => m.value == params)
+            if (obj) {
+              return this.insResultList.find((m) => m.value == params).type;
+            }
           },
         },
         {
diff --git a/src/views/performance/class/index.vue b/src/views/performance/class/index.vue
index d5a7a4a..31ac64c 100644
--- a/src/views/performance/class/index.vue
+++ b/src/views/performance/class/index.vue
@@ -808,7 +808,7 @@
       }
     },
     getUsers() {
-      selectUserCondition().then((res) => {
+      selectUserCondition({ type: 1 }).then((res) => {
         if (res.code === 201) {
           return;
         }
diff --git a/src/views/system/menu/index.vue b/src/views/system/menu/index.vue
index c9e5b75..108aa2a 100644
--- a/src/views/system/menu/index.vue
+++ b/src/views/system/menu/index.vue
@@ -223,8 +223,8 @@
                 </el-tooltip>
                 鍙湅鎴戞寜閽�
               </span>
-              <el-switch v-model="form.isRersonalButton" inactive-text="涓嶆樉绀�" active-text="鏄剧ず" inactive-value="0"
-                active-value="1">
+              <el-switch v-model="form.isRersonalButton" inactive-text="涓嶆樉绀�" active-text="鏄剧ず" :inactive-value="0"
+                :active-value="1">
               </el-switch>
             </el-form-item>
           </el-col>
@@ -340,7 +340,8 @@
         isFrame: "1",
         isCache: "0",
         visible: "0",
-        status: "0"
+        status: "0",
+        isRersonalButton: 0
       };
       this.resetForm("form");
     },
@@ -379,6 +380,7 @@
       this.getTreeselect();
       getMenu(row.menuId).then(response => {
         this.form = response.data;
+        this.form.isRersonalButton = Number(this.form.isRersonalButton)
         this.open = true;
         this.title = "淇敼鑿滃崟";
       });
diff --git a/src/views/system/role/index.vue b/src/views/system/role/index.vue
index 0f5f894..93de712 100644
--- a/src/views/system/role/index.vue
+++ b/src/views/system/role/index.vue
@@ -4,48 +4,22 @@
       <div>
         <el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch">
           <el-form-item label="瑙掕壊鍚嶇О" prop="roleName">
-            <el-input
-              v-model="queryParams.roleName"
-              placeholder="璇疯緭鍏ヨ鑹插悕绉�"
-              clearable
-              style="width: 200px"
-              @keyup.enter.native="handleQuery"
-            />
+            <el-input v-model="queryParams.roleName" placeholder="璇疯緭鍏ヨ鑹插悕绉�" clearable style="width: 200px"
+              @keyup.enter.native="handleQuery" />
           </el-form-item>
           <el-form-item label="鏉冮檺瀛楃" prop="roleKey">
-            <el-input
-              v-model="queryParams.roleKey"
-              placeholder="璇疯緭鍏ユ潈闄愬瓧绗�"
-              clearable
-              style="width: 200px"
-              @keyup.enter.native="handleQuery"
-            />
+            <el-input v-model="queryParams.roleKey" placeholder="璇疯緭鍏ユ潈闄愬瓧绗�" clearable style="width: 200px"
+              @keyup.enter.native="handleQuery" />
           </el-form-item>
           <el-form-item label="鐘舵��" prop="status">
-            <el-select
-              v-model="queryParams.status"
-              placeholder="瑙掕壊鐘舵��"
-              clearable
-              style="width: 200px"
-            >
-              <el-option
-                v-for="dict in dict.type.sys_normal_disable"
-                :key="dict.value"
-                :label="dict.label"
-                :value="dict.value"
-              />
+            <el-select v-model="queryParams.status" placeholder="瑙掕壊鐘舵��" clearable style="width: 200px">
+              <el-option v-for="dict in dict.type.sys_normal_disable" :key="dict.value" :label="dict.label"
+                :value="dict.value" />
             </el-select>
           </el-form-item>
           <el-form-item label="鍒涘缓鏃堕棿">
-            <el-date-picker
-              v-model="dateRange"
-              style="width: 200px"
-              value-format="yyyy-MM-dd"
-              type="daterange"
-              range-separator="-"
-              start-placeholder="寮�濮嬫棩鏈�"
-              end-placeholder="缁撴潫鏃ユ湡"
-            ></el-date-picker>
+            <el-date-picker v-model="dateRange" style="width: 200px" value-format="yyyy-MM-dd" type="daterange"
+              range-separator="-" start-placeholder="寮�濮嬫棩鏈�" end-placeholder="缁撴潫鏃ユ湡"></el-date-picker>
           </el-form-item>
           <el-form-item>
             <el-button type="primary" icon="el-icon-search" size="mini" @click="handleQuery">鏌� 璇�</el-button>
@@ -54,7 +28,8 @@
         </el-form>
       </div>
       <div class="addButton mb8">
-        <el-button type="primary" icon="el-icon-plus" size="mini" @click="handleAdd" v-hasPermi="['system:role:add']">鏂板</el-button>
+        <el-button type="primary" icon="el-icon-plus" size="mini" @click="handleAdd"
+          v-hasPermi="['system:role:add']">鏂板</el-button>
       </div>
     </div>
 
@@ -66,12 +41,8 @@
       <el-table-column label="鏄剧ず椤哄簭" prop="roleSort" width="100" />
       <el-table-column label="鐘舵��" align="center" width="100">
         <template slot-scope="scope">
-          <el-switch
-            v-model="scope.row.status"
-            active-value="0"
-            inactive-value="1"
-            @change="handleStatusChange(scope.row)"
-          ></el-switch>
+          <el-switch v-model="scope.row.status" active-value="0" inactive-value="1"
+            @change="handleStatusChange(scope.row)"></el-switch>
         </template>
       </el-table-column>
       <el-table-column label="鍒涘缓鏃堕棿" align="center" prop="createTime" width="180">
@@ -81,52 +52,32 @@
       </el-table-column>
       <el-table-column label="鎿嶄綔" align="center" class-name="small-padding fixed-width">
         <template slot-scope="scope" v-if="scope.row.roleId !== 1">
-          <el-button
-            size="mini"
-            type="text"
-            icon="el-icon-edit"
-            @click="handleUpdate(scope.row)"
-            v-hasPermi="['system:role:edit']"
-          >淇敼</el-button>
-          <el-button
-            size="mini"
-            type="text"
-            icon="el-icon-delete"
-            @click="handleDelete(scope.row)"
-            v-hasPermi="['system:role:remove']"
-          >鍒犻櫎</el-button>
-          <el-button
-            size="mini"
-            type="text"
-            icon="el-icon-view"
-            @click="handleView(scope.row)"
-          >璇︾粏</el-button>
-<!--          <el-dropdown size="mini" @command="(command) => handleCommand(command, scope.row)" v-hasPermi="['system:role:edit']">-->
-<!--            <el-button size="mini" type="text" icon="el-icon-d-arrow-right">鏇村</el-button>-->
-<!--            <el-dropdown-menu slot="dropdown">-->
-<!--              <el-dropdown-item command="handleDataScope" icon="el-icon-circle-check"-->
-<!--                v-hasPermi="['system:role:edit']">鏁版嵁鏉冮檺</el-dropdown-item>-->
-<!--              <el-dropdown-item command="handleAuthUser" icon="el-icon-user"-->
-<!--                v-hasPermi="['system:role:edit']">鍒嗛厤鐢ㄦ埛</el-dropdown-item>-->
-<!--            </el-dropdown-menu>-->
-<!--          </el-dropdown>-->
+          <el-button size="mini" type="text" icon="el-icon-edit" @click="handleUpdate(scope.row)"
+            v-hasPermi="['system:role:edit']">淇敼</el-button>
+          <el-button size="mini" type="text" icon="el-icon-delete" @click="handleDelete(scope.row)"
+            v-hasPermi="['system:role:remove']">鍒犻櫎</el-button>
+          <el-button size="mini" type="text" icon="el-icon-view" @click="handleView(scope.row)">璇︾粏</el-button>
+          <!--          <el-dropdown size="mini" @command="(command) => handleCommand(command, scope.row)" v-hasPermi="['system:role:edit']">-->
+          <!--            <el-button size="mini" type="text" icon="el-icon-d-arrow-right">鏇村</el-button>-->
+          <!--            <el-dropdown-menu slot="dropdown">-->
+          <!--              <el-dropdown-item command="handleDataScope" icon="el-icon-circle-check"-->
+          <!--                v-hasPermi="['system:role:edit']">鏁版嵁鏉冮檺</el-dropdown-item>-->
+          <!--              <el-dropdown-item command="handleAuthUser" icon="el-icon-user"-->
+          <!--                v-hasPermi="['system:role:edit']">鍒嗛厤鐢ㄦ埛</el-dropdown-item>-->
+          <!--            </el-dropdown-menu>-->
+          <!--          </el-dropdown>-->
         </template>
       </el-table-column>
     </el-table>
 
-    <pagination
-      v-show="total>0"
-      :total="total"
-      :page.sync="queryParams.pageNum"
-      :limit.sync="queryParams.pageSize"
-      @pagination="getList"
-    />
+    <pagination v-show="total > 0" :total="total" :page.sync="queryParams.pageNum" :limit.sync="queryParams.pageSize"
+      @pagination="getList" />
 
     <!-- 娣诲姞鎴栦慨鏀硅鑹查厤缃璇濇 -->
     <el-dialog :title="title" :visible.sync="open" width="500px" append-to-body>
       <el-form ref="form" :model="form" :rules="rules" label-width="100px">
         <el-form-item label="瑙掕壊鍚嶇О" prop="roleName">
-          <el-input v-model="form.roleName" placeholder="璇疯緭鍏ヨ鑹插悕绉�" :disabled="title === '鏌ョ湅瑙掕壊'"/>
+          <el-input v-model="form.roleName" placeholder="璇疯緭鍏ヨ鑹插悕绉�" :disabled="title === '鏌ョ湅瑙掕壊'" />
         </el-form-item>
         <el-form-item prop="roleKey">
           <span slot="label">
@@ -135,35 +86,35 @@
             </el-tooltip>
             鏉冮檺瀛楃
           </span>
-          <el-input v-model="form.roleKey" placeholder="璇疯緭鍏ユ潈闄愬瓧绗�"  :disabled="title === '鏌ョ湅瑙掕壊'"/>
+          <el-input v-model="form.roleKey" placeholder="璇疯緭鍏ユ潈闄愬瓧绗�" :disabled="title === '鏌ョ湅瑙掕壊'" />
         </el-form-item>
         <el-form-item label="瑙掕壊椤哄簭" prop="roleSort">
-          <el-input-number v-model="form.roleSort" controls-position="right" :min="0"  :disabled="title === '鏌ョ湅瑙掕壊'"/>
+          <el-input-number v-model="form.roleSort" controls-position="right" :min="0" :disabled="title === '鏌ョ湅瑙掕壊'" />
         </el-form-item>
         <el-form-item label="鐘舵��">
           <el-radio-group v-model="form.status" :disabled="title === '鏌ョ湅瑙掕壊'">
-            <el-radio
-              v-for="dict in dict.type.sys_normal_disable"
-              :key="dict.value"
-              :label="dict.value"
-            >{{dict.label}}</el-radio>
+            <el-radio v-for="dict in dict.type.sys_normal_disable" :key="dict.value" :label="dict.value">{{ dict.label
+              }}</el-radio>
           </el-radio-group>
         </el-form-item>
         <el-form-item label="鑿滃崟鏉冮檺">
-          <el-checkbox v-model="menuExpand" @change="handleCheckedTreeExpand($event, 'menu')" v-if="title !== '鏌ョ湅瑙掕壊'">灞曞紑/鎶樺彔</el-checkbox>
-          <el-checkbox v-model="menuNodeAll" @change="handleCheckedTreeNodeAll($event, 'menu')" v-if="title !== '鏌ョ湅瑙掕壊'">鍏ㄩ��/鍏ㄤ笉閫�</el-checkbox>
-          <el-checkbox v-model="form.menuCheckStrictly" @change="handleCheckedTreeConnect($event, 'menu')" v-if="title !== '鏌ョ湅瑙掕壊'">鐖跺瓙鑱斿姩</el-checkbox>
-          <el-tree
-            :disabled="title === '鏌ョ湅瑙掕壊'"
-            class="tree-border"
-            :data="menuOptions"
-            show-checkbox
-            ref="menu"
-            node-key="id"
-            :check-strictly="!form.menuCheckStrictly"
-            empty-text="鍔犺浇涓紝璇风◢鍊�"
-            :props="defaultProps"
-          ></el-tree>
+          <el-checkbox v-model="menuExpand" @change="handleCheckedTreeExpand($event, 'menu')"
+            v-if="title !== '鏌ョ湅瑙掕壊'">灞曞紑/鎶樺彔</el-checkbox>
+          <el-checkbox v-model="menuNodeAll" @change="handleCheckedTreeNodeAll($event, 'menu')"
+            v-if="title !== '鏌ョ湅瑙掕壊'">鍏ㄩ��/鍏ㄤ笉閫�</el-checkbox>
+          <el-checkbox v-model="form.menuCheckStrictly" @change="handleCheckedTreeConnect($event, 'menu')"
+            v-if="title !== '鏌ョ湅瑙掕壊'">鐖跺瓙鑱斿姩</el-checkbox>
+          <el-tree :disabled="title === '鏌ョ湅瑙掕壊'" class="tree-border" :data="menuOptions" show-checkbox ref="menu"
+            node-key="id" :check-strictly="!form.menuCheckStrictly" empty-text="鍔犺浇涓紝璇风◢鍊�" :props="defaultProps">
+            <span class="custom-tree-node" slot-scope="{ node, data }">
+              <span>{{ node.label }}</span>
+              <span>
+                <el-checkbox v-model="data.isRersonal" :true-label="1" :false-label="0"
+                  v-if="data.isRersonalButton == 1" @change="m => chooseMe(m, data)"
+                  :disabled="title === '鏌ョ湅瑙掕壊'">鍙湅鎴�</el-checkbox>
+              </span>
+            </span>
+          </el-tree>
         </el-form-item>
         <el-form-item label="澶囨敞">
           <el-input v-model="form.remark" type="textarea" placeholder="璇疯緭鍏ュ唴瀹�" :disabled="title === '鏌ョ湅瑙掕壊'"></el-input>
@@ -179,36 +130,24 @@
     <el-dialog :title="title" :visible.sync="openDataScope" width="500px" append-to-body>
       <el-form :model="form" label-width="80px">
         <el-form-item label="瑙掕壊鍚嶇О">
-          <el-input v-model="form.roleName" :disabled="true"/>
+          <el-input v-model="form.roleName" :disabled="true" />
         </el-form-item>
         <el-form-item label="鏉冮檺瀛楃">
           <el-input v-model="form.roleKey" :disabled="true" />
         </el-form-item>
         <el-form-item label="鏉冮檺鑼冨洿">
           <el-select v-model="form.dataScope" @change="dataScopeSelectChange">
-            <el-option
-              v-for="item in dataScopeOptions"
-              :key="item.value"
-              :label="item.label"
-              :value="item.value"
-            ></el-option>
+            <el-option v-for="item in dataScopeOptions" :key="item.value" :label="item.label"
+              :value="item.value"></el-option>
           </el-select>
         </el-form-item>
         <el-form-item label="鏁版嵁鏉冮檺" v-show="form.dataScope == 2">
           <el-checkbox v-model="deptExpand" @change="handleCheckedTreeExpand($event, 'dept')">灞曞紑/鎶樺彔</el-checkbox>
           <el-checkbox v-model="deptNodeAll" @change="handleCheckedTreeNodeAll($event, 'dept')">鍏ㄩ��/鍏ㄤ笉閫�</el-checkbox>
-          <el-checkbox v-model="form.deptCheckStrictly" @change="handleCheckedTreeConnect($event, 'dept')">鐖跺瓙鑱斿姩</el-checkbox>
-          <el-tree
-            class="tree-border"
-            :data="deptOptions"
-            show-checkbox
-            default-expand-all
-            ref="dept"
-            node-key="id"
-            :check-strictly="!form.deptCheckStrictly"
-            empty-text="鍔犺浇涓紝璇风◢鍊�"
-            :props="defaultProps"
-          ></el-tree>
+          <el-checkbox v-model="form.deptCheckStrictly"
+            @change="handleCheckedTreeConnect($event, 'dept')">鐖跺瓙鑱斿姩</el-checkbox>
+          <el-tree class="tree-border" :data="deptOptions" show-checkbox default-expand-all ref="dept" node-key="id"
+            :check-strictly="!form.deptCheckStrictly" empty-text="鍔犺浇涓紝璇风◢鍊�" :props="defaultProps"></el-tree>
         </el-form-item>
       </el-form>
       <div slot="footer" class="dialog-footer">
@@ -232,6 +171,8 @@
       loading: true,
       // 閫変腑鏁扮粍
       ids: [],
+      // 鍙湅鎴戞暟缁�
+      isRersonalMenuIds: [],
       // 闈炲崟涓鐢�
       single: true,
       // 闈炲涓鐢�
@@ -317,10 +258,10 @@
     getList() {
       this.loading = true;
       listRole(this.addDateRange(this.queryParams, this.dateRange)).then(response => {
-          this.roleList = response.rows;
-          this.total = response.total;
-          this.loading = false;
-        }
+        this.roleList = response.rows;
+        this.total = response.total;
+        this.loading = false;
+      }
       );
     },
     /** 鏌ヨ鑿滃崟鏍戠粨鏋� */
@@ -364,11 +305,11 @@
     // 瑙掕壊鐘舵�佷慨鏀�
     handleStatusChange(row) {
       let text = row.status === "0" ? "鍚敤" : "鍋滅敤";
-      this.$modal.confirm('纭瑕�"' + text + '""' + row.roleName + '"瑙掕壊鍚楋紵').then(function() {
+      this.$modal.confirm('纭瑕�"' + text + '""' + row.roleName + '"瑙掕壊鍚楋紵').then(function () {
         return changeRoleStatus(row.roleId, row.status);
       }).then(() => {
         this.$modal.msgSuccess(text + "鎴愬姛");
-      }).catch(function() {
+      }).catch(function () {
         row.status = row.status === "0" ? "1" : "0";
       });
     },
@@ -388,21 +329,22 @@
         this.$refs.menu.setCheckedKeys([]);
       }
       this.menuExpand = false,
-      this.menuNodeAll = false,
-      this.deptExpand = true,
-      this.deptNodeAll = false,
-      this.form = {
-        roleId: undefined,
-        roleName: undefined,
-        roleKey: undefined,
-        roleSort: 0,
-        status: "0",
-        menuIds: [],
-        deptIds: [],
-        menuCheckStrictly: true,
-        deptCheckStrictly: true,
-        remark: undefined
-      };
+        this.menuNodeAll = false,
+        this.deptExpand = true,
+        this.deptNodeAll = false,
+        this.form = {
+          roleId: undefined,
+          roleName: undefined,
+          roleKey: undefined,
+          roleSort: 0,
+          status: "0",
+          menuIds: [],
+          deptIds: [],
+          isRersonalMenuIds: [],
+          menuCheckStrictly: true,
+          deptCheckStrictly: true,
+          remark: undefined
+        };
       this.resetForm("form");
     },
     /** 鎼滅储鎸夐挳鎿嶄綔 */
@@ -419,7 +361,7 @@
     // 澶氶�夋閫変腑鏁版嵁
     handleSelectionChange(selection) {
       this.ids = selection.map(item => item.roleId)
-      this.single = selection.length!=1
+      this.single = selection.length != 1
       this.multiple = !selection.length
     },
     // 鏇村鎿嶄綔瑙﹀彂
@@ -452,17 +394,17 @@
     // 鏍戞潈闄愶紙鍏ㄩ��/鍏ㄤ笉閫夛級
     handleCheckedTreeNodeAll(value, type) {
       if (type == 'menu') {
-        this.$refs.menu.setCheckedNodes(value ? this.menuOptions: []);
+        this.$refs.menu.setCheckedNodes(value ? this.menuOptions : []);
       } else if (type == 'dept') {
-        this.$refs.dept.setCheckedNodes(value ? this.deptOptions: []);
+        this.$refs.dept.setCheckedNodes(value ? this.deptOptions : []);
       }
     },
     // 鏍戞潈闄愶紙鐖跺瓙鑱斿姩锛�
     handleCheckedTreeConnect(value, type) {
       if (type == 'menu') {
-        this.form.menuCheckStrictly = value ? true: false;
+        this.form.menuCheckStrictly = value ? true : false;
       } else if (type == 'dept') {
-        this.form.deptCheckStrictly = value ? true: false;
+        this.form.deptCheckStrictly = value ? true : false;
       }
     },
     /** 鏂板鎸夐挳鎿嶄綔 */
@@ -484,9 +426,9 @@
           roleMenu.then(res => {
             let checkedKeys = res.checkedKeys
             checkedKeys.forEach((v) => {
-                this.$nextTick(()=>{
-                    this.$refs.menu.setChecked(v, true ,false);
-                })
+              this.$nextTick(() => {
+                this.$refs.menu.setChecked(v, true, false);
+              })
             })
           });
         });
@@ -494,7 +436,7 @@
       this.title = "淇敼瑙掕壊";
     },
     // 鏌ョ湅瑙掕壊璇︽儏
-    handleView (row) {
+    handleView(row) {
       this.title = "鏌ョ湅瑙掕壊";
       this.reset();
       const roleId = row.roleId || this.ids
@@ -506,8 +448,8 @@
           roleMenu.then(res => {
             let checkedKeys = res.checkedKeys
             checkedKeys.forEach((v) => {
-              this.$nextTick(()=>{
-                this.$refs.menu.setChecked(v, true ,false);
+              this.$nextTick(() => {
+                this.$refs.menu.setChecked(v, true, false);
               })
             })
           });
@@ -516,7 +458,7 @@
     },
     /** 閫夋嫨瑙掕壊鏉冮檺鑼冨洿瑙﹀彂 */
     dataScopeSelectChange(value) {
-      if(value !== '2') {
+      if (value !== '2') {
         this.$refs.dept.setCheckedKeys([]);
       }
     },
@@ -536,16 +478,17 @@
       this.title = "鍒嗛厤鏁版嵁鏉冮檺";
     },
     /** 鍒嗛厤鐢ㄦ埛鎿嶄綔 */
-    handleAuthUser: function(row) {
+    handleAuthUser: function (row) {
       const roleId = row.roleId;
       this.$router.push("/system/role-auth/user/" + roleId);
     },
     /** 鎻愪氦鎸夐挳 */
-    submitForm: function() {
+    submitForm: function () {
       this.$refs["form"].validate(valid => {
         if (valid) {
           if (this.form.roleId != undefined) {
             this.form.menuIds = this.getMenuAllCheckedKeys();
+            this.form.isRersonalMenuIds = this.isRersonalMenuIds;
             updateRole(this.form).then(response => {
               this.$modal.msgSuccess("淇敼鎴愬姛");
               this.open = false;
@@ -553,6 +496,7 @@
             });
           } else {
             this.form.menuIds = this.getMenuAllCheckedKeys();
+            this.form.isRersonalMenuIds = this.isRersonalMenuIds;
             addRole(this.form).then(response => {
               this.$modal.msgSuccess("鏂板鎴愬姛");
               this.open = false;
@@ -563,7 +507,7 @@
       });
     },
     /** 鎻愪氦鎸夐挳锛堟暟鎹潈闄愶級 */
-    submitDataScope: function() {
+    submitDataScope: function () {
       if (this.form.roleId != undefined) {
         this.form.deptIds = this.getDeptAllCheckedKeys();
         dataScope(this.form).then(response => {
@@ -576,18 +520,27 @@
     /** 鍒犻櫎鎸夐挳鎿嶄綔 */
     handleDelete(row) {
       const roleIds = row.roleId || this.ids;
-      this.$modal.confirm('鏄惁纭鍒犻櫎瑙掕壊缂栧彿涓�"' + roleIds + '"鐨勬暟鎹」锛�').then(function() {
+      this.$modal.confirm('鏄惁纭鍒犻櫎瑙掕壊缂栧彿涓�"' + roleIds + '"鐨勬暟鎹」锛�').then(function () {
         return delRole(roleIds);
       }).then(() => {
         this.getList();
         this.$modal.msgSuccess("鍒犻櫎鎴愬姛");
-      }).catch(() => {});
+      }).catch(() => { });
     },
     /** 瀵煎嚭鎸夐挳鎿嶄綔 */
     handleExport() {
       this.download('system/role/export', {
         ...this.queryParams
       }, `role_${new Date().getTime()}.xlsx`)
+    },
+    // 鍙湅鎴�
+    chooseMe(val, data) {
+      let index = this.isRersonalMenuIds.findIndex(m => m == data.id)
+      if (index < 0 && val == 1) {
+        this.isRersonalMenuIds.push(data.id)
+      } else if (val == 0 && index > -1) {
+        this.isRersonalMenuIds.splice(index, 1)
+      }
     }
   }
 };
@@ -598,7 +551,17 @@
   display: flex;
   justify-content: space-between;
 }
+
 .addButton {
   margin-top: 3px;
 }
+
+.custom-tree-node {
+  flex: 1;
+  display: flex;
+  align-items: center;
+  justify-content: space-between;
+  font-size: 14px;
+  padding-right: 8px;
+}
 </style>

--
Gitblit v1.9.3