From a904da0bb0764bec4261ee7f1fce103d3c155339 Mon Sep 17 00:00:00 2001
From: spring <2396852758@qq.com>
Date: 星期五, 07 三月 2025 09:42:22 +0800
Subject: [PATCH] Merge branch 'dev' of http://114.132.189.42:9002/r/center-lims-before-ruoyi into dev

---
 src/views/CNAS/resourceDemand/standardMaterialAccept/component/AddRecord.vue |  261 ++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 261 insertions(+), 0 deletions(-)

diff --git a/src/views/CNAS/resourceDemand/standardMaterialAccept/component/AddRecord.vue b/src/views/CNAS/resourceDemand/standardMaterialAccept/component/AddRecord.vue
new file mode 100644
index 0000000..dc48446
--- /dev/null
+++ b/src/views/CNAS/resourceDemand/standardMaterialAccept/component/AddRecord.vue
@@ -0,0 +1,261 @@
+<template>
+  <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 limsTable from "@/components/Table/lims-table.vue";
+import {
+  addAcceptance, getAcceptanceDetails,
+  getStandardSubstanceAll,
+  updateAcceptance
+} from "@/api/cnas/resourceDemand/standardMaterialAccept/standardMaterialAccept";
+export default {
+  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
+        }
+      ],
+      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>
+>>>.el-dialog__body {
+  height: 580px;
+  overflow-y: auto;
+}
+</style>

--
Gitblit v1.9.3