From a5ddaf6b76f1266a180a45d0cbde9cd4eefe5912 Mon Sep 17 00:00:00 2001
From: gaoluyang <2820782392@qq.com>
Date: 星期三, 19 十一月 2025 16:49:57 +0800
Subject: [PATCH] 1.金鹰黄金-人员入职的时候岗位改为下拉框

---
 src/views/personnelManagement/onboarding/components/formDia.vue |  217 ++++++++++++++++++++++++++++++++++++++++-------------
 1 files changed, 162 insertions(+), 55 deletions(-)

diff --git a/src/views/personnelManagement/onboarding/components/formDia.vue b/src/views/personnelManagement/onboarding/components/formDia.vue
index c8bd008..cfd26b4 100644
--- a/src/views/personnelManagement/onboarding/components/formDia.vue
+++ b/src/views/personnelManagement/onboarding/components/formDia.vue
@@ -9,97 +9,115 @@
       <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="purchaseContractNumber">
-              <el-input v-model="form.purchaseContractNumber" placeholder="璇疯緭鍏�" clearable/>
+            <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="salesLedgerId">
-              <el-input v-model="form.purchaseContractNumber" placeholder="璇疯緭鍏�" clearable/>
+            <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="purchaseContractNumber">
-              <el-input v-model="form.purchaseContractNumber" placeholder="璇疯緭鍏�" clearable/>
+            <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="salesLedgerId">
-              <el-input v-model="form.purchaseContractNumber" placeholder="璇疯緭鍏�" clearable/>
+            <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="purchaseContractNumber">
-              <el-input v-model="form.purchaseContractNumber" placeholder="璇疯緭鍏�" clearable/>
+            <el-form-item label="宀椾綅锛�" prop="postJob">
+              <el-select v-model="form.postJob" filterable placeholder="璇烽�夋嫨宀椾綅" :loading="positionLoading" clearable>
+                <el-option v-for="p in positionOptions" :key="p.id" :label="p.name || p.label" :value="p.id" />
+              </el-select>
             </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="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="purchaseContractNumber">
-              <el-input v-model="form.purchaseContractNumber" placeholder="璇疯緭鍏�" clearable/>
+            <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="salesLedgerId">
-              <el-input v-model="form.purchaseContractNumber" placeholder="璇疯緭鍏�" clearable/>
+            <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="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 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="purchaseContractNumber">
-              <el-input v-model="form.purchaseContractNumber" placeholder="璇疯緭鍏�" clearable/>
+            <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="salesLedgerId">
-              <el-input v-model="form.purchaseContractNumber" placeholder="璇疯緭鍏�" clearable/>
+            <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="purchaseContractNumber">
-              <el-input v-model="form.purchaseContractNumber" placeholder="璇疯緭鍏�" clearable/>
+            <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="salesLedgerId">
-              <el-input v-model="form.purchaseContractNumber" placeholder="璇疯緭鍏�" clearable/>
+            <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="purchaseContractNumber">
-              <el-input v-model="form.purchaseContractNumber" placeholder="璇疯緭鍏�" clearable/>
+            <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%"
+									@change="calculateContractTerm"
+              />
             </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="contractEndTime">
+              <el-date-picker
+                  v-model="form.contractEndTime"
+                  type="date"
+                  placeholder="璇烽�夋嫨鏃ユ湡"
+                  value-format="YYYY-MM-DD"
+                  format="YYYY-MM-DD"
+                  clearable
+                  style="width: 100%"
+									@change="calculateContractTerm"
+              />
             </el-form-item>
           </el-col>
         </el-row>
@@ -115,46 +133,135 @@
 </template>
 
 <script setup>
-import {ref} from "vue";
+import {ref, reactive, toRefs, getCurrentInstance, onMounted} from "vue";
+import {getStaffJoinInfo, staffJoinAdd, staffJoinUpdate} from "@/api/personnelManagement/onboarding.js";
+import {deptPositionListPage} from "@/api/lavorissce/issue";
+
+const {proxy} = getCurrentInstance()
+const emit = defineEmits(['close'])
 
 const dialogFormVisible = ref(false);
 const operationType = ref('')
+const positionOptions = ref([])
+const positionLoading = ref(false)
+
 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: "",
+    staffState: "",
   },
   rules: {
-    purchaseContractNumber: [
-      { required: true, message: "璇疯緭鍏�", trigger: "blur" },
-    ],
-    projectName: [{ required: true, message: "璇疯緭鍏�", trigger: "blur" }],
-    supplierId: [{ required: true, message: "璇疯緭鍏�", trigger: "blur" }],
+    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"}],
+    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"}],
   },
 });
-const { form, rules } = toRefs(data);
+const {form, rules} = toRefs(data);
+
+async function loadPositions() {
+  try {
+    positionLoading.value = true
+    const res = await deptPositionListPage({pageNum: 1, pageSize: 9999})
+    positionOptions.value = res?.data?.records || res?.data || []
+  } finally {
+    positionLoading.value = false
+  }
+}
 
 // 鎵撳紑寮规
 const openDialog = (type, row) => {
+  operationType.value = type;
   dialogFormVisible.value = true;
+  loadPositions()
+  if (operationType.value === 'edit') {
+    getStaffJoinInfo(row.id).then(res => {
+      form.value = {...res.data}
+      // 缂栬緫鏃朵篃璁$畻涓�娆″悎鍚屽勾闄�
+      calculateContractTerm();
+    })
+  } else {
+    form.value.id = ''
+  }
 }
+
 // 鎻愪氦浜у搧琛ㄥ崟
 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");
+  proxy.resetForm("formRef");
   dialogFormVisible.value = false;
+  emit('close')
 };
 defineExpose({
   openDialog,

--
Gitblit v1.9.3