pref_mail@163.com 1 year ago
parent
commit
b40f87f9e9
  1. 2
      src/components/tablecmt/tablecmt.vue
  2. 12
      src/option/aftersales/vueTvemp.js
  3. 10
      src/option/distribution/zeroAdditionalRecording.js
  4. 17
      src/router/views/index.js
  5. 110
      src/views/aftersales/aftersalesWorkOrder.vue
  6. 84
      src/views/aftersales/aftersalesWorkOrderAdd.vue
  7. 6
      src/views/aftersales/aftersalesWorkOrderend.vue
  8. 208
      src/views/distribution/artery/zeroAdditionalRecording.vue
  9. 56
      src/views/distribution/deliverylist/distributionDeliveryListedt.vue
  10. 10
      src/views/distribution/inventory/BookingNote.vue
  11. 1539
      src/views/distribution/inventory/addArteryDistrilbutionBillLadingList.vue
  12. 29
      src/views/distribution/inventory/arteryDistrilbutionBillLadingList.vue
  13. 48
      src/views/distribution/signfor/distributionSignforedt.vue
  14. 11
      src/views/distribution/signfor/distributionSignfortreat.vue
  15. 124
      src/views/distribution/turndelivery/deliveryDiscuss.vue
  16. 50
      src/views/warehouse/parcelList/distributionParcelList.vue
  17. 3
      vite.config.js

2
src/components/tablecmt/tablecmt.vue

@ -40,7 +40,7 @@
<template #header>
<!-- <el-text class="mx-1">{{ column.label }}</el-text> -->
<el-input
v-if="column.type == 2"
v-if="column.type == 2 || column.type == 13"
v-model.trim="column.values"
clearable
:placeholder="`请输入${column.label}`"

12
src/option/aftersales/vueTvemp.js

