refactor(biz): 优化销售订单和出库单功能

This commit is contained in:
zxy 2026-05-15 10:29:37 +08:00
parent 281bedbaa5
commit 14b19dc223
8 changed files with 294 additions and 155 deletions

View File

@ -7,9 +7,11 @@ import com.ningxia.yunxi.chemmes.framework.common.pojo.PageResult;
import com.ningxia.yunxi.chemmes.framework.common.util.object.BeanUtils;
import com.ningxia.yunxi.chemmes.framework.excel.core.util.ExcelUtils;
import com.ningxia.yunxi.chemmes.framework.operatelog.core.annotations.OperateLog;
import com.ningxia.yunxi.chemmes.module.biz.controller.admin.order.vo.*;
import com.ningxia.yunxi.chemmes.module.biz.controller.admin.order.vo.OrderItemWithOrderRespVO;
import com.ningxia.yunxi.chemmes.module.biz.controller.admin.order.vo.OrderPageReqVO;
import com.ningxia.yunxi.chemmes.module.biz.controller.admin.order.vo.OrderRespVO;
import com.ningxia.yunxi.chemmes.module.biz.controller.admin.order.vo.OrderSaveReqVO;
import com.ningxia.yunxi.chemmes.module.biz.dal.dataobject.order.OrderDO;
import com.ningxia.yunxi.chemmes.module.biz.dal.dataobject.orderitem.OrderItemDO;
import com.ningxia.yunxi.chemmes.module.biz.service.order.OrderService;
import com.ningxia.yunxi.chemmes.module.biz.service.orderitem.OrderItemService;
import com.ningxia.yunxi.chemmes.module.system.dal.dataobject.user.AdminUserDO;
@ -105,6 +107,7 @@ public class TsoOrderController {
}
return success(respPageResult);
}
// 分页查询子表关联主表
@GetMapping("/page-item")
@Operation(summary = "获得销售订单子项分页(关联主表)")

View File

