- 在订单编辑、详情和表格中添加合同号字段 - 创建新的OrderTable组件用于订单选择 - 添加发货单与订单的绑定功能 - 在运单详情中显示合同号信息 - 调整表格列宽和字体大小
157 lines
6.2 KiB
Vue
157 lines
6.2 KiB
Vue
<template>
|
||
<div class="app-container">
|
||
<el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="68px">
|
||
<el-form-item label="发货单名称" prop="waybillName">
|
||
<el-input v-model="queryParams.waybillName" placeholder="请输入发货单名称" clearable
|
||
@keyup.enter.native="handleQuery" />
|
||
</el-form-item>
|
||
<el-form-item label="收货单位" prop="consigneeUnit">
|
||
<el-input v-model="queryParams.consigneeUnit" placeholder="请输入收货单位" clearable
|
||
@keyup.enter.native="handleQuery" />
|
||
</el-form-item>
|
||
<el-form-item>
|
||
<el-button type="primary" icon="el-icon-search" size="mini" @click="handleQuery">搜索</el-button>
|
||
<el-button icon="el-icon-refresh" size="mini" @click="resetQuery">重置</el-button>
|
||
<!-- <el-button type="primary" plain icon="el-icon-plus" size="mini" @click="handleAdd" :disabled="!selectedPlan"
|
||
title="请先选择发货计划">新增</el-button> -->
|
||
<el-button type="success" plain icon="el-icon-refresh" size="mini" @click="handleQuery">刷新</el-button>
|
||
<!-- <el-button type="warning" plain icon="el-icon-download" size="mini" @click="handleExport">导出</el-button> -->
|
||
</el-form-item>
|
||
</el-form>
|
||
|
||
<el-table v-loading="loading" border :data="deliveryWaybillList" highlight-current-row>
|
||
<el-table-column label="发货单唯一ID" align="center" prop="waybillId" v-if="false" />
|
||
<el-table-column label="发货单名称" align="center" prop="waybillName" />
|
||
<el-table-column label="车牌" align="center" prop="licensePlate" width="100" />
|
||
<el-table-column label="发货单位" align="center" prop="senderUnit" />
|
||
<el-table-column label="发货时间" align="center" prop="deliveryTime" width="100">
|
||
<template slot-scope="scope">
|
||
<span>{{ parseTime(scope.row.deliveryTime, '{y}-{m}-{d}') }}</span>
|
||
</template>
|
||
</el-table-column>
|
||
<el-table-column label="负责人" align="center" prop="principal" />
|
||
<el-table-column label="负责人电话" align="center" prop="principalPhone" width="100" />
|
||
<el-table-column label="完成状态" align="center" prop="status" width="120">
|
||
<template slot-scope="scope">
|
||
<el-tag size="mini" type="success" v-if="scope.row.status === 1">已发货</el-tag>
|
||
<el-tag size="mini" type="info" v-else>未发货</el-tag>
|
||
<!-- <el-select v-model="scope.row.status" placeholder="请选择完成状态" @change="handleStatusChange(scope.row)">
|
||
<el-option label="已发货" :value="1" />
|
||
<el-option label="未发货" :value="0" />
|
||
</el-select> -->
|
||
</template>
|
||
</el-table-column>
|
||
<el-table-column label="订单合同号" align="center" prop="contractCode" />
|
||
<el-table-column label="操作" align="center" class-name="small-padding fixed-width">
|
||
<template slot-scope="scope">
|
||
<el-button size="mini" type="text" icon="el-icon-paperclip" @click.stop="handleBind(scope.row)">绑定订单</el-button>
|
||
<!-- <el-button size="mini" type="text" icon="el-icon-edit" :disabled="scope.row.status === 1" title="已发货的发货单不能修改"
|
||
@click.stop="handleUpdate(scope.row)">修改</el-button>
|
||
<el-button size="mini" type="text" icon="el-icon-delete" :disabled="scope.row.status === 1"
|
||
title="已发货的发货单不能删除" @click.stop="handleDelete(scope.row)">删除</el-button> -->
|
||
</template>
|
||
</el-table-column>
|
||
</el-table>
|
||
|
||
<pagination v-show="total > 0" :total="total" :page.sync="queryParams.pageNum" :limit.sync="queryParams.pageSize"
|
||
@pagination="getList" />
|
||
|
||
<el-dialog title="选择订单" :visible.sync="dialogVisible" width="80%">
|
||
<order-table ref="orderTable" @row-click="submitBind" />
|
||
</el-dialog>
|
||
</div>
|
||
</template>
|
||
|
||
<script>
|
||
import { listDeliveryWaybill, updateDeliveryWaybill } from "@/api/wms/deliveryWaybill";
|
||
import OrderTable from "../components/OrderTable.vue";
|
||
|
||
export default {
|
||
data() {
|
||
return {
|
||
deliveryWaybillList: [],
|
||
total: 0,
|
||
queryParams: {
|
||
pageNum: 1,
|
||
pageSize: 10,
|
||
waybillName: '',
|
||
consigneeUnit: ''
|
||
},
|
||
dialogVisible: false,
|
||
currentWaybill: {},
|
||
currentWaybillDetails: [],
|
||
loading: false,
|
||
showSearch: true,
|
||
}
|
||
},
|
||
components: {
|
||
OrderTable,
|
||
},
|
||
mounted() {
|
||
this.getList();
|
||
},
|
||
methods: {
|
||
/** 完成状态改变时的处理 */
|
||
handleStatusChange(row) {
|
||
// 确保在更新状态时包含waybillId
|
||
updateDeliveryWaybillStatus({
|
||
waybillId: row.waybillId,
|
||
status: row.status
|
||
}).then(() => {
|
||
this.$modal.msgSuccess("状态更新成功");
|
||
this.getList(); // 刷新列表
|
||
});
|
||
},
|
||
/** 查询发货单列表 */
|
||
getList() {
|
||
this.loading = true;
|
||
// 确保查询参数包含planId
|
||
const params = {
|
||
...this.queryParams,
|
||
// 如果选中了计划,传递planId,否则不传递该参数
|
||
planId: this.selectedPlan ? this.selectedPlan.planId : undefined
|
||
};
|
||
listDeliveryWaybill(params).then(response => {
|
||
this.deliveryWaybillList = response.rows;
|
||
this.total = response.total;
|
||
this.loading = false;
|
||
});
|
||
},
|
||
handleBind(row) {
|
||
this.dialogVisible = true;
|
||
this.currentWaybill = row;
|
||
},
|
||
submitBind(order) {
|
||
this.loading = true;
|
||
this.dialogVisible = false;
|
||
updateDeliveryWaybill({
|
||
...this.currentWaybill,
|
||
orderId: order.orderId,
|
||
}).then(() => {
|
||
this.loading = false;
|
||
this.$modal.msgSuccess("绑定成功");
|
||
this.getList();
|
||
}).catch(() => {
|
||
this.$modal.msgError("绑定失败");
|
||
this.dialogVisible = true;
|
||
});
|
||
},
|
||
/** 搜索按钮操作 */
|
||
handleQuery() {
|
||
this.queryParams.pageNum = 1;
|
||
this.getList();
|
||
},
|
||
/** 重置按钮操作 */
|
||
resetQuery() {
|
||
this.resetForm("queryForm");
|
||
this.handleQuery();
|
||
},
|
||
/** 导出按钮操作 */
|
||
handleExport() {
|
||
this.download('wms/deliveryWaybill/export', {
|
||
...this.queryParams
|
||
}, `deliveryWaybill_${new Date().getTime()}.xlsx`)
|
||
},
|
||
}
|
||
}
|
||
</script> |