@ -39,7 +39,7 @@ export const columnList = [
{
prop: 'workOrderNumber',
label: '异常工单号',
type: 2,
type: 13,
values: '',
width: '120',
checkarr: [],
@ -743,6 +743,16 @@ export const AppealList = [
sortable: true,
head: false,
},
{
prop: '',
label: '操作',
type: 6,
values: '',
width: '80',
checkarr: [],
fixed: 'right',
sortable: false,
},
]

10
src/option/distribution/zeroAdditionalRecording.js

@ -237,6 +237,16 @@ export const newColumnList = [
fixed: false,
sortable: true,
},
{
prop: 'warehouseName',
label: '计划目的网点',
type: 1,
values: '',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
},
{
prop: 'shipperName',
label: '发货单位',

17
src/router/views/index.js

@ -279,13 +279,14 @@ export default [
redirect: '/distribution/inventory/arteryDistrilbutionBillLadingList',
children: [
{
path: '/distribution/inventory/arteryDistrilbutionBillLadingList',
name: '干线提货管理',
path: '/distribution/inventory/addArteryDistrilbutionBillLadingList',
name: '新增干线提货',
meta: {
data: 'data',
keepAlive: true,
},
component: () =>
import('@/views/distribution/inventory/arteryDistrilbutionBillLadingList.vue'),
import('@/views/distribution/inventory/addArteryDistrilbutionBillLadingList.vue'),
},
{
path: '/distribution/inventory/arteryDistrilbutionBillLadingListDetails',
@ -1211,7 +1212,7 @@ export default [
{
meta: {
i18n: 'dict',
keepAlive:false,
keepAlive: false,
},
path: '/aftersales/aftersalesWorkOrder',
name: '工单',
@ -1244,7 +1245,7 @@ export default [
{
meta: {
i18n: 'dict',
keepAlive:false,
keepAlive: false,
},
path: '/aftersales/aftersalesWorkOrderInfo',
name: '工单详情查看',
@ -1261,7 +1262,7 @@ export default [
{
meta: {
i18n: 'dict',
keepAlive:false,
keepAlive: false,
},
path: '/aftersales/aftersalesWorkOrderend',
name: '工单完结',
@ -1277,7 +1278,7 @@ export default [
{
meta: {
i18n: 'dict',
keepAlive:false,
keepAlive: false,
},
path: '/aftersales/WorkorderTimeout',
name: '工单超时罚款',
@ -1317,7 +1318,7 @@ export default [
},
],
},
{
path: '/aftersales/DataSynchronization',
component: Layout,

110
src/views/aftersales/aftersalesWorkOrder.vue

@ -120,10 +120,10 @@
<!-- 申诉列表展示 -->
<el-tabs
type="border-card"
v-if="details.query.workOrderStatus == 30"
v-if="TabPermissions == 6"
@tab-change="AppealTab"
>
<el-tab-pane label="处理完毕"></el-tab-pane>
<el-tab-pane label="完结"></el-tab-pane>
<el-tab-pane label="申诉列表"></el-tab-pane>
</el-tabs>
<!-- 首页表格 -->
@ -154,9 +154,13 @@
<div class="ElBtnClass">
<div>
<!-- <el-button @click="addingRecord(slotProps.scope)">新增记录</el-button> -->
<el-button v-if="TabPermissions != '4'" @click="view(slotProps.scope)"
<el-button v-if="TabPermissions != '4' && !AppealStatusT" @click="view(slotProps.scope)"
>查看</el-button
>
<!-- AppealStatusT申诉列表状态 -->
<el-button v-if="AppealStatusT"
>待添加</el-button
>
<!-- <el-button @click="ViewEvent(slotProps.scope)">编辑</el-button> -->
<!-- <el-button @click="reply(slotProps.scope)">回复</el-button> -->
<!-- <el-button @click="ViewDelete(slotProps.scope)">删除</el-button> -->
@ -400,10 +404,10 @@
<el-upload
v-model:file-list="AppealAttachment"
list-type="picture-card"
:on-preview="pictureList"
:on-remove="ImgListRemove"
:on-preview="AppealAttachmentpictureList"
:on-remove="AppealAttachmentImgListRemove"
:action="doubledCount"
:on-success="ImgSuccess"
:on-success="AppealAttachmentImgSuccess"
:before-upload="beforeAvatarUpload"
:headers="headers"
multiple
@ -548,7 +552,7 @@ const TransportlossList = ref([
//
]);
const pageSize = ref(30); //
const AppealAttachment=ref('');//
const AppealAttachment = ref([]); //
const total = ref(0); //
const KFinput = ref(''); //
const Appealselection = ref([]); //
@ -1118,7 +1122,18 @@ const AddInfo = () => {
// });
// });
};
//
const beforeAvatarUpload = rawFile => {
console.log(rawFile);
if (rawFile.type !== 'image/png' && rawFile.type !== 'image/jpeg') {
ElMessage.error('图片格式只能为 png/jpg!');
return false;
} else if (rawFile.size / 1024 / 1024 > 10) {
ElMessage.error('图片大小不能大于10MB!');
return false;
}
return true;
};
//
const ConfirmForm = () => {
console.log(warehouseData.value, '准备好的数据');
@ -1182,6 +1197,22 @@ const searchHide = () => {
console.log(details);
details.search = !details.search;
};
//
const InformationViewing=(val)=>{
$router.push({
path: '/aftersales/aftersalesWorkOrderInfo',
query: {
id: val.row.id,
name: val.row.workOrderNumber + '-信息查看',
warehouseId: val.row.warehouseId,
workOrderNumber: val.row.workOrderNumber, //
businessId: val.row.businessId,
ProcessType: TabPermissions.value == 2 ? '2' : TabPermissions.value == 3 ? '1' : '', // 1 2
RouteIndexs: TabPermissions.value, //
},
});
}
//
const view = val => {
console.log(val.row.id);
@ -1297,6 +1328,18 @@ const addingRecord = val => {
});
};
//
const AppealAttachmentpictureList = val => {
console.log(val, '点击申诉附件图片');
};
//
const AppealAttachmentImgListRemove = val => {
console.log(val, '申诉附件移除');
};
//
const AppealAttachmentImgSuccess = val => {
console.log(val, '申诉图片上传成功');
};
//
const appeal = val => {
console.log(details.selectionList, 'details.selectionList');
@ -1318,36 +1361,46 @@ const appeal = val => {
};
//
const Appealbutton = () => {
if(AppealAttachment.value.length>1){
ElMessage({
message: '只能上传一张图片',
type: 'warning',
});
return
}
console.log(details.selectionList, '当前申诉的东西');
loadingappeal.value = true; //
console.log(Appealselection.value, '当前选择的责任人');
console.log(warehouseData.value, '要循环处理的参数');
let data = {
peopleEntityList: [], //
imagePath: '', //
};
data.workOrderId = details.selectionList[0].lawoId;
data.reason = Reasonforappeal.value;
(data.appealPeopleName = warehouseData.value
data.appealPeopleName = warehouseData.value
.filter(item => Appealselection.value.includes(item.value))
.map(item => item.label)
.join(',')), //
details.selectionList.forEach(item => {
console.log(item.id);
console.log(item, '已经选择的列表');
data['peopleEntityList'].push({
workOrderId: item.id, //ID
warehouseId: item.warehouseId == '/' ? '' : item.warehouseId,
reason: Reasonforappeal.value, //
claimant: userInfo.value.content.user_name, //
claimantUserId: userInfo.value.content.user_id, //ID
actualPersonName: warehouseData.value
.filter(item => Appealselection.value.includes(item.value))
.map(item => item.label)
.join(','), //
});
.join(','); //
details.selectionList.forEach(item => {
console.log(item.id);
console.log(item, '已经选择的列表');
data['peopleEntityList'].push({
workOrderId: item.id, //ID
warehouseId: item.warehouseId == '/' ? '' : item.warehouseId,
reason: Reasonforappeal.value, //
claimant: userInfo.value.content.user_name, //
claimantUserId: userInfo.value.content.user_id, //ID
actualPersonName: warehouseData.value
.filter(item => Appealselection.value.includes(item.value))
.map(item => item.label)
.join(','), //
});
});
data.imagePath = AppealAttachment.value[0].response.data.link; //
console.log(data, '处理好的值');
$_appealSubmit(data).then(res => {
dialogappeal.value = false; //
loadingappeal.value = false; //
@ -1754,11 +1807,11 @@ const AppealTab = val => {
Tableheaderswitching(columnList); //
console.log('处理完毕');
ProcessingPartyState.value = false; //
details.query.workOrderStatus = 30;
details.query.workOrderStatus = 80;
ArbitrationStatus.value = false; //
empty(); //
let data = {
workOrderStatus: 30,
...details.query,
};
IndexTable(data);
@ -2957,4 +3010,9 @@ const CompletedSubmission = () => {
.el_textBtn {
color: #9bb40d;
}
:deep(.el-upload-dragger) {
display: flex;
align-items: center;
justify-content: center;
}
</style>

84
src/views/aftersales/aftersalesWorkOrderAdd.vue

@ -137,36 +137,7 @@
<el-input v-model="Indexform.orderCode" placeholder="请输入订单自编号" clearable />
</el-form-item> -->
<!-- 必填 -->
<el-form-item
label="配送司机"
v-if="
groundlineSet ||
groundlineType == 3 ||
groundlineType == 4 ||
groundlineType == 8 ||
groundlineType == 5 ||
groundlineType == 7 ||
groundlineType == 8
"
>
<el-select
v-model="Indexform.deliveryDriver"
filterable
default-first-option
:reserve-keyword="false"
placeholder="请输入配送司机"
@change="changeDeliveryDriver"
>
<el-option
v-for="item in DeliveryDriver"
:key="item.value"
:label="item.driverName + '-' + item.trainNumber"
:value="item.id"
/>
</el-select>
</el-form-item>
<!-- 必填 -->
<el-form-item
@ -205,12 +176,44 @@
<el-date-picker
v-model="Indexform.deliveryTime"
type="datetime"
format="YYYY-MM-DD HH:mm:ss"
value-format="YYYY-MM-DD"
format="YYYY-MM-DD"
value-format="YYYY-MM-DD HH:mm:ss"
placeholder="请选择配送时间"
@change="DeliveryTrainnumber"
/>
</el-form-item>
<!-- 必填 -->
<el-form-item
label="配送司机"
v-if="
groundlineSet ||
groundlineType == 3 ||
groundlineType == 4 ||
groundlineType == 8 ||
groundlineType == 5 ||
groundlineType == 7 ||
groundlineType == 8
"
>
<el-select
v-model="Indexform.deliveryDriver"
filterable
default-first-option
:reserve-keyword="false"
placeholder="请输入配送司机"
@change="changeDeliveryDriver"
>
<el-option
v-for="item in DeliveryDriver"
:key="item.value"
:label="item.driverName + '-' + item.trainNumber"
:value="item.id"
/>
</el-select>
</el-form-item>
<el-form-item label="车辆路线" v-if="groundlineSet || groundlineType == 3">
<el-input v-model="Indexform.vehicleRoute" placeholder="请输入车辆路线车次号" clearable />
</el-form-item>
@ -219,7 +222,7 @@
<el-date-picker
v-model="Indexform.deliverGoodsTime"
type="datetime"
format="YYYY-MM-DD HH:mm:ss"
format="YYYY-MM-DD"
value-format="YYYY-MM-DD HH:mm:ss"
placeholder="请选择发货时间"
/>
@ -708,7 +711,7 @@ const ResponsiblePartychange = (val, index) => {
});
};
const onLoad = () => {
DeliveryTrainnumber(); //
// DeliveryTrainnumber(); //
console.log($route.query.id, '页面初始化');
routerState.value = $route.query.routerState;
updateDictionary(IndexException.value, 'pc_work_order'); //
@ -747,16 +750,21 @@ const DiscoveringNodesChange = val => {
//
function DeliveryTrainnumber() {
if(!Indexform.value.trainNumber){
Indexform.value.deliveryTime=''
Indexform.value.deliveryDriver=''
DeliveryDriver.value =[]
}
if(!Indexform.value.trainNumber){
return
}
let data = {
trainNumber: Indexform.value.trainNumber,
taskTime: Indexform.value.deliveryTime,
};
data.current = 1; //
data.size = 999; //
data.size = 200; //
$_shippingInformation(data).then(res => {
// DeliveryDriver;
// Indexform.deliveryDriver;
console.log(res, '查询返回值');
DeliveryDriver.value = res.data.data.records; //
//

6
src/views/aftersales/aftersalesWorkOrderend.vue

@ -1010,7 +1010,7 @@ const onLoad = () => {
});
//
PackageInfo.value = res.data.data.abnormalPackageVOList;
//
//
FangAddList.value = res.data.data.processorVOList
.filter(item => item.typesOf == '1')
@ -1028,12 +1028,12 @@ const onLoad = () => {
description: res.description, //
};
});
//
res.data.data.processorVOList.forEach(item => {
if (item.typesOf == 2) {
//
endFrom.value.processor.push(item.businessId);
// MessageResponsibility.value.push(item.businessId)
//MessageResponsibility.value.push(item.businessId)
}
});
console.log(endFrom.value.processor, ' endFrom.value.processor');

208
src/views/distribution/artery/zeroAdditionalRecording.vue

@ -149,14 +149,25 @@
</div>
<div style="margin-bottom: 10px" class="flex-c-sb">
<el-button type="text" class="pointer" @click="handleRemoveWaybill">
<el-icon><CaretLeft /></el-icon>
移除调度池
</el-button>
<div>
<el-button type="text" class="pointer" @click="handleRemoveWaybill">
<el-icon><CaretLeft /></el-icon>
移除调度池
</el-button>
<el-button
type="primary"
icon="Edit"
v-if="details.finalNodeIdArr.length > 1"
@click="handleEditNode"
>
修改节点
</el-button>
</div>
<!-- 控件 -->
<div class="avue-crud__right">
<el-button icon="el-icon-refresh" @click="searchChange" circle></el-button>
<el-button icon="el-icon-refresh" @click="handleRefresh" circle></el-button>
<el-button icon="Operation" @click="showdrawer(true, 2)" circle></el-button>
<el-button icon="el-icon-search" @click="searchHide" circle></el-button>
</div>
@ -200,6 +211,7 @@
type="primary"
class="submitBtn"
icon="el-icon-circle-check"
:loading="details.loadingObj.submitLoading"
@click="handleEditZeroSubmit"
> </el-button
>
@ -211,7 +223,7 @@
:align-center="true"
>
<el-form-item label-width="100px" label="选择节点">
<el-select v-model="details.chooseNodeId" class="m-2" placeholder="Select">
<el-select v-model="details.finalNodeId" class="m-2" placeholder="选择节点">
<el-option
v-for="item in details.finalNodeIdArr"
:key="item.warehouseId"
@ -223,8 +235,8 @@
<template #footer>
<div class="flex-c-c">
<el-button @click="dialogVisible = false">取消</el-button>
<el-button type="primary" @click="submitClient"> 确定(修改客户) </el-button>
<el-button @click="details.showPopUpObj.editNodeIdDialogVisible = false">取消</el-button>
<el-button type="primary" @click="handleChooseNode"> 确定(选择节点) </el-button>
</div>
</template>
</el-dialog>
@ -256,10 +268,15 @@ import {
import { downloadXls } from '@/utils/util';
import { oldColumnList, newColumnList } from '@/option/distribution/zeroAdditionalRecording';
import { ElMessage } from 'element-plus';
import { useRoute } from 'vue-router';
import { useRoute, useRouter } from 'vue-router';
import { useStore } from 'vuex';
//
const $route = useRoute();
const $router = useRouter();
//
const $store = useStore();
const details = reactive<any>({
/** 是否开启搜索 */
@ -305,7 +322,7 @@ const details = reactive<any>({
oldColumnList,
newColumnList,
/** 订单池数据 */
oldData: [{}],
oldData: [],
/** 调度池数据 */
newData: [],
/** 页面loading */
@ -313,6 +330,8 @@ const details = reactive<any>({
/** 列表加载loading */
list: false,
newListLoading: false,
/** 提交按钮 */
submitLoading: false,
},
/** 订单池列表复选框选中的数据 */
oldSelectionList: [],
@ -353,11 +372,14 @@ const details = reactive<any>({
finalNodeIdArr: [],
/** 运单Id */
loadId: '',
/** 弹出层 */
showPopUpObj: {
editNodeIdDialogVisible: true,
editNodeIdDialogVisible: false,
},
/** 选择的Id */
chooseNodeId: '',
finalNodeId: '',
/** 确认框的事件类型 add -- 新增 edit -- 修改 */
confirmType: 'add',
});
const {
@ -587,26 +609,33 @@ const setnewcolum = (newarr, headarr, type) => {
const handleAddWaybill = () => {
if (details.oldSelectionList.length === 0) return ElMessage.error('最少选择一条数据');
for (let item of details.oldSelectionList) {
console.log('item.stockNum :>> ', item.stockNum);
item.loadingNum = Number(item.stockNum || 0);
details.newData.push(item);
}
//
if (details.finalNodeIdArr.length > 1) {
details.confirmType = 'add';
details.orderCodeList = [
...new Set([...details.orderCodeList, ...details.oldSelectionList.map(val => val.orderCode)]),
];
details.showPopUpObj.editNodeIdDialogVisible = true;
} else {
const _item = details.finalNodeIdArr[0];
details.page.pageNum = 1;
onLoad();
for (let item of details.oldSelectionList) {
item.finalNodeId = _item.warehouseId;
item.warehouseName = _item.warehouseName;
item.loadingNum = Number(item.stockNum || 0);
details.newData.push(item);
}
details.orderCodeList = [
...new Set([...details.orderCodeList, ...details.oldSelectionList.map(val => val.orderCode)]),
];
details.page.pageNum = 1;
onLoad();
}
};
/** 移除运单 */
const handleRemoveWaybill = () => {
if (details.newSelectionList.length === 0) return ElMessage.warning('最少选择一条运单');
for (const iterator of details.newSelectionList) {
console.log('111 :>> ', 111);
}
details.newData = details.newData.filter((val, index) => {
const _flag = !details.newSelectionList.includes(val);
@ -623,29 +652,114 @@ const handleRemoveWaybill = () => {
onLoad();
};
/** 清空调度池 */
const handleRefresh = () => {
details.newData = [];
details.newSelectionList = [];
details.orderCodeList = [];
details.page.pageNum = 1;
onLoad();
};
/** 开启修改零担补录节点弹窗 */
const handleEditNode = () => {
if (details.finalNodeIdArr.length <= 1) return ElMessage.error('后续节点数小于2个');
if (details.newSelectionList.length === 0) return ElMessage.warning('最少选择一条数据');
details.confirmType = 'edit';
details.showPopUpObj.editNodeIdDialogVisible = true;
};
/** 新增提交 */
const handleAdd = (warehouseName, finalNodeId) => {
for (let item of details.oldSelectionList) {
item.finalNodeId = details.finalNodeId;
item.warehouseName = warehouseName;
item.loadingNum = Number(item.stockNum || 0);
details.newData.push(item);
}
details.orderCodeList = [
...new Set([...details.orderCodeList, ...details.oldSelectionList.map(val => val.orderCode)]),
];
details.page.pageNum = 1;
onLoad();
details.showPopUpObj.editNodeIdDialogVisible = false;
};
const handleEdit = (warehouseName, finalNodeId) => {
for (const iterator of details.newSelectionList) {
iterator.finalNodeId = finalNodeId;
iterator.warehouseName = warehouseName;
}
details.showPopUpObj.editNodeIdDialogVisible = false;
};
/** 修改零担补录节点 */
const handleChooseNode = () => {
if (!details.finalNodeId) return ElMessage.error('请选择节点');
const _finalNodeId = details.finalNodeId;
//
const _warehouseName = details.finalNodeIdArr.find(
val => val.warehouseId === _finalNodeId
).warehouseName;
details.confirmType === 'add'
? handleAdd(_warehouseName, _finalNodeId)
: handleEdit(_warehouseName, _finalNodeId);
};
/** 返回上一页 */
const back = () => {
$router.back();
$store.commit('DEL_TAG');
};
/** 零担补录提交 */
const handleEditZeroSubmit = () => {
if (details.newData.length === 0) return ElMessage.error('请选择运单');
// const _data = details.newData.filter(val => {
// return val.loadingNum > 0;
// });
const submitData = {
loadId: details.loadId,
zeroSuppleList: [],
};
for (const iterator of details.newData) {
submitData.zeroSuppleList.push({
orderCode: iterator.orderCode,
waybillNo: iterator.waybillNo,
enterNum: iterator.stockNum,
finalNodeId: iterator.nodeId,
const handleEditZeroSubmit = async () => {
try {
// loading
details.loadingObj.submitLoading = true;
if (details.newData.length === 0) return ElMessage.error('请选择运单');
const _data = details.newData.filter(val => {
return val.loadingNum > 0;
});
}
console.log('_data :>> ', _data);
const submitData = {
loadId: details.loadId,
zeroSuppleList: [],
};
for (const iterator of details.newData) {
submitData.zeroSuppleList.push({
orderCode: iterator.orderCode,
waybillNo: iterator.waybillNo,
enterNum: iterator.loadingNum,
finalNodeId: iterator.finalNodeId,
});
}
console.log('submitData :>> ', submitData);
const res = await postAddZeroSupple(submitData);
const { code } = res.data;
if (code !== 200) return;
} catch (error) {
console.log('error :>> ', error);
} finally {
// loading
details.loadingObj.submitLoading = false;
}
};
</script>
@ -743,4 +857,8 @@ const handleEditZeroSubmit = () => {
:deep(.el-input-number__increase) {
zoom: 0.8;
}
.el-select {
width: 100%;
}
</style>

56
src/views/distribution/deliverylist/distributionDeliveryListedt.vue

@ -183,11 +183,12 @@
text
icon="el-icon-view"
@click="handleSignone(slotProps.scope.row)"
v-if="
>一键签收
<!-- v-if="
slotProps.scope.row.signingStatus == '待审核' &&
slotProps.scope.row.driverSigning == '未签收'
"
>一键签收
" -->
</el-text>
</template>
</tablecmt>
@ -552,6 +553,7 @@
:on-remove="handleRemove"
:on-success="ImgSuccessA"
:headers="headers"
multiple
>
<el-icon><Plus /></el-icon>
</el-upload>
@ -570,6 +572,7 @@
:on-remove="handleRemove"
:on-success="ImgSuccessB"
:headers="headers"
multiple
>
<el-icon><Plus /></el-icon>
</el-upload>
@ -588,6 +591,7 @@
:on-remove="handleRemove"
:on-success="ImgSuccessC"
:headers="headers"
multiple
>
<el-icon><Plus /></el-icon>
</el-upload>
@ -606,6 +610,7 @@
:on-remove="handleRemove"
:on-success="ImgSuccessD"
:headers="headers"
multiple
>
<el-icon><Plus /></el-icon>
</el-upload>
@ -613,7 +618,7 @@
<img w-full :src="dialogImageUrlD" alt="IMG" />
</el-dialog>
</div>
<div class="imgName">
<span>签收照</span>
<el-upload
@ -624,6 +629,7 @@
:on-remove="handleRemove"
:on-success="ImgSuccessE"
:headers="headers"
multiple
>
<el-icon><Plus /></el-icon>
</el-upload>
@ -1382,7 +1388,7 @@ export default {
values: '',
width: '150',
checkarr: [],
fixed: false,
fixed: true,
sortable: true,
head: false,
},
@ -1393,7 +1399,7 @@ export default {
values: '',
width: '150',
checkarr: [],
fixed: false,
fixed: true,
sortable: true,
head: false,
},
@ -1404,7 +1410,7 @@ export default {
values: '',
width: '150',
checkarr: [],
fixed: false,
fixed: true,
sortable: true,
head: false,
},
@ -1415,7 +1421,7 @@ export default {
values: '',
width: '180',
checkarr: [],
fixed: false,
fixed: true,
sortable: true,
},
{
@ -1423,7 +1429,7 @@ export default {
label: '仓库',
type: 2,
values: '',
width: '180',
width: '100',
checkarr: [],
fixed: false,
sortable: true,
@ -1476,7 +1482,7 @@ export default {
label: '一级品类',
type: 2,
values: '',
width: '180',
width: '100',
checkarr: [],
fixed: false,
sortable: true,
@ -1486,7 +1492,7 @@ export default {
label: '二级品类',
type: 2,
values: '',
width: '180',
width: '100',
checkarr: [],
fixed: false,
sortable: true,
@ -1496,7 +1502,7 @@ export default {
label: '三级品类',
type: 2,
values: '',
width: '180',
width: '100',
checkarr: [],
fixed: false,
sortable: true,
@ -1528,7 +1534,7 @@ export default {
label: '包件状态',
type: 1,
values: '',
width: '180',
width: '80',
checkarr: [],
fixed: false,
sortable: true,
@ -1538,7 +1544,7 @@ export default {
label: '冻结状态',
type: 1,
values: '',
width: '150',
width: '80',
checkarr: [],
fixed: false,
sortable: true,
@ -1548,7 +1554,7 @@ export default {
label: '上架状态',
type: 1,
values: '',
width: '150',
width: '80',
checkarr: [],
fixed: false,
sortable: true,
@ -1559,7 +1565,7 @@ export default {
label: '备货状态',
type: 1,
values: '',
width: '150',
width: '80',
checkarr: [],
fixed: false,
sortable: true,
@ -1570,7 +1576,7 @@ export default {
label: '预约状态',
type: 1,
values: '',
width: '150',
width: '80',
checkarr: [],
fixed: false,
sortable: true,
@ -1581,7 +1587,7 @@ export default {
label: '装车状态',
type: 1,
values: '',
width: '150',
width: '80',
checkarr: [],
fixed: false,
sortable: true,
@ -1592,7 +1598,7 @@ export default {
label: '包件数量',
type: 1,
values: '',
width: '180',
width: '40',
checkarr: [],
fixed: false,
sortable: true,
@ -1603,7 +1609,7 @@ export default {
label: '计划数量',
type: 1,
values: '',
width: '180',
width: '40',
checkarr: [],
fixed: false,
sortable: true,
@ -1613,7 +1619,7 @@ export default {
label: '装车数量',
type: 1,
values: '',
width: '180',
width: '40',
checkarr: [],
fixed: false,
sortable: true,
@ -1623,7 +1629,7 @@ export default {
label: '签收数量',
type: 1,
values: '',
width: '180',
width: '40',
checkarr: [],
fixed: false,
sortable: true,
@ -3569,6 +3575,12 @@ export default {
},
//
handleSignone(row) {
//
this.DoorstepPhoto=[]
this.StackingPhoto=[]
this.FragilePhotos=[]
this.HomePhotos=[]
this.SignForPhotos=[]
console.log('一键签收222>>>>>>>>>>', row);
if (row.loadingStatus != '已装车') {
ElMessage({

10
src/views/distribution/inventory/BookingNote.vue

@ -186,7 +186,7 @@
<div class="table-row table_row_number" v-for="item in pageInfo.detailList" :key="item">
<div style="width: 230px; flex: none">
<el-form-item label="计价方式:" label-width="fit-content" class="el-times">
<el-radio-group v-model="item.chargeType" style="display: flex">
<el-radio-group v-model="item.chargeType" disabled style="display: flex">
<el-radio :label="1"></el-radio>
<el-radio :label="2"></el-radio>
<el-radio :label="3">公斤</el-radio>
@ -200,6 +200,7 @@
v-for="item in details.options"
:key="item.value"
:label="item.label"
readonly
:value="item.value"
/>
</el-select>
@ -210,6 +211,7 @@
v-model="item.num"
controls-position="right"
:precision="0"
readonly
:step="0.1"
/>
</el-form-item>
@ -219,6 +221,7 @@
v-model="item.volume"
controls-position="right"
:precision="4"
readonly
:step="0.1"
/>
</el-form-item>
@ -228,6 +231,7 @@
v-model="item.weight"
controls-position="right"
:precision="3"
readonly
:step="0.1"
/>
</el-form-item>
@ -237,6 +241,7 @@
v-model="item.price"
controls-position="right"
:precision="2"
readonly
:step="0.1"
/>
</el-form-item>
@ -247,6 +252,7 @@
controls-position="right"
:precision="2"
:step="0.1"
readonly
/>
</el-form-item>
</div>
@ -362,7 +368,7 @@
<span class="red">{{ totalCost }}</span>
</div>
<div>
<el-form label-width="fit-content" readonly>
<el-form label-width="fit-content">
<el-row>
<el-form-item label="运费:">
<el-input

1539
src/views/distribution/inventory/addArteryDistrilbutionBillLadingList.vue

File diff suppressed because it is too large Load Diff

29
src/views/distribution/inventory/arteryDistrilbutionBillLadingList.vue

@ -1147,18 +1147,25 @@ export default {
async handleSubmit() {},
/** 新增 */
handleAdd() {
this.title = '新增';
this.addInfo.form = {};
this.box = true;
this.addInfo.isNew = true;
this.$nextTick(() => {
//
var bodyContent = document.querySelectorAll('.el-dialog .maboxhi');
bodyContent.forEach(val => {
val.style.height = '350px';
// val.style.width = '45%';
});
this.$router.push({
path: '/distribution/inventory/addArteryDistrilbutionBillLadingList',
query: {
name: '新增提货',
},
});
// this.title = '';
// this.addInfo.form = {};
// this.box = true;
// this.addInfo.isNew = true;
// this.$nextTick(() => {
// //
// var bodyContent = document.querySelectorAll('.el-dialog .maboxhi');
// bodyContent.forEach(val => {
// val.style.height = '350px';
// // val.style.width = '45%';
// });
// });
},
/** 修改 */
handleEdit() {

48
src/views/distribution/signfor/distributionSignforedt.vue

@ -1035,9 +1035,9 @@ const menuData2 = ref([
label: '运单号',
type: 2,
values: '',
width: '150',
width: '100',
checkarr: [],
fixed: false,
fixed: true,
sortable: true,
head: false,
},
@ -1046,9 +1046,9 @@ const menuData2 = ref([
label: '服务号',
type: 2,
values: '',
width: '250',
width: '150',
checkarr: [],
fixed: false,
fixed: true,
sortable: true,
head: false,
},
@ -1057,9 +1057,9 @@ const menuData2 = ref([
label: '订单自编号',
type: 2,
values: '',
width: '280',
width: '160',
checkarr: [],
fixed: false,
fixed: true,
sortable: true,
head: false,
},
@ -1068,9 +1068,9 @@ const menuData2 = ref([
label: '包条码',
type: 2,
values: '',
width: '200',
width: '130',
checkarr: [],
fixed: false,
fixed: true,
sortable: true,
head: false,
},
@ -1079,7 +1079,7 @@ const menuData2 = ref([
label: '仓库',
type: 2,
values: '',
width: '150',
width: '80',
checkarr: [],
fixed: false,
sortable: true,
@ -1090,7 +1090,7 @@ const menuData2 = ref([
label: '发站仓',
type: 2,
values: '',
width: '150',
width: '80',
checkarr: [],
fixed: false,
sortable: true,
@ -1101,7 +1101,7 @@ const menuData2 = ref([
label: '目的地',
type: 2,
values: '',
width: '150',
width: '80',
checkarr: [],
fixed: false,
sortable: true,
@ -1157,7 +1157,7 @@ const menuData2 = ref([
label: '计划数量',
type: 1,
values: '',
width: '150',
width: '40',
checkarr: [],
fixed: false,
sortable: true,
@ -1169,7 +1169,7 @@ const menuData2 = ref([
label: '装车数量',
type: 1,
values: '',
width: '150',
width: '40',
checkarr: [],
fixed: false,
sortable: true,
@ -1181,7 +1181,7 @@ const menuData2 = ref([
label: '签收数量',
type: 1,
values: '',
width: '150',
width: '40',
checkarr: [],
fixed: false,
sortable: true,
@ -1193,7 +1193,7 @@ const menuData2 = ref([
label: '一级品类',
type: 2,
values: '',
width: '150',
width: '100',
checkarr: [],
fixed: false,
sortable: true,
@ -1204,7 +1204,7 @@ const menuData2 = ref([
label: '二级品类',
type: 2,
values: '',
width: '200',
width: '100',
checkarr: [],
fixed: false,
sortable: true,
@ -1215,7 +1215,7 @@ const menuData2 = ref([
label: '三级品类',
type: 2,
values: '',
width: '200',
width: '100',
checkarr: [],
fixed: false,
sortable: true,
@ -1226,7 +1226,7 @@ const menuData2 = ref([
label: '包件状态',
type: 1,
values: '',
width: '200',
width: '80',
checkarr: [],
fixed: false,
sortable: true,
@ -1237,7 +1237,7 @@ const menuData2 = ref([
label: '冻结状态',
type: 2,
values: '',
width: '200',
width: '80',
checkarr: [],
fixed: false,
sortable: true,
@ -1259,7 +1259,7 @@ const menuData2 = ref([
label: '备货状态',
type: 2,
values: '',
width: '200',
width: '80',
checkarr: [],
fixed: false,
sortable: true,
@ -1270,7 +1270,7 @@ const menuData2 = ref([
label: '预约状态',
type: 2,
values: '',
width: '200',
width: '80',
checkarr: [],
fixed: false,
sortable: true,
@ -1281,7 +1281,7 @@ const menuData2 = ref([
label: '装车状态 ',
type: 2,
values: '',
width: '200',
width: '80',
checkarr: [],
fixed: false,
sortable: true,
@ -1292,7 +1292,7 @@ const menuData2 = ref([
label: '装车方式',
type: 2,
values: '',
width: '200',
width: '80',
checkarr: [],
fixed: false,
sortable: true,
@ -1303,7 +1303,7 @@ const menuData2 = ref([
label: '计划装车人',
type: 2,
values: '',
width: '200',
width: '80',
checkarr: [],
fixed: false,
sortable: true,

11
src/views/distribution/signfor/distributionSignfortreat.vue

@ -162,8 +162,8 @@
'装车件数' ||
'签收数' ||
'未签收数' ||
'未装车件数'||
'异常装车件数'||
'未装车件数' ||
'异常装车件数' ||
'异常签收件数'
"
>
@ -394,7 +394,6 @@
:on-success="ImgSuccessC"
:headers="headers"
multiple
>
<el-icon><Plus /></el-icon>
</el-upload>
@ -1856,11 +1855,11 @@ export default {
type = 5;
this.numberTitle = '未签收详情列表';
break;
case '异常装车件数':
case '异常装车件数':
type = 6;
this.numberTitle = '异常装车详情列表';
break;
case '异常签收件数':
case '异常签收件数':
type = 7;
this.numberTitle = '异常签收详情列表';
break;
@ -2511,7 +2510,7 @@ export default {
display: flex;
align-items: flex-end;
}
:deep(.el-upload-list__item-thumbnail){
:deep(.el-upload-list__item-thumbnail) {
object-fit: fill;
}
</style>

124
src/views/distribution/turndelivery/deliveryDiscuss.vue

@ -421,6 +421,9 @@
<el-dialog v-model="AddLalog" :title="wrapLoading ? '包件信息' : '在库订单信息'">
<!-- 表格列开始 -->
<!-- data 订单信息 wrapData包件信息 -->
<div v-if="!wrapLoading">
<div class="SoInput" v-if="searchSo" ref="SoHeight">
<el-form label-width="100px" :model="parameter">
<el-form-item label="商场名称:">
@ -484,6 +487,27 @@
搜索菜单预留按钮
</div> -->
</div>
</div>
<!-- 包件搜索 -->
<div v-else class="el_package">
<el-form :model="PackageFrom">
<el-form-item label="运单号:">
<el-input
v-model="PackageFrom.inputwaybillNumber"
clearable
placeholder="请输入运单号"
/>
</el-form-item>
<el-form-item label="包条码:">
<el-input
v-model="PackageFrom.orderPackageCode"
placeholder="请输入包条码"
/>
</el-form-item>
</el-form>
</div>
<!-- 顶部开始 -->
<div class="el-Cart-button">
<!-- 表格顶部左侧按钮 -->
@ -831,6 +855,7 @@ const pageList = ref([5, 10, 50, 100, 200]); // 选择每页显示多少条
const background = ref(true); //
const disabled = ref(false); // 使
const data = ref([]); //
const PackageFrom=ref({});//
const wrapData = ref([]); //
const wrapLoading = ref(false); //
const dataInfo = ref([]); //
@ -849,6 +874,7 @@ const flexList = ref<(string | number)[]>([]); //冻结
const loading = ref(false); //
const BG = ref(false); //
const BtnRadio = ref('1'); //
const Packageow = ref(); //
const ElBtnClass = ref('el-Btn-link'); //
const searchSo = ref(false); //
const SoHeight = ref(); //
@ -1614,8 +1640,6 @@ const wrap = ref([
head: true,
},
{
prop: 'quantity',
label: '数量',
@ -2107,17 +2131,89 @@ const findIndexById = id => {
return -1; //-1
};
//
const PackageFn=()=>{
//;
//
if (RouteId.value) {
console.log(wrapLoading.value, '当前为编辑状态');
$_getPackageListByDeliveryIdAndOrderId({
...PackageFrom.value,//
current: 1,
size: 100,
deliveryId: RouteId.value,
id: Packageow.value.id,
}).then(res => {
console.log(res, '订单包件信息');
if (res.data.code == 200) {
wrapData.value = res.data.data.data.packageList;
let IdTmp = []; //ID
dataInfo.value[dataId.value].packageListInfo = wrapTemp.value[dataId.value];
//,,,使API
if (dataInfo.value[dataId.value].packageListInfo) {
dataInfo.value[dataId.value].packageListInfo.forEach(item => {
IdTmp.push(item.id);
});
}
toggleSelection({
val: false,
data: IdTmp.length ? IdTmp : res.data.data.data.packageListIds.split(','),
index: kind.value ? 0 : 1,
}); //
}
// AddLalog.value = false; //
console.log(wrapData.value, '包件表格信息');
console.log(res);
});
} else {
//
//
$_getPackageListByStockArticleId({
...PackageFrom.value,//
id: Packageow.value.id,
current: 1,
size: 100,
}).then(res => {
wrapData.value = res.data.data.records;
console.log(res, '订单包件');
if (kind.value) {
toggleSelection({ index: 0 }); //
} else {
toggleSelection({ index: 1 }); //
}
console.log(tableRefs, 'tableRefs');
console.log(res.data.data.records, '查看下面的包件');
});
//
console.log('当前为新增状态');
console.log(Packageow.value, Packageow.value.id, '查看包件事件');
//
console.log(dataId.value, 'dataId.value下标');
console.log(wrapDataInfo.value[dataId.value], '当前订单下面的包件信息');
console.log(wrapDataInfo, '订单');
}
editLoading.value = false; //
}
//
const ViewEvent = val => {
Packageow.value = val;
wrapLoading.value = true; //
AddLalog.value = true; //
editLoading.value = true; //
dataId.value = findIndexById(val.id);
//;
//
PackageFn()
return
if (RouteId.value) {
console.log(wrapLoading.value, '当前为编辑状态');
$_getPackageListByDeliveryIdAndOrderId({
waybillNumber: '', //
orderPackageCode: '', //
current: 1,
size: 100,
deliveryId: RouteId.value,
@ -2145,7 +2241,11 @@ const ViewEvent = val => {
console.log(res);
});
} else {
//
//
$_getPackageListByStockArticleId({
waybillNumber: '', //
orderPackageCode: '', //
id: val.id,
current: 1,
size: 100,
@ -2317,20 +2417,33 @@ const search = () => {
};
//
const SoInput = () => {
if(!wrapLoading){
if (kind.value) {
OrderSelection(0, parameter.value);
} else {
OrderSelection(1, parameter.value);
}
}else{
PackageFn()
}
};
//
const SoEmpty = () => {
parameter.value = {};
if(!wrapLoading){
parameter.value = {};
if (kind.value) {
OrderSelection(0);
} else {
OrderSelection(1);
}
}else{
PackageFrom.value={}
PackageFn()
}
};
// ID
@ -3172,4 +3285,9 @@ const SubmitCommercial = () => {
background-color: #ff0000;
color: #fff;
}
.el_package{
:deep(.el-form){
justify-content: flex-start !important;
}
}
</style>

50
src/views/warehouse/parcelList/distributionParcelList.vue

@ -260,7 +260,7 @@ export default {
head: false,
},
{
prop: 'trainNumber',
prop: 'carNumber',
label: '客户车次号',
type: 2,
values: '',
@ -370,7 +370,6 @@ export default {
sortable: true,
},
{
prop: 'reservationCode',
label: '预约单编号',
@ -381,11 +380,9 @@ export default {
fixed: false,
sortable: true,
},
{
prop: 'noteNumber',
label: '配送车次号',
label: '配送号',
type: 2,
values: '',
width: '130',
@ -393,8 +390,6 @@ export default {
fixed: false,
sortable: true,
},
{
prop: 'driverName',
label: '配送司机',
@ -405,8 +400,6 @@ export default {
fixed: false,
sortable: true,
},
{
prop: 'scanTime',
label: '装车时间',
@ -417,8 +410,6 @@ export default {
fixed: false,
sortable: true,
},
{
prop: 'scanUser',
label: '实际装车人',
@ -449,8 +440,28 @@ export default {
fixed: false,
sortable: true,
},
{
prop: 'noteNumber',
label: '配送单号',
type: 2,
values: '',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
},
{
prop: 'dvehicleName',
label: '配送车次号',
type: 2,
values: '',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
},
{
prop: 'vehicleName',
label: '配送车牌',
type: 2,
values: '',
@ -509,7 +520,7 @@ export default {
fixed: false,
sortable: true,
},
// {
// prop: 'allocationMsg',
// label: '',
@ -761,21 +772,6 @@ export default {
delete this.query[row.prop.replace(/Name/, '')];
delete this.query[row.prop];
}
// //
// if (row.prop === 'orderPackageGroundingStatusName') {
// this.query.orderPackageGroundingStatus = value;
// if (value === '') delete this.query.orderPackageGroundingStatus;
// }
// if (row.prop === 'orderPackageStatusName') {
// this.query.orderPackageStatus = value;
// if (value === '') delete this.query.orderPackageStatus;
// }
// if (value === '') {
// delete this.query[row.prop];
// }
this.page.currentPage = 1;
this.onLoad(this.page);
},

3
vite.config.js

@ -24,12 +24,13 @@ export default ({ mode, command }) => {
// target: 'http://192.168.6.116:8777',
// target: 'http://192.168.6.122:8777',
// target: 'http://192.168.10.25:13000',
// target: 'http://192.168.10.25:13000',
// target: 'http://192.168.10.25:2888',
target: 'http://192.168.10.57:13000',
// target: 'http://192.168.10.57:13000',
// tjj
// sst
// target: 'http://192.168.10.94:8888',
// target: 'http://192.168.10.200:13000',
// target: 'http://192.168.10.29:13000',
// target: 'http://h5uapi.huitongys.com',
// target: 'http://test.api.huitongys.com',

Loading…
Cancel
Save