军泰伟业
1.仓储物流需要加上库位,库位暂时分为外购、自制、委外三种类型
2.生产订单加上库存数量,方便实时查看
3.产品发货后,若部分产品退回,可修改订单发货数量(减去退回的产品数量),若订单产品全部退回,可对发货的订单进行取消撤回操作
| | |
| | | params: query, |
| | | }); |
| | | } |
| | | |
| | | // 撤销发货 |
| | | export function cancelDelivery(query) { |
| | | return request({ |
| | | url: "/sales/product/cancelDelivery", |
| | | method: "post", |
| | | data: query, |
| | | }); |
| | | } |
| | |
| | | /> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column label="审核状态" prop="status" align="center" width="120"> |
| | | <el-table-column label="状态" prop="status" align="center" width="120"> |
| | | <template #default="scope"> |
| | | <el-tag :type="getApprovalStatusType(scope.row.status)"> |
| | | {{ getApprovalStatusText(scope.row.status) }} |
| | |
| | | link |
| | | type="primary" |
| | | size="small" |
| | | :disabled="(scope.row.waitShippingTotal || 0) <= 0" |
| | | :disabled="(scope.row.waitShippingTotal || 0) <= 0 || isRevoked(scope.row.status)" |
| | | @click="openForm('edit', scope.row)">分批发货</el-button> |
| | | <el-button |
| | | link |
| | |
| | | <div class="summary-value shipped">{{ currentShippingOrder.shippingSuccessTotal || 0 }}</div> |
| | | </div> |
| | | <div class="summary-item"> |
| | | <div class="summary-label">已退货数量</div> |
| | | <div class="summary-value returned">{{ currentShippingOrder.returnedQuantity || 0 }}</div> |
| | | </div> |
| | | <div class="summary-item"> |
| | | <div class="summary-label">待发货数量</div> |
| | | <div class="summary-value waiting">{{ currentShippingOrder.waitShippingTotal || 0 }}</div> |
| | | </div> |
| | |
| | | <span class="info-label">发货数量</span> |
| | | <span class="info-value quantity">{{ record.shippingNum }}</span> |
| | | </div> |
| | | <div class="info-row"> |
| | | <span class="info-label">退货数量</span> |
| | | <span class="info-value returned">{{ record.returnNum || 0 }}</span> |
| | | </div> |
| | | <div class="info-row" v-if="record.type === '货车'"> |
| | | <span class="info-label">车牌号</span> |
| | | <span class="info-value">{{ record.shippingCarNumber || '--' }}</span> |
| | |
| | | preview-teleported |
| | | /> |
| | | </div> |
| | | </div> |
| | | <div class="record-actions" v-if="canRevokeShipping(record)"> |
| | | <el-button |
| | | type="danger" |
| | | size="small" |
| | | @click="handleRevokeShipping(record)"> |
| | | 撤销发货 |
| | | </el-button> |
| | | </div> |
| | | </div> |
| | | </div> |
| | |
| | | return; |
| | | } |
| | | |
| | | if (type === 'edit' && isRevoked(row.status)) { |
| | | proxy.$modal.msgWarning("已撤销状态不能分批发货"); |
| | | return; |
| | | } |
| | | |
| | | dialogMode.value = type === 'edit' ? 'edit' : 'view'; |
| | | currentShippingOrder.value = row; |
| | | showAddForm.value = false; |
| | |
| | | if (!currentShippingOrder.value) return false; |
| | | const waitShipping = currentShippingOrder.value.waitShippingTotal || 0; |
| | | return waitShipping > 0; |
| | | }; |
| | | |
| | | // 是否可以撤销发货 |
| | | const canRevokeShipping = (record) => { |
| | | const shippingNum = record.shippingNum || 0; |
| | | const returnNum = record.returnNum || 0; |
| | | return shippingNum > 0 && returnNum > 0 && shippingNum === returnNum; |
| | | }; |
| | | |
| | | // 撤销发货 |
| | | const handleRevokeShipping = (record) => { |
| | | ElMessageBox.confirm("此操作将撤销该发货记录,是否确认?", "撤销发货", { |
| | | confirmButtonText: "确认", |
| | | cancelButtonText: "取消", |
| | | type: "warning", |
| | | }) |
| | | .then(() => { |
| | | updateShippingInfoDetail({ ...record, status: 3 }).then((res) => { |
| | | proxy.$modal.msgSuccess("撤销成功"); |
| | | loadShippingRecords(currentShippingOrder.value.id); |
| | | getList(); |
| | | }); |
| | | }) |
| | | .catch(() => {}); |
| | | }; |
| | | |
| | | // 提交发货 |
| | |
| | | '审核中': '审核中', |
| | | '审核拒绝': '审核拒绝', |
| | | '审核通过': '审核通过', |
| | | '已撤销': '已撤销', |
| | | '0': '待审核', |
| | | '1': '审核中', |
| | | '2': '审核拒绝', |
| | |
| | | '审核中': 'warning', |
| | | '审核拒绝': 'danger', |
| | | '审核通过': 'success', |
| | | '已撤销': 'warning', |
| | | '0': 'info', |
| | | '1': 'warning', |
| | | '2': 'danger', |
| | |
| | | } |
| | | const statusStr = String(status).trim(); |
| | | return statusStr === '审核中' || statusStr === '1'; |
| | | }; |
| | | |
| | | // 检查状态是否为"已撤销" |
| | | const isRevoked = (status) => { |
| | | if (status === null || status === undefined || status === '') { |
| | | return false; |
| | | } |
| | | if (typeof status === 'number') { |
| | | return status === 3; |
| | | } |
| | | const statusStr = String(status).trim(); |
| | | return statusStr === '已撤销' || statusStr === '3'; |
| | | }; |
| | | |
| | | onMounted(() => { |
| | |
| | | |
| | | &.shipped { |
| | | color: #67C23A; |
| | | } |
| | | |
| | | &.returned { |
| | | color: #F56C6C; |
| | | } |
| | | |
| | | &.waiting { |
| | |
| | | color: #409EFF; |
| | | font-size: 16px; |
| | | } |
| | | |
| | | &.returned { |
| | | font-weight: bold; |
| | | color: #F56C6C; |
| | | font-size: 16px; |
| | | } |
| | | } |
| | | } |
| | | |
| | | .record-actions { |
| | | margin-top: 12px; |
| | | padding-top: 12px; |
| | | border-top: 1px solid #EBEEF5; |
| | | } |
| | | |
| | | .record-images { |
| | | display: flex; |
| | |
| | | <el-option label="待发货" value="待发货"></el-option> |
| | | <el-option label="已发货" value="已发货"></el-option> |
| | | <el-option label="已签收" value="已签收"></el-option> |
| | | <el-option label="已撤销" value="已撤销"></el-option> |
| | | </el-select> |
| | | </el-col> |
| | | <el-col :span="6"> |
| | |
| | | <el-option label="待发货" value="待发货"></el-option> |
| | | <el-option label="已发货" value="已发货"></el-option> |
| | | <el-option label="已签收" value="已签收"></el-option> |
| | | <el-option label="已撤销" value="已撤销"></el-option> |
| | | </el-select> |
| | | </el-form-item> |
| | | </el-col> |
| | |
| | | const statusMap = { |
| | | '待发货': 'warning', |
| | | '已发货': 'primary', |
| | | '已签收': 'success' |
| | | '已签收': 'success', |
| | | '已撤销': 'warning' |
| | | } |
| | | return statusMap[status] || 'info' |
| | | } |
| | |
| | | |
| | | const documentStatusOptions = ref([ |
| | | { label: "待处理", value: 0 }, |
| | | { label: "已处理", value: 1 } |
| | | { label: "已处理", value: 1 }, |
| | | { label: "已撤销", value: 2 } |
| | | ]); |
| | | |
| | | const defaultColumns = [ |
| | |
| | | { name: "编辑", disabled: (row) => row.status !== 0, type: "text", clickFun: (row) => openForm("edit", row) }, |
| | | { name: "退款处理", disabled: (row) => row.status !== 0, type: "text", clickFun: (row) => handleRowHandle(row) }, |
| | | { name: "详情", type: "text", clickFun: (row) => openDetail(row) }, |
| | | { name: "删除", disabled: (row) => row.status !== 0, type: "text", clickFun: (row) => handleRowDelete(row) }, |
| | | { name: "删除", disabled: (row) => row.status === 1 || row.status === 2, type: "text", clickFun: (row) => handleRowDelete(row) }, |
| | | ], |
| | | }, |
| | | ]; |
| | |
| | | const getStatusType = (status) => { |
| | | const statusMap = { |
| | | 0: "warning", |
| | | 1: "success" |
| | | 1: "success", |
| | | 2: "warning" |
| | | }; |
| | | return statusMap[status] || "info"; |
| | | }; |
| | |
| | | const getStatusText = (status) => { |
| | | const statusMap = { |
| | | 0: "待处理", |
| | | 1: "已处理" |
| | | 1: "已处理", |
| | | 2: "已撤销" |
| | | }; |
| | | return statusMap[status] || "未知"; |
| | | }; |
| | |
| | | </el-tag> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column label="快递公司" prop="expressCompany" show-overflow-tooltip /> |
| | | <el-table-column label="快递单号" prop="expressNumber" show-overflow-tooltip /> |
| | | <el-table-column label="发货车牌" minWidth="100px" align="center"> |
| | | <template #default="scope"> |
| | | <div> |
| | | <el-tag type="success" v-if="scope.row.shippingCarNumber">{{ scope.row.shippingCarNumber }}</el-tag> |
| | | <el-tag v-else type="info">-</el-tag> |
| | | </div> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column label="发货日期" |
| | | minWidth="100px" |
| | | align="center"> |
| | | <template #default="scope"> |
| | | <div> |
| | | <div v-if="scope.row.shippingDate">{{ scope.row.shippingDate }}</div> |
| | | <el-tag v-else |
| | | type="info">-</el-tag> |
| | | </div> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column label="已发货数量" prop="shippingNum" align="center" /> |
| | | <el-table-column label="已退货数量" prop="returnNum" align="center" /> |
| | | <el-table-column label="数量" prop="quantity" /> |
| | | <el-table-column label="税率(%)" prop="taxRate" /> |
| | | <el-table-column label="含税单价(元)" prop="taxInclusiveUnitPrice" :formatter="formattedNumber" /> |
| | | <el-table-column label="含税总价(元)" prop="taxInclusiveTotalPrice" :formatter="formattedNumber" /> |
| | | <el-table-column label="不含税总价(元)" prop="taxExclusiveTotalPrice" :formatter="formattedNumber" /> |
| | | <!--操作--> |
| | | <el-table-column width="100" label="操作" align="center" fixed="right"> |
| | | <el-table-column width="150" label="操作" align="center" fixed="right"> |
| | | <template #default="scope"> |
| | | <el-button |
| | | link |
| | |
| | | :disabled="!canShip(scope.row)" |
| | | @click="openDeliveryForm(scope.row)"> |
| | | 发货 |
| | | </el-button> |
| | | <el-button |
| | | link |
| | | type="danger" |
| | | size="small" |
| | | :disabled="!canRevokeShipping(scope.row)" |
| | | @click="handleRevokeShipping(scope.row)"> |
| | | 撤销发货 |
| | | </el-button> |
| | | </template> |
| | | </el-table-column> |
| | |
| | | delLedger, |
| | | addOrUpdateSalesLedgerProduct, |
| | | delProduct, |
| | | delLedgerFile, getProductInventory, |
| | | delLedgerFile, getProductInventory, cancelDelivery, |
| | | } from "@/api/salesManagement/salesLedger.js"; |
| | | import { modelList, productTreeList } from "@/api/basicData/product.js"; |
| | | import useFormData from "@/hooks/useFormData.js"; |
| | |
| | | * @param row 行数据 |
| | | */ |
| | | const getShippingStatusText = (row) => { |
| | | // 如果已发货(有发货日期或车牌号),显示"已发货" |
| | | if (row.shippingDate || row.shippingCarNumber) { |
| | | return '已发货'; |
| | | } |
| | | |
| | | // 获取发货状态字段 |
| | | const status = row.shippingStatus; |
| | | |
| | |
| | | |
| | | // 状态是字符串 |
| | | const statusStr = String(status).trim(); |
| | | |
| | | // 如果状态是"已撤销",直接返回 |
| | | if (statusStr === '已撤销') { |
| | | return '已撤销'; |
| | | } |
| | | |
| | | // 如果已发货(有发货日期或车牌号),显示"已发货" |
| | | if (row.shippingDate || row.shippingCarNumber) { |
| | | return '已发货'; |
| | | } |
| | | |
| | | const statusTextMap = { |
| | | '待发货': '待发货', |
| | | '待审核': '待审核', |
| | |
| | | * @param row 行数据 |
| | | */ |
| | | const getShippingStatusType = (row) => { |
| | | // 如果已发货(有发货日期或车牌号),显示绿色 |
| | | if (row.shippingDate || row.shippingCarNumber) { |
| | | return 'success'; |
| | | } |
| | | |
| | | // 获取发货状态字段 |
| | | const status = row.shippingStatus; |
| | | |
| | |
| | | |
| | | // 状态是字符串 |
| | | const statusStr = String(status).trim(); |
| | | |
| | | // 如果状态是"已撤销",显示橙色 |
| | | if (statusStr === '已撤销') { |
| | | return 'warning'; |
| | | } |
| | | |
| | | // 如果已发货(有发货日期或车牌号),显示绿色 |
| | | if (row.shippingDate || row.shippingCarNumber) { |
| | | return 'success'; |
| | | } |
| | | |
| | | const typeTextMap = { |
| | | '待发货': 'info', |
| | | '待审核': 'info', |
| | | '审核中': 'warning', |
| | | '审核拒绝': 'danger', |
| | | '已撤销': 'danger', |
| | | '已撤销': 'warning', |
| | | '审核通过': 'success', |
| | | '已发货': 'success' |
| | | }; |
| | |
| | | // 获取发货状态 |
| | | const shippingStatus = row.shippingStatus; |
| | | |
| | | // 如果状态为空或未定义,默认为"待发货" |
| | | if (shippingStatus === null || shippingStatus === undefined || shippingStatus === '') { |
| | | return true; |
| | | } |
| | | |
| | | // 状态是字符串 |
| | | const statusStr = String(shippingStatus).trim(); |
| | | |
| | | // 如果状态是"已撤销",允许发货 |
| | | if (statusStr === '已撤销') { |
| | | return true; |
| | | } |
| | | |
| | | // 如果已发货(有发货日期或车牌号),不能再次发货 |
| | | if (row.shippingDate || row.shippingCarNumber) { |
| | | return false; |
| | | } |
| | | |
| | | // 发货状态必须是"待发货"、"审核拒绝"或"已撤销" |
| | | const statusStr = shippingStatus ? String(shippingStatus).trim() : ''; |
| | | return statusStr === '待发货' || statusStr === '审核拒绝' || statusStr === '已撤销'; |
| | | return statusStr === '待发货' || statusStr === '审核拒绝'; |
| | | }; |
| | | |
| | | /** |
| | | * 判断是否可以撤销发货 |
| | | * 只有当发货数量等于退货数量且都不为0时才可以撤销 |
| | | * @param row 行数据 |
| | | */ |
| | | const canRevokeShipping = (row) => { |
| | | const shippingNum = row.shippingNum || 0; |
| | | const returnNum = row.returnNum || 0; |
| | | return shippingNum > 0 && returnNum > 0 && shippingNum === returnNum; |
| | | }; |
| | | |
| | | /** |
| | | * 撤销发货 |
| | | * @param row 行数据 |
| | | */ |
| | | const handleRevokeShipping = (row) => { |
| | | ElMessageBox.confirm("此操作将撤销该发货记录,是否确认?", "撤销发货", { |
| | | confirmButtonText: "确认", |
| | | cancelButtonText: "取消", |
| | | type: "warning", |
| | | }) |
| | | .then(() => { |
| | | cancelDelivery({ id: row.id }).then(() => { |
| | | proxy.$modal.msgSuccess("撤销成功"); |
| | | getList(); |
| | | }); |
| | | }) |
| | | .catch(() => {}); |
| | | }; |
| | | |
| | | /** |