From 0af58ec5acb61a3ac6dbf1af46fe44c485fee341 Mon Sep 17 00:00:00 2001
From: gaoluyang <2820782392@qq.com>
Date: 星期三, 05 十一月 2025 16:05:11 +0800
Subject: [PATCH] 新增离职-数据展示修改

---
 src/views/personnelManagement/dimission/components/formDia.vue          |  299 +++++++++++++---------
 src/views/personnelManagement/onboarding/components/formDia.vue         |   18 
 src/views/personnelManagement/contractManagement/components/formDia.vue |    8 
 src/views/personnelManagement/employeeRecord/components/formDia.vue     |    8 
 src/views/personnelManagement/employeeRecord/index.vue                  |    8 
 src/views/personnelManagement/onboarding/components/formDiaXJHT.vue     |  393 ++++++++++++++++++++++++++++++
 src/views/personnelManagement/contractManagement/index.vue              |   17 
 src/views/personnelManagement/dimission/index.vue                       |    8 
 src/views/personnelManagement/onboarding/index.vue                      |   13 
 9 files changed, 604 insertions(+), 168 deletions(-)

diff --git a/src/views/personnelManagement/contractManagement/components/formDia.vue b/src/views/personnelManagement/contractManagement/components/formDia.vue
index 6538273..3c9674c 100644
--- a/src/views/personnelManagement/contractManagement/components/formDia.vue
+++ b/src/views/personnelManagement/contractManagement/components/formDia.vue
@@ -31,10 +31,10 @@
 const dialogFormVisible = ref(false);
 const operationType = ref('')
 const tableColumn = ref([
-  {
-    label: "鍚堝悓骞撮檺",
-    prop: "contractTerm",
-  },
+  // {
+  //   label: "鍚堝悓骞撮檺",
+  //   prop: "contractTerm",
+  // },
   {
     label: "鍚堝悓寮�濮嬫棩鏈�",
     prop: "contractStartTime",
diff --git a/src/views/personnelManagement/contractManagement/index.vue b/src/views/personnelManagement/contractManagement/index.vue
index daf42ee..a39fcf2 100644
--- a/src/views/personnelManagement/contractManagement/index.vue
+++ b/src/views/personnelManagement/contractManagement/index.vue
@@ -81,12 +81,9 @@
 const data = reactive({
   searchForm: {
     staffName: "",
-    entryDate: [
-      dayjs().format("YYYY-MM-DD"),
-      dayjs().add(1, "day").format("YYYY-MM-DD"),
-    ], // 褰曞叆鏃ユ湡
-    entryDateStart: dayjs().format("YYYY-MM-DD"),
-    entryDateEnd: dayjs().add(1, "day").format("YYYY-MM-DD"),
+    entryDate: null, // 褰曞叆鏃ユ湡
+    entryDateStart: undefined,
+    entryDateEnd: undefined,
   },
 });
 const { searchForm } = toRefs(data);
@@ -172,10 +169,10 @@
     prop: "emergencyContactPhone",
     width: 150
   },
-  {
-    label: "鍚堝悓骞撮檺",
-    prop: "contractTerm",
-  },
+  // {
+  //   label: "鍚堝悓骞撮檺",
+  //   prop: "contractTerm",
+  // },
   // {
   //   label: "鍚堝悓寮�濮嬫棩鏈�",
   //   prop: "contractStartTime",
diff --git a/src/views/personnelManagement/dimission/components/formDia.vue b/src/views/personnelManagement/dimission/components/formDia.vue
index f63b011..3dd4c8c 100644
--- a/src/views/personnelManagement/dimission/components/formDia.vue
+++ b/src/views/personnelManagement/dimission/components/formDia.vue
@@ -6,128 +6,149 @@
         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="staffName">
-              <!-- <el-input v-model="form.staffName" placeholder="璇疯緭鍏�" clearable/> -->
+            <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-option
+                  v-for="item in personList"
+                  :key="item.id"
+                  :label="item.staffName"
+                  :value="item.staffName"
+                />
               </el-select>
-            </el-form-item>
+            </div>
           </el-col>
           <el-col :span="12">
-            <el-form-item label="鍛樺伐缂栧彿锛�" prop="staffNo">
-              <el-input v-model="form.staffNo" placeholder="璇疯緭鍏�" clearable disabled/>
-            </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="sex">
-              <el-select v-model="form.sex" disabled>
-                <el-option label="鐢�" value="鐢�" />
-                <el-option label="濂�" value="濂�" />
-              </el-select>
-            </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="nativePlace">
-              <el-input v-model="form.nativePlace" placeholder="璇疯緭鍏�" clearable disabled/>
-            </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="postJob">
-              <el-input v-model="form.postJob" placeholder="璇疯緭鍏�" clearable disabled/>
-            </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="adress">
-              <el-input v-model="form.adress" placeholder="璇疯緭鍏�" clearable disabled/>
-            </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="firstStudy">
-              <el-input v-model="form.firstStudy" placeholder="璇疯緭鍏�" clearable disabled/>
-            </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="profession">
-              <el-input v-model="form.profession" placeholder="璇疯緭鍏�" clearable disabled/>
-            </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="identityCard">
-              <el-input v-model="form.identityCard" placeholder="璇疯緭鍏�" clearable disabled/>
-            </el-form-item>
+            <div class="info-item">
+              <span class="info-label">韬唤璇佸彿锛�</span>
+              <span class="info-value">{{ form.identityCard || '-' }}</span>
+            </div>
           </el-col>
           <el-col :span="12">
-            <el-form-item label="骞撮緞锛�" prop="age">
-              <el-input-number v-model="form.age" :precision="0" :step="1" style="width: 100%" disabled/>
-            </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="phone">
-              <el-input v-model="form.phone" placeholder="璇疯緭鍏�" clearable disabled/>
-            </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="emergencyContact">
-              <el-input v-model="form.emergencyContact" placeholder="璇疯緭鍏�" clearable disabled/>
-            </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="emergencyContactPhone">
-              <el-input v-model="form.emergencyContactPhone" placeholder="璇疯緭鍏�" clearable disabled/>
-            </el-form-item>
-          </el-col>
-          <el-col :span="12">
-            <el-form-item label="鍚堝悓骞撮檺锛�" prop="contractTerm">
-              <el-input-number v-model="form.contractTerm" :precision="0" :step="1" style="width: 100%" disabled/>
-            </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="contractStartTime">
+            <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
-								disabled
-                  v-model="form.contractStartTime"
-                  type="date"
-                  placeholder="璇烽�夋嫨鏃ユ湡"
-                  value-format="YYYY-MM-DD"
-                  format="YYYY-MM-DD"
-                  clearable
-                  style="width: 100%"
+                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="contractEndTime">
-              <el-date-picker
-								disabled
-                  v-model="form.contractEndTime"
-                  type="date"
-                  placeholder="璇烽�夋嫨鏃ユ湡"
-                  value-format="YYYY-MM-DD"
-                  format="YYYY-MM-DD"
-                  clearable
-                  style="width: 100%"
+            <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>
@@ -144,7 +165,7 @@
 </template>
 
 <script setup>
-import {ref} from "vue";
+import {ref, reactive, toRefs, getCurrentInstance} from "vue";
 import {getStaffJoinInfo, staffJoinAdd, staffJoinUpdate,getStaffOnJob} from "@/api/personnelManagement/onboarding.js";
 const { proxy } = getCurrentInstance()
 const emit = defineEmits(['close'])
@@ -169,25 +190,14 @@
     contractTerm: 0,
     contractStartTime: "",
     contractEndTime: "",
+    dimissionDate: "",
+    dimissionReason: "",
     staffState: "",
   },
   rules: {
-    staffNo: [{ required: true, message: "璇疯緭鍏�", trigger: "blur" },],
-    staffName: [{ required: true, message: "璇疯緭鍏�", trigger: "blur" }],
-    sex: [{ required: true, message: "璇疯緭鍏�", trigger: "blur" }],
-    nativePlace: [{ required: true, message: "璇疯緭鍏�", trigger: "blur" }],
-    postJob: [{ required: true, message: "璇疯緭鍏�", trigger: "blur" }],
-    adress: [{ required: true, message: "璇疯緭鍏�", trigger: "blur" }],
-    firstStudy: [{ required: true, message: "璇疯緭鍏�", trigger: "blur" }],
-    profession: [{ required: true, message: "璇疯緭鍏�", trigger: "blur" }],
-    identityCard: [{ required: true, message: "璇疯緭鍏�", trigger: "blur" }],
-    age: [{ required: true, message: "璇疯緭鍏�", trigger: "blur" }],
-    phone: [{ required: true, message: "璇疯緭鍏�", trigger: "blur" }],
-    emergencyContact: [{ required: true, message: "璇疯緭鍏�", trigger: "blur" }],
-    emergencyContactPhone: [{ required: true, message: "璇疯緭鍏�", trigger: "blur" }],
-    contractTerm: [{ required: true, message: "璇疯緭鍏�", trigger: "blur" }],
-    contractStartTime: [{ required: true, message: "璇疯緭鍏�", trigger: "blur" }],
-    contractEndTime: [{ 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);
@@ -242,43 +252,46 @@
 
 const handleSelect = (val) => {
   let obj = personList.value.find(item => item.staffName === val)
-  let {
-    sex,
-    phone,
-    staffNo,
-    nativePlace,
-    postJob,
-    adress,
-    firstStudy,
-    profession,
-    identityCard,
-    age,
-    emergencyContact,
-    emergencyContactPhone,
-    contractTerm,
-    contractStartTime,
-    contractEndTime,
-    staffName
-  } = obj
-  form.value = {
-    sex,
-    phone,
-    staffNo,
-    nativePlace,
-    postJob,
-    adress,
-    firstStudy,
-    profession,
-    identityCard,
-    age,
-    emergencyContact,
-    emergencyContactPhone,
-    contractTerm,
-    contractStartTime,
-    contractEndTime,
-    staffName
+  if (obj) {
+    let {
+      sex,
+      phone,
+      staffNo,
+      nativePlace,
+      postJob,
+      adress,
+      firstStudy,
+      profession,
+      identityCard,
+      age,
+      emergencyContact,
+      emergencyContactPhone,
+      contractTerm,
+      contractStartTime,
+      contractEndTime,
+      staffName
+    } = obj
+    // 淇濈暀绂昏亴鏃ユ湡鍜岀鑱屽師鍥狅紝鍙洿鏂板憳宸ヤ俊鎭�
+    form.value = {
+      ...form.value,
+      sex,
+      phone,
+      staffNo,
+      nativePlace,
+      postJob,
+      adress,
+      firstStudy,
+      profession,
+      identityCard,
+      age,
+      emergencyContact,
+      emergencyContactPhone,
+      contractTerm,
+      contractStartTime,
+      contractEndTime,
+      staffName
+    }
   }
-
 }
 defineExpose({
   openDialog,
@@ -286,5 +299,39 @@
 </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
diff --git a/src/views/personnelManagement/dimission/index.vue b/src/views/personnelManagement/dimission/index.vue
index f2ab4c9..ca17ac7 100644
--- a/src/views/personnelManagement/dimission/index.vue
+++ b/src/views/personnelManagement/dimission/index.vue
@@ -150,10 +150,10 @@
     prop: "emergencyContactPhone",
     width:150
   },
-  {
-    label: "鍚堝悓骞撮檺",
-    prop: "contractTerm",
-  },
+  // {
+  //   label: "鍚堝悓骞撮檺",
+  //   prop: "contractTerm",
+  // },
   {
     label: "鍚堝悓寮�濮嬫棩鏈�",
     prop: "contractStartTime",
diff --git a/src/views/personnelManagement/employeeRecord/components/formDia.vue b/src/views/personnelManagement/employeeRecord/components/formDia.vue
index 6538273..3c9674c 100644
--- a/src/views/personnelManagement/employeeRecord/components/formDia.vue
+++ b/src/views/personnelManagement/employeeRecord/components/formDia.vue
@@ -31,10 +31,10 @@
 const dialogFormVisible = ref(false);
 const operationType = ref('')
 const tableColumn = ref([
-  {
-    label: "鍚堝悓骞撮檺",
-    prop: "contractTerm",
-  },
+  // {
+  //   label: "鍚堝悓骞撮檺",
+  //   prop: "contractTerm",
+  // },
   {
     label: "鍚堝悓寮�濮嬫棩鏈�",
     prop: "contractStartTime",
diff --git a/src/views/personnelManagement/employeeRecord/index.vue b/src/views/personnelManagement/employeeRecord/index.vue
index 4c2e296..d9901c3 100644
--- a/src/views/personnelManagement/employeeRecord/index.vue
+++ b/src/views/personnelManagement/employeeRecord/index.vue
@@ -140,10 +140,10 @@
     prop: "emergencyContactPhone",
     width:150
   },
-  {
-    label: "鍚堝悓骞撮檺",
-    prop: "contractTerm",
-  },
+  // {
+  //   label: "鍚堝悓骞撮檺",
+  //   prop: "contractTerm",
+  // },
   // {
   //   label: "鍚堝悓寮�濮嬫棩鏈�",
   //   prop: "contractStartTime",
diff --git a/src/views/personnelManagement/onboarding/components/formDia.vue b/src/views/personnelManagement/onboarding/components/formDia.vue
index d0e76cc..e0f053f 100644
--- a/src/views/personnelManagement/onboarding/components/formDia.vue
+++ b/src/views/personnelManagement/onboarding/components/formDia.vue
@@ -29,7 +29,7 @@
             </el-form-item>
           </el-col>
           <el-col :span="12">
-            <el-form-item label="绫嶈疮锛�" prop="nativePlace">
+            <el-form-item label="鎴风睄浣忓潃锛�" prop="nativePlace">
               <el-input v-model="form.nativePlace" placeholder="璇疯緭鍏�" clearable/>
             </el-form-item>
           </el-col>
@@ -41,7 +41,7 @@
             </el-form-item>
           </el-col>
           <el-col :span="12">
-            <el-form-item label="瀹跺涵浣忓潃锛�" prop="adress">
+            <el-form-item label="鐜颁綇鍧�锛�" prop="adress">
               <el-input v-model="form.adress" placeholder="璇疯緭鍏�" clearable/>
             </el-form-item>
           </el-col>
@@ -88,11 +88,11 @@
               <el-input v-model="form.emergencyContactPhone" placeholder="璇疯緭鍏�" clearable/>
             </el-form-item>
           </el-col>
-          <el-col :span="12">
-            <el-form-item label="鍚堝悓骞撮檺锛�" prop="contractTerm">
-              <el-input-number v-model="form.contractTerm" :precision="0" :step="1" style="width: 100%" :disabled="true"/>
-            </el-form-item>
-          </el-col>
+<!--          <el-col :span="12">-->
+<!--            <el-form-item label="鍚堝悓骞撮檺锛�" prop="contractTermcontractTerm">-->
+<!--              <el-input-number v-model="form.contractTerm" :precision="0" :step="1" style="width: 100%" :disabled="true"/>-->
+<!--            </el-form-item>-->
+<!--          </el-col>-->
         </el-row>
         <el-row :gutter="30">
           <el-col :span="12">
@@ -105,7 +105,6 @@
                   format="YYYY-MM-DD"
                   clearable
                   style="width: 100%"
-                  @change="calculateContractTerm"
               />
             </el-form-item>
           </el-col>
@@ -119,7 +118,6 @@
                   format="YYYY-MM-DD"
                   clearable
                   style="width: 100%"
-                  @change="calculateContractTerm"
               />
             </el-form-item>
           </el-col>
@@ -192,7 +190,7 @@
     getStaffJoinInfo(row.id).then(res => {
       form.value = {...res.data}
       // 缂栬緫鏃朵篃璁$畻涓�娆″悎鍚屽勾闄�
-      calculateContractTerm();
+      // calculateContractTerm();
     })
   }
 }
diff --git a/src/views/personnelManagement/onboarding/components/formDiaXJHT.vue b/src/views/personnelManagement/onboarding/components/formDiaXJHT.vue
new file mode 100644
index 0000000..f829a58
--- /dev/null
+++ b/src/views/personnelManagement/onboarding/components/formDiaXJHT.vue
@@ -0,0 +1,393 @@
+<template>
+  <div>
+    <el-dialog
+        v-model="dialogFormVisible"
+        :title="operationType === 'add' ? '鏂板鍏ヨ亴' : '缂栬緫浜哄憳'"
+        width="70%"
+        @close="closeDia"
+    >
+      <el-form :model="form" label-width="140px" label-position="top" :rules="rules" ref="formRef">
+        <el-row :gutter="30">
+          <el-col :span="12">
+            <el-form-item label="鍛樺伐缂栧彿锛�" prop="staffNo">
+              <el-input v-model="form.staffNo" placeholder="璇疯緭鍏�" clearable :disabled="operationType !== 'add'"/>
+            </el-form-item>
+          </el-col>
+          <el-col :span="12">
+            <el-form-item label="濮撳悕锛�" prop="staffName">
+              <el-input v-model="form.staffName" placeholder="璇疯緭鍏�" clearable/>
+            </el-form-item>
+          </el-col>
+        </el-row>
+        <el-row :gutter="30">
+          <el-col :span="12">
+            <el-form-item label="鎬у埆锛�" prop="sex">
+              <el-select v-model="form.sex">
+                <el-option label="鐢�" value="鐢�" />
+                <el-option label="濂�" value="濂�" />
+              </el-select>
+            </el-form-item>
+          </el-col>
+          <el-col :span="12">
+            <el-form-item label="鎴风睄浣忓潃锛�" prop="nativePlace">
+              <el-input v-model="form.nativePlace" placeholder="璇疯緭鍏�" clearable/>
+            </el-form-item>
+          </el-col>
+        </el-row>
+        <el-row :gutter="30">
+          <el-col :span="12">
+            <el-form-item label="宀椾綅锛�" prop="postJob">
+              <el-input v-model="form.postJob" placeholder="璇疯緭鍏�" clearable/>
+            </el-form-item>
+          </el-col>
+          <el-col :span="12">
+            <el-form-item label="鐜颁綇鍧�锛�" prop="adress">
+              <el-input v-model="form.adress" placeholder="璇疯緭鍏�" clearable/>
+            </el-form-item>
+          </el-col>
+        </el-row>
+        <el-row :gutter="30">
+          <el-col :span="12">
+            <el-form-item label="绗竴瀛﹀巻锛�" prop="firstStudy">
+              <el-input v-model="form.firstStudy" placeholder="璇疯緭鍏�" clearable/>
+            </el-form-item>
+          </el-col>
+          <el-col :span="12">
+            <el-form-item label="涓撲笟锛�" prop="profession">
+              <el-input v-model="form.profession" placeholder="璇疯緭鍏�" clearable/>
+            </el-form-item>
+          </el-col>
+        </el-row>
+        <el-row :gutter="30">
+          <el-col :span="12">
+            <el-form-item label="韬唤璇佸彿锛�" prop="identityCard">
+              <el-input v-model="form.identityCard" placeholder="璇疯緭鍏�" clearable/>
+            </el-form-item>
+          </el-col>
+          <el-col :span="12">
+            <el-form-item label="骞撮緞锛�" prop="age">
+              <el-input-number v-model="form.age" :precision="0" :step="1" style="width: 100%"/>
+            </el-form-item>
+          </el-col>
+        </el-row>
+        <el-row :gutter="30">
+          <el-col :span="12">
+            <el-form-item label="鑱旂郴鐢佃瘽锛�" prop="phone">
+              <el-input v-model="form.phone" placeholder="璇疯緭鍏�" clearable/>
+            </el-form-item>
+          </el-col>
+          <el-col :span="12">
+            <el-form-item label="绱ф�ヨ仈绯讳汉锛�" prop="emergencyContact">
+              <el-input v-model="form.emergencyContact" placeholder="璇疯緭鍏�" clearable/>
+            </el-form-item>
+          </el-col>
+        </el-row>
+        <el-row :gutter="30">
+          <el-col :span="12">
+            <el-form-item label="绱ф�ヨ仈绯讳汉鑱旂郴鐢佃瘽锛�" prop="emergencyContactPhone">
+              <el-input v-model="form.emergencyContactPhone" placeholder="璇疯緭鍏�" clearable/>
+            </el-form-item>
+          </el-col>
+          <el-col :span="12">
+            <el-form-item label="鍚堝悓绛捐鏃ユ湡锛�" prop="trialStartDate">
+              <el-date-picker
+                  v-model="form.trialStartDate"
+                  type="date"
+                  placeholder="璇烽�夋嫨鏃ユ湡"
+                  value-format="YYYY-MM-DD"
+                  format="YYYY-MM-DD"
+                  clearable
+                  style="width: 100%"
+              />
+            </el-form-item>
+          </el-col>
+        </el-row>
+        <el-row :gutter="30">
+          <el-col :span="24">
+            <el-form-item label="鍔冲姩鍚堝悓鏈熼檺閫夋嫨锛�" prop="dateSelect">
+              <el-radio-group v-model="form.dateSelect">
+                <el-radio :value="'A'">
+                  A銆佹湁鍥哄畾鏈熼檺
+                </el-radio>
+                <el-radio :value="'B'">
+                  B銆佹棤鍥哄畾鏈熼檺
+                </el-radio>
+                <el-radio :value="'C'">
+                  C銆佷互瀹屾垚涓�瀹氬伐浣滀换鍔′负鏈熼檺
+                </el-radio>
+              </el-radio-group>
+            </el-form-item>
+          </el-col>
+        </el-row>
+        <el-row :gutter="30" v-if="showProbationDates">
+          <el-col :span="12">
+            <el-form-item label="璇曠敤鏈熷紑濮嬫棩鏈燂細" prop="signDate">
+              <el-date-picker
+                  v-model="form.signDate"
+                  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="trialEndDate">
+              <el-date-picker
+                  v-model="form.trialEndDate"
+                  type="date"
+                  placeholder="璇烽�夋嫨鏃ユ湡"
+                  value-format="YYYY-MM-DD"
+                  format="YYYY-MM-DD"
+                  clearable
+                  style="width: 100%"
+              />
+            </el-form-item>
+          </el-col>
+        </el-row>
+<!--        <el-row :gutter="30">-->
+<!--          <el-col :span="12">-->
+<!--            <el-form-item label="鍚堝悓骞撮檺锛�" prop="contractTerm">-->
+<!--              <el-input-number v-model="form.contractTerm" :precision="0" :step="1" style="width: 100%" :disabled="true"/>-->
+<!--            </el-form-item>-->
+<!--          </el-col>-->
+<!--        </el-row>-->
+        <el-row :gutter="30">
+          <el-col :span="12">
+            <el-form-item label="鍚堝悓寮�濮嬫棩鏈燂細" prop="contractStartTime">
+              <el-date-picker
+                  v-model="form.contractStartTime"
+                  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" v-if="showContractEnd">
+            <el-form-item label="鍚堝悓缁撴潫鏃ユ湡锛�" prop="contractEndTime">
+              <el-date-picker
+                  v-model="form.contractEndTime"
+                  type="date"
+                  placeholder="璇烽�夋嫨鏃ユ湡"
+                  value-format="YYYY-MM-DD"
+                  format="YYYY-MM-DD"
+                  clearable
+                  style="width: 100%"
+              />
+            </el-form-item>
+          </el-col>
+        </el-row>
+				<el-row :gutter="30">
+					<el-col :span="12">
+						<el-form-item label="璇曠敤鏈熷伐璧勶細" prop="proSalary">
+							<el-input-number placeholder="璇疯緭鍏ヨ瘯鐢ㄦ湡宸ヨ祫" :precision="2"
+															 :step="100"
+															 :min="0" v-model="form.proSalary" style="width: 100%"/>
+						</el-form-item>
+					</el-col>
+				</el-row>
+        <el-row :gutter="30">
+          <el-col :span="24">
+            <el-form-item label="宸ヨ祫鎶ラ叕锛�" prop="salarySelect">
+              <el-radio-group v-model="form.salarySelect" class="salary-radio-group">
+                <el-radio :value="'A'" class="salary-radio-item">
+                  A銆佷箼鏂圭殑宸ヨ祫鎶ラ叕鎸夌収鐢叉柟渚濇硶鍒跺畾鐨勮绔犲埗搴︿腑鐨勫唴閮ㄥ伐璧勫垎閰嶅姙娉曠‘瀹氾紝鏍规嵁涔欐柟鐨勫伐浣滃矖浣嶇‘瀹氬叾姣忔湀宸ヨ祫銆�
+                </el-radio>
+                <el-radio :value="'B'" class="salary-radio-item">
+                  B銆佺敳鏂瑰涔欐柟瀹炶鍩烘湰宸ヨ祫鍜岀哗鏁堝伐璧勭浉缁撳悎鐨勫唴閮ㄥ伐璧勫垎閰嶅姙娉曪紝涔欐柟鐨勬敹鍏ュ寘鎷熀鏈伐璧勩�佽椁愩�佷氦閫氥�佺敓娲讳綇瀹跨瓑鍚勯」琛ュ姪锛屽鏈夊彉鍔ㄦ牴鎹唴閮ㄥ伐璧勫垎閰嶅姙娉曡皟鏁村叾宸ヨ祫锛涚哗鏁堝伐璧勬牴鎹箼鏂圭殑宸ヤ綔涓氱哗銆佸姵鍔ㄦ垚鏋滃拰瀹為檯璐$尞鎸夌収鍐呴儴鍒嗛厤鍔炴硶鑰冩牳纭畾銆�
+                </el-radio>
+                <el-radio :value="'C'" class="salary-radio-item">
+                  C銆佺敳鏂瑰疄琛岃浠跺伐璧勫埗锛屼互鐢叉柟鎺ュ埌璁㈠崟鍙婂叕鍙哥敓浜ц鍒掞紝鎸夌収瀹氶鍜岃浠跺崟浠凤紝鏍规嵁涔欐柟瀹屾垚鐨勪笟缁╋紝鎸夋椂瓒抽鏀粯涔欐柟鐨勫伐璧勬姤閰��
+                </el-radio>
+              </el-radio-group>
+            </el-form-item>
+          </el-col>
+        </el-row>
+				<el-row :gutter="30">
+					<el-col :span="12">
+						<el-form-item label="绂忓埄寰呴亣锛�" prop="remark">
+							<el-input v-model="form.remark" placeholder="璇疯緭鍏�" clearable/>
+						</el-form-item>
+					</el-col>
+				</el-row>
+      </el-form>
+      <template #footer>
+        <div class="dialog-footer">
+          <el-button type="primary" @click="submitForm">纭</el-button>
+          <el-button @click="closeDia">鍙栨秷</el-button>
+        </div>
+      </template>
+    </el-dialog>
+  </div>
+</template>
+
+<script setup>
+import {ref, reactive, toRefs, getCurrentInstance, computed, watch} from "vue";
+import {getStaffJoinInfo, staffJoinAdd, staffJoinUpdate} from "@/api/personnelManagement/onboarding.js";
+const { proxy } = getCurrentInstance()
+const emit = defineEmits(['close'])
+
+const dialogFormVisible = ref(false);
+const operationType = ref('')
+const data = reactive({
+  form: {
+    staffNo: "",
+    staffName: "",
+    sex: "",
+    nativePlace: "",
+    postJob: "",
+    adress: "",
+    firstStudy: "",
+    profession: "",
+    identityCard: "",
+    age: 0,
+    phone: "",
+    emergencyContact: "",
+    emergencyContactPhone: "",
+    dateSelect: "",
+    signDate: "",
+    trialEndDate: "",
+    proSalary: null,
+    trialStartDate: "",
+    salarySelect: "",
+    // contractTerm: 0,
+    contractStartTime: "",
+    contractEndTime: "",
+    staffState: "",
+  },
+  rules: {
+    staffNo: [{ required: true, message: "璇疯緭鍏�", trigger: "blur" },],
+    staffName: [{ required: true, message: "璇疯緭鍏�", trigger: "blur" }],
+    sex: [{ required: true, message: "璇疯緭鍏�", trigger: "blur" }],
+    nativePlace: [{ required: true, message: "璇疯緭鍏�", trigger: "blur" }],
+    postJob: [{ required: true, message: "璇疯緭鍏�", trigger: "blur" }],
+    adress: [{ required: true, message: "璇疯緭鍏�", trigger: "blur" }],
+    firstStudy: [{ required: true, message: "璇疯緭鍏�", trigger: "blur" }],
+    profession: [{ required: true, message: "璇疯緭鍏�", trigger: "blur" }],
+    identityCard: [{ required: true, message: "璇疯緭鍏�", trigger: "blur" }],
+    age: [{ required: true, message: "璇疯緭鍏�", trigger: "blur" }],
+    phone: [{ required: true, message: "璇疯緭鍏�", trigger: "blur" }],
+    emergencyContact: [{ required: true, message: "璇疯緭鍏�", trigger: "blur" }],
+		remark: [{ required: false, message: "璇疯緭鍏�", trigger: "blur" }],
+    dateSelect: [{ required: true, message: "璇烽�夋嫨鍔冲姩鍚堝悓鏈熼檺", trigger: "change" }],
+    signDate: [{ required: true, message: "璇烽�夋嫨", trigger: "change" }],
+    trialEndDate: [{ required: true, message: "璇烽�夋嫨", trigger: "change" }],
+    trialStartDate: [{ required: true, message: "璇烽�夋嫨", trigger: "change" }],
+    salarySelect: [{ required: true, message: "璇烽�夋嫨宸ヨ祫鎶ラ叕鏂瑰紡", trigger: "change" }],
+    // contractTerm: [{ required: true, message: "璇疯緭鍏�", trigger: "blur" }],
+    contractStartTime: [{ required: true, message: "璇疯緭鍏�", trigger: "blur" }],
+    contractEndTime: [{ required: true, message: "璇疯緭鍏�", trigger: "blur" }],
+  },
+});
+const { form, rules } = toRefs(data);
+
+const showContractEnd = computed(() => form.value.dateSelect === "A");
+const showProbationDates = computed(() => form.value.dateSelect === "A" || form.value.dateSelect === "B");
+
+watch(() => form.value.dateSelect, (type) => {
+  if (type !== "A") {
+    form.value.contractEndTime = "";
+  }
+
+  if (type === "C") {
+    form.value.signDate = "";
+    form.value.trialEndDate = "";
+    form.value.proSalary = null;
+  }
+}, { immediate: true });
+
+// 鎵撳紑寮规
+const openDialog = (type, row) => {
+  operationType.value = type;
+  dialogFormVisible.value = true;
+  if (operationType.value === 'edit') {
+    getStaffJoinInfo(row.id).then(res => {
+      form.value = {...res.data}
+      // 缂栬緫鏃朵篃璁$畻涓�娆″悎鍚屽勾闄�
+      // calculateContractTerm();
+    })
+  }
+}
+// 鎻愪氦浜у搧琛ㄥ崟
+const submitForm = () => {
+  proxy.$refs.formRef.validate(valid => {
+    if (valid) {
+      form.value.staffState = 1
+      if (operationType.value === "add") {
+        staffJoinAdd(form.value).then(res => {
+          proxy.$modal.msgSuccess("鎻愪氦鎴愬姛");
+          closeDia();
+        })
+      } else {
+        staffJoinUpdate(form.value).then(res => {
+          proxy.$modal.msgSuccess("鎻愪氦鎴愬姛");
+          closeDia();
+        })
+      }
+    }
+  })
+}
+// 璁$畻鍚堝悓骞撮檺
+// const calculateContractTerm = () => {
+//   if (form.value.contractStartTime && form.value.contractEndTime) {
+//     const startDate = new Date(form.value.contractStartTime);
+//     const endDate = new Date(form.value.contractEndTime);
+//
+//     if (endDate > startDate) {
+//       // 璁$畻骞翠唤宸�
+//       const yearDiff = endDate.getFullYear() - startDate.getFullYear();
+//       const monthDiff = endDate.getMonth() - startDate.getMonth();
+//       const dayDiff = endDate.getDate() - startDate.getDate();
+//
+//       let years = yearDiff;
+//
+//       // 濡傛灉缁撴潫鏃ユ湡鐨勬湀鏃ュ皬浜庡紑濮嬫棩鏈熺殑鏈堟棩锛屽垯鍑忓幓1骞�
+//       if (monthDiff < 0 || (monthDiff === 0 && dayDiff < 0)) {
+//         years = yearDiff - 1;
+//       }
+//
+//       form.value.contractTerm = Math.max(0, years);
+//     } else {
+//       form.value.contractTerm = 0;
+//     }
+//   } else {
+//     form.value.contractTerm = 0;
+//   }
+// };
+
+// 鍏抽棴寮规
+const closeDia = () => {
+  proxy.resetForm("formRef");
+  dialogFormVisible.value = false;
+  emit('close')
+};
+defineExpose({
+  openDialog,
+});
+</script>
+
+<style scoped>
+.salary-radio-group {
+  display: flex;
+  gap: 12px;
+}
+
+.salary-radio-item {
+  white-space: normal;
+  word-wrap: break-word;
+  line-height: 1.6;
+  align-items: flex-start;
+}
+
+.salary-radio-item :deep(.el-radio__label) {
+  white-space: normal;
+  word-wrap: break-word;
+  line-height: 1.6;
+  padding-left: 8px;
+}
+</style>
\ No newline at end of file
diff --git a/src/views/personnelManagement/onboarding/index.vue b/src/views/personnelManagement/onboarding/index.vue
index d36f2e5..6106002 100644
--- a/src/views/personnelManagement/onboarding/index.vue
+++ b/src/views/personnelManagement/onboarding/index.vue
@@ -58,6 +58,7 @@
 import { Search } from "@element-plus/icons-vue";
 import {onMounted, ref} from "vue";
 import FormDia from "@/views/personnelManagement/onboarding/components/formDia.vue";
+// import FormDia from "@/views/personnelManagement/onboarding/components/formDiaXJHT.vue"; // 鏂扮枂椋熷搧鍏徃鐢ㄧ殑琛ㄥ崟
 import {staffJoinDel, staffJoinListPage} from "@/api/personnelManagement/onboarding.js";
 import {ElMessageBox} from "element-plus";
 import dayjs from "dayjs";
@@ -105,7 +106,7 @@
     prop: "sex",
   },
   {
-    label: "绫嶈疮",
+    label: "鎴风睄浣忓潃",
     prop: "nativePlace",
   },
   {
@@ -113,7 +114,7 @@
     prop: "postJob",
   },
   {
-    label: "瀹跺涵浣忓潃",
+    label: "鐜颁綇鍧�",
     prop: "adress",
     width:200
   },
@@ -150,10 +151,10 @@
     prop: "emergencyContactPhone",
     width:150
   },
-  {
-    label: "鍚堝悓骞撮檺",
-    prop: "contractTerm",
-  },
+  // {
+  //   label: "鍚堝悓骞撮檺",
+  //   prop: "contractTerm",
+  // },
   {
     label: "鍚堝悓寮�濮嬫棩鏈�",
     prop: "contractStartTime",

--
Gitblit v1.9.3