| | |
| | | <template> |
| | | <ContentScrollView :paddingH="false"> |
| | | <nut-form :model-value="form" ref="formRef" :rules="rules"> |
| | | <nut-form-item |
| | | label="供应商:" |
| | | class="bole-form-item" |
| | | prop="supplierEnterpriseId" |
| | | label-width="90px" |
| | | required |
| | | > |
| | | <ChooseInputWithPicker |
| | | v-model="form.supplierEnterpriseId" |
| | | placeholder="请选择供应商" |
| | | :value-enum="supplierEnterpriseSelect" |
| | | /> |
| | | </nut-form-item> |
| | | <nut-form-item label="任务名称:" class="bole-form-item" prop="name" label-width="90px"> |
| | | <nut-input v-model="form.name" placeholder="请输入任务名称"> </nut-input> |
| | | </nut-form-item> |
| | | <nut-form-item |
| | | label="需求人数:" |
| | | class="bole-form-item" |
| | | prop="needPeopleNumber" |
| | | label-width="90px" |
| | | > |
| | | <div class="bole-form-input-wrapper"> |
| | | <NumberInput |
| | | v-model.trim="form.needPeopleNumber" |
| | | class="nut-input-text bole-input-text" |
| | | placeholder="请输入需求人数" |
| | | :min="0" |
| | | :max="999999999999" |
| | | :precision="0" |
| | | /> |
| | | <div class="form-input-unit">人</div> |
| | | </div> |
| | | </nut-form-item> |
| | | <nut-form-item |
| | | label="服务费:" |
| | |
| | | </nut-radio-group> |
| | | </nut-form-item> |
| | | <nut-form-item |
| | | v-if="form.billingMethod !== EnumBillingMethod.Face" |
| | | label=" " |
| | | class="bole-form-item" |
| | | prop="serviceFee" |
| | | label-width="0" |
| | | v-if="form.billingMethod !== EnumBillingMethod.Face" |
| | | > |
| | | <div class="bole-form-input-wrapper"> |
| | | <NumberInput |
| | |
| | | </div> |
| | | </nut-form-item> |
| | | </template> |
| | | <nut-form-item |
| | | v-if="form.billingMethod === EnumBillingMethod.Piece" |
| | | label="总件数:" |
| | | class="bole-form-item" |
| | | prop="totalPieces" |
| | | label-width="90" |
| | | > |
| | | <div class="bole-form-input-wrapper"> |
| | | <NumberInput |
| | | v-model.trim="form.totalPieces" |
| | | class="nut-input-text bole-input-text" |
| | | placeholder="请输入任务总件数" |
| | | :min="0" |
| | | :max="999999999999" |
| | | :precision="2" |
| | | type="text" |
| | | /> |
| | | <div class="form-input-unit">{{ '件' }}</div> |
| | | </div> |
| | | </nut-form-item> |
| | | <nut-form-item |
| | | label="结算方式:" |
| | | class="bole-form-item" |
| | |
| | | > |
| | | <ChooseInputWithDatePicker |
| | | v-model="form.applyBeginTime" |
| | | :minDate="form.beginTime ? dayjs(form.beginTime).toDate() : nowDate" |
| | | :minDate="nowDate" |
| | | placeholder="请选择报名开始日期" |
| | | ></ChooseInputWithDatePicker> |
| | | </nut-form-item> |
| | |
| | | > |
| | | <ChooseInputWithDatePicker |
| | | v-model="form.applyEndTime" |
| | | :minDate="form.beginTime ? dayjs(form.beginTime).toDate() : nowDate" |
| | | :minDate="form.applyBeginTime ? dayjs(form.applyBeginTime).toDate() : nowDate" |
| | | placeholder="请选择报名结束日期" |
| | | ></ChooseInputWithDatePicker> |
| | | </nut-form-item> |
| | |
| | | prop="checkReceiveMethod" |
| | | label-width="90px" |
| | | > |
| | | <nut-radio-group v-model="form.checkReceiveMethod" direction="horizontal"> |
| | | <!-- <nut-radio-group v-model="form.checkReceiveMethod" direction="horizontal"> |
| | | <BlRadio |
| | | :label="Number(key)" |
| | | v-for="(val, key) in EnumTaskCheckReceiveMethodText" |
| | | :key="key" |
| | | >{{ val }}</BlRadio |
| | | > |
| | | </nut-radio-group> |
| | | </nut-radio-group> --> |
| | | <nut-checkbox-group v-model="form.checkReceiveMethods"> |
| | | <nut-checkbox |
| | | v-for="(val, key) in EnumTaskCheckReceiveMethodText" |
| | | :key="key" |
| | | :label="key as any" |
| | | > |
| | | {{ val }} |
| | | </nut-checkbox> |
| | | </nut-checkbox-group> |
| | | </nut-form-item> |
| | | <nut-form-item |
| | | label="结算方式:" |
| | |
| | | :value-enum="settlementAccessList" |
| | | :disabled="isEdit" |
| | | /> |
| | | </nut-form-item> |
| | | <nut-form-item |
| | | label="预计服务费总额:" |
| | | class="bole-form-item" |
| | | prop="totalServiceFee" |
| | | label-width="110px" |
| | | > |
| | | {{ form.totalServiceFee }} |
| | | </nut-form-item> |
| | | </nut-form> |
| | | </ContentScrollView> |
| | |
| | | useAllAreaList, |
| | | useDictionaryDataSelect, |
| | | useEnterpriseWalletAccessSelect, |
| | | useGetSupplierEnterpriseSelect, |
| | | } from '@12333/hooks'; |
| | | import { useQuery } from '@tanstack/vue-query'; |
| | | import dayjs from 'dayjs'; |
| | |
| | | |
| | | const { userDetail } = useUser(); |
| | | const { findAreaNameFromCode } = useAllAreaList(); |
| | | const { settlementAccessList } = useEnterpriseWalletAccessSelect(); |
| | | |
| | | const { supplierEnterpriseSelect } = useGetSupplierEnterpriseSelect(); |
| | | const router = Taro.useRouter(); |
| | | const taskId = router.params?.id ?? ''; |
| | | const isEdit = !!taskId; |
| | |
| | | }); |
| | | |
| | | const form = reactive({ |
| | | supplierEnterpriseId: '', |
| | | name: '', |
| | | needPeopleNumber: '' as any as number, |
| | | billingMethod: EnumBillingMethod.Day, |
| | | serviceFee: '' as any as number, |
| | | settlementCycle: EnumSettlementCycle.Day, |
| | |
| | | verifyWorkHours: null as number, |
| | | timeoutServiceFee: null as number, |
| | | description: '', |
| | | checkReceiveMethod: EnumTaskCheckReceiveMethod.CheckIn, |
| | | checkReceiveMethods: [] as EnumTaskCheckReceiveMethod[], |
| | | applyBeginTime: '', |
| | | applyEndTime: '', |
| | | settlementAccess: '' as any as EnumEnterpriseWalletAccess, |
| | | totalPieces: '' as any as number, |
| | | |
| | | totalServiceFee: null as number, |
| | | }); |
| | | |
| | | const rules = reactive<FormRules>({ |
| | | supplierEnterpriseId: [{ required: true, message: '请选择供应商' }], |
| | | name: [{ required: true, message: '请输入任务名称' }], |
| | | needPeopleNumber: [{ required: true, message: '请输入需求人数' }], |
| | | totalPieces: [{ required: true, message: '请输入任务总件数' }], |
| | | verifyWorkHours: [{ required: true, message: '请输入核定工时' }], |
| | | timeoutServiceFee: [{ required: true, message: '请输入超时服务费' }], |
| | | genderLimit: [{ required: true, message: '请选择性别要求' }], |
| | | settlementCycleDate: [{ required: true, message: '请设置结算日期' }], |
| | | settlementAccess: [{ required: true, message: '请选择结算方式' }], |
| | |
| | | if (!form.billingMethod) { |
| | | return Promise.reject('请选择服务费类型'); |
| | | } |
| | | if (!form.serviceFee) { |
| | | if (!form.serviceFee && form.billingMethod !== EnumBillingMethod.Face) { |
| | | return Promise.reject('请输入服务费'); |
| | | } |
| | | return Promise.resolve(true); |
| | |
| | | message: '请选择结束日期', |
| | | validator(value) { |
| | | if (!value) return Promise.reject('请选择结束日期'); |
| | | if (form.billingMethod === EnumBillingMethod.Month) { |
| | | if (dayjs(form.endTime).isBefore(dayjs(form.beginTime).add(1, 'month'))) { |
| | | return Promise.reject('按月服务费,任务时长需大于一个月'); |
| | | } |
| | | return Promise.resolve(true); |
| | | } |
| | | if (dayjs(value).isBefore(dayjs(form.beginTime))) |
| | | return Promise.reject('结束日期需大于开始日期'); |
| | | return Promise.resolve(true); |
| | |
| | | ], |
| | | }); |
| | | |
| | | const { settlementAccessList } = useEnterpriseWalletAccessSelect({ |
| | | supplierEnterpriseId: computed(() => form.supplierEnterpriseId), |
| | | }); |
| | | |
| | | const { |
| | | isLoading, |
| | | isError, |
| | |
| | | placeholderData: () => ({} as API.GetTaskInfoQueryResult), |
| | | enabled: isEdit, |
| | | onSuccess(data) { |
| | | form.supplierEnterpriseId = data.supplierEnterpriseId; |
| | | form.name = data.name; |
| | | form.needPeopleNumber = data.needPeopleNumber; |
| | | form.billingMethod = data.billingMethod; |
| | | form.serviceFee = data.serviceFee; |
| | | form.settlementCycle = data.settlementCycle; |
| | |
| | | form.description = data.description; |
| | | form.verifyWorkHours = data.verifyWorkHours; |
| | | form.timeoutServiceFee = data.timeoutServiceFee; |
| | | form.checkReceiveMethod = data.checkReceiveMethod; |
| | | form.checkReceiveMethods = data.checkReceiveMethods; |
| | | form.applyBeginTime = dayjs(data.applyBeginTime).format('YYYY-MM-DD'); |
| | | form.applyEndTime = dayjs(data.applyEndTime).format('YYYY-MM-DD'); |
| | | form.settlementAccess = data.settlementAccess; |
| | |
| | | async function confirm() { |
| | | try { |
| | | let params: API.SaveTaskInfoCommand = { |
| | | supplierEnterpriseId: form.supplierEnterpriseId, |
| | | name: form.name, |
| | | needPeopleNumber: form.needPeopleNumber, |
| | | billingMethod: form.billingMethod, |
| | | serviceFee: form.serviceFee, |
| | | settlementCycle: form.settlementCycle, |
| | |
| | | description: form.description, |
| | | verifyWorkHours: form.verifyWorkHours, |
| | | timeoutServiceFee: form.timeoutServiceFee, |
| | | checkReceiveMethod: form.checkReceiveMethod, |
| | | checkReceiveMethods: form.checkReceiveMethods, |
| | | 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, |