<template>
|
<!--
|
描述:门店
|
-->
|
<div class="product">
|
<div style="display: flex;">
|
<div class="banner">
|
<p>门店数量</p>
|
<span>{{datahead[0]}}</span>
|
</div>
|
<div class="banner">
|
<p>上架门店(正常使用)</p>
|
<span>{{datahead[1]}}</span>
|
</div>
|
<div class="banner">
|
<p>昨日新增门店数量</p>
|
<span>{{datahead[2]}}</span>
|
</div>
|
<div class="banner">
|
<p>已过期门店数量</p>
|
<span>{{datahead[3]}}</span>
|
</div>
|
</div>
|
|
<div class="search">
|
<el-input v-model="search_name" style="width: 200px;" placeholder="门店名称"></el-input>
|
<!-- <el-input v-model="search_text" style="width: 200px;" placeholder="到期状态"></el-input> -->
|
<!-- <el-select v-model="search_text" placeholder="到期状态">
|
<el-option label="已过期"></el-option>
|
<el-option label="未过期"></el-option>
|
</el-select> -->
|
<el-select v-model="search_type" placeholder="请选择门店类型">
|
<el-option v-for="(dict,index) in type_dict" :label="dict.name" :value="dict.value" :key="index"></el-option>
|
</el-select>
|
<el-select v-model="search_status" placeholder="请选择状态">
|
<el-option v-for="(dict,index) in status_dict" :label="dict.name" :value="dict.value" :key="index"></el-option>
|
</el-select>
|
<el-input v-model="search_app_name" style="width: 200px;" placeholder="小程序名称"></el-input>
|
<el-button size="small" type="primary" @click="search">搜索</el-button>
|
<el-button size="small" type="primary" @click="reset">重置</el-button>
|
|
<el-upload
|
class="upload-demo"
|
:action="up_url"
|
:before-remove="beforeRemove"
|
multiple
|
:limit="1"
|
:on-exceed="handleExceed"
|
:file-list="fileList">
|
<el-button size="small" type="primary">上传图片</el-button>
|
</el-upload>
|
|
<!-- <el-button size="small" type="primary" @click="upload_img">点击上传</el-button> -->
|
</div>
|
|
<div class="common-level-rail"><el-button size="small" type="primary" @click="addClick">添加门店</el-button></div>
|
|
<!--内容-->
|
<div class="product-content">
|
<div class="table-wrap">
|
<el-table size="small" :data="tableData" border default-expand-all :tree-props="{ children: 'children' }" row-key="plus_id" v-loading="loading">
|
<el-table-column prop="store_name" label="门店名称"></el-table-column>
|
<el-table-column prop="expire_status" label="到期状态"></el-table-column>
|
<el-table-column prop="month_register" label="本月注册人数"></el-table-column>
|
<el-table-column prop="market_manager" label="市场经理"></el-table-column>
|
<el-table-column prop="store_type" label="门店类型"></el-table-column>
|
<el-table-column prop="status_name" label="状态"></el-table-column>
|
<el-table-column prop="store_app_name" label="小程序名称"></el-table-column>
|
<el-table-column prop="agent.agent_name" label="所属代理商"></el-table-column>
|
<el-table-column prop="register_date" label="注册时间"></el-table-column>
|
<el-table-column prop="end_date" label="到期时间"></el-table-column>
|
<el-table-column fixed="right" label="操作">
|
<template slot-scope="scope">
|
<el-button @click="editClick(scope.row)" type="text" size="small">编辑</el-button>
|
<el-button @click="deleteClick(scope.row)" type="text" size="small">删除</el-button>
|
</template>
|
</el-table-column>
|
</el-table>
|
</div>
|
</div>
|
|
<!--添加-->
|
<Add :dict='[type_dict,belonging_dict]' v-if="open_add" :open_add="open_add" @closeDialog="closeDialogFunc($event, 'add')"></Add>
|
<!--编辑-->
|
<Edit :dict='[status_dict,type_dict,belonging_dict]' v-if="open_edit" :open_edit="open_edit" :form="storeModel" @closeDialog="closeDialogFunc($event, 'edit')"></Edit>
|
<!--编辑-->
|
<Field v-if="open_field" :open_field="open_field" :form="storeModel" @closeDialog="closeDialogFunc($event, 'field')"></Field>
|
</div>
|
</template>
|
|
<script>
|
import StoreApi from '@/api/store.js';
|
import DictApi from '@/api/base_dict.js';
|
import LocalupApi from '@/api/local_upload.js';
|
import Edit from './dialog/Edit.vue';
|
import Add from './dialog/Add';
|
import Field from './dialog/Field';
|
import { deepClone } from '@/utils/base.js';
|
|
export default {
|
components: {
|
/*编辑组件*/
|
Edit: Edit,
|
Add: Add,
|
Field: Field
|
},
|
data() {
|
return {
|
loading: true,
|
/*切换选中值*/
|
activeIndex: '0',
|
/*横向表单数据模型*/
|
formInline: {
|
user: '',
|
region: ''
|
},
|
/*表格数据*/
|
tableData: [],
|
/*总条数*/
|
totalDataNumber: 0,
|
/*分类列表*/
|
categoryList: [],
|
/*是否打开添加弹窗*/
|
open_add: false,
|
/*是否打开编辑弹窗*/
|
open_edit: false,
|
/*当前编辑的对象*/
|
storeModel: {},
|
/*是否打开字段弹窗*/
|
open_field: false,
|
store_count:0,
|
|
search_name:'',//搜索内容
|
search_type:'',
|
search_status:'',
|
search_belonging:'',
|
search_app_name:'',
|
|
datahead:[],//页面头部panel数据
|
status_dict:[],
|
belonging_dict:[],
|
type_dict:[],
|
|
fileList: [],//上传图片数组
|
up_url:'/index.php/admin/admin.upload/local_image',
|
};
|
},
|
created() {
|
/*获取列表*/
|
this.getTableList();
|
this.get_dict();
|
},
|
|
methods: {
|
reset(){//重置搜索条件
|
let self = this;
|
self.search_name = '';
|
self.search_type = '';
|
self.search_status = '';
|
self.search_belonging = '';
|
self.search_app_name = '';
|
self.search();
|
},
|
|
handleExceed(files, fileList) {
|
this.$message.warning(`当前限制选择 1 个文件,本次选择了 ${files.length} 个文件,共选择了 ${files.length + fileList.length} 个文件`);
|
},
|
beforeRemove(file, fileList) {
|
return this.$confirm(`确定移除 ${ file.name }?`);
|
},
|
|
|
/*获取字典*/
|
get_dict() {
|
let self = this;
|
DictApi.get_dict(['门店状态','代理商','门店类型'], true)
|
.then(data => {
|
//console.log(data);
|
self.status_dict = data.data.dict[0];
|
self.belonging_dict = data.data.dict[1];
|
self.type_dict = data.data.dict[2];
|
})
|
.catch(error => {
|
self.loading = false;
|
});
|
},
|
/*搜索*/
|
search() {
|
let self = this;
|
let searchdata = [
|
self.search_name,
|
self.search_type,
|
self.search_status,
|
self.search_belonging,
|
self.search_app_name
|
];
|
console.log(searchdata);
|
self.loading = true;
|
StoreApi.search(searchdata, true)
|
.then(data => {
|
self.loading = false;
|
self.tableData = data.data.list;
|
})
|
.catch(error => {
|
self.loading = false;
|
});
|
},
|
/*获取列表*/
|
getTableList() {
|
let self = this;
|
let Params = {};
|
StoreApi.storeList(Params, true)
|
.then(data => {
|
self.loading = false;
|
self.tableData = data.data.list;
|
self.datahead = data.data.data;
|
self.totalDataNumber = data.data.list.total;
|
})
|
.catch(error => {
|
self.loading = false;
|
});
|
},
|
|
/*打开添加*/
|
addClick() {
|
this.open_add = true;
|
},
|
/*打开编辑*/
|
editClick(item) {
|
// this.storeModel = item;
|
this.storeModel = deepClone(item);
|
console.log(this.storeModel);
|
// this.storeModel.store_to = this.storeModel.store_to.value;
|
// this.storeModel.store_type = this.storeModel.store_type.value;
|
|
this.open_edit = true;
|
},
|
closeDialogFunc(e, f) {
|
if (f == 'add') {
|
this.open_add = e.openDialog;
|
if (e.type == 'success') {
|
this.getTableList();
|
}
|
}
|
if (f == 'edit') {
|
this.open_edit = e.openDialog;
|
if (e.type == 'success') {
|
this.getTableList();
|
}
|
}
|
if (f == 'field') {
|
this.open_field = e.openDialog;
|
if (e.type == 'success') {
|
this.getTableList();
|
}
|
}
|
},
|
/*删除记录*/
|
deleteClick(row) {
|
let self = this;
|
self
|
.$confirm('删除后不可恢复,确认删除该记录吗?', '提示', {
|
confirmButtonText: '确定',
|
cancelButtonText: '取消',
|
type: 'warning'
|
})
|
.then(() => {
|
self.loading = true;
|
StoreApi.deleteStore(
|
{
|
store_id: row.store_id
|
},
|
true
|
)
|
.then(data => {
|
self.loading = false;
|
self.$message({
|
message: data.msg,
|
type: 'success'
|
});
|
self.getTableList();
|
})
|
.catch(error => {
|
self.loading = false;
|
});
|
})
|
.catch(() => {});
|
}
|
|
}
|
};
|
</script>
|
<style>
|
.upload-demo{float: right;}
|
.banner{background-color: #dfdfdf;width: 25%;height: 90px;margin: 0 10px 10px 10px;border-radius: 10px;text-align: center;}
|
.banner p{font-size: 20px;padding-top: 20px;color: #409EFF;}
|
.banner span{font-size: 16px;}
|
.search{margin: 5px 0;}
|
</style>
|