Browse Source

Merge branch 'dev' into pre-production

pre-production
pref_mail@163.com 4 months ago
parent
commit
177a7a1b69
  1. 28
      src/api/reportforms/SalesDepartmentIncomeReport.js
  2. 59
      src/api/storagecost/index.js
  3. 6
      src/api/wel/index.js
  4. 484
      src/components/ArteryPrintTemplate/ArteryPrintTemplate.vue
  5. 398
      src/components/ArteryPrintTemplateV2/ArteryPrintTemplateV2.vue
  6. 6
      src/css/common.css
  7. 2
      src/option/reportforms/DeliveryStatisticsReport.js
  8. 275
      src/option/reportforms/SalesDepartmentIncomeReport.js
  9. 97
      src/option/storagecost/Transferwarehouseorders.js
  10. 126
      src/option/storagecost/Transferwarehousestatistics.js
  11. 2
      src/page/index/index.vue
  12. 14
      src/page/index/top/index.vue
  13. 6
      src/page/index/top/top-search.vue
  14. 39
      src/page/login/aiqa.vue
  15. 17
      src/router/views/index.js
  16. 11
      src/styles/top.scss
  17. 3
      src/views/cost/Deliverycostmanagement/OrderTotalCostDetail.vue
  18. 1
      src/views/cost/storagecost/OrderTotalTransferDetails.vue
  19. 93
      src/views/cost/storagecost/Transferwarehouseorders.vue
  20. 624
      src/views/cost/storagecost/Transferwarehousestatistics.vue
  21. 487
      src/views/desk/DataBoard.vue
  22. 8
      src/views/reportforms/DeliveryStatisticsReport.vue
  23. 522
      src/views/reportforms/SalesDepartmentIncomeReport.vue
  24. 34
      src/views/waybill/orderPackageList.vue

28
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',
});
};

59
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',
});
};

6
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,
});
};

484
src/components/ArteryPrintTemplate/ArteryPrintTemplate.vue

@ -10,271 +10,281 @@
border-right: 1px solid #000;
"
>
<tr>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" colspan="4">
<img style="height: 40px" src="../../../public/img/htlogo.png" alt="暂无图片" />
</th>
<th
colspan="6"
style="font-size: 20px; border-bottom: 1px solid #000; border-left: 1px solid #000"
>
线
</th>
<th
style="border-bottom: 1px solid #000; border-left: 1px solid #000"
:colspan="6 + goodsTitleList.length + 1"
>
<img id="imgcode" :src="renderInfo.carsNoBase64" />
<div>{{ renderInfo.carsNo }}</div>
</th>
</tr>
<tr>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" colspan="4">
始发站{{ renderInfo.startWarehouseName }}
</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" colspan="6">
经停站{{
renderInfo.endWarehouseNames.slice(0, renderInfo.endWarehouseNames.length - 1)[0] || ''
}}
</th>
<th
style="border-bottom: 1px solid #000; border-left: 1px solid #000"
:colspan="6 + goodsTitleList.length + 1"
>
目的站{{ renderInfo.endWarehouseNames.slice(-1)[0] }}
</th>
</tr>
<tr>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" colspan="4">
司机{{ renderInfo.assistantName || '' }}
</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" colspan="2">
司机电话{{ renderInfo.assistantMobile || '' }}
</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" colspan="3">
车牌号{{ renderInfo.carNumber || '' }}
</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000">
卸车完成时间 {{ renderInfo.unloadDate || '年 月 日' }}
</th>
<th
style="border-bottom: 1px solid #000; border-left: 1px solid #000"
:colspan="6 + goodsTitleList.length + 1"
>
卸车人员签字
</th>
</tr>
<tr>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" rowspan="2">序号</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" rowspan="2">
发货单位
</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" rowspan="2">
开单时间
</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" rowspan="2">
始发仓
</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" rowspan="2">
目的仓
</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" rowspan="2">
收货单位
</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" rowspan="2">
收货人
</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" rowspan="2">
收货电话
</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" rowspan="2">
物流单号
</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" rowspan="2">
合同号
</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" rowspan="2">
计划件数
</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" rowspan="2">货位</th>
<th
style="border-bottom: 1px solid #000; border-left: 1px solid #000"
:colspan="goodsTitleList.length + 1"
>
装车产品明细
</th>
<!-- <th style="border-bottom: 1px solid #000; border-left: 1px solid #000;" rowspan="2">合计件数</th> -->
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" rowspan="2">
卸车件数
</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" rowspan="2">
卸车网点
</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" rowspan="2">
卸车时间
</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" rowspan="2">
异常备注
</th>
</tr>
<tr>
<th
style="border-bottom: 1px solid #000; border-left: 1px solid #000"
v-for="item in goodsTitleList"
:key="item"
>
{{ item }}
</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000">小计</th>
</tr>
<!-- -->
<template v-if="orderList.length > 0">
<tr v-for="(value, index) in orderList" style="word-break: break-all">
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000">
{{ index + 1 }}
</td>
<!-- 发货单位 -->
<td
v-if="value.mergeColumnIndex"
style="border-bottom: 1px solid #000; border-left: 1px solid #000"
:rowspan="value.mergeColumnIndex"
contenteditable
<thead>
<tr>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" colspan="4">
<img style="height: 40px" src="../../../public/img/htlogo.png" alt="暂无图片" />
</th>
<th
colspan="6"
style="font-size: 20px; border-bottom: 1px solid #000; border-left: 1px solid #000"
>
{{ value.shipper || '' }}
</td>
<!-- 开单时间 -->
<td
v-if="value.mergeColumnIndex"
线
</th>
<th
style="border-bottom: 1px solid #000; border-left: 1px solid #000"
:rowspan="value.mergeColumnIndex"
contenteditable
:colspan="6 + goodsTitleList.length + 1"
>
{{ value.createTime || '' }}
</td>
<!-- 始发仓 -->
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000" contenteditable>
{{ value.departureWarehouseName || '' }}
</td>
<!-- 目的仓 -->
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000" contenteditable>
{{ value.destinationWarehouseName || '' }}
</td>
<!-- 收货单位 -->
<td
v-if="value.mergeColumnIndex"
<img id="imgcode" :src="renderInfo.carsNoBase64" />
<div>{{ renderInfo.carsNo }}</div>
</th>
</tr>
<tr>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" colspan="4">
始发站{{ renderInfo.startWarehouseName }}
</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" colspan="6">
经停站{{
renderInfo.endWarehouseNames.slice(0, renderInfo.endWarehouseNames.length - 1)[0] ||
''
}}
</th>
<th
style="border-bottom: 1px solid #000; border-left: 1px solid #000"
:rowspan="value.mergeColumnIndex"
contenteditable
:colspan="6 + goodsTitleList.length + 1"
>
{{ value.consignee }}
</td>
<!-- 收货人 -->
<td
v-if="value.mergeColumnIndex"
目的站{{ renderInfo.endWarehouseNames.slice(-1)[0] }}
</th>
</tr>
<tr>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" colspan="4">
司机{{ renderInfo.assistantName || '' }}
</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" colspan="2">
司机电话{{ renderInfo.assistantMobile || '' }}
</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" colspan="3">
车牌号{{ renderInfo.carNumber || '' }}
</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000">
卸车完成时间 {{ renderInfo.unloadDate || '年 月 日' }}
</th>
<th
style="border-bottom: 1px solid #000; border-left: 1px solid #000"
:rowspan="value.mergeColumnIndex"
contenteditable
:colspan="6 + goodsTitleList.length + 1"
>
{{ value.consigneeName }}
</td>
<!-- 收货电话 -->
<td
v-if="value.mergeColumnIndex"
卸车人员签字
</th>
</tr>
<tr>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" rowspan="2">
序号
</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" rowspan="2">
发货单位
</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" rowspan="2">
开单时间
</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" rowspan="2">
始发仓
</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" rowspan="2">
目的仓
</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" rowspan="2">
收货单位
</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" rowspan="2">
收货人
</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" rowspan="2">
收货电话
</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" rowspan="2">
物流单号
</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" rowspan="2">
合同号
</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" rowspan="2">
计划件数
</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" rowspan="2">
货位
</th>
<th
style="border-bottom: 1px solid #000; border-left: 1px solid #000"
:rowspan="value.mergeColumnIndex"
contenteditable
:colspan="goodsTitleList.length + 1"
>
{{ value.consigneeMobile }}
</td>
<!-- 物流单号 -->
<td
v-if="value.mergeColumnIndex"
装车产品明细
</th>
<!-- <th style="border-bottom: 1px solid #000; border-left: 1px solid #000;" rowspan="2">合计件数</th> -->
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" rowspan="2">
卸车件数
</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" rowspan="2">
卸车网点
</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" rowspan="2">
卸车时间
</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" rowspan="2">
异常备注
</th>
</tr>
<tr>
<th
style="border-bottom: 1px solid #000; border-left: 1px solid #000"
:rowspan="value.mergeColumnIndex"
v-for="item in goodsTitleList"
:key="item"
>
{{ value.waybillNo }}
</td>
<!-- 合同号 -->
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000">
{{ value.orderCode }}
{{ item }}
</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000">小计</th>
</tr>
</thead>
<tbody>
<!-- -->
<template v-if="orderList.length > 0">
<tr v-for="(value, index) in orderList" style="word-break: break-all">
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000">
{{ index + 1 }}
</td>
<!-- 发货单位 -->
<td
v-if="value.mergeColumnIndex"
style="border-bottom: 1px solid #000; border-left: 1px solid #000"
:rowspan="value.mergeColumnIndex"
contenteditable
>
{{ value.shipper || '' }}
</td>
<!-- 开单时间 -->
<td
v-if="value.mergeColumnIndex"
style="border-bottom: 1px solid #000; border-left: 1px solid #000"
:rowspan="value.mergeColumnIndex"
contenteditable
>
{{ value.createTime || '' }}
</td>
<!-- 始发仓 -->
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000" contenteditable>
{{ value.departureWarehouseName || '' }}
</td>
<!-- 目的仓 -->
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000" contenteditable>
{{ value.destinationWarehouseName || '' }}
</td>
<!-- 收货单位 -->
<td
v-if="value.mergeColumnIndex"
style="border-bottom: 1px solid #000; border-left: 1px solid #000"
:rowspan="value.mergeColumnIndex"
contenteditable
>
{{ value.consignee }}
</td>
<!-- 收货人 -->
<td
v-if="value.mergeColumnIndex"
style="border-bottom: 1px solid #000; border-left: 1px solid #000"
:rowspan="value.mergeColumnIndex"
contenteditable
>
{{ value.consigneeName }}
</td>
<!-- 收货电话 -->
<td
v-if="value.mergeColumnIndex"
style="border-bottom: 1px solid #000; border-left: 1px solid #000"
:rowspan="value.mergeColumnIndex"
contenteditable
>
{{ value.consigneeMobile }}
</td>
<!-- 物流单号 -->
<td
v-if="value.mergeColumnIndex"
style="border-bottom: 1px solid #000; border-left: 1px solid #000"
:rowspan="value.mergeColumnIndex"
>
{{ value.waybillNo }}
</td>
<!-- 合同号 -->
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000">
{{ value.orderCode }}
</td>
<!-- 计划件数 -->
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000" contenteditable>
{{ value.planNum }}
</td>
<!-- 货位 -->
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000"></td>
<td
style="border-bottom: 1px solid #000; border-left: 1px solid #000"
contenteditable
v-for="item in goodsTitleList"
>
{{ (value.goodsList.find(val => val.goodsName === item) || {}).num || '' }}
</td>
<!-- 小计 -->
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000" contenteditable>
{{ value.smallTotal }}
</td>
<!-- 合计件数 -->
<!-- <td style="border-bottom: 1px solid #000; border-left: 1px solid #000;" contenteditable>{{ value.smallTotal }}</td> -->
<!-- 卸车件数 -->
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000" contenteditable>
{{ value.unloadNum }}
</td>
<!-- 卸车网点 -->
<td
style="border-bottom: 1px solid #000; border-left: 1px solid #000"
contenteditable
></td>
<!-- 卸车时间 -->
<td
style="border-bottom: 1px solid #000; border-left: 1px solid #000"
contenteditable
></td>
<!-- 异常备注 -->
<td
style="border-bottom: 1px solid #000; border-left: 1px solid #000"
contenteditable
></td>
</tr>
</template>
<!-- 合计行 -->
<tr>
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000" colspan="10">
合计
</td>
<!-- 计划件数 -->
<!-- 合计 -- 计划件数 -->
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000" contenteditable>
{{ value.planNum }}
{{ totalPlanNum }}
</td>
<!-- 货位 -->
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000"></td>
<td
style="border-bottom: 1px solid #000; border-left: 1px solid #000"
contenteditable
v-for="item in goodsTitleList"
>
{{ (value.goodsList.find(val => val.goodsName === item) || {}).num || '' }}
</td>
<!-- 小计 -->
></td>
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000" contenteditable>
{{ value.smallTotal }}
{{ totalNum }}
</td>
<!-- 合计件数 -->
<!-- <td style="border-bottom: 1px solid #000; border-left: 1px solid #000;" contenteditable>{{ value.smallTotal }}</td> -->
<!-- <td style="border-bottom: 1px solid #000; border-left: 1px solid #000;" contenteditable>{{ totalNum }}</td> -->
<!-- 卸车件数 -->
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000" contenteditable>
{{ value.unloadNum }}
{{ totalUnLoadNum }}
</td>
<!-- 卸车网点 -->
<td
style="border-bottom: 1px solid #000; border-left: 1px solid #000"
contenteditable
></td>
<!-- 卸车时间 -->
<td
style="border-bottom: 1px solid #000; border-left: 1px solid #000"
contenteditable
></td>
<!-- 异常备注 -->
<td
style="border-bottom: 1px solid #000; border-left: 1px solid #000"
contenteditable
></td>
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000"></td>
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000"></td>
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000"></td>
</tr>
</template>
<!-- 合计行 -->
<tr>
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000" colspan="10">
合计
</td>
<!-- 合计 -- 计划件数 -->
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000" contenteditable>
{{ totalPlanNum }}
</td>
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000"></td>
<td
style="border-bottom: 1px solid #000; border-left: 1px solid #000"
contenteditable
v-for="item in goodsTitleList"
></td>
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000" contenteditable>
{{ totalNum }}
</td>
<!-- 合计件数 -->
<!-- <td style="border-bottom: 1px solid #000; border-left: 1px solid #000;" contenteditable>{{ totalNum }}</td> -->
<!-- 卸车件数 -->
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000" contenteditable>
{{ totalUnLoadNum }}
</td>
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000"></td>
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000"></td>
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000"></td>
</tr>
<tr style="border-bottom: 1px solid #000; border-left: 1px solid #000">
<td :colspan="6" contenteditable>投诉电话4000184668</td>
<tr style="border-bottom: 1px solid #000; border-left: 1px solid #000">
<td :colspan="6" contenteditable>投诉电话4000184668</td>
<td :colspan="6" contenteditable>营业部电话</td>
<td :colspan="6" contenteditable>营业部电话</td>
<td :colspan="5 + goodsTitleList.length" contenteditable>系统单调度</td>
</tr>
<td :colspan="5 + goodsTitleList.length" contenteditable>系统单调度</td>
</tr>
</tbody>
</table>
</div>
</template>

