From 27652573ea8a58d5593791e27b4d326f84187093 Mon Sep 17 00:00:00 2001
From: wupengfei <834520024@qq.com>
Date: 星期五, 12 十二月 2025 21:37:30 +0800
Subject: [PATCH] fix: bug

---
 apps/bMiniApp/src/subpackages/task/publishTask/InnerPage.vue |   23 +++++++++++++++++------
 1 files changed, 17 insertions(+), 6 deletions(-)

diff --git a/apps/bMiniApp/src/subpackages/task/publishTask/InnerPage.vue b/apps/bMiniApp/src/subpackages/task/publishTask/InnerPage.vue
index d96eb17..2999743 100644
--- a/apps/bMiniApp/src/subpackages/task/publishTask/InnerPage.vue
+++ b/apps/bMiniApp/src/subpackages/task/publishTask/InnerPage.vue
@@ -13,6 +13,7 @@
           placeholder="璇烽�夋嫨渚涘簲鍟�"
           :value-enum="supplierEnterpriseSelect"
           :disabled="isEdit"
+          @change="supplierEnterpriseChange"
         />
       </nut-form-item>
       <nut-form-item label="浠诲姟鍚嶇О:" class="bole-form-item" prop="name" label-width="90px">
@@ -340,7 +341,7 @@
         required
         v-if="
           form.checkReceiveMethods.includes(EnumTaskCheckReceiveMethod.CheckIn) &&
-          enterpriseInsuranceProductSelect?.length > 0
+          form.isConfiguredInsurance
         "
       >
         <ChooseInputWithPicker
@@ -497,6 +498,7 @@
 
   totalServiceFee: null as number,
   insuranceProductId: '',
+  isConfiguredInsurance: false,
 });
 
 const rules = reactive<FormRules>({
@@ -626,6 +628,7 @@
 
 const { enterpriseInsuranceProductSelect } = useEnterpriseInsuranceProductSelect({
   supplierEnterpriseId: computed(() => form.supplierEnterpriseId),
+  isConfiguredInsurance: computed(() => form.isConfiguredInsurance),
 });
 
 const {
@@ -682,6 +685,7 @@
     form.insuranceProductId = data.insuranceProductId;
     form.totalServiceFee = data.estimatedServiceFee;
 
+    supplierEnterpriseChange();
     if (!!data.timeoutServiceFee) {
       calcTaskTotalServiceFee();
     }
@@ -690,18 +694,17 @@
 
 async function calcTaskTotalServiceFee() {
   try {
+    console.log();
     if (!form.beginTime || !form.endTime) {
       return;
     }
-    if (form.billingMethod !== EnumBillingMethod.Piece && !form.needPeopleNumber) {
-      return;
-    }
+
     let params: API.CalcTaskTotalServiceFeeCommand = {
       billingMethod: form.billingMethod,
       serviceFee: form.serviceFee,
       verifyWorkHours: form.verifyWorkHours,
       totalPieceQuantity: form.totalPieceQuantity,
-      needPeopleNumber: form.needPeopleNumber,
+      needPeopleNumber: form.needPeopleNumber ? form.needPeopleNumber : 0,
       beginTime: dayjs(form.beginTime).format('YYYY-MM-DD 00:00:00'),
       endTime: dayjs(form.endTime).format('YYYY-MM-DD 23:59:59'),
       supplierEnterpriseId: form.supplierEnterpriseId,
@@ -715,6 +718,14 @@
       form.totalServiceFee = res.totalServiceFee;
     }
   } catch (error) {}
+}
+
+function supplierEnterpriseChange() {
+  if (form.supplierEnterpriseId) {
+    form.isConfiguredInsurance = supplierEnterpriseSelect.value?.find(
+      (item) => item.value === form.supplierEnterpriseId
+    )?.data?.isConfiguredInsurance;
+  }
 }
 
 // const totalServiceFee = computed(() => {
@@ -781,7 +792,7 @@
       applyBeginTime: dayjs(form.applyBeginTime).format('YYYY-MM-DD 00:00:00'),
       applyEndTime: dayjs(form.applyEndTime).format('YYYY-MM-DD 23:59:59'),
       settlementAccess: form.settlementAccess,
-      insuranceProductId: form.insuranceProductId,
+      insuranceProductId: form.insuranceProductId ? form.insuranceProductId : null,
     };
     if (form.billingMethod !== EnumBillingMethod.Face) {
       params.serviceFee = form.serviceFee;

--
Gitblit v1.9.1