From df174a7a91ca8b354ded7752f21ea0253881eb02 Mon Sep 17 00:00:00 2001
From: wupengfei <834520024@qq.com>
Date: 星期五, 12 十二月 2025 17:45:48 +0800
Subject: [PATCH] feat: 保险

---
 apps/bMiniApp/src/subpackages/task/publishTask/InnerPage.vue |  109 ++++++++++++++++++++++++++++++++++++++++++++++++++++--
 1 files changed, 104 insertions(+), 5 deletions(-)

diff --git a/apps/bMiniApp/src/subpackages/task/publishTask/InnerPage.vue b/apps/bMiniApp/src/subpackages/task/publishTask/InnerPage.vue
index 534de01..d8ee63b 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">
@@ -32,6 +33,7 @@
             :min="0"
             :max="999999999999"
             :precision="0"
+            @change="calcTaskTotalServiceFee"
           />
           <div class="form-input-unit">浜�</div>
         </div>
@@ -44,7 +46,11 @@
         label-width="90px"
         label-position="top"
       >
-        <nut-radio-group v-model="form.billingMethod" direction="horizontal">
+        <nut-radio-group
+          v-model="form.billingMethod"
+          direction="horizontal"
+          @change="calcTaskTotalServiceFee"
+        >
           <BlRadio
             :label="Number(key)"
             v-for="(val, key) in EnumBillingMethodText"
@@ -71,6 +77,7 @@
             :precision="2"
             type="text"
             :disabled="feeCannotEdit"
+            @change="calcTaskTotalServiceFee"
           />
           <div class="form-input-unit">{{ BillingMethodEnumUnit[form.billingMethod] }}</div>
         </div>
@@ -92,6 +99,7 @@
               :precision="2"
               type="text"
               :disabled="feeCannotEdit"
+              @change="calcTaskTotalServiceFee"
             />
             <div class="form-input-unit">{{ '灏忔椂/澶�' }}</div>
           </div>
@@ -134,6 +142,7 @@
             :precision="2"
             type="text"
             :disabled="feeCannotEdit"
+            @change="calcTaskTotalServiceFee"
           />
           <div class="form-input-unit">{{ '浠�' }}</div>
         </div>
@@ -272,6 +281,7 @@
           v-model="form.endTime"
           :minDate="nowDate"
           placeholder="璇烽�夋嫨浠诲姟缁撴潫鏃ユ湡"
+          @change="calcTaskTotalServiceFee()"
         ></ChooseInputWithDatePicker>
       </nut-form-item>
       <nut-form-item
@@ -322,6 +332,24 @@
             {{ val }}
           </nut-checkbox>
         </nut-checkbox-group>
+      </nut-form-item>
+      <nut-form-item
+        label="淇濋櫓浜у搧:"
+        class="bole-form-item"
+        prop="insuranceProductId"
+        label-width="90px"
+        required
+        v-if="
+          form.checkReceiveMethods.includes(EnumTaskCheckReceiveMethod.CheckIn) &&
+          form.isConfiguredInsurance
+        "
+      >
+        <ChooseInputWithPicker
+          v-model="form.insuranceProductId"
+          placeholder="璇烽�夋嫨淇濋櫓浜у搧"
+          :value-enum="enterpriseInsuranceProductSelect"
+          @change="calcTaskTotalServiceFee()"
+        />
       </nut-form-item>
       <nut-form-item
         label="缁撶畻鏂瑰紡:"
@@ -389,6 +417,7 @@
 import {
   useAllAreaList,
   useDictionaryDataSelect,
+  useEnterpriseInsuranceProductSelect,
   useEnterpriseWalletAccessSelect,
   useGetSupplierEnterpriseSelect,
 } from '@12333/hooks';
@@ -403,10 +432,11 @@
 const { findAreaNameFromCode } = useAllAreaList();
 
 const { supplierEnterpriseSelect } = useGetSupplierEnterpriseSelect();
+
 const router = Taro.useRouter();
 const taskId = router.params?.id ?? '';
-const isEdit = !!taskId;
 const isCopy = router.params?.isCopy === 'true';
