qb 1 year ago
parent
commit
56ba5b1303
  1. 8
      src/api/basic/basicMaterial.js
  2. 14
      src/api/distribution/distributionDeliveryList.js
  3. 85
      src/api/reportforms/index.js
  4. 45
      src/components/ImgList/ImgList.vue
  5. 1
      src/components/tablecmt/tablecmt.vue
  6. 2
      src/main.js
  7. 9
      src/option/reportforms/DeliveryCustomers.js
  8. 53
      src/option/reportforms/DeliveryTrainNumber.js
  9. 153
      src/option/reportforms/Inventory.js
  10. 325
      src/option/reportforms/InventoryOutbound.js
  11. 149
      src/option/reportforms/InventoryReceipt.js
  12. 237
      src/option/reportforms/Selfpickupreport.js
  13. 13
      src/utils/LodopFuncs.js
  14. 11
      src/views/basicdata/brand/basicClient.vue
  15. 1
      src/views/basicdata/driverArtery/basicdataDriverArtery.vue
  16. 313
      src/views/basicdata/warehouse/warehouse/basicdataWarehouseTemp.vue
  17. 155
      src/views/distribution/deliverylist/distributionDeliveryListedt.vue
  18. 115
      src/views/distribution/inventory/distributionStockListMarket.vue
  19. 1
      src/views/distribution/inventory/distrilbutionBillLading.vue
  20. 1
      src/views/distribution/turndelivery/deliveryDiscuss.vue
  21. 171
      src/views/reportforms/DeliveryCustomers.vue
  22. 181
      src/views/reportforms/DeliveryTrainNumber.vue
  23. 366
      src/views/reportforms/Inventory.vue
  24. 366
      src/views/reportforms/InventoryOutbound.vue
  25. 366
      src/views/reportforms/InventoryReceipt.vue
  26. 366
      src/views/reportforms/Selfpickupreport.vue

8
src/api/basic/basicMaterial.js

@ -23,7 +23,13 @@ export const getListMaterial = (current, size, params) => {
}
})
}
export const $_getListMaterial = (params) => {
return request({
url: '/api/logpm-basic/material//findPidList',
method: 'get',
params,
})
}
export const getDetail = (id) => {
return request({
url: '/api/logpm-basic/material/detail',

14
src/api/distribution/distributionDeliveryList.js

@ -346,4 +346,18 @@ export const $_cancelDelivery = data => {
method: 'post',
data: data,
});
};
/**
* 零担签收
* @param data
* @returns {AxiosPromise}
*/
export const $_deliveryZeroPackage = data => {
return request({
url: '/api/logpm-distribution/deliveryList/deliveryZeroPackage',
method: 'post',
data: data,
});
};

85
src/api/reportforms/index.js

@ -55,4 +55,87 @@ export const $_getdetails = (params) => {
params,
responseType: 'blob',
})
}
}
// 自提明细报表
export const $_getSelfpickup = (params) => {
return request({
url: '/api/logpm-report/reportBillLoading/details',
method: 'get',
params,
});
};
// 自提明细报表报表导出
export const $_exportSelfpickup = (params) => {
return request({
url: '/api/logpm-report/reportBillLoading/exportDetails',
method: 'get',
params,
responseType: 'blob',
})
}
// 库存品出库明细报表
export const $_getreport = (params) => {
return request({
url: '/api/logpm-report/stock-out-detail/report',
method: 'get',
params,
});
};
// 导出库存出库明细
export const $_exportOutStocks = (params) => {
return request({
url: '/api/logpm-report/stock/exportOutStocks',
method: 'get',
params,
responseType: 'blob',
})
}
// 库存品入库明细报表
export const $_getinStocks = (params) => {
return request({
url: '/api/logpm-report/stock/inStocks',
method: 'get',
params,
});
};
// 库存品入库明细报表导出
export const $_exportInStocks = (params) => {
return request({
url: '/api/logpm-report/stock/exportInStocks',
method: 'get',
params,
responseType: 'blob',
})
}
// 库存品明细报表
export const $_getInventory = (params) => {
return request({
url: '/api/logpm-report/stock/details',
method: 'get',
params,
});
};
// 导出库存品明细报表
export const $_exportInventory = (params) => {
return request({
url: '/api/logpm-report/stock/exportDetails',
method: 'get',
params,
responseType: 'blob',
})
}
// 获取仓库
export const $_getMyWarehouseList = data => {
return request({
url: '/api/logpm-basicdata/warehouse/getMyWarehouseList',
method: 'get',
data,
});
};

45
src/components/ImgList/ImgList.vue

@ -0,0 +1,45 @@
<template>
<div class="demo-image__preview" v-for="(item, index) in srcList">
<el-image
:src="item"
:zoom-rate="1.2"
:max-scale="7"
:min-scale="0.2"
:preview-src-list="srcList"
:initial-index="index"
fit="cover"
/>
</div>
</template>
<script setup>
import { defineProps, ref, onMounted, reactive } from 'vue';
const props = defineProps(['imgList']);
const srcList = ref([]);
const { imgList } = props;
srcList.value = imgList;//
</script>
<style scoped lang="scss">
.demo-image__error .image-slot {
font-size: 30px;
}
.demo-image__error .image-slot .el-icon {
font-size: 30px;
}
.demo-image__error .el-image {
width: 100%;
height: 200px;
}
.demo-image__preview{
height: 100px;
width: 100px;
margin: 4px;
.el-image{
height: 100%;
width: 100%;
}
}
</style>

1
src/components/tablecmt/tablecmt.vue

@ -58,6 +58,7 @@
<el-select
v-if="column.type == 3"
v-model="column.values"
filterable
class="m-2 selectbr"
clearable
:placeholder="`请选择${column.label}`"

2
src/main.js

@ -28,6 +28,7 @@ import edittablehead from './components/edittablehead/index.vue';
import WaybillPrintTemplate from './components/WaybillPrintTemplate/WaybillPrintTemplate.vue';
import ArteryPrintTemplate from './components/ArteryPrintTemplate/ArteryPrintTemplate.vue';
import TripartiteTransferPrintTemplate from './components/TripartiteTransferPrintTemplate/TripartiteTransferPrintTemplate.vue';
import ImgList from './components/ImgList/ImgList.vue';
import { message } from './utils/resetMessage';
import App from './App.vue';
import 'animate.css';
@ -59,6 +60,7 @@ app.component('WaybillPrintTemplate', WaybillPrintTemplate);
app.component('ArteryPrintTemplate', ArteryPrintTemplate);
/** 三方运输打印模版 */
app.component('TripartiteTransferPrintTemplate', TripartiteTransferPrintTemplate);
app.component('ImgList', ImgList);
app.config.globalProperties.$dayjs = dayjs;
app.config.globalProperties.$functions = functions;
app.provide('functions', functions);

9
src/option/reportforms/DeliveryCustomers.js

