Explorar el Código

装卸货点位时间段配置

shasha hace 1 mes
padre
commit
1737bf6ceb

+ 125 - 0
snowy-admin-web/src/views/biz/bizloadtime/addForm.vue

@@ -0,0 +1,125 @@
+<template>
+	<xn-form-container
+		title="增加装货时间配置"
+		:width="700"
+		v-model:open="open"
+		:destroy-on-close="true"
+		@close="onClose"
+	>
+		<a-form ref="formRef" :model="formData" :rules="formRules" :wrapper-col="wrapperCol" :label-col="labelCol">
+			<a-form-item label="装货点位:" name="pointId">
+				<a-select
+					v-model:value="formData.pointId"
+					:dropdown-style="{ maxHeight: '400px', overflow: 'auto' }"
+					:options="pointList"
+					class="xn-wd"
+					placeholder="请选择装货点位"
+				/>
+			</a-form-item>
+			<a-form-item label="装货时间段:" name="loadStartEndTime">
+				<a-range-picker v-model:value="formData.loadStartEndTime" value-format="YYYY-MM-DD HH:mm" show-time :disabled-date="disabledDate" style="width: 100%" />
+			</a-form-item>
+			<a-form-item label="可约次数:" name="availableNumber">
+				<a-input-number v-model:value="formData.availableNumber" style="width: 100%;" placeholder="请输入可约次数" allow-clear />
+			</a-form-item>
+		</a-form>
+		<template #footer>
+			<a-button style="margin-right: 8px" @click="onClose">关闭</a-button>
+			<a-button type="primary" @click="onSubmit" :loading="submitLoading">保存</a-button>
+		</template>
+	</xn-form-container>
+</template>
+
+<script setup name="bizLoadTimeForm">
+	import { cloneDeep } from 'lodash-es'
+	import { message } from 'ant-design-vue'
+	import { required } from '@/utils/formRules'
+	import bizLoadPointApi from '@/api/biz/bizLoadPointApi'
+	import bizLoadTimeApi from '@/api/biz/bizLoadTimeApi'
+	import dayjs from 'dayjs'
+
+	// 抽屉状态
+	const open = ref(false)
+	const emit = defineEmits({ successful: null })
+	const formRef = ref()
+	// 表单数据
+	const formData = ref({})
+	const submitLoading = ref(false)
+	// 装卸货点位列表
+	const pointList = ref([])
+
+	//设置表单样式
+	const labelCol = ref({ span: 4})
+	const wrapperCol = ref({ span: 16})
+
+	// 当前时间
+	const nowTime = ref(new Date())
+	// 禁用时间范围
+	const disabledDate = (current) => {
+		return (
+			(current && current < dayjs(nowTime.value).startOf('time'))
+		)
+	}
+
+	// 打开抽屉
+	const onOpen = (record) => {
+		open.value = true
+		formData.value = {
+			confStartEndTime: '',
+			goodsJson: []
+		}
+		if (record) {
+			let recordData = cloneDeep(record)
+			formData.value = Object.assign({}, recordData)
+		}
+
+		// 获取装卸货点位列表
+		bizLoadPointApi.getList().then((data) => {
+			pointList.value = data.map((item) => {
+				return {
+					value: item['id'],
+					label: item['loadPoint']
+				}
+			})
+		}).finally(() => {
+			submitLoading.value = false
+		})
+	}
+	// 关闭抽屉
+	const onClose = () => {
+		formRef.value.resetFields()
+		formData.value = {}
+		open.value = false
+	}
+	// 默认要校验的
+	const formRules = {
+		pointId: [required('请选择装货点位')],
+		loadStartEndTime: [required('请选择装货时间段')],
+		availableNumber: [required('请输入可预约次数')],
+	}
+	// 验证并提交数据
+	const onSubmit = () => {
+		formRef.value
+			.validate()
+			.then(() => {
+				submitLoading.value = true
+				const formDataParam = cloneDeep(formData.value)
+				formDataParam.beginTime = formDataParam.loadStartEndTime[0]+":00"
+				formDataParam.endTime = formDataParam.loadStartEndTime[1]+":00"
+				bizLoadTimeApi
+					.bizLoadTimeSubmitForm(formDataParam, formDataParam.id)
+					.then(() => {
+						onClose()
+						emit('successful')
+					})
+					.finally(() => {
+						submitLoading.value = false
+					})
+			})
+			.catch(() => {})
+	}
+	// 抛出函数
+	defineExpose({
+		onOpen
+	})
+</script>

+ 92 - 0
snowy-admin-web/src/views/biz/bizloadtime/alreadyForm.vue

