|
|
|
|
<template>
|
|
|
|
|
<div>
|
|
|
|
|
<Row :gutter="32">
|
|
|
|
|
<i-col span="32">
|
|
|
|
|
<row>
|
|
|
|
|
<!--搜索、状态行-->
|
|
|
|
|
<row style="height: 73px;line-height: 73px;background: #F7F8FA">
|
|
|
|
|
<row>
|
|
|
|
|
<span class="left-15">选择日期</span>
|
|
|
|
|
<DatePicker v-model="dateRange" separator="至" class="left-10" type="daterange" placement="bottom-start" split-panels placeholder="请选择日期区间" style="width: 200px"></DatePicker>
|
|
|
|
|
<span style="margin: 0 10px">大区</span>
|
|
|
|
|
<Select filterable placeholder="请选择大区" v-model="regionId" @on-change="regionSelect" style="width:190px">
|
|
|
|
|
<Option v-for="item in regionList" :value="item.id" :key="item.id">{{ item.name }}</Option>
|
|
|
|
|
</Select>
|
|
|
|
|
<span style="margin: 0 10px">零售公司</span>
|
|
|
|
|
<Select filterable placeholder="请选择零售公司" v-model="companyId" @on-change="companySelect" style="width:190px">
|
|
|
|
|
<Option v-for="item in companyList" :value="item.id" :key="item.id">{{ item.name }}</Option>
|
|
|
|
|
</Select>
|
|
|
|
|
<span style="margin: 0 10px">客户</span>
|
|
|
|
|
<Select filterable placeholder="请选择客户" v-model="customerId" style="width:190px">
|
|
|
|
|
<Option v-for="item in customerList" :value="item.id" :key="item.id">{{ item.name }}</Option>
|
|
|
|
|
</Select>
|
|
|
|
|
<Button type="primary" style="width: 70px;margin-left: 20px" @click="searchBtnClick">查询</Button>
|
|
|
|
|
<Button type="primary" style="width: 90px;margin-left: 20px;" @click="exportZeroExtend">导出数据</Button>
|
|
|
|
|
</row>
|
|
|
|
|
</row>
|
|
|
|
|
<!--表格数据-->
|
|
|
|
|
<row style="margin-top: 30px">
|
|
|
|
|
<Table :columns="columns1" :data="data1" size="small"></Table>
|
|
|
|
|
<Spin style="top: 40px;height: 200px" size="large" fix v-if="spinShow"></Spin>
|
|
|
|
|
<Page :total="totalSize" :current="pageNum" :page-size="pageSize" show-elevator show-total
|
|
|
|
|
placement="top" @on-change="handlePage" style="margin-top: 20px;float: right"></Page>
|
|
|
|
|
</row>
|
|
|
|
|
</row>
|
|
|
|
|
</i-col>
|
|
|
|
|
</Row>
|
|
|
|
|
</div>
|
|
|
|
|
</template>
|
|
|
|
|
<script>
|
|
|
|
|
|
|
|
|
|
import zeroExtend from "../services/customer/zeroExtend";
|
|
|
|
|
export default {
|
|
|
|
|
inject:['checkParamBlank'],
|
|
|
|
|
data() {
|
|
|
|
|
return {
|
|
|
|
|
columns1: [
|
|
|
|
|
{
|
|
|
|
|
title: '序号',
|
|
|
|
|
width:'80px',
|
|
|
|
|
key: 'number',
|
|
|
|
|
align: 'center',
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
title: '店铺名称',
|
|
|
|
|
key: 'shopName',
|
|
|
|
|
align: 'left',
|
|
|
|
|
width:'300px',
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
title: '店铺编码',
|
|
|
|
|
key: 'shopCode',
|
|
|
|
|
align: 'left',
|
|
|
|
|
width:'150px',
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
title: '大区',
|
|
|
|
|
key: 'region',
|
|
|
|
|
align: 'left',
|
|
|
|
|
width:'200px',
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
title: '零售公司',
|
|
|
|
|
key: 'company',
|
|
|
|
|
width:'170px',
|
|
|
|
|
align: 'left',
|
|
|
|
|
},
|
|
|
|
|
{
|
|
|
|
|
title: '客户',
|
|
|
|
|
key: 'customer',
|
|
|
|
|
align: 'left',
|
|
|
|
|
},
|
|
|
|
|
],
|
|
|
|
|
|
|
|
|
|
userId: JSON.parse(sessionStorage.getItem("loginInfo")).userId,
|
|
|
|
|
//加载遮罩
|
|
|
|
|
spinShow: false,
|
|
|
|
|
//mainData
|
|
|
|
|
data1: [],
|
|
|
|
|
orginAllData: [],
|
|
|
|
|
|
|
|
|
|
//开始时间,结束时间
|
|
|
|
|
dateRange: [this.$route.query.startDate, this.$route.query.endDate],
|
|
|
|
|
//所有组织list
|
|
|
|
|
organizationalList: [],
|
|
|
|
|
//区域list
|
|
|
|
|
regionList: [],
|
|
|
|
|
regionId: 0,
|
|
|
|
|
//零售公司list
|
|
|
|
|
companyList: [],
|
|
|
|
|
companyId: 0,
|
|
|
|
|
//客户list
|
|
|
|
|
customerList: [],
|
|
|
|
|
customerId: 0,
|
|
|
|
|
|
|
|
|
|
totalSize: 0,
|
|
|
|
|
pageNum: 1,
|
|
|
|
|
pageSize: 15,
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
mounted: function () {
|
|
|
|
|
this.getSelectList();
|
|
|
|
|
this.getMainList();
|
|
|
|
|
},
|
|
|
|
|
methods: {
|
|
|
|
|
//格式化日期
|
|
|
|
|
formartDate: function(date, format, endFlag){
|
|
|
|
|
if(!date){
|
|
|
|
|
return null;
|
|
|
|
|
}
|
|
|
|
|
if(endFlag == null){
|
|
|
|
|
return this.$moment(date).format(format) + " 00:00:00";
|
|
|
|
|
}else{
|
|
|
|
|
return this.$moment(date).format(format) + " 23:59:59";
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
//区域选择
|
|
|
|
|
regionSelect: function(){
|
|
|
|
|
let regionId = this.regionId;
|
|
|
|
|
if(regionId === 0){
|
|
|
|
|
this.companyList = this.organizationalList.filter(item => item.level === 2);
|
|
|
|
|
this.customerList = this.organizationalList.filter(item => item.level === 3);
|
|
|
|
|
}else{
|
|
|
|
|
this.companyList = this.organizationalList.filter(item => item.parentId === regionId && item.level === 2);
|
|
|
|
|
let companyIds = this.companyList.map(item => item.id);
|
|
|
|
|
this.customerList = this.organizationalList.filter(item => companyIds.indexOf(item.parentId) !== -1 && item.level === 3);
|
|
|
|
|
}
|
|
|
|
|
this.insertAllOption();
|
|
|
|
|
this.companyId = 0;
|
|
|
|
|
this.customerId = 0;
|
|
|
|
|
},
|
|
|
|
|
//零售公司选择
|
|
|
|
|
companySelect: function(){
|
|
|
|
|
let companyId = this.companyId;
|
|
|
|
|
if(companyId === 0){
|
|
|
|
|
let companyIds = this.companyList.map(item => item.id);
|
|
|
|
|
this.customerList = this.organizationalList.filter(item => companyIds.indexOf(item.parentId) !== -1 && item.level === 3);
|
|
|
|
|
}else{
|
|
|
|
|
this.customerList = this.organizationalList.filter(item => item.parentId === companyId && item.level === 3);
|
|
|
|
|
}
|
|
|
|
|
this.insertAllOption();
|
|
|
|
|
this.customerId = 0;
|
|
|
|
|
},
|
|
|
|
|
//插入全部选项
|
|
|
|
|
insertAllOption: function(){
|
|
|
|
|
if(this.regionList.length === 0 || this.regionList[0].id !== 0){
|
|
|
|
|
this.regionList.splice(0,0, {"id":0, "name":"全部"});
|
|
|
|
|
}
|
|
|
|
|
if(this.companyList.length === 0 || this.companyList[0].id !== 0){
|
|
|
|
|
this.companyList.splice(0, 0, {"id":0, "name":"全部"});
|
|
|
|
|
}
|
|
|
|
|
if(this.customerList.length === 0 || this.customerList[0].id !== 0){
|
|
|
|
|
this.customerList.splice(0, 0, {"id":0, "name":"全部"});
|
|
|
|
|
}
|
|
|
|
|
},
|
|
|
|
|
//查询按钮
|
|
|
|
|
searchBtnClick: function(){
|
|
|
|
|
this.pageNum = 1;
|
|
|
|
|
this.getMainList();
|
|
|
|
|
},
|
|
|
|
|
//零推广导出
|
|
|
|
|
exportZeroExtend: function(){
|
|
|
|
|
let title = "0推广店铺";
|
|
|
|
|
if(this.dateRange[0]){
|
|
|
|
|
let start = this.$moment(this.dateRange[0]).format("YYYY-MM-DD");
|
|
|
|
|
let end = this.$moment(this.dateRange[1]).format("YYYY-MM-DD");
|
|
|
|
|
title += "(" + start + "至" + end + ")";
|
|
|
|
|
}
|
|
|
|
|
this.originAllData = [];
|
|
|
|
|
let that = this;
|
|
|
|
|
let request = {
|
|
|
|
|
userId: that.userId,
|
|
|
|
|
pageNum : 1,
|
|
|
|
|
pageSize : that.totalSize,
|
|
|
|
|
regionId : that.regionId === 0 ? null : that.regionId,
|
|
|
|
|
companyId : that.companyId === 0 ? null : that.companyId,
|
|
|
|
|
customerId : that.customerId === 0 ? null : that.customerId,
|
|
|
|
|
startTime : this.formartDate(that.dateRange[0], "YYYY-MM-DD"),
|
|
|
|
|
endTime : this.formartDate(that.dateRange[1], "YYYY-MM-DD", true),
|
|
|
|
|
};
|
|
|
|
|
zeroExtend.getMainRequest(request,function (data) {
|
|
|
|
|
if(data.data.code !== "0000"){
|
|
|
|
|
that.$Message.error("系统异常");
|
|
|
|
|
}
|
|
|
|
|
data = data.data.results;
|
|
|
|
|
if(data && data.length > 0){
|
|
|
|
|
that.totalSize = data[0].totalSize;
|
|
|
|
|
for(let i=0;i<data.length;i++){
|
|
|
|
|
let entity = data[i];
|
|
|
|
|
that.originAllData.push(entity);
|
|
|
|
|
}
|
|
|
|
|
require.ensure([], () => {
|
|
|
|
|
const { export_json_to_excel } = require('../excel/Export2Excel');
|
|
|
|
|
const tHeader = ['序号', '店铺名称', '店铺编码', '大区', '零售公司', '客户'];
|
|
|
|
|
// 属性名
|
|
|
|
|
const filterVal = ['number', 'shopName', 'shopCode', 'region', 'company', 'customer'];
|
|
|
|
|
// 数据
|
|
|
|
|
const list = that.originAllData; //把data里的tableData存到list
|
|
|
|
|
const data = that.formatJson(filterVal, list);
|
|
|
|
|
export_json_to_excel(tHeader, data, title);
|
|
|
|
|
});
|
|
|
|
|
}
|
|
|
|
|
if(data && data.length === 0){
|
|
|
|
|
that.$Message.info("暂无数据");
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
},
|
|
|
|
|
formatJson(filterVal, jsonData) {
|
|
|
|
|
return jsonData.map(v => filterVal.map(j => v[j]))
|
|
|
|
|
},
|
|
|
|
|
/**mainList数据*/
|
|
|
|
|
getMainList: function () {
|
|
|
|
|
this.data1 = [];
|
|
|
|
|
let that = this;
|
|
|
|
|
let request = {
|
|
|
|
|
userId: that.userId,
|
|
|
|
|
pageNum : that.pageNum,
|
|
|
|
|
pageSize : that.pageSize,
|
|
|
|
|
regionId : that.regionId === 0 ? null : that.regionId,
|
|
|
|
|
companyId : that.companyId === 0 ? null : that.companyId,
|
|
|
|
|
customerId : that.customerId === 0 ? null : that.customerId,
|
|
|
|
|
startTime : this.formartDate(that.dateRange[0], "YYYY-MM-DD"),
|
|
|
|
|
endTime : this.formartDate(that.dateRange[1], "YYYY-MM-DD", true),
|
|
|
|
|
};
|
|
|
|
|
//加载遮罩
|
|
|
|
|
this.spinShow = true;
|
|
|
|
|
zeroExtend.getMainRequest(request,function (data) {
|
|
|
|
|
that.data1 = [];
|
|
|
|
|
that.spinShow = false;
|
|
|
|
|
if(data.data.code !== "0000"){
|
|
|
|
|
that.$Message.error("系统异常");
|
|
|
|
|
}
|
|
|
|
|
data = data.data.results;
|
|
|
|
|
if(data && data.length > 0){
|
|
|
|
|
that.totalSize = data[0].totalSize;
|
|
|
|
|
for(let i=0;i<data.length;i++){
|
|
|
|
|
let entity = data[i];
|
|
|
|
|
that.data1.push(entity);
|
|
|
|
|
//null改--
|
|
|
|
|
that.checkParamBlank(entity);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
if(data == null || data.length === 0){
|
|
|
|
|
that.totalSize = 0;
|
|
|
|
|
}
|
|
|
|
|
});
|
|
|
|
|
|
|
|
|
|
},
|
|
|
|
|
/**基础数据:区域list、零售公司list、客户list*/
|
|
|
|
|
getSelectList:function(){
|
|
|
|
|
let that = this;
|
|
|
|
|
let request = {
|
|
|
|
|
userId: this.userId,
|
|
|
|
|
};
|
|
|
|
|
zeroExtend.getSelectListRequest(request,function (data) {
|
|
|
|
|
if(data.data.code !== "0000"){
|
|
|
|
|
that.$Message.error("系统异常");
|
|
|
|
|
}
|
|
|
|
|
data = data.data.results;
|
|
|
|
|
if(data){
|
|
|
|
|
that.organizationalList = data;
|
|
|
|
|
that.regionList = that.organizationalList.filter(item => item.level === 1);
|
|
|
|
|
that.companyList = that.organizationalList.filter(item => item.level === 2);
|
|
|
|
|
that.customerList = that.organizationalList.filter(item => item.level === 3);
|
|
|
|
|
}
|
|
|
|
|
//插入全部选项
|
|
|
|
|
that.insertAllOption();
|
|
|
|
|
});
|
|
|
|
|
},
|
|
|
|
|
//切页处理
|
|
|
|
|
handlePage: function (value) {
|
|
|
|
|
this.pageNum = value;
|
|
|
|
|
this.getMainList();
|
|
|
|
|
sessionStorage.setItem("hisOrderPageNum", this.pageNum)
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
</script>
|
|
|
|
|
|
|
|
|
|
<style scoped>
|
|
|
|
|
|
|
|
|
|
.top-10{
|
|
|
|
|
margin-top: 10px;
|
|
|
|
|
}
|
|
|
|
|
.left-10{
|
|
|
|
|
margin-left: 10px;
|
|
|
|
|
}
|
|
|
|
|
.left-15{
|
|
|
|
|
margin-left: 15px;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
</style>
|