You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
bsdgy-front/src/pages/user/AccountManager.vue

331 lines
13 KiB
Vue

6 years ago
<template>
<div style="margin-top: 20px;margin-left: 20px">
<template>
<Row style="background-color: #F7F8FA;line-height: 80px;">
<span style="margin-left: 20px">账户名</span>
<i-input placeholder="搜索用户名/账户" style="width: 10%;margin-left: 10px;" v-model="searchContent"/>
6 years ago
<span style=";margin-left: 20px;">角色</span>
<Select filterable placeholder="请选择角色" v-model="changeRoleId" class="left-15"
style="width:190px;margin-left: 10px;">
6 years ago
<Option v-for="item in roleList" :value="item.id" :key="item.id">{{ item.name }}</Option>
</Select>
<span style=";margin-left: 20px;">店铺</span>
<Select filterable placeholder="请选择店铺" v-model="changeShopId" class="left-15"
style="width:190px;margin-left: 10px;">
<Option v-for="item in shopList" :value="item.id" :key="item.name">{{ item.name }}</Option>
6 years ago
</Select>
<Button type="primary" style="margin-left: 30px" @click="listAccountInfoFunction"></Button>
<Button type="primary" style="margin-bottom: 20px;margin-right: 20px;float:right;margin-top: 25px"
@click="addOneAccount()">+添加账户
</Button>
<Button type="primary" ghost style="margin-bottom: 20px;margin-right: 20px;float:right;margin-top: 25px"
@click="uploadAccount">批量导入账户
</Button>
6 years ago
</Row>
</template>
<Table :columns="columns1" :data="data1" style="margin-top: 30px"></Table>
6 years ago
<Page :total="totalSize" :current="pageNum" :page-size="pageSize" show-elevator show-total
placement="top" style="float: right;margin-top: 20px"></Page>
<Modal
v-model="modal13"
title="删除提示"
@on-cancel="cancel" align="center">
<p style="margin-top: 20px;margin-bottom: 20px">确定要删除此账户吗删除后不可恢复</p>
<div slot="footer" style="text-align: center;margin-bottom: 10px;margin-top: 10px">
<Button style="width: 100px;" @click="modal13 = false">取消删除</Button>
<Button type="error" style="width: 100px;margin-left: 20px" @click="ok"></Button>
</div>
</Modal>
6 years ago
</div>
</template>
<script>
import accountManagement from "../../services/account/AccountManagement";
6 years ago
export default {
data() {
6 years ago
return {
modal13: false,
roleList: [
6 years ago
{
id: '1',
name: '系统管理员',
},
{
id: '2',
name: '运营人员',
},
{
id: '3',
name: '店长',
},
{
id: '4',
name: '导购',
},
],
shopList: [
6 years ago
{
shopId: '1',
shopName: '店铺1',
},
{
shopId: '2',
shopName: '店铺2',
},
],
columns1: [
{
type: 'index',
width: 80,
title: "序号",
align: 'center'
},
{
title: '用户名',
6 years ago
key: 'userName',
width: '150px'
6 years ago
},
{
title: '系统账号',
key: 'account',
width: '150px',
6 years ago
},
{
title: '系统角色',
key: 'roleName',
width: '150px'
6 years ago
},
{
title: '可见店铺',
key: 'shopName',
width: '200px'
6 years ago
},
{
title: '操作',
key: 'operation',
render: (h, params) => {
let that = this;
6 years ago
return h('div', [
h('span', {
style: {
background: 'white',
border: '0',
color: '#3496EB',
marginRight: '15px',
cursor: 'pointer'
},
on: {
click: () => {
this.$router.push({
path: '/account/management/modify',
query: {
accountId: params.row.accountId,
userId: params.row.userId,
userName: params.row.userName,
account: params.row.account,
password: params.row.password,
confirmPassword: params.row.confirmPassword,
roleId: params.row.roleId,
roleCode: params.row.roleCode,
shopId: params.row.shopId,
}
});
6 years ago
}
}
}, '修改'),
h('span', {
style: {
background: 'white',
border: '0',
color: 'red',
marginRight: '15px',
cursor: 'pointer'
},
on: {
click: () => {
that.modal13 = true;
that.updateAccountId = that.data1[params.index].accountId;
that.updateUserId = that.data1[params.index].userId;
6 years ago
}
}
}, '删除')
])
}
},
],
data1: [
{
userName: "何永东",
userCode: "7833",
roleName: "系统管理员",
shopName: "全部",
6 years ago
}
],
roleId: '',
shopId: '',
6 years ago
//分页内容
totalSize: 0,
pageNum: 1,
pageSize: 20,
6 years ago
//搜索内容
searchContent: null,
changeShopId: null,
changeRoleId: null,
updateAccountId: 0,
updateUserId: 0,
item: null,
6 years ago
}
},
mounted: function () {
this.listRoleInfo();
this.listOfShop();
if (this.$route.query != null) {
6 years ago
this.item = this.$route.query;
6 years ago
//别的页面跳转过来
this.changeRoleId = this.item.id;
6 years ago
this.bus.$emit('callBack');
6 years ago
}
this.listAccountInfoFunction();
},
methods: {
//切页处理
handlePage: function (value) {
this.pageNum = value;
this.listAccountInfoFunction();
},
6 years ago
//添加单个账户
addOneAccount() {
this.$router.push({
path: '/account/management/add',
});
6 years ago
},
//导入账户
uploadAccount() {
this.$router.push({path: '/account/upload'});
},
//查询所有角色
listRoleInfo() {
let that = this;
that.roleList = [];
accountManagement.listRoleInfoApi({}, function (data) {
data = data.data;
if (data.code === '0001') {
that.$Message.error("查询角色失败!");
return;
}
if (data.code === '0000') {
data = data.results;
for (let i = 0; i < data.length; i++) {
let row = data[i];
that.roleList.push(row);
}
}
})
},
//查询所有店铺
listOfShop() {
let that = this;
that.shopList = [];
let request = {
userId: JSON.parse(sessionStorage.getItem("loginInfo")).userId
};
accountManagement.listAllShopApi(request, function (data) {
data = data.data;
if (data.code === '0001') {
that.$Message.error("查询店铺失败!");
return;
}
if (data.code === '0000') {
data = data.results;
for (let i = 0; i < data.length; i++) {
let row = data[i];
that.shopList.push(row);
}
}
})
},
//搜索账号内容
listAccountInfoFunction: function () {
let that = this;
that.data1 = [];
let request = {
searchContent: that.searchContent,
pageNum: that.pageNum,
pageSize: that.pageSize,
roleId: that.changeRoleId,
shopId: that.changeShopId
};
accountManagement.listAccountInfoApi(request, function (data) {
data = data.data;
if (data.code === '0001') {
that.$Message.error("系统繁忙!");
return
}
if (data.code === '0000') {
if (data) {
let row = data.results.records;
that.totalSize = data.results.total;
for (let i = 0; i < row.length; i++) {
let entity = row[i];
if (!entity.channel) {
entity.channel = '--';
}
if (!entity.account) {
entity.account = '--';
}
if (!entity.userName) {
entity.userName = '--';
}
if (!entity.roleName) {
entity.roleName = '--';
}
if (!entity.shopName) {
entity.shopName = '--';
}
that.data1.push(entity);
}
if (row === null || row.length === 0) {
that.totalSize = 0;
}
}
}
})
6 years ago
},
//删除账号
remove() {
let that = this;
let request = {
accountId: that.updateAccountId,
userId: that.updateUserId
};
accountManagement.removeAccountApi(request, function (data) {
if (data.data.code === '0001') {
that.$Message.info("删除失败");
return
}
if (data.data.code === '0000') {
that.$Message.info("删除成功");
that.pageNum = 1;
that.listAccountInfoFunction();
}
})
},
cancel() {
},
ok() {
this.modal13 = false;
this.remove();
}
},
6 years ago
}
</script>
<style scoped>
</style>