Browse Source

完善数据大屏,新增超时搜素,新增收获单位收入报表

dev
qb 4 months ago
parent
commit
466067ae63
  1. 33
      src/api/distribution/VehicleArrivalManagement.js
  2. 19
      src/option/distribution/OrderInTransit.js
  3. 19
      src/option/distribution/addVehicleStowage.js
  4. 66
      src/option/reportforms/ConsigneeReport.js
  5. 66
      src/option/reportforms/SalesDepartmentIncomeReport.js
  6. 422
      src/views/desk/DataBoard.vue
  7. 11
      src/views/distribution/artery/AddVehicleStowage.vue
  8. 677
      src/views/distribution/artery/VehicleNodeImgs.vue
  9. 10
      src/views/distribution/artery/VehicleStowage.vue
  10. 10
      src/views/distribution/artery/addTripartiteTransfer.vue
  11. 46
      src/views/distribution/signfor/distributionSignfortreat.vue
  12. 2
      src/views/reportforms/ConsigneeReport.vue
  13. 2
      src/views/reportforms/SalesDepartmentIncomeReport.vue

33
src/api/distribution/VehicleArrivalManagement.js

@ -81,6 +81,39 @@ export const postFindLinePhoto = data => {
});
};
/**
* 编辑配载图片 -- 装车前
*/
export const postUploadLoadingPhoto = data => {
return request({
url: '/api/logpm-trunkline/carsLoad/uploadLoadingPhoto',
method: 'post',
data,
});
};
/**
* 编辑配载图片 -- 发车前
*/
export const postUploadStartPhoto = data => {
return request({
url: '/api/logpm-trunkline/carsLoad/uploadStartPhoto',
method: 'post',
data,
});
};
/**
* 编辑配载图片 -- 卸车前
*/
export const postUploadUnloadPhoto = data => {
return request({
url: '/api/logpm-trunkline/carsLoad/uploadUnloadPhoto',
method: 'post',
data,
});
};
/**
* 到车数据导出
*/

19
src/option/distribution/OrderInTransit.js

