From 32f10392ab00b07e85c0b4229037c30af7c3f28e Mon Sep 17 00:00:00 2001
From: zouyu <2723363702@qq.com>
Date: 星期二, 27 一月 2026 10:42:49 +0800
Subject: [PATCH] 浪潮对接单点登录:mis调整2

---
 src/views/personnelManagement/dimission/components/formDia.vue |  472 +++++++++++++++++++++++-----------------------------------
 1 files changed, 189 insertions(+), 283 deletions(-)

diff --git a/src/views/personnelManagement/dimission/components/formDia.vue b/src/views/personnelManagement/dimission/components/formDia.vue
index 84808f8..2508173 100644
--- a/src/views/personnelManagement/dimission/components/formDia.vue
+++ b/src/views/personnelManagement/dimission/components/formDia.vue
@@ -6,155 +6,133 @@
         width="70%"
         @close="closeDia"
     >
-      <!-- 鍛樺伐淇℃伅灞曠ず鍖哄煙 -->
-      <div class="info-section">
-        <div class="info-title">鍛樺伐淇℃伅</div>
-        <el-form :model="form" label-width="200px" label-position="left" :rules="rules" ref="formRef" style="margin-top: 20px">
-          <el-row :gutter="30">
-            <el-col :span="12">
-              <el-form-item label="濮撳悕锛�" prop="staffName">
-                <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>
-              </el-form-item>
-            </el-col>
-            <el-col :span="12">
-              <el-form-item label="鍛樺伐缂栧彿锛�">
-                {{ form.staffNo || '-' }}
-              </el-form-item>
-            </el-col>
-          </el-row>
-          <el-row :gutter="30">
-            <el-col :span="12">
-              <el-form-item label="鎬у埆锛�">
-                {{ form.sex || '-' }}
-              </el-form-item>
-            </el-col>
-            <el-col :span="12">
-              <el-form-item label="鎴风睄浣忓潃锛�">
-                {{ form.nativePlace || '-' }}
-              </el-form-item>
-            </el-col>
-          </el-row>
-          <el-row :gutter="30">
-            <el-col :span="12">
-              <el-form-item label="宀椾綅锛�">
-                {{ form.postName || '-' }}
-              </el-form-item>
-            </el-col>
-            <el-col :span="12">
-              <el-form-item label="鐜颁綇鍧�锛�">
-                {{ form.adress || '-' }}
-              </el-form-item>
-            </el-col>
-          </el-row>
-          <el-row :gutter="30">
-            <el-col :span="12">
-              <el-form-item label="绗竴瀛﹀巻锛�">
-                {{ form.firstStudy || '-' }}
-              </el-form-item>
-            </el-col>
-            <el-col :span="12">
-              <el-form-item label="涓撲笟锛�">
-                {{ form.profession || '-' }}
-              </el-form-item>
-            </el-col>
-          </el-row>
-          <el-row :gutter="30">
-            <el-col :span="12">
-              <el-form-item label="骞撮緞锛�">
-                {{ form.age || '-' }}
-              </el-form-item>
-            </el-col>
-          </el-row>
-          <el-row :gutter="30">
-            <el-col :span="12">
-              <el-form-item label="鑱旂郴鐢佃瘽锛�">
-                {{ form.phone || '-' }}
-              </el-form-item>
-            </el-col>
-            <el-col :span="12">
-              <el-form-item label="绱ф�ヨ仈绯讳汉锛�">
-                {{ form.emergencyContact || '-' }}
-              </el-form-item>
-            </el-col>
-          </el-row>
-          <el-row :gutter="30">
-            <el-col :span="12">
-              <el-form-item label="绱ф�ヨ仈绯讳汉鑱旂郴鐢佃瘽锛�">
-                {{ form.emergencyContactPhone || '-' }}
-              </el-form-item>
-            </el-col>
-          </el-row>
-          <el-row :gutter="30">
-            <el-col :span="12">
-              <el-form-item label="鍚堝悓寮�濮嬫棩鏈燂細">
-                {{ form.contractStartTime || '-' }}
-              </el-form-item>
-            </el-col>
-            <el-col :span="12">
-              <el-form-item label="鍚堝悓缁撴潫鏃ユ湡锛�">
-                {{ form.contractEndTime || '-' }}
-              </el-form-item>
-            </el-col>
-          </el-row>
-          <el-row :gutter="30">
-            <el-col :span="12">
-              <el-form-item label="绂昏亴鍘熷洜锛�" prop="dimissionReason">
-                <el-select v-model="form.dimissionReason" placeholder="璇烽�夋嫨绂昏亴鍘熷洜" style="width: 100%" @change="handleSelectDimissionReason">
-                  <el-option
-                      v-for="(item, index) in dimissionReasonOptions"
-                      :key="index"
-                      :label="item.label"
-                      :value="item.value"
-                  />
-                </el-select>
-              </el-form-item>
-            </el-col>
-            <el-col :span="12">
-              <el-form-item label="澶囨敞锛�" prop="dimissionRemark" v-show="form.dimissionReason === 'other'">
-                <el-input
-                    v-model="form.dimissionRemark"
-                    type="textarea"
-                    v-show="form.dimissionReason === 'other'"
-                    :rows="3"
-                    placeholder="澶囨敞"
-                    maxlength="500"
-                    show-word-limit
+      <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="staffName">
+              <!-- <el-input v-model="form.staffName" placeholder="璇疯緭鍏�" clearable/> -->
+              <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-form-item>
-            </el-col>
-          </el-row>
-        </el-form>
-
-<!--        <el-row :gutter="30">-->
-<!--          <el-col :span="12">-->
-<!--            <div class="info-item">-->
-<!--              <span class="info-label">绂昏亴鍘熷洜锛�</span>-->
-<!--              <el-select v-model="form.dimissionReason" placeholder="璇烽�夋嫨浜哄憳" style="width: 100%" @change="handleSelect">-->
-<!--                <el-option-->
-<!--                    v-for="(item, index) in dimissionReasonOptions"-->
-<!--                    :key="index"-->
-<!--                    :label="item.label"-->
-<!--                    :value="item.value"-->
-<!--                />-->
-<!--              </el-select>-->
-<!--            </div>-->
-<!--          </el-col>-->
-<!--          <el-col :span="12">-->
-<!--            <div class="info-item">-->
-<!--              <span class="info-label">鍛樺伐缂栧彿锛�</span>-->
-<!--              <span class="info-value">{{ form.staffNo || '-' }}</span>-->
-<!--            </div>-->
-<!--          </el-col>-->
-<!--        </el-row>-->
-      </div>
-
+              </el-select>
+            </el-form-item>
+          </el-col>
+          <el-col :span="12">
+            <el-form-item label="鍛樺伐缂栧彿锛�" prop="staffNo">
+              <el-input v-model="form.staffNo" placeholder="璇疯緭鍏�" clearable disabled/>
+            </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" disabled>
+                <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 disabled/>
+            </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 disabled/>
+            </el-form-item>
+          </el-col>
+          <el-col :span="12">
+            <el-form-item label="瀹跺涵浣忓潃锛�" prop="adress">
+              <el-input v-model="form.adress" placeholder="璇疯緭鍏�" clearable disabled/>
+            </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 disabled/>
+            </el-form-item>
+          </el-col>
+          <el-col :span="12">
+            <el-form-item label="涓撲笟锛�" prop="profession">
+              <el-input v-model="form.profession" placeholder="璇疯緭鍏�" clearable disabled/>
+            </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 disabled/>
+            </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%" disabled/>
+            </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 disabled/>
+            </el-form-item>
+          </el-col>
+          <el-col :span="12">
+            <el-form-item label="绱ф�ヨ仈绯讳汉锛�" prop="emergencyContact">
+              <el-input v-model="form.emergencyContact" placeholder="璇疯緭鍏�" clearable disabled/>
+            </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 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>
+          </el-col>
+        </el-row>
+        <el-row :gutter="30">
+          <el-col :span="12">
+            <el-form-item label="鍚堝悓寮�濮嬫棩鏈燂細" prop="contractStartTime">
+              <el-date-picker
+                  disabled
+                  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">
+            <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>
+          </el-col>
+        </el-row>
+      </el-form>
       <template #footer>
         <div class="dialog-footer">
           <el-button type="primary" @click="submitForm">纭</el-button>
