231 lines
		
	
	
		
			11 KiB
		
	
	
	
		
			HTML
		
	
	
		
		
			
		
	
	
			231 lines
		
	
	
		
			11 KiB
		
	
	
	
		
			HTML
		
	
	
|  | <div class="upload-audio-box"> | |||
|  |     <div id="upload_audio_list{$append}" class="upload_audio_list upload-items-list"> | |||
|  |         {if !empty($audios)} | |||
|  |         {php}$audios = json_decode($audios, true);{/php} | |||
|  |         {foreach $audios as $k => $audio} | |||
|  |         <dd class="item_audio upload-items-one" id="audio_{$k}"> | |||
|  |             <div class="audios"> | |||
|  |                 <div class="operate"> | |||
|  |                     <i onclick="UPLOAD_AUDIO_DEL(this)" class="close layui-icon"></i> | |||
|  |                 </div> | |||
|  |                 <div class="layer-audios"> | |||
|  |                     <audio src="{$audio.src}" controls="controls">您的浏览器不支持audio标签。</audio> | |||
|  |                 </div> | |||
|  |             </div> | |||
|  |             <div class="info"> | |||
|  |                 <textarea name="audios{$append}[{$k}][title]" class="layui-textarea" placeholder="标题">{$audio.title}</textarea> | |||
|  |                 <textarea name="audios{$append}[{$k}][desc]" class="layui-textarea" placeholder="描述">{$audio.desc}</textarea> | |||
|  |                 <input type="text" class="layui-input" name="audios{$append}[{$k}][alt]" value="{$audio.alt ?? ''}" placeholder="ALT属性,选填" /> | |||
|  |                 <input type="text" class="layui-input" name="audios{$append}[{$k}][link]" value="{$audio.link ?? ''}" placeholder="链接,选填" /> | |||
|  |                 <input type="hidden" name="audios{$append}[{$k}][src]" value="{$audio.src}" /> | |||
|  |             </div> | |||
|  |         </dd> | |||
|  |         {/foreach} | |||
|  |         {/if} | |||
|  |     </div> | |||
|  |     <div class="upload_audio_btn upload_file_btn" id="upload-audios{$append}"> | |||
|  |         <i></i><p>音频上传</p> | |||
|  |     </div> | |||
|  |     <div class="upload_img_btn" id="serverAudioList{$append}" style="margin-left: 15px;"> | |||
|  |         <i></i><p>服务器音频</p> | |||
|  |     </div> | |||
|  |     <div class="layui-clear"></div> | |||
|  |     <div class="upload-image-points"> | |||
|  |         <div class="layui-form-mid layui-word-aux">服务器最大支持:{$post_max_size}以内的文件上传</div> | |||
|  |     </div> | |||
|  | </div> | |||
|  | <style type="text/css"> | |||
|  | #selectable .ui-selecting { background: #FECA40; } | |||
|  | #selectable .ui-selected { background: #F39814; color: white; } | |||
|  | #selectable { list-style-type: none; margin: 0; padding: 0;} | |||
|  | </style> | |||
|  | <script type="text/javascript"> | |||
|  |     var _token = $('#token').attr('content'); | |||
|  |     var page = 1; | |||
|  | 
 | |||
