From 61a645e754754781ba62c2ffcd0df1a79925e6e0 Mon Sep 17 00:00:00 2001
From: gaoluyang <2820782392@qq.com>
Date: 星期四, 06 十一月 2025 10:50:40 +0800
Subject: [PATCH] 去掉身份证号字段

---
 src/views/personnelManagement/dimission/components/formDia.vue |  332 +++++++++++++++++++++++++++++++++++++++++++------------
 1 files changed, 260 insertions(+), 72 deletions(-)

diff --git a/src/views/personnelManagement/dimission/components/formDia.vue b/src/views/personnelManagement/dimission/components/formDia.vue
index 68185cc..d77eb90 100644
--- a/src/views/personnelManagement/dimission/components/formDia.vue
+++ b/src/views/personnelManagement/dimission/components/formDia.vue
@@ -2,108 +2,152 @@
   <div>
     <el-dialog
         v-model="dialogFormVisible"
-        :title="operationType === 'add' ? '鏂板绂昏亴' : '缂栬緫浜哄憳'"
+        :title="operationType === 'add' ? '鏂板绂昏亴' : '缂栬緫绂昏亴'"
         width="70%"
         @close="closeDia"
     >
-      <el-form :model="form" label-width="140px" label-position="top" :rules="rules" ref="formRef">
+      <!-- 鍛樺伐淇℃伅灞曠ず鍖哄煙 -->
+      <div class="info-section">
+        <div class="info-title">鍛樺伐淇℃伅</div>
         <el-row :gutter="30">
           <el-col :span="12">
-            <el-form-item label="鍛樺伐缂栧彿锛�" prop="purchaseContractNumber">
-              <el-input v-model="form.purchaseContractNumber" placeholder="璇疯緭鍏�" clearable/>
-            </el-form-item>
+            <div class="info-item">
+              <span class="info-label">濮撳悕锛�</span>
+              <el-select v-model="form.staffName" placeholder="璇烽�夋嫨浜哄憳" style="width: 100%" @change="handleSelect">
+                <el-option
+                  v-for="item in personList"
+                  :key="item.id"
+                  :label="item.staffName"
+                  :value="item.staffName"
+                />
+              </el-select>
+            </div>
           </el-col>
           <el-col :span="12">
-            <el-form-item label="濮撳悕锛�" prop="salesLedgerId">
-              <el-input v-model="form.purchaseContractNumber" placeholder="璇疯緭鍏�" clearable/>
-            </el-form-item>
+            <div class="info-item">
+              <span class="info-label">鍛樺伐缂栧彿锛�</span>
+              <span class="info-value">{{ form.staffNo || '-' }}</span>
+            </div>
           </el-col>
         </el-row>
         <el-row :gutter="30">
           <el-col :span="12">
-            <el-form-item label="鎬у埆锛�" prop="purchaseContractNumber">
-              <el-input v-model="form.purchaseContractNumber" placeholder="璇疯緭鍏�" clearable/>
-            </el-form-item>
+            <div class="info-item">
+              <span class="info-label">鎬у埆锛�</span>
+              <span class="info-value">{{ form.sex || '-' }}</span>
+            </div>
           </el-col>
           <el-col :span="12">
-            <el-form-item label="绫嶈疮锛�" prop="salesLedgerId">
-              <el-input v-model="form.purchaseContractNumber" placeholder="璇疯緭鍏�" clearable/>
-            </el-form-item>
+            <div class="info-item">
+              <span class="info-label">鎴风睄浣忓潃锛�</span>
+              <span class="info-value">{{ form.nativePlace || '-' }}</span>
+            </div>
           </el-col>
         </el-row>
         <el-row :gutter="30">
           <el-col :span="12">
-            <el-form-item label="宀椾綅锛�" prop="purchaseContractNumber">
-              <el-input v-model="form.purchaseContractNumber" placeholder="璇疯緭鍏�" clearable/>
-            </el-form-item>
+            <div class="info-item">
+              <span class="info-label">宀椾綅锛�</span>
+              <span class="info-value">{{ form.postJob || '-' }}</span>
+            </div>
           </el-col>
           <el-col :span="12">