@@ -166,9 +144,8 @@
 </template>
 
 <script setup>
-import {ref, reactive, toRefs, getCurrentInstance} from "vue";
-import {getStaffJoinInfo, staffJoinAdd, staffJoinUpdate} from "@/api/personnelManagement/onboarding.js";
-import { staffOnJobListPage } from "@/api/personnelManagement/staffOnJob.js";
+import {ref} from "vue";
+import {getStaffJoinInfo, staffJoinAdd, staffJoinUpdate,getStaffOnJob} from "@/api/personnelManagement/onboarding.js";
 const { proxy } = getCurrentInstance()
 const emit = defineEmits(['close'])
 
@@ -180,11 +157,11 @@
     staffName: "",
     sex: "",
     nativePlace: "",
-    postName: "",
-    sysPostId: 0,
+    postJob: "",
     adress: "",
     firstStudy: "",
     profession: "",
+    identityCard: "",
     age: 0,
     phone: "",
     emergencyContact: "",
@@ -192,24 +169,28 @@
     contractTerm: 0,
     contractStartTime: "",
     contractEndTime: "",
-    dimissionDate: "",
-    dimissionReason: "",
-    dimissionRemark: "",
     staffState: "",
   },
   rules: {
-    staffName: [{ required: true, message: "璇烽�夋嫨浜哄憳" }],
-    dimissionReason: [{ required: true, message: "璇烽�夋嫨绂昏亴鍘熷洜"}],
+    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" }],
   },