398
src/components/ArteryPrintTemplateV2/ArteryPrintTemplateV2.vue

@ -10,215 +10,221 @@
border-right: 1px solid #000;
"
>
<tr>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" colspan="4">
<img style="height: 40px" src="../../../public/img/htlogo.png" alt="暂无图片" />
</th>
<th
colspan="6"
style="font-size: 20px; border-bottom: 1px solid #000; border-left: 1px solid #000"
>
线
</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" :colspan="7">
<img id="imgcode" :src="renderInfo.carsNoBase64" />
<div>{{ renderInfo.carsNo }}</div>
</th>
</tr>
<tr>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" colspan="4">
始发站{{ renderInfo.startWarehouseName }}
</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" colspan="6">
经停站{{
renderInfo.endWarehouseNames.slice(0, renderInfo.endWarehouseNames.length - 1)[0] || ''
}}
</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" :colspan="7">
目的站{{ renderInfo.endWarehouseNames.slice(-1)[0] }}
</th>
</tr>
<tr>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" colspan="4">
司机{{ renderInfo.assistantName || '' }}
</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" colspan="2">
司机电话{{ renderInfo.assistantMobile || '' }}
</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" colspan="3">
车牌号{{ renderInfo.carNumber || '' }}
</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000">
卸车完成时间 {{ renderInfo.unloadDate || '年 月 日' }}
</th>
<th
style="
border-bottom: 1px solid #000;
border-left: 1px solid #000;
text-align: left;
padding-left: 10px;
"
:colspan="7"
>
卸车人员签字
</th>
</tr>
<tr>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000">序号</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000">发货单位</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000">开单时间</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000">始发仓</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000">目的仓</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000">收货单位</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000">收货人</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000">收货电话</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000">物流单号</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000">合同号</th>
<th colspan="2" style="border-bottom: 1px solid #000; border-left: 1px solid #000">
装车产品明细
</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000">计划件数</th>
<!-- 本仓装车件数 -->
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000">本仓装车件数</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000">总装车件数</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000">卸车件数</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000">异常备注</th>
</tr>
<!-- -->
<template v-if="orderList.length > 0">
<tr v-for="(value, index) in orderList" style="word-break: break-all">
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000">
{{ index + 1 }}
</td>
<!-- 发货单位 -->
<td
v-if="value.mergeColumnIndex"
style="border-bottom: 1px solid #000; border-left: 1px solid #000"
:rowspan="value.mergeColumnIndex"
contenteditable
>
{{ value.shipper || '' }}
</td>
<!-- 开单时间 -->
<td
v-if="value.mergeColumnIndex"
style="border-bottom: 1px solid #000; border-left: 1px solid #000"
:rowspan="value.mergeColumnIndex"
contenteditable
>
{{ value.createTime || '' }}
</td>
<!-- 始发仓 -->
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000" contenteditable>
{{ value.departureWarehouseName || '' }}
</td>
<!-- 目的仓 -->
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000" contenteditable>
{{ value.destinationWarehouseName || '' }}
</td>
<!-- 收货单位 -->
<td
v-if="value.mergeColumnIndex"
style="border-bottom: 1px solid #000; border-left: 1px solid #000"
:rowspan="value.mergeColumnIndex"
contenteditable
>
{{ value.consignee }}
</td>
<!-- 收货人 -->
<td
v-if="value.mergeColumnIndex"
style="border-bottom: 1px solid #000; border-left: 1px solid #000"
:rowspan="value.mergeColumnIndex"
contenteditable
>
{{ value.consigneeName }}
</td>
<!-- 收货电话 -->
<td
v-if="value.mergeColumnIndex"
style="border-bottom: 1px solid #000; border-left: 1px solid #000"
:rowspan="value.mergeColumnIndex"
contenteditable
>
{{ value.consigneeMobile }}
</td>
<!-- 物流单号 -->
<td
v-if="value.mergeColumnIndex"
style="border-bottom: 1px solid #000; border-left: 1px solid #000"
:rowspan="value.mergeColumnIndex"
<thead>
<tr>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" colspan="4">
<img style="height: 40px" src="../../../public/img/htlogo.png" alt="暂无图片" />
</th>
<th
colspan="6"
style="font-size: 20px; border-bottom: 1px solid #000; border-left: 1px solid #000"
>
{{ value.waybillNo }}
</td>
<!-- 合同号 -->
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000">
{{ value.orderCode }}
</td>
<!-- 品类明细 -->
<td
colspan="2"
style="border-bottom: 1px solid #000; border-left: 1px solid #000"
contenteditable
线
</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" :colspan="7">
<img id="imgcode" :src="renderInfo.carsNoBase64" />
<div>{{ renderInfo.carsNo }}</div>
</th>
</tr>
<tr>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" colspan="4">
始发站{{ renderInfo.startWarehouseName }}
</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" colspan="6">
经停站{{
renderInfo.endWarehouseNames.slice(0, renderInfo.endWarehouseNames.length - 1)[0] ||
''
}}
</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" :colspan="7">
目的站{{ renderInfo.endWarehouseNames.slice(-1)[0] }}
</th>
</tr>
<tr>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" colspan="4">
司机{{ renderInfo.assistantName || '' }}
</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" colspan="2">
司机电话{{ renderInfo.assistantMobile || '' }}
</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000" colspan="3">
车牌号{{ renderInfo.carNumber || '' }}
</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000">
卸车完成时间 {{ renderInfo.unloadDate || '年 月 日' }}
</th>
<th
style="
border-bottom: 1px solid #000;
border-left: 1px solid #000;
text-align: left;
padding-left: 10px;
"
:colspan="7"
>
{{ value.goodsListStr }}
卸车人员签字
</th>
</tr>
<tr>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000">序号</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000">发货单位</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000">开单时间</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000">始发仓</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000">目的仓</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000">收货单位</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000">收货人</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000">收货电话</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000">物流单号</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000">合同号</th>
<th colspan="2" style="border-bottom: 1px solid #000; border-left: 1px solid #000">
装车产品明细
</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000">计划件数</th>
<!-- 本仓装车件数 -->
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000">本仓装车件数</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000">总装车件数</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000">卸车件数</th>
<th style="border-bottom: 1px solid #000; border-left: 1px solid #000">异常备注</th>
</tr>
</thead>
<tbody>
<!-- -->
<template v-if="orderList.length > 0">
<tr v-for="(value, index) in orderList" style="word-break: break-all">
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000">
{{ index + 1 }}
</td>
<!-- 发货单位 -->
<td
v-if="value.mergeColumnIndex"
style="border-bottom: 1px solid #000; border-left: 1px solid #000"
:rowspan="value.mergeColumnIndex"
contenteditable
>
{{ value.shipper || '' }}
</td>
<!-- 开单时间 -->
<td
v-if="value.mergeColumnIndex"
style="border-bottom: 1px solid #000; border-left: 1px solid #000"
:rowspan="value.mergeColumnIndex"
contenteditable
>
{{ value.createTime || '' }}
</td>
<!-- 始发仓 -->
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000" contenteditable>
{{ value.departureWarehouseName || '' }}
</td>
<!-- 目的仓 -->
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000" contenteditable>
{{ value.destinationWarehouseName || '' }}
</td>
<!-- 收货单位 -->
<td
v-if="value.mergeColumnIndex"
style="border-bottom: 1px solid #000; border-left: 1px solid #000"
:rowspan="value.mergeColumnIndex"
contenteditable
>
{{ value.consignee }}
</td>
<!-- 收货人 -->
<td
v-if="value.mergeColumnIndex"
style="border-bottom: 1px solid #000; border-left: 1px solid #000"
:rowspan="value.mergeColumnIndex"
contenteditable
>
{{ value.consigneeName }}
</td>
<!-- 收货电话 -->
<td
v-if="value.mergeColumnIndex"
style="border-bottom: 1px solid #000; border-left: 1px solid #000"
:rowspan="value.mergeColumnIndex"
contenteditable
>
{{ value.consigneeMobile }}
</td>
<!-- 物流单号 -->
<td
v-if="value.mergeColumnIndex"
style="border-bottom: 1px solid #000; border-left: 1px solid #000"
:rowspan="value.mergeColumnIndex"
>
{{ value.waybillNo }}
</td>
<!-- 合同号 -->
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000">
{{ value.orderCode }}
</td>
<!-- 品类明细 -->
<td
colspan="2"
style="border-bottom: 1px solid #000; border-left: 1px solid #000"
contenteditable
>
{{ value.goodsListStr }}
</td>
<!-- 计划件数 -->
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000" contenteditable>
{{ value.planNum || 0 }}
</td>
<!-- 本仓装车件数 -->
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000" contenteditable>
{{ value.loadingNum || 0 }}
</td>
<!-- 总装车件数 -->
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000" contenteditable>
{{ value.stockNum || 0 }}
</td>
<!-- 卸车件数 -->
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000" contenteditable>
{{ value.unloadNum || 0 }}
</td>
<!-- 异常备注 -->
<td
style="border-bottom: 1px solid #000; border-left: 1px solid #000"
contenteditable
></td>
</tr>
</template>
<!-- 合计行 -->
<tr>
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000" colspan="10">
合计
</td>
<!-- 计划件数 -->
<td colspan="2" style="border-bottom: 1px solid #000; border-left: 1px solid #000"></td>
<!-- 合计 -- 计划件数 -->
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000" contenteditable>
{{ value.planNum || 0 }}
{{ totalPlanNum }}
</td>
<!-- 本仓装车件数 -->
<!-- 本仓装车数 -->
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000" contenteditable>
{{ value.loadingNum || 0 }}
{{ totalloadingNum }}
</td>
<!-- 总装车件数 -->
<!-- 总装车数 -->
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000" contenteditable>
{{ value.stockNum || 0 }}
{{ totalStockloadingNum }}
</td>
<!-- 卸车件数 -->
<!-- 卸车数 -->
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000" contenteditable>
{{ value.unloadNum || 0 }}
{{ totalUnLoadNum }}
</td>
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000"></td>
</tr>
<tr style="border-bottom: 1px solid #000; border-left: 1px solid #000">
<td :colspan="6" contenteditable>投诉电话4000184668</td>
<td :colspan="6" contenteditable>营业部电话</td>
<!-- 异常备注 -->
<td
style="border-bottom: 1px solid #000; border-left: 1px solid #000"
contenteditable
></td>
<td :colspan="5" contenteditable>系统单调度</td>
</tr>
</template>
<!-- 合计行 -->
<tr>
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000" colspan="10">
合计
</td>
<td colspan="2" style="border-bottom: 1px solid #000; border-left: 1px solid #000"></td>
<!-- 合计 -- 计划件数 -->
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000" contenteditable>
{{ totalPlanNum }}
</td>
<!-- 本仓装车数 -->
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000" contenteditable>
{{ totalloadingNum }}
</td>
<!-- 总装车数 -->
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000" contenteditable>
{{ totalStockloadingNum }}
</td>
<!-- 卸车数 -->
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000" contenteditable>
{{ totalUnLoadNum }}
</td>
<td style="border-bottom: 1px solid #000; border-left: 1px solid #000"></td>
</tr>
<tr style="border-bottom: 1px solid #000; border-left: 1px solid #000">
<td :colspan="6" contenteditable>投诉电话4000184668</td>
<td :colspan="6" contenteditable>营业部电话</td>
<td :colspan="5" contenteditable>系统单调度</td>
</tr>
</tbody>
</table>
</div>
</template>

