From 39fe8d064f84088d1f8a897495fa05baf671bba8 Mon Sep 17 00:00:00 2001
From: zhengyiming <540361168@qq.com>
Date: 星期一, 10 十一月 2025 18:34:48 +0800
Subject: [PATCH] fix: bug
---
apps/bMiniApp/src/subpackages/task/publishTask/InnerPage.vue | 64 ++++++++++++++++++++++++++++---
1 files changed, 57 insertions(+), 7 deletions(-)
diff --git a/apps/bMiniApp/src/subpackages/task/publishTask/InnerPage.vue b/apps/bMiniApp/src/subpackages/task/publishTask/InnerPage.vue
index 7a91f45..7f83fa7 100644
--- a/apps/bMiniApp/src/subpackages/task/publishTask/InnerPage.vue
+++ b/apps/bMiniApp/src/subpackages/task/publishTask/InnerPage.vue
@@ -32,6 +32,7 @@
:min="0"
:max="999999999999"
:precision="0"
+ @change="calcTaskTotalServiceFee"
/>
<div class="form-input-unit">浜�</div>
</div>
@@ -44,7 +45,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 +76,7 @@
:precision="2"
type="text"
:disabled="feeCannotEdit"
+ @change="calcTaskTotalServiceFee"
/>
<div class="form-input-unit">{{ BillingMethodEnumUnit[form.billingMethod] }}</div>
</div>
@@ -92,6 +98,7 @@
:precision="2"
type="text"
:disabled="feeCannotEdit"
+ @change="calcTaskTotalServiceFee"
/>
<div class="form-input-unit">{{ '灏忔椂/澶�' }}</div>
</div>
@@ -134,6 +141,7 @@
:precision="2"
type="text"
:disabled="feeCannotEdit"
+ @change="calcTaskTotalServiceFee"
/>
<div class="form-input-unit">{{ '浠�' }}</div>
</div>
@@ -272,6 +280,7 @@
v-model="form.endTime"
:minDate="nowDate"
placeholder="璇烽�夋嫨浠诲姟缁撴潫鏃ユ湡"
+ @change="calcTaskTotalServiceFee()"
></ChooseInputWithDatePicker>
</nut-form-item>
<nut-form-item
@@ -343,7 +352,7 @@
prop="totalServiceFee"
label-width="110px"
>
- {{ `${toThousand(form.totalServiceFee)}鍏僠 }}
+ {{ `${toThousand(totalServiceFee)}鍏僠 }}
</nut-form-item>
</nut-form>
</ContentScrollView>
@@ -405,8 +414,8 @@
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(() => {
@@ -572,6 +581,10 @@
{
required: true,
message: '璇烽�夋嫨楠屾敹鏂瑰紡',
+ validator(value) {
+ if (!value?.length) return Promise.reject('璇烽�夋嫨楠屾敹鏂瑰紡');
+ return Promise.resolve(true);
+ },
},
],
});
@@ -596,7 +609,7 @@
);
},
placeholderData: () => ({} as API.GetTaskInfoQueryResult),
- enabled: isEdit,
+ enabled: isEdit || isCopy,
onSuccess(data) {
form.supplierEnterpriseId = data.supplierEnterpriseId;
form.name = data.name;
@@ -622,6 +635,7 @@
latitude: data.latitude,
longitude: data.longitude,
addressName: data.addressName,
+ address: data.addressName,
};
form.description = data.description;
form.verifyWorkHours = data.verifyWorkHours;
@@ -631,12 +645,20 @@
form.applyEndTime = dayjs(data.applyEndTime).format('YYYY-MM-DD');
form.settlementAccess = data.settlementAccess;
- calcTaskTotalServiceFee();
+ if (!!data.timeoutServiceFee) {
+ calcTaskTotalServiceFee();
+ }
},
});
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,
@@ -646,12 +668,33 @@
beginTime: dayjs(form.beginTime).format('YYYY-MM-DD 00:00:00'),
endTime: dayjs(form.endTime).format('YYYY-MM-DD 23:59:59'),
};
- let res = await taskServices.calcTaskTotalServiceFee(params);
+ let res = await taskServices.calcTaskTotalServiceFee(params, { showLoading: false });
if (res) {
form.totalServiceFee = res.totalServiceFee;
}
} catch (error) {}
}
+
+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() {
@@ -672,7 +715,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,
@@ -697,6 +740,12 @@
applyEndTime: dayjs(form.applyEndTime).format('YYYY-MM-DD 23:59:59'),
settlementAccess: form.settlementAccess,
};
+ if (
+ form.billingMethod !== EnumBillingMethod.Face &&
+ form.billingMethod !== EnumBillingMethod.Piece
+ ) {
+ params.serviceFee = form.serviceFee;
+ }
if (isEdit) {
params.id = taskId;
}
@@ -726,6 +775,7 @@
function timeChange() {
form.applyBeginTime = '';
form.applyEndTime = '';
+ calcTaskTotalServiceFee();
}
function applyTimeChange() {
--
Gitblit v1.9.1