@ -200,6 +200,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,//开启统计
},
{
prop: 'reservationNum',
@ -211,6 +212,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,//开启统计
},
{
prop: 'reservationStockListNum',
@ -222,6 +224,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,//开启统计
},
{
prop: 'loadedNum',
@ -233,6 +236,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,//开启统计
},
{
prop: 'invnLoadedNum',
@ -244,6 +248,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,//开启统计
},
{
prop: 'exLoadedNum',
@ -255,6 +260,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,//开启统计
},
{
prop: 'reNum',
@ -266,6 +272,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,//开启统计
},
{
prop: 'invnReNum',
@ -277,6 +284,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,//开启统计
},
{
prop: 'exReNum',
@ -288,6 +296,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,//开启统计
},
{
prop: 'sjsigningTime',

53
src/option/reportforms/DeliveryTrainNumber.js

@ -39,7 +39,7 @@ export const columnList = [
{
prop: 'warehouseName',
label: '仓库',
type: 2,
type: 3,
values: '',
width: '150',
checkarr: [],
@ -50,7 +50,7 @@ export const columnList = [
{
prop: 'type',
label: '配送类型',
type: 1,
type: 3,
values: '',
width: '150',
checkarr: [],
@ -61,7 +61,7 @@ export const columnList = [
{
prop: 'kind',
label: '配送种类',
type: 1,
type: 3,
values: '',
width: '150',
checkarr: [],
@ -123,7 +123,22 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,//开启统计
},
{
prop: 'planLoadingNumber',
label: '计划装车',
type: 1,
values: '',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
isshowSummary: true,//开启统计
},
{
prop: 'price',
label: '配送价格',
@ -134,6 +149,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,//开启统计
},
{
prop: 'orderNumber',
@ -145,6 +161,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,//开启统计
},
{
prop: 'reservationNum',
@ -156,6 +173,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,//开启统计
},
{
prop: 'reservationStockListNum',
@ -167,6 +185,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,//开启统计
},
{
prop: 'loadedNum',
@ -178,6 +197,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,//开启统计
},
{
prop: 'invnLoadedNum',
@ -189,6 +209,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,//开启统计
},
{
prop: 'exLoadedNum',
@ -200,6 +221,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,//开启统计
},
{
prop: 'reNum',
@ -211,6 +233,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,//开启统计
},
{
prop: 'invnReNum',
@ -222,6 +245,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,//开启统计
},
{
prop: 'exReNum',
@ -233,6 +257,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,//开启统计
},
{
prop: 'dsNum',
@ -244,6 +269,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,//开启统计
},
{
prop: 'ssNum',
@ -255,6 +281,7 @@ export const columnList = [
fixed: false,
sortable: true,
head: false,
isshowSummary: true,//开启统计
},
{
prop: 'unloadingTeamName',
@ -267,14 +294,14 @@ export const columnList = [
sortable: true,
head: false,
},
{
prop: 'createUserName',
label: '操作',
type: 6,
values: '',
width: '200',
checkarr: [],
fixed: 'right',
sortable: false,
},
// {
// prop: 'createUserName',
// label: '操作',
// type: 6,
// values: '',
// width: '200',
// checkarr: [],
// fixed: 'right',
// sortable: false,
// },
]

153
src/option/reportforms/Inventory.js

@ -0,0 +1,153 @@
export const columnList = [
{
prop: '',
label: '复选框',
type: 0,
width: 55,
fixed: true,
},
{
prop: '',
label: '序号',
type: 12,
values: '',
width: 55,
fixed: true,
},
{
prop: 'warehouseName',
label: '仓库',
type: 2,
values: '',
width: '180',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'marketName',
label: '商场名称',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'serviceType',
label: '类型',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'cargoNumber',
label: '物料编码',
type: 2,
values: '',
width: '180',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'descriptionGoods',
label: '物料名称',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'quantityStock',
label: '入库总数',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
isshowSummary: true,//开启统计
},
{
prop: 'outboundQuantity',
label: '出库总数',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
isshowSummary: true,//开启统计
},
{
prop: 'currentQuantity',
label: '当前库存数',
type: 1,
values: '',
width: '200',
checkarr: [],
fixed: false,
sortable: true,
head: false,
isshowSummary: true,//开启统计
},
{
prop: 'quantityOccupied',
label: '占用数',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
isshowSummary: true,//开启统计
},
{
prop: 'usableQuantity',
label: '可用数',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
isshowSummary: true,//开启统计
},
{
prop: 'allocationTitle',
label: '货位信息',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
// {
// prop: 'createUserName',
// label: '操作',
// type: 6,
// values: '',
// width: '200',
// checkarr: [],
// fixed: 'right',
// sortable: false,
// },
]

325
src/option/reportforms/InventoryOutbound.js

@ -0,0 +1,325 @@
// export const columnList = [
// {
// prop: '',
// label: '复选框',
// type: 0,
// width: 55,
// fixed: true,
// },
// {
// prop: '',
// label: '序号',
// type: 12,
// values: '',
// width: 55,
// fixed: true,
// },
// {
// prop: 'warehouse_name',
// label: '仓库',
// type: 2,
// values: '',
// width: '180',
// checkarr: [],
// fixed: false,
// sortable: true,
// head: false,
// },
// {
// prop: 'market_name',
// label: '商场名称',
// type: 2,
// values: '',
// width: '150',
// checkarr: [],
// fixed: false,
// sortable: true,
// head: false,
// },
// {
// prop: 'cargo_number',
// label: '物料编码',
// type: 2,
// values: '',
// width: '150',
// checkarr: [],
// fixed: false,
// sortable: true,
// head: false,
// },
// {
// prop: 'material_name',
// label: '物料名称',
// type: 2,
// values: '',
// width: '180',
// checkarr: [],
// fixed: false,
// sortable: true,
// head: false,
// },
// {
// prop: 'create_time',
// label: '出库时间',
// type: 4,
// values: '',
// width: '150',
// checkarr: [],
// fixed: false,
// sortable: true,
// head: false,
// },
// {
// prop: 'stock_quantity',
// label: '出库件数',
// type: 1,
// values: '',
// width: '150',
// checkarr: [],
// fixed: false,
// sortable: true,
// head: false,
// },
// {
// prop: 'goods_allocation_name',
// label: '货位信息',
// type: 2,
// values: '',
// width: '150',
// checkarr: [],
// fixed: false,
// sortable: true,
// head: false,
// },
// {
// prop: 'out_type',
// label: '出库类型',
// type: 2,
// values: '',
// width: '150',
// checkarr: [],
// fixed: false,
// sortable: true,
// head: false,
// },
// {
// prop: 'note_number',
// label: '配送单号',
// type: 2,
// values: '',
// width: '150',
// checkarr: [],
// fixed: false,
// sortable: true,
// head: false,
// },
// {
// prop: 'train_number',
// label: '配送车次号',
// type: 2,
// values: '',
// width: '150',
// checkarr: [],
// fixed: false,
// sortable: true,
// head: false,
// },
// {
// prop: 'reservation_code',
// label: '预约单号',
// type: 2,
// values: '',
// width: '150',
// checkarr: [],
// fixed: false,
// sortable: true,
// head: false,
// },
// {
// prop: 'client_name',
// label: '配送客户',
// type: 2,
// values: '',
// width: '150',
// checkarr: [],
// fixed: false,
// sortable: true,
// head: false,
// },
// // {
// // prop: 'createUserName',
// // label: '操作',
// // type: 6,
// // values: '',
// // width: '200',
// // checkarr: [],
// // fixed: 'right',
// // sortable: false,
// // },
// ]
export const columnList = [
{
prop: '',
label: '复选框',
type: 0,
width: 55,
fixed: true,
},
{
prop: '',
label: '序号',
type: 12,
values: '',
width: 55,
fixed: true,
},
{
prop: 'warehouseName',
label: '仓库',
type: 2,
values: '',
width: '180',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'marketName',
label: '商场名称',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'cargoNumber',
label: '物料编码',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'materialName',
label: '物料名称',
type: 2,
values: '',
width: '180',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'createTime',
label: '出库时间',
type: 4,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'stockQuantity',
label: '出库件数',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
isshowSummary: true,//开启统计
},
{
prop: 'goodsAllocationName',
label: '货位信息',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'outType',
label: '出库类型',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'noteNumber',
label: '配送单号',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'trainNumber',
label: '配送车次号',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'reservationCode',
label: '预约单号',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'clientName',
label: '配送客户',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
// {
// prop: 'createUserName',
// label: '操作',
// type: 6,
// values: '',
// width: '200',
// checkarr: [],
// fixed: 'right',
// sortable: false,
// },
]

149
src/option/reportforms/InventoryReceipt.js

@ -0,0 +1,149 @@
export const columnList = [
{
prop: '',
label: '复选框',
type: 0,
width: 55,
fixed: true,
},
{
prop: '',
label: '序号',
type: 12,
values: '',
width: 55,
fixed: true,
},
{
prop: 'warehouseName',
label: '仓库',
type: 2,
values: '',
width: '180',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'marketName',
label: '商场名称',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'serviceType',
label: '类型',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'cargoNumber',
label: '物料编码',
type: 2,
values: '',
width: '180',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'descriptionGoods',
label: '物料名称',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'stock_quantity',
label: '入库时间',
type: 4,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'despatch',
label: '运单号',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'orderCode',
label: '订单自编码',
type: 2,
values: '',
width: '200',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'packageCode',
label: '包条码',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'quantityStock',
label: '入库数',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
isshowSummary: true,//开启统计
},
{
prop: 'allocationTitle',
label: '货位信息',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
// {
// prop: 'createUserName',
// label: '操作',
// type: 6,
// values: '',
// width: '200',
// checkarr: [],
// fixed: 'right',
// sortable: false,
// },
]

237
src/option/reportforms/Selfpickupreport.js

@ -0,0 +1,237 @@
export const columnList = [
{
prop: '',
label: '复选框',
type: 0,
width: 55,
fixed: true,
},
{
prop: '',
label: '序号',
type: 12,
values: '',
width: 55,
fixed: true,
},
{
prop: 'pickupBatch',
label: '自提批次号',
type: 2,
values: '',
width: '180',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'warehouse',
label: '仓库',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'consigneeUnit',
label: '收货单位',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'waybillNumber',
label: '运单号',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'orderCode',
label: '订单自编号',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'packetBarCode',
label: '包条',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'trainNumber',
label: '客户车次号',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'firsts',
label: '一级品',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'second',
label: '二级品',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'thirdProduct',
label: '三级品',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'materialCode',
label: '物料编码',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'materialName',
label: '物料名称',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'startWareInTime',
label: '始发仓入库日期',
type: 4,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'startWareOutTime',
label: '始发仓发货日期',
type: 4,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'warehouseEntryTimeEnd',
label: '入库时间',
type: 4,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'scanUser',
label: '提货扫码人',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'scanTime',
label: '提货扫描时间',
type: 4,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'examineTime',
label: '文员复核时间',
type: 4,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'examineUser',
label: '文员复核人',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
// {
// prop: 'createUserName',
// label: '操作',
// type: 6,
// values: '',
// width: '200',
// checkarr: [],
// fixed: 'right',
// sortable: false,
// },
]

13
src/utils/LodopFuncs.js

@ -101,7 +101,12 @@ export function getLodop(oOBJECT, oEMBED) {
var strCLodopInstallA =
`<font>
<p>检测到到您的打印设备尚未安装驱动或打印服务!请按照以下提示进行操作:</p>
<div class='container'><div class='left'>
<div class='container'>
<div class='left'>
<h2>安装Web打印服务</h2>
<p><b>第一步</b>:请您下载并安装Web打印服务CLodop。<a href='http://47.108.51.143:9000/logpm/other/CLodop_Setup_for_Win32NT.exe' target='_self'><b>点击下载</b></a></p>
</div>
<div class='right'>
<h2>打印机驱动下载</h2>
<table><thead>
<tr>
@ -113,11 +118,7 @@ export function getLodop(oOBJECT, oEMBED) {
<td>2020.4</td></tr>
</tbody>
</table>
</div>
<div class='right'>
<h2>安装Web打印服务</h2>
<p>第一步:请您下载并安装Web打印服务CLodop<a href='http://47.108.51.143:9000/logpm/other/CLodop_Setup_for_Win32NT.exe' target='_self'><b>点击下载</b></a></p>
</div>
</div>
</div>`;
// var strCLodopInstallB = "<br>(若此前已安装过,可<a href='CLodop.protocol:setup' target='_self'>点这里直接再次启动</a>)";
var strCLodopInstallB = "<br>注意事项:";

11
src/views/basicdata/brand/basicClient.vue

@ -554,6 +554,17 @@ export default {
sortable: true,
head: false,
},
{
prop: 'phone',
label: '联系电话',
type: 1,
values: '',
width: '130',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'typeServiceName',
label: '配送类型',

1
src/views/basicdata/driverArtery/basicdataDriverArtery.vue

@ -328,6 +328,7 @@ export default {
labelWidth: '150',
width: '200px',
align: 'center',
multiple:true,
span: 11,
// dicData: [],
dicUrl: '/api/logpm-basicdata/vehicle/dictionary?vehicleNub={{key}}',

313
src/views/basicdata/warehouse/warehouse/basicdataWarehouseTemp.vue

@ -85,11 +85,15 @@
</el-form-item>
<el-form-item label="管理区域">
<el-cascader v-model="Addform.administrativeAreas" :options="areaoptions" placeholder="省/市/区" />
<el-cascader
v-model="Addform.administrativeAreas"
:options="areaoptions"
placeholder="省/市/区"
/>
</el-form-item>
<el-form-item label="职能类型">
<el-select v-model="Addform.functionType" clearable placeholder="请选择职能类型" >
<el-select v-model="Addform.functionType" clearable placeholder="请选择职能类型">
<el-option
v-for="item in options"
:key="item.dictKey"
@ -100,44 +104,87 @@
</el-form-item>
<el-form-item label="仓库地区">
<el-cascader v-model="Addform.addressInfo" :options="areaoptions" placeholder="省/市/区" />
<el-cascader
v-model="Addform.addressInfo"
:options="areaoptions"
placeholder="省/市/区"
/>
</el-form-item>
<el-form-item label="仓库地址">
<avue-input-map :params="warehouseAddress" placeholder="请选择地图" v-model="Addform.map" ></avue-input-map>
<avue-input-map
:params="warehouseAddress"
placeholder="请选择地图"
v-model="Addform.map"
></avue-input-map>
</el-form-item>
<el-form-item label="所属部门">
<el-tree-select
v-model="Addform.department"
:data="AssessmentDepartment"
check-strictly
:render-after-expand="false"
style="width: 240px"
@node-click="BelongsearcheNodeClick"
clearable
@change="Belongingdepartment"
/>
v-model="Addform.department"
:data="AssessmentDepartment"
check-strictly
:render-after-expand="false"
style="width: 240px"
@node-click="BelongsearcheNodeClick"
clearable
@change="Belongingdepartment"
/>
</el-form-item>
<el-form-item label="仓库类型">
<el-input v-model="Addform.warehouseType" placeholder="请选择仓库类型" />
<el-select v-model="Addform.warehouseType" clearable placeholder="请选择仓库类型">
<el-option
v-for="item in WarehouseType"
:key="item.dictKey"
:label="item.dictValue"
:value="item.dictKey"
/>
</el-select>
</el-form-item>
<el-form-item label="消防等级">
<el-input v-model="Addform.fireGrade" placeholder="请选择消防等级" />
<el-select v-model="Addform.fireGrade" clearable placeholder="请选择消防等级">
<el-option
v-for="item in FireProtection"
:key="item.dictKey"
:label="item.dictValue"
:value="item.dictKey"
/>
</el-select>
</el-form-item>
<el-form-item label="是否具有消防等级">
<el-input v-model="Addform.fireRatingNot" placeholder="请选择是否具有消防等级" />
<el-select v-model="Addform.fireRatingNot" clearable placeholder="请选择是否具有消防等级">
<el-option
v-for="item in Isprotection"
:key="item.dictKey"
:label="item.dictValue"
:value="item.dictKey"
/>
</el-select>
</el-form-item>
<el-form-item label="仓库结构">
<el-input v-model="Addform.warehouseStructure" placeholder="请选择仓库结构" />
<el-select v-model="Addform.warehouseStructure" clearable placeholder="请选择仓库结构">
<el-option
v-for="item in WarehouseStructureList"
:key="item.dictKey"
:label="item.dictValue"
:value="item.dictKey"
/>
</el-select>
</el-form-item>
<el-form-item label="是否高架">
<el-input v-model="Addform.elevatedNot" placeholder="请选择是否高架" />
<el-select v-model="Addform.elevatedNot" clearable placeholder="请选择是否高架">
<el-option
v-for="item in Iselevated"
:key="item.dictKey"
:label="item.dictValue"
:value="item.dictKey"
/>
</el-select>
</el-form-item>
<el-form-item label="仓库层高">
@ -145,7 +192,14 @@
</el-form-item>
<el-form-item label="电力类型">
<el-input v-model="Addform.powerCondition" placeholder="请输入仓库层高" />
<el-select v-model="Addform.powerCondition" clearable placeholder="请选择电力类型">
<el-option
v-for="item in powerConditionList"
:key="item.dictKey"
:label="item.dictValue"
:value="item.dictKey"
/>
</el-select>
</el-form-item>
<el-form-item label="租金单价">
@ -157,11 +211,25 @@
</el-form-item>
<el-form-item label="租金类型">
<el-input v-model="Addform.rentType" placeholder="请输入租金类型" />
<el-select v-model="Addform.rentType" clearable placeholder="请选择租金类型">
<el-option
v-for="item in rentTypeList"
:key="item.dictKey"
:label="item.dictValue"
:value="item.dictKey"
/>
</el-select>
</el-form-item>
<el-form-item label="仓库等级">
<el-input v-model="Addform.grade" placeholder="请输入仓库等级" />
<el-select v-model="Addform.grade" clearable placeholder="请选择仓库等级">
<el-option
v-for="item in gradeList"
:key="item.dictKey"
:label="item.dictValue"
:value="item.dictKey"
/>
</el-select>
</el-form-item>
<el-form-item label="管理费">
@ -173,13 +241,55 @@
</el-form-item>
<el-form-item label="日期范围">
<el-input v-model="Addform.daterange" placeholder="请输入日期范围" />
<el-date-picker
v-model="Addform.daterange"
type="datetimerange"
start-placeholder="租赁开始日期"
end-placeholder="租赁结束日期"
format="YYYY-MM-DD"
date-format="YYYY/MM/DD"
time-format="A hh:mm:ss"
/>
</el-form-item>
<el-form-item label="备注">
<el-input v-model="Addform.remarks" placeholder="请输入日期范围" />
</el-form-item>
<el-form-item label="收款码">
<el-input v-model="Addform.paymentCodeUrl" placeholder="请输入日期范围" />
<el-upload :action="doubledCount" :headers="headers" v-model:file-list="Addform.paymentCodeUrl" list-type="picture-card" :auto-upload="true">
<el-icon><Plus /></el-icon>
<template #file="{ file }">
<div>
<img class="el-upload-list__item-thumbnail" :src="file.url" alt="" />
<span class="el-upload-list__item-actions">
<span
class="el-upload-list__item-preview"
@click="handlePictureCardPreview(file)"
>
<el-icon><zoom-in /></el-icon>
</span>
<span
v-if="!disabled"
class="el-upload-list__item-delete"
@click="handleDownload(file)"
>
<el-icon><Download /></el-icon>
</span>
<span
v-if="!disabled"
class="el-upload-list__item-delete"
@click="handleRemove(file)"
>
<el-icon><Delete /></el-icon>
</span>
</span>
</div>
</template>
</el-upload>
<el-dialog v-model="dialogVisible">
<img w-full :src="dialogImageUrl" alt="Preview Image" />
</el-dialog>
</el-form-item>
</el-form>
<template #footer>
@ -211,22 +321,63 @@ import {
getCurrentInstance,
} from 'vue';
import { columnList } from '@/option/basicdata/basicdataWarehouseTemp.js';
import { $_getList, $_ObtainRegion,$_parentId } from '@/api/basicdata/basicdataWarehouse';
import { $_getList, $_ObtainRegion, $_parentId } from '@/api/basicdata/basicdataWarehouse';
import { getDictionaryBiz } from '@/api/system/dict'; //
import { getToken } from '@/utils/auth';
import { ElMessage } from 'element-plus';
const options = ref([{
dictKey:'1',
dictValue:'22'
}]); //
import { Delete, Download, Plus, ZoomIn } from '@element-plus/icons-vue';
const options = ref([]); //
const search = ref(false); //
const imgs = ref([
'https://fuss10.elemecdn.com/3/28/bbf893f792f03a54408b3b7a7ebf0jpeg.jpeg',
'https://fuss10.elemecdn.com/2/11/6535bcfb26e4c79b48ddde44f4b6fjpeg.jpeg',
]);
const imgs1 = ref([
'https://fuss10.elemecdn.com/a/3f/3302e58f9a181d2509f3dc0fa68b0jpeg.jpeg',
'https://fuss10.elemecdn.com/1/34/19aa98b1fcb2781c4fba33d850549jpeg.jpeg',
'https://fuss10.elemecdn.com/0/6f/e35ff375812e6b0020b6b4e8f9583jpeg.jpeg',
]);
const dialogImageUrl = ref('');
const dialogVisible = ref(false);
const disabled = ref(false);
const handleRemove = file => {
console.log(file);
};
const handlePictureCardPreview = file => {
dialogImageUrl.value = file.url;
dialogVisible.value = true;
};
const handleDownload = file => {
console.log(file);
};
const query = ref({}); //
const newlyaddload = ref(false); //
const AssessmentDepartment = ref([]); //
const department=ref()
const department = ref();
const Addform = ref({
map:[],
map: [],
}); //
const WarehouseType = ref([]); //
const FireProtection = ref([]); //
const Isprotection = ref([]); //
const WarehouseStructureList = ref([]); //
const Iselevated = ref([]); //
const powerConditionList = ref([]); //
const rentTypeList = ref([]); //
const gradeList = ref([]); //
//
const doubledCount = computed(() => {
return '/api/blade-resource/oss/endpoint/put-file';
});
// TOKEN
const headers = computed(() => {
return { 'Blade-Auth': 'Bearer ' + getToken() };
});
//
//
const loadChildren = (targetList, parentId, indicatorValue) => {
@ -264,7 +415,6 @@ const loadChildren = (targetList, parentId, indicatorValue) => {
});
};
//
const classification = (val, index) => {
console.log(index, '当前点击的谁');
@ -284,8 +434,6 @@ const classification = (val, index) => {
}
};
const BelongsearcheNodeClick = data => {
department.value = data; //
if (data.hasChildren) {
@ -321,6 +469,7 @@ const searchChangeS = () => {
query.value = {};
onLoad();
};
const areaoptions = ref([]); //
//
const initialization = () => {
$_ObtainRegion().then(res => {
@ -330,11 +479,10 @@ const initialization = () => {
console.log(res, '获取地区');
});
};
initialization();
const searchHide = () => {};
const areaoptions = ref([]);//
const details = reactive({
/** 是否开启搜索 */
search: false,
@ -420,17 +568,25 @@ const showdrawer = _flag => {
//
function updateDictionary(targetArray, dictionaryType) {
getDictionaryBiz(dictionaryType).then(res => {
res.data.data.forEach((item)=>{
console.log(item);
targetArray.push({
dictKey:item.dictKey,
dictValue:item.dictValue,
})
})
res.data.data.forEach(item => {
console.log(item);
targetArray.push({
dictKey: item.dictKey,
dictValue: item.dictValue,
});
});
});
}
const dictionary = () => {
updateDictionary(options.value, 'warehouse_function_type'); //
updateDictionary(WarehouseType.value, 'warehouse_type'); //
updateDictionary(FireProtection.value, 'warehouse_fireGrade'); //
updateDictionary(Isprotection.value, 'yes_no'); //
updateDictionary(WarehouseStructureList.value, 'warehouse_structure'); //
updateDictionary(Iselevated.value, 'yes_no'); //
updateDictionary(powerConditionList.value, 'power_condition'); //
updateDictionary(rentTypeList.value, 'rent_type'); //
updateDictionary(gradeList.value, 'warehouse_grade'); //
};
//
dictionary();
@ -479,37 +635,41 @@ const newlyaddSubmit = () => {
console.log(Addform.value);
};
//
const AffiliationList=ref({
formOption: {
labelWidth: 100,
column: [{
label: '自定义项',
prop: 'label'
}],
const AffiliationList = ref({
formOption: {
labelWidth: 100,
column: [
{
label: '自定义项',
prop: 'label',
},
],
},
lazy: true,
treeLoad: function (node, resolve) {
if (node.level === 0) {
return resolve([{ is_show: true, label: 'region', value: new Date().getTime() }]);
}
if (node.level > 2) return resolve([]);
setTimeout(() => {
const data = [
{
label: 'leaf',
is_show: true,
value: new Date().getTime(),
leaf: true,
},
lazy: true,
treeLoad: function (node, resolve) {
if (node.level === 0) {
return resolve([{ is_show: true, label: 'region', value: new Date().getTime() }]);
}
if (node.level > 2) return resolve([]);
setTimeout(() => {
const data = [{
label: 'leaf',
is_show: true,
value: new Date().getTime(),
leaf: true
}, {
is_show: true,
value: new Date().getTime(),
label: 'zone'
}];
resolve(data);
}, 500);
{
is_show: true,
value: new Date().getTime(),
label: 'zone',
},
}
)
];
resolve(data);
}, 500);
},
});
</script>
<style scoped lang="scss">
@ -535,8 +695,13 @@ const AffiliationList=ref({
.el-form-item {
width: 46%;
}
.el-form-item__content{
width: 100%;
.el-form-item__content {
width: 100% !important;
.el-select,
.avue-input-map,
.el-cascader {
width: 100% !important;
}
}
}
</style>

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

@ -518,7 +518,23 @@
>
</template>
</template>
</tablecmt>
<div class="avue-crud__pagination" style="width: 100%">
<!-- 分页模块 -->
<el-pagination
background
@size-change="wsizeChange"
@current-change="wcurrentChange"
:current-page="wpage.currentPage"
:page-sizes="[30, 50, 80, 120]"
:page-size="wpage.pageSize"
layout="total, sizes, prev, pager, next, jumper"
:total="wpage.total"
>
<!-- :align="center"-->
</el-pagination>
</div>
</el-tab-pane>
<el-tab-pane label="库存品包件" name="reservationInventoryPackage">
<el-button @click="Batchsigning" style="margin-bottom: 4px" type="primary"
@ -563,6 +579,21 @@
</template>
</template>
</tablecmt>
<div class="avue-crud__pagination" style="width: 100%">
<!-- 分页模块 -->
<el-pagination
background
@size-change="InventoryChange"
@current-change="InventorycurrentChange"
:current-page="wpage.currentPage"
:page-sizes="[30, 50, 80, 120]"
:page-size="wpage.pageSize"
layout="total, sizes, prev, pager, next, jumper"
:total="wpage.total"
>
<!-- :align="center"-->
</el-pagination>
</div>
</el-tab-pane>
<!-- <el-tab-pane label="角色管理" name="third">角色管理</el-tab-pane>-->
<!-- <el-tab-pane label="定时任务补偿" name="fourth">定时任务补偿</el-tab-pane>-->
@ -610,24 +641,29 @@
</template>
</template>
</tablecmt>
</el-tab-pane>
</el-tabs>
<div class="avue-crud__pagination" style="width: 100%">
<!-- 分页模块 -->
<div class="avue-crud__pagination" style="width: 100%">
<!-- 分页模块 -->
<el-pagination
background
@size-change="wsizeChange"
@current-change="wcurrentChange"
:current-page="wpage.currentPage"
@size-change="zeroChange"
@current-change="zerocurrentChange"
:current-page="zeroPg.currentPage"
:page-sizes="[30, 50, 80, 120]"
:page-size="wpage.pageSize"
:page-size="zeroPg.pageSize"
layout="total, sizes, prev, pager, next, jumper"
:total="wpage.total"
:total="zeroPg.total"
>
<!-- :align="center"-->
</el-pagination>
</div>
</el-tab-pane>
</el-tabs>
<!-- 表单按钮 -->
<!-- <template #footer>-->
<!-- <span v-if="!view" class="dialog-footer">-->
@ -866,6 +902,7 @@ import {
getReservationPackageList,
deliveryInventorySign,
printBatch,
$_deliveryZeroPackage,
} from '@/api/distribution/distributionDeliveryList';
import { showOrderPackgeCode } from '@/api/distribution/distributionStockArticle';
import { showInventoryPackgeCode } from '@/api/distribution/distributionStockList';
@ -2306,6 +2343,11 @@ export default {
//
stateData: [],
//
zeroPg:{
currentPage: 1,
pageSize: 30,
total: 40,
},
option: {
expand: false,
index: true,
@ -3961,8 +4003,11 @@ export default {
console.log(res, '零担数据');
const data = res.data.data;
this.LessThantruckloadListData = data.records;
this.zeroPg.total = data.total;
})
.catch(() => {
})
.catch(() => {})
.finally(() => {
this.loading = false; //
});
@ -4383,35 +4428,68 @@ export default {
message: '请勾选需要批量签收的数据',
type: 'warning',
});
return
return;
}
this.$confirm('是否进行批量签收?').then(()=>{
this.loading=true;//
if(res.data.code==200){
this.truckload(this.page);
}
}).catch(()=>{
})
const allSigned = this.LessThantruckloadListData.every(
item => item.signingStatusName == '待签收' || item.signingStatusName == '部分签收'
);
console.log(allSigned,'allSigned');
if (!allSigned) {
let temp = {};
console.log(true); // true
temp = this.LessThantruckloadListData.find(item => item.signingStatusName == '已签收');
ElMessage({
message: `${temp.orderCode}运单号已签收`,
type: 'warning',
});
return
}
this.$confirm('是否进行批量签收?')
.then(() => {
this.loading = true; //
let data = {
deliveryId: this.deliveryId,
reservationId: this.wid,
zeroPackageIds: this.selectionList.map(item => item.id).join(','),
};
$_deliveryZeroPackage(data).then(res => {
if (res.data.code == 200) {
ElMessage({
showClose: true,
message: res.data.msg,
type: 'success',
})
this.truckload(this.page);
this.selectionList = [];
}
}).catch(()=>{
}).finally(()=>{
this.loading = false; //
});
})
.catch(() => {});
},
//
LdBatchcancellation() {
return
if (!this.selectionList.length) {
ElMessage({
message: '请勾选需要计划取消的数据',
type: 'warning',
});
return
return;
}
this.$confirm('是否进行批量计划取消?').then(()=>{
this.loading=true;//
if(res.data.code == 200){
this.truckload(this.page);
}
}).catch(()=>{
})
this.$confirm('是否进行批量计划取消?')
.then(() => {
this.loading = true; //
if (res.data.code == 200) {
this.truckload(this.page);
}
})
.catch(() => {});
},
//
Batchsigning() {
@ -5065,6 +5143,7 @@ export default {
console.log('库存品包件>>>>>>>', res.data.data);
const data = res.data.data;
this.reservationInventoryPackageData = data.records;
this.wpage.total = data.total;
this.loading = false; //
});
},
@ -5132,10 +5211,30 @@ export default {
this.wpage.currentPage = currentPage;
this.getWrapdetails(this.wpage);
},
//
InventorycurrentChange(currentPage){
this.wpage.currentPage = currentPage;
this.getReservationInventoryPackageListInfo(this.wpage)
},
wsizeChange(pageSize) {
this.wpage.pageSize = pageSize;
this.getWrapdetails(this.wpage);
},
//
InventoryChange(pageSize){
this.wpage.pageSize = pageSize;
this.getReservationInventoryPackageListInfo(this.wpage)
},
//
zeroChange(pageSize){
this.zeroPg.pageSize = pageSize;
this.truckload(this.zeroPg);
},
//
zerocurrentChange(currentPage){
this.zeroPg.currentPag=currentPage;
this.truckload(this.zeroPg);
},
winputsc(index, row) {
this.wrapoption.query[row.prop] = index;
this.getWrapdetails(this.wpage);

115
src/views/distribution/inventory/distributionStockListMarket.vue

@ -143,12 +143,12 @@
v-model="formInline.sku"
placeholder="请输入sku"
clearable
:disabled="Boolean(unpackFormDisable.sku)"
:disabled="FromDis"
/>
</el-form-item>
<el-form-item label="货物名称" style="width: 40%">
<!-- <el-input v-model="formInline.descriptionGoods" placeholder="请输入货物名称" clearable />-->
<el-select
<!-- <el-select
style="width: 100%"
v-model="formInline.materialIdName"
filterable
@ -167,6 +167,24 @@
:label="item.name"
:value="item.id"
/>
</el-select> -->
<el-select
style="width: 100%"
v-model="formInline.materialIdName"
filterable
remote
reserve-keyword
placeholder="请选择物料名称"
clearable
:disabled="goodsDis"
@change="getMethodName($event, '1')"
>
<el-option
v-for="item in optionsName"
:key="item.id"
:label="item.name"
:value="item.id"
/>
</el-select>
</el-form-item>
<el-form-item label="货物单位" style="width: 40%">
@ -178,7 +196,7 @@
reserve-keyword
remote-show-suffix
placeholder="请选择货物单位"
:disabled="Boolean(unpackFormDisable.cargoUnit)"
:disabled="FromDis"
>
<el-option
v-for="item in distributionUnit"
@ -193,7 +211,7 @@
v-model="formInline.cargoNorms"
placeholder="请输入规格"
clearable
:disabled="Boolean(unpackFormDisable.cargoNorms)"
:disabled="FromDis"
/>
</el-form-item>
<el-form-item label="产品编码" style="width: 40%">
@ -201,7 +219,7 @@
v-model="formInline.cargoNumber"
placeholder="请输入产品编码"
clearable
:disabled="Boolean(unpackFormDisable.cargoNumber)"
:disabled="goodsDis || FromDis"
/>
</el-form-item>
<el-form-item label="包装数量" style="width: 40%">
@ -209,7 +227,7 @@
v-model="formInline.packageNum"
placeholder="请输入包装数量"
clearable
:disabled="Boolean(unpackFormDisable.packageNum)"
:disabled="FromDis"
/>
</el-form-item>
<el-form-item label="拆箱数" style="width: 40%">
@ -314,7 +332,7 @@ import {
stockExport,
} from '@/api/distribution/distributionStockList';
import { getListParcelDetails } from '@/api/distribution/distributionParcelDetails';
import { getListMaterial } from '@/api/basic/basicMaterial';
import { getListMaterial, $_getListMaterial } from '@/api/basic/basicMaterial';
import option from '@/option/distribution/distributionStockList';
import { mapGetters } from 'vuex';
import { exportBlob } from '@/api/common';
@ -333,6 +351,8 @@ export default {
unpackFormDisable: {},
//
optionsName: [],
goodsDis: true,
FromDis: true,
columnList: [
{
prop: '',
@ -820,24 +840,24 @@ export default {
/**
* 查询
* */
async remoteMethodName(query) {
console.log('query', query);
if (query) {
this.loading = true;
//
let asd = await getListMaterial(this.page.currentPage, this.page.pageSize, {
name: query,
// pid: this.stockList.materialId,
}).then();
console.log('物料信息', asd.data.data);
if (!!asd.data.data) {
this.optionsName = asd.data.data.records;
}
this.loading = false;
} else {
this.optionsName = [];
}
},
// async remoteMethodName(query) {
// console.log('query', query);
// if (query) {
// this.loading = true;
// //
// let asd = await getListMaterial(this.page.currentPage, this.page.pageSize, {
// name: query,
// pid: this.stockList.materialId,
// }).then();
// console.log('', asd.data.data);
// if (!!asd.data.data) {
// this.optionsName = asd.data.data.records;
// }
// this.loading = false;
// } else {
// this.optionsName = [];
// }
// },
/**
* 物料选择赋值
* */
@ -1032,6 +1052,35 @@ export default {
// this.form.parcels = shi;
// }
// console.log("");
if (this.FromDis) {
if (!this.formInline.materialIdName) {
this.$message.warning('请选择货物名称');
return;
}
}
if (!this.formInline.sku) {
this.$message.warning('请输入Sku');
return;
}
if (!this.formInline.cargoUnit) {
this.$message.warning('请选择货物单位');
return;
}
if (!this.formInline.cargoNorms) {
this.$message.warning('请输入规格');
return;
}
if (!this.formInline.packageNum) {
this.$message.warning('请输入包装数量');
return;
}
if (!this.formInline.unpackingQuantity) {
this.$message.warning('请输入拆箱数量');
return;
}
if (parseInt(this.formInline.unpackingQuantity) > parseInt(this.getQuery.quantityStock)) {
this.$message.warning('拆包数量大于在库数量!!!');
return;
@ -1105,6 +1154,22 @@ export default {
});
},
async handleViewDismantle(row) {
let data = {
pid: row.row.materialId,
};
$_getListMaterial(data).then(res => {
console.log('物料信息', res);
if (res.data.data.length) {
this.optionsName = res.data.data;
console.log('this.optionsName', this.optionsName);
this.goodsDis = false;
this.FromDis = true;
} else {
this.goodsDis = true;
this.FromDis = false;
}
});
console.log('><<>L:', row.row);
this.dismantle = true;
this.view = true;

1
src/views/distribution/inventory/distrilbutionBillLading.vue

@ -2906,6 +2906,7 @@ export default {
params.genre = 1;
params.typeService = 3;
params.reservation = '30';
params.isAll=0;
getListOne(page.currentPage, page.pageSize, Object.assign(params, this.queryOrder)).then(
res => {
const data = res.data.data;

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

@ -292,6 +292,7 @@
>
<template #default="slotProps">
<el-text
v-if="slotProps.scope.row.isZero != '1'"
:link="ElButtonS[0].link"
:class="ElButtonS[0].class"
:auto-insert-space="ElButtonS[0].space"

171
src/views/reportforms/DeliveryCustomers.vue

@ -7,13 +7,85 @@
<!-- 搜索模块 -->
<el-row v-if="search">
<!-- 查询模块 -->
<el-form :inline="true" :model="query" class="el-fr-d">
<!-- 查询按钮 -->
<el-form-item class="el-btn">
<el-button type="primary" icon="el-icon-search" @click="searchChange"> </el-button>
<el-button icon="el-icon-delete" @click="searchReset()"> </el-button>
<el-form :inline="true" :model="TopQuery" class="el-fr-d">
<!-- 查询按钮 -->
<div class="el_top_left">
<el-form-item label="配送日期">
<el-date-picker
v-model="TopQuery.time"
type="datetimerange"
start-placeholder="开始日期"
end-placeholder="结束日期"
format="YYYY-MM-DD"
date-format="YYYY/MM/DD"
time-format="A"
@change="Toptiem"
/>
</el-form-item>
<el-form-item label="仓库">
<el-select
multiple
v-model="TopQuery.warehouse"
filterable
placeholder="多选仓库搜索"
style="width: 240px"
>
<el-option
v-for="item in warehouseList"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</el-form-item>
<el-form-item label="配送车辆">
<el-input
v-model="TopQuery.vehicle"
style="width: 240px"
:rows="1"
type="textarea"
placeholder="多个配送车辆请用逗号隔开"
/>
</el-form-item>
<el-form-item label="配送司机">
<el-input
v-model="TopQuery.vehicle"
style="width: 240px"
:rows="1"
type="textarea"
placeholder="多个配送司机请用逗号隔开"
/>
</el-form-item>
</el-form>
<!-- <el-form-item label="配送类型">
<el-select multiple v-model="TopQuery.DeliveryType" filterable placeholder="多选仓库搜索" style="width: 240px">
<el-option
v-for="item in DeliveryTypeList"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</el-form-item> -->
<!-- <el-form-item label="配送种类">
<el-select multiple v-model="TopQuery.Deliverygeneric" filterable placeholder="多选仓库搜索" style="width: 240px">
<el-option
v-for="item in DeliverygenericList"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</el-form-item> -->
</div>
<el-form-item class="el-btn">
<el-button type="primary" icon="el-icon-search" @click="searchChange"> </el-button>
<el-button icon="el-icon-delete" @click="searchReset()"> </el-button>
</el-form-item>
</el-form>
</el-row>
<!-- 控件模块 -->
@ -91,11 +163,15 @@
import { columnList } from '@/option/reportforms/DeliveryCustomers.js';
import { getDictionaryBiz } from '@/api/system/dict'; //
import { processRowProperty,setNodeHeight } from '@/utils/util';
import {$_getcustomer,$_exportCustomer} from '@/api/reportforms/index.js';
import {$_getcustomer,$_exportCustomer,$_getMyWarehouseList} from '@/api/reportforms/index.js';
import { ElMessageBox } from 'element-plus';
import { downloadXls } from '@/utils/util';
import functions from '@/utils/functions.js';
import dayjs from 'dayjs';
const TopQuery=ref({});//
const warehouseList = ref([]); //
const DeliveryTypeList =ref([])
const DeliverygenericList =ref([])
const details = reactive({
/** 是否开启搜索 */
search: false,
@ -218,7 +294,14 @@
};
//
const Toptiem = val => {
if (!val) {
delete TopQuery.value.ks;
delete TopQuery.value.end;
}
console.log(val, '顶部时间触发');
console.log(TopQuery.value, '顶部时间触发');
};
/** 表格表头时间选择 */
const timesc = (index, row) => {
console.log(index, row);
@ -247,8 +330,18 @@
};
//
const searchChange = () => {
details.search = false; //
};
//
if (TopQuery.value.time) {
TopQuery.value.ks = dayjs(TopQuery.value.time[0]).format('YYYY-MM-DD'); //
TopQuery.value.end = dayjs(TopQuery.value.time[1]).format('YYYY-MM-DD'); //
}
//
if (TopQuery.value.warehouse) {
TopQuery.value.warehouseJoin = TopQuery.value.warehouse.join(',');
}
console.log(TopQuery.value, '顶部搜索触发');
// details.search = false; //
};
//
const sizeChange = val => {
details.page.pageSize = val;
@ -288,9 +381,31 @@
});
}
//
const onLoad = () => {
// updateDictionary(columnList[3].checkarr, 'pc_work_order'); //
};
//
const onLoad = () => {
warehouseList.value = [];
columnList.find(res => res.label == '配送类型').checkarr = [];
columnList.find(res => res.label == '配送类型').checkarr = DeliveryTypeList.value;
columnList.find(res => res.label == '配送种类').checkarr = [];
columnList.find(res => res.label == '配送种类').checkarr = DeliverygenericList.value;
columnList.find(res => res.label == '仓库').checkarr = [];
columnList.find(res => res.label == '仓库').checkarr = warehouseList.value;
console.log(columnList, 'columnList');
//
$_getMyWarehouseList().then(res => {
console.log(res, '仓库列表');
if (res.data.data.length)
res.data.data.forEach(item => {
warehouseList.value.push({
value: item.name,
label: item.name,
});
});
});
};
onLoad();
//
const getrain=()=>{
@ -360,5 +475,35 @@ const exportReport=()=>{
display: flex;
flex-direction: column;
}
:deep(.el-fr-d) {
width: 100%;
display: flex;
flex-wrap: wrap;
justify-content: space-between;
.el_top_left {
width: 100%;
display: flex;
justify-content: space-between;
.el-form-item {
align-items: flex-start;
}
.el-form-item__content {
align-items: flex-start;
height: 100%;
.el-date-editor {
height: 29px !important;
}
}
}
}
:deep(.el-btn) {
margin-right: 0;
display: flex;
width: 100%;
justify-content: flex-end;
.el-form-item__content {
justify-content: flex-end;
}
}
</style>

181
src/views/reportforms/DeliveryTrainNumber.vue

@ -5,8 +5,80 @@
<!-- 搜索模块 -->
<el-row v-if="search">
<!-- 查询模块 -->
<el-form :inline="true" :model="query" class="el-fr-d">
<el-form :inline="true" :model="TopQuery" class="el-fr-d">
<!-- 查询按钮 -->
<div class="el_top_left">
<el-form-item label="配送日期">
<el-date-picker
v-model="TopQuery.time"
type="datetimerange"
start-placeholder="开始日期"
end-placeholder="结束日期"
format="YYYY-MM-DD"
date-format="YYYY/MM/DD"
time-format="A"
@change="Toptiem"
/>
</el-form-item>
<el-form-item label="仓库">
<el-select
multiple
v-model="TopQuery.warehouse"
filterable
placeholder="多选仓库搜索"
style="width: 240px"
>
<el-option
v-for="item in warehouseList"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</el-form-item>
<el-form-item label="配送车辆">
<el-input
v-model="TopQuery.vehicle"
style="width: 240px"
:rows="1"
type="textarea"
placeholder="多个配送车辆请用逗号隔开"
/>
</el-form-item>
<el-form-item label="配送司机">
<el-input
v-model="TopQuery.vehicle"
style="width: 240px"
:rows="1"
type="textarea"
placeholder="多个配送司机请用逗号隔开"
/>
</el-form-item>
<!-- <el-form-item label="配送类型">
<el-select multiple v-model="TopQuery.DeliveryType" filterable placeholder="多选仓库搜索" style="width: 240px">
<el-option
v-for="item in DeliveryTypeList"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</el-form-item> -->
<!-- <el-form-item label="配送种类">
<el-select multiple v-model="TopQuery.Deliverygeneric" filterable placeholder="多选仓库搜索" style="width: 240px">
<el-option
v-for="item in DeliverygenericList"
:key="item.value"
:label="item.label"
:value="item.value"
/>
</el-select>
</el-form-item> -->
</div>
<el-form-item class="el-btn">
<el-button type="primary" icon="el-icon-search" @click="searchChange"> </el-button>
<el-button icon="el-icon-delete" @click="searchReset()"> </el-button>
@ -90,11 +162,36 @@ import { ref, reactive, toRefs, computed, onMounted, nextTick, watch } from 'vue
import { columnList } from '@/option/reportforms/DeliveryTrainNumber.js';
import { getDictionaryBiz } from '@/api/system/dict'; //
import { processRowProperty, setNodeHeight } from '@/utils/util';
import { $_getrain, $_exportTrain } from '@/api/reportforms/index.js';
import { $_getrain, $_exportTrain, $_getMyWarehouseList } from '@/api/reportforms/index.js';
import { ElMessageBox } from 'element-plus';
import { downloadXls } from '@/utils/util';
import functions from '@/utils/functions.js';
const warehouseList = ref([]); //
const DeliveryTypeList = ref([
{
label: '商配',
value: '商配',
},
{
label: '市配',
value: '市配',
},
]); //
//
const DeliverygenericList = ref([
{
label: '自主配送',
value: '自主配送',
},
{
label: '三方配送',
value: '三方配送',
},
]); //
import dayjs from 'dayjs';
const TopQuery = ref({}); //
const details = reactive({
/** 是否开启搜索 */
search: false,
@ -236,6 +333,7 @@ const btnsc = val => {
/** 表格表头下拉框选择 */
const selectsc = (index, row) => {
processRowProperty(index, row, details);
getrain();
};
/** 表格表头复选框选择 */
const selectionChange = list => {
@ -244,7 +342,25 @@ const selectionChange = list => {
};
//
const searchChange = () => {
details.search = false; //
//
if (TopQuery.value.time) {
TopQuery.value.ks = dayjs(TopQuery.value.time[0]).format('YYYY-MM-DD'); //
TopQuery.value.end = dayjs(TopQuery.value.time[1]).format('YYYY-MM-DD'); //
}
//
if (TopQuery.value.warehouse) {
TopQuery.value.warehouseJoin = TopQuery.value.warehouse.join(',');
}
console.log(TopQuery.value, '顶部搜索触发');
// details.search = false; //
};
const Toptiem = val => {
if (!val) {
delete TopQuery.value.ks;
delete TopQuery.value.end;
}
console.log(val, '顶部时间触发');
console.log(TopQuery.value, '顶部时间触发');
};
//
const sizeChange = val => {
@ -286,7 +402,28 @@ function updateDictionary(targetArray, dictionaryType) {
}
//
const onLoad = () => {
// updateDictionary(columnList[3].checkarr, 'pc_work_order'); //
warehouseList.value = [];
columnList.find(res => res.label == '配送类型').checkarr = [];
columnList.find(res => res.label == '配送类型').checkarr = DeliveryTypeList.value;
columnList.find(res => res.label == '配送种类').checkarr = [];
columnList.find(res => res.label == '配送种类').checkarr = DeliverygenericList.value;
columnList.find(res => res.label == '仓库').checkarr = [];
columnList.find(res => res.label == '仓库').checkarr = warehouseList.value;
console.log(columnList, 'columnList');
//
$_getMyWarehouseList().then(res => {
console.log(res, '仓库列表');
if (res.data.data.length)
res.data.data.forEach(item => {
warehouseList.value.push({
value: item.name,
label: item.name,
});
});
});
};
onLoad();
//
@ -326,12 +463,10 @@ const exportReport = () => {
.then(res => {
downloadXls(res.data, `配送车次报表数据.xlsx`);
})
.catch(() => {
})
.catch(() => {})
.finally(() => {
details.loadingObj.list = false;
})
});
})
.catch(() => {});
};
@ -362,4 +497,34 @@ const exportReport = () => {
display: flex;
flex-direction: column;
}
:deep(.el-fr-d) {
width: 100%;
display: flex;
flex-wrap: wrap;
justify-content: space-between;
.el_top_left {
width: 100%;
display: flex;
justify-content: space-between;
.el-form-item {
align-items: flex-start;
}
.el-form-item__content {
align-items: flex-start;
height: 100%;
.el-date-editor {
height: 29px !important;
}
}
}
}
:deep(.el-btn) {
margin-right: 0;
display: flex;
width: 100%;
justify-content: flex-end;
.el-form-item__content {
justify-content: flex-end;
}
}
</style>

366
src/views/reportforms/Inventory.vue

@ -0,0 +1,366 @@
<template>
<basic-container>
<!-- 首页表格 -->
<div class="avue-crud">
<!-- 搜索模块 -->
<el-row v-if="search">
<!-- 查询模块 -->
<el-form :inline="true" :model="query" class="el-fr-d">
<!-- 查询按钮 -->
<el-form-item class="el-btn">
<el-button type="primary" icon="el-icon-search" @click="searchChange"> </el-button>
<el-button icon="el-icon-delete" @click="searchReset()"> </el-button>
</el-form-item>
</el-form>
</el-row>
<!-- 控件模块 -->
<el-row>
<div class="avue-crud__header">
<!-- 头部左侧按钮模块 -->
<div class="avue-crud__left">
<el-button type="primary" @click="exportReport">
<el-icon><Download /></el-icon></el-button
>
</div>
<!-- 头部右侧按钮模块 -->
<div class="avue-crud__right">
<el-button icon="el-icon-refresh" @click="searchChangeS" circle></el-button>
<el-button icon="Operation" @click="showdrawer(true)" circle></el-button>
<el-button icon="Search" @click="searchHide" circle></el-button>
</div>
</div>
</el-row>
<!-- 首页表格 -->
<el-row>
<!-- 列表模块 -->
<tablecmt
class="tableNode"
:columnList="columnList"
:tableData="data"
:loading="loadingObj.list"
@inputTxt="inputsc"
@timeCheck="timesc"
@btnCheck="btnsc"
@selectCheck="selectsc"
@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>
</tablecmt>
</el-row>
<!-- 分页模块 -->
<el-row class="el-fy">
<div class="avue-crud__pagination flex-c-sb" style="width: 100%">
<div></div>
<el-pagination
align="right"
background
@size-change="sizeChange"
@current-change="currentChange"
:current-page="page.currentPage"
:page-sizes="[30, 50, 80, 120]"
:page-size="page.pageSize"
layout="total, sizes, prev, pager, next, jumper"
:total="page.total"
>
</el-pagination>
</div>
</el-row>
</div>
</basic-container>
<!-- 列表配置显示 -->
<edittablehead
@setcolum="setnewcolum"
@closce="showdrawer"
:drawerShow="drawerShow"
:columnList="details.columnList"
></edittablehead>
</template>
<script setup>
import { ref, reactive, toRefs, computed, onMounted, nextTick, watch } from 'vue';
import { columnList } from '@/option/reportforms/Inventory.js';
import { getDictionaryBiz } from '@/api/system/dict'; //
import { processRowProperty, setNodeHeight } from '@/utils/util';
import { $_exportInventory ,$_getInventory} from '@/api/reportforms/index.js';
import { ElMessageBox } from 'element-plus';
import { downloadXls } from '@/utils/util';
import functions from '@/utils/functions.js';
import dayjs from 'dayjs';
const details = reactive({
/** 是否开启搜索 */
search: false,
/** 表格搜索条件 */
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];
},
},
],
/** 时间选择器数据 */
stockupDate: [],
/** 列表 */
columnList,
/** 列表数据 */
data: [],
/** 页面loading */
loadingObj: {
/** 列表加载loading */
list: false,
packageListLoading: false,
},
/** 列表复选框选中的数据 */
selectionList: [],
/** 是否显示设置表格 */
drawerShow: false,
/** 分页参数 */
page: {
currentPage: 1,
pageSize: 50,
total: 0,
},
/** 弹出层显示 */
popUpShow: {
/** 包件明细 */
packageOrderListlVisited: false,
/** 二维码 */
QRCodeVisible: false,
/** 修改客户信息 */
editClientInfoVisible: false,
},
/** 列表Dom节点 */
listNode: '',
form: {},
/** 全屏 */
fullscreenObj: {
/** 包明细 */
packageOrderListlVisited: false,
},
});
const {
search,
query,
shortcuts,
stockupDate,
data,
loadingObj,
selectionList,
drawerShow,
page,
trickleLoadingPage,
zeroAdditionalRecordingInfo,
popUpShow,
recorddata,
} = toRefs(details);
/**
* 设置列表 -- 固定函数
* 弹窗的勾选回调用于更改头部数组
* 固定搭配只需要更换 columnList
* */
const setnewcolum = (newarr, headarr, type) => {
if (type == 1) {
details.columnList = newarr;
functions.setStorage(window.location.pathname + 'checkList', headarr);
} else if (type == 2) {
details.columnList = newarr;
functions.setStorage(window.location.pathname + 'flexList', headarr);
} else if (type == 3) {
details.columnList = newarr;
functions.setStorage(window.location.pathname + 'sortlist', headarr);
}
};
/** 展开列表控件 */
const showdrawer = _flag => {
details.drawerShow = _flag;
};
/** 表格表头输入框搜索 */
const inputsc = (index, row) => {
details.query[row.prop] = index;
processRowProperty(index, row, details);
getrain();
};
/** 表格表头时间选择 */
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];
}
getrain();
};
/** 表格表头输入框搜索 */
const btnsc = val => {
console.log(val);
};
/** 表格表头下拉框选择 */
const selectsc = (index, row) => {
processRowProperty(index, row, details);
};
/** 表格表头复选框选择 */
const selectionChange = list => {
console.log(list);
details.selectionList = list;
};
//
const searchChange = () => {
details.search = false; //
};
//
const sizeChange = val => {
details.page.pageSize = val;
getrain();
};
/** 页码改变执行的回调 */
const currentChange = val => {
details.page.currentPage = val;
getrain();
};
//
const searchChangeS = () => {
details.columnList.forEach(item => {
item.values = '';
});
details.search = false; //
getrain();
};
//
const searchHide = () => {
console.log(details);
details.search = !details.search;
const _node = document.querySelector('.tableNode');
setNodeHeight(_node, '', true);
};
//
function updateDictionary(targetArray, dictionaryType) {
getDictionaryBiz(dictionaryType).then(res => {
console.log(res, '字典');
res.data.data.forEach(item => {
targetArray.push({
value: item.dictKey,
label: item.dictValue,
});
});
});
}
//
const onLoad = () => {
// updateDictionary(columnList[3].checkarr, 'pc_work_order'); //
};
onLoad();
//
const getrain = () => {
let data = {
current: details.page.currentPage,
size: details.page.pageSize,
...details.query,
};
details.loadingObj.list = true;
$_getInventory(data)
.then(res => {
console.log(res, '当前参数1');
details.page.total = res.data.data.total;
details.data = res.data.data.records;
})
.catch(() => {})
.finally(() => {
details.loadingObj.list = false;
});
};
getrain();
//
const exportReport = () => {
ElMessageBox.confirm('是否导出报表?', {
confirmButtonText: '确定',
cancelButtonText: '取消',
type: 'warning',
})
.then(() => {
details.loadingObj.list = true;
let data = {
...details.query,
};
$_exportInventory(data)
.then(res => {
downloadXls(res.data, `库存品明细报表数据.xlsx`);
})
.catch(() => {
})
.finally(() => {
details.loadingObj.list = false;
})
})
.catch(() => {});
};
</script>
<style scoped lang="scss">
.ElBtnClass button {
border: none;
padding: 0;
background-color: transparent;
}
:deep(.el-card) {
height: 100%;
}
:deep(.el-card__body) {
height: 100%;
display: flex;
flex-direction: column;
}
.el-fy {
flex: 1;
display: flex;
align-items: flex-end;
margin-bottom: 10px;
}
.avue-crud {
height: 100%;
display: flex;
flex-direction: column;
}
</style>

366
src/views/reportforms/InventoryOutbound.vue

@ -0,0 +1,366 @@
<template>
<basic-container>
<!-- 首页表格 -->
<div class="avue-crud">
<!-- 搜索模块 -->
<el-row v-if="search">
<!-- 查询模块 -->
<el-form :inline="true" :model="query" class="el-fr-d">
<!-- 查询按钮 -->
<el-form-item class="el-btn">
<el-button type="primary" icon="el-icon-search" @click="searchChange"> </el-button>
<el-button icon="el-icon-delete" @click="searchReset()"> </el-button>
</el-form-item>
</el-form>
</el-row>
<!-- 控件模块 -->
<el-row>
<div class="avue-crud__header">
<!-- 头部左侧按钮模块 -->
<div class="avue-crud__left">
<el-button type="primary" @click="exportReport">
<el-icon><Download /></el-icon></el-button
>
</div>
<!-- 头部右侧按钮模块 -->
<div class="avue-crud__right">
<el-button icon="el-icon-refresh" @click="searchChangeS" circle></el-button>
<el-button icon="Operation" @click="showdrawer(true)" circle></el-button>
<el-button icon="Search" @click="searchHide" circle></el-button>
</div>
</div>
</el-row>
<!-- 首页表格 -->
<el-row>
<!-- 列表模块 -->
<tablecmt
class="tableNode"
:columnList="columnList"
:tableData="data"
:loading="loadingObj.list"
@inputTxt="inputsc"
@timeCheck="timesc"
@btnCheck="btnsc"
@selectCheck="selectsc"
@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>
</tablecmt>
</el-row>
<!-- 分页模块 -->
<el-row class="el-fy">
<div class="avue-crud__pagination flex-c-sb" style="width: 100%">
<div></div>
<el-pagination
align="right"
background
@size-change="sizeChange"
@current-change="currentChange"
:current-page="page.currentPage"
:page-sizes="[30, 50, 80, 120]"
:page-size="page.pageSize"
layout="total, sizes, prev, pager, next, jumper"
:total="page.total"
>
</el-pagination>
</div>
</el-row>
</div>
</basic-container>
<!-- 列表配置显示 -->
<edittablehead
@setcolum="setnewcolum"
@closce="showdrawer"
:drawerShow="drawerShow"
:columnList="details.columnList"
></edittablehead>
</template>
<script setup>
import { ref, reactive, toRefs, computed, onMounted, nextTick, watch } from 'vue';
import { columnList } from '@/option/reportforms/InventoryOutbound.js';
import { getDictionaryBiz } from '@/api/system/dict'; //
import { processRowProperty, setNodeHeight } from '@/utils/util';
import { $_getreport ,$_exportOutStocks} from '@/api/reportforms/index.js';
import { ElMessageBox } from 'element-plus';
import { downloadXls } from '@/utils/util';
import functions from '@/utils/functions.js';
import dayjs from 'dayjs';
const details = reactive({
/** 是否开启搜索 */
search: false,
/** 表格搜索条件 */
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];
},
},
],
/** 时间选择器数据 */
stockupDate: [],
/** 列表 */
columnList,
/** 列表数据 */
data: [],
/** 页面loading */
loadingObj: {
/** 列表加载loading */
list: false,
packageListLoading: false,
},
/** 列表复选框选中的数据 */
selectionList: [],
/** 是否显示设置表格 */
drawerShow: false,
/** 分页参数 */
page: {
currentPage: 1,
pageSize: 50,
total: 0,
},
/** 弹出层显示 */
popUpShow: {
/** 包件明细 */
packageOrderListlVisited: false,
/** 二维码 */
QRCodeVisible: false,
/** 修改客户信息 */
editClientInfoVisible: false,
},
/** 列表Dom节点 */
listNode: '',
form: {},
/** 全屏 */
fullscreenObj: {
/** 包明细 */
packageOrderListlVisited: false,
},
});
const {
search,
query,
shortcuts,
stockupDate,
data,
loadingObj,
selectionList,
drawerShow,
page,
trickleLoadingPage,
zeroAdditionalRecordingInfo,
popUpShow,
recorddata,
} = toRefs(details);
/**
* 设置列表 -- 固定函数
* 弹窗的勾选回调用于更改头部数组
* 固定搭配只需要更换 columnList
* */
const setnewcolum = (newarr, headarr, type) => {
if (type == 1) {
details.columnList = newarr;
functions.setStorage(window.location.pathname + 'checkList', headarr);
} else if (type == 2) {
details.columnList = newarr;
functions.setStorage(window.location.pathname + 'flexList', headarr);
} else if (type == 3) {
details.columnList = newarr;
functions.setStorage(window.location.pathname + 'sortlist', headarr);
}
};
/** 展开列表控件 */
const showdrawer = _flag => {
details.drawerShow = _flag;
};
/** 表格表头输入框搜索 */
const inputsc = (index, row) => {
details.query[row.prop] = index;
processRowProperty(index, row, details);
getrain();
};
/** 表格表头时间选择 */
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];
}
getrain();
};
/** 表格表头输入框搜索 */
const btnsc = val => {
console.log(val);
};
/** 表格表头下拉框选择 */
const selectsc = (index, row) => {
processRowProperty(index, row, details);
};
/** 表格表头复选框选择 */
const selectionChange = list => {
console.log(list);
details.selectionList = list;
};
//
const searchChange = () => {
details.search = false; //
};
//
const sizeChange = val => {
details.page.pageSize = val;
getrain();
};
/** 页码改变执行的回调 */
const currentChange = val => {
details.page.currentPage = val;
getrain();
};
//
const searchChangeS = () => {
details.columnList.forEach(item => {
item.values = '';
});
details.search = false; //
getrain();
};
//
const searchHide = () => {
console.log(details);
details.search = !details.search;
const _node = document.querySelector('.tableNode');
setNodeHeight(_node, '', true);
};
//
function updateDictionary(targetArray, dictionaryType) {
getDictionaryBiz(dictionaryType).then(res => {
console.log(res, '字典');
res.data.data.forEach(item => {
targetArray.push({
value: item.dictKey,
label: item.dictValue,
});
});
});
}
//
const onLoad = () => {
// updateDictionary(columnList[3].checkarr, 'pc_work_order'); //
};
onLoad();
//
const getrain = () => {
let data = {
current: details.page.currentPage,
size: details.page.pageSize,
...details.query,
};
details.loadingObj.list = true;
$_getreport(data)
.then(res => {
console.log(res, '当前参数1');
details.page.total = res.data.data.total;
details.data = res.data.data.records;
})
.catch(() => {})
.finally(() => {
details.loadingObj.list = false;
});
};
getrain();
//
const exportReport = () => {
ElMessageBox.confirm('是否导出报表?', {
confirmButtonText: '确定',
cancelButtonText: '取消',
type: 'warning',
})
.then(() => {
details.loadingObj.list = true;
let data = {
...details.query,
};
$_exportOutStocks(data)
.then(res => {
downloadXls(res.data, `库存出库明细报表数据.xlsx`);
})
.catch(() => {
})
.finally(() => {
details.loadingObj.list = false;
})
})
.catch(() => {});
};
</script>
<style scoped lang="scss">
.ElBtnClass button {
border: none;
padding: 0;
background-color: transparent;
}
:deep(.el-card) {
height: 100%;
}
:deep(.el-card__body) {
height: 100%;
display: flex;
flex-direction: column;
}
.el-fy {
flex: 1;
display: flex;
align-items: flex-end;
margin-bottom: 10px;
}
.avue-crud {
height: 100%;
display: flex;
flex-direction: column;
}
</style>

366
src/views/reportforms/InventoryReceipt.vue

@ -0,0 +1,366 @@
<template>
<basic-container>
<!-- 首页表格 -->
<div class="avue-crud">
<!-- 搜索模块 -->
<el-row v-if="search">
<!-- 查询模块 -->
<el-form :inline="true" :model="query" class="el-fr-d">
<!-- 查询按钮 -->
<el-form-item class="el-btn">
<el-button type="primary" icon="el-icon-search" @click="searchChange"> </el-button>
<el-button icon="el-icon-delete" @click="searchReset()"> </el-button>
</el-form-item>
</el-form>
</el-row>
<!-- 控件模块 -->
<el-row>
<div class="avue-crud__header">
<!-- 头部左侧按钮模块 -->
<div class="avue-crud__left">
<el-button type="primary" @click="exportReport">
<el-icon><Download /></el-icon></el-button
>
</div>
<!-- 头部右侧按钮模块 -->
<div class="avue-crud__right">
<el-button icon="el-icon-refresh" @click="searchChangeS" circle></el-button>
<el-button icon="Operation" @click="showdrawer(true)" circle></el-button>
<el-button icon="Search" @click="searchHide" circle></el-button>
</div>
</div>
</el-row>
<!-- 首页表格 -->
<el-row>
<!-- 列表模块 -->
<tablecmt
class="tableNode"
:columnList="columnList"
:tableData="data"
:loading="loadingObj.list"
@inputTxt="inputsc"
@timeCheck="timesc"
@btnCheck="btnsc"
@selectCheck="selectsc"
@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>
</tablecmt>
</el-row>
<!-- 分页模块 -->
<el-row class="el-fy">
<div class="avue-crud__pagination flex-c-sb" style="width: 100%">
<div></div>
<el-pagination
align="right"
background
@size-change="sizeChange"
@current-change="currentChange"
:current-page="page.currentPage"
:page-sizes="[30, 50, 80, 120]"
:page-size="page.pageSize"
layout="total, sizes, prev, pager, next, jumper"
:total="page.total"
>
</el-pagination>
</div>
</el-row>
</div>
</basic-container>
<!-- 列表配置显示 -->
<edittablehead
@setcolum="setnewcolum"
@closce="showdrawer"
:drawerShow="drawerShow"
:columnList="details.columnList"
></edittablehead>
</template>
<script setup>
import { ref, reactive, toRefs, computed, onMounted, nextTick, watch } from 'vue';
import { columnList } from '@/option/reportforms/InventoryReceipt.js';
import { getDictionaryBiz } from '@/api/system/dict'; //
import { processRowProperty, setNodeHeight } from '@/utils/util';
import { $_exportInStocks ,$_getinStocks} from '@/api/reportforms/index.js';
import { ElMessageBox } from 'element-plus';
import { downloadXls } from '@/utils/util';
import functions from '@/utils/functions.js';
import dayjs from 'dayjs';
const details = reactive({
/** 是否开启搜索 */
search: false,
/** 表格搜索条件 */
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];
},
},
],
/** 时间选择器数据 */
stockupDate: [],
/** 列表 */
columnList,
/** 列表数据 */
data: [],
/** 页面loading */
loadingObj: {
/** 列表加载loading */
list: false,
packageListLoading: false,
},
/** 列表复选框选中的数据 */
selectionList: [],
/** 是否显示设置表格 */
drawerShow: false,
/** 分页参数 */
page: {
currentPage: 1,
pageSize: 50,
total: 0,
},
/** 弹出层显示 */
popUpShow: {
/** 包件明细 */
packageOrderListlVisited: false,
/** 二维码 */
QRCodeVisible: false,
/** 修改客户信息 */
editClientInfoVisible: false,
},
/** 列表Dom节点 */
listNode: '',
form: {},
/** 全屏 */
fullscreenObj: {
/** 包明细 */
packageOrderListlVisited: false,
},
});
const {
search,
query,
shortcuts,
stockupDate,
data,
loadingObj,
selectionList,
drawerShow,
page,
trickleLoadingPage,
zeroAdditionalRecordingInfo,
popUpShow,
recorddata,
} = toRefs(details);
/**
* 设置列表 -- 固定函数
* 弹窗的勾选回调用于更改头部数组
* 固定搭配只需要更换 columnList
* */
const setnewcolum = (newarr, headarr, type) => {
if (type == 1) {
details.columnList = newarr;
functions.setStorage(window.location.pathname + 'checkList', headarr);
} else if (type == 2) {
details.columnList = newarr;
functions.setStorage(window.location.pathname + 'flexList', headarr);
} else if (type == 3) {
details.columnList = newarr;
functions.setStorage(window.location.pathname + 'sortlist', headarr);
}
};
/** 展开列表控件 */
const showdrawer = _flag => {
details.drawerShow = _flag;
};
/** 表格表头输入框搜索 */
const inputsc = (index, row) => {
details.query[row.prop] = index;
processRowProperty(index, row, details);
getrain();
};
/** 表格表头时间选择 */
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];
}
getrain();
};
/** 表格表头输入框搜索 */
const btnsc = val => {
console.log(val);
};
/** 表格表头下拉框选择 */
const selectsc = (index, row) => {
processRowProperty(index, row, details);
};
/** 表格表头复选框选择 */
const selectionChange = list => {
console.log(list);
details.selectionList = list;
};
//
const searchChange = () => {
details.search = false; //
};
//
const sizeChange = val => {
details.page.pageSize = val;
getrain();
};
/** 页码改变执行的回调 */
const currentChange = val => {
details.page.currentPage = val;
getrain();
};
//
const searchChangeS = () => {
details.columnList.forEach(item => {
item.values = '';
});
details.search = false; //
getrain();
};
//
const searchHide = () => {
console.log(details);
details.search = !details.search;
const _node = document.querySelector('.tableNode');
setNodeHeight(_node, '', true);
};
//
function updateDictionary(targetArray, dictionaryType) {
getDictionaryBiz(dictionaryType).then(res => {
console.log(res, '字典');
res.data.data.forEach(item => {
targetArray.push({
value: item.dictKey,
label: item.dictValue,
});
});
});
}
//
const onLoad = () => {
// updateDictionary(columnList[3].checkarr, 'pc_work_order'); //
};
onLoad();
//
const getrain = () => {
let data = {
current: details.page.currentPage,
size: details.page.pageSize,
...details.query,
};
details.loadingObj.list = true;
$_getinStocks(data)
.then(res => {
console.log(res, '当前参数1');
details.page.total = res.data.data.total;
details.data = res.data.data.records;
})
.catch(() => {})
.finally(() => {
details.loadingObj.list = false;
});
};
getrain();
//
const exportReport = () => {
ElMessageBox.confirm('是否导出报表?', {
confirmButtonText: '确定',
cancelButtonText: '取消',
type: 'warning',
})
.then(() => {
details.loadingObj.list = true;
let data = {
...details.query,
};
$_exportInStocks(data)
.then(res => {
downloadXls(res.data, `库存入库明细报表数据.xlsx`);
})
.catch(() => {
})
.finally(() => {
details.loadingObj.list = false;
})
})
.catch(() => {});
};
</script>
<style scoped lang="scss">
.ElBtnClass button {
border: none;
padding: 0;
background-color: transparent;
}
:deep(.el-card) {
height: 100%;
}
:deep(.el-card__body) {
height: 100%;
display: flex;
flex-direction: column;
}
.el-fy {
flex: 1;
display: flex;
align-items: flex-end;
margin-bottom: 10px;
}
.avue-crud {
height: 100%;
display: flex;
flex-direction: column;
}
</style>

366
src/views/reportforms/Selfpickupreport.vue

@ -0,0 +1,366 @@
<template>
<basic-container>
<!-- 首页表格 -->
<div class="avue-crud">
<!-- 搜索模块 -->
<el-row v-if="search">
<!-- 查询模块 -->
<el-form :inline="true" :model="query" class="el-fr-d">
<!-- 查询按钮 -->
<el-form-item class="el-btn">
<el-button type="primary" icon="el-icon-search" @click="searchChange"> </el-button>
<el-button icon="el-icon-delete" @click="searchReset()"> </el-button>
</el-form-item>
</el-form>
</el-row>
<!-- 控件模块 -->
<el-row>
<div class="avue-crud__header">
<!-- 头部左侧按钮模块 -->
<div class="avue-crud__left">
<el-button type="primary" @click="exportReport">
<el-icon><Download /></el-icon></el-button
>
</div>
<!-- 头部右侧按钮模块 -->
<div class="avue-crud__right">
<el-button icon="el-icon-refresh" @click="searchChangeS" circle></el-button>
<el-button icon="Operation" @click="showdrawer(true)" circle></el-button>
<el-button icon="Search" @click="searchHide" circle></el-button>
</div>
</div>
</el-row>
<!-- 首页表格 -->
<el-row>
<!-- 列表模块 -->
<tablecmt
class="tableNode"
:columnList="columnList"
:tableData="data"
:loading="loadingObj.list"
@inputTxt="inputsc"
@timeCheck="timesc"
@btnCheck="btnsc"
@selectCheck="selectsc"
@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>
</tablecmt>
</el-row>
<!-- 分页模块 -->
<el-row class="el-fy">
<div class="avue-crud__pagination flex-c-sb" style="width: 100%">
<div></div>
<el-pagination
align="right"
background
@size-change="sizeChange"
@current-change="currentChange"
:current-page="page.currentPage"
:page-sizes="[30, 50, 80, 120]"
:page-size="page.pageSize"
layout="total, sizes, prev, pager, next, jumper"
:total="page.total"
>
</el-pagination>
</div>
</el-row>
</div>
</basic-container>
<!-- 列表配置显示 -->
<edittablehead
@setcolum="setnewcolum"
@closce="showdrawer"
:drawerShow="drawerShow"
:columnList="details.columnList"
></edittablehead>
</template>
<script setup>
import { ref, reactive, toRefs, computed, onMounted, nextTick, watch } from 'vue';
import { columnList } from '@/option/reportforms/Selfpickupreport.js';
import { getDictionaryBiz } from '@/api/system/dict'; //
import { processRowProperty, setNodeHeight } from '@/utils/util';
import { $_getSelfpickup,$_exportSelfpickup } from '@/api/reportforms/index.js';
import { ElMessageBox } from 'element-plus';
import { downloadXls } from '@/utils/util';
import functions from '@/utils/functions.js';
import dayjs from 'dayjs';
const details = reactive({
/** 是否开启搜索 */
search: false,
/** 表格搜索条件 */
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];
},
},
],
/** 时间选择器数据 */
stockupDate: [],
/** 列表 */
columnList,
/** 列表数据 */
data: [],
/** 页面loading */
loadingObj: {
/** 列表加载loading */
list: false,
packageListLoading: false,
},
/** 列表复选框选中的数据 */
selectionList: [],
/** 是否显示设置表格 */
drawerShow: false,
/** 分页参数 */
page: {
currentPage: 1,
pageSize: 50,
total: 0,
},
/** 弹出层显示 */
popUpShow: {
/** 包件明细 */
packageOrderListlVisited: false,
/** 二维码 */
QRCodeVisible: false,
/** 修改客户信息 */
editClientInfoVisible: false,
},
/** 列表Dom节点 */
listNode: '',
form: {},
/** 全屏 */
fullscreenObj: {
/** 包明细 */
packageOrderListlVisited: false,
},
});
const {
search,
query,
shortcuts,
stockupDate,
data,
loadingObj,
selectionList,
drawerShow,
page,
trickleLoadingPage,
zeroAdditionalRecordingInfo,
popUpShow,
recorddata,
} = toRefs(details);
/**
* 设置列表 -- 固定函数
* 弹窗的勾选回调用于更改头部数组
* 固定搭配只需要更换 columnList
* */
const setnewcolum = (newarr, headarr, type) => {
if (type == 1) {
details.columnList = newarr;
functions.setStorage(window.location.pathname + 'checkList', headarr);
} else if (type == 2) {
details.columnList = newarr;
functions.setStorage(window.location.pathname + 'flexList', headarr);
} else if (type == 3) {
details.columnList = newarr;
functions.setStorage(window.location.pathname + 'sortlist', headarr);
}
};
/** 展开列表控件 */
const showdrawer = _flag => {
details.drawerShow = _flag;
};
/** 表格表头输入框搜索 */
const inputsc = (index, row) => {
details.query[row.prop] = index;
processRowProperty(index, row, details);
getrain();
};
/** 表格表头时间选择 */
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];
}
getrain();
};
/** 表格表头输入框搜索 */
const btnsc = val => {
console.log(val);
};
/** 表格表头下拉框选择 */
const selectsc = (index, row) => {
processRowProperty(index, row, details);
};
/** 表格表头复选框选择 */
const selectionChange = list => {
console.log(list);
details.selectionList = list;
};
//
const searchChange = () => {
details.search = false; //
};
//
const sizeChange = val => {
details.page.pageSize = val;
getrain();
};
/** 页码改变执行的回调 */
const currentChange = val => {
details.page.currentPage = val;
getrain();
};
//
const searchChangeS = () => {
details.columnList.forEach(item => {
item.values = '';
});
details.search = false; //
getrain();
};
//
const searchHide = () => {
console.log(details);
details.search = !details.search;
const _node = document.querySelector('.tableNode');
setNodeHeight(_node, '', true);
};
//
function updateDictionary(targetArray, dictionaryType) {
getDictionaryBiz(dictionaryType).then(res => {
console.log(res, '字典');
res.data.data.forEach(item => {
targetArray.push({
value: item.dictKey,
label: item.dictValue,
});
});
});
}
//
const onLoad = () => {
// updateDictionary(columnList[3].checkarr, 'pc_work_order'); //
};
onLoad();
//
const getrain = () => {
let data = {
current: details.page.currentPage,
size: details.page.pageSize,
...details.query,
};
details.loadingObj.list = true;
$_getSelfpickup(data)
.then(res => {
console.log(res, '当前参数');
details.page.total = res.data.data.total;
details.data = res.data.data.records;
})
.catch(() => {})
.finally(() => {
details.loadingObj.list = false;
});
};
getrain();
//
const exportReport = () => {
ElMessageBox.confirm('是否导出报表?', {
confirmButtonText: '确定',
cancelButtonText: '取消',
type: 'warning',
})
.then(() => {
details.loadingObj.list = true;
let data = {
...details.query,
};
$_exportSelfpickup(data)
.then(res => {
downloadXls(res.data, `自提明细报表数据.xlsx`);
})
.catch(() => {
})
.finally(() => {
details.loadingObj.list = false;
})
})
.catch(() => {});
};
</script>
<style scoped lang="scss">
.ElBtnClass button {
border: none;
padding: 0;
background-color: transparent;
}
:deep(.el-card) {
height: 100%;
}
:deep(.el-card__body) {
height: 100%;
display: flex;
flex-direction: column;
}
.el-fy {
flex: 1;
display: flex;
align-items: flex-end;
margin-bottom: 10px;
}
.avue-crud {
height: 100%;
display: flex;
flex-direction: column;
}
</style>
Loading…
Cancel
Save