From 1d8a2ae469d44476c8af208f00359508bec65c82 Mon Sep 17 00:00:00 2001 From: wupengfei <834520024@qq.com> Date: 星期二, 12 八月 2025 10:38:37 +0800 Subject: [PATCH] feat: 接口 --- src/views/EmploymentManage/components/AddOrEditEmploymentView.vue | 94 +++++++++++++++++++++++++++++++++++++++------- 1 files changed, 79 insertions(+), 15 deletions(-) diff --git a/src/views/EmploymentManage/components/AddOrEditEmploymentView.vue b/src/views/EmploymentManage/components/AddOrEditEmploymentView.vue index 1060e6b..c40ec24 100644 --- a/src/views/EmploymentManage/components/AddOrEditEmploymentView.vue +++ b/src/views/EmploymentManage/components/AddOrEditEmploymentView.vue @@ -5,14 +5,34 @@ <ProForm :model="form" ref="productFormRef" label-width="110px" :is-read="isDetail"> <ProFormCol> <ProFormColItem :span="12"> - <ProFormItemV2 label="浠诲姟鍚嶇О:" prop="name"> + <ProFormItemV2 + label="浠诲姟鍚嶇О:" + prop="name" + :check-rules="[{ message: '璇疯緭鍏ヤ换鍔″悕绉�' }]" + > <ProFormText v-model.trim="form.name" placeholder="璇疯緭鍏ヤ换鍔″悕绉�" /> </ProFormItemV2> </ProFormColItem> </ProFormCol> <ProFormCol> <ProFormColItem :span="12"> - <ProFormItemV2 label="鏈嶅姟璐�:" prop="billingMethod"> + <ProFormItemV2 + label="鏈嶅姟璐�:" + prop="billingMethod" + :check-rules="[ + { + validator: (rule, value, callback) => { + if (!form.billingMethod) { + callback(new Error('璇烽�夋嫨鏈嶅姟璐圭被鍨�')); + } + if (!form.serviceFee) { + callback(new Error('璇疯緭鍏ユ湇鍔¤垂')); + } + callback(); + }, + }, + ]" + > <RadioWithExtra v-model="form.billingMethod" :value-enum="EnumBillingMethodText" @@ -33,7 +53,11 @@ </ProFormCol> <ProFormCol> <ProFormColItem :span="12"> - <ProFormItemV2 label="缁撶畻鏂瑰紡:" prop="settlementCycle"> + <ProFormItemV2 + label="缁撶畻鏂瑰紡:" + prop="settlementCycle" + :check-rules="[{ message: '璇烽�夋嫨缁撶畻鏂瑰紡' }]" + > <ProFormRadio v-model="form.settlementCycle" :value-enum="EnumSettlementCycleText" @@ -63,7 +87,27 @@ </ProFormCol> <ProFormCol> <ProFormColItem :span="12"> - <ProFormItemV2 label="骞撮緞鑼冨洿:" prop="ageRange" class="form-age-range"> + <ProFormItemV2 + label="骞撮緞鑼冨洿:" + prop="ageRange" + class="form-age-range" + :check-rules="[ + { + validator: (rule, value, callback) => { + if (!form.ageMinLimit) { + callback(new Error('璇疯緭鍏ュ勾榫勮姹�')); + } + if (!form.ageMaxLimit) { + callback(new Error('璇疯緭鍏ュ勾榫勮姹�')); + } + if (Number(form.ageMaxLimit) <= Number(form.ageMinLimit)) { + callback(new Error('鏈�澶у勾榫勪笉鑳藉皬浜庢渶灏忓勾榫�')); + } + callback(); + }, + }, + ]" + > <ProFormInputNumber :controls="false" :min="1" @@ -82,13 +126,14 @@ </ProFormCol> <ProFormCol> <ProFormColItem :span="12"> - <ProFormItemV2 label="鎬у埆瑕佹眰:" prop="genderLimit"> + <ProFormItemV2 + label="鎬у埆瑕佹眰:" + prop="genderLimit" + :check-rules="[{ message: '璇烽�夋嫨鎬у埆瑕佹眰' }]" + > <ProFormRadio v-model="form.genderLimit" :value-enum="EnumUserGenderTextForEdit" - show-all-btn - :all-btn-label="'涓嶉檺'" - :allBtnValue="0" ></ProFormRadio> </ProFormItemV2> </ProFormColItem> @@ -114,7 +159,13 @@ </ProFormCol> <ProFormCol> <ProFormColItem :span="12"> - <ProFormItemV2 label="浠诲姟鍦扮偣:" prop="weMapInfo"> + <ProFormItemV2 + label="浠诲姟鍦扮偣:" + prop="weMapInfo" + :check-rules="[ + { message: '璇烽�夋嫨浠诲姟鍦扮偣', validator: FormValidator.validatorWeMap }, + ]" + > <WeMap v-if="!isDetail" v-model="form.weMapInfo" /> <div v-else> {{ @@ -128,20 +179,29 @@ </ProFormCol> <ProFormCol> <ProFormColItem :span="12"> - <ProFormItemV2 label="璇︾粏鍦板潃:" prop="addressDetail"> + <ProFormItemV2 + label="璇︾粏鍦板潃:" + prop="addressDetail" + :check-rules="[{ message: '璇疯緭鍏ヨ缁嗗湴鍧�' }]" + > <ProFormText v-model.trim="form.addressDetail" placeholder="璇疯緭鍏ヨ缁嗗湴鍧�" /> </ProFormItemV2> </ProFormColItem> </ProFormCol> <ProFormCol> <ProFormColItem :span="12"> - <ProFormItemV2 label="浠诲姟鏃堕棿:" prop="time"> + <ProFormItemV2 + label="浠诲姟鏃堕棿:" + prop="time" + :check-rules="[{ message: '璇烽�夋嫨浠诲姟鏃堕棿', type: 'array' }]" + > <ProFormDatePicker v-model="form.time" type="daterange" range-separator="鑷�" start-placeholder="寮�濮嬫棩鏈�" end-placeholder="缁撴潫鏃ユ湡" + :disabled-date="disabledDate" ></ProFormDatePicker> </ProFormItemV2> </ProFormColItem> @@ -181,7 +241,7 @@ EnumBillingMethodUnitText, EnumSettlementCycleText, } from '@/constants'; -import { format } from '@/utils'; +import { format, FormValidator } from '@/utils'; import dayjs from 'dayjs'; defineOptions({ @@ -194,6 +254,10 @@ const route = useRoute(); const id = route.params.id as string; const isEdit = !!id; + +function disabledDate(time: Date) { + return dayjs(time).isBefore(dayjs(), 'day'); +} const eventContext = useGlobalEventContext(); @@ -217,7 +281,7 @@ name: '', billingMethod: '' as any as EnumBillingMethod, serviceFee: 0, - settlementCycle: '' as any as EnumSettlementCycle, + settlementCycle: EnumSettlementCycle.Month, benefits: [] as string[], ageMinLimit: 0, ageMaxLimit: 0, @@ -269,7 +333,7 @@ function handleBack() { closeViewPush(route, { - name: 'EmploymentManageList', + name: 'TaskManageList', }); } const productFormRef = ref<FormInstance>(); @@ -311,7 +375,7 @@ let res = await taskServices.saveTaskInfo(params); if (res) { Message.successMessage('鎿嶄綔鎴愬姛'); - eventContext.emit(isEdit ? 'employment:edit' : 'employment:add'); + eventContext.emit(isEdit ? 'taskManage:edit' : 'taskManage:add'); handleBack(); } } catch (error) {} -- Gitblit v1.9.1