@@ -0,0 +1,92 @@
+<template>
+	<xn-form-container
+		:title="formData.id ? '编辑装货时间配置' : '增加装货时间配置'"
+		:width="700"
+		v-model:open="open"
+		:destroy-on-close="true"
+		@close="onClose"
+	>
+		<a-descriptions :column="4" size="middle" bordered class="mb-2" :label-style="labelStyle" :contentStyle="contentStyle">
+			<a-descriptions-item label="装货点位" :span="4">{{ formData.pointId }}</a-descriptions-item>
+			<a-descriptions-item label="装货段" :span="4">{{ formData.beginTime }} ~ {{ formData.endTime }}</a-descriptions-item>
+			<a-descriptions-item label="原可约次数" :span="4">{{ availableNumber }}</a-descriptions-item>
+			<a-descriptions-item label="已约次数" :span="4">{{ alreadyNumber }} </a-descriptions-item>
+			<a-descriptions-item label="剩余可约次数" :span="4">{{ lastNumber }} </a-descriptions-item>
+		</a-descriptions>
+
+		<a-form ref="formRef" :model="formData" :rules="formRules" :wrapper-col="wrapperCol" :label-col="labelCol">
+			<a-form-item label="可约次数:" name="availableNumber">
+				<a-input-number v-model:value="formData.availableNumber" :min="alreadyNumber" style="width: 100%;" placeholder="请输入可约次数" allow-clear />
+			</a-form-item>
+		</a-form>
+
+		<div style="color: red;">提示:不得小于当前已约次数 {{ alreadyNumber }} </div>
+
+		<template #footer>
+			<a-button style="margin-right: 8px" @click="onClose">关闭</a-button>
+			<a-button type="primary" @click="onSubmit" :loading="submitLoading">保存</a-button>
+		</template>
+	</xn-form-container>
+</template>
+
+<script setup name="bizLoadTimeForm">
+	import { cloneDeep } from 'lodash-es'
+	import { required } from '@/utils/formRules'
+	import bizLoadTimeApi from '@/api/biz/bizLoadTimeApi'
+	// 抽屉状态
+	const open = ref(false)
+	const emit = defineEmits({ successful: null })
+	const formRef = ref()
+	// 表单数据
+	const formData = ref({})
+	const submitLoading = ref(false)
+	const availableNumber = ref("")
+	const alreadyNumber = ref("")
+	const lastNumber = ref("")	
+
+	// 打开抽屉
+	const onOpen = (record, pointId) => {
+		open.value = true
+		formData.value.pointId = pointId
+		if (record) {
+			let recordData = cloneDeep(record)
+			formData.value = Object.assign({}, recordData)
+			availableNumber.value = Number(formData.value.availableNumber)
+			alreadyNumber.value = Number(formData.value.alreadyNumber)
+			lastNumber.value = availableNumber.value - alreadyNumber.value
+		}
+	}
+	// 关闭抽屉
+	const onClose = () => {
+		formRef.value.resetFields()
+		formData.value = {}
+		open.value = false
+	}
+	// 默认要校验的
+	const formRules = {
+		availableNumber: [required("请输入可约次数")]
+	}
+	// 验证并提交数据
+	const onSubmit = () => {
+		formRef.value
+			.validate()
+			.then(() => {
+				submitLoading.value = true
+				const formDataParam = cloneDeep(formData.value)
+				bizLoadTimeApi
+					.bizLoadTimeSubmitForm(formDataParam, formDataParam.id)
+					.then(() => {
+						onClose()
+						emit('successful')
+					})
+					.finally(() => {
+						submitLoading.value = false
+					})
+			})
+			.catch(() => {})
+	}
+	// 抛出函数
+	defineExpose({
+		onOpen
+	})
+</script>

+ 23 - 11
snowy-admin-web/src/views/biz/bizloadtime/form.vue → snowy-admin-web/src/views/biz/bizloadtime/editForm.vue

@@ -1,26 +1,20 @@
 <template>
 	<xn-form-container
-		:title="formData.id ? '编辑装货时间配置' : '增加装货时间配置'"
+		title="编辑装货时间配置"
 		:width="700"
 		v-model:open="open"
 		:destroy-on-close="true"
 		@close="onClose"
 	>
-		<a-form ref="formRef" :model="formData" :rules="formRules" layout="vertical">
-			<a-form-item label="装货点位id:" name="pointId">
-				<a-input v-model:value="formData.pointId" placeholder="请输入装货点位id" allow-clear />
-			</a-form-item>
+		<a-form ref="formRef" :model="formData" :rules="formRules" :wrapper-col="wrapperCol" :label-col="labelCol">
 			<a-form-item label="开始时间:" name="beginTime">
-				<a-date-picker v-model:value="formData.beginTime" value-format="YYYY-MM-DD HH:mm:ss" show-time placeholder="请选择开始时间" style="width: 100%" />
+				<a-date-picker v-model:value="formData.beginTime" value-format="YYYY-MM-DD HH:mm" show-time placeholder="请选择开始时间" :disabled-date="disabledDate" style="width: 100%" />
 			</a-form-item>
 			<a-form-item label="结束时间:" name="endTime">