6
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;
}

2
src/option/reportforms/DeliveryStatisticsReport.js

@ -157,7 +157,7 @@ export const columnList = [
},
{
prop: 'reviewOnTimeRate',
label: '符合及时率',
label: '复核及时率',
type: 6,
values: '',
width: '150',

275
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, //开启统计
},
];

97
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',

126
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,
},
];

2
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;
}
</style>

14
src/page/index/top/index.vue

@ -11,9 +11,9 @@
</div>
<div class="top-bar__title">
<top-menu ref="topMenu" v-if="setting.menu"></top-menu>
<top-search class="top-bar__item" v-if="setting.search"></top-search>
</div>
<div class="top-bar__right">
<!-- <top-search class="top-bar__item" v-if="setting.search"></top-search> -->
<div v-if="setting.lock" class="top-bar__item">
<top-lock></top-lock>
</div>
@ -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([

6
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;
}
}

39
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"
/>
<el-button type="primary" @click="inputData(Data.input)">发送</el-button>
</div>
@ -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;
}

17
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'),
},
],
},
];

11
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;

3
src/views/cost/Deliverycostmanagement/OrderTotalCostDetail.vue

@ -39,9 +39,6 @@
<el-button type="primary" @click="exportExcel"
><el-icon><Download /></el-icon></el-button
>
<el-button type="primary" @click="aaa"
><el-icon><Download /></el-icon></el-button
>
</div>
<!-- 头部右侧按钮模块 -->
<div class="avue-crud__right">

1
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';

93
src/views/cost/storagecost/Transferwarehouseorders.vue