+const isEdit = !!taskId && !isCopy;
 
 const nowDate = dayjs().toDate();
 const applyBeginTimeMinDate = computed(() => {
@@ -467,6 +497,8 @@
   totalPieceQuantity: '' as any as number,
 
   totalServiceFee: null as number,
+  insuranceProductId: '',
+  isConfiguredInsurance: false,
 });
 
 const rules = reactive<FormRules>({
@@ -572,11 +604,29 @@
     {
       required: true,
       message: '璇烽�夋嫨楠屾敹鏂瑰紡',
+      validator(value) {
+        if (!value?.length) return Promise.reject('璇烽�夋嫨楠屾敹鏂瑰紡');
+        return Promise.resolve(true);
+      },
+    },
+  ],
+  insuranceProductId: [
+    {
+      required: true,
+      message: '璇烽�夋嫨淇濋櫓浜у搧',
+      validator(value) {
+        if (!value?.length) return Promise.reject('璇烽�夋嫨淇濋櫓浜у搧');
+        return Promise.resolve(true);
+      },
     },
   ],
 });
 
 const { settlementAccessList } = useEnterpriseWalletAccessSelect({
+  supplierEnterpriseId: computed(() => form.supplierEnterpriseId),
+});
+
+const { enterpriseInsuranceProductSelect } = useEnterpriseInsuranceProductSelect({
   supplierEnterpriseId: computed(() => form.supplierEnterpriseId),
 });
 
@@ -596,7 +646,7 @@
     );
   },
   placeholderData: () => ({} as API.GetTaskInfoQueryResult),
-  enabled: isEdit,
+  enabled: isEdit || isCopy,
   onSuccess(data) {
     form.supplierEnterpriseId = data.supplierEnterpriseId;
     form.name = data.name;
@@ -622,6 +672,7 @@
       latitude: data.latitude,
       longitude: data.longitude,
       addressName: data.addressName,
+      address: data.addressName,
     };
     form.description = data.description;
     form.verifyWorkHours = data.verifyWorkHours;
@@ -630,7 +681,10 @@
     form.applyBeginTime = dayjs(data.applyBeginTime).format('YYYY-MM-DD');
     form.applyEndTime = dayjs(data.applyEndTime).format('YYYY-MM-DD');
     form.settlementAccess = data.settlementAccess;
+    form.insuranceProductId = data.insuranceProductId;
+    form.totalServiceFee = data.estimatedServiceFee;
 
+    supplierEnterpriseChange();
     if (!!data.timeoutServiceFee) {
       calcTaskTotalServiceFee();
     }
@@ -639,6 +693,12 @@
 
 async function calcTaskTotalServiceFee() {
   try {
+    if (!form.beginTime || !form.endTime) {
+      return;
+    }
+    if (form.billingMethod !== EnumBillingMethod.Piece && !form.needPeopleNumber) {
+      return;
+    }
     let params: API.CalcTaskTotalServiceFeeCommand = {
       billingMethod: form.billingMethod,
       serviceFee: form.serviceFee,
@@ -647,13 +707,47 @@
       needPeopleNumber: form.needPeopleNumber,
       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,
+      checkReceiveMethods: form.checkReceiveMethods,
     };
-    let res = await taskServices.calcTaskTotalServiceFee(params);
+    if (form.insuranceProductId) {
+      params.insuranceProductId = form.insuranceProductId;
+    }
+    let res = await taskServices.calcTaskTotalServiceFee(params, { showLoading: false });
     if (res) {
       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(() => {
+//   if (!form.beginTime || !form.endTime) {
+//     return 0;
+//   }
+//   var days = dayjs(form.endTime).diff(dayjs(form.beginTime), 'day') + 1;
+//   const serviceFee = form.serviceFee || 0;
+//   const needPeopleNumber = form.needPeopleNumber || 0;
+//   switch (form.billingMethod) {
+//     case EnumBillingMethod.Month:
+//       return serviceFee * Math.round(days / 30) * needPeopleNumber;
+//     case EnumBillingMethod.Day:
+//       return serviceFee * days * needPeopleNumber;
+//     case EnumBillingMethod.Hour:
+//       return serviceFee * (form.verifyWorkHours || 0) * days * needPeopleNumber;
+//     case EnumBillingMethod.Piece:
+//       return serviceFee * (form.totalPieceQuantity || 0);
+//     default:
+//       return 0;
+//   }
+// });
 
 const formRef = ref<any>(null);
 function handleConfirm() {
@@ -674,7 +768,7 @@
       name: form.name,
       needPeopleNumber: form.needPeopleNumber,
       billingMethod: form.billingMethod,
-      serviceFee: form.serviceFee,
+      // serviceFee: form.serviceFee,
       totalPieceQuantity: form.totalPieceQuantity,
       settlementCycle: form.settlementCycle,
       settlementDate: form.settlementDate ? form.settlementDate : 0,
@@ -698,7 +792,11 @@
       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,
     };
+    if (form.billingMethod !== EnumBillingMethod.Face) {
+      params.serviceFee = form.serviceFee;
+    }
     if (isEdit) {
       params.id = taskId;
     }
@@ -728,6 +826,7 @@
 function timeChange() {
   form.applyBeginTime = '';
   form.applyEndTime = '';
+  calcTaskTotalServiceFee();
 }
 
 function applyTimeChange() {

--
Gitblit v1.9.1