-            <el-form-item label="瀹跺涵浣忓潃锛�" prop="salesLedgerId">
-              <el-input v-model="form.purchaseContractNumber" placeholder="璇疯緭鍏�" clearable/>
-            </el-form-item>
+            <div class="info-item">
+              <span class="info-label">鐜颁綇鍧�锛�</span>
+              <span class="info-value">{{ form.adress || '-' }}</span>
+            </div>
           </el-col>
         </el-row>
         <el-row :gutter="30">
           <el-col :span="12">
-            <el-form-item label="绗竴瀛﹀巻锛�" prop="purchaseContractNumber">
-              <el-input v-model="form.purchaseContractNumber" placeholder="璇疯緭鍏�" clearable/>
-            </el-form-item>
+            <div class="info-item">
+              <span class="info-label">绗竴瀛﹀巻锛�</span>
+              <span class="info-value">{{ form.firstStudy || '-' }}</span>
+            </div>
           </el-col>
           <el-col :span="12">
-            <el-form-item label="涓撲笟锛�" prop="salesLedgerId">
-              <el-input v-model="form.purchaseContractNumber" placeholder="璇疯緭鍏�" clearable/>
-            </el-form-item>
+            <div class="info-item">
+              <span class="info-label">涓撲笟锛�</span>
+              <span class="info-value">{{ form.profession || '-' }}</span>
+            </div>
           </el-col>
         </el-row>
         <el-row :gutter="30">
           <el-col :span="12">
-            <el-form-item label="韬唤璇佸彿锛�" prop="purchaseContractNumber">
-              <el-input v-model="form.purchaseContractNumber" placeholder="璇疯緭鍏�" clearable/>
-            </el-form-item>
-          </el-col>
-          <el-col :span="12">
-            <el-form-item label="骞撮緞锛�" prop="salesLedgerId">
-              <el-input v-model="form.purchaseContractNumber" placeholder="璇疯緭鍏�" clearable/>
-            </el-form-item>
+            <div class="info-item">
+              <span class="info-label">骞撮緞锛�</span>
+              <span class="info-value">{{ form.age || '-' }}</span>
+            </div>
           </el-col>
         </el-row>
         <el-row :gutter="30">
           <el-col :span="12">
-            <el-form-item label="鑱旂郴鐢佃瘽锛�" prop="purchaseContractNumber">
-              <el-input v-model="form.purchaseContractNumber" placeholder="璇疯緭鍏�" clearable/>
-            </el-form-item>
+            <div class="info-item">
+              <span class="info-label">鑱旂郴鐢佃瘽锛�</span>
+              <span class="info-value">{{ form.phone || '-' }}</span>
+            </div>
           </el-col>
           <el-col :span="12">
-            <el-form-item label="绱ф�ヨ仈绯讳汉锛�" prop="salesLedgerId">
-              <el-input v-model="form.purchaseContractNumber" placeholder="璇疯緭鍏�" clearable/>
-            </el-form-item>
+            <div class="info-item">
+              <span class="info-label">绱ф�ヨ仈绯讳汉锛�</span>
+              <span class="info-value">{{ form.emergencyContact || '-' }}</span>
+            </div>
           </el-col>
         </el-row>
         <el-row :gutter="30">
           <el-col :span="12">
-            <el-form-item label="绱ф�ヨ仈绯讳汉鑱旂郴鐢佃瘽锛�" prop="purchaseContractNumber">
-              <el-input v-model="form.purchaseContractNumber" placeholder="璇疯緭鍏�" clearable/>
-            </el-form-item>
-          </el-col>
-          <el-col :span="12">
-            <el-form-item label="鍚堝悓骞撮檺锛�" prop="salesLedgerId">
-              <el-input v-model="form.purchaseContractNumber" placeholder="璇疯緭鍏�" clearable/>
-            </el-form-item>
+            <div class="info-item">
+              <span class="info-label">绱ф�ヨ仈绯讳汉鑱旂郴鐢佃瘽锛�</span>
+              <span class="info-value">{{ form.emergencyContactPhone || '-' }}</span>
+            </div>
           </el-col>
         </el-row>
         <el-row :gutter="30">
           <el-col :span="12">
