You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
292 lines
14 KiB
292 lines
14 KiB
11 months ago
|
{extend name="public/container"}
|
||
|
{block name='head_top'}
|
||
|
<style>
|
||
|
|
||
|
.layui-form-item .special-label i{display: inline-block;width: 18px;height: 18px;font-size: 18px;color: #fff;}
|
||
|
.layui-form-item .label-box p{line-height: inherit;}
|
||
|
.m-t-5{margin-top:5px;}
|
||
|
#app .layui-barrage-box{margin-bottom: 10px;margin-top: 10px;margin-left: 10px;border: 1px solid #0092DC;border-radius: 5px;cursor: pointer;position: relative;}
|
||
|
#app .layui-barrage-box.border-color{border-color: #0bb20c;}
|
||
|
#app .layui-barrage-box .del-text{position: absolute;top: 0;left: 0;background-color: rgba(0,0,0,0.5);color: #ffffff;width: 92%;text-align: center;}
|
||
|
#app .layui-barrage-box p{padding:5px 5px; overflow: hidden;white-space: nowrap;text-overflow: ellipsis;}
|
||
|
#app .layui-empty-text{text-align: center;font-size: 18px;}
|
||
|
#app .layui-empty-text p{padding: 10px 10px;}
|
||
|
</style>
|
||
|
{/block}
|
||
|
{block name="content"}
|
||
|
<div class="layui-fluid">
|
||
|
<div class="layui-card" id="app" v-cloak>
|
||
|
<div class="layui-card-header">拼团弹幕</div>
|
||
|
<div class="layui-card-body">
|
||
|
<div class="layui-row layui-col-space15">
|
||
|
<div class="layui-col-md12">
|
||
|
<form action="" class="layui-form">
|
||
|
<div class="layui-form-item">
|
||
|
<label class="layui-form-label">弹幕开关</label>
|
||
|
<div class="layui-input-block">
|
||
|
<input type="checkbox" checked="" name="open_barrage" lay-skin="switch" :value="open_barrage" lay-filter='is_show' lay-text="打开|关闭" :checked="open_barrage">
|
||
|
</div>
|
||
|
</div>
|
||
|
</form>
|
||
|
</div>
|
||
|
<div class="layui-col-md12">
|
||
|
<form action="" class="layui-form">
|
||
|
<div class="layui-form-item">
|
||
|
<label class="layui-form-label required">头像:(300*300)</label>
|
||
|
<div class="layui-input-block">
|
||
|
<div class="upload-image-box" v-if="avatar">
|
||
|
<img :src="avatar" alt="" style="border-radius: 5px;">
|
||
|
<div class="mask">
|
||
|
<p><i class="fa fa-eye" @click="look(avatar)"></i><i class="fa fa-trash-o" @click="avatar = ''"></i></p>
|
||
|
</div>
|
||
|
</div>
|
||
|
<div class="upload-image" v-show="!avatar" @click="upload(1)">
|
||
|
<div class="fiexd"><i class="fa fa-plus"></i></div>
|
||
|
<p>上传图片</p>
|
||
|
</div>
|
||
|
</div>
|
||
|
</div>
|
||
|
<div class="layui-form-item">
|
||
|
<label class="layui-form-label required">昵称:</label>
|
||
|
<div class="layui-input-inline">
|
||
|
<input type="text" name="title" v-model="nickname" maxlength="30" autocomplete="off" placeholder="请输入昵称" class="layui-input">
|
||
|
</div>
|
||
|
</div>
|
||
|
<div class="layui-form-item">
|
||
|
<label class="layui-form-label">排序:</label>
|
||
|
<div class="layui-input-inline">
|
||
|
<input type="number" name="sort" v-model="sort" autocomplete="off" class="layui-input">
|
||
|
</div>
|
||
|
</div>
|
||
|
<div class="layui-form-item">
|
||
|
<label class="layui-form-label">动作:</label>
|
||
|
<div class="layui-input-block">
|
||
|
<input type="radio" name="action" value="1" title="开团" v-model="action" lay-filter="action">
|
||
|
<input type="radio" name="action" value="2" title="参团" v-model="action" lay-filter="action">
|
||
|
</div>
|
||
|
</div>
|
||
|
<div class="layui-form-item">
|
||
|
<div class="layui-input-block">
|
||
|
<button class="layui-btn layui-btn-normal" type="button" @click="save_barrage">{{id ? '立即修改':'立即提交'}}</button>
|
||
|
<button class="layui-btn layui-btn-primary clone" type="button" @click="empty_barrage">清空</button>
|
||
|
</div>
|
||
|
</div>
|
||
|
</form>
|
||
|
</div>
|
||
|
<div class="layui-col-md12">
|
||
|
<blockquote class="layui-elem-quote layui-quote-nm" style="margin: 10px;">
|
||
|
点击列表里面的弹幕可进行修改,取消修改请点击【清空】按钮;
|
||
|
</blockquote>
|
||
|
<div class="layui-row">
|
||
|
<div class="layui-col-md1 layui-barrage-box" :class="id==item.id ? 'border-color':'' " v-for="(item,index) in barrageList" @click.stop="set_barrage(item)">
|
||
|
<p @click.stop="del_barrage(item,index)" class="del-text"><span>删除</span></p>
|
||
|
<img :src="item.avatar" alt="" style="width: 100%;height: 136px;">
|
||
|
<p><span>用户名:</span>{{ item.nickname.length > 6 ? item.nickname.slice(0,5) : item.nickname }}</p>
|
||
|
<p><span>排序:</span>{{ item.sort }}</p>
|
||
|
<p><span>类型:</span>{{ item.action==1 ? '开团':'参团' }}</p>
|
||
|
</div>
|
||
|
<div class="layui-col-md12 layui-empty-text" v-if="barrageList.length <= 0">
|
||
|
<p>暂无数据</p>
|
||
|
</div>
|
||
|
</div>
|
||
|
<div class="layui-row" style="text-align: right;">
|
||
|
<div ref="barrage_page"></div>
|
||
|
</div>
|
||
|
</div>
|
||
|
</div>
|
||
|
</div>
|
||
|
</div>
|
||
|
</div>
|
||
|
<script type="text/javascript" src="{__ADMIN_PATH}js/request.js"></script>
|
||
|
<script type="text/javascript" src="{__ADMIN_PATH}js/layuiList.js"></script>
|
||
|
<script type="text/javascript" src="{__MODULE_PATH}widget/OssUpload.js"></script>
|
||
|
{/block}
|
||
|
{block name='script'}
|
||
|
<script>
|
||
|
var open_barrage=<?=$open_barrage ? (int)$open_barrage : 0?>;
|
||
|
require(['vue'],function(Vue) {
|
||
|
new Vue({
|
||
|
el: "#app",
|
||
|
data: {
|
||
|
avatar:'',
|
||
|
nickname:'',
|
||
|
sort:0,
|
||
|
action:1,
|
||
|
id:0,
|
||
|
open_barrage:open_barrage,
|
||
|
barrageList:[],
|
||
|
loading:false,
|
||
|
loadend:false,
|
||
|
page:1,
|
||
|
limit:22,
|
||
|
is_show:false
|
||
|
},
|
||
|
watch:{
|
||
|
page:function () {
|
||
|
this.get_barrage_list();
|
||
|
}
|
||
|
},
|
||
|
methods:{
|
||
|
del_barrage:function(item,index){
|
||
|
var that=this;
|
||
|
layList.layer.confirm('是否删除【'+item.nickname+'】虚拟用户的弹幕?', {
|
||
|
btn: ['删除','我在想想'] //按钮
|
||
|
}, function(){
|
||
|
layList.baseGet(layList.U({a:'del_barrage',q:{id:item.id}}),function () {
|
||
|
that.get_barrage_list();
|
||
|
layList.msg('删除成功');
|
||
|
});
|
||
|
}, function(){
|
||
|
that.get_barrage_list();
|
||
|
});
|
||
|
},
|
||
|
set_barrage:function(item){
|
||
|
this.action=item.action;
|
||
|
this.avatar=item.avatar;
|
||
|
this.avatar.is_show=false;
|
||
|
this.$set(this,'avatar',this.avatar);
|
||
|
this.sort=item.sort;
|
||
|
this.id=item.id;
|
||
|
this.nickname=item.nickname;
|
||
|
this.$nextTick(function () {
|
||
|
layList.form.render('radio');
|
||
|
})
|
||
|
},
|
||
|
empty_barrage:function(){
|
||
|
if(this.id){
|
||
|
this.avatar='';
|
||
|
this.nickname='';
|
||
|
this.sort=0;
|
||
|
this.action=1;
|
||
|
this.id=0;
|
||
|
}else{
|
||
|
this.avatar='';
|
||
|
this.nickname='';
|
||
|
this.sort=0;
|
||
|
this.action=1;
|
||
|
}
|
||
|
},
|
||
|
save_barrage:function(){
|
||
|
var that=this;
|
||
|
if(!this.avatar) return layList.msg('请上传虚拟用户头像');
|
||
|
if(!this.nickname) return layList.msg('请输入虚拟用户昵称');
|
||
|
layList.loadFFF();
|
||
|
layList.basePost(layList.U({a:'save_barrage'}),{nickname:that.nickname,avatar:that.avatar,action:that.action,sort:that.sort,id:that.id},function (res) {
|
||
|
layList.loadClear();
|
||
|
if(that.id) return layList.msg('修改成功',function () {
|
||
|
that.avatar='';
|
||
|
that.nickname='';
|
||
|
that.sort=0;
|
||
|
that.action=1;
|
||
|
that.id=0;
|
||
|
that.$nextTick(function () {
|
||
|
layList.form.render('radio');
|
||
|
})
|
||
|
});
|
||
|
layList.layer.confirm('添加成功,是保留当前内容?', {
|
||
|
btn: ['保留','清空'] //按钮
|
||
|
}, function(index){
|
||
|
that.get_barrage_list();
|
||
|
layList.layer.close(index);
|
||
|
}, function(){
|
||
|
that.avatar='';
|
||
|
that.nickname='';
|
||
|
that.sort=0;
|
||
|
that.action=1;
|
||
|
that.get_barrage_list();
|
||
|
});
|
||
|
},function (res) {
|
||
|
layList.loadClear();
|
||
|
});
|
||
|
},
|
||
|
//删除图片
|
||
|
delect:function(act,key,index) {
|
||
|
var that = this;
|
||
|
that.avatar = '';
|
||
|
},
|
||
|
//查看图片
|
||
|
look:function(pic){
|
||
|
$eb.openImage(pic);
|
||
|
},
|
||
|
//鼠标移入事件
|
||
|
enter:function(){
|
||
|
this.avatar.is_show=true;
|
||
|
this.$set(this,'avatar',this.avatar);
|
||
|
},
|
||
|
//鼠标移出事件
|
||
|
leave:function(){
|
||
|
this.avatar.is_show=false;
|
||
|
this.$set(this,'avatar',this.avatar);
|
||
|
},
|
||
|
changeIMG:function(key,value,multiple){
|
||
|
if(multiple){
|
||
|
var that = this;
|
||
|
value.map(function (v) {
|
||
|
that[key].push({pic:v,is_show:false});
|
||
|
});
|
||
|
this.$set(this,key,this[key]);
|
||
|
}else{
|
||
|
this.$set(this,key,value);
|
||
|
}
|
||
|
},
|
||
|
//上传图片
|
||
|
upload:function() {
|
||
|
ossUpload.createFrame('选择头像',{fodder:'avatar'},{w:800,h:550});
|
||
|
},
|
||
|
get_barrage_list:function(){
|
||
|
var that=this;
|
||
|
if(that.loading) return;
|
||
|
if(that.loadend) return;
|
||
|
that.loading=true;
|
||
|
layList.baseGet(layList.U({a:'get_barrage_list',q:{page:that.page,limit:that.limit}}),function (res){
|
||
|
that.loading=false;
|
||
|
that.$set(that,'barrageList',res.data.list);
|
||
|
that.page === 1 && that.set_page(res.data.count);
|
||
|
that.$nextTick(function () {
|
||
|
layList.form.render('radio');
|
||
|
})
|
||
|
},function (res) {
|
||
|
that.loading=false;
|
||
|
});
|
||
|
},
|
||
|
set_page:function (count){
|
||
|
var that=this;
|
||
|
layList.laypage.render({
|
||
|
elem: this.$refs.barrage_page,
|
||
|
count: count,
|
||
|
limit:this.limit,theme: '#1E9FFF',
|
||
|
jump:function (obj,first) {
|
||
|
if (!first) {
|
||
|
that.page=obj.curr;
|
||
|
}
|
||
|
}
|
||
|
});
|
||
|
}
|
||
|
},
|
||
|
mounted:function () {
|
||
|
var that=this;
|
||
|
this.$nextTick(function () {
|
||
|
layList.form.render();
|
||
|
});
|
||
|
this.get_barrage_list();
|
||
|
window.changeIMG = this.changeIMG;
|
||
|
layList.form.on('radio(action)',function (data) {
|
||
|
that.action=data.value;
|
||
|
});
|
||
|
layList.switch('is_show',function (odj,value) {
|
||
|
if(odj.elem.checked==true){
|
||
|
layList.baseGet(layList.Url({a:'set_barrage_show',p:{value:1,key_nime:'open_barrage'}}),function (res) {
|
||
|
layList.msg(res.msg);
|
||
|
});
|
||
|
}else{
|
||
|
layList.baseGet(layList.Url({a:'set_barrage_show',p:{value:0,key_nime:'open_barrage'}}),function (res) {
|
||
|
layList.msg(res.msg);
|
||
|
});
|
||
|
}
|
||
|
});
|
||
|
}
|
||
|
})
|
||
|
})
|
||
|
</script>
|
||
|
{/block}
|