-				<a-date-picker v-model:value="formData.endTime" value-format="YYYY-MM-DD HH:mm:ss" show-time placeholder="请选择结束时间" style="width: 100%" />
+				<a-date-picker v-model:value="formData.endTime" value-format="YYYY-MM-DD HH:mm" show-time placeholder="请选择结束时间" :disabled-date="disabledDate" style="width: 100%" />
 			</a-form-item>
 			<a-form-item label="可约次数:" name="availableNumber">
-				<a-input v-model:value="formData.availableNumber" placeholder="请输入可约次数" allow-clear />
-			</a-form-item>
-			<a-form-item label="已约次数:" name="alreadyNumber">
-				<a-input v-model:value="formData.alreadyNumber" placeholder="请输入已约次数" allow-clear />
+				<a-input-number v-model:value="formData.availableNumber" style="width: 100%;" placeholder="请输入可约次数" allow-clear />
 			</a-form-item>
 		</a-form>
 		<template #footer>
@@ -34,6 +28,8 @@
 	import { cloneDeep } from 'lodash-es'
 	import { required } from '@/utils/formRules'
 	import bizLoadTimeApi from '@/api/biz/bizLoadTimeApi'
+	import dayjs from 'dayjs'
+
 	// 抽屉状态
 	const open = ref(false)
 	const emit = defineEmits({ successful: null })
@@ -42,6 +38,19 @@
 	const formData = ref({})
 	const submitLoading = ref(false)
 
+	//设置表单样式
+	const labelCol = ref({ span: 4})
+	const wrapperCol = ref({ span: 16})
+
+	// 当前时间
+	const nowTime = ref(new Date())
+	// 禁用时间范围
+	const disabledDate = (current) => {
+		return (
+			(current && current < dayjs(nowTime.value).startOf('time'))
+		)
+	}
+
 	// 打开抽屉
 	const onOpen = (record) => {
 		open.value = true
@@ -58,6 +67,9 @@
 	}
 	// 默认要校验的
 	const formRules = {
+		beginTime: [required('请选择提货开始时间')],
+		endTime: [required('请选择提货结束时间')],
+		availableNumber: [required('请输入可预约次数')],
 	}
 	// 验证并提交数据
 	const onSubmit = () => {

+ 17 - 7
snowy-admin-web/src/views/biz/bizloadtime/index.vue

@@ -25,7 +25,7 @@
 					<a-button type="primary" @click="tableRef.refresh()">查询</a-button>
 					<a-button style="margin: 0 8px" @click="reset">重置</a-button>
 					
-					<a-button type="primary" @click="formRef.onOpen()" v-if="hasPerm('bizLoadTimeAdd')">
+					<a-button type="primary" @click="addFormRef.onOpen()" v-if="hasPerm('bizLoadTimeAdd')">
 						<template #icon><plus-outlined /></template>
 						新增
 					</a-button>
@@ -61,22 +61,32 @@
 			</template>
 		</s-table>
 	</a-card>
-	<Form ref="formRef" @successful="tableRef.refresh()" />
+
+	<AddForm ref="addFormRef" @successful="tableRef.refresh()" />
+	<EditForm ref="editFormRef" @successful="tableRef.refresh()" />
 	<AlreadyForm ref="alreadyFormRef" @successful="tableRef.refresh()" />
 </template>
 
 <script setup name="bizloadtime">
 	import { cloneDeep } from 'lodash-es'
-	import Form from './form.vue'
+	import AddForm from './addForm.vue'
+	import EditForm from './editForm.vue'
 	import AlreadyForm from './alreadyForm.vue'
 	import bizLoadTimeApi from '@/api/biz/bizLoadTimeApi'
+	import {ExclamationCircleOutlined} from '@ant-design/icons-vue';
+	import {Modal} from 'ant-design-vue';
+	import {createVNode} from 'vue';
 
+	const submitLoading = ref(false)
 	const searchFormState = ref({})
 	const searchFormRef = ref()
+	const toolConfig = { refresh: true, height: true, columnSetting: true, striped: false }
+
 	const tableRef = ref()
-	const formRef = ref()
+	const addFormRef = ref()
+	const editFormRef = ref()
 	const alreadyFormRef = ref()
-	const toolConfig = { refresh: true, height: true, columnSetting: true, striped: false }
+	
 	const columns = [
 		{
 			title: '序号',
@@ -155,8 +165,8 @@
 					}
 				]
 
-				customerApi
-					.customerDelete(params)
+				bizLoadTimeApi
+					.bizLoadTimeDelete(params)
 					.then(() => {
 						tableRef.value.refresh(true)
 					})