From 29600478c3a9379e691ed065f4e29e5cea6de9e0 Mon Sep 17 00:00:00 2001
From: wupengfei <834520024@qq.com>
Date: 星期四, 13 十一月 2025 16:58:49 +0800
Subject: [PATCH] fix: bug

---
 src/views/FlexJobManage/FlexJobManage.vue |   47 ++++++++++++++++++++++++++++++++++++++++++++---
 1 files changed, 44 insertions(+), 3 deletions(-)

diff --git a/src/views/FlexJobManage/FlexJobManage.vue b/src/views/FlexJobManage/FlexJobManage.vue
index b723cbc..88ce9a7 100644
--- a/src/views/FlexJobManage/FlexJobManage.vue
+++ b/src/views/FlexJobManage/FlexJobManage.vue
@@ -217,7 +217,11 @@
 const operationBtnMap: Record<string, OperationBtnType> = {
   editBtn: {
     emits: {
-      onClick: (role) => openDialog(role),
+      onClick: (role) => openInternalDialog(role),
+    },
+    extraProps: {
+      hide: (row: API.GetEnterpriseEmployeesQueryResultItem) =>
+        row.source === EnumEnterpriseEmployeeSource.External,
     },
   },
   detailBtn: {
@@ -657,10 +661,13 @@
 const {
   dialogProps: dialogAddInternalStaffProps,
   handleAdd: handleInternalStaffAdd,
+  handleEdit: handleInternalStaffEdit,
   editForm: internalStaffEditForm,
+  dialogState: internalDialogState,
 } = useFormDialog({
   onConfirm: addEnterpriseEmployee,
   defaultFormParams: {
+    id: '',
     name: '',
     identity: '',
     contactPhoneNumber: '',
@@ -674,10 +681,35 @@
     userSignContractTime: '',
     contractTime: [] as unknown as ModelValueType,
   },
+  closeAfterConfirm: false,
 });
+
+async function openInternalDialog(row: API.GetEnterpriseEmployeesQueryResultItem) {
+  try {
+    let detail = await enterpriseEmployeeServices.getEnterpriseEmployee({ id: row.id });
+    handleInternalStaffEdit({
+      id: row.id,
+      name: row.name,
+      identity: row.identity,
+      contactPhoneNumber: row.contactPhoneNumber,
+      gender: detail.gender,
+      age: detail.age ?? null,
+      identityImg: convertApi2FormUrlOnlyOne(detail.identityImg),
+      identityBackImg: convertApi2FormUrlOnlyOne(detail.identityBackImg),
+      contractUrl: convertApi2FormUrlOnlyOne(detail.contractUrl, {
+        fileName: detail.contractUrl ? detail.contractUrl.split('/').pop() : '鍚堝悓',
+      }),
+      regiterTime: detail.applyTime ?? '',
+      userRealTime: row.userRealTime ?? '',
+      userSignContractTime: row.userSignContractTime ?? '',
+      contractTime: [row.contractBegin, row.contractEnd],
+    });
+  } catch (error) {}
+}
 
 async function addEnterpriseEmployee() {
   try {
+    const isEdit = !!internalStaffEditForm.id;
     let params: API.AddEnterpriseEmployeeCommand = {
       name: internalStaffEditForm.name,
       identity: internalStaffEditForm.identity,
@@ -690,11 +722,20 @@
       contractBegin: format(internalStaffEditForm.contractTime[0], 'YYYY-MM-DD 00:00:00'),
       contractEnd: format(internalStaffEditForm.contractTime[1], 'YYYY-MM-DD 23:59:59'),
     };
-    let res = await enterpriseEmployeeServices.addEnterpriseEmployee(params);
+    let res;
+    if (isEdit) {
+      (params as API.EditEnterpriseEmployeeCommand).id = internalStaffEditForm.id;
+      res = await enterpriseEmployeeServices.editEnterpriseEmployee(params);
+    } else {
+      res = await enterpriseEmployeeServices.addEnterpriseEmployee(params);
+    }
     if (res) {
       Message.successMessage('鎿嶄綔鎴愬姛');
       getList(paginationState.pageIndex);
+      internalDialogState.dialogVisible = false;
     }
-  } catch (error) {}
+  } catch (error) {
+    internalDialogState.dialogVisible = true;
+  }
 }
 </script>

--
Gitblit v1.9.1