@ -201,6 +201,25 @@ export const columnList = [
fixed: false,
sortable: true,
},
{
prop: 'isTimeOutName',
label: '是否超时',
type: 3,
values: '',
width: '100',
checkarr: [
{
value: '0',
label: '否',
},
{
value: '1',
label: '是',
},
],
fixed: false,
sortable: true,
},
{
prop: 'warehouse',
label: '所在仓库',

19
src/option/distribution/addVehicleStowage.js

@ -260,6 +260,25 @@ export const columnList = [
isColumnMerge: true,
sortable: true,
},
{
prop: 'isTimeOutName',
label: '是否超时',
type: 3,
values: '',
width: '100',
checkarr: [
{
value: 0,
label: '否',
},
{
value: 1,
label: '是',
},
],
fixed: false,
sortable: true,
},
{
prop: 'goodsName',
label: '品类名称',

66
src/option/reportforms/ConsigneeReport.js

@ -70,8 +70,8 @@ export const columnList = [
head: false,
},
{
prop: 'waybillNum',
label: '运单数',
prop: 'nian',
label: '',
type: 1,
values: '',
width: '150',
@ -79,11 +79,10 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true, //开启统计
},
{
prop: 'num',
label: '件数',
prop: 'yue',
label: '',
type: 1,
values: '',
width: '150',
@ -91,23 +90,21 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true, //开启统计
},
{
prop: 'weight',
label: '重量',
prop: 'timeStr',
label: '制单时间',
type: 1,
values: '',
width: '200',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
isshowSummary: true, //开启统计
},
{
prop: 'volume',
label: '体积',
prop: 'waybillNum',
label: '运单数',
type: 1,
values: '',
width: '150',
@ -118,8 +115,8 @@ export const columnList = [
isshowSummary: true, //开启统计
},
{
prop: 'stockNum',
label: '到货件数',
prop: 'num',
label: '件数',
type: 1,
values: '',
width: '150',
@ -130,11 +127,11 @@ export const columnList = [
isshowSummary: true, //开启统计
},
{
prop: 'signNum',
label: '签收件数',
prop: 'weight',
label: '重量',
type: 1,
values: '',
width: '150',
width: '200',
checkarr: [],
fixed: false,
sortable: true,
@ -142,8 +139,8 @@ export const columnList = [
isshowSummary: true, //开启统计
},
{
prop: 'pickupFee',
label: '提货费',
prop: 'volume',
label: '体积',
type: 1,
values: '',
width: '150',
@ -154,8 +151,8 @@ export const columnList = [
isshowSummary: true, //开启统计
},
{
prop: 'freightFee',
label: '运费',
prop: 'stockNum',
label: '到货件数',
type: 1,
values: '',
width: '150',
@ -166,8 +163,8 @@ export const columnList = [
isshowSummary: true, //开启统计
},
{
prop: 'deliveryFee',
label: '送货费',
prop: 'signNum',
label: '签收件数',
type: 1,
values: '',
width: '150',
@ -178,8 +175,8 @@ export const columnList = [
isshowSummary: true, //开启统计
},
{
prop: 'warehouseManagementFee',
label: '仓库管理费',
prop: 'pickupFee',
label: '提货费',
type: 1,
values: '',
width: '150',
@ -190,8 +187,8 @@ export const columnList = [
isshowSummary: true, //开启统计
},
{
prop: 'storageFee',
label: '仓储费',
prop: 'freightFee',
label: '费',
type: 1,
values: '',
width: '150',
@ -202,8 +199,8 @@ export const columnList = [
isshowSummary: true, //开启统计
},
{
prop: 'nian',
label: '',
prop: 'deliveryFee',
label: '送货费',
type: 1,
values: '',
width: '150',
@ -211,10 +208,11 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true, //开启统计
},
{
prop: 'yue',
label: '',
prop: 'warehouseManagementFee',
label: '仓库管理费',
type: 1,
values: '',
width: '150',
@ -222,10 +220,11 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true, //开启统计
},
{
prop: 'timeStr',
label: '时间周期',
prop: 'storageFee',
label: '仓储费',
type: 1,
values: '',
width: '150',
@ -233,6 +232,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true, //开启统计
},
{
prop: 'handlingFee',

66
src/option/reportforms/SalesDepartmentIncomeReport.js

@ -59,8 +59,8 @@ export const columnList = [
head: false,
},
{
prop: 'waybillNum',
label: '运单数',
prop: 'nian',
label: '',
type: 1,
values: '',
width: '150',
@ -68,11 +68,10 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true, //开启统计
},
{
prop: 'num',
label: '件数',
prop: 'yue',
label: '',
type: 1,
values: '',
width: '150',
@ -80,23 +79,21 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true, //开启统计
},
{
prop: 'weight',
label: '重量',
prop: 'timeStr',
label: '制单时间',
type: 1,
values: '',
width: '200',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
isshowSummary: true, //开启统计
},
{
prop: 'volume',
label: '体积',
prop: 'waybillNum',
label: '运单数',
type: 1,
values: '',
width: '150',
@ -107,8 +104,8 @@ export const columnList = [
isshowSummary: true, //开启统计
},
{
prop: 'stockNum',
label: '到货件数',
prop: 'num',
label: '件数',
type: 1,
values: '',
width: '150',
@ -119,11 +116,11 @@ export const columnList = [
isshowSummary: true, //开启统计
},
{
prop: 'signNum',
label: '签收件数',
prop: 'weight',
label: '重量',
type: 1,
values: '',
width: '150',
width: '200',
checkarr: [],
fixed: false,
sortable: true,
@ -131,8 +128,8 @@ export const columnList = [
isshowSummary: true, //开启统计
},
{
prop: 'pickupFee',
label: '提货费',
prop: 'volume',
label: '体积',
type: 1,
values: '',
width: '150',
@ -143,8 +140,8 @@ export const columnList = [
isshowSummary: true, //开启统计
},
{
prop: 'freightFee',
label: '运费',
prop: 'stockNum',
label: '到货件数',
type: 1,
values: '',
width: '150',
@ -155,8 +152,8 @@ export const columnList = [
isshowSummary: true, //开启统计
},
{
prop: 'deliveryFee',
label: '送货费',
prop: 'signNum',
label: '签收件数',
type: 1,
values: '',
width: '150',
@ -167,8 +164,8 @@ export const columnList = [
isshowSummary: true, //开启统计
},
{
prop: 'warehouseManagementFee',
label: '仓库管理费',
prop: 'pickupFee',
label: '提货费',
type: 1,
values: '',
width: '150',
@ -179,8 +176,8 @@ export const columnList = [
isshowSummary: true, //开启统计
},
{
prop: 'storageFee',
label: '仓储费',
prop: 'freightFee',
label: '费',
type: 1,
values: '',
width: '150',
@ -191,8 +188,8 @@ export const columnList = [
isshowSummary: true, //开启统计
},
{
prop: 'nian',
label: '',
prop: 'deliveryFee',
label: '送货费',
type: 1,
values: '',
width: '150',
@ -200,10 +197,11 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true, //开启统计
},
{
prop: 'yue',
label: '',
prop: 'warehouseManagementFee',
label: '仓库管理费',
type: 1,
values: '',
width: '150',
@ -211,10 +209,11 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true, //开启统计
},
{
prop: 'timeStr',
label: '时间周期',
prop: 'storageFee',
label: '仓储费',
type: 1,
values: '',
width: '150',
@ -222,6 +221,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true, //开启统计
},
{
prop: 'handlingFee',

422
src/views/desk/DataBoard.vue

@ -164,8 +164,19 @@
<div>总计</div>
</div>
<div class="align_center">
<span class="data mr10">{{ details.openOrderIncomeInfo.totalFee || 0 }}</span>
<div
class="align_center"
@click="
() =>
handleDetails('openOrderIncomeInfo', '开单数据详情 - 总计 - 元', {
tip: '总计',
prop: 'totalFee',
})
"
>
<span class="data mr10 underline">{{
details.openOrderIncomeInfo.totalFee || 0
}}</span>
<span></span>
</div>
</div>
@ -179,8 +190,19 @@
<div>当月</div>
</div>
<div class="align_center">
<span class="data mr10">{{ details.openOrderIncomeInfo.monthFee || 0 }}</span>
<div
class="align_center"
@click="
() =>
handleDetails('openOrderIncomeInfo', '开单数据详情 - 当月 - 元', {
tip: '当月',
prop: 'monthFee',
})
"
>
<span class="data mr10 underline">{{
details.openOrderIncomeInfo.monthFee || 0
}}</span>
<span></span>
</div>
</div>
@ -193,8 +215,19 @@
<div>当日</div>
</div>
<div class="align_center">
<span class="data mr10">{{ details.openOrderIncomeInfo.dayFee || 0 }}</span>
<div
class="align_center"
@click="
() =>
handleDetails('openOrderIncomeInfo', '开单数据详情 - 当日 - 元', {
tip: '当日',
prop: 'dayFee',
})
"
>
<span class="data mr10 underline">{{
details.openOrderIncomeInfo.dayFee || 0
}}</span>
<span></span>
</div>
</div>
@ -206,9 +239,18 @@
<!-- -->
<div class="flex-c-sb">
<!-- 干线 -->
<div class="item flex1 mr10">
<div
class="item flex1 mr10"
@click="
() =>
handleDetails('openOrderIncomeInfo', '开单数据详情 - 干线 - 月 - 元', {
tip: '干线 - 月',
prop: 'monthTrunklineFee',
})
"
>
<div>
<span class="data mr5px">{{
<span class="data mr5px underline">{{
details.openOrderIncomeInfo.monthTrunklineFee || 0
}}</span>
<span></span>
@ -217,9 +259,18 @@
<div>干线 - </div>
</div>
<!-- 仓储 -->
<div class="item flex1 mr10">
<div
class="item flex1 mr10"
@click="
() =>
handleDetails('openOrderIncomeInfo', '开单数据详情 - 仓储 - 月 - 元', {
tip: '仓储 - 月',
prop: 'monthWarehouseFee',
})
"
>
<div>
<span class="data mr5px">{{
<span class="data mr5px underline">{{
details.openOrderIncomeInfo.monthWarehouseFee || 0
}}</span>
<span></span>
@ -228,9 +279,18 @@
<div>仓储 - </div>
</div>
<!-- 配送 -->
<div class="item flex1 mr10">
<div
class="item flex1 mr10"
@click="
() =>
handleDetails('openOrderIncomeInfo', '开单数据详情 - 配送 - 月 - 元', {
tip: '配送 - 月',
prop: 'monthDistributionFee',
})
"
>
<div>
<span class="data mr5px">{{
<span class="data mr5px underline">{{
details.openOrderIncomeInfo.monthDistributionFee || 0
}}</span>
<span></span>
@ -239,9 +299,18 @@
<div>配送 - </div>
</div>
<!-- 提货 -->
<div class="item flex1 mr10">
<div
class="item flex1 mr10"
@click="
() =>
handleDetails('openOrderIncomeInfo', '开单数据详情 - 提货 - 月 - 元', {
tip: '提货 - 月',
prop: 'monthBillladingFee',
})
"
>
<div>
<span class="data mr5px">{{
<span class="data mr5px underline">{{
details.openOrderIncomeInfo.monthBillladingFee || 0
}}</span>
<span></span>
@ -250,9 +319,18 @@
<div>提货 - </div>
</div>
<!-- 安装 -->
<div class="item flex1">
<div
class="item flex1"
@click="
() =>
handleDetails('openOrderIncomeInfo', '开单数据详情 - 安装 - 月 - 元', {
tip: '安装 - 月',
prop: 'monthInstallFee',
})
"
>
<div>
<span class="data mr5px">{{
<span class="data mr5px underline">{{
details.openOrderIncomeInfo.monthInstallFee || 0
}}</span>
<span></span>
@ -265,9 +343,18 @@
<!-- -->
<div class="flex-c-sb mt10">
<!-- 干线 -->
<div class="item flex1 mr10">
<div
class="item flex1 mr10"
@click="
() =>
handleDetails('openOrderIncomeInfo', '开单数据详情 - 干线 - 日 - 元', {
tip: '干线 - 日',
prop: 'dayTrunklineFee',
})
"
>
<div>
<span class="data mr5px">{{
<span class="data mr5px underline">{{
details.openOrderIncomeInfo.dayTrunklineFee || 0
}}</span>
<span></span>
@ -276,9 +363,18 @@
<div>干线 - </div>
</div>
<!-- 仓储 -->
<div class="item flex1 mr10">
<div
class="item flex1 mr10"
@click="
() =>
handleDetails('openOrderIncomeInfo', '开单数据详情 - 仓储 - 日 - 元', {
tip: '仓储 - 日',
prop: 'dayWarehouseFee',
})
"
>
<div>
<span class="data mr5px">{{
<span class="data mr5px underline">{{
details.openOrderIncomeInfo.dayWarehouseFee || 0
}}</span>
<span></span>
@ -287,9 +383,18 @@
<div>仓储 - </div>
</div>
<!-- 配送 -->
<div class="item flex1 mr10">
<div
class="item flex1 mr10"
@click="
() =>
handleDetails('openOrderIncomeInfo', '开单数据详情 - 配送 - 日 - 元', {
tip: '配送 - 日',
prop: 'dayDistributionFee',
})
"
>
<div>
<span class="data mr5px">{{
<span class="data mr5px underline">{{
details.openOrderIncomeInfo.dayDistributionFee || 0
}}</span>
<span></span>
@ -298,9 +403,18 @@
<div>配送 - </div>
</div>
<!-- 提货 -->
<div class="item flex1 mr10">
<div
class="item flex1 mr10"
@click="
() =>
handleDetails('openOrderIncomeInfo', '开单数据详情 - 提货 - 日 - 元', {
tip: '提货 - 日',
prop: 'dayBillladingFee',
})
"
>
<div>
<span class="data mr5px">{{
<span class="data mr5px underline">{{
details.openOrderIncomeInfo.dayBillladingFee || 0
}}</span>
<span></span>
@ -309,9 +423,18 @@
<div>提货 - </div>
</div>
<!-- 安装 -->
<div class="item flex1">
<div
class="item flex1"
@click="
() =>
handleDetails('openOrderIncomeInfo', '开单数据详情 - 安装 - - 元', {
tip: '安装 - ',
prop: 'dayInstallFee',
})
"
>
<div>
<span class="data mr5px">{{
<span class="data mr5px underline">{{
details.openOrderIncomeInfo.dayInstallFee || 0
}}</span>
<span></span>
@ -629,9 +752,22 @@
<!-- 数据 -->
<div class="border pd10 flex-c-sb">
<div class="text_center">
<div
class="text_center"
@click="
() =>
handleDetails(
'trunklineHandOrderDataInfo',
'干线待发运在库数据 - 运单总数 - 单',
{
tip: '运单总数',
prop: 'waybillNum',
}
)
"
>
<div class="data_box orange mb10">
<div class="data mr5px">
<div class="data mr5px underline">
{{ details.trunklineHandOrderDataInfo.waybillNum || 0 }}
</div>
<div class=""></div>
@ -641,9 +777,22 @@
</div>
</div>
<div class="text_center">
<div
class="text_center"
@click="
() =>
handleDetails(
'trunklineHandOrderDataInfo',
'干线待发运在库数据 - 在库总件数 - 件',
{
tip: '在库总件数',
prop: 'handleNum',
}
)
"
>
<div class="data_box orange mb10">
<div class="data mr5px">
<div class="data mr5px underline">
{{ details.trunklineHandOrderDataInfo.handleNum || 0 }}
</div>
<div class=""></div>
@ -653,9 +802,22 @@
</div>
</div>
<div class="text_center">
<div
class="text_center"
@click="
() =>
handleDetails(
'trunklineHandOrderDataInfo',
'干线待发运在库数据 - 在库总重量 - kg',
{
tip: '在库总重量',
prop: 'handleWeight',
}
)
"
>
<div class="data_box orange mb10">
<div class="data mr5px">
<div class="data mr5px underline">
{{ details.trunklineHandOrderDataInfo.handleWeight || 0 }}
</div>
<div class="">kg</div>
@ -665,9 +827,22 @@
</div>
</div>
<div class="text_center">
<div
class="text_center"
@click="
() =>
handleDetails(
'trunklineHandOrderDataInfo',
'干线待发运在库数据 - 在库总方数 - m³',
{
tip: '在库总方数',
prop: 'handleVolume',
}
)
"
>
<div class="data_box orange mb10">
<div class="data mr5px">
<div class="data mr5px underline">
{{ details.trunklineHandOrderDataInfo.handleVolume || 0 }}
</div>
<div class=""></div>
@ -1842,15 +2017,51 @@ const initOpenOrderData = async () => {
/** 请求开单收入 */
const initOpenOrderIncome = async () => {
const _obj: any = {};
const _keyArr = [
'totalFee',
'monthFee',
'dayFee',
'monthTrunklineFee',
'monthWarehouseFee',
'monthDistributionFee',
'monthBillladingFee',
'monthInstallFee',
'dayTrunklineFee',
'dayWarehouseFee',
'dayDistributionFee',
'dayBillladingFee',
'dayInstallFee',
];
for (let i = 0; i < _keyArr.length; i++) {
const value = _keyArr[i];
_obj[value] = 0;
}
_obj.list = [];
try {
details.loadingObj.openOrderIncome = true;
const res = await postOpenOrderIncome({});
const { code, data } = res.data;
if (code !== 200) return;
details.openOrderIncomeInfo = data || {};
for (let i = 0; i < data.length; i++) {
const value = data[i];
for (let i = 0; i < _keyArr.length; i++) {
const key = _keyArr[i];
value[key] = isNumber(value[key]) ? Number(value[key]) : 0;
_obj[key] = computeNumber(_obj[key], '+', value[key]).result;
}
_obj.list.push(value);
}
} catch (error) {
console.log('error :>> ', error);
} finally {
details.openOrderIncomeInfo = _obj;
details.loadingObj.openOrderIncome = false;
}
};
@ -1887,15 +2098,37 @@ const initHandOrderData = async () => {
/** 请求干线发运数据 */
const initTrunklineHandOrderData = async () => {
const _obj: any = {};
const _keyArr = ['waybillNum', 'handleNum', 'handleWeight', 'handleVolume'];
for (let i = 0; i < _keyArr.length; i++) {
const value = _keyArr[i];
_obj[value] = 0;
}
_obj.list = [];
try {
details.loadingObj.trunklineHandOrderData = true;
const res = await postTrunklineHandOrderData({});
const { code, data } = res.data;
if (code !== 200) return;
details.trunklineHandOrderDataInfo = data || {};
for (let i = 0; i < data.length; i++) {
const value = data[i];
for (let i = 0; i < _keyArr.length; i++) {
const key = _keyArr[i];
value[key] = isNumber(value[key]) ? Number(value[key]) : 0;
_obj[key] = computeNumber(_obj[key], '+', value[key]).result;
}
_obj.list.push(value);
}
} catch (error) {
console.log('error :>> ', error);
} finally {
details.trunklineHandOrderDataInfo = _obj;
details.loadingObj.trunklineHandOrderData = false;
}
};
@ -2431,117 +2664,13 @@ type OptionObjType = { prop: string; tip: string };
//
const colors = ['#008CBA', '#808080']; //
// /** */
// const getProportion = (value: number, total: number) => {
// if (total === 0) return '0%';
// if (!isNumber(value)) return '0%';
// return computeNumber(Number(value), '/', total).next('*', 100).result.toFixed(2) + '%';
// };
/** 获取百分比 */
const getProportion = (value: number) => {
if (!isNumber(value)) return '0%';
return (value * 100).toFixed(2) + '%';
};
// /** */
// const handleShowEcharts = (data: any[], title: string, optionObj: OptionObjType) => {
// console.log('data :>> ', data);
// console.log('title :>> ', title);
// console.log('optionObj :>> ', optionObj);
// if (getObjType(data) !== 'array') return;
// const _arr = [];
// let _total = 0;
// for (let i = 0; i < data.length; i++) {
// const value = data[i];
// value[optionObj.prop] = isNumber(value[optionObj.prop]) ? Number(value[optionObj.prop]) : 0;
// _total = computeNumber(_total, '+', value[optionObj.prop]).result;
// }
// for (let i = 0; i < data.length; i++) {
// const value = data[i];
// let isContinue = false;
// for (let j = 0; j < _arr.length; j++) {
// const item = _arr[j];
// if (item.value > value[optionObj.prop]) continue;
// _arr.splice(j, 0, {
// name: value.warehouseName + ' - ' + getProportion(value[optionObj.prop], _total),
// value: value[optionObj.prop],
// });
// isContinue = true;
// break;
// }
// if (isContinue) continue;
// _arr.push({
// name: value.warehouseName + ' - ' + getProportion(value[optionObj.prop], _total),
// value: value[optionObj.prop],
// });
// }
// nextTick(() => {
// // Echarts
// const chartDom = document.getElementById('echartBox');
// const myChart = echarts.init(chartDom);
// const option = {
// title: {
// text: title,
// // subtext: 'Fake Data',
// left: 'right',
// },
// tooltip: {
// trigger: 'item',
// },
// legend: {
// orient: 'vertical',
// left: 'left',
// },
// series: [
// {
// name: optionObj.tip,
// // --
// type: 'bar',
// // radius: '50%',
// //
// data: _arr,
// //
// emphasis: {
// itemStyle: {
// shadowBlur: 10,
// shadowOffsetX: 0,
// shadowColor: 'rgba(0, 0, 0, 0.5)',
// },
// label: {
// show: true,
// fontSize: 20,
// fontWeight: 'bold',
// },
// },
// //
// radius: ['30%', '70%'],
// // avoidLabelOverlap: false,
// //
// // padAngle: 2,
// //
// // minShowLabelAngle: 5,
// //
// left: '20%',
// },
// ],
// };
// option && myChart.setOption(option);
// });
// };
//
const handleShowEcharts = (
data: any[],
@ -2721,6 +2850,11 @@ const handleDetails = async (type, title, optionObj: OptionObjType) => {
res = await postOpenOrderDataByWarehouseId({});
break;
//
case 'openOrderIncomeInfo':
handleShowEcharts(details.openOrderIncomeInfo.list, title, optionObj);
break;
//
case 'allocationDataColumn':
res = await postAllocationDataByWarehouseId({});
@ -2731,6 +2865,10 @@ const handleDetails = async (type, title, optionObj: OptionObjType) => {
res = await postHandOrderDataByWarehouseId({});
break;
case 'trunklineHandOrderDataInfo':
handleShowEcharts(details.trunklineHandOrderDataInfo.list, title, optionObj);
break;
// 线
case 'trunklineCarsDataColumn':
handleShowEcharts(details.trunklineCarsDataInfo.list, title, optionObj);

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

@ -423,6 +423,7 @@
:columnList="details.columnList"
:tableData="details.data"
@inputTxt="inputsc"
@selectCheck="selectsc"
:loading="loadingObj.oldListLoading"
@selection="selectionChange"
:tableRowClassName="handleSetRowClassName"
@ -815,6 +816,8 @@ import {
debounce,
handleClearTableQuery,
getObjType,
handleSelectQuery,
handleTranslationDataSeclect,
} from '@/utils/util';
import {
columnList,
@ -1155,6 +1158,7 @@ const initOriginWarehouseOrder = debounce(async (params = {}) => {
const { code, data } = res.data;
if (code !== 200) return;
details.data = data.records;
handleTranslationDataSeclect(details.data, details.columnList);
details.page.total = data.total;
} catch (error) {
console.log('error :>> ', error);
@ -1560,12 +1564,7 @@ const btnsc = () => {};
/** 表格表头下拉框选择 */
const selectsc = (index, row) => {
details.query[row.prop] = index;
if (!index && index !== 0) delete details.query[row.prop];
if (row.prop === 'certificateTypeName') {
details.query['certificateType'] = index;
if (!index) delete details.query['certificateType'];
}
handleSelectQuery(index, row, details.query);
initOriginWarehouseOrder();
};

677
src/views/distribution/artery/VehicleNodeImgs.vue

@ -6,33 +6,24 @@
<div class="VehicleLineImgs_line">
<div
v-for="(item, index) in details.loadLineArr"
:key="item.nodeId"
:class="{
VehicleLineNode_item: true,
notActive: false,
choose: false,
}"
>
<div class="VehicleLineNode_item_container">
<!-- <el-icon size="20px" color=""><Box /></el-icon> -->
<el-icon size="20px"><CircleCheck /></el-icon>
<span class="VehicleLineNode_item_title">龙泉仓</span>
</div>
<el-icon><ArrowRight /></el-icon>
</div>
<div
:class="{
VehicleLineNode_item: true,
notActive: false,
choose: true,
choose: details.activeIndex === index,
}"
@click="() => handleCheckNode(item, index)"
>
<div class="VehicleLineNode_item_container">
<el-icon size="20px" color=""><Box /></el-icon>
<span class="VehicleLineNode_item_title">龙泉仓</span>
<span class="VehicleLineNode_item_title">{{ item.nodeName }}</span>
</div>
<template v-if="index !== details.loadLineArr.length - 1">
<el-icon><ArrowRight /></el-icon>
</template>
</div>
</div>
@ -43,10 +34,20 @@
<!-- 图片容器 -->
<div class="VehicleLineImgs_container">
<div class="VehicleLineImgs_container_title">发车前图片</div>
<div class="mb20 align-center">
<div class="VehicleLineImgs_container_title">装车前图片</div>
<el-button
type="primary"
icon="edit"
@click="() => handleEdit('beforeLoad', beforeLoadImgArr, '装车前图片')"
>
编辑
</el-button>
</div>
<div
class="VehicleLineImgs_container_list"
v-for="(item, index) in details.beforeLoadImgArr"
class="VehicleLineImgs_container_list mb20"
v-for="(item, index) in beforeLoadImgArr"
:key="item.type + '-' + item.position"
>
<div class="title">{{ item.title }}</div>
@ -61,24 +62,146 @@
:max-scale="7"
:min-scale="0.2"
:preview-src-list="item.imgArr.map(val => val.url)"
:initial-index="index"
:initial-index="i"
fit="cover"
/>
</div>
</div>
<div class="VehicleLineImgs_container_title">发车前图片</div>
<div class="VehicleLineImgs_container_list">
<div class="VehicleLineImgs_container_list_item"></div>
<div class="mb20 align-center">
<div class="VehicleLineImgs_container_title">发车前图片</div>
<el-button
type="primary"
icon="edit"
@click="() => handleEdit('boforeStart', boforeStartImgArr, '发车前图片')"
>
编辑
</el-button>
</div>
<div
class="VehicleLineImgs_container_list mb20"
v-for="(item, index) in boforeStartImgArr"
:key="item.type + '-' + item.position"
>
<div class="title">{{ item.title }}</div>
<div class="VehicleLineImgs_container_title">发车前图片</div>
<div class="VehicleLineImgs_container_list">
<div class="VehicleLineImgs_container_list_item"></div>
<div class="item">
<el-image
v-for="(value, i) in item.imgArr"
:key="value.url"
style="width: 150px; height: 150px; margin: 5px; border-radius: 5px"
:src="value.url"
:zoom-rate="1.2"
:max-scale="7"
:min-scale="0.2"
:preview-src-list="item.imgArr.map(val => val.url)"
:initial-index="i"
fit="cover"
/>
</div>
</div>
<template v-if="details.activeIndex !== 0">
<div class="mb20 align-center">
<div class="VehicleLineImgs_container_title">卸车前图片</div>
<el-button
type="primary"
icon="edit"
@click="() => handleEdit('beforeUnload', beforeUnloadImgArr, '卸车前图片')"
>
编辑
</el-button>
</div>
<div
class="VehicleLineImgs_container_list mb20"
v-for="(item, index) in beforeUnloadImgArr"
:key="item.type + '-' + item.position"
>
<div class="title">{{ item.title }}</div>
<div class="item">
<el-image
v-for="(value, i) in item.imgArr"
:key="value.url"
style="width: 150px; height: 150px; margin: 5px; border-radius: 5px"
:src="value.url"
:zoom-rate="1.2"
:max-scale="7"
:min-scale="0.2"
:preview-src-list="item.imgArr.map(val => val.url)"
:initial-index="i"
fit="cover"
/>
</div>
</div>
</template>
</div>
</div>
</basic-container>
<!-- 编辑图片 -->
<el-dialog v-model="details.popUpShow.editImg" :title="details.title" width="70%">
<div v-loading="details.loadingObj.imgEdit">
<div
class="VehicleLineImgs_container_list mb20"
v-for="(item, index) in details.editFormList"
:key="item.type + '-' + item.position"
>
<div class="title">{{ item.title }}</div>
<div class="item">
<div class="imgBox" v-for="(value, i) in item.imgArr" :key="value.url">
<el-image
style="width: 150px; height: 150px; margin: 5px; border-radius: 5px"
:src="value.url"
v-loading="!value.imgUrl"
:zoom-rate="1.2"
:max-scale="7"
:min-scale="0.2"
:preview-src-list="item.imgArr.map(val => val.url)"
:initial-index="i"
fit="cover"
/>
<div class="remove" @click="() => item.imgArr.splice(i, 1)">
<el-icon size="16" color="#f00"><DeleteFilled /></el-icon>
</div>
</div>
<div class="add">
<el-upload
list-type="picture-card"
v-model:file-list="item.imgArr"
:show-file-list="false"
:action="'/api/blade-resource/oss/endpoint/put-file'"
:on-success="file => handleUpLoadSuccess(file, item)"
:before-upload="file => handleBeforeUpload(file, item)"
multiple
:headers="details.headers"
>
<el-icon class="avatar-uploader-icon"><Plus /></el-icon>
</el-upload>
</div>
</div>
</div>
</div>
<template #footer>
<div class="dialog-footer">
<el-button @click="details.popUpShow.editImg = false" icon="CircleClose">关闭</el-button>
<el-button
type="primary"
:loading="details.loadingObj.imgEdit"
icon="Position"
@click="handleEditSubmit"
>
提交
</el-button>
</div>
</template>
</el-dialog>
</template>
<script setup lang="ts">
@ -86,60 +209,160 @@ import { ref, reactive, toRefs, computed, onMounted, nextTick } from 'vue';
/** 获取字典 */
import { getDictionaryBiz } from '@/api/system/dict';
import { deepClone, getObjType, ChecksWhetherTheWarehouseIsSelected } from '@/utils/util';
import { postFindLinePhoto } from '@/api/distribution/VehicleArrivalManagement';
import {
postFindLinePhoto,
postUploadLoadingPhoto,
postUploadStartPhoto,
postUploadUnloadPhoto,
} from '@/api/distribution/VehicleArrivalManagement';
import { useStore } from 'vuex';
import { useRouter, useRoute } from 'vue-router';
import { ElMessage, ElMessageBox } from 'element-plus';
import { compressImageBlob } from '@/components/IMGcompressor/imgcompressor.js';
import { getToken } from '@/utils/auth';
const $route = useRoute();
const $router = useRouter();
const $store = useStore();
type ImgArr =
| [
{
//
title: string;
//
type: string;
//
position: string;
//
imgArr:
| [
{
url: string;
}
]
| [];
}
]
| [];
type ImgArr = {
//
title: string;
//
type: number;
//
position: number;
//
imgArr: {
id: string;
url: string;
imgUrl: string;
}[];
}[];
type LoadItme = {
nodeName?: string;
nodeId?: string;
/** 装车前图片 */
beforeLoadImgArr?: ImgArr;
/** 发车前图片 */
boforeStartImgArr?: ImgArr;
/** 卸车完成图片 */
beforeUnloadImgArr?: ImgArr;
};
const details = reactive({
loadingObj: {
pageLoading: false,
imgEdit: false,
},
nodeImgArr: [],
/** 装车前图片 */
beforeLoadImgArr: [
{
title: '123',
type: '1',
position: '2',
imgArr: [
{
url: '',
},
],
},
] as ImgArr,
/** 发车前图片 */
boforeStartImgArr: [] as ImgArr,
/** 卸车完成图片 */
confirmUnloadImgArr: [] as ImgArr,
popUpShow: {
editImg: false,
},
/** 弹窗标题 */
title: '',
loadLineArr: [] as LoadItme[],
activeIndex: 0,
/** 提交类型 */
editType: 'beforeLoad' as 'beforeLoad' | 'boforeStart' | 'beforeUnload',
/** 回显数据 */
editFormList: [] as ImgArr,
/** 克隆数据 */
cloneImgList: [],
/** 类型字典 */
typeOption: {
'10': '车厢卫生',
'20': '盖雨棚前',
'21': '盖雨棚后',
'30': '卸车前车辆照片',
'31': '防护措施',
},
/** 位置字典 */
positionOption: {
'1': '前',
'2': '后',
'3': '左',
'4': '右',
},
/** 头部 */
headers: {
'Blade-Auth': 'bearer ' + getToken(),
},
});
//
const beforeLoadImgArr = computed<ImgArr>((): ImgArr => {
const _arr = details.loadLineArr[details.activeIndex]?.beforeLoadImgArr;
return getObjType(_arr) === 'array' ? _arr : [];
});
//
const boforeStartImgArr = computed<ImgArr>((): ImgArr => {
const _arr = details.loadLineArr[details.activeIndex]?.boforeStartImgArr;
return getObjType(_arr) === 'array' ? _arr : [];
});
//
const beforeUnloadImgArr = computed<ImgArr>((): ImgArr => {
const _arr = details.loadLineArr[details.activeIndex]?.beforeUnloadImgArr;
return getObjType(_arr) === 'array' ? _arr : [];
});
//
const handleAddImg = (arr, addArr, isHavePosition = true) => {
for (let i = 0; i < arr.length; i++) {
const val = arr[i];
let isContinue = false;
for (let j = 0; j < addArr.length; j++) {
const item = addArr[j];
console.log(
isHavePosition
? item.type + '' === val.type + ''
: item.type + '' + item.position === val.type + '' + val.position
);
if (
isHavePosition
? item.type + '' + item.position === val.type + '' + val.position
: item.type + '' === val.type + ''
) {
item.imgArr.push({
url: val.url,
id: val.id,
imgUrl: val.url,
});
isContinue = true;
break;
}
}
if (isContinue) continue;
let title = isHavePosition
? details.typeOption[val.type + ''] + ' - ' + details.positionOption[val.position]
: details.typeOption[val.type + ''];
const _obj = {
//
title,
//
type: val.type,
//
position: val.position,
imgArr: [{ url: val.url, id: val.id, imgUrl: val.url }],
};
addArr.push(_obj);
}
};
/** 配载图片显示 */
const initImgList = async () => {
try {
@ -147,23 +370,127 @@ const initImgList = async () => {
const res = await postFindLinePhoto({ loadId: $route.query.loadId });
const { code, data } = res.data;
if (code !== 200 || getObjType(data) !== 'array') return;
details.loadLineArr = [];
for (let i = 0; i < data.length; i++) {
const value = data[i];
const { loadingObject, startObject, unloadObject } = value;
const { loadingObject, startObject, unloadObject, carsLoadLineEntity } = value;
const _obj: LoadItme = {
nodeId: '',
nodeName: '',
beforeLoadImgArr: [
{
title: '车厢卫生',
type: 10,
position: 1,
imgArr: [],
},
],
boforeStartImgArr: [
{
title: '盖雨棚前 - 左',
type: 20,
position: 3,
imgArr: [],
},
{
title: '盖雨棚前 - 右',
type: 20,
position: 4,
imgArr: [],
},
{
title: '盖雨棚前 - 后',
type: 20,
position: 2,
imgArr: [],
},
{
title: '盖雨棚后 - 左',
type: 21,
position: 3,
imgArr: [],
},
{
title: '盖雨棚后 - 右',
type: 21,
position: 4,
imgArr: [],
},
{
title: '盖雨棚后 - 后',
type: 21,
position: 2,
imgArr: [],
},
],
beforeUnloadImgArr: [
{
title: '卸车前车辆照片 - 左',
type: 20,
position: 3,
imgArr: [],
},
{
title: '卸车前车辆照片 - 右',
type: 20,
position: 4,
imgArr: [],
},
{
title: '卸车前车辆照片 - 后',
type: 20,
position: 2,
imgArr: [],
},
{
title: '防护措施 - 左',
type: 21,
position: 3,
imgArr: [],
},
{
title: '防护措施 - 右',
type: 21,
position: 4,
imgArr: [],
},
{
title: '防护措施 - 后',
type: 21,
position: 2,
imgArr: [],
},
],
};
//
if (getObjType(carsLoadLineEntity) === 'object') {
_obj.nodeName = carsLoadLineEntity.nodeName;
_obj.nodeId = carsLoadLineEntity.nodeId;
} else {
ElMessage.warning('存在异常节点信息');
return;
}
//
if (getObjType(loadingObject) === 'object') {
} else details.beforeLoadImgArr = [];
if (getObjType(loadingObject) === 'array') {
handleAddImg(loadingObject, _obj.beforeLoadImgArr, false);
}
//
if (getObjType(startObject) === 'object') {
} else details.beforeLoadImgArr = [];
if (getObjType(startObject) === 'array') {
handleAddImg(startObject, _obj.boforeStartImgArr);
}
//
if (getObjType(unloadObject) === 'array') {
handleAddImg(unloadObject, _obj.beforeUnloadImgArr);
}
//
if (getObjType(unloadObject) === 'object') {
} else details.beforeLoadImgArr = [];
details.loadLineArr.push(_obj);
}
console.log(' details.loadLineArr :>> ', details.loadLineArr);
} catch (error) {
console.log('error :>> ', error);
} finally {
@ -172,6 +499,150 @@ const initImgList = async () => {
};
initImgList();
const handleCheckNode = (item, index) => {
details.activeIndex = index;
};
const handleEdit = (type, arr, title) => {
details.title = title;
console.log('arr :>> ', arr);
details.editType = type;
details.editFormList = deepClone([...arr]);
const _arr = [];
for (let i = 0; i < details.editFormList.length; i++) {
const value = details.editFormList[i];
for (let j = 0; j < value.imgArr.length; j++) {
const item = value.imgArr[j];
_arr.push({ ...value, ...item });
}
}
details.cloneImgList = _arr;
details.popUpShow.editImg = true;
};
/** 上传前 */
const handleBeforeUpload = async (file, item) => {
try {
console.log('file :>> ', file);
console.log('item :>> ', item);
const isJPG = file.type === 'image/jpeg';
const isPNG = file.type === 'image/png';
const isLt2M = file.size / 1024 / 1024 < 2;
if (!isJPG && !isPNG) {
ElMessage.warning('上传图片只能是 JPG 或 PNG 格式!');
return false;
}
if (!isLt2M) {
ElMessage.warning('上传图片大小不能超过 2MB!');
return false;
}
item.loading = true;
const res = await compressImageBlob(file);
console.log('res :>> ', res);
return res;
} catch (error) {
console.log('error :>> ', error);
}
};
/** 上传成功 */
const handleUpLoadSuccess = (file, item) => {
console.log('file :>> ', file);
console.log('item.imgArr :>> ', item.imgArr);
const { code, data } = file;
if (code !== 200) return;
for (let i = 0; i < item.imgArr.length; i++) {
const val = item.imgArr[i];
if (val.name !== data.originalName) continue;
val.imgUrl = data.link;
}
};
/** 编辑提交 */
const handleEditSubmit = async () => {
try {
details.loadingObj.imgEdit = true;
const submitData = {
loadId: $route.query.loadId,
removeUrlList: [],
addUrlList: [],
};
const _cloneArr = deepClone(details.cloneImgList);
for (let i = 0; i < details.editFormList.length; i++) {
const value = details.editFormList[i];
for (let j = 0; j < value.imgArr.length; j++) {
const item = value.imgArr[j];
// id,
if (item.id) {
for (let index = 0; index < _cloneArr.length; index++) {
const val = _cloneArr[index];
if (item.id !== val.id) continue;
_cloneArr.splice(index, 1);
break;
}
continue;
}
if (!item.imgUrl) return ElMessage.warning('存在未上传完成的图片,请等待上传完成或移除');
submitData.addUrlList.push({
type: value.type,
position: value.position,
url: item.imgUrl,
});
}
}
submitData.removeUrlList = _cloneArr.map(val => val.id);
let res: any = { data: {} };
switch (details.editType) {
case 'beforeLoad':
res = await postUploadLoadingPhoto(submitData);
break;
case 'boforeStart':
res = await postUploadStartPhoto(submitData);
break;
case 'boforeStart':
res = await postUploadUnloadPhoto(submitData);
break;
default:
break;
}
const { code, msg } = res.data;
if (code !== 200) {
ElMessage.warning(msg);
return;
}
details.popUpShow.editImg = false;
ElMessage.success(msg);
initImgList();
} catch (error) {
console.log('error :>> ', error);
} finally {
details.loadingObj.imgEdit = false;
}
};
</script>
<style lang="scss" scoped>
@ -184,9 +655,11 @@ initImgList();
&::before {
content: '';
width: 3px;
height: 20px;
background-color: var(--el-color-primary);
width: 20px;
// height: 20px;
height: 1px;
// background-color: var(--el-color-primary);
background-color: #ccc;
margin-right: 10px;
}
@ -194,7 +667,8 @@ initImgList();
content: '';
height: 1px;
flex: 1;
background-color: var(--el-color-primary);
// background-color: var(--el-color-primary);
background-color: #ccc;
margin-left: 10px;
}
}
@ -292,8 +766,13 @@ initImgList();
@extend .VehicleLineImgs_title;
font-size: 16px;
&:first-child {
margin-top: 20px;
// &:first-child {
// margin-top: 20px;
// }
&::before {
width: 2px;
height: 20px;
}
&::after {
@ -303,7 +782,7 @@ initImgList();
}
.VehicleLineImgs_container_list {
padding: 20px;
padding: 0 20px;
.title {
@extend .VehicleLineImgs_container_title;
@ -316,6 +795,38 @@ initImgList();
.item {
display: flex;
flex-wrap: wrap;
.imgBox {
position: relative;
.remove {
$size: 30px;
width: $size;
height: $size;
border-radius: 50%;
background-color: #fff;
transition: all 0.5s;
opacity: 0;
position: absolute;
top: 10px;
right: 10px;
display: flex;
align-items: center;
justify-content: center;
cursor: pointer;
z-index: 2001;
}
&:hover {
.remove {
opacity: 1;
}
}
}
.add {
margin: 5px;
}
}
}
</style>

10
src/views/distribution/artery/VehicleStowage.vue

@ -1617,6 +1617,16 @@ const searchOrder = async () => {
details.loadingObj.searchOrder = false;
}
};
const handleShowVehicleImgs = ({ row }) => {
$router.push({
path: '/distribution/artery/VehicleNodeImgs',
query: {
name: `${row.carsNo} - 节点图片`,
loadId: row.id,
},
});
};
</script>
<style scoped lang="scss">

10
src/views/distribution/artery/addTripartiteTransfer.vue

@ -496,6 +496,8 @@ import {
debounce,
deepClone,
getObjType,
handleTranslationDataSeclect,
handleSelectQuery,
} from '@/utils/util';
import { columnList, newColumnList } from '@/option/distribution/addVehicleStowage';
import {
@ -883,6 +885,7 @@ const initOriginWarehouseOrder = debounce(async function (params = {}) {
const { code, data } = res.data;
if (code !== 200) return;
details.oldData = data.records;
handleTranslationDataSeclect(details.oldData, details.columnList);
details.oldPage.total = data.total;
} catch (error) {
console.log('error :>> ', error);
@ -1016,12 +1019,7 @@ const timesc = (index, row) => {
/** 表格表头下拉框选择 */
const selectsc = (index, row) => {
details.query[row.prop] = index;
if (!index && index !== 0) delete details.query[row.prop];
if (row.prop === 'certificateTypeName') {
details.query['certificateType'] = index;
if (!index) delete details.query['certificateType'];
}
handleSelectQuery(index, row, details.query);
initOriginWarehouseOrder();
};

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

@ -584,7 +584,13 @@ import { mapGetters } from 'vuex';
import { getDictionaryBiz } from '@/api/system/dict';
import dayjs from 'dayjs';
import { getDeliveryListExport } from '@/api/distribution/distributionDeliveryList';
import { downloadXls, handleClearTableQuery, setNodeHeight } from '@/utils/util';
import {
downloadXls,
handleClearTableQuery,
handleSelectQuery,
handleTranslationDataSeclect,
setNodeHeight,
} from '@/utils/util';
import { getToken } from '@/utils/auth';
import { ElMessage, ElMessageBox } from 'element-plus';
export default {
@ -1005,6 +1011,25 @@ export default {
fixed: false,
sortable: true,
},
{
prop: 'isTimeOutName',
label: '是否超时',
type: 3,
values: '',
width: '100',
checkarr: [
{
value: '0',
label: '否',
},
{
value: '1',
label: '是',
},
],
fixed: false,
sortable: true,
},
{
prop: '',
label: '操作',
@ -2346,14 +2371,7 @@ export default {
console.log(index, row);
},
selectsc(index, row) {
this.query[row.prop] = index;
if (!index) {
delete this.query[row.prop];
}
if (row.prop === 'deliveryTypeName') {
this.query.deliveryType = index;
if (!index) delete this.query.deliveryType;
}
handleSelectQuery(index, row, this.query);
this.onLoad(this.page);
},
timesc(index, row) {
@ -2538,21 +2556,12 @@ export default {
const data = res.data.data;
// eslint-disable-next-line no-empty
for (let i = 0; i < data.records.length; i++) {
// eslint-disable-next-line no-empty
// for (let j = 0; j < this.deliveryTypeData.length; j++) {
// // eslint-disable-next-line no-empty
// if (data.records[i].deliveryType == this.deliveryTypeData[j].dictKey) {
// data.records[i].deliveryType = this.deliveryTypeData[j].dictValue;
// }
// }
for (let j = 0; j < this.orderSourceData.length; j++) {
// eslint-disable-next-line no-empty
if (data.records[i].orderSource == this.orderSourceData[j].dictKey) {
data.records[i].orderSource = this.orderSourceData[j].dictValue;
}
}
for (let j = 0; j < this.signingStatusData.length; j++) {
// eslint-disable-next-line no-empty
if (data.records[i].driverSigning == this.signingStatusData[j].dictKey) {
data.records[i].driverSigning = this.signingStatusData[j].dictValue;
}
@ -2560,6 +2569,7 @@ export default {
}
this.page.total = data.total;
this.data = data.records;
handleTranslationDataSeclect(this.data, this.columnList);
this.loading = false;
// this.selectionClear();
});

2
src/views/reportforms/ConsigneeReport.vue

@ -55,7 +55,7 @@
/>
</el-form-item>
<el-form-item label="时间周期">
<el-form-item label="制单时间">
<el-date-picker
v-model="query.timeArr"
type="daterange"

2
src/views/reportforms/SalesDepartmentIncomeReport.vue

@ -55,7 +55,7 @@
/>
</el-form-item>
<el-form-item label="时间周期">
<el-form-item label="制单时间">
<el-date-picker
v-model="query.timeArr"
type="daterange"

Loading…
Cancel
Save