pzct/view/manager/widget/video.html

189 lines
7.9 KiB
HTML
Executable File
Raw Blame History

This file contains ambiguous Unicode characters!

This file contains ambiguous Unicode characters that may be confused with others in your current locale. If your use case is intentional and legitimate, you can safely ignore this warning. Use the Escape button to highlight these characters.

<div class="upload-video-box">
<div id="listVideo{$append}" class="upload_video">
{if file_exists('.'.$src)&&!empty($src)}
<div class="video-item">
<video src="{$src}" controls="controls" width="260">您的浏览器不支持 video 标签。</video>
</div>
<hr />
{/if}
</div>
<div class="upload_img_btn" id="upload-video{$append}">
<i></i>
<p>上传视频</p>
</div>
<div class="upload_img_btn" id="serverVideos{$append}" style="margin-left: 15px;">
<i></i><p>服务器视频</p>
</div>
<div class="upload clearfix">
<div class="layui-clear"></div>
<div class="upload-image-points">
<p id="upload-video-src{$append}"></p>
<input type="hidden" id="video{$append}" name="video{$append}" value="{$src??''}" class="layui-file" readonly />
</div>
<div class="upload-image-points">
{if !empty($videoSize)}
<div class="layui-form-mid layui-word-aux">{$videoSize}</div>
{else /}
<div class="layui-form-mid layui-word-aux">请上传大小合适的视频</div>
{/if}
</div>
</div>
</div>
<script type="text/javascript">
var _token = $('#token').attr('content');
var page = 1;
$(document).ready(function() {
var videoInput = "#video{$append}";
var uploadUrl = "{:url('manager.upload/video')}";
layui.use(['upload', 'element'], function() {
var upload = layui.upload;
var element = layui.element;
var uploadInst = upload.render({
elem: '#upload-video{$append}',
url: uploadUrl,
data:{_token:_token},
field: 'video',
accept: 'video',
choose: function(obj) {
console.log(obj)
obj.preview(function(index, file, result) {
var imTpl = '<div class="video-item">' +
'<video src="' + result +
'" controls="controls" width="260">您的浏览器不支持 video 标签。</video>' +
'</div><hr />';
$('#listVideo{$append}').html(imTpl);
$(window).trigger("resize");
});
},
before: function(obj) {
console.log(obj)
layer.load();
},
done: function(res, index, upload) {
console.log(res)
layer.closeAll('loading');
if (res.code == 0) {
$(videoInput).val(res.data.src);
} else {
$(videoInput).val('');
layer.msg(res.msg, {
time: 1500
});
}
},
error: function(index, upload) {
layer.closeAll('loading');
}
});
$('#serverVideos{$append}').click(function(){
var html = ''
page = 1;
$.ajax('/manager/file/list',{
data:{
type:'video',
page:page,
size:30
},
headers: {
'X-CSRF-TOKEN': _token
},
dataType:'json',//服务器返回json格式数据
type:'post',//HTTP请求类型
timeout:10000,//超时时间设置为10秒
success:function(data){
if(data.code == 0){
if(data.data.length > 0){
html += '<div class="layui-card-body"><div class="serverVideoList"><ul>'
$.each(data.data,function(i,item){
html += '<li><i data-src="'+item.src+'" data-box="listVideo{$append}" data-input="video{$append}" onclick="videoUrl(this)"></i><video src="'+item.src+'" controls="controls" width="260">您的浏览器不支持 video 标签。</video></li>'
})
html += '</ul></div>';
if(data.data.length >= 30){
html += '<div class="serverMore"><a data-box="listVideo{$append}" data-input="video{$append}" onclick="videoList(this)">加载更多</a></div>'
page++
}
html += '<div class="layui-clear"></div></div>';
layer.open({
type: 1,
title: '服务器视频',
shadeClose: true,
area: ['800px',''], //宽高
move: false,
content: html,
success:function(layero, index) {
alertRender()
layero.find('.serverVideoList ul li i').attr('data-id',index)
layero.find('.serverMore a').attr('data-id',index)
}
});
}else{
layer.msg('暂无数据')
}
}
},
error:function(xhr,type,errorThrown){
}
});
})
});
});
function videoUrl(obj){
var imTpl = '<div class="video-item">' +
'<video src="' + $(obj).attr('data-src') +
'" controls="controls" width="260">您的浏览器不支持 video 标签。</video>' +
'</div><hr />';
$('#'+$(obj).attr('data-box')).html(imTpl);
$('#'+$(obj).attr('data-input')).val($(obj).attr('data-src'));
parent.layer.close($(obj).attr('data-id'));
$(window).trigger("resize");
}
function videoList(obj){
$.ajax('/manager/file/list',{
data:{
type:'img',
page:page,
size:30
},
headers: {
'X-CSRF-TOKEN': _token
},
dataType:'json',//服务器返回json格式数据
type:'post',//HTTP请求类型
timeout:10000,//超时时间设置为10秒
success:function(data){
if(data.code == 0){
if(data.data.length > 0){
var html = ''
$.each(data.data,function(i,item){
html += '<li><i data-src="'+item.src+'" data-id="'+$(obj).attr('data-id')+'" data-box="'+$(obj).attr('data-box')+'" data-input="'+$(obj).attr('data-input')+'" onclick="videoUrl(this)"></i><video src="'+item.src+'" controls="controls" width="260">您的浏览器不支持 video 标签。</video></li>'
})
$(obj).parent().parent().find('.serverVideoList ul').append(html)
$(window).trigger("resize");
if(data.data.length < 30){
$(obj).parent().append('<p>没有了</p>')
$(obj).parent().find('a').remove();
}else{
page++;
}
}else{
layer.msg(data.msg)
}
}
},
error:function(xhr,type,errorThrown){
}
});
}
</script>