189 lines
		
	
	
		
			7.9 KiB
		
	
	
	
		
			HTML
		
	
	
		
		
			
		
	
	
			189 lines
		
	
	
		
			7.9 KiB
		
	
	
	
		
			HTML
		
	
	
|  | <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> |