diff --git a/src/api/reportforms/SalesDepartmentIncomeReport.js b/src/api/reportforms/SalesDepartmentIncomeReport.js new file mode 100644 index 00000000..a63ed5c2 --- /dev/null +++ b/src/api/reportforms/SalesDepartmentIncomeReport.js @@ -0,0 +1,28 @@ +import request from '@/axios'; +/** 报表列表 */ +export const postDeptIncomingPage = params => { + return request({ + url: '/api/logpm-report/reportIncoming/deptIncomingPage', + method: 'get', + params, + }); +}; + +/** 查询事业线 */ +export const postFindbusinessLine = () => { + return request({ + url: '/api/logpm-basicdata/warehouse/findBusunessLineList', + method: 'get', + params: {}, + }); +}; + +/** 报表导出 */ +export const postDeptIncomingExport = params => { + return request({ + url: '/api/logpm-report/reportIncoming/deptIncomingExport', + method: 'get', + params, + responseType: 'blob', + }); +}; diff --git a/src/api/storagecost/index.js b/src/api/storagecost/index.js index e7324d98..577402f0 100644 --- a/src/api/storagecost/index.js +++ b/src/api/storagecost/index.js @@ -429,4 +429,63 @@ export const $_Warehouserentalmanagementremove = params => { params, }); }; +// 仓储成本中专月度作业统计 +export const $_Transferwarehousestatistics = params => { + return request({ + url: '/api/logpm-statisticsdata/expenseWarehouseTransitMonth/page', + method: 'get', + params, + }); +}; +// 仓储成本中专月度作业统计-详情 +export const $_Transferwarehousestatisticsdetail = params => { + return request({ + url: '/api/logpm-statisticsdata/expenseWarehouseTransitMonth/detail', + method: 'get', + params, + }); +}; + +// 仓储成本中专月度作业统计-保存 +export const $_Transferwarehousestatisticssave = data => { + return request({ + url: '/api/logpm-statisticsdata/expenseWarehouseTransitChange/save', + method: 'post', + data, + }); +}; +// 仓储成本中专月度作业统计-确认结算 +export const $_TransferwarehousestatisticsconfirmSettlement= data => { + return request({ + url: '/api/logpm-statisticsdata/expenseWarehouseTransitMonth/confirmSettlement', + method: 'post', + data, + }); +}; +// 仓储成本中专月度作业统计-明细 +export const $_Transferwarehouseorderspage= params => { + return request({ + url: '/api/logpm-statisticsdata/expenseWarehouseTransit/page', + method: 'get', + params, + }); +}; +// 仓储成本中专月度作业统计-导出 +export const $_exportTransitMonth = params => { + return request({ + url: '/api/logpm-statisticsdata/expenseWarehouseTransitMonth/exportTransitMonth', + method: 'get', + params, + responseType: 'blob', + }); +}; +// 仓储成本中专月度作业统计-明细导出 +export const $_exportTransit = params => { + return request({ + url: '/api/logpm-statisticsdata/expenseWarehouseTransit/exportTransit', + method: 'get', + params, + responseType: 'blob', + }); +}; \ No newline at end of file diff --git a/src/api/wel/index.js b/src/api/wel/index.js index 17228b74..41766ecf 100644 --- a/src/api/wel/index.js +++ b/src/api/wel/index.js @@ -109,10 +109,10 @@ export const postTrunklineCarsData = data => { * @param {Object} data * @returns */ -export const postTrunklineCarsDataByWarehouseId = data => { +export const getCarsStattisNum = data => { return request({ - url: '/api/logpm-report/warehouseIndex/trunklineCarsDataByWarehouseId', - method: 'post', + url: '/api/logpm-report/warehouseIndex/carsStattisNum', + method: 'get', data, }); }; diff --git a/src/components/ArteryPrintTemplate/ArteryPrintTemplate.vue b/src/components/ArteryPrintTemplate/ArteryPrintTemplate.vue index 0d67cf69..f70b2b21 100644 --- a/src/components/ArteryPrintTemplate/ArteryPrintTemplate.vue +++ b/src/components/ArteryPrintTemplate/ArteryPrintTemplate.vue @@ -10,271 +10,281 @@ border-right: 1px solid #000; " > - - - 暂无图片 - - - 干 线 装 载 清 单 - - - -
{{ renderInfo.carsNo }}
- - - - - 始发站:{{ renderInfo.startWarehouseName }} - - - 经停站:{{ - renderInfo.endWarehouseNames.slice(0, renderInfo.endWarehouseNames.length - 1)[0] || '' - }} - - - 目的站:{{ renderInfo.endWarehouseNames.slice(-1)[0] }} - - - - - 司机:{{ renderInfo.assistantName || '' }} - - - 司机电话:{{ renderInfo.assistantMobile || '' }} - - - 车牌号:{{ renderInfo.carNumber || '' }} - - - 卸车完成时间: {{ renderInfo.unloadDate || '年 月 日' }} - - - 卸车人员签字 - - - - 序号 - - 发货单位 - - - 开单时间 - - - 始发仓 - - - 目的仓 - - - 收货单位 - - - 收货人 - - - 收货电话 - - - 物流单号 - - - 合同号 - - - 计划件数 - - 货位 - - 装车产品明细 - - - - 卸车件数 - - - 卸车网点 - - - 卸车时间 - - - 异常备注 - - - - - {{ item }} - - - 小计 - - - - - - - - 合计 - - - - {{ totalPlanNum }} - - - - - {{ totalNum }} - - - - - - {{ totalUnLoadNum }} - - - - - - - 投诉电话:4000184668 + + 投诉电话:4000184668 - 营业部电话: + 营业部电话: - 系统单调度: - + 系统单调度: + + diff --git a/src/components/ArteryPrintTemplateV2/ArteryPrintTemplateV2.vue b/src/components/ArteryPrintTemplateV2/ArteryPrintTemplateV2.vue index 4f00c43f..8533b2d0 100644 --- a/src/components/ArteryPrintTemplateV2/ArteryPrintTemplateV2.vue +++ b/src/components/ArteryPrintTemplateV2/ArteryPrintTemplateV2.vue @@ -10,215 +10,221 @@ border-right: 1px solid #000; " > - - - 暂无图片 - - - 干 线 装 载 清 单 - - - -
{{ renderInfo.carsNo }}
- - - - - 始发站:{{ renderInfo.startWarehouseName }} - - - 经停站:{{ - renderInfo.endWarehouseNames.slice(0, renderInfo.endWarehouseNames.length - 1)[0] || '' - }} - - - 目的站:{{ renderInfo.endWarehouseNames.slice(-1)[0] }} - - - - - 司机:{{ renderInfo.assistantName || '' }} - - - 司机电话:{{ renderInfo.assistantMobile || '' }} - - - 车牌号:{{ renderInfo.carNumber || '' }} - - - 卸车完成时间: {{ renderInfo.unloadDate || '年 月 日' }} - - - 卸车人员签字: - - - - 序号 - 发货单位 - 开单时间 - 始发仓 - 目的仓 - 收货单位 - 收货人 - 收货电话 - 物流单号 - 合同号 - - 装车产品明细 - - 计划件数 - - 本仓装车件数 - 总装车件数 - 卸车件数 - 异常备注 - - - - - - - - 合计 - - - - - {{ totalPlanNum }} - - - - {{ totalloadingNum }} - - - - {{ totalStockloadingNum }} - - - - {{ totalUnLoadNum }} - - - - - 投诉电话:4000184668 - - 营业部电话: - - 系统单调度: - + diff --git a/src/css/common.css b/src/css/common.css index 55b7c114..d40e2c2f 100644 --- a/src/css/common.css +++ b/src/css/common.css @@ -74,7 +74,7 @@ a { .avue-view { width: 100%; - box-sizing: border-box; + box-sizing: border-box; } .avue-footer { @@ -208,8 +208,8 @@ a { .top-search { line-height: 50px; - position: absolute !important; - right: 200px; + /* position: absolute !important; */ + /* right: 200px; */ top: 0; width: 300px; } diff --git a/src/option/reportforms/DeliveryStatisticsReport.js b/src/option/reportforms/DeliveryStatisticsReport.js index 7c97fdb1..7a830e9f 100644 --- a/src/option/reportforms/DeliveryStatisticsReport.js +++ b/src/option/reportforms/DeliveryStatisticsReport.js @@ -157,7 +157,7 @@ export const columnList = [ }, { prop: 'reviewOnTimeRate', - label: '符合及时率', + label: '复核及时率', type: 6, values: '', width: '150', diff --git a/src/option/reportforms/SalesDepartmentIncomeReport.js b/src/option/reportforms/SalesDepartmentIncomeReport.js new file mode 100644 index 00000000..2e30d079 --- /dev/null +++ b/src/option/reportforms/SalesDepartmentIncomeReport.js @@ -0,0 +1,275 @@ +export const columnList = [ + { + prop: '', + label: '复选框', + type: 0, + width: 55, + fixed: true, + }, + { + prop: '', + label: '序号', + type: 12, + values: '', + width: 55, + fixed: true, + }, + { + prop: 'businessLine', + label: '事业线', + type: 1, + values: '', + width: '180', + checkarr: [], + fixed: false, + sortable: true, + head: false, + }, + { + prop: 'departureWarehouseName', + label: '始发仓', + type: 1, + values: '', + width: '150', + checkarr: [], + fixed: false, + sortable: true, + head: false, + }, + { + prop: 'destinationWarehouseName', + label: '目的仓', + type: 1, + values: '', + width: '150', + checkarr: [], + fixed: false, + sortable: true, + head: false, + }, + { + prop: 'brand', + label: '品牌', + type: 1, + values: '', + width: '150', + checkarr: [], + fixed: false, + sortable: true, + head: false, + }, + { + prop: 'waybillNum', + label: '运单数', + type: 1, + values: '', + width: '150', + checkarr: [], + fixed: false, + sortable: true, + head: false, + isshowSummary: true, //开启统计 + }, + { + prop: 'num', + label: '件数', + type: 1, + values: '', + width: '150', + checkarr: [], + fixed: false, + sortable: true, + head: false, + isshowSummary: true, //开启统计 + }, + { + prop: 'weight', + label: '重量', + type: 1, + values: '', + width: '200', + checkarr: [], + fixed: false, + sortable: true, + head: false, + isshowSummary: true, //开启统计 + }, + { + prop: 'volume', + label: '体积', + type: 1, + values: '', + width: '150', + checkarr: [], + fixed: false, + sortable: true, + head: false, + isshowSummary: true, //开启统计 + }, + { + prop: 'stockNum', + label: '到货件数', + type: 1, + values: '', + width: '150', + checkarr: [], + fixed: false, + sortable: true, + head: false, + isshowSummary: true, //开启统计 + }, + { + prop: 'signNum', + label: '签收件数', + type: 1, + values: '', + width: '150', + checkarr: [], + fixed: false, + sortable: true, + head: false, + isshowSummary: true, //开启统计 + }, + { + prop: 'pickupFee', + label: '提货费', + type: 1, + values: '', + width: '150', + checkarr: [], + fixed: false, + sortable: true, + head: false, + isshowSummary: true, //开启统计 + }, + { + prop: 'freightFee', + label: '运费', + type: 1, + values: '', + width: '150', + checkarr: [], + fixed: false, + sortable: true, + head: false, + isshowSummary: true, //开启统计 + }, + { + prop: 'deliveryFee', + label: '送货费', + type: 1, + values: '', + width: '150', + checkarr: [], + fixed: false, + sortable: true, + head: false, + isshowSummary: true, //开启统计 + }, + { + prop: 'warehouseManagementFee', + label: '仓库管理费', + type: 1, + values: '', + width: '150', + checkarr: [], + fixed: false, + sortable: true, + head: false, + isshowSummary: true, //开启统计 + }, + { + prop: 'storageFee', + label: '仓储费', + type: 1, + values: '', + width: '150', + checkarr: [], + fixed: false, + sortable: true, + head: false, + isshowSummary: true, //开启统计 + }, + { + prop: 'startWareOutTime', + label: '始发仓发货日期', + type: 1, + values: '', + width: '150', + checkarr: [], + fixed: false, + sortable: true, + head: false, + }, + { + prop: 'timeStr', + label: '时间周期', + type: 1, + values: '', + width: '150', + checkarr: [], + fixed: false, + sortable: true, + head: false, + }, + { + prop: 'handlingFee', + label: '仓储操作费', + type: 1, + values: '', + width: '150', + checkarr: [], + fixed: false, + sortable: true, + head: false, + isshowSummary: true, //开启统计 + }, + { + prop: 'sortingFee', + label: '仓储分拣费', + type: 1, + values: '', + width: '150', + checkarr: [], + fixed: false, + sortable: true, + head: false, + isshowSummary: true, //开启统计 + }, + { + prop: 'installFee', + label: '安装费', + type: 1, + values: '', + width: '150', + checkarr: [], + fixed: false, + sortable: true, + head: false, + isshowSummary: true, //开启统计 + }, + { + prop: 'otherFee', + label: '其他费', + type: 1, + values: '', + width: '150', + checkarr: [], + fixed: false, + sortable: true, + head: false, + isshowSummary: true, //开启统计 + }, + { + prop: 'totalFee', + label: '总费用', + type: 1, + values: '', + width: '150', + checkarr: [], + fixed: false, + sortable: true, + head: false, + isshowSummary: true, //开启统计 + }, +]; diff --git a/src/option/storagecost/Transferwarehouseorders.js b/src/option/storagecost/Transferwarehouseorders.js index 7f24c5d8..a6246e46 100644 --- a/src/option/storagecost/Transferwarehouseorders.js +++ b/src/option/storagecost/Transferwarehouseorders.js @@ -15,41 +15,8 @@ export const columnList = [ fixed: true, }, { - prop: 'a1', + prop: 'transitWarehouseName', label: '中转仓', - type: 2, - values: '', - width: '150', - checkarr: [], - fixed: false, - sortable: true, - head: false, - }, - { - prop: 'a2', - label: '订单编号', - type: 2, - values: '', - width: '150', - checkarr: [], - fixed: false, - sortable: true, - head: false, - }, - { - prop: 'a3', - label: '运单号', - type: 1, - values: '', - width: '150', - checkarr: [], - fixed: false, - sortable: true, - head: false, - }, - { - prop: 'a4', - label: '到站仓', type: 1, values: '', width: '150', @@ -59,30 +26,8 @@ export const columnList = [ head: false, }, { - prop: 'a5', - label: '发站仓', - type: 1, - values: '', - width: '150', - checkarr: [], - fixed: false, - sortable: true, - head: false, - }, - { - prop: 'a6', - label: '发货单位', - type: 2, - values: '', - width: '150', - checkarr: [], - fixed: false, - sortable: true, - head: false, - }, - { - prop: 'a7', - label: '收货单位', + prop: 'destinationWarehouseName', + label: '目的仓', type: 1, values: '', width: '150', @@ -92,8 +37,8 @@ export const columnList = [ head: false, }, { - prop: 'a8', - label: '运单类型', + prop: 'workType', + label: '作业类型', type: 1, values: '', width: '150', @@ -103,8 +48,8 @@ export const columnList = [ head: false, }, { - prop: 'a9', - label: '服务类型', + prop: 'packageType', + label: '包件类型', type: 1, values: '', width: '150', @@ -114,8 +59,8 @@ export const columnList = [ head: false, }, { - prop: 'a11', - label: '总件数', + prop: 'packageCode', + label: '包条码', type: 1, values: '', width: '150', @@ -125,8 +70,8 @@ export const columnList = [ head: false, }, { - prop: 'a12', - label: '中转入库件数', + prop: 'orderCode', + label: '订单号', type: 1, values: '', width: '150', @@ -136,8 +81,8 @@ export const columnList = [ head: false, }, { - prop: 'a13', - label: '中转入库收入', + prop: 'waybillNumber', + label: '运单编号', type: 1, values: '', width: '150', @@ -147,8 +92,8 @@ export const columnList = [ head: false, }, { - prop: 'a14', - label: '中转出库件数', + prop: 'trainNumber', + label: '车次号', type: 1, values: '', width: '150', @@ -158,8 +103,8 @@ export const columnList = [ head: false, }, { - prop: 'a15', - label: '中转出库收入', + prop: 'num', + label: '件数', type: 1, values: '', width: '150', @@ -169,8 +114,8 @@ export const columnList = [ head: false, }, { - prop: 'a16', - label: '中转作业收入', + prop: 'taskTime', + label: '操作时间', type: 1, values: '', width: '150', @@ -180,8 +125,8 @@ export const columnList = [ head: false, }, { - prop: 'a17', - label: '中转作业结算时间', + prop: 'confirmAllocationTime', + label: '确认分摊时间', type: 1, values: '', width: '150', diff --git a/src/option/storagecost/Transferwarehousestatistics.js b/src/option/storagecost/Transferwarehousestatistics.js index 3df85bc0..113c5818 100644 --- a/src/option/storagecost/Transferwarehousestatistics.js +++ b/src/option/storagecost/Transferwarehousestatistics.js @@ -15,7 +15,7 @@ export const columnList = [ fixed: true, }, { - prop: 'a1', + prop: 'transitWarehouseName', label: '中转仓', type: 1, values: '', @@ -26,7 +26,7 @@ export const columnList = [ head: false, }, { - prop: 'a2', + prop: 'destinationWarehouseName', label: '目的仓', type: 1, values: '', @@ -37,7 +37,7 @@ export const columnList = [ head: false, }, { - prop: 'a3', + prop: 'statisticalTime', label: '中转作业出账时间', type: 1, values: '', @@ -48,7 +48,7 @@ export const columnList = [ head: false, }, { - prop: 'a4', + prop: 'inNumber', label: '月中转入库件数', type: 1, values: '', @@ -57,9 +57,10 @@ export const columnList = [ fixed: false, sortable: true, head: false, + isshowSummary: true, }, { - prop: 'a5', + prop: 'inCost', label: '月中转入库收入', type: 1, values: '', @@ -68,9 +69,10 @@ export const columnList = [ fixed: false, sortable: true, head: false, + isshowSummary: true, }, { - prop: 'a6', + prop: 'outNumber', label: '月中转出库件数', type: 1, values: '', @@ -79,9 +81,10 @@ export const columnList = [ fixed: false, sortable: true, head: false, + isshowSummary: true, }, { - prop: 'a7', + prop: 'outCost', label: '月中转出库收入', type: 1, values: '', @@ -90,9 +93,10 @@ export const columnList = [ fixed: false, sortable: true, head: false, + isshowSummary: true, }, { - prop: 'a7', + prop: 'totalCost', label: '月中转作业收入', type: 1, values: '', @@ -101,20 +105,34 @@ export const columnList = [ fixed: false, sortable: true, head: false, + isshowSummary: true, }, { - prop: 'a7', + prop: 'settlementStatus', label: '结算状态', - type: 1, + type: 3, values: '', width: '150', - checkarr: [], + checkarr: [ + { + label: '未结算', + value: '未结算', + }, + { + label: '已结算', + value: '已结算', + }, + { + label: '部分结算', + value: '部分结算', + }, + ], fixed: false, sortable: true, head: false, }, { - prop: 'a7', + prop: 'settledAmount', label: '已结算金额', type: 1, values: '', @@ -123,9 +141,10 @@ export const columnList = [ fixed: false, sortable: true, head: false, + isshowSummary: true, }, { - prop: 'a7', + prop: 'pendingSettlementAmount', label: '待结算金额', type: 1, values: '', @@ -134,9 +153,10 @@ export const columnList = [ fixed: false, sortable: true, head: false, + isshowSummary: true, }, { - prop: 'a7', + prop: 'settlementUser', label: '结算人', type: 1, values: '', @@ -147,7 +167,7 @@ export const columnList = [ head: false, }, { - prop: 'a7', + prop: 'settlementTime', label: '结算时间', type: 1, values: '', @@ -158,7 +178,7 @@ export const columnList = [ head: false, }, { - prop: 'a7', + prop: 'changeAmount', label: '异常金额', type: 1, values: '', @@ -167,6 +187,7 @@ export const columnList = [ fixed: false, sortable: true, head: false, + isshowSummary: true, }, { prop: 'createUserName', @@ -179,3 +200,76 @@ export const columnList = [ sortable: false, }, ]; +export const columnListrecord = [ + { + prop: 'checkbox', + label: '复选框', + type: 0, + width: 55, + fixed: true, + }, + { + prop: 'xh', + label: '序号', + type: 12, + values: '', + width: 55, + fixed: true, + }, + { + prop: 'changeAmount', + label: '异常费用', + type: 1, + values: '', + width: '150', + checkarr: [], + fixed: false, + sortable: true, + head: false, + isshowSummary: true, + }, + { + prop: 'changeNote', + label: '异常备注', + type: 1, + values: '', + width: '150', + checkarr: [], + fixed: false, + sortable: true, + head: false, + }, + { + prop: 'changeImageList', + label: '异常图片', + type: 6, + values: '', + width: '150', + checkarr: [], + fixed: false, + sortable: true, + head: false, + }, + { + prop: 'changeOperator', + label: '操作人', + type: 1, + values: '', + width: '150', + checkarr: [], + fixed: false, + sortable: true, + head: false, + }, + { + prop: 'changeTime', + label: '异常操作时间', + type: 1, + values: '', + width: '150', + checkarr: [], + fixed: false, + sortable: true, + head: false, + }, +]; diff --git a/src/page/index/index.vue b/src/page/index/index.vue index 48644bd3..2d297de5 100644 --- a/src/page/index/index.vue +++ b/src/page/index/index.vue @@ -206,7 +206,7 @@ export default { #avue-view { position: relative; } -.el-popup-parent--hidden{ +.el-popup-parent--hidden { width: 100% !important; } diff --git a/src/page/index/top/index.vue b/src/page/index/top/index.vue index f739eb19..02aeb291 100644 --- a/src/page/index/top/index.vue +++ b/src/page/index/top/index.vue @@ -11,9 +11,9 @@
-
+
@@ -137,23 +137,21 @@ export default { filters: {}, created() { - getMyCurrentWarehouse().then(res => { if (res.data.data == null) { console.log('当前没有数据'); localStorage.setItem('WarehouseName', void 0); - localStorage.setItem('my_data', JSON.stringify('')) + localStorage.setItem('my_data', JSON.stringify('')); return; } localStorage.setItem('WarehouseName', res.data.data.name); - localStorage.setItem('my_data', JSON.stringify(res.data.data)) - if(!res.data.data.name){ + localStorage.setItem('my_data', JSON.stringify(res.data.data)); + if (!res.data.data.name) { this.dataName = ''; - }else{ - this.dataName = res.data.data.name;//仓库名字 + } else { + this.dataName = res.data.data.name; //仓库名字 } }); - }, computed: { ...mapGetters([ diff --git a/src/page/index/top/top-search.vue b/src/page/index/top/top-search.vue index 09796fd3..bfb8a58e 100644 --- a/src/page/index/top/top-search.vue +++ b/src/page/index/top/top-search.vue @@ -117,10 +117,10 @@ export default { } } } -.el-autocomplete{ +.el-autocomplete { width: 300px !important; - margin-right:7% !important; - .el-input__wrapper{ + // margin-right:7% !important; + .el-input__wrapper { border: 1px solid #d3d3d3 !important; } } diff --git a/src/page/login/aiqa.vue b/src/page/login/aiqa.vue index bb83345e..4b508f5a 100644 --- a/src/page/login/aiqa.vue +++ b/src/page/login/aiqa.vue @@ -66,6 +66,8 @@ @keydown.enter="inputData(Data.input)" v-model="Data.input" placeholder="请输入问题描述" + type="textarea" + style="height: 100%; resize: none" /> 发送
@@ -106,7 +108,7 @@ const isFirstMessage = ref(true); const chatContainer = ref(null); const inputState = ref(false); //当前是否在回答 const props = defineProps({ - templateData:Boolean, + templateData: Boolean, }); const input = ref(null); //输入框实例 const Data = ref({ @@ -146,8 +148,7 @@ const Data = ref({ }, { content: '向日葵下载地址', - } - + }, ], ChathistoryList: [ // { @@ -316,11 +317,9 @@ const AiData = (value = '') => { lowercaseValue.includes('东集pad安装初始密码') ) { aiResponse = '东集PDA安装初始密码是:4007770876'; - } - else if ( - lowercaseValue.includes('东集pad-q7恢复出厂设置') - ) { - aiResponse = '东集pad-q7恢复出厂设置教程地址:1、关机状态下,按下【电源键】、【两侧扫描键】; 2、出现开机画面,松开【电源键】,出现工厂模式界面,按键全部松开;3、进入工厂模式后通过方向键选择【wipe data/factory reset】, 按电源键确认进入子菜单,选择【yes】,按【电源键】确认,恢复出厂完成后选择第一个【reboot system now】 ,按【电源键】确认重启设备。视频教程如下:https://mp.weixin.qq.com/s/0CG-jYooh9LJ-9aLauVGfA'; + } else if (lowercaseValue.includes('东集pad-q7恢复出厂设置')) { + aiResponse = + '东集pad-q7恢复出厂设置教程地址:1、关机状态下,按下【电源键】、【两侧扫描键】; 2、出现开机画面,松开【电源键】,出现工厂模式界面,按键全部松开;3、进入工厂模式后通过方向键选择【wipe data/factory reset】, 按电源键确认进入子菜单,选择【yes】,按【电源键】确认,恢复出厂完成后选择第一个【reboot system now】 ,按【电源键】确认重启设备。视频教程如下:https://mp.weixin.qq.com/s/0CG-jYooh9LJ-9aLauVGfA'; } // else if ( // lowercaseValue.includes('货无忧的汇通物流公司编码是多少') @@ -328,17 +327,15 @@ const AiData = (value = '') => { // aiResponse = '货无忧的汇通物流公司编码是:627683'; // } else if ( - lowercaseValue.includes('蓝牙打印机芝柯tx453设备连接密码是多少') || lowercaseValue.includes('tx453') + lowercaseValue.includes('蓝牙打印机芝柯tx453设备连接密码是多少') || + lowercaseValue.includes('tx453') ) { aiResponse = '蓝牙打印机芝柯xt453设备连接密码是:0000'; - } - else if ( - lowercaseValue.includes('向日葵') || lowercaseValue.includes('向日葵下载地址') - ) { + } else if (lowercaseValue.includes('向日葵') || lowercaseValue.includes('向日葵下载地址')) { aiResponse = '向日葵下载地址:https://sunlogin.oray.com/,使用教程点击下方立即下载'; - data.link = 'http://files.huo5u.com/plugins/%E5%90%91%E6%97%A5%E8%91%B5%E8%BF%9C%E7%A8%8B%E8%BD%AF%E4%BB%B6%E4%BD%BF%E7%94%A8%E6%95%99%E7%A8%8B.docx'; - } - else { + data.link = + 'http://files.huo5u.com/plugins/%E5%90%91%E6%97%A5%E8%91%B5%E8%BF%9C%E7%A8%8B%E8%BD%AF%E4%BB%B6%E4%BD%BF%E7%94%A8%E6%95%99%E7%A8%8B.docx'; + } else { aiResponse = '我不太理解您的问题,我正在努力学习中,请重新描述或输入其他问题,或联系管理员'; } } @@ -500,10 +497,11 @@ AiData(); //初始化AI机器人 flex: 1; background-color: #fff; border: 1px solid #9e9e9e; - padding: 0 4px; + padding: 0px 10px; border-radius: 4px; p { font-size: 13px; + margin: 10px 0; // text-indent: 24px; } } @@ -537,6 +535,13 @@ AiData(); //初始化AI机器人 height: 100%; font-size: 16px; } + + .el-textarea__inner { + height: 100%; + box-shadow: none; + resize: none; + } + .is-focus { box-shadow: none; } diff --git a/src/router/views/index.js b/src/router/views/index.js index 5b3bea46..d2c50dd2 100644 --- a/src/router/views/index.js +++ b/src/router/views/index.js @@ -1882,4 +1882,21 @@ export default [ }, ], }, + + { + path: '/cost/storagecost/Transferwarehouseorders', + component: Layout, + redirect: '/cost/storagecost/Transferwarehouseorders', + children: [ + { + meta: { + i18n: 'dict', + keepAlive: true, + }, + path: '/cost/storagecost/Transferwarehouseorders', + name: '中转仓月度订单明细', + component: () => import('@/views/cost/storagecost/Transferwarehouseorders.vue'), + }, + ], + }, ]; diff --git a/src/styles/top.scss b/src/styles/top.scss index c0d717be..9b8ca219 100644 --- a/src/styles/top.scss +++ b/src/styles/top.scss @@ -2,7 +2,7 @@ position: relative; background-color: #fff; box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.15); - color: rgba(0, 0, 0, .65); + color: rgba(0, 0, 0, 0.65); font-size: 28px; height: $top_height; line-height: $top_height; @@ -10,13 +10,14 @@ white-space: nowrap; .el-menu-item { - i, span { + i, + span { font-size: 13px; // background-color: #d3832a; } } } -.el-menu-item>.is-active{ +.el-menu-item > .is-active { background-color: #d3832a !important; } .avue-breadcrumb { @@ -46,8 +47,8 @@ .top-search { line-height: $top_height; - position: absolute !important; - right: 200px; + // position: absolute !important; + // right: 200px; top: 0; width: 300px; diff --git a/src/views/cost/Deliverycostmanagement/OrderTotalCostDetail.vue b/src/views/cost/Deliverycostmanagement/OrderTotalCostDetail.vue index 61b2ce30..cb586acf 100644 --- a/src/views/cost/Deliverycostmanagement/OrderTotalCostDetail.vue +++ b/src/views/cost/Deliverycostmanagement/OrderTotalCostDetail.vue @@ -39,9 +39,6 @@ 导出 - 测试
diff --git a/src/views/cost/storagecost/OrderTotalTransferDetails.vue b/src/views/cost/storagecost/OrderTotalTransferDetails.vue index 360f569b..543aec84 100644 --- a/src/views/cost/storagecost/OrderTotalTransferDetails.vue +++ b/src/views/cost/storagecost/OrderTotalTransferDetails.vue @@ -151,7 +151,6 @@ import { columnList } from '@/option/storagecost/OrderTotalTransferDetails.js'; import { getDictionaryBiz } from '@/api/system/dict'; //字典 import { $_getMyWarehouseList } from '@/api/storagecost/index.js'; import { processRowProperty, setNodeHeight } from '@/utils/util'; -import functions from '@/utils/functions.js'; import { ElMessageBox, ElMessage } from 'element-plus'; import { downloadXls } from '@/utils/util'; import { useStore } from 'vuex'; diff --git a/src/views/cost/storagecost/Transferwarehouseorders.vue b/src/views/cost/storagecost/Transferwarehouseorders.vue index 72c216fb..91b0f7a1 100644 --- a/src/views/cost/storagecost/Transferwarehouseorders.vue +++ b/src/views/cost/storagecost/Transferwarehouseorders.vue @@ -6,7 +6,7 @@ -
+ 搜 索 @@ -79,10 +79,7 @@
- 导入 - 导出
@@ -110,11 +107,7 @@ @selection="selectionChange" > @@ -147,14 +140,17 @@ v-model="details.columnList" > - + diff --git a/src/views/desk/DataBoard.vue b/src/views/desk/DataBoard.vue index e57ec982..b1c27495 100644 --- a/src/views/desk/DataBoard.vue +++ b/src/views/desk/DataBoard.vue @@ -520,7 +520,7 @@ 总数
- +
-
+
@@ -548,7 +548,7 @@ 已上架
- - -
- {{ details.allocationDataInfo.useNum || 0 }} -
@@ -576,7 +571,7 @@ 空闲库位 - - -
- {{ details.allocationDataInfo.nullNum || 0 }} -
@@ -604,7 +594,7 @@ 未上架 - - -
- {{ details.allocationDataInfo.noUpshelfNum || 0 }} -
@@ -718,9 +703,20 @@
-
+
-
{{ details.trunklineCarsDataInfo.totalNum || 0 }}
+
+ {{ details.trunklineCarsDataInfo.totalNum || 0 }} +
@@ -728,9 +724,20 @@
-
+
-
{{ details.trunklineCarsDataInfo.inTransitNum || 0 }}
+
+ {{ details.trunklineCarsDataInfo.inTransitNum || 0 }} +
@@ -738,9 +745,20 @@
-
+
-
{{ details.trunklineCarsDataInfo.workNum || 0 }}
+
+ {{ details.trunklineCarsDataInfo.workNum || 0 }} +
@@ -748,9 +766,20 @@
-
+
-
{{ details.trunklineCarsDataInfo.unloadNum || 0 }}
+
+ {{ details.trunklineCarsDataInfo.unloadNum || 0 }} +
@@ -831,7 +860,7 @@
- + 处理率
@@ -839,10 +868,15 @@ class="data mr5px underline" @click=" () => - handleShowAbnormalData('异常数据-处理率-%', abnormal_status, { - tip: '处理率', - prop: 'processingRate', - },'bar') + handleShowAbnormalData( + '异常数据-处理率-%', + abnormal_status, + { + tip: '处理率', + prop: 'processingRate', + }, + 'bar' + ) " >{{ abnormal_Info.abnormalRate }} @@ -1028,7 +1062,7 @@
-
+
+
+
@@ -1084,7 +1123,7 @@
-
+
+
{{ signforData.clerkSignforScale || 0 }}
-
+
%
- 文员签收件 + 文员签收率
-
+
+
-
+
{{ signforData.clerkOverTimeScale ? signforData.clerkOverTimeScale : 0 }}
%
@@ -1311,7 +1360,7 @@
-
+
+
+
@@ -1367,7 +1424,7 @@
-
+
+
{{ billSignforData.clerkSignforScale ? billSignforData.clerkSignforScale : 0 }}
-
+
%
- 文员签收数 + 文员签收率
-
+
+
@@ -1521,7 +1594,7 @@ import { postOpenOrderDataByWarehouseId, postAllocationDataByWarehouseId, postHandOrderDataByWarehouseId, - postTrunklineCarsDataByWarehouseId, + getCarsStattisNum, $_aftersalesData, } from '@/api/wel/index'; import { exportExcelByDom } from '@/utils/export'; @@ -1628,13 +1701,53 @@ const details = reactive({ /** 签收数据 */ signforDataInfo: { /** 当日签收数据 */ - daySignData: {}, + daySignData: { + signNum: 0, + clerkOverTimeSignfoNum: 0, + clerkOverTimeScale: 0, + signScale: 0, + clerkSignNum: 0, + planNum: 0, + unSignNum: 0, + clerkSignforScale: 0, + data: [], + }, /** 当月签收数据 */ - monthSignData: {}, + monthSignData: { + signNum: 0, + clerkOverTimeSignfoNum: 0, + clerkOverTimeScale: 0, + signScale: 0, + clerkSignNum: 0, + planNum: 0, + unSignNum: 0, + clerkSignforScale: 0, + data: [], + }, /** 当日自提签收数据 */ - dayBillLadingSignData: {}, + dayBillLadingSignData: { + signNum: 0, + clerkOverTimeSignfoNum: 0, + clerkOverTimeScale: 0, + signScale: 0, + clerkSignNum: 0, + planNum: 0, + unSignNum: 0, + clerkSignforScale: 0, + data: [], + }, /** 当月自提签收数据 */ - monthBillLadingSignData: {}, + monthBillLadingSignData: { + signNum: 0, + clerkOverTimeSignfoNum: 0, + clerkOverTimeScale: 0, + signScale: 0, + clerkSignNum: 0, + planNum: 0, + unSignNum: 0, + clerkSignforScale: 0, + data: [], + }, }, loadingObj: { /** 开单数据 */ @@ -1789,15 +1902,37 @@ const initTrunklineHandOrderData = async () => { /** 请求干线车次数据 */ const initTrunklineCarsData = async () => { + const _obj: any = {}; + const _keyArr = ['inTransitNum', 'totalNum', 'unloadNum', 'workNum']; + for (let i = 0; i < _keyArr.length; i++) { + const value = _keyArr[i]; + + _obj[value] = 0; + } + _obj.list = []; + try { details.loadingObj.trunklineCarsData = true; - const res = await postTrunklineCarsData({}); + const res = await getCarsStattisNum({}); const { code, data } = res.data; if (code !== 200) return; - details.trunklineCarsDataInfo = 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.trunklineCarsDataInfo = _obj; details.loadingObj.trunklineCarsData = false; } }; @@ -1996,17 +2131,9 @@ const initDeliveryData = async () => { /** 签收数据 */ const initSignforData = async () => { - const _keyArr = [ - 'signNum', - 'unSignNum', - 'signScale', - 'clerkSignNum', - 'clerkSignforScale', - 'clerkOverTimeSignfoNum', - 'clerkOverTimeScale', - ]; + const _keyArr = ['signNum', 'unSignNum', 'clerkSignNum', 'planNum', 'clerkOverTimeSignfoNum']; - const _obj = { + const _obj: any = { daySignData: { data: [] }, monthSignData: { data: [] }, dayBillLadingSignData: { data: [] }, @@ -2042,6 +2169,7 @@ const initSignforData = async () => { const key = _keyArr[j]; const _val = isNumber(value[key]) ? Number(value[key]) : 0; + value[key] = _val; // 签收数据 if (Number(value.type) === 1) { @@ -2063,6 +2191,104 @@ const initSignforData = async () => { : // 自提签收数据 _obj.monthBillLadingSignData.data.push(value); } + + _obj.monthBillLadingSignData.totalSinNum = computeNumber( + _obj.monthBillLadingSignData.signNum, + '+', + _obj.monthBillLadingSignData.unSignNum + ).result; + _obj.monthSignData.totalSinNum = computeNumber( + _obj.monthSignData.signNum, + '+', + _obj.monthSignData.unSignNum + ).result; + + // 签收率 + if ( + !isNumber(_obj.monthBillLadingSignData.signNum) || + !isNumber(_obj.monthBillLadingSignData.totalSinNum) || + Number(_obj.monthBillLadingSignData.totalSinNum) === 0 + ) { + _obj.monthBillLadingSignData.signScale = 0; + } else { + _obj.monthBillLadingSignData.signScale = computeNumber( + _obj.monthBillLadingSignData.signNum, + '/', + _obj.monthBillLadingSignData.totalSinNum + ).result; + } + + if ( + !isNumber(_obj.monthSignData.signNum) || + !isNumber(_obj.monthSignData.totalSinNum) || + Number(_obj.monthSignData.totalSinNum) === 0 + ) { + _obj.monthSignData.signScale = 0; + } else { + _obj.monthSignData.signScale = computeNumber( + _obj.monthSignData.signNum, + '/', + _obj.monthSignData.totalSinNum + ).result; + } + + // 文员签收率 + if ( + !isNumber(_obj.monthBillLadingSignData.clerkSignNum) || + !isNumber(_obj.monthBillLadingSignData.planNum) || + Number(_obj.monthBillLadingSignData.planNum) === 0 + ) { + _obj.monthBillLadingSignData.clerkSignforScale = 0; + } else { + _obj.monthBillLadingSignData.clerkSignforScale = computeNumber( + Number(_obj.monthBillLadingSignData.clerkSignNum), + '/', + Number(_obj.monthBillLadingSignData.planNum) + ).result; + } + + if ( + !isNumber(_obj.monthSignData.clerkSignNum) || + !isNumber(_obj.monthSignData.planNum) || + Number(_obj.monthSignData.planNum) === 0 + ) { + _obj.monthSignData.clerkSignforScale = 0; + } else { + _obj.monthSignData.clerkSignforScale = computeNumber( + Number(_obj.monthSignData.clerkSignNum), + '/', + Number(_obj.monthSignData.planNum) + ).result; + } + + // 异常签收率 + if ( + !isNumber(_obj.monthBillLadingSignData.clerkOverTimeSignfoNum) || + !isNumber(_obj.monthBillLadingSignData.planNum) || + Number(_obj.monthBillLadingSignData.planNum) === 0 + ) { + _obj.monthBillLadingSignData.clerkOverTimeScale = 0; + } else { + _obj.monthBillLadingSignData.clerkOverTimeScale = computeNumber( + _obj.monthBillLadingSignData.clerkOverTimeSignfoNum, + '/', + _obj.monthBillLadingSignData.planNum + ).result; + } + + if ( + !isNumber(_obj.monthSignData.clerkOverTimeSignfoNum) || + !isNumber(_obj.monthSignData.planNum) || + Number(_obj.monthSignData.planNum) === 0 + ) { + _obj.monthSignData.clerkOverTimeScale = 0; + } else { + _obj.monthSignData.clerkOverTimeScale = computeNumber( + _obj.monthSignData.clerkOverTimeSignfoNum, + '/', + _obj.monthSignData.planNum + ).result; + } } // 当日数据 @@ -2097,11 +2323,12 @@ const initSignforData = async () => { } } - details.signforDataInfo = data || []; + // details.signforDataInfo = data || []; } catch (error) { console.log('error :>> ', error); } finally { details.signforDataInfo = _obj; + console.log('details.signforDataInfo :>> ', details.signforDataInfo); details.loadingObj.signforData = false; } }; @@ -2156,7 +2383,7 @@ const delivery_bill_info = computed(() => { /** 签收数据 */ const signforData = computed(() => { const _obj: any = details.signforDataInfo[signforData_status.value] || {}; - console.log('_obj :>> ', _obj); + // console.log('_obj :>> ', _obj); _obj.signScaleNum ? _obj.signScaleNum : (_obj.signScaleNum = _obj.signScale || 0); _obj.clerkSignforScaleNum @@ -2202,7 +2429,6 @@ const billSignforData = computed(() => { type OptionObjType = { prop: string; tip: string }; - // 定义两种颜色 const colors = ['#008CBA', '#808080']; // 蓝色和灰色 // /** 获取百分比 */ @@ -2317,10 +2543,15 @@ const getProportion = (value: number) => { // }); // }; // 定义显示图表的函数,接受数据、标题、选项对象和图表类型(默认为饼图) -const handleShowEcharts = (data: any[], title: string, optionObj: OptionObjType, chartType: string = 'pie') => { - console.log('data :>> ', data); - console.log('title :>> ', title); - console.log('optionObj :>> ', optionObj); +const handleShowEcharts = ( + data: any[], + title: string, + optionObj: OptionObjType, + chartType: string = 'pie' +) => { + console.log('data :>> ', data); + console.log('title :>> ', title); + console.log('optionObj :>> ', optionObj); if (getObjType(data) !== 'array') return; // 检查传入的数据是否为数组,如果不是则返回 @@ -2344,7 +2575,8 @@ const handleShowEcharts = (data: any[], title: string, optionObj: OptionObjType, const item = _arr[j]; // 获取当前 _arr 中的数据项 if (item.value > value[optionObj.prop]) continue; // 如果当前 _arr 中的数据项值大于当前数据项的值,继续下一个循环 - _arr.splice(j, 0, { // 在当前位置插入当前数据项 + _arr.splice(j, 0, { + // 在当前位置插入当前数据项 name: value.warehouseName, // 数据项的名称 value: value[optionObj.prop], // 数据项的值 }); @@ -2353,13 +2585,15 @@ const handleShowEcharts = (data: any[], title: string, optionObj: OptionObjType, } if (isContinue) continue; // 如果已插入当前数据项,跳过插入到数组末尾的操作 - _arr.push({ // 如果未插入,将当前数据项添加到数组末尾 + _arr.push({ + // 如果未插入,将当前数据项添加到数组末尾 name: value.warehouseName, // 数据项的名称 value: value[optionObj.prop], // 数据项的值 }); } - nextTick(() => { // 确保 DOM 更新完成后再进行图表初始化 + nextTick(() => { + // 确保 DOM 更新完成后再进行图表初始化 // 获取图表容器元素 const chartDom = document.getElementById('echartBox'); if (!chartDom) return; // 如果未找到图表容器元素,则返回 @@ -2373,7 +2607,7 @@ const handleShowEcharts = (data: any[], title: string, optionObj: OptionObjType, }, tooltip: { trigger: 'item', // 设置提示框触发方式为数据项 - formatter: (params) => { + formatter: params => { if (chartType === 'pie') { return `${params.name}: ${params.value} (${params.percent}%)`; // 如果是饼图,格式化提示信息为名称、值和百分比 } else { @@ -2385,7 +2619,8 @@ const handleShowEcharts = (data: any[], title: string, optionObj: OptionObjType, orient: 'vertical', // 图例布局方向 left: 'left', // 图例位置 }, - ...(chartType === 'bar' && { // 如果是柱状图,添加柱状图的配置 + ...(chartType === 'bar' && { + // 如果是柱状图,添加柱状图的配置 xAxis: { type: 'category', // x 轴类型为类别 data: _arr.map(item => item.name), // x 轴数据为类别名称 @@ -2397,24 +2632,25 @@ const handleShowEcharts = (data: any[], title: string, optionObj: OptionObjType, yAxis: { type: 'value', // y 轴类型为数值 axisLabel: { - formatter: (value) => { + formatter: value => { return getProportion(value); // 将 y 轴标签格式化为百分比形式 - } + }, }, }, series: [ { name: optionObj.tip, // 系列名称 type: 'bar', // 系列类型为柱状图 - data: _arr.map(item => ({ // 系列数据 + data: _arr.map(item => ({ + // 系列数据 name: item.name, // 数据项名称 value: item.value, // 数据项值 })), itemStyle: { - color: (params) => { + color: params => { // 根据数据项的索引选择颜色 return colors[params.dataIndex % 2]; - } + }, }, emphasis: { itemStyle: { @@ -2426,9 +2662,9 @@ const handleShowEcharts = (data: any[], title: string, optionObj: OptionObjType, show: true, // 显示高亮标签 fontSize: 20, // 高亮标签字体大小 fontWeight: 'bold', // 高亮标签字体粗细 - formatter: (params) => { + formatter: params => { return getProportion(params.value); // 高亮标签格式化为百分比形式 - } + }, }, }, barGap: '30%', // 柱子之间的间隔 @@ -2437,12 +2673,14 @@ const handleShowEcharts = (data: any[], title: string, optionObj: OptionObjType, }, ], }), - ...(chartType === 'pie' && { // 如果是饼图,添加饼图的配置 + ...(chartType === 'pie' && { + // 如果是饼图,添加饼图的配置 series: [ { name: optionObj.tip, // 系列名称 type: 'pie', // 系列类型为饼图 - data: _arr.map((item) => ({ // 系列数据 + data: _arr.map(item => ({ + // 系列数据 name: item.name + ' - ' + getProportion(item.value / _total), // 数据项名称,附加百分比 value: item.value, // 数据项值 })), @@ -2469,8 +2707,6 @@ const handleShowEcharts = (data: any[], title: string, optionObj: OptionObjType, }); }; - - /** 请求详情 */ const handleDetails = async (type, title, optionObj: OptionObjType) => { details.popUpShow.isShow = true; @@ -2497,8 +2733,8 @@ const handleDetails = async (type, title, optionObj: OptionObjType) => { // 干线车次数据 case 'trunklineCarsDataColumn': - res = await postTrunklineCarsDataByWarehouseId({}); - break; + handleShowEcharts(details.trunklineCarsDataInfo.list, title, optionObj); + return; default: break; } @@ -2534,7 +2770,12 @@ const handleShowDeliveryDetail = ( handleShowEcharts(data, title, optionObj); }; /** 显示售后异常数据 */ -const handleShowAbnormalData = (title, type: 'dayData' | 'monthData', optionObj: any = {},chartType) => { +const handleShowAbnormalData = ( + title, + type: 'dayData' | 'monthData', + optionObj: any = {}, + chartType = 'pie' +) => { details.popUpShow.isShow = true; details.title = title; console.log(optionObj, 'optionObj'); @@ -2544,7 +2785,7 @@ const handleShowAbnormalData = (title, type: 'dayData' | 'monthData', optionObj: if (getObjType(details.unloadAbnormalDataInfo[type]) !== 'object') return; const { data } = details.unloadAbnormalDataInfo[type]; - handleShowEcharts(data, title, optionObj,chartType); + handleShowEcharts(data, title, optionObj, chartType); }; /** 显示签收详情 */ @@ -2567,7 +2808,7 @@ const handleShowSignDetail = ( console.log('data :>> ', data); - handleShowEcharts(data, title, optionObj,chartType); + handleShowEcharts(data, title, optionObj, chartType); }; /** 导出 */ diff --git a/src/views/reportforms/DeliveryStatisticsReport.vue b/src/views/reportforms/DeliveryStatisticsReport.vue index 5c25e5a4..ebe52d6b 100644 --- a/src/views/reportforms/DeliveryStatisticsReport.vue +++ b/src/views/reportforms/DeliveryStatisticsReport.vue @@ -106,7 +106,7 @@