Browse Source

配送详情导出

dev-xx
马远东 1 year ago
parent
commit
935f623bbb
  1. 125
      src/views/distribution/deliverylist/distributionDeliveryListedt.vue
  2. 107
      src/views/distribution/reservation/atlas.vue
  3. 235
      src/views/distribution/signfor/distributionSignforedt.vue

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

@ -128,6 +128,11 @@
<!-- </div>-->
<!-- </div>-->
<!-- </el-row>-->
<el-button type="warning"
plain
icon="el-icon-download"
@click="handleExport">
</el-button>
<el-tabs
v-model="activeTab"
@tab-click="handleTabClick"
@ -902,6 +907,10 @@ import {
$_showInventoryPackgeCode,
} from '@/api/distribution/distributionDeliveryList';
import { showOrderPackgeCode } from '@/api/distribution/distributionStockArticle';
import { exportBlob } from '@/api/common';
import { downloadXls } from '@/utils/util';
import { dateNow } from '@/utils/date';
import NProgress from 'nprogress';
import { showInventoryPackgeCode } from '@/api/distribution/distributionStockList';
import {
update as updatesign,
@ -1541,17 +1550,17 @@ export default {
sortable: true,
head: false,
},
{
prop: 'pallet',
label: '托盘码',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
// {
// prop: 'pallet',
// label: '',
// type: 2,
// values: '',
// width: '150',
// checkarr: [],
// fixed: false,
// sortable: true,
// head: false,
// },
// {
// prop: 'goodsAllocation',
// label: '',
@ -1700,16 +1709,16 @@ export default {
fixed: false,
sortable: true,
},
{
prop: 'materialName',
label: '物品名称',
type: 2,
values: '',
width: '180',
checkarr: [],
fixed: false,
sortable: true,
},
// {
// prop: 'materialName',
// label: '',
// type: 2,
// values: '',
// width: '180',
// checkarr: [],
// fixed: false,
// sortable: true,
// },
{
prop: 'sendWarehouseName',
@ -1773,17 +1782,17 @@ export default {
fixed: false,
sortable: true,
},
{
prop: 'fahuoTime',
label: '发货时间',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
// {
// prop: 'fahuoTime',
// label: '',
// type: 1,
// values: '',
// width: '150',
// checkarr: [],
// fixed: false,
// sortable: true,
// head: false,
// },
{
prop: 'warehouseEntryTimeEnd',
label: '入库时间',
@ -1864,7 +1873,7 @@ export default {
label: '包件数量',
type: 1,
values: '',
width: '40',
width: '120',
checkarr: [],
fixed: false,
sortable: true,
@ -1875,7 +1884,7 @@ export default {
label: '计划数量',
type: 1,
values: '',
width: '40',
width: '120',
checkarr: [],
fixed: false,
sortable: true,
@ -1885,7 +1894,7 @@ export default {
label: '装车数量',
type: 1,
values: '',
width: '40',
width: '120',
checkarr: [],
fixed: false,
sortable: true,
@ -1895,7 +1904,7 @@ export default {
label: '签收数量',
type: 1,
values: '',
width: '40',
width: '120',
checkarr: [],
fixed: false,
sortable: true,
@ -1991,7 +2000,7 @@ export default {
},
{
prop: 'orderCode',
label: '订单自编码',
label: '服务号',
type: 2,
values: '',
width: '150',
@ -2077,17 +2086,17 @@ export default {
sortable: true,
head: false,
},
{
prop: 'loadingStatusName',
label: '装车状态',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
// {
// prop: 'loadingStatusName',
// label: '',
// type: 2,
// values: '',
// width: '150',
// checkarr: [],
// fixed: false,
// sortable: true,
// head: false,
// },
{
prop: 'reservationNum',
label: '计划出库数',
@ -4028,6 +4037,26 @@ export default {
searchHide() {
this.search = !this.search;
},
//
handleExport() {
let downloadUrl = `/logpm-distribution/deliveryList/export-distributionDeliveryListDetail?${
this.website.tokenHeader
}=${getToken()}`;
let values = {
deliveryId:this.deliveryId
};
this.$confirm('是否导出数据?', '提示', {
confirmButtonText: '确定',
cancelButtonText: '取消',
type: 'warning',
}).then(() => {
NProgress.start();
exportBlob(downloadUrl, values).then(res => {
downloadXls(res.data, `配送详情${dateNow()}.xlsx`);
NProgress.done();
});
});
},
searchChange() {
this.onLoad(this.page);
},

107
src/views/distribution/reservation/atlas.vue

@ -1,13 +1,13 @@
<template>
<basic-container>
<div class="avue-crud">
<basic-container >
<div class="avue-crud" v-loading="Dtloading" element-loading-text="数据正在加载中...">
<div class="mabxmp">
<div class="mapbox">
<div class="bmap" id="container"></div>
</div>
<div class="maplists">
<el-scrollbar>
<div class="mbx">
<div class="mbx" >
<el-checkbox
v-for="item in datalists"
v-model="item.isck"
@ -17,20 +17,16 @@
size="large"
@change="ListChange"
/>
<!-- <el-text class="mx-1 txbx" type="primary">
{{ item.content }}--时间:{{ item.time }}--距离:{{ item.distance }}公里({{
item.items.handQuantity
}})
</el-text> -->
</div>
</el-scrollbar>
<span class="txbxSpan">当前总条数:{{datalists.length}}&emsp;&emsp;当前勾选条数:{{Checkthebox.length}}</span>
</div>
</div>
<div style="display: flex; align-items: center; justify-content: center">
<el-button @click="checkgoto">确认(转配送)</el-button>
<el-button icon="el-icon-circle-close" @click="back"> </el-button>
</div>
</div>
</div>
</basic-container>
</template>
@ -40,11 +36,10 @@ import { getReservationAddr } from '@/api/distribution/distributionReservation';
import { getDictionaryBiz } from '@/api/system/dict';
import { onMounted, reactive, toRefs, watchEffect } from 'vue';
import { useRouter } from 'vue-router';
import { selectStockArticleAtlasInfo } from '@/api/distribution/distributionDeliveryList';
import { ElMessage } from 'element-plus';
// import { getReservationAddr } from '@/api/distribution/distributionReservation';
let router = useRouter();
let useStores = useStore();
const Dtloading = ref(true);
let details = reactive({
name: 'BmapDemo',
item: null,
@ -61,6 +56,7 @@ let details = reactive({
drivingarrs: [],
// datalist:[]
});
const Checkthebox=ref([]);
onMounted(() => {
initmap();
});
@ -69,14 +65,10 @@ watchEffect(() => {
details.item = router.currentRoute.value.query.id;
if (!details.item) return;
getReservationAddr(details.item).then(res => {
// selectStockArticleAtlasInfo(details.item.id).then(res => {
console.log(res.data.data);
console.log(res.data.data,'参数接受的');
Checkthebox.value = res.data.data;//
const data = res.data.data;
// details.lng = res.data.data[0].jingdu;
// details.lat = res.data.data[0].weidu;
// details.abbreviation=res?.data?.data[0]?.warehouseName
// console.log('res------------->', data);
details.reservationData = data;
details.reservationData = res.data.data;
details.mapLoc.remove(details.markersarr);
details.drivingarrs.map(item => {
if (item) {
@ -84,12 +76,10 @@ watchEffect(() => {
}
});
details.drivingarrs = [];
details.datalists = [];
init(data);
// details.datalists = [];
init(res.data.data);
Dtloading.value=false
});
// setTimeout(() => {
// init();
// }, 5000);
});
function initmap() {
AMap.plugin('AMap.Geocoder', function () {
@ -123,13 +113,14 @@ function checkgoto() {
useStores.commit('DEL_TAG_CURRENT');
}
async function init(data) {
await details.mapLoc.clearMap();//
await details.mapLoc.clearMap(); //
// maplabel()
console.log(details.mapLoc);
let geocodess = [];
var geocoder = new AMap.Geocoder({});
data.map(async (item, index) => {
if (!item.jingdu || !item.weidu) {
console.log(item.jingdu);
return ElMessage.warning('地址有问题');
}
var marker = new AMap.Marker({
@ -139,15 +130,17 @@ async function init(data) {
anchor: 'bottom-center',
offset: new AMap.Pixel(0, 0),
});
await marker.setMap(details.mapLoc);
await marker.setLabel({
await marker.setMap(details.mapLoc);
await marker.setLabel({
offset: new AMap.Pixel(0, -5), //
content: `<div class='info'>${item.warehouseName}</div>`, //
direction: 'top', //
});
details.markersarr=[]
// details.markersarr=[]//
details.markersarr.push(marker);
await geocoder.getLocation(item.deliveryAddress, (status, result) => {
console.log(status,'status');
console.log(result,'result');
if (status === 'complete' && result.info === 'OK') {
// result
details.mapLoc.setCenter([
@ -168,25 +161,26 @@ async function init(data) {
});
}
//
function maker (geocodess) {
function maker(geocodess) {
geocodess.map(item => {
var marker = new AMap.Marker({
map: details.mapLoc,
position: item.pontion,
icon: '//a.amap.com/jsapi_demos/static/demo-center/icons/poi-marker-default.png',
anchor: 'bottom-center',
offset: new AMap.Pixel(0, 0),
});
marker.setMap(details.mapLoc);
marker.setLabel({
offset: new AMap.Pixel(0, -5), //
content: `<div class='info'>${item.content}</div>`, //
direction: 'top', //
});
details.markersarr.push(marker);
if (item.pontion) {
console.log(item, 'item=====');
var marker = new AMap.Marker({
map: details.mapLoc,
position: item.pontion,
icon: '//a.amap.com/jsapi_demos/static/demo-center/icons/poi-marker-default.png',
anchor: 'bottom-center',
offset: new AMap.Pixel(0, 0),
});
marker.setMap(details.mapLoc);
marker.setLabel({
offset: new AMap.Pixel(0, -5), //
content: `<div class='info'>${item.content}</div>`, //
direction: 'top', //
});
details.markersarr.push(marker);
}
});
}
//
// seenIds
@ -208,8 +202,8 @@ function Driving(geocodess) {
item.distance = result.routes[0].distance / 1000;
item.isck = true;
// item.distance=result.routes[0].distance/1000
// push seenIds
if (!seenIds.hasOwnProperty(item.items.id)) {
// push seenIds
if (!seenIds.hasOwnProperty(item.items.id)) {
item.time = formatSeconds(result.routes[0].time);
item.distance = result.routes[0].distance / 1000;
item.isck = true;
@ -242,14 +236,14 @@ function back() {
router.back(-1);
}
const { datalists } = toRefs(details);
const ListChange= (val)=>{
console.log(details.datalists,'最新的数据');
let data = details.datalists
.filter(item => item.isck === true)
.map(item => item.items);
init(data)
console.log(details.datalists,'数据');
}
const ListChange = val => {
console.log(val,'val====');
console.log(details.datalists, '最新的数据');
let data = details.datalists.filter(item => item.isck === true).map(item => item.items);
init(data);
Checkthebox.value = data;//
console.log(details.datalists, '数据');
};
</script>
<style lang="scss" scoped>
@ -285,4 +279,9 @@ console.log(details.datalists,'数据');
box-sizing: border-box;
width: 100%;
}
.txbxSpan{
color: #d3832a;
border-bottom: 1px solid;
padding: 0 4px;
}
</style>

235
src/views/distribution/signfor/distributionSignforedt.vue

@ -370,7 +370,7 @@
<el-collapse-item title="商品信息" name="1">
<el-tabs
v-loading="editLoading"
element-loading-text="数据正在更新中..."
element-loading-text="加载中..."
type="border-card"
@tab-click="tabClick"
>
@ -409,7 +409,7 @@
<el-collapse-item title="增值服务信息" name="2">
<el-tabs
v-loading="ZCeditLoading"
element-loading-text="数据正在更新中..."
element-loading-text="加载中..."
type="border-card"
@tab-click="tabClickB"
>
@ -566,7 +566,7 @@
style="width: 100%"
ref="tableRefs"
v-loading="TCeditLoading"
element-loading-text="数据正在更新中..."
element-loading-text="加载中..."
@select-all="selectAll"
@select="selectChange"
>
@ -792,12 +792,14 @@ const TabTitle = ref([
]);
//
const menuData1 = ref([
{
prop: 'orderCode',
label: '订单自编号',
prop: 'waybillNumber',
label: '运单号',
type: 2,
values: '',
width: '130',
width: '150',
checkarr: [],
fixed: true,
sortable: true,
@ -815,11 +817,11 @@ const menuData1 = ref([
head: false,
},
{
prop: 'waybillNumber',
label: '运单号',
prop: 'orderCode',
label: '订单自编号',
type: 2,
values: '',
width: '150',
width: '130',
checkarr: [],
fixed: true,
sortable: true,
@ -909,19 +911,8 @@ const menuData1 = ref([
head: false,
},
{
prop: 'mallName',
label: '商场名称',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'storeName',
label: '门店名称',
prop: 'consigneeUnit',
label: '收货单位',
type: 2,
values: '',
width: '150',
@ -930,10 +921,9 @@ const menuData1 = ref([
sortable: true,
head: false,
},
{
prop: 'descriptionGoods',
label: '货物名称',
prop: 'mallName',
label: '商场名称',
type: 2,
values: '',
width: '150',
@ -943,20 +933,8 @@ const menuData1 = ref([
head: false,
},
{
prop: 'reservationNum',
label: '计划包件数',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
isshowSummary: true,
head: false,
},
{
prop: 'consigneeUnit',
label: '收货单位',
prop: 'storeName',
label: '门店名称',
type: 2,
values: '',
width: '150',
@ -987,6 +965,8 @@ const menuData1 = ref([
sortable: true,
head: false,
},
{
prop: 'consigneeMobile',
label: '运单收货电话',
@ -1031,6 +1011,33 @@ const menuData1 = ref([
sortable: true,
head: false,
},
{
prop: 'descriptionGoods',
label: '货物名称',
type: 2,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'reservationNum',
label: '计划包件数',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
isshowSummary: true,
head: false,
},
]);
//
//
@ -1152,75 +1159,6 @@ const menuData2 = ref([
sortable: true,
head: false,
},
{
prop: 'loadingTime',
label: '装车时间',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'signingUser',
label: '签收人',
type: 1,
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: 'reservationNum',
label: '计划数量',
type: 1,
values: '',
width: '40',
checkarr: [],
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'loadingNub',
label: '装车数量',
type: 1,
values: '',
width: '40',
checkarr: [],
fixed: false,
sortable: true,
isshowSummary: true,
head: false,
},
{
prop: 'signingNub',
label: '签收数量',
type: 1,
values: '',
width: '40',
checkarr: [],
fixed: false,
sortable: true,
isshowSummary: true,
head: false,
},
{
prop: 'firsts',
label: '一级品类',
@ -1276,7 +1214,7 @@ const menuData2 = ref([
sortable: true,
head: false,
},
// {
// {
// prop: 'orderPackageGroundingStatusName',
// label: '',
// type: 1,
@ -1320,6 +1258,81 @@ const menuData2 = ref([
sortable: true,
head: false,
},
{
prop: 'reservationNum',
label: '计划数量',
type: 1,
values: '',
width: '40',
checkarr: [],
fixed: false,
sortable: true,
head: false,
isshowSummary: true,
},
{
prop: 'loadingNub',
label: '装车数量',
type: 1,
values: '',
width: '40',
checkarr: [],
fixed: false,
sortable: true,
isshowSummary: true,
head: false,
},
{
prop: 'signingNub',
label: '签收数量',
type: 1,
values: '',
width: '40',
checkarr: [],
fixed: false,
sortable: true,
isshowSummary: true,
head: false,
},
{
prop: 'loadingTime',
label: '装车时间',
type: 1,
values: '',
width: '150',
checkarr: [],
fixed: false,
sortable: true,
head: false,
},
{
prop: 'signingUser',
label: '签收人',
type: 1,
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: 'scanStatus',
label: '装车方式',
@ -2171,7 +2184,7 @@ const Signforexport = () => {
downloadXls(res.data, `订单列表.xlsx`);
ElMessage({
type: 'success',
message: res.data.msg,
message: '导出成功',
});
})
.catch(() => {})
@ -2187,7 +2200,7 @@ const Signforexport = () => {
downloadXls(res.data, `包件列表.xlsx`);
ElMessage({
type: 'success',
message: res.data.msg,
message: '导出成功',
});
})
.catch(() => {})

Loading…
Cancel
Save