@ -6,7 +6,7 @@
<el-row v-if="search">
<!-- 查询模块 -->
<el-form :inline="true" :model="queryTop" class="el-fr-d">
<div>
<!-- <div>
<el-form-item label="中转仓">
<el-select
v-model="queryTop.warehouse"
@ -65,7 +65,7 @@
:default-time="defaultTime2"
/>
</el-form-item>
</div>
</div> -->
<!-- 查询按钮 -->
<el-form-item class="el-btn">
<el-button type="primary" icon="el-icon-search" @click="searchChange"> </el-button>
@ -79,10 +79,7 @@
<div class="avue-crud__header">
<!-- 头部左侧按钮模块 -->
<div class="avue-crud__left">
<el-button type="primary" @click="AddInfo"
><el-icon><Plus /></el-icon></el-button
>
<el-button type="primary" @click="AddInfo"
<el-button type="primary" @click="exportExcel"
><el-icon><Download /></el-icon></el-button
>
</div>
@ -110,11 +107,7 @@
@selection="selectionChange"
>
<template #default="slotProps">
<template v-if="slotProps.scope.column.label === '操作'">
<div class="ElBtnClass">
<el-button @click="view(slotProps.scope)">查看</el-button>
</div>
</template>
<template v-if="slotProps.scope.column.label === '操作'"> </template>
</template>
</tablecmt>
</el-row>
@ -147,14 +140,17 @@
v-model="details.columnList"
></edittablehead>
</template>
<script>
export default {
name: '/cost/storagecost/Transferwarehouseorders',
};
</script>
<script setup>
import { ref, reactive, toRefs, computed, onMounted, nextTick, watch } from 'vue';
import { columnList } from '@/option/storagecost/Transferwarehouseorders.js';
import { getDictionaryBiz } from '@/api/system/dict'; //
import { processRowProperty, setNodeHeight } from '@/utils/util';
import { $_getMyWarehouseList } from '@/api/storagecost/index.js';
import functions from '@/utils/functions.js';
import { processRowProperty, setNodeHeight,handleClearTableQuery } from '@/utils/util';
import { $_getMyWarehouseList, $_Transferwarehouseorderspage ,$_exportTransit} from '@/api/storagecost/index.js';
import { ElMessageBox, ElMessage } from 'element-plus';
import { downloadXls } from '@/utils/util';
import { useStore } from 'vuex';
@ -205,7 +201,7 @@ const details = reactive({
columnList,
/** 列表数据 */
data: [{}],
data: [],
/** 页面loading */
loadingObj: {
/** 列表加载loading */
@ -266,10 +262,7 @@ const showdrawer = _flag => {
const inputsc = (index, row) => {
details.query[row.prop] = index;
processRowProperty(index, row, details);
test(details.query);
};
//
const test = val => {};
/** 表格表头时间选择 */
const timesc = (index, row) => {
console.log(index, row);
@ -299,6 +292,12 @@ const selectionChange = list => {
const searchChange = () => {
details.search = false; //
};
//
const searchReset=()=>{
details.query = {};
handleClearTableQuery(details.columnList);
onLoad();
}
//
const sizeChange = val => {
details.page.pageSize = val;
@ -311,7 +310,7 @@ const currentChange = val => {
};
//
const searchChangeS = () => {
details.search = false; //
onLoad();
};
//
const searchHide = () => {
@ -354,7 +353,31 @@ const MyWarehouseList = () => {
});
};
//
const onLoad = () => {};
const onLoad = async () => {
try {
details.loadingObj.list = true;
let submit = {
current: details.page.currentPage,
size: details.page.pageSize,
...details.query,
...$route.query,
};
let res = await $_Transferwarehouseorderspage(submit);
console.log(res, 'res');
const { code, data } = res.data;
if (code != 200) {
return;
}
console.log(data, 'data');
details.data = data.records;
details.page.total = data.total;
} catch (e) {
console.log(e);
} finally {
details.loadingObj.list = false;
}
};
const PageOnload = () => {
onLoad(); //
MyWarehouseList(); //
@ -363,7 +386,33 @@ const PageOnload = () => {
//
PageOnload();
//
const exportExcel = () => {
ElMessageBox.confirm('是否导出数据?', {
confirmButtonText: '确定',
cancelButtonText: '取消',
type: 'warning',
})
.then(async () => {
try {
details.loadingObj.list = true;
let data = {
...details.query,
...$route.query,
};
let res = await $_exportTransit(data);
downloadXls(res.data, `中转月度作业明细统计.xlsx`);
ElMessage({
message: '导出成功',
type: 'success',
});
} catch (error) {
console.log(error);
} finally {
details.loadingObj.list = false;
}
})
.catch(() => {});
};
</script>
<style scoped lang="scss">

624
src/views/cost/storagecost/Transferwarehousestatistics.vue

@ -9,11 +9,26 @@
<div>
<el-form-item label="中转仓">
<el-select
v-model="queryTop.warehouse"
multiple
placeholder="请选择仓库"
style="min-width: 340px"
v-model="queryTop.transitWarehouseName"
filterable
clearable
collapse-tags
popper-class="custom-header"
:max-collapse-tags="1"
placeholder="多选仓库搜索"
style="width: 200px"
>
<template #header>
<el-checkbox
v-model="checkAlla"
:indeterminate="indeterminatea"
@change="handleCheckAlla"
>
全选
</el-checkbox>
</template>
<el-option
v-for="item in warehouseList"
:key="item.value"
@ -22,29 +37,58 @@
/>
</el-select>
</el-form-item>
<el-form-item label="结算年份">
<el-date-picker
v-model="queryTop.costSettlementYear"
type="year"
placeholder="请选择年份"
value-format="YYYY"
/>
</el-form-item>
<el-form-item label="结算月">
<el-form-item label="目的仓">
<el-select
v-model="queryTop.costSettlementMonth"
placeholder="请选择月份"
style="min-width: 80px"
multiple
v-model="queryTop.destinationWarehouseName"
filterable
clearable
collapse-tags
popper-class="custom-header"
:max-collapse-tags="1"
placeholder="多选仓库搜索"
style="width: 200px"
>
<template #header>
<el-checkbox
v-model="checkAllb"
:indeterminate="indeterminateb"
@change="handleCheckAllb"
>
全选
</el-checkbox>
</template>
<el-option
v-for="item in monthList"
v-for="item in warehouseList"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</el-form-item>
<el-form-item label="出账时间">
<el-date-picker
v-model="queryTop.PaymentTime"
type="month"
value-format="YYYY-MM"
placeholder="请选择日期"
/>
</el-form-item>
<el-form-item label="结算时间">
<el-date-picker
v-model="queryTop.SettlementTime"
type="datetimerange"
unlink-panels
range-separator="至"
start-placeholder="开始时间"
end-placeholder="结束时间"
:shortcuts="shortcuts"
:default-time="defaultTime2"
value-format="YYYY-MM-DD HH:mm:ss"
/>
</el-form-item>
</div>
<!-- 查询按钮 -->
<el-form-item class="el-btn">
@ -59,10 +103,7 @@
<div class="avue-crud__header">
<!-- 头部左侧按钮模块 -->
<div class="avue-crud__left">
<el-button type="primary" @click="AddInfo"
><el-icon><Plus /></el-icon></el-button
>
<el-button type="primary" @click="AddInfo"
<el-button type="primary" @click="exportExcel"
><el-icon><Download /></el-icon></el-button
>
</div>
@ -91,11 +132,20 @@
>
<template #default="slotProps">
<template v-if="slotProps.scope.column.label === '操作'">
<!-- <div class="ElBtnClass">
<el-text @click="abnormalinformation(slotProps.scope.row)">异常信息</el-text>
<el-text @click="view(slotProps.scope.row)">结算信息</el-text>
<div class="ElBtnClass">
<el-text @click="abnormalinformation(slotProps.scope.row, '异常')"
>异常信息</el-text
>
<el-text @click="abnormalinformation(slotProps.scope.row, '结算')"
>结算信息</el-text
>
<el-text
v-if="slotProps.scope.row.settlementStatus !== '已结算'"
@click="Confirmsettlement(slotProps.scope.row)"
>确认结算</el-text
>
<el-text @click="view(slotProps.scope.row)">明细</el-text>
</div> -->
</div>
</template>
</template>
</tablecmt>
@ -123,75 +173,122 @@
<el-dialog
v-model="Abnormalsettlement.dialogVisible"
title="结算信息"
:close-on-click-modal="false"
:title="Abnormalsettlement.title + '信息'"
width="60%"
class="el_Abnormalsettlement"
>
<el-tabs class="demo-tabs" v-model="Abnormalsettlement.activeName1">
<el-tab-pane label="费用信息" name="费用信息">
<h3>结算单号:XXXXXXXXXXXX</h3>
<h3>结算状态:已结算</h3>
<div class="el_money">
<span>总费用:<b>199999</b></span>
<span>待结算费用:<b>2232</b></span>
<span>已结算费用:<b>23423</b></span>
<span>异常费用:<b>124124</b></span>
</div>
<el-form
:model="Abnormalsettlement.form"
label-width="auto"
:rules="Abnormalsettlement.rules"
ref="ruleFormRef"
>
<el-form-item label="异常费用:" prop="money">
<el-input-number
v-model="Abnormalsettlement.form.money"
:controls="false"
:value-on-clear="0"
:precision="2"
:step="1"
placeholder="此处填写要登记的异常金额,正数表示异常增款,负数表示异常减款"
/>
</el-form-item>
<el-form-item label="异常备注:" prop="textarea2">
<el-input
v-model="Abnormalsettlement.form.textarea2"
:autosize="{ minRows: 4, maxRows: 4 }"
type="textarea"
placeholder="请输入异常备注"
/>
</el-form-item>
<el-form-item label="异常图片:" prop="fileList">
<el-upload
list-type="picture-card"
v-model:file-list="Abnormalsettlement.form.fileList"
drag
:action="FileUpload()"
multiple
:limit="10"
:on-preview="handlePictureCardPreview"
:before-upload="beforeAvatarUpload"
:on-remove="handleRemove"
:headers="headers()"
<div v-loading="Abnormalsettlement.loading" element-loading-text="Loading...">
<el-tabs class="demo-tabs" v-model="Abnormalsettlement.activeName1" v-if="Abnormalsettlement.form.settlementStatus !='已结算'">
<el-tab-pane label="费用信息" name="费用信息">
<h3>结算单号:{{ Abnormalsettlement.form.settlementCode }}</h3>
<h3>结算状态:{{ Abnormalsettlement.form.settlementStatus }}</h3>
<div class="el_money">
<span
>总费用:<b>{{ Abnormalsettlement.form.totalCost || 0 }}</b></span
>
<el-icon><Plus /></el-icon>
</el-upload>
<!-- 图片预览 -->
<el-dialog v-model="Abnormalsettlement.dialogurl" class="el_imgdialog">
<img w-full :src="Abnormalsettlement.url" />
</el-dialog>
</el-form-item>
</el-form>
</el-tab-pane>
</el-tabs>
<el-tabs class="demo-tabs" v-model="Abnormalsettlement.activeName2">
<el-tab-pane label="异常记录" name="异常记录"> </el-tab-pane>
</el-tabs>
<span
>待结算费用:<b>{{ Abnormalsettlement.form.pendingSettlementAmount || 0 }}</b></span
>
<span
>已结算费用:<b>{{ Abnormalsettlement.form.settledAmount || 0 }}</b></span
>
<span
>异常费用:<b>{{ Abnormalsettlement.form.changeAmount || 0 }}</b></span
>
</div>
<el-form
:model="Abnormalsettlement.form"
label-width="auto"
:rules="Abnormalsettlement.rules"
ref="ruleFormRef"
>
<el-form-item :label="`${Abnormalsettlement.title}费用:`" prop="money">
<el-input-number
v-model="Abnormalsettlement.form.money"
:controls="false"
:value-on-clear="0"
:precision="2"
:step="1"
placeholder="此处填写要登记的异常金额,正数表示异常增款,负数表示异常减款"
/>
</el-form-item>
<el-form-item :label="`${Abnormalsettlement.title}备注:`" prop="changeNote">
<el-input
v-model="Abnormalsettlement.form.changeNote"
:autosize="{ minRows: 4, maxRows: 4 }"
type="textarea"
placeholder="请输入备注"
/>
</el-form-item>
<el-form-item :label="`${Abnormalsettlement.title}图片:`" prop="changeImageList">
<el-upload
list-type="picture-card"
v-model:file-list="Abnormalsettlement.form.changeImageList"
drag
:action="FileUpload()"
multiple
:limit="10"
:on-preview="handlePictureCardPreview"
:before-upload="beforeAvatarUpload"
:on-remove="handleRemove"
:headers="headers()"
>
<el-icon><Plus /></el-icon>
</el-upload>
<!-- 图片预览 -->
<el-dialog v-model="Abnormalsettlement.dialogurl" class="el_imgdialog">
<img w-full :src="Abnormalsettlement.url" />
</el-dialog>
</el-form-item>
</el-form>
</el-tab-pane>
</el-tabs>
<el-tabs class="demo-tabs" v-model="Abnormalsettlement.activeName2">
<el-tab-pane :label="`${Abnormalsettlement.title}记录`" name="异常记录">
<tablecmt
class="tableNodeRef"
:columnList="details.columnListrecord"
:tableData="details.datarecord"
:loading="details.loadingObj.listrecord"
>
<template #default="slotProps">
<el-text @click="handleShowImg(slotProps.scope.row)">查看图片</el-text>
</template>
</tablecmt>
</el-tab-pane>
</el-tabs>
</div>
<template #footer>
<el-button @click="Abnormalsettlement.dialogVisible = false">关闭</el-button>
<el-button type="primary" @click="AbnormalsettlementSubmit"> 确定 </el-button>
<el-button
type="primary"
@click="AbnormalsettlementSubmit"
:disabled="Abnormalsettlement.loading"
v-if="Abnormalsettlement.form.settlementStatus !='已结算'"
>
确定
</el-button>
</template>
</el-dialog>
<!-- 记录图片查看 -->
<el-dialog v-model="details.popUpShow.showImgVisited">
<div class="dialog_img">
<el-image
v-for="(url, index) in details.imgList"
:key="url"
style="width: 100px; height: 100px"
:src="url"
:zoom-rate="1.2"
:max-scale="7"
:min-scale="0.2"
:preview-src-list="details.imgList"
:initial-index="index"
fit="cover"
/>
</div>
</el-dialog>
</basic-container>
<!-- 列表配置显示 -->
<edittablehead
@ -204,13 +301,20 @@
<script setup>
import { ref, reactive, toRefs, computed, onMounted, nextTick, watch } from 'vue';
import { columnList } from '@/option/storagecost/Transferwarehousestatistics.js';
import { $_getMyWarehouseList } from '@/api/storagecost/index.js';
import { columnList, columnListrecord } from '@/option/storagecost/Transferwarehousestatistics.js';
import {
$_getMyWarehouseList,
$_Transferwarehousestatistics,
$_Transferwarehousestatisticsdetail,
$_Transferwarehousestatisticssave,
$_TransferwarehousestatisticsconfirmSettlement,
$_exportTransitMonth,
} from '@/api/storagecost/index.js';
import { compressImageBlob } from '@/components/IMGcompressor/imgcompressor.js';
import { getDictionaryBiz } from '@/api/system/dict'; //
import { processRowProperty, setNodeHeight } from '@/utils/util';
import { processRowPropertyName, setNodeHeight, handleClearTableQuery } from '@/utils/util';
import { ElMessageBox, ElMessage } from 'element-plus';
import { downloadXls, FileUpload, headers } from '@/utils/util';
import { downloadXls, FileUpload, headers, getObjType } from '@/utils/util';
import { getToken } from '@/utils/auth';
import { useStore } from 'vuex';
import dayjs from 'dayjs';
@ -221,6 +325,10 @@ const $route = useRoute(); //获取地址栏参数
const queryTop = ref({});
const warehouseList = ref([]);
const monthList = ref([]);
const indeterminatea = ref(false);
const checkAlla = ref(false);
const indeterminateb = ref(false);
const checkAllb = ref(false);
const validateFileList = (rule, value, callback) => {
if (!value.length) {
callback(new Error('至少上传一张图片'));
@ -229,14 +337,16 @@ const validateFileList = (rule, value, callback) => {
}
};
const Abnormalsettlement = ref({
title: '结算',
loading: false,
dialogVisible: false,
activeName1: '费用信息',
activeName2: '异常记录',
url: '',
dialogurl: false,
form: {
money: null,
fileList: [], //
money: 0,
changeImageList: [], //
},
rules: {
money: [
@ -246,23 +356,24 @@ const Abnormalsettlement = ref({
trigger: ['change', 'blur'],
},
],
textarea2: [
changeNote: [
{
required: true,
message: '请填写备注',
trigger: ['change', 'blur'],
},
],
fileList: [{ validator: validateFileList, trigger: 'change' }],
changeImageList: [{ validator: validateFileList, trigger: 'change' }],
},
});
const details = reactive({
fileList: [],
/** 是否开启搜索 */
search: false,
imgList: [],
/** 表格搜索条件 */
query: {},
/** 时间快捷选择设置 */
defaultTime2: [new Date(2000, 1, 1, 0, 0, 0), new Date(2000, 2, 1, 23, 59, 59)], // '12:00:00', '08:00:00'
shortcuts: [
{
text: '最近一周',
@ -294,14 +405,15 @@ const details = reactive({
],
/** 列表 */
columnList,
columnListrecord,
/** 列表数据 */
data: [{}],
data: [],
datarecord: [],
/** 页面loading */
loadingObj: {
/** 列表加载loading */
list: false,
packageListLoading: false,
listrecord: false,
},
/** 列表复选框选中的数据 */
selectionList: [],
@ -322,6 +434,7 @@ const details = reactive({
QRCodeVisible: false,
/** 修改客户信息 */
editClientInfoVisible: false,
showImgVisited: false,
},
/** 列表Dom节点 */
listNode: '',
@ -346,6 +459,8 @@ const {
zeroAdditionalRecordingInfo,
popUpShow,
recorddata,
datarecord,
defaultTime2,
} = toRefs(details);
/** 展开列表控件 */
@ -355,8 +470,8 @@ const showdrawer = _flag => {
/** 表格表头输入框搜索 */
const inputsc = (index, row) => {
details.query[row.prop] = index;
processRowProperty(index, row, details);
test(details.query);
processRowPropertyName(index, row, details.query);
onLoad();
};
//
const test = val => {};
@ -378,7 +493,8 @@ const btnsc = val => {
};
/** 表格表头下拉框选择 */
const selectsc = (index, row) => {
processRowProperty(index, row, details);
processRowPropertyName(index, row, details.query);
onLoad();
};
/** 表格表头复选框选择 */
const selectionChange = list => {
@ -387,25 +503,89 @@ const selectionChange = list => {
};
//
const searchChange = () => {
if (queryTop.value.warehouse?.length) {
queryTop.value.warehouseName = queryTop.value.warehouse.join(',');
//
if (queryTop.value.transitWarehouseName?.length) {
details.query.transitWarehouseName = queryTop.value.transitWarehouseName.join(',');
} else {
delete details.query.warehouseName;
delete queryTop.value.warehouseName;
delete details.query.transitWarehouseName;
}
if (queryTop.value.costSettlementMonth) {
if (!queryTop.value.costSettlementYear) {
ElMessage({
message: '请选择年份',
type: 'warning',
});
return;
}
//
if (queryTop.value.destinationWarehouseName?.length) {
details.query.destinationWarehouseName = queryTop.value.destinationWarehouseName.join(',');
} else {
delete details.query.destinationWarehouseName;
}
details.query = { ...details.query, ...queryTop.value };
delete details.query.warehouse; //
//
if (queryTop.value.PaymentTime?.length) {
const date = dayjs(queryTop.value.PaymentTime, 'YYYY年MM月');
console.log(queryTop.value.PaymentTime, 'queryTop.value.PaymentTime');
details.query.statisticalYear = date.year(); //
details.query.statisticalMonth = date.month() + 1; //
} else {
delete details.query.statisticalYear;
delete details.query.statisticalMonth;
}
//
if (queryTop.value.SettlementTime?.length) {
details.query.settlementTimeStart = queryTop.value.SettlementTime[0]; //
details.query.settlementTimeEnd = queryTop.value.SettlementTime[1]; //
} else {
delete details.query.settlementTimeStart;
delete details.query.settlementTimeEnd;
}
console.log(details.query, 'details.query');
onLoad();
};
//
const handleCheckAlla = val => {
indeterminatea.value = false;
if (val) {
queryTop.value.transitWarehouseName = warehouseList.value.map(_ => _.value);
} else {
queryTop.value.transitWarehouseName = [];
}
};
//
const handleCheckAllb = val => {
indeterminateb.value = false;
if (val) {
queryTop.value.destinationWarehouseName = warehouseList.value.map(_ => _.value);
} else {
queryTop.value.destinationWarehouseName = [];
}
};
watch(
() => queryTop.value.transitWarehouseName,
(newValue, oldValue) => {
if (newValue.length === 0) {
checkAlla.value = false;
indeterminatea.value = false;
} else if (newValue.length === warehouseList.value.length) {
checkAlla.value = true;
indeterminatea.value = false;
} else {
indeterminatea.value = true;
}
},
{ deep: true }
);
watch(
() => queryTop.value.destinationWarehouseName,
(newValue, oldValue) => {
if (newValue.length === 0) {
checkAllb.value = false;
indeterminateb.value = false;
} else if (newValue.length === warehouseList.value.length) {
checkAllb.value = true;
indeterminateb.value = false;
} else {
indeterminateb.value = true;
}
},
{ deep: true }
);
//
const sizeChange = val => {
details.page.pageSize = val;
@ -416,9 +596,16 @@ const currentChange = val => {
details.page.currentPage = val;
onLoad();
};
//
const searchReset = () => {
queryTop.value = {};
details.query = {};
handleClearTableQuery(details.columnList);
onLoad();
};
//
const searchChangeS = () => {
details.search = false; //
onLoad();
};
//
const searchHide = () => {
@ -480,7 +667,30 @@ const MyWarehouseList = () => {
});
};
//
const onLoad = () => {};
const onLoad = async () => {
try {
details.loadingObj.list = true;
let submit = {
current: details.page.currentPage,
size: details.page.pageSize,
...details.query,
};
let res = await $_Transferwarehousestatistics(submit);
console.log(res, 'res');
const { code, data } = res.data;
if (code != 200) {
return;
}
console.log(data, 'data');
details.data = data.records;
details.page.total = data.total;
} catch (error) {
console.log(error);
} finally {
details.loadingObj.list = false;
}
};
const PageOnload = () => {
onLoad(); //
MyWarehouseList(); //
@ -489,21 +699,170 @@ const PageOnload = () => {
//
PageOnload();
//
const abnormalinformation = () => {
Abnormalsettlement.value.dialogVisible = true;
//
const abnormalinformation = async (row, state) => {
try {
Abnormalsettlement.value.loading = true;
Abnormalsettlement.value.title = state;
Abnormalsettlement.value.form.money = null;
Abnormalsettlement.value.form.changeNote = '';
Abnormalsettlement.value.form.changeImageList = [];
Abnormalsettlement.value.dialogVisible = true;
let submit = {
id: row.id,
type: state,
};
let res = await $_Transferwarehousestatisticsdetail(submit);
console.log(res, 'res');
const { code, data } = res.data;
if (code != 200) {
return;
}
Abnormalsettlement.value.form = { ...Abnormalsettlement.value.form, ...data };
details.datarecord = data.changeList;
} catch (e) {
console.log(e);
} finally {
nextTick(() => {
const _node = document.querySelector('.tableNodeRef');
setNodeHeight(_node, '', true);
});
Abnormalsettlement.value.loading = false;
}
};
//
const Confirmsettlement = row => {
if (row.pendingSettlementAmount != 0) {
ElMessage({
message: '待结算金额不为0,无法确认结算',
type: 'warning',
plain: true,
});
return;
}
ElMessageBox.confirm('是否确认结算?', '提示', {
confirmButtonText: '确定',
cancelButtonText: '取消',
type: 'warning',
})
.then(async () => {
try {
details.loadingObj.list = true;
let submit = {
id: row.id,
};
let res = await $_TransferwarehousestatisticsconfirmSettlement(submit);
const { code, msg } = res.data;
if (code != 200) {
return;
}
ElMessage({
type: 'success',
message: msg,
});
onLoad();
} catch (e) {
console.log(e);
} finally {
details.loadingObj.list = false;
}
})
.catch(() => {});
};
//
const AbnormalsettlementSubmit = async () => {
await ruleFormRef.value.validate((valid, fields) => {
if (valid) {
console.log('submit!');
} else {
console.log('error submit!', fields);
ElMessage.error('表单校验未通过,请检查输入');
//
let state = await ruleFormRef.value.validate();
if (!state) {
return;
}
try {
Abnormalsettlement.value.loading = true;
details.loadingObj.list = true;
//
let submit = {
changeAmount: Abnormalsettlement.value.form.money, //
changeImageList: [], //
changeNote: Abnormalsettlement.value.form.changeNote, //
detailId: Abnormalsettlement.value.form.id, // id
type: Abnormalsettlement.value.title, // /
};
console.log(Abnormalsettlement.value.form, 'Abnormalsettlement.value.form');
Abnormalsettlement.value.form.changeImageList.forEach(item => {
let data = {
imageUrl: item.response.data.link,
};
submit['changeImageList'].push(data);
});
console.log(submit, '准备提交的数据');
//
let res = await $_Transferwarehousestatisticssave(submit);
const { msg, code } = res.data;
if (code == 200) {
Abnormalsettlement.value.dialogVisible = false;
ElMessage.success(msg);
onLoad();
}
} catch (error) {
//
console.error('提交失败:', error);
} finally {
Abnormalsettlement.value.loading = false;
details.loadingObj.list = false;
}
};
//
const view = row => {
console.log(row);
const date = dayjs(row.statisticalTime, 'YYYY年MM月');
$useStore.commit('DEL_ONCE_TAG', '/cost/storagecost/Transferwarehouseorders');
$router.push({
path: '/cost/storagecost/Transferwarehouseorders',
query: {
confirmAllocationMonth: date.month() + 1, //-
confirmAllocationYear: date.year(), //-
destinationWarehouseName: row.destinationWarehouseName, //
transitWarehouseName: row.transitWarehouseName, //
},
});
};
/** 查看图片 */
const handleShowImg = row => {
console.log(row);
if (!row.changeImageList || getObjType(row.changeImageList) !== 'array')
return ElMessage.warning('该结算异常信息没有图片');
details.imgList = row.changeImageList.map(val => val.imageUrl) || [];
console.log('details.imgList :>> ', details.imgList);
details.popUpShow.showImgVisited = true;
};
const exportExcel = () => {
ElMessageBox.confirm('是否导出数据?', {
confirmButtonText: '确定',
cancelButtonText: '取消',
type: 'warning',
})
.then(async () => {
try {
details.loadingObj.list = true;
let data = {
...details.query,
};
let res = await $_exportTransitMonth(data);
downloadXls(res.data, `中转月度作业统计.xlsx`);
ElMessage({
message: '导出成功',
type: 'success',
});
} catch (error) {
console.log(error);
} finally {
details.loadingObj.list = false;
}
})
.catch(() => {});
};
</script>
<style scoped lang="scss">
@ -575,4 +934,17 @@ const AbnormalsettlementSubmit = async () => {
justify-content: center;
}
}
.dialog_img {
& > div {
margin: 10px;
}
}
.el-fr-d{
display: flex;
width: 100%;
.el-btn{
margin: 0;
align-items: flex-start;
}
}
</style>

487
src/views/desk/DataBoard.vue

@ -520,7 +520,7 @@
<img class="dataIcon mr5px" src="@/static/icon_money_day.png" alt="" />
<span>总数</span>
</div>
<!-- <div
<div
class="mt10"
@click="
() =>
@ -534,12 +534,12 @@
details.allocationDataInfo.totalNum || 0
}}</span>
<span class=""></span>
</div> -->
</div>
<div class="mt10">
<!-- <div class="mt10">
<span class="data mr5px">{{ details.allocationDataInfo.totalNum || 0 }}</span>
<span class=""></span>
</div>
</div> -->
</div>
<!-- 已上架 -->
@ -548,7 +548,7 @@
<img class="dataIcon mr5px" src="@/static/icon_money_day.png" alt="" />
<span>已上架</span>
</div>
<!-- <div
<div
class="mt10"
@click="
() =>
@ -562,11 +562,6 @@
details.allocationDataInfo.useNum || 0
}}</span>
<span class=""></span>
</div> -->
<div class="mt10">
<span class="data mr5px">{{ details.allocationDataInfo.useNum || 0 }}</span>
<span class=""></span>
</div>
</div>
@ -576,7 +571,7 @@
<img class="dataIcon mr5px" src="@/static/icon_money_day.png" alt="" />
<span>空闲库位</span>
</div>
<!-- <div
<div
class="mt10"
@click="
() =>
@ -590,11 +585,6 @@
details.allocationDataInfo.nullNum || 0
}}</span>
<span class=""></span>
</div> -->
<div class="mt10">
<span class="data mr5px">{{ details.allocationDataInfo.nullNum || 0 }}</span>
<span class=""></span>
</div>
</div>
@ -604,7 +594,7 @@
<img class="dataIcon mr5px" src="@/static/icon_money_day.png" alt="" />
<span>未上架</span>
</div>
<!-- <div
<div
class="mt10"
@click="
() =>
@ -618,11 +608,6 @@
details.allocationDataInfo.noUpshelfNum || 0
}}</span>
<span class=""></span>
</div> -->
<div class="mt10">
<span class="data mr5px">{{ details.allocationDataInfo.noUpshelfNum || 0 }}</span>
<span class=""></span>
</div>
</div>
</div>
@ -718,9 +703,20 @@
</div>
<div class="border pd10 flex-c-sb">
<div class="text_center">
<div
class="text_center"
@click="
() =>
handleDetails('trunklineCarsDataColumn', '干线车次统计 - 总车次 - 车', {
tip: '总车次',
prop: 'totalNum',
})
"
>
<div class="data_box mb10">
<div class="data mr5px">{{ details.trunklineCarsDataInfo.totalNum || 0 }}</div>
<div class="data mr5px underline">
{{ details.trunklineCarsDataInfo.totalNum || 0 }}
</div>
<div class=""></div>
</div>
<div class="">
@ -728,9 +724,20 @@
</div>
</div>
<div class="text_center">
<div
class="text_center"
@click="
() =>
handleDetails('trunklineCarsDataColumn', '干线车次统计 - 在途 - 车', {
tip: '在途',
prop: 'inTransitNum',
})
"
>
<div class="data_box mb10">
<div class="data mr5px">{{ details.trunklineCarsDataInfo.inTransitNum || 0 }}</div>
<div class="data mr5px underline">
{{ details.trunklineCarsDataInfo.inTransitNum || 0 }}
</div>
<div class=""></div>
</div>
<div class="">
@ -738,9 +745,20 @@
</div>
</div>
<div class="text_center">
<div
class="text_center"
@click="
() =>
handleDetails('trunklineCarsDataColumn', '干线车次统计 - 作业 - 车', {
tip: '作业',
prop: 'workNum',
})
"
>
<div class="data_box mb10">
<div class="data mr5px">{{ details.trunklineCarsDataInfo.workNum || 0 }}</div>
<div class="data mr5px underline">
{{ details.trunklineCarsDataInfo.workNum || 0 }}
</div>
<div class=""></div>
</div>
<div class="">
@ -748,9 +766,20 @@
</div>
</div>
<div class="text_center">
<div
class="text_center"
@click="
() =>
handleDetails('trunklineCarsDataColumn', '干线车次统计 - 卸车完成 - 车', {
tip: '卸车完成',
prop: 'unloadNum',
})
"
>
<div class="data_box mb10">
<div class="data mr5px">{{ details.trunklineCarsDataInfo.unloadNum || 0 }}</div>
<div class="data mr5px underline">
{{ details.trunklineCarsDataInfo.unloadNum || 0 }}
</div>
<div class=""></div>
</div>
<div class="">
@ -831,7 +860,7 @@
<div class="abnormal_item red">
<div class="align_center">
<img class="dataIcon mr5px " src="@/static/icon_money_day.png" alt="" />
<img class="dataIcon mr5px" src="@/static/icon_money_day.png" alt="" />
<span>处理率</span>
</div>
<div class="mt10">
@ -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 }}</span
>
@ -1028,7 +1062,7 @@
</div>
<div class="border pd10 flex-c-sb">
<div class="text_center">
<div class="text_center flex1 mr10">
<div
class="data_box mb10"
@click="
@ -1046,7 +1080,7 @@
</div>
</div>
<div class="text_center">
<div class="text_center flex1 mr10">
<div
class="data_box orange mb10"
@click="
@ -1064,14 +1098,19 @@
</div>
</div>
<div class="text_center" v-if="signforData_status !== 'daySignData'">
<div class="text_center flex1 mr10" v-if="signforData_status !== 'daySignData'">
<div
class="data_box blue mb10"
@click="
handleShowSignDetail('签收数据 - 签收率 - %', signforData_status, {
tip: '签收率',
prop: 'signScale',
},'bar')
handleShowSignDetail(
'签收数据 - 签收率 - %',
signforData_status,
{
tip: '签收率',
prop: 'signScale',
},
'bar'
)
"
>
<div class="data mr5px underline">
@ -1084,7 +1123,7 @@
</div>
</div>
<div class="text_center">
<div class="text_center flex1 mr10">
<div
class="data_box purple mb10"
@click="
@ -1102,27 +1141,32 @@
</div>
</div>
<div class="text_center">
<div class="text_center flex1 mr10" v-if="signforData_status !== 'daySignData'">
<div
class="data_box purple mb10"
@click="
handleShowSignDetail('签收数据 - 文员签收数 - 件', signforData_status, {
tip: '文员签收数',
prop: 'clerkSignforScale',
})
handleShowSignDetail(
'签收数据 - 文员签收率 - %',
signforData_status,
{
tip: '文员签收率',
prop: 'clerkSignforScale',
},
'bar'
)
"
>
<div class="data mr5px underline">
{{ signforData.clerkSignforScale || 0 }}
</div>
<div class=""></div>
<div class="">%</div>
</div>
<div class="">
<span>文员签收</span>
<span>文员签收</span>
</div>
</div>
<div class="text_center">
<div class="text_center flex1 mr10">
<div
class="data_box red mb10"
@click="
@ -1142,17 +1186,22 @@
</div>
</div>
<div class="text_center" v-if="signforData_status !== 'daySignData'">
<div class="text_center flex1" v-if="signforData_status !== 'daySignData'">
<div
class="data_box red mb10"
@click="
handleShowSignDetail('签收数据 - 签收超时率 - %', signforData_status, {
tip: '签收超时率',
prop: 'clerkOverTimeScale',
},'bar')
handleShowSignDetail(
'签收数据 - 签收超时率 - %',
signforData_status,
{
tip: '签收超时率',
prop: 'clerkOverTimeScale',
},
'bar'
)
"
>
<div class="data mr5px">
<div class="data mr5px underline">
{{ signforData.clerkOverTimeScale ? signforData.clerkOverTimeScale : 0 }}
</div>
<div class="">%</div>
@ -1311,7 +1360,7 @@
</div>
<div class="border pd10 flex-c-sb">
<div class="text_center">
<div class="text_center flex1 mr10">
<div
class="data_box mb10"
@click="
@ -1329,7 +1378,7 @@
</div>
</div>
<div class="text_center">
<div class="text_center flex1 mr10">
<div
class="data_box orange mb10"
@click="
@ -1347,14 +1396,22 @@
</div>
</div>
<div class="text_center" v-if="billSignforData_status !== 'dayBillLadingSignData'">
<div
class="text_center flex1 mr10"
v-if="billSignforData_status !== 'dayBillLadingSignData'"
>
<div
class="data_box blue mb10"
@click="
handleShowSignDetail('自提签收数据 - 签收率 - %', billSignforData_status, {
tip: '签收率',
prop: 'signScale',
},'bar')
handleShowSignDetail(
'自提签收数据 - 签收率 - %',
billSignforData_status,
{
tip: '签收率',
prop: 'signScale',
},
'bar'
)
"
>
<div class="data mr5px underline">
@ -1367,7 +1424,7 @@
</div>
</div>
<div class="text_center">
<div class="text_center flex1 mr10">
<div
class="data_box purple mb10"
@click="
@ -1385,27 +1442,35 @@
</div>
</div>
<div class="text_center">
<div
class="text_center flex1 mr10"
v-if="billSignforData_status !== 'dayBillLadingSignData'"
>
<div
class="data_box purple mb10"
@click="
handleShowSignDetail('自提签收数据 - 文员签收数 - 件', billSignforData_status, {
tip: '文员签收率',
prop: 'clerkSignforScale',
})
handleShowSignDetail(
'自提签收数据 - 文员签收数 - %',
billSignforData_status,
{
tip: '文员签收率',
prop: 'clerkSignforScale',
},
'bar'
)
"
>
<div class="data mr5px underline">
{{ billSignforData.clerkSignforScale ? billSignforData.clerkSignforScale : 0 }}
</div>
<div class=""></div>
<div class="">%</div>
</div>
<div class="">
<span>文员签收</span>
<span>文员签收</span>
</div>
</div>
<div class="text_center">
<div class="text_center flex1 mr10">
<div
class="data_box red mb10"
@click="
@ -1425,14 +1490,22 @@
</div>
</div>
<div class="text_center" v-if="billSignforData_status !== 'dayBillLadingSignData'">
<div
class="text_center flex1 mr10"
v-if="billSignforData_status !== 'dayBillLadingSignData'"
>
<div
class="data_box red mb10"
@click="
handleShowSignDetail('自提签收数据 - 超时签收任务 - %', billSignforData_status, {
tip: '超时签收任务',
prop: 'clerkOverTimeScale',
},'bar')
handleShowSignDetail(
'自提签收数据 - 超时签收任务 - %',
billSignforData_status,
{
tip: '超时签收任务',
prop: 'clerkOverTimeScale',
},
'bar'
)
"
>
<div class="data mr5px underline">
@ -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<any>(() => {
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<any>(() => {
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);
};
/** 导出 */

8
src/views/reportforms/DeliveryStatisticsReport.vue

@ -106,7 +106,7 @@
<template #default="slotProps">
<template
v-if="
['审核率', '签收率', '库存品签收率', '计划准确率'].includes(
['审核率', '签收率', '库存品签收率', '计划准确率','签收及时率','复核及时率'].includes(
slotProps.scope.column.label
)
"
@ -461,8 +461,10 @@ const onLoad = async () => {
item.reviewOnTimeRate = parsePercentage(item.reviewOnTimeRate);
}
details.data = data.records;
details.page.total = data.total;
console.log(details.data,'details.data');
} catch (e) {
console.error(e);
} finally {
@ -485,6 +487,10 @@ const getRateValue = (label, row) => {
return row.signStockRate;
case '计划准确率':
return row.planAccuracy;
case '签收及时率':
return row.signOnTimeRate;
case '复核及时率':
return row.reviewOnTimeRate;
default:
return 0;
}

522
src/views/reportforms/SalesDepartmentIncomeReport.vue

@ -0,0 +1,522 @@
<template>
<basic-container v-loading="details.loadingObj.pageLoading">
<div class="avue-crud">
<!-- 搜索模块 -->
<div v-h5uShow="search">
<!-- 查询模块 -->
<el-form :inline="true" :model="query" class="header_search" label-width="100px">
<el-form-item label="品牌" prop="brandId">
<el-select
class="w100"
v-model="query.brand"
filterable
placeholder="请选择"
default-first-option
clearable
>
<el-option
v-for="item in details.brandOptions"
:key="item.brandId"
:label="item.brandName"
:value="item.brandId"
/>
</el-select>
</el-form-item>
<el-form-item label="年份">
<el-date-picker
v-model="query.year"
type="year"
format="YYYY"
placeholder="请选择"
value-format="YYYY"
@change="
() => {
delete details.query.month;
delete details.query.timeArr;
}
"
/>
</el-form-item>
<el-form-item label="月份">
<el-date-picker
v-model="query.month"
type="month"
format="YYYY-MM"
placeholder="请选择"
value-format="YYYY-MM"
@change="
() => {
delete details.query.year;
delete details.query.timeArr;
}
"
/>
</el-form-item>
<el-form-item label="时间周期">
<el-date-picker
v-model="query.timeArr"
type="daterange"
range-separator="-"
start-placeholder="开始时间"
end-placeholder="结束时间"
value-format="YYYY-MM-DD"
@change="
() => {
delete details.query.year;
delete details.query.month;
}
"
/>
</el-form-item>
<el-form-item label="事业线">
<el-select
class="w100"
v-model="query.businessLine"
filterable
placeholder="请选择"
default-first-option
clearable
>
<el-option
v-for="item in details.businessLineOption"
:key="item"
:label="item"
:value="item"
/>
</el-select>
</el-form-item>
<el-form-item label="始发仓">
<el-input v-model="query.departureWarehouseName" placeholder="请输入" clearable />
</el-form-item>
<el-form-item label="目的仓">
<el-input v-model="query.destinationWarehouseName" placeholder="请输入" clearable />
</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>
</div>
<!-- 控件模块 -->
<div class="avue-crud__header flex-c-sb">
<!-- 头部左侧按钮模块 -->
<div class="avue-crud__left">
<el-button type="primary" icon="Download" @click="ExportData"> 导出 </el-button>
</div>
<!-- 头部右侧按钮模块 -->
<div class="avue-crud__right">
<el-button icon="el-icon-refresh" @click="searchChange" circle></el-button>
<el-button icon="Operation" @click="showdrawer(true)" circle></el-button>
<el-button icon="Search" @click="searchHide" circle></el-button>
</div>
</div>
<!-- 表格 -->
<!-- 列表模块 -->
<tablecmt
ref="tableNodeRef"
:columnList="details.columnList"
:tableData="details.data"
:loading="loadingObj.list"
@inputTxt="inputsc"
@timeCheck="timesc"
@btnCheck="btnsc"
@selectCheck="selectsc"
@selection="selectionChange"
>
<template #default="slotProps">
<template v-if="slotProps.scope.column.label === '操作'"> </template>
</template>
</tablecmt>
<!-- 分页模块 -->
<div class="avue-crud__pagination flex-c-sb" style="width: 100%">
<div style="font-size: 14px">勾选数量: {{ selectionList.length }}</div>
<!-- 分页模块 -->
<el-pagination
align="right"
background
@size-change="sizeChange"
@current-change="currentChange"
:current-page="page.pageNum"
:page-sizes="[30, 50, 80, 120, 500]"
:page-size="page.pageSize"
layout="total, sizes, prev, pager, next, jumper"
:total="page.total"
>
</el-pagination>
</div>
</div>
</basic-container>
<edittablehead
@closce="showdrawer"
:drawerShow="drawerShow"
:columnList="details.columnList"
v-model="details.columnList"
></edittablehead>
</template>
<script setup lang="ts">
import { ref, reactive, toRefs, computed, onMounted, nextTick, defineAsyncComponent } from 'vue';
import functions from '@/utils/functions.js';
import dayjs from 'dayjs';
import { mapGetters, useStore } from 'vuex';
/** 获取字典 */
import { getDictionaryBiz } from '@/api/system/dict';
import { postFindBrandList } from '@/api/waybill/TemporaryStorageList';
import {
postDeptIncomingPage,
postFindbusinessLine,
postDeptIncomingExport,
} from '@/api/reportforms/SalesDepartmentIncomeReport';
import {
setNodeHeight,
getHtmls,
deepClone,
getObjType,
handleTranslationDataSeclect,
handleClearTableQuery,
handleSelectQuery,
handleInputQuery,
downloadXls,
} from '@/utils/util';
import { useRouter } from 'vue-router';
import { ElMessage, ElMessageBox } from 'element-plus';
import { columnList } from '@/option/reportforms/SalesDepartmentIncomeReport';
//
const $router = useRouter();
const $store = useStore();
//
const tableNodeRef = ref();
const details = reactive<any>({
/** 是否开启搜索 */
search: true,
/** 表格搜索条件 */
query: {},
/** 时间快捷选择设置 */
shortcuts: [
{
text: '最近一周',
value: () => {
const end = new Date();
const start = new Date();
start.setTime(start.getTime() - 3600 * 1000 * 24 * 7);
return [start, end];
},
},
{
text: '最近一个月',
value: () => {
const end = new Date();
const start = new Date();
start.setTime(start.getTime() - 3600 * 1000 * 24 * 30);
return [start, end];
},
},
{
text: '最近三个月',
value: () => {
const end = new Date();
const start = new Date();
start.setTime(start.getTime() - 3600 * 1000 * 24 * 90);
return [start, end];
},
},
],
columnList: deepClone(columnList),
data: [],
/** 头部搜索配置 */
titleSearchOption: [],
/** 流转节点数据 */
flowNodeData: [],
/** 页面loading */
loadingObj: {
/** 列表加载loading */
list: false,
packageListLoading: false,
},
/** 列表复选框选中的数据 */
selectionList: [],
/** 是否显示设置表格 */
drawerShow: false,
/** 分页参数 */
page: {
pageNum: 1,
pageSize: 30,
total: 0,
},
/** 品牌 */
brandOptions: [],
/** 事业线 */
businessLineOption: [],
/** 弹出层显示 */
popUpShow: {},
/** 全屏 */
fullscreenObj: {},
});
const { search, query, shortcuts, loadingObj, selectionList, drawerShow, page } = toRefs(details);
/** vuex */
const permission = computed(() => mapGetters(['permission', 'tagWel', 'tagList']));
console.log('permission :>> ', permission);
/** 权限按钮 */
const permissionObj = reactive({});
/** 请求页面数据 */
const onLoad = async (params = {}) => {
try {
details.loadingObj.list = true;
const submitData = { ...details.page, ...details.query, ...params };
for (const key in submitData) {
const element = submitData[key];
if (!element && element !== 0) delete submitData[key];
}
//
if (submitData.month) {
const _arr = submitData.month.split('-');
submitData.year = _arr[0];
submitData.month = _arr[1];
}
//
else if (getObjType(submitData.timeArr) === 'array' && submitData.timeArr.length > 0) {
submitData.startTimeStr = submitData.timeArr[0];
submitData.endTimeStr = submitData.timeArr[1];
}
if (
(getObjType(submitData.timeArr) !== 'array' || submitData.timeArr.length === 0) &&
!submitData.year &&
!submitData.month
) {
details.data = [];
return ElMessage.warning('请选择时间');
}
delete submitData.timeArr;
delete submitData.total;
const res = await postDeptIncomingPage(submitData);
const { code, data } = res.data;
if (code !== 200) return;
details.data = getObjType(data.records) === 'array' ? data.records : [];
details.page.total = data.total;
handleTranslationDataSeclect(details.data, details.columnList);
} catch (error) {
console.log('error :>> ', error);
} finally {
details.loadingObj.list = false;
}
};
const init = () => {
const time = new Date().getTime();
details.query.timeArr = [
dayjs(time - 1000 * 60 * 60 * 24 * 7).format('YYYY-MM-DD'),
dayjs(time).format('YYYY-MM-DD'),
];
onLoad();
};
init();
/** 查询品牌 */
const handleFindBrand = async () => {
try {
const res = await postFindBrandList();
console.log('res :>> ', res);
const { data, code } = res.data;
if (code !== 200) return;
console.log('data :>> ', data);
details.brandOptions = data || [];
} catch (error) {
console.log('error :>> ', error);
}
};
/** 查询事业线 */
const handleFindbusinessLine = async () => {
try {
const res = await postFindbusinessLine();
console.log('res :>> ', res);
const { data, code } = res.data;
if (code !== 200) return;
console.log('data :>> ', data);
details.businessLineOption = data || [];
} catch (error) {
console.log('error :>> ', error);
}
};
handleFindbusinessLine();
handleFindBrand();
/** 搜索 */
const searchChange = () => {
onLoad();
};
/** 清空表单 */
const searchReset = () => {
details.query = {};
details.page.pageNum = 1;
handleClearTableQuery(details.columnList);
onLoad();
};
/** 展开列表控件 */
const showdrawer = (_flag?: boolean) => {
details.drawerShow = _flag;
};
/** 是否开启搜索区 */
const searchHide = () => {
details.search = !details.search;
setNodeHeight(tableNodeRef.value.$el, '', true);
};
/** 表格表头输入框搜索 */
const inputsc = (index, row) => {
handleInputQuery(index, row, details.query);
onLoad();
};
/** 表格表头时间选择 */
const timesc = (index, row) => {
console.log(index, row);
if (!!index) {
index = dayjs(index).format('YYYY-MM-DD');
}
details.query[row.prop] = index;
if (!index) {
delete details.query[row.prop];
}
onLoad();
};
/** 表格表头输入框搜索 */
const btnsc = () => {};
/** 表格表头下拉框选择 */
const selectsc = (index, row) => {
handleSelectQuery(index, row, details.query);
onLoad();
};
/** 表格表头复选框选择 */
const selectionChange = (list: any) => {
details.selectionList = list;
};
/** 每页数量改变执行的回调 */
const sizeChange = (pageSize: number) => {
details.page.pageSize = pageSize;
onLoad();
};
/** 页码改变执行的回调 */
const currentChange = pageNum => {
details.page.pageNum = pageNum;
onLoad();
};
/** 弹出层开启前清除数据 */
const beforeClose = done => {
done();
details.form = {};
details.selectionList = [];
details.view = false;
};
//
const ExportData = async () => {
try {
details.loadingObj.list = true;
const submitData = { ...details.page, ...details.query };
for (const key in submitData) {
const element = submitData[key];
if (!element && element !== 0) delete submitData[key];
}
//
if (submitData.month) {
const _arr = submitData.month.split('-');
submitData.year = _arr[0];
submitData.month = _arr[1];
}
//
else if (getObjType(submitData.timeArr) === 'array' && submitData.timeArr.length > 0) {
submitData.startTimeStr = submitData.timeArr[0];
submitData.endTimeStr = submitData.timeArr[1];
}
if (
(getObjType(submitData.timeArr) !== 'array' || submitData.timeArr.length === 0) &&
!submitData.year &&
!submitData.month
) {
return ElMessage.warning('请选择时间');
}
delete submitData.timeArr;
delete submitData.total;
const res = await postDeptIncomingExport(submitData);
const { status, data } = res;
if (status !== 200) return;
const time = new Date().getTime();
downloadXls(data, '营业部收入报表 -' + time + '.xlsx');
} catch (error) {
console.log('error :>> ', error);
} finally {
details.loadingObj.list = false;
}
};
</script>
<style scoped lang="scss">
//
:deep(.el-date-editor.el-input) {
height: 100% !important;
width: 100% !important;
}
:deep(.el-range-editor.el-input__wrapper) {
height: 100% !important;
}
.el_div_input {
width: 100%;
display: flex;
align-items: center;
.el_dy_icon {
font-size: 1.5em;
}
}
</style>

34
src/views/waybill/orderPackageList.vue

@ -120,24 +120,22 @@
</tablecmt>
<!-- 分页模块 -->
<el-row class="el-fy">
<div class="avue-crud__pagination flex-c-sb" style="width: 100%">
<div style="font-size: 14px">勾选数量: {{ selectionList.length }}</div>
<!-- 分页模块 -->
<el-pagination
align="right"
background
@size-change="sizeChange"
@current-change="currentChange"
:current-page="page.pageNum"
:page-sizes="[30, 50, 80, 120, 500]"
:page-size="page.pageSize"
layout="total, sizes, prev, pager, next, jumper"
:total="page.total"
>
</el-pagination>
</div>
</el-row>
<div class="avue-crud__pagination flex-c-sb" style="width: 100%">
<div style="font-size: 14px">勾选数量: {{ selectionList.length }}</div>
<!-- 分页模块 -->
<el-pagination
align="right"
background
@size-change="sizeChange"
@current-change="currentChange"
:current-page="page.pageNum"
:page-sizes="[30, 50, 80, 120, 500]"
:page-size="page.pageSize"
layout="total, sizes, prev, pager, next, jumper"
:total="page.total"
>
</el-pagination>
</div>
</div>
</basic-container>

Loading…
Cancel
Save