-            <el-form-item label="鍚堝悓寮�濮嬫棩鏈燂細" prop="purchaseContractNumber">
-              <el-input v-model="form.purchaseContractNumber" placeholder="璇疯緭鍏�" clearable/>
+            <div class="info-item">
+              <span class="info-label">鍚堝悓寮�濮嬫棩鏈燂細</span>
+              <span class="info-value">{{ form.contractStartTime || '-' }}</span>
+            </div>
+          </el-col>
+          <el-col :span="12">
+            <div class="info-item">
+              <span class="info-label">鍚堝悓缁撴潫鏃ユ湡锛�</span>
+              <span class="info-value">{{ form.contractEndTime || '-' }}</span>
+            </div>
+          </el-col>
+        </el-row>
+      </div>
+
+      <!-- 绂昏亴淇℃伅濉啓鍖哄煙 -->
+      <!-- <el-form :model="form" label-width="140px" label-position="top" :rules="rules" ref="formRef" style="margin-top: 20px">
+        <el-row :gutter="30">
+          <el-col :span="12">
+            <el-form-item label="绂昏亴鏃ユ湡锛�" prop="dimissionDate">
+              <el-date-picker
+                v-model="form.dimissionDate"
+                type="date"
+                placeholder="璇烽�夋嫨绂昏亴鏃ユ湡"
+                value-format="YYYY-MM-DD"
+                format="YYYY-MM-DD"
+                clearable
+                style="width: 100%"
+              />
             </el-form-item>
           </el-col>
           <el-col :span="12">
-            <el-form-item label="鍚堝悓缁撴潫鏃ユ湡锛�" prop="salesLedgerId">
-              <el-input v-model="form.purchaseContractNumber" placeholder="璇疯緭鍏�" clearable/>
+            <el-form-item label="绂昏亴鍘熷洜锛�" prop="dimissionReason">
+              <el-input
+                v-model="form.dimissionReason"
+                type="textarea"
+                :rows="3"
+                placeholder="璇疯緭鍏ョ鑱屽師鍥�"
+                maxlength="500"
+                show-word-limit
+              />
             </el-form-item>
           </el-col>
         </el-row>
-      </el-form>
+      </el-form> -->
       <template #footer>
         <div class="dialog-footer">
           <el-button type="primary" @click="submitForm">纭</el-button>
@@ -115,52 +159,196 @@
 </template>
 
 <script setup>
-import {ref} from "vue";
+import {ref, reactive, toRefs, getCurrentInstance} from "vue";
+import {getStaffJoinInfo, staffJoinAdd, staffJoinUpdate} from "@/api/personnelManagement/onboarding.js";
+import { staffOnJobListPage } from "@/api/personnelManagement/employeeRecord.js";
+const { proxy } = getCurrentInstance()
+const emit = defineEmits(['close'])
 
 const dialogFormVisible = ref(false);
 const operationType = ref('')
 const data = reactive({
-  searchForm: {
-    purchaseContractNumber: "",
-  },
   form: {
-    purchaseContractNumber: "",
-    salesLedgerId: "",
-    projectName: "",
-    recorderId: "",
-    entryDate: "",
-    productData: [],
-    supplierName: "",
-    supplierId: "",
+    staffNo: "",
+    staffName: "",
+    sex: "",
+    nativePlace: "",
+    postJob: "",
+    adress: "",
+    firstStudy: "",
+    profession: "",
+    age: 0,
+    phone: "",
+    emergencyContact: "",
+    emergencyContactPhone: "",
+    contractTerm: 0,
+    contractStartTime: "",
+    contractEndTime: "",
+    dimissionDate: "",
+    dimissionReason: "",
+    staffState: "",
   },
   rules: {
-    purchaseContractNumber: [
-      { required: true, message: "璇疯緭鍏�", trigger: "blur" },
-    ],
-    projectName: [{ required: true, message: "璇疯緭鍏�", trigger: "blur" }],
-    supplierId: [{ required: true, message: "璇疯緭鍏�", trigger: "blur" }],
+    staffName: [{ required: true, message: "璇烽�夋嫨浜哄憳", trigger: "change" }],
+    dimissionDate: [{ required: true, message: "璇烽�夋嫨绂昏亴鏃ユ湡", trigger: "change" }],
+    dimissionReason: [{ required: true, message: "璇疯緭鍏ョ鑱屽師鍥�", trigger: "blur" }],
   },
 });
 const { form, rules } = toRefs(data);
 
 // 鎵撳紑寮规
 const openDialog = (type, row) => {
+  getList()
+  operationType.value = type;
   dialogFormVisible.value = true;
+  if (operationType.value === 'edit') {
+    getStaffJoinInfo(row.id).then(res => {
+      form.value = {...res.data}
+    })
+  }
 }
 // 鎻愪氦浜у搧琛ㄥ崟
 const submitForm = () => {
-
+  // 琛ㄥ崟宸叉敞閲婏紝鐩存帴鎻愪氦锛屼笉杩涜楠岃瘉
+  if (!form.value.staffName) {
+    proxy.$modal.msgError("璇烽�夋嫨浜哄憳");
+    return;
+  }
+  form.value.staffState = 0
+  if (operationType.value === "add") {
+    staffJoinAdd(form.value).then(res => {
+      proxy.$modal.msgSuccess("鎻愪氦鎴愬姛");
+      closeDia();
+    })
+  } else {
+    staffJoinUpdate(form.value).then(res => {
+      proxy.$modal.msgSuccess("鎻愪氦鎴愬姛");
+      closeDia();
+    })
+  }
 }
 // 鍏抽棴寮规
 const closeDia = () => {
-  // proxy.resetForm("formRef");
+  // 琛ㄥ崟宸叉敞閲婏紝鎵嬪姩閲嶇疆琛ㄥ崟鏁版嵁
+  form.value = {
+    staffNo: "",
+    staffName: "",
+    sex: "",
+    nativePlace: "",
+    postJob: "",
+    adress: "",
+    firstStudy: "",
+    profession: "",
+    age: 0,
+    phone: "",
+    emergencyContact: "",
+    emergencyContactPhone: "",
+    contractTerm: 0,
+    contractStartTime: "",
+    contractEndTime: "",
+    dimissionDate: "",
+    dimissionReason: "",
+    staffState: "",
+  };
   dialogFormVisible.value = false;
+  emit('close')
 };
