105 lines
2.9 KiB
Vue
105 lines
2.9 KiB
Vue
<template>
|
||
<el-dialog :title="title" :close-on-click-modal="false" :visible.sync="open" width="700px" append-to-body>
|
||
<el-form ref="form" :model="form" :rules="rules" label-width="100px">
|
||
<el-form-item :label="systemName+'号'" prop="usercode">
|
||
<el-autocomplete
|
||
class="inline-input"
|
||
v-model="form.usercode"
|
||
:fetch-suggestions="querySearch"
|
||
placeholder="请输入内容"
|
||
@select="handleSelect"
|
||
></el-autocomplete>
|
||
</el-form-item>
|
||
<el-form-item label="昵称" v-if="info.nickname">
|
||
{{ info.nickname }} 【{{ info.usercode }}】
|
||
</el-form-item>
|
||
<el-form-item label="性别" v-if="info.gender">
|
||
<cai-dict-tag :options="genderList" :value="info.gender" />
|
||
</el-form-item>
|
||
<el-form-item label="头像" v-if="info.avatar">
|
||
<image-avatar :src="info.avatar"/>
|
||
</el-form-item>
|
||
<el-form-item>
|
||
注意:只有女用户可以成为主播
|
||
</el-form-item>
|
||
</el-form>
|
||
<div slot="footer" class="dialog-footer">
|
||
<el-button :loading="buttonLoading" type="primary" @click="submitForm">确 定</el-button>
|
||
<el-button @click="open = false">取 消</el-button>
|
||
</div>
|
||
</el-dialog>
|
||
</template>
|
||
|
||
<script>
|
||
import {getUserByUsercode, listUserByUserCode} from "@/api/cai/user";
|
||
import {addAnchor} from "@/api/cai/anchor";
|
||
import {genderList} from "@/constant/statusMap";
|
||
|
||
export default {
|
||
components: {
|
||
},
|
||
data () {
|
||
return {
|
||
systemName: process.env.VUE_APP_SYSTEM_HOME,
|
||
genderList,
|
||
open: false,
|
||
title: '',
|
||
form:{
|
||
usercode: undefined,
|
||
},
|
||
info:{
|
||
},
|
||
memberPriceList:[],
|
||
// 表单校验
|
||
rules: {
|
||
usercode: [
|
||
{ required: true, message: "数据不能为空", trigger: "blur" }
|
||
]
|
||
},
|
||
buttonLoading: false,
|
||
}
|
||
},
|
||
created() {
|
||
},
|
||
methods: {
|
||
init () {
|
||
this.open = true;
|
||
this.title = "新增主播"
|
||
this.info = {};
|
||
this.form.usercode = undefined
|
||
},
|
||
querySearch(querySearch,cb){
|
||
listUserByUserCode(querySearch).then(res => {
|
||
cb(res.data.map((terminal) => {
|
||
return {
|
||
value: terminal,
|
||
name: terminal,
|
||
};
|
||
}))
|
||
})
|
||
},
|
||
handleSelect(item){
|
||
getUserByUsercode(item.value).then(res => {
|
||
this.info = res.data
|
||
})
|
||
},
|
||
// 表单提交
|
||
submitForm () {
|
||
this.$refs['form'].validate((valid) => {
|
||
if (valid) {
|
||
this.buttonLoading = true;
|
||
addAnchor(this.form).then(data => {
|
||
this.$modal.msgSuccess("新增主播成功");
|
||
this.buttonLoading = false;
|
||
this.open = false
|
||
this.$emit('refreshDataList')
|
||
}).finally(() => {
|
||
this.buttonLoading = false;
|
||
});
|
||
}
|
||
})
|
||
},
|
||
}
|
||
}
|
||
</script>
|