|  |     $(document).ready(function() { | |||
|  |         var numid = $('#upload_audio_list{$append}>dd').length; | |||
|  |         $(".upload_audio_list").sortable({ | |||
|  |             cursor: "move", | |||
|  |             items: "dd", //只是li可以拖动 | |||
|  |             opacity: 0.6, //拖动时,透明度为0.6 | |||
|  |             revert: true, //释放时,增加动画 | |||
|  |             update: function(event, ui) { //更新排序之后 | |||
|  |                 //alert($(this).sortable("toArray")); | |||
|  |             } | |||
|  |         }); | |||
|  | 
 | |||
|  |         var uploadUrl = "{:url('manager.upload/audio')}"; | |||
|  |         layui.use(['upload', 'element'], function() { | |||
|  |             var upload = layui.upload; | |||
|  |             var element = layui.element; | |||
|  | 
 | |||
|  |             upload.render({ | |||
|  |                 elem: '#upload-audios{$append}', | |||
|  |                 url: uploadUrl, | |||
|  |                 data: {_token:_token}, | |||
|  |                 field: 'audio', | |||
|  |                 multiple: false, | |||
|  |                 accept: 'audio', | |||
|  |                 acceptMime: 'audio/mpeg', | |||
|  |                 exts: 'mp3', | |||
|  |                 before: function(obj) { | |||
|  |                     layer.msg('文件上传中...', { | |||
|  |                         icon: 16, | |||
|  |                         shade: 0.01, | |||
|  |                         time: 0 | |||
|  |                     }) | |||
|  |                 }, | |||
|  |                 done: function(res) { | |||
|  |                     if(res.code == 0){ | |||
|  |                         layer.close(layer.msg()); | |||
|  |                         $('#upload_audio_list{$append}').append('<dd class="item_audio" id="audio_' + numid +'">'+ | |||
|  |                             '<div class="audios">' + | |||
|  |                                 '<div class="operate"><i onclick="UPLOAD_AUDIO_DEL(this)" class="close layui-icon"></i></div>'+ | |||
|  |                                 '<div class="layer-audios"><audio src="' +res.data.src +'" controls="controls">您的浏览器不支持audio标签。</audio></div>' + | |||
|  |                             '</div>'+ | |||
|  |                             '<div class="info">' + | |||
|  |                                 '<textarea name="audios{$append}['+numid+'][title]" class="layui-textarea" placeholder="标题"></textarea>' + | |||
|  |                                 '<textarea name="audios{$append}['+numid+'][desc]" class="layui-textarea" placeholder="描述"></textarea>' + | |||
|  |                                 '<input type="text" class="layui-input" name="audios{$append}['+numid+'][alt]" value="" placeholder="ALT属性,选填" />'+ | |||
|  |                                 '<input type="text" class="layui-input" name="audios{$append}['+numid+'][link]" value="" placeholder="链接,选填" />'+ | |||
|  |                                 '<input type="hidden" name="audios{$append}['+numid+'][src]" value="' +res.data.src + '" />' + | |||
|  |                             '</div>' + | |||
|  |                         '</dd>'); | |||
|  |                         numid++; | |||
|  |                         $(window).trigger("resize"); | |||
|  |                     }else{ | |||
|  |                         layer.msg(res.msg); | |||
|  |                     } | |||
|  |                 } | |||
|  |             }) | |||
|  | 
 | |||
|  |             $('#serverAudioList{$append}').click(function(){ | |||
|  |                 var html = ''; | |||
|  |                 page = 1; | |||
|  |                 $.ajax('/manager/file/list',{ | |||
|  |                     data:{ | |||
|  |                         type:'audio', | |||
|  |                         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="serverAudiosList"><ul id="selectable">' | |||
|  |                                 $.each(data.data,function(i,item){ | |||
|  |                                     html += '<li>' + | |||
|  |                                             '<audio controls="controls" src="'+item.src+'"></audio>' + | |||
|  |                                             '<p onclick="audioListUrl(this, ' + numid + ')" data-box="upload_audio_list{$append}">'+item.name+'</p>'+ | |||
|  |                                         '</li>' | |||
|  |                                 }) | |||
|  |                                 html += '</ul></div>'; | |||
|  |                                 if(data.data.length >= 30){ | |||
|  |                                     html += '<div class="serverMore"><a data-box="upload_audio_list{$append}" onclick="audiosList(this, ' + numid + ')">加载更多</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('.serverAudiosList ul li p').attr('data-id',index) | |||
|  |                                         layero.find('.serverMore a').attr('data-id',index) | |||
|  |                                     } | |||
|  |                                 }); | |||
|  |                                 numid++; | |||
|  |                             }else{ | |||
|  |                                 layer.msg('暂无数据') | |||
|  |                             } | |||
|  |                         } | |||
|  |                     }, | |||
|  |                     error:function(xhr,type,errorThrown){ | |||
|  | 
 | |||
|  |                     } | |||
|  |                 }); | |||
|  | 
 | |||
|  |             }) | |||
|  | 
 | |||
|  |         }); | |||
|  |     }); | |||
|  | 
 | |||
|  |     function audioListUrl(obj, numid){ | |||
|  |         var audioSrc = $(obj).parent().find('audio').attr('src'); | |||
|  |         var imTpl = '<dd class="item_audio upload-items-one" id="audio_' + numid +'">'+ | |||
|  |             '<div class="audios">' + | |||
|  |                 '<div class="operate"><i onclick="UPLOAD_AUDIO_DEL(this)" class="close layui-icon"></i></div>'+ | |||
|  |                 '<div class="layer-audios"><audio src="'+ audioSrc +'" controls="controls">您的浏览器不支持audio标签。</audio></div>'+ | |||
|  |             '</div>'+ | |||
|  |             '<div class="info">' + | |||
|  |                 '<textarea name="audios{$append}['+numid+'][title]" class="layui-textarea" placeholder="标题"></textarea>' + | |||
|  |                 '<textarea name="audios{$append}['+numid+'][desc]" class="layui-textarea" placeholder="描述"></textarea>' + | |||
|  |                 '<input type="text" class="layui-input" name="audios{$append}['+numid+'][alt]" value="" placeholder="ALT属性,选填" />'+ | |||
|  |                 '<input type="text" class="layui-input" name="audios{$append}['+numid+'][link]" value="" placeholder="链接,选填" />'+ | |||
|  |                 '<input type="hidden" name="audios{$append}['+numid+'][src]" value="' + audioSrc + '" />' + | |||
|  |             '</div>' + | |||
|  |         '</dd>'; | |||
|  |         numid++; | |||
|  |         $('#'+$(obj).attr('data-box')).append(imTpl); | |||
|  |         parent.layer.close($(obj).attr('data-id')); | |||
|  |     } | |||
|  | 
 | |||
|  | 
 | |||
|  |     function audiosList(obj, numid){ | |||
|  |         $.ajax('/manager/file/list',{ | |||
|  |             data:{ | |||
|  |                 type:'audio', | |||
|  |                 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>' + | |||
|  |                                 '<audio controls="controls" src="'+item.src+'" data-id="'+$(obj).attr('data-id')+'" ></audio>' + | |||
|  |                                 '<p onclick="audioListUrl(this, ' + numid + ')" data-box="'+$(obj).attr('data-box')+'">'+item.name+'</p>'+ | |||
|  |                             '</li>' | |||
|  |                         }) | |||
|  |                         $(obj).parent().parent().find('.serverAudiosList 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){ | |||
|  | 
 | |||
|  |             } | |||
|  |         }); | |||
|  |     } | |||
|  | 
 | |||
|  |     // 删除上传音频 | |||
|  |     function UPLOAD_AUDIO_DEL(divs) { | |||
|  |         $(divs).closest('dd.item_audio').remove(); | |||
|  |     } | |||
|  | </script> |