-  dimissionReasonOptions: [
-      {label: '钖祫寰呴亣', value: 'salary'},
-      {label: '鑱屼笟鍙戝睍', value: 'career_development'},
-      {label: '宸ヤ綔鐜', value: 'work_environment'},
-      {label: '涓汉鍘熷洜', value: 'personal_reason'},
-      {label: '鍏朵粬', value: 'other'},
-  ]
 });
-const { form, rules, dimissionReasonOptions } = toRefs(data);
+const { form, rules } = toRefs(data);
 
 // 鎵撳紑寮规
 const openDialog = (type, row) => {
@@ -222,23 +203,11 @@
     })
   }
 }
-
-const handleSelectDimissionReason = (val) => {
-  if (val === 'other') {
-    form.value.dimissionRemark = ''
-  }
-}
 // 鎻愪氦浜у搧琛ㄥ崟
 const submitForm = () => {
-  form.value.staffState = 0
-  if (form.value.dimissionReason !== 'other') {
-    form.value.dimissionRemark = ''
-  }
-  if (!form.value.sysPostId) {
-    form.value.sysPostId = 0;
-  }
-  proxy.$refs["formRef"].validate(valid => {
+  proxy.$refs.formRef.validate(valid => {
     if (valid) {
+      form.value.staffState = 0
       if (operationType.value === "add") {
         staffJoinAdd(form.value).then(res => {
           proxy.$modal.msgSuccess("鎻愪氦鎴愬姛");
@@ -252,32 +221,10 @@
       }
     }
   })
-
 }
 // 鍏抽棴寮规
 const closeDia = () => {
-  // 琛ㄥ崟宸叉敞閲婏紝鎵嬪姩閲嶇疆琛ㄥ崟鏁版嵁
-  form.value = {
-    staffNo: "",
-    staffName: "",
-    sex: "",
-    nativePlace: "",
-    postName: "",
-    sysPostId: 0,
-    adress: "",
-    firstStudy: "",
-    profession: "",
-    age: 0,
-    phone: "",
-    emergencyContact: "",
-    emergencyContactPhone: "",
-    contractTerm: 0,
-    contractStartTime: "",
-    contractEndTime: "",
-    dimissionDate: "",
-    dimissionReason: "",
-    staffState: "",
-  };
+  proxy.resetForm("formRef");
   dialogFormVisible.value = false;
   emit('close')
 };
@@ -288,57 +235,50 @@
  * 鑾峰彇褰撳墠鍦ㄨ亴浜哄憳鍒楄〃
  */
 const getList = () => {
-  staffOnJobListPage({
-    current: -1,
-    size: -1,
-		staffState: 1
-  }).then(res => {
-    personList.value = res.data.records || []
+  getStaffOnJob().then(res => {
+    personList.value = res.data
   })
 };
 
 const handleSelect = (val) => {
   let obj = personList.value.find(item => item.staffName === val)
-  if (obj) {
-    let {
-      sex,
-      phone,
-      staffNo,
-      nativePlace,
-      postName,
-      sysPostId,
-      adress,
-      firstStudy,
-      profession,
-      age,
-      emergencyContact,
-      emergencyContactPhone,
-      contractTerm,
-      contractStartTime,
-      contractEndTime,
-      staffName
-    } = obj
-    // 淇濈暀绂昏亴鏃ユ湡鍜岀鑱屽師鍥狅紝鍙洿鏂板憳宸ヤ俊鎭�
-    form.value = {
-      ...form.value,
-      sex,
-      phone,
-      staffNo,
-      nativePlace,
-      postName,
-      sysPostId,
-      adress,
-      firstStudy,
-      profession,
-      age,
-      emergencyContact,
-      emergencyContactPhone,
-      contractTerm,
-      contractStartTime,
-      contractEndTime,
-      staffName
-    }
+  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
   }
+
 }
 defineExpose({
   openDialog,
@@ -346,39 +286,5 @@
 </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
+</style>

--
Gitblit v1.9.3