Browse Source

包件明细新增时间搜索

dev-xx
qb 1 year ago
parent
commit
b4bba0ebde
  1. 2
      src/components/tablecmt/tablecmt.vue
  2. 38
      src/option/distribution/addVehicleStowage.js
  3. 179
      src/views/distribution/artery/AddVehicleStowage.vue
  4. 36
      src/views/distribution/inventory/arteryDistrilbutionBillLadingListDetails.vue
  5. 5
      src/views/distribution/reservation/reservationAddFrom.vue
  6. 91
      src/views/warehouse/parcelList/distributionParcelList.vue
  7. 2
      src/views/waybill/WaybillOrderList.vue

2
src/components/tablecmt/tablecmt.vue

@ -45,8 +45,6 @@
clearable
:placeholder="`请输入${column.label}`"
@change="inputchange($event, column)"
@blur="inputchange($event, column)"
@clear="inputclear($event, column)"
/>
<el-select
v-if="column.type == 3"

38
src/option/distribution/addVehicleStowage.js

@ -174,7 +174,7 @@ export const columnList = [
{
prop: 'orderCode',
label: '订单自编号',
type: 1,
type: 2,
values: '',
width: '150',
checkarr: [],
@ -184,7 +184,7 @@ export const columnList = [
{
prop: 'waybillNo',
label: '运单号',
type: 1,
type: 2,
values: '',
width: '130',
checkarr: [],
@ -374,7 +374,7 @@ export const newColumnList = [
{
prop: 'orderCode',
label: '订单自编号',
type: 1,
type: 2,
values: '',
width: '150',
checkarr: [],
@ -384,7 +384,7 @@ export const newColumnList = [
{
prop: 'waybillNo',
label: '运单号',
type: 1,
type: 2,
values: '',
width: '130',
checkarr: [],
@ -395,7 +395,7 @@ export const newColumnList = [
{
prop: 'destination',
label: '到站',
type: 1,
type: 2,
values: '',
width: '130',
checkarr: [],
@ -406,7 +406,7 @@ export const newColumnList = [
{
prop: 'destinationWarehouseName',
label: '目的站',
type: 1,
type: 2,
values: '',
width: '130',
checkarr: [],
@ -417,7 +417,7 @@ export const newColumnList = [
{
prop: 'shipper',
label: '发货单位',
type: 1,
type: 2,
values: '',
width: '130',
checkarr: [],
@ -428,7 +428,7 @@ export const newColumnList = [
{
prop: 'consignee',
label: '收货单位',
type: 1,
type: 2,
values: '',
width: '130',
checkarr: [],
@ -438,7 +438,7 @@ export const newColumnList = [
{
prop: 'consigneeName',
label: '收货人',
type: 1,
type: 2,
values: '',
width: '130',
checkarr: [],
@ -448,7 +448,7 @@ export const newColumnList = [
{
prop: 'productName',
label: '品类名称',
type: 1,
type: 2,
values: '',
width: '130',
checkarr: [],
@ -458,7 +458,7 @@ export const newColumnList = [
{
prop: 'totalNum',
label: '件数',
type: 1,
type: 2,
values: '',
width: '130',
checkarr: [],
@ -469,7 +469,7 @@ export const newColumnList = [
{
prop: 'stockNum',
label: '在库数',
type: 1,
type: 2,
values: '',
width: '150',
checkarr: [],
@ -491,7 +491,7 @@ export const newColumnList = [
{
prop: 'loadingNum',
label: '装车数',
type: 1,
type: 2,
values: '',
width: '150',
checkarr: [],
@ -502,7 +502,7 @@ export const newColumnList = [
{
prop: 'price',
label: '单价',
type: 1,
type: 2,
values: '',
width: '150',
checkarr: [],
@ -512,7 +512,7 @@ export const newColumnList = [
{
prop: 'totalWeight',
label: '重量(KG)',
type: 1,
type: 2,
values: '',
width: '130',
checkarr: [],
@ -523,7 +523,7 @@ export const newColumnList = [
{
prop: 'totalVolume',
label: '体积',
type: 1,
type: 2,
values: '',
width: '130',
checkarr: [],
@ -534,7 +534,7 @@ export const newColumnList = [
{
prop: 'freight',
label: '运费',
type: 1,
type: 2,
values: '',
width: '130',
checkarr: [],
@ -545,7 +545,7 @@ export const newColumnList = [
{
prop: 'customerTrain',
label: '客户车次',
type: 1,
type: 2,
values: '',
width: '130',
checkarr: [],
@ -555,7 +555,7 @@ export const newColumnList = [
{
prop: 'remark',
label: '运单备注',
type: 1,
type: 2,
values: '',
width: '130',
checkarr: [],

179
src/views/distribution/artery/AddVehicleStowage.vue

@ -187,6 +187,7 @@
<div class="form_row_item">
<el-form-item inline label="合计运费">
<el-input-number
:controls="false"
v-model="form.countTransportCost"
controls-position="right"
:precision="2"
@ -225,6 +226,7 @@
>
<template #default="slotProps">
<el-input-number
:controls="false"
controls-position="right"
:precision="2"
:min="0"
@ -327,6 +329,7 @@
class="columnList"
:columnList="details.columnList"
:tableData="details.data"
@inputTxt="inputsc"
:loading="loadingObj.oldListLoading"
@selection="selectionChange"
>
@ -431,14 +434,16 @@
<tablecmt
class="columnList"
ref="newColumnListNode"
:columnList="details.newColumnList"
:tableData="item.lineCarsOrderList"
:columnList="item.newColumnList"
:tableData="item.renderData"
:loading="item.loading"
@inputTxt="(value, row) => item.itemInputsc(value, row, index)"
@selection="list => item.selectionChange(list, index)"
>
<template #default="slotProps">
<template v-if="slotProps.scope.column.label === '计划数'">
<el-input-number
:controls="false"
v-if="Number(details.pageType) === 1"
v-model="slotProps.scope.row.planNum"
controls-position="right"
@ -508,6 +513,7 @@
<el-form>
<el-form-item label="计划数量:" label-width="100px">
<el-input-number
:controls="false"
controls-position="right"
:min="0"
:precision="0"
@ -519,7 +525,7 @@
</el-form-item>
</el-form>
<div class="flex-c-c">
<el-button>取消</el-button>
<el-button @click="details.popUpShow.editPlanNumberVisited = false">取消</el-button>
<el-button
type="primary"
:loading="btnLoadingObj.editPlanNumBtn"
@ -539,7 +545,7 @@ import dayjs from 'dayjs';
import { mapGetters } from 'vuex';
/** 获取字典 */
import { getDictionaryBiz } from '@/api/system/dict';
import { downloadXls, setNodeHeight, computeNumber, isNumer } from '@/utils/util';
import { downloadXls, setNodeHeight, computeNumber, isNumer, deepClone } from '@/utils/util';
import {
columnList,
nodeInfoColumnList,
@ -865,6 +871,7 @@ const initDispatchOrder = async item => {
const { code, data } = res.data;
if (code !== 200) return;
item.lineCarsOrderList = data;
item.renderData = data;
} catch (error) {
} finally {
//
@ -908,25 +915,108 @@ const onLoad = async () => {
const { code, data } = res.data;
details.nodeInfoData = handleEditForbidden(
data.allCarsLineList.map((val, index) => {
const _node = {
...val,
//
query: {},
//
selectionList: [],
//
lineCarsOrderList: [],
/** 渲染数据 */
renderData: [],
filterData: [],
//
newColumnList: deepClone(newColumnList),
loading: false,
selectionChange(list, index) {
details.nodeInfoData[index].selectionList = list;
console.log('list :>> ', list);
},
itemInputsc(value, row, index) {
console.log('this :>> ', this);
try {
//
const reg = new RegExp(value, 'i');
this.query[row.prop] = reg;
if (value === '') delete this.query[row.prop];
if (Object.keys(this.query).length === 0)
return (this.renderData = this.lineCarsOrderList);
const _data = this.lineCarsOrderList.filter(value => {
let _flag = true;
for (let key in this.query) {
if (!this.query[key].test(value[key])) _flag = false;
if (!_flag) break;
}
return _flag;
});
this.renderData = _data;
} catch (error) {
console.log('error :>> ', error);
} finally {
}
},
};
if (val.nodeName === data.warehouseName) {
//
details.warehouseIndex = index;
}
//
val.query = {};
//
val.selectionList = [];
//
val.lineCarsOrderList = [];
val.filterData = [];
val.loading = false;
val.selectionChange = (list, index) => {
details.nodeInfoData[index].selectionList = list;
console.log('list :>> ', list);
};
if (Number(details.pageType) === 2) initDispatchOrder(val);
return val;
// //
// val.query = {};
// //
// val.selectionList = [];
// //
// val.lineCarsOrderList = [];
// //
// val.renderData = [];
// val.newColumnList = deepClone(newColumnList);
// val.filterData = [];
// val.loading = false;
// val.selectionChange = (list, index) => {
// details.nodeInfoData[index].selectionList = list;
// console.log('list :>> ', list);
// };
// val.itemInputsc = (value, row, index) => {
// console.log('this :>> ', this);
// try {
// //
// const reg = new RegExp(value, 'i');
// this.query[row.prop] = reg;
// if (value === '') delete this.query[row.prop];
// if (Object.keys(this.query).length === 0)
// return (this.renderData = this.lineCarsOrderList);
// const _data = this.lineCarsOrderList.filter(value => {
// let _flag = true;
// for (let key in this.query) {
// if (!this.query[key].test(value[key])) _flag = false;
// if (!_flag) break;
// }
// return _flag;
// });
// this.renderData = _data;
// } catch (error) {
// console.log('error :>> ', error);
// } finally {
// }
// };
if (Number(details.pageType) === 2) initDispatchOrder(_node);
return _node;
})
);
details.form = data.carsLoadEntity;
@ -993,6 +1083,8 @@ const searchHide = () => {
/** 表格表头输入框搜索 */
const inputsc = (index, row) => {
details.query[row.prop] = index;
console.log('111 :>> ', 111);
if (index === '') delete details.query[row.prop];
initOriginWarehouseOrder();
};
@ -1143,12 +1235,45 @@ const handleAddNode = () => {
selectionList: [],
//
lineCarsOrderList: [],
/** 渲染数据 */
renderData: [],
filterData: [],
//
newColumnList: deepClone(newColumnList),
loading: false,
selectionChange(list, index) {
details.nodeInfoData[index].selectionList = list;
console.log('list :>> ', list);
},
itemInputsc(value, row, index) {
console.log('this :>> ', this);
try {
//
const reg = new RegExp(value, 'i');
this.query[row.prop] = reg;
if (value === '') delete this.query[row.prop];
if (Object.keys(this.query).length === 0) return (this.renderData = this.lineCarsOrderList);
const _data = this.lineCarsOrderList.filter(value => {
let _flag = true;
for (let key in this.query) {
if (!this.query[key].test(value[key])) _flag = false;
if (!_flag) break;
}
return _flag;
});
this.renderData = _data;
} catch (error) {
console.log('error :>> ', error);
} finally {
}
},
});
details.nodeInfoData = handleEditForbidden(details.nodeInfoData);
// ,
@ -1189,6 +1314,9 @@ const handleAddWaybill = async (index: number) => {
...details.selectionList.map(val => val.orderCode + ',' + val.waybillNo),
]),
];
_node.renderData = _node.lineCarsOrderList;
console.log('details.orderCodeList :>> ', details.orderCodeList);
const orderCodes = details.selectionList.map(val => val.orderCode);
@ -1237,10 +1365,12 @@ const handleRemoveWaybill = async (index: number) => {
message: '未选择目的仓或目的仓信息异常',
});
}
console.log('_node :>> ', _node);
//
const _selectList = [..._node.selectionList];
//
_node.lineCarsOrderList = _node.lineCarsOrderList.filter((val, index) => {
const _flag = !_node.selectionList.includes(val);
const _flag = !_selectList.includes(val);
if (!_flag) {
const _code = val.orderCode + ',' + val.waybillNo;
const _index = details.orderCodeList.indexOf(_code);
@ -1249,6 +1379,11 @@ const handleRemoveWaybill = async (index: number) => {
}
return _flag;
});
_node.renderData = _node.renderData.filter((val, index) => {
const _flag = !_selectList.includes(val);
return _flag;
});
clearSelectionList();
initOriginWarehouseOrder();
}
@ -1256,7 +1391,7 @@ const handleRemoveWaybill = async (index: number) => {
else if (Number(details.pageType) === 2) {
console.log('_node :>> ', _node);
const submitData = {
carsOrderId: _node.selectionList.map(val => val.carsOrderId).join(','),
carsOrderIds: _node.selectionList.map(val => val.carsOrderId).join(','),
};
const res = await postRemoveCarsOrderByCarsOrderId(submitData);
const { code, data } = res.data;
@ -1310,7 +1445,7 @@ const handleSubmitEdit = async () => {
btnLoadingObj.editPlanNumBtn = true;
const submitData = {
carsOrderId: details.editInfo.carsOrderId,
carsOrderIds: details.editInfo.carsOrderId,
planNum: details.editInfo.enterPlanNum,
};

36
src/views/distribution/inventory/arteryDistrilbutionBillLadingListDetails.vue

@ -105,6 +105,34 @@
slotProps.scope.row.waybillNo
}}</el-text>
</template>
<template v-if="slotProps.scope.column.label === '提货件数'">
<el-input-number
v-model="slotProps.scope.row[slotProps.scope.column.property]"
:controls="false"
:precision="0"
:min="0"
/>
</template>
<template v-if="slotProps.scope.column.label === '提货重量'">
<el-input-number
v-model="slotProps.scope.row[slotProps.scope.column.property]"
:controls="false"
:precision="4"
:min="0"
/>
</template>
<template v-if="slotProps.scope.column.label === '提货体积'">
<el-input-number
v-model="slotProps.scope.row[slotProps.scope.column.property]"
:controls="false"
:precision="4"
:min="0"
/>
</template>
<template v-if="slotProps.scope.column.label === '操作'">
<el-text @click="handleEdit(slotProps.scope)">编辑</el-text>
</template>
@ -309,7 +337,7 @@ export default {
{
prop: 'realNum',
label: '提货件数',
type: 10,
type: 13,
values: '',
width: '150',
checkarr: [],
@ -320,7 +348,7 @@ export default {
{
prop: 'realWeight',
label: '提货重量',
type: 10,
type: 13,
values: '',
width: '150',
checkarr: [],
@ -331,7 +359,7 @@ export default {
{
prop: 'realVolume',
label: '提货体积',
type: 10,
type: 13,
values: '',
width: '150',
checkarr: [],
@ -638,7 +666,7 @@ export default {
},
/** 跳转到运单详情 */
handleGoWayBillDetail({ row }) {
handleGoWayBillDetail({row}) {
if (row.waybillNo === '————') return this.$message.warning('暂无运单号');
this.$router.push({

5
src/views/distribution/reservation/reservationAddFrom.vue

@ -1997,6 +1997,7 @@ export default {
packageDataSec: [],
inventoryData: [],
orderData: [],
renderOrderData: [],
stockListShow: false,
isaddvalue: false,
packageData: [],
@ -2614,6 +2615,8 @@ export default {
this.orderData.forEach((item, index) => {
if (item.id === row.id) {
this.orderData.splice(index, 1);
const _index = this.renderOrderData.indexOf(item);
this.renderOrderData.splice(_index, 1);
}
console.log(this.orderData, '当前存在的数据');
});
@ -3218,6 +3221,7 @@ export default {
this.form.deliveryType = typeService;
this.form.deliveryAddress = address;
this.orderData = data;
this.renderOrderData = this.orderData;
});
}
if (this.reservationId) {
@ -3232,6 +3236,7 @@ export default {
//
this.marketName = reservation.mallName;
this.orderData = reservation.stockArticleList;
this.renderOrderData = this.orderData;
this.inventoryData = reservation.inventoryList;
this.inventoryData.forEach(item => {
item.quantityOccupied -= item.reservationNum;

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

@ -1,6 +1,49 @@
<template>
<basic-container>
<div class="avue-crud">
<el-row v-if="!search">
<!-- 查询模块 -->
<el-form :inline="true" :model="query" class="el-fr">
<el-form-item label="入库时间:" class="el-times">
<el-date-picker
v-model="warehouseEntryTimeEnd"
type="datetimerange"
unlink-panels
range-separator="至"
start-placeholder="开始时间"
end-placeholder="结束时间"
/>
</el-form-item>
<el-form-item label="装车时间:" class="el-times">
<el-date-picker
v-model="loadingTime"
type="datetimerange"
unlink-panels
range-separator="至"
start-placeholder="开始时间"
end-placeholder="结束时间"
/>
</el-form-item>
<el-form-item label="签收时间:" class="el-times">
<el-date-picker
v-model="signingTime"
type="datetimerange"
unlink-panels
range-separator="至"
start-placeholder="开始时间"
end-placeholder="结束时间"
/>
</el-form-item>
<el-form-item>
<el-button type="primary" icon="el-icon-search" @click="searchChange"> </el-button>
<el-button icon="el-icon-delete" @click="searchReset()"> </el-button>
</el-form-item>
</el-form>
</el-row>
<el-row>
<div class="avue-crud__header">
<!-- 头部左侧按钮模块 -->
@ -16,8 +59,9 @@
</div>
<!-- 头部右侧按钮模块 -->
<div class="avue-crud__right">
<el-button icon="el-icon-refresh" @click="searchChange" circle></el-button>
<el-button icon="el-icon-refresh" @click="onLoad(page)" circle></el-button>
<el-button icon="Operation" @click="showdrawer(true)" circle></el-button>
<el-button icon="el-icon-search" @click="searchHide" circle></el-button>
</div>
</div>
</el-row>
@ -158,7 +202,7 @@ import { mapGetters } from 'vuex';
import { downloadXls } from '@/utils/util';
import { showInventoryPackgeCode } from '@/api/distribution/distributionStockList';
import { showOrderPackgeCode } from '@/api/distribution/distributionStockArticle';
import print from "@/utils/print";
import print from '@/utils/print';
export default {
data() {
@ -275,9 +319,9 @@ export default {
{
prop: 'warehouseEntryTimeEnd',
label: '入库时间',
type: 2,
type: 4,
values: '',
width: '100',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
@ -370,7 +414,7 @@ export default {
],
fixed: false,
sortable: true,
},
},
// {
// prop: '',
// label: '',
@ -412,11 +456,11 @@ export default {
sortable: true,
},
{
prop: 'scanTime',
prop: 'loadingTime',
label: '装车时间',
type: 2,
type: 4,
values: '',
width: '130',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
@ -434,9 +478,9 @@ export default {
{
prop: 'signingTime',
label: '签收时间',
type: 2,
type: 4,
values: '',
width: '130',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
@ -615,6 +659,13 @@ export default {
option: option,
//
data: [],
/** 时间 */
/** 入库时间 */
warehouseEntryTimeEnd: [],
/** 装车时间 */
loadingTime: [],
/** 签收时间 */
signingTime: [],
};
},
mounted() {
@ -873,9 +924,25 @@ export default {
this.search = !this.search;
},
searchChange() {
/** 入库时间 */
this.query.startWarehouseEntryTimeEnd = this.warehouseEntryTimeEnd[0];
this.query.lastWarehouseEntryTimeEnd = this.warehouseEntryTimeEnd[1];
/** 装车时间 */
this.query.startLoadingTime = this.loadingTime[0];
this.query.lastLoadingTime = this.loadingTime[1];
/** 签收时间 */
this.query.startSigningTime = this.signingTime[0];
this.query.lastSigningTime = this.signingTime[1];
this.onLoad(this.page);
},
searchReset() {
/** 入库时间 */
this.warehouseEntryTimeEnd = [];
/** 装车时间 */
this.loadingTime = [];
/** 签收时间 */
this.signingTime = [];
this.query = {};
this.page.currentPage = 1;
this.onLoad(this.page);
@ -1035,4 +1102,8 @@ export default {
display: flex;
align-items: flex-end;
}
//
:deep(.el-date-editor.el-input__wrapper) {
height: 100% !important;
}
</style>

2
src/views/waybill/WaybillOrderList.vue

@ -256,7 +256,7 @@ const details = reactive<any>({
/** 列表 */
columnList,
/** 列表数据 */
data: [{}],
data: [],
/** 查看列表表头 */
viewColumnList,
/** 页面loading */

Loading…
Cancel
Save