|
|
|
@ -85,10 +85,14 @@
|
|
|
|
|
<el-button type="primary" icon="Printer" @click="searchReset()" |
|
|
|
|
>装载卸车清单(财务)</el-button |
|
|
|
|
> |
|
|
|
|
<el-button type="primary" icon="Van" @click="searchReset()">发 车</el-button> |
|
|
|
|
<el-button type="primary" icon="Delete" @click="searchReset()">取消发车</el-button> |
|
|
|
|
<el-button type="primary" icon="Delete" @click="searchReset()">取消装车</el-button> |
|
|
|
|
<el-button type="primary" icon="CircleCheck" @click="searchReset()">到 达</el-button> |
|
|
|
|
<el-button type="primary" icon="Van" @click="handleConfirmStartCar">发 车</el-button> |
|
|
|
|
<el-button type="primary" icon="Delete" @click="handleCancelStartCar"> |
|
|
|
|
取消发车 |
|
|
|
|
</el-button> |
|
|
|
|
<!-- 到达 --> |
|
|
|
|
<el-button type="primary" icon="CircleCheck" @click="handleShowConfirm"> |
|
|
|
|
到 达 |
|
|
|
|
</el-button> |
|
|
|
|
<el-button type="primary" icon="Edit" @click="searchReset()">修 改</el-button> |
|
|
|
|
</div> |
|
|
|
|
<!-- 头部右侧按钮模块 --> |
|
|
|
@ -101,40 +105,38 @@
|
|
|
|
|
</el-row> |
|
|
|
|
|
|
|
|
|
<!-- 表格 --> |
|
|
|
|
<el-row> |
|
|
|
|
<!-- 列表模块 --> |
|
|
|
|
<tablecmt |
|
|
|
|
:columnList="details.columnList" |
|
|
|
|
:tableData="data" |
|
|
|
|
:loading="loadingObj.list" |
|
|
|
|
@inputTxt="inputsc" |
|
|
|
|
@timeCheck="timesc" |
|
|
|
|
@btnCheck="btnsc" |
|
|
|
|
@selectCheck="selectsc" |
|
|
|
|
@selection="selectionChange" |
|
|
|
|
> |
|
|
|
|
<template #default="slotProps"> |
|
|
|
|
<template v-if="slotProps.scope.column.label === '批次号'"> |
|
|
|
|
<el-text>123</el-text> |
|
|
|
|
</template> |
|
|
|
|
|
|
|
|
|
<template v-if="slotProps.scope.column.label === '操作'"> |
|
|
|
|
<el-button type="text" @click="handleShowzeroAdditionalRecording(slotProps.scope)"> |
|
|
|
|
删除 |
|
|
|
|
</el-button> |
|
|
|
|
<el-button type="text" @click="handleShowzeroAdditionalRecording(slotProps.scope)"> |
|
|
|
|
文员签收 |
|
|
|
|
</el-button> |
|
|
|
|
<el-button type="text" @click="handleShowzeroAdditionalRecording(slotProps.scope)"> |
|
|
|
|
结算 |
|
|
|
|
</el-button> |
|
|
|
|
<el-button type="text" @click="handleShowTruckLoadingDetails(slotProps.scope)" |
|
|
|
|
>装车明细</el-button |
|
|
|
|
> |
|
|
|
|
</template> |
|
|
|
|
<!-- 列表模块 --> |
|
|
|
|
<tablecmt |
|
|
|
|
:columnList="details.columnList" |
|
|
|
|
:tableData="data" |
|
|
|
|
:loading="loadingObj.list" |
|
|
|
|
@inputTxt="inputsc" |
|
|
|
|
@timeCheck="timesc" |
|
|
|
|
@btnCheck="btnsc" |
|
|
|
|
@selectCheck="selectsc" |
|
|
|
|
@selection="selectionChange" |
|
|
|
|
> |
|
|
|
|
<template #default="slotProps"> |
|
|
|
|
<template v-if="slotProps.scope.column.label === '批次号'"> |
|
|
|
|
<el-text>123</el-text> |
|
|
|
|
</template> |
|
|
|
|
</tablecmt> |
|
|
|
|
</el-row> |
|
|
|
|
|
|
|
|
|
<template v-if="slotProps.scope.column.label === '操作'"> |
|
|
|
|
<el-button type="text" @click="handleShowzeroAdditionalRecording(slotProps.scope)"> |
|
|
|
|
删除 |
|
|
|
|
</el-button> |
|
|
|
|
<el-button type="text" @click="handleShowzeroAdditionalRecording(slotProps.scope)"> |
|
|
|
|
文员签收 |
|
|
|
|
</el-button> |
|
|
|
|
<el-button type="text" @click="handleShowzeroAdditionalRecording(slotProps.scope)"> |
|
|
|
|
结算 |
|
|
|
|
</el-button> |
|
|
|
|
<el-button type="text" @click="handleShowTruckLoadingDetails(slotProps.scope)" |
|
|
|
|
>装车明细</el-button |
|
|
|
|
> |
|
|
|
|
</template> |
|
|
|
|
</template> |
|
|
|
|
</tablecmt> |
|
|
|
|
|
|
|
|
|
<!-- 统计 --> |
|
|
|
|
<el-row> |
|
|
|
@ -152,7 +154,7 @@
|
|
|
|
|
background |
|
|
|
|
@size-change="sizeChange" |
|
|
|
|
@current-change="currentChange" |
|
|
|
|
:current-page="page.currentPage" |
|
|
|
|
:current-page="page.pageNum" |
|
|
|
|
:page-sizes="[30, 50, 80, 120]" |
|
|
|
|
:page-size="page.pageSize" |
|
|
|
|
layout="total, sizes, prev, pager, next, jumper" |
|
|
|
@ -232,7 +234,7 @@
|
|
|
|
|
background |
|
|
|
|
@size-change="sizeChange" |
|
|
|
|
@current-change="currentChange" |
|
|
|
|
:current-page="trickleLoadingPage.currentPage" |
|
|
|
|
:current-page="trickleLoadingPage.pageNum" |
|
|
|
|
:page-sizes="[30, 50, 80, 120]" |
|
|
|
|
:page-size="trickleLoadingPage.pageSize" |
|
|
|
|
layout="total, sizes, prev, pager, next, jumper" |
|
|
|
@ -241,6 +243,44 @@
|
|
|
|
|
</el-pagination> |
|
|
|
|
</el-dialog> |
|
|
|
|
|
|
|
|
|
<!-- 编辑弹窗 --> |
|
|
|
|
<el-dialog |
|
|
|
|
title="确认到达信息" |
|
|
|
|
v-model="details.popUpShow.confirmArriveVisited" |
|
|
|
|
width="50%" |
|
|
|
|
:before-close="beforeClose" |
|
|
|
|
append-to-body |
|
|
|
|
class="confirmArriveVisited" |
|
|
|
|
> |
|
|
|
|
<el-form :inline="false" label-width="100px" :model="query"> |
|
|
|
|
<el-form-item label="到达时间"> |
|
|
|
|
<el-date-picker |
|
|
|
|
v-model="details.form.arriveDateStr" |
|
|
|
|
type="datetime" |
|
|
|
|
placeholder="到达时间" |
|
|
|
|
size="default" |
|
|
|
|
/> |
|
|
|
|
</el-form-item> |
|
|
|
|
|
|
|
|
|
<el-form-item label="备注(非必填)"> |
|
|
|
|
<el-input v-model="details.form.remark" type="textarea" placeholder="备注" size="default" /> |
|
|
|
|
</el-form-item> |
|
|
|
|
</el-form> |
|
|
|
|
<div class="flex-c-c"> |
|
|
|
|
<el-button |
|
|
|
|
@click=" |
|
|
|
|
() => { |
|
|
|
|
details.form = {}; |
|
|
|
|
details.popUpShow.confirmArriveVisited = false; |
|
|
|
|
} |
|
|
|
|
" |
|
|
|
|
> |
|
|
|
|
取消 |
|
|
|
|
</el-button> |
|
|
|
|
<el-button type="primary" icon="Promotion" @click="submitConfirmArrive">提交</el-button> |
|
|
|
|
</div> |
|
|
|
|
</el-dialog> |
|
|
|
|
|
|
|
|
|
<!-- 创建 && 编辑 中转 --> |
|
|
|
|
<el-dialog |
|
|
|
|
title="新增中转" |
|
|
|
@ -449,7 +489,7 @@
|
|
|
|
|
background |
|
|
|
|
@size-change="sizeChange" |
|
|
|
|
@current-change="currentChange" |
|
|
|
|
:current-page="zeroAdditionalRecordingInfo.oldPage.currentPage" |
|
|
|
|
:current-page="zeroAdditionalRecordingInfo.oldPage.pageNum" |
|
|
|
|
:page-sizes="[30, 50, 80, 120]" |
|
|
|
|
:page-size="zeroAdditionalRecordingInfo.oldPage.pageSize" |
|
|
|
|
layout="total, sizes, prev, pager, next, jumper" |
|
|
|
@ -553,6 +593,13 @@ import {
|
|
|
|
|
oldColumnList, |
|
|
|
|
newColumnList, |
|
|
|
|
} from '@/option/distribution/TripartiteTransfer'; |
|
|
|
|
import { |
|
|
|
|
postArriveCars, |
|
|
|
|
postTripartiteTransferPageList, |
|
|
|
|
postStartCars, |
|
|
|
|
postCancelStartCars, |
|
|
|
|
} from '@/api/distribution/TripartiteTransfer.js'; |
|
|
|
|
import { ElMessage, ElMessageBox } from 'element-plus'; |
|
|
|
|
import { useRouter } from 'vue-router'; |
|
|
|
|
|
|
|
|
|
// 获取路由实例 |
|
|
|
@ -606,7 +653,7 @@ const details = reactive<any>({
|
|
|
|
|
/** 调度池 */ |
|
|
|
|
newColumnList, |
|
|
|
|
/** 列表数据 */ |
|
|
|
|
data: [{}], |
|
|
|
|
data: [], |
|
|
|
|
newData: [], |
|
|
|
|
oldData: [], |
|
|
|
|
/** 页面loading */ |
|
|
|
@ -621,13 +668,13 @@ const details = reactive<any>({
|
|
|
|
|
drawerShow: false, |
|
|
|
|
/** 分页参数 */ |
|
|
|
|
page: { |
|
|
|
|
currentPage: 1, |
|
|
|
|
pageNum: 1, |
|
|
|
|
pageSize: 30, |
|
|
|
|
total: 0, |
|
|
|
|
}, |
|
|
|
|
/** 装车明细分页参数 */ |
|
|
|
|
trickleLoadingPage: { |
|
|
|
|
currentPage: 1, |
|
|
|
|
pageNum: 1, |
|
|
|
|
pageSize: 30, |
|
|
|
|
total: 0, |
|
|
|
|
}, |
|
|
|
@ -637,6 +684,8 @@ const details = reactive<any>({
|
|
|
|
|
truckLoadingDetailVisited: false, |
|
|
|
|
/** 零担补录 */ |
|
|
|
|
transferVisited: false, |
|
|
|
|
/** 到达确认 */ |
|
|
|
|
confirmArriveVisited: false, |
|
|
|
|
}, |
|
|
|
|
/** 列表Dom节点 */ |
|
|
|
|
listNode: '', |
|
|
|
@ -645,7 +694,7 @@ const details = reactive<any>({
|
|
|
|
|
zeroAdditionalRecordingInfo: { |
|
|
|
|
oldPage: { |
|
|
|
|
pageSize: 30, |
|
|
|
|
currentPage: 1, |
|
|
|
|
pageNum: 1, |
|
|
|
|
total: 0, |
|
|
|
|
}, |
|
|
|
|
}, |
|
|
|
@ -682,7 +731,25 @@ onMounted(() => {
|
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
/** 请求页面数据 */ |
|
|
|
|
const onLoad = (page: any) => {}; |
|
|
|
|
const onLoad = async (params = {}) => { |
|
|
|
|
try { |
|
|
|
|
// 开启loading |
|
|
|
|
details.loadingObj.list = true; |
|
|
|
|
|
|
|
|
|
// 请求页面数据 |
|
|
|
|
const res = await postTripartiteTransferPageList(details.page, { ...details.query, ...params }); |
|
|
|
|
const { code, data } = res.data; |
|
|
|
|
if (code !== 200) return; |
|
|
|
|
details.data = data.records; |
|
|
|
|
details.page.total = data.total; |
|
|
|
|
} catch (error) { |
|
|
|
|
console.log('error :>> ', error); |
|
|
|
|
} finally { |
|
|
|
|
details.loadingObj.list = false; |
|
|
|
|
} |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
onLoad(); |
|
|
|
|
|
|
|
|
|
/** 搜索 */ |
|
|
|
|
const searchChange = () => { |
|
|
|
@ -693,7 +760,7 @@ const searchChange = () => {
|
|
|
|
|
const searchReset = () => { |
|
|
|
|
details.query = {}; |
|
|
|
|
details.stockupDate = []; |
|
|
|
|
details.page.currentPage = 1; |
|
|
|
|
details.page.pageNum = 1; |
|
|
|
|
onLoad(details.page); |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
@ -769,6 +836,7 @@ const selectsc = (index, row) => {
|
|
|
|
|
|
|
|
|
|
/** 表格表头复选框选择 */ |
|
|
|
|
const selectionChange = (list: any) => { |
|
|
|
|
console.log('list :>> ', list); |
|
|
|
|
details.selectionList = list; |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
@ -864,6 +932,10 @@ const handleShowzeroAdditionalRecording = ({ row }) => {
|
|
|
|
|
|
|
|
|
|
/** 新增中转 */ |
|
|
|
|
const addTransfer = async () => { |
|
|
|
|
$router.push({ |
|
|
|
|
path: '/distribution/artery/addTripartiteTransfer', |
|
|
|
|
name: '新增中转', |
|
|
|
|
}); |
|
|
|
|
return null; |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
@ -888,13 +960,13 @@ const handleShowTransfer = async (_type: string) => {
|
|
|
|
|
default: |
|
|
|
|
break; |
|
|
|
|
} |
|
|
|
|
details.popUpShow.transferVisited = true; |
|
|
|
|
// details.popUpShow.transferVisited = true; |
|
|
|
|
|
|
|
|
|
nextTick(() => { |
|
|
|
|
// 获取弹窗内表格元素节点, 并设置高度 |
|
|
|
|
const _nodeList = document.querySelectorAll('.transferPopUp .maboxhi'); |
|
|
|
|
_nodeList.forEach(val => (val.style.height = '300px')); |
|
|
|
|
}); |
|
|
|
|
// nextTick(() => { |
|
|
|
|
// // 获取弹窗内表格元素节点, 并设置高度 |
|
|
|
|
// const _nodeList = document.querySelectorAll('.transferPopUp .maboxhi'); |
|
|
|
|
// _nodeList.forEach(val => (val.style.height = '300px')); |
|
|
|
|
// }); |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
/** 添加运单 */ |
|
|
|
@ -909,6 +981,117 @@ const handleRemoveWaybill = () => {
|
|
|
|
|
// this.addInfo.newData = [...this.addInfo.newData, ...this.addInfo.oldSelectionList]; |
|
|
|
|
// this.addInfo.haveIds = this.addInfo.map(val => val.id); |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
/** 开启到达弹窗 */ |
|
|
|
|
const handleShowConfirm = () => { |
|
|
|
|
if (details.selectionList.length === 0) { |
|
|
|
|
return ElMessage({ |
|
|
|
|
message: '请选择到达数据', |
|
|
|
|
type: 'warning', |
|
|
|
|
}); |
|
|
|
|
} else if (details.selectionList.length !== 1) { |
|
|
|
|
return ElMessage({ |
|
|
|
|
message: '仅支持单条数据操作', |
|
|
|
|
type: 'warning', |
|
|
|
|
}); |
|
|
|
|
} |
|
|
|
|
details.popUpShow.confirmArriveVisited = true; |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
/** 提交到达 */ |
|
|
|
|
const submitConfirmArrive = async () => { |
|
|
|
|
console.log('details.selectionList :>> ', details.selectionList); |
|
|
|
|
console.log( |
|
|
|
|
'details.selectionList.map(val => val.id) :>> ', |
|
|
|
|
details.selectionList.map(val => val.id) |
|
|
|
|
); |
|
|
|
|
const submitData = { |
|
|
|
|
loadId: details.selectionList.map(val => val.id).join(','), |
|
|
|
|
...details.form, |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
const res = await postArriveCars(submitData); |
|
|
|
|
const { code } = res.data; |
|
|
|
|
if (code !== 200) { |
|
|
|
|
return; |
|
|
|
|
} |
|
|
|
|
ElMessage({ |
|
|
|
|
type: 'success', |
|
|
|
|
message: '到达成功', |
|
|
|
|
}); |
|
|
|
|
|
|
|
|
|
onLoad(); |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
/** 发车 */ |
|
|
|
|
const handleConfirmStartCar = () => { |
|
|
|
|
if (details.selectionList.length === 0) { |
|
|
|
|
return ElMessage({ |
|
|
|
|
message: '请选择发车数据', |
|
|
|
|
type: 'warning', |
|
|
|
|
}); |
|
|
|
|
} else if (details.selectionList.length !== 1) { |
|
|
|
|
return ElMessage({ |
|
|
|
|
message: '仅支持单条数据操作', |
|
|
|
|
type: 'warning', |
|
|
|
|
}); |
|
|
|
|
} |
|
|
|
|
ElMessageBox.confirm('确认发车吗?', 'Warning', { |
|
|
|
|
confirmButtonText: '确认', |
|
|
|
|
cancelButtonText: '取消', |
|
|
|
|
type: 'warning', |
|
|
|
|
}).then(async () => { |
|
|
|
|
const submitData = { |
|
|
|
|
loadId: details.selectionList.map(val => val.id).join(','), |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
const res = await postStartCars(submitData); |
|
|
|
|
const { code } = res.data; |
|
|
|
|
if (code !== 200) { |
|
|
|
|
return; |
|
|
|
|
} |
|
|
|
|
ElMessage({ |
|
|
|
|
type: 'success', |
|
|
|
|
message: '发车成功', |
|
|
|
|
}); |
|
|
|
|
onLoad(); |
|
|
|
|
}); |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
/** 取消发车 */ |
|
|
|
|
const handleCancelStartCar = () => { |
|
|
|
|
if (details.selectionList.length === 0) { |
|
|
|
|
return ElMessage({ |
|
|
|
|
message: '请选择发车数据', |
|
|
|
|
type: 'warning', |
|
|
|
|
}); |
|
|
|
|
} else if (details.selectionList.length !== 1) { |
|
|
|
|
return ElMessage({ |
|
|
|
|
message: '仅支持单条数据操作', |
|
|
|
|
type: 'warning', |
|
|
|
|
}); |
|
|
|
|
} |
|
|
|
|
ElMessageBox.confirm('确认取消发车吗?', 'Warning', { |
|
|
|
|
confirmButtonText: '确认', |
|
|
|
|
cancelButtonText: '取消', |
|
|
|
|
type: 'warning', |
|
|
|
|
}).then(async () => { |
|
|
|
|
const submitData = { |
|
|
|
|
loadId: details.selectionList.map(val => val.id).join(','), |
|
|
|
|
}; |
|
|
|
|
|
|
|
|
|
const res = await postCancelStartCars(submitData); |
|
|
|
|
const { code } = res.data; |
|
|
|
|
if (code !== 200) { |
|
|
|
|
return; |
|
|
|
|
} |
|
|
|
|
ElMessage({ |
|
|
|
|
type: 'success', |
|
|
|
|
message: '取消发车成功', |
|
|
|
|
}); |
|
|
|
|
onLoad(); |
|
|
|
|
}); |
|
|
|
|
}; |
|
|
|
|
</script> |
|
|
|
|
|
|
|
|
|
<style scoped lang="scss"> |
|
|
|
|