@ -2,6 +2,7 @@ package com.ningxia.yunxi.chemmes.module.biz.controller.admin.order.vo;
import com.alibaba.excel.annotation.ExcelIgnoreUnannotated;
import com.alibaba.excel.annotation.ExcelProperty;
import com.fasterxml.jackson.annotation.JsonFormat;
import io.swagger.v3.oas.annotations.media.Schema;
import lombok.Data;
@ -15,7 +16,7 @@ import java.time.LocalDateTime;
public class OrderItemWithOrderRespVO {
// ==================== 子表字段 (tso_order_item) ====================
@Schema(description = "子表自增字段", requiredMode = Schema.RequiredMode.REQUIRED, example = "26357")
@ExcelProperty("子表ID")
private Integer itemId;
@ -84,6 +85,7 @@ public class OrderItemWithOrderRespVO {
@Schema(description = "下单日期")
@ExcelProperty("下单日期")
@JsonFormat(pattern = "yyyy-MM-dd")
private LocalDate ordDate;
@Schema(description = "客户id", example = "23476")
@ -128,6 +130,7 @@ public class OrderItemWithOrderRespVO {
@Schema(description = "要求交货日期")
@ExcelProperty("要求交货日期")
@JsonFormat(pattern = "yyyy-MM-dd")
private LocalDate reqDeliveryDate;
@Schema(description = "是否急单(0 是 1 否)")
@ -164,6 +167,7 @@ public class OrderItemWithOrderRespVO {
@Schema(description = "审核时间")
@ExcelProperty("审核时间")
@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")
private LocalDateTime auditTime;
@Schema(description = "附件信息")

View File

@ -251,13 +251,6 @@ export enum DICT_TYPE {
KEEP_TYPE='keep_type', // 保管类型
KEEP_MARK='keep_mark', // 保管标识
PLAN_STATUS='plan_status', // 计划状态
CHECK_STATUS='check_status', // 原材料单据状态
CHECK_RESULT='check_result', // 原材料检验结果
BILL_TYPE='bill_type', // 采购订单单据类型
STOCK_OUT_TYPE='stock_out_type', // 出库类型
STOCK_OUT_STATUS='stock_out_status', // 出库状态
DELIVERY_METHOD='delivery_method', // 配送方式
BILL_STATUS='bill_status', // 单据状态

View File

@ -28,64 +28,83 @@
<!-- 订单列表 -->
<el-table
ref="orderTableRef"
v-loading="loading"
:data="orderList"
:show-overflow-tooltip="true"
row-key="id"
row-key="uniqueId"
:tree-props="{ children: 'items', hasChildren: 'hasChildren' }"
@row-dblclick="handleRowDoubleClick"
@row-click="handleRowClick"
highlight-current-row
:height="400"
border
>
<el-table-column type="radio" width="50px" />
<el-table-column label="序号" type="index" width="60px" />
<el-table-column label="" width="50px" align="center">
<template #default="scope">
<!-- 只有子行显示单选按钮 -->
<div
v-if="!scope.row.hasChildren"
class="radio-btn"
:class="{ checked: selectedId === scope.row.uniqueId }"
@click.stop="handleSelect(scope.row)"
>
<span v-if="selectedId === scope.row.uniqueId" class="radio-inner"></span>
</div>
</template>
</el-table-column>
<el-table-column label="序号" type="index" width="60px" align="center" />
<el-table-column label="订单号" align="center" prop="saleOrdNo" width="130px" />
<el-table-column label="发货状态" align="center" prop="deliveryStatus" width="100px">
<template #default="scope">
<dict-tag :type="DICT_TYPE.SHIPPING_STATUS" :value="scope.row.deliveryStatus" />
</template>
</el-table-column>
<el-table-column label="订单日期" align="center" prop="ordDate" width="100px" />
<el-table-column label="客户名称" align="center" prop="custName" width="200px" />
<el-table-column label="订单日期" align="center" prop="ordDate" width="110px" />
<el-table-column label="客户名称" align="center" prop="custName" width="220px" />
<el-table-column label="订单状态" align="center" prop="ordStatus" width="100px">
<template #default="scope">
<dict-tag :type="DICT_TYPE.ORDER_STATUS" :value="scope.row.ordStatus" />
</template>
</el-table-column>
<el-table-column label="交货日期" align="center" prop="reqDeliveryDate" width="100px" />
<el-table-column label="交货日期" align="center" prop="reqDeliveryDate" width="110px" />
<el-table-column label="产品名称" align="center" prop="materialName" width="180px" />
<el-table-column label="规格型号" align="center" prop="spec" width="110px" />
<el-table-column label="订单数量" align="center" prop="ordQty" width="100px" />
<el-table-column label="剩余数量" align="center" prop="remaimQty" width="100px" />
<!-- 单位转换 -->
<el-table-column label="单位" align="center" prop="unit" width="80px" >
<template #default="scope">
<dict-tag :type="DICT_TYPE.UNIT" :value="scope.row.unit" />
<el-table-column label="剩余数量" align="center" width="100px">
<template #default="scope">
{{ (scope.row.ordQty || 0) - (scope.row.deliveriedQty || 0) }}
</template>
</el-table-column>
</el-table-column>
<el-table-column label="单位" align="center" width="80px">
<template #default="scope">
<dict-tag v-if="scope.row.unit" :type="DICT_TYPE.UNIT" :value="scope.row.unit" />
<span v-else>-</span>
</template>
</el-table-column>
</el-table>
<!-- 分页 -->
<Pagination
:total="total"
v-model:page="queryParams.pageNo"
v-model:limit="queryParams.pageSize"
@pagination="getList"
class="mt-4"
/>
<div class="pagination-container">
<Pagination
:total="total"
v-model:page="queryParams.pageNo"
v-model:limit="queryParams.pageSize"
@pagination="getList"
class="mb-4 mt-4"
/>
</div>
<!-- 底部按钮 -->
<template #footer>
<el-button @click="handleSave" type="primary" :disabled="!selectedRow">保存</el-button>
<el-button @click="handleSave" type="primary" :disabled="!selectedId">保存</el-button>
<el-button @click="dialogVisible = false">取消</el-button>
</template>
</Dialog>
</template>
<script setup lang="ts">
import { ref, reactive } from 'vue'
import { ref, reactive, computed, onMounted, watch } from 'vue'
import * as OrderApi from '@/api/biz/tsoorder'
import { DICT_TYPE } from '@/utils/dict'
@ -93,7 +112,8 @@ const dialogVisible = ref(false)
const loading = ref(false)
const orderList = ref([])
const total = ref(0)
const selectedRow = ref(null)
const selectedId = ref('') //
const orderTableRef = ref(null)
const emit = defineEmits(['select', 'close'])
@ -104,25 +124,51 @@ const queryParams = reactive({
saleOrdNo: undefined,
})
//
const selectedRow = computed(() => {
if (!selectedId.value) return null
for (const order of orderList.value) {
if (order.uniqueId === selectedId.value) {
return order
}
if (order.items) {
for (const item of order.items) {
if (item.uniqueId === selectedId.value) {
return item
}
}
}
}
return null
})
/** 获取订单列表 */
const getList = async () => {
loading.value = true
try {
const data = await OrderApi.getOrderList(queryParams)
//
orderList.value = data.list.map(order => {
// 使ID
const requestId = Date.now().toString(36)
orderList.value = data.list.map((order, orderIndex) => {
const items = order.items || []
return {
...order,
uniqueId: `order_${requestId}_${orderIndex}_${order.id}`,
hasChildren: items.length > 0,
items: items.map(item => ({
items: items.map((item, itemIndex) => ({
...item,
remaimQty: item.ordQty - (item.deliveriedQty || 0),
uniqueId: `item_${requestId}_${orderIndex}_${itemIndex}_${item.id || Math.random().toString(36).substr(2, 9)}`,
// = - 0
remaimQty: ((item.ordQty || 0) - (item.deliveriedQty || 0)) || 0,
ordStatus: order.ordStatus,
deliveryStatus: order.deliveryStatus,
ordDate: order.ordDate,
custName: order.custName,
reqDeliveryDate: order.reqDeliveryDate,
saleOrdNo: order.saleOrdNo,
saleOrdId: order.id,
custId: order.custId, // ID
deliveriedQty: item.deliveriedQty || 0,
})),
}
})
@ -135,6 +181,7 @@ const getList = async () => {
/** 搜索 */
const handleQuery = () => {
queryParams.pageNo = 1
selectedId.value = '' //
getList()
}
@ -147,16 +194,23 @@ const resetQuery = () => {
/** 点击行选择 */
const handleRowClick = (row) => {
selectedRow.value = row
//
if (!row.hasChildren && !row.items) {
selectedId.value = row.uniqueId
}
}
/** 点击单选按钮 */
const handleSelect = (row) => {
selectedId.value = row.uniqueId
}
/** 双击行 */
const handleRowDoubleClick = (row) => {
// detailId
if (row.detailId) {
// hasChildrenhasChildrenfalse
if (!row.hasChildren) {
selectedId.value = row.uniqueId
emitSelect(row)
} else if (row.items && row.items.length > 0) {
emitSelect(row.items[0])
}
}
@ -169,33 +223,75 @@ const handleSave = () => {
/** 触发选择事件 */
const emitSelect = (row) => {
emit('select', {
console.log('emitSelect row:', row)
const selectData = {
saleOrdId: row.saleOrdId || row.id,
saleOrdNo: row.saleOrdNo,
custName: row.custName,
custId: row.custId,
ordDate: row.ordDate,
reqDeliveryDate: row.reqDeliveryDate,
materialName: row.materialName,
materialId: row.materialId,
materialCode: row.materialCode,
spec: row.spec,
ordQty: row.ordQty,
remaimQty: row.remaimQty,
remaimQty: ((row.ordQty || 0) - (row.deliveriedQty || 0)) || 0,
deliveriedQty: row.deliveriedQty || 0,
unit: row.unit,
})
}
console.log('emitSelect data:', selectData)
emit('select', selectData)
dialogVisible.value = false
}
/** 打开弹窗 */
const open = () => {
dialogVisible.value = true
selectedRow.value = null
selectedId.value = ''
handleQuery()
}
defineExpose({ open })
/** 监听关闭 */
import { watch } from 'vue'
watch(dialogVisible, (val) => {
if (!val) {
emit('close')
}
})
</script>
<style scoped>
.pagination-container {
margin-bottom: 16px;
}
.radio-btn {
width: 18px;
height: 18px;
border: 2px solid #d9d9d9;
border-radius: 50%;
cursor: pointer;
display: flex;
align-items: center;
justify-content: center;
transition: all 0.2s;
flex-shrink: 0;
}
.radio-btn:hover {
border-color: #409eff;
}
.radio-btn.checked {
border-color: #409eff;
background-color: #409eff;
}
.radio-inner {
width: 8px;
height: 8px;
border-radius: 50%;
background-color: #fff;
}
</style>

View File

@ -11,35 +11,20 @@
<el-card title="基础信息" class="mb-4">
<el-row :gutter="20">
<el-col :span="6">
<el-form-item label="*销售订单" prop="saleOrdId">
<el-select
v-model="formData.saleOrdId"
filterable
<el-form-item label="销售订单" prop="saleOrdId">
<el-input
v-model="formData.saleOrdNo"
placeholder="请选择"
@change="handleSaleOrderChange"
disabled
>
<el-option
v-for="order in saleOrderOptions"
:key="order.id"
:label="order.saleOrdNo"
:value="order.id"
/>
</el-select>
<el-button
v-if="formType === 'create'"
type="text"
readonly
@click="openOrderSelect"
class="ml-2"
>
选择订单
</el-button>
class="cursor-pointer"
/>
</el-form-item>
</el-col>
<el-col :span="6">
<el-form-item label="*单据日期" prop="deliveryDate">
<el-form-item label="单据日期" prop="ordDate">
<el-date-picker
v-model="formData.deliveryDate"
v-model="formData.ordDate"
type="date"
value-format="YYYY-MM-DD"
format="YYYY-MM-DD"
@ -48,7 +33,7 @@
</el-form-item>
</el-col>
<el-col :span="6">
<el-form-item label="*单据状态" prop="deliveryStatus">
<el-form-item label="单据状态" prop="deliveryStatus">
<el-select v-model="formData.deliveryStatus" disabled>
<el-option label="已创建" value="1" />
<el-option label="已确认" value="2" />
@ -66,40 +51,46 @@
</el-row>
<el-row :gutter="20" class="mt-4">
<el-col :span="8">
<el-form-item label="*客户名称" prop="custName">
<el-input v-model="formData.custName" placeholder="请输入客户名称" readonly />
<el-form-item label="客户名称" prop="custName">
<el-input v-model="formData.custName" placeholder="请输入客户名称" disabled />
</el-form-item>
</el-col>
<el-col :span="8">
<el-form-item label="*产品名称" prop="materialName">
<el-input v-model="formData.materialName" placeholder="请输入产品名称" readonly />
<el-form-item label="产品名称" prop="materialName">
<el-input v-model="formData.materialName" placeholder="请输入产品名称" disabled />
</el-form-item>
</el-col>
<el-col :span="8">
<el-form-item label="*规格型号" prop="spec">
<el-input v-model="formData.spec" placeholder="请输入规格型号" readonly />
<el-form-item label="规格型号" prop="spec">
<el-input v-model="formData.spec" placeholder="请输入规格型号" disabled />
</el-form-item>
</el-col>
</el-row>
<el-row :gutter="20" class="mt-4">
<el-col :span="6">
<el-form-item label="*出库单号" prop="saleDeliveryNo">
<el-input v-model="formData.saleDeliveryNo" placeholder="自动生成" readonly />
<el-form-item label="出库单号" prop="saleDeliveryNo">
<el-input v-model="formData.saleDeliveryNo" placeholder="自动生成" disabled />
</el-form-item>
</el-col>
<el-col :span="6">
<el-form-item label="*订单数量" prop="ordQty">
<el-input v-model="formData.ordQty" placeholder="请输入订单数量" readonly />
<el-form-item label="订单数量" prop="ordQty">
<el-input v-model="formData.ordQty" placeholder="请输入订单数量" disabled />
</el-form-item>
</el-col>
<el-col :span="6">
<el-form-item label="*剩余数量" prop="remaimQty">
<el-input v-model="formData.remaimQty" placeholder="请输入剩余数量" readonly />
<el-form-item label="剩余数量" prop="remaimQty">
<el-input v-model="formData.remaimQty" placeholder="请输入剩余数量" disabled />
</el-form-item>
</el-col>
<el-col :span="6">
<el-form-item label="*发货数量" prop="deliveriedQty">
<el-input v-model="formData.deliveriedQty" placeholder="请输入" />
<el-form-item label="发货数量" prop="deliveriedQty">
<el-input
v-model="formData.deliveriedQty"
placeholder="请输入发货数量"
type="number"
:min="0"
:max="formData.remaimQty || 0"
/>
</el-form-item>
</el-col>
</el-row>
@ -122,38 +113,17 @@
<el-row :gutter="20">
<el-col :span="8">
<el-form-item label="联系人" prop="contact">
<el-select v-model="formData.contact" placeholder="请选择">
<el-option
v-for="item in contactOptions"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
<el-input v-model="formData.contact" placeholder="请输入联系人" />
</el-form-item>
</el-col>
<el-col :span="8">
<el-form-item label="联系电话" prop="conPhone">
<el-select v-model="formData.conPhone" placeholder="请选择">
<el-option
v-for="item in phoneOptions"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
<el-input v-model="formData.conPhone" placeholder="请输入联系电话" />
</el-form-item>
</el-col>
<el-col :span="8">
<el-form-item label="联系地址" prop="conAddress">
<el-select v-model="formData.conAddress" placeholder="请选择">
<el-option
v-for="item in addressOptions"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
<el-input v-model="formData.conAddress" placeholder="请输入联系地址" />
</el-form-item>
</el-col>
</el-row>
@ -165,7 +135,7 @@
<span></span>
<el-button type="primary" plain @click="addProductItem">新增</el-button>
</div>
<el-table :data="productList" border>
<el-table :data="productList" show-summary border :summary-method="getSummary">
<el-table-column label="序号" type="index" width="60px" />
<el-table-column label="仓库(*)" prop="warehouse" width="100px">
<template #default="scope">
@ -197,12 +167,12 @@
<el-input v-model="scope.row.bagSpec" placeholder="手动录入" />
</template>
</el-table-column>
<el-table-column label="发货袋数(*)" prop="deliveriedBag" width="100px">
<el-table-column label="发货袋数(*)" prop="deliveriedBag" width="120px">
<template #default="scope">
<el-input v-model="scope.row.deliveriedBag" placeholder="请输入" />
</template>
</el-table-column>
<el-table-column label="发货数量(*)" prop="deliveriedQty" width="100px">
<el-table-column label="发货数量(*)" prop="deliveriedQty" width="120px">
<template #default="scope">
<el-input v-model="scope.row.deliveriedQty" placeholder="请输入" />
</template>
@ -224,12 +194,6 @@
</template>
</el-table-column>
</el-table>
<!-- 合计行 -->
<div class="mt-2 flex justify-end">
<span class="font-bold">合计: </span>
<span>发货袋数: {{ totalBag }}</span>
<span class="ml-4">发货数量: {{ totalQty }}</span>
</div>
</el-card>
</el-form>
<template #footer>
@ -247,6 +211,7 @@
import { ref, reactive, computed } from 'vue'
import * as SaleDeliveryApi from '@/api/biz/saledelivery'
import * as OrderApi from '@/api/biz/tsoorder'
import * as CustomerApi from '@/api/biz/customer'
import { watch } from 'vue'
import OrderSelectDialog from './OrderSelectDialog.vue'
@ -264,23 +229,6 @@ const saleOrderOptions = ref([])
//
const orderSelectRef = ref()
//
const contactOptions = ref([
{ label: '联系人1', value: '联系人1' },
{ label: '联系人2', value: '联系人2' },
])
//
const phoneOptions = ref([
{ label: '13800138001', value: '13800138001' },
{ label: '13800138002', value: '13800138002' },
])
//
const addressOptions = ref([
{ label: '地址1', value: '地址1' },
{ label: '地址2', value: '地址2' },
])
//
const getToday = () => {
@ -297,6 +245,7 @@ const formData = reactive({
deliveryDate: getToday(),
deliveryStatus: '1',
deliveryType: undefined,
ordDate: undefined,
custId: undefined,
custName: undefined,
contact: undefined,
@ -341,6 +290,26 @@ const totalQty = computed(() => {
return productList.value.reduce((sum, item) => sum + (parseInt(item.deliveriedQty) || 0), 0)
})
/** 表格合计方法 */
const getSummary = (param: any) => {
const { columns, data } = param
const sums: any[] = []
columns.forEach((column: any, index: number) => {
if (index === 0) {
sums[index] = '合计'
} else if (column.prop === 'deliveriedBag') {
const total = data.reduce((sum: number, item: any) => sum + (parseInt(item.deliveriedBag) || 0), 0)
sums[index] = total
} else if (column.prop === 'deliveriedQty') {
const total = data.reduce((sum: number, item: any) => sum + (parseInt(item.deliveriedQty) || 0), 0)
sums[index] = total
} else {
sums[index] = ''
}
})
return sums
}
//
watch(dialogVisible, (val) => {
if (!val) {
@ -352,7 +321,19 @@ const formRules = reactive({
saleOrdId: [{ required: true, message: '销售订单不能为空', trigger: 'change' }],
deliveryDate: [{ required: true, message: '单据日期不能为空', trigger: 'change' }],
deliveryStatus: [{ required: true, message: '单据状态不能为空', trigger: 'change' }],
deliveriedQty: [{ required: true, message: '发货数量不能为空', trigger: 'change' }],
deliveriedQty: [
{ required: true, message: '发货数量不能为空', trigger: 'change' },
{
validator: (rule, value, callback) => {
if (value && formData.remaimQty !== undefined && Number(value) > Number(formData.remaimQty)) {
callback(new Error(`发货数量不能大于剩余数量(${formData.remaimQty})`))
} else {
callback()
}
},
trigger: ['change', 'blur']
}
],
})
const formRef = ref()
@ -415,22 +396,59 @@ const handleSaleOrderChange = async (value: number) => {
}
}
//
let isOpeningOrderSelect = false
/** 打开订单选择弹窗 */
const openOrderSelect = () => {
orderSelectRef.value.open()
if (isOpeningOrderSelect) return
isOpeningOrderSelect = true
try {
orderSelectRef.value.open()
} finally {
setTimeout(() => {
isOpeningOrderSelect = false
}, 300)
}
}
/** 处理订单选择 */
const handleOrderSelect = (data: any) => {
const handleOrderSelect = async (data: any) => {
console.log('handleOrderSelect data:', data)
formData.saleOrdId = data.saleOrdId
formData.saleOrdNo = data.saleOrdNo
formData.custId = data.custId
formData.custName = data.custName
formData.materialName = data.materialName
formData.materialId = data.materialId
formData.materialCode = data.materialCode
formData.spec = data.spec
formData.ordQty = data.ordQty
formData.remaimQty = data.remaimQty
formData.deliveriedQty = data.remaimQty
formData.unit = data.unit
//
if (data.ordDate) {
// YYYY-MM-DD
const ordDateStr = String(data.ordDate).trim()
if (/^\d{4}-\d{2}-\d{2}$/.test(ordDateStr)) {
formData.ordDate = ordDateStr
} else {
try {
const date = new Date(data.ordDate)
if (!isNaN(date.getTime())) {
formData.ordDate = date.toISOString().split('T')[0]
}
} catch (e) {
console.warn('日期转换失败:', e)
}
}
} else {
//
formData.ordDate = null
}
console.log('formData after set:', formData)
// 便
if (!saleOrderOptions.value.find(item => item.id === data.saleOrdId)) {
@ -442,8 +460,29 @@ const handleOrderSelect = (data: any) => {
spec: data.spec,
ordQty: data.ordQty,
remaimQty: data.remaimQty,
deliveriedQty: data.deliveriedQty,
})
}
// ID
if (data.custId) {
await loadCustomerContact(data.custId)
}
}
/** 根据客户ID查询客户联系人信息 */
const loadCustomerContact = async (custId: number) => {
try {
const customer = await CustomerApi.getCustomer(custId)
if (customer) {
// 使contact1使contact2
formData.contact = customer.contact1 || customer.contact2
formData.conPhone = customer.conPhone1 || customer.conPhone2
formData.conAddress = customer.conAddress1 || customer.conAddress2
}
} catch (error) {
console.error('查询客户联系人信息失败', error)
}
}
/** 添加产品项 */
@ -551,6 +590,7 @@ const resetForm = () => {
ordQty: undefined,
remaimQty: undefined,
deliveriedQty: undefined,
ordDate: null,
})
productList.value = [{

View File

@ -77,7 +77,7 @@
<el-table-column type="selection" width="55px" />
<el-table-column label="序号" align="center" type="index" width="60px"/>
<el-table-column label="出库单号" align="center" prop="saleDeliveryNo" width="140px" />
<el-table-column label="单据日期" align="center" prop="deliveryDate" width="120px" />
<el-table-column label="单据日期" align="center" prop="ordDate" width="120px" />
<el-table-column label="客户名称" align="center" prop="custName" width="120px" />
<el-table-column label="产品名称" align="center" prop="materialName" width="120px" />
<el-table-column label="产品规格" align="center" prop="spec" width="120px" />

View File

@ -260,8 +260,8 @@
</el-select>
</template>
</el-table-column>
<el-table-column label="发货数量(*)" align="center" prop="deliveriedQty" />
<el-table-column label="已转生成数量(*)" align="center" prop="produceQty" />
<el-table-column label="发货数量" align="center" prop="deliveriedQty" />
<el-table-column label="已转生成数量" align="center" prop="produceQty" />
<el-table-column label="备注" align="center" prop="remark">
<template #default="scope">
<el-input v-model="scope.row.remark" placeholder="请输入" />
@ -286,6 +286,7 @@
:headers="uploadHeaders"
:auto-upload="true"
:limit="10"
:show-file-list="false"
:on-success="handleUploadSuccess"
:on-error="handleUploadError"
:on-remove="handleRemoveFile"
@ -311,10 +312,10 @@
size="small"
class="mt-20px"
>
<el-table-column type="index" label="序号" width="80" align="center" />
<el-table-column type="index" label="序号" width="80px" align="center" />
<el-table-column prop="name" label="文件名称" align="center" />
<el-table-column prop="uploadTime" label="上传时间" width="100" align="center" />
<el-table-column label="操作" width="80" align="center">
<el-table-column prop="uploadTime" label="上传时间" width="180px" align="center" />
<el-table-column label="操作" width="80px" align="center">
<template #default="scope">
<el-button
type="text"
@ -333,7 +334,7 @@
<!-- 底部按钮区域 -->
<div class="form-footer">
<el-button @click="submitForm" type="primary" :disabled="formLoading">保存</el-button>
<el-button @click="submitAudit" type="success" :disabled="formLoading">送审</el-button>
<el-button @click="submitAudit" type="success" :disabled="formLoading">确认</el-button>
<el-button @click="handleCancel">取消</el-button>
</div>
</div>
@ -418,7 +419,7 @@ const formData = reactive({
saleManName: undefined,
saleDeptId: undefined,
saleDeptName: undefined,
ordType: undefined,
ordType: '2',
paymentTerms: undefined,
taxRate: undefined,
totalAmount: undefined,
@ -720,7 +721,7 @@ const resetForm = () => {
formData.saleManName = undefined
formData.saleDeptId = undefined
formData.saleDeptName = undefined
formData.ordType = undefined
formData.ordType = '2'
formData.paymentTerms = undefined
formData.taxRate = undefined
formData.totalAmount = undefined
@ -912,16 +913,18 @@ const handleUploadSuccess = (response: any, file: any, fileList: any) => {
if (response.code === 0) {
const fileUrl = response.data
//
const startTime = uploadStartTime.value.get(file.name) || Date.now()
const uploadDuration = ((Date.now() - startTime) / 1000).toFixed(2) + 's'
uploadStartTime.value.delete(file.name)
const fileId = fileUrl.split('/').pop() || Date.now().toString()
//
const now = new Date()
const uploadTime = `${now.getFullYear()}-${String(now.getMonth() + 1).padStart(2, '0')}-${String(now.getDate()).padStart(2, '0')} ${String(now.getHours()).padStart(2, '0')}:${String(now.getMinutes()).padStart(2, '0')}:${String(now.getSeconds()).padStart(2, '0')}`
uploadedFiles.value.push({
id: fileId,
name: file.name,
uploadTime: uploadDuration, // "2.35s"
uploadTime: uploadTime, //
url: fileUrl
})
// ...

View File

@ -59,7 +59,7 @@
</el-select>
</el-form-item>
<el-form-item label="是否加急" prop="isUrgent">
<el-select v-model="queryParams.isUrgent" class="!w-240px">
<el-select v-model="queryParams.isUrgent" class="!w-240px" clearable>
<el-option
v-for="dict in getStrDictOptions(DICT_TYPE.SYSTEM_IS_CELL)"
:key="dict.value"
@ -135,12 +135,12 @@
<el-table-column label="包装要求" align="center" prop="packReq" width="180px" />
<el-table-column label="质量要求" align="center" prop="qualityReq" width="180px" />
<el-table-column label="订单状态" prop="ordStatus" width="120px">
<el-table-column label="订单状态" prop="ordStatus" width="120px" fixed="right">
<template #default="scope">
<dict-tag :type="DICT_TYPE.ORDER_STATUS" :value="scope.row.ordStatus" />
</template>
</el-table-column>
<el-table-column label="发货状态" align="center" prop="deliveryStatus" width="110px">
<el-table-column label="发货状态" align="center" prop="deliveryStatus" width="110px" fixed="right">
<template #default="scope">
<dict-tag :type="DICT_TYPE.SHIPPING_STATUS" :value="scope.row.deliveryStatus" />
</template>