+
+const personList = ref([]);
+
+/**
+ * 鑾峰彇褰撳墠鍦ㄨ亴浜哄憳鍒楄〃
+ */
+const getList = () => {
+  staffOnJobListPage({
+    current: -1,
+    size: -1,
+		staffState: 1
+  }).then(res => {
+    personList.value = res.data.records || []
+  })
+};
+
+const handleSelect = (val) => {
+  let obj = personList.value.find(item => item.staffName === val)
+  if (obj) {
+    let {
+      sex,
+      phone,
+      staffNo,
+      nativePlace,
+      postJob,
+      adress,
+      firstStudy,
+      profession,
+      age,
+      emergencyContact,
+      emergencyContactPhone,
+      contractTerm,
+      contractStartTime,
+      contractEndTime,
+      staffName
+    } = obj
+    // 淇濈暀绂昏亴鏃ユ湡鍜岀鑱屽師鍥狅紝鍙洿鏂板憳宸ヤ俊鎭�
+    form.value = {
+      ...form.value,
+      sex,
+      phone,
+      staffNo,
+      nativePlace,
+      postJob,
+      adress,
+      firstStudy,
+      profession,
+      age,
+      emergencyContact,
+      emergencyContactPhone,
+      contractTerm,
+      contractStartTime,
+      contractEndTime,
+      staffName
+    }
+  }
+}
 defineExpose({
   openDialog,
 });
 </script>
 
 <style scoped>
+.info-section {
+  background: #f5f7fa;
+  padding: 20px;
+  border-radius: 8px;
+  margin-bottom: 20px;
+}
 
+.info-title {
+  font-size: 16px;
+  font-weight: 600;
+  color: #303133;
+  margin-bottom: 20px;
+  padding-bottom: 10px;
+  border-bottom: 1px solid #e4e7ed;
+}
+
+.info-item {
+  display: flex;
+  align-items: center;
+  margin-bottom: 16px;
+  min-height: 32px;
+}
+
+.info-label {
+  min-width: 140px;
+  color: #606266;
+  font-size: 14px;
+  font-weight: 500;
+}
+
+.info-value {
+  flex: 1;
+  color: #303133;
+  font-size: 14px;
+}
 </style>
\ No newline at end of file

--
Gitblit v1.9.3