{php}
use app\service\Image as WImage;
{/php}
<div class="upload-image-box">
    <input type="hidden" class="append-val" value="{$append}">
    <div id="upload_img_list{$append}" class="upload_img_list">
        {if !empty($imgs)}
        {foreach $imgs as $k => $img}
        <dd class="item_img" id="img_{$append}{$k}">
            <div class="imgs">
                <div class="operate">
                    <i onclick="UPLOAD_IMG_DEL(this)" class="close layui-icon"></i>
                </div>
                <img src="{:WImage::getThumb($img.src, 100, 100)}"/>
                <input type="hidden" name="{$fieldName}[{$k}][src]" value="{$img.src}" />
            </div>
            <div class="info">
                {foreach $fields as $name => $desc}
                <input type="text" class="layui-input" name="{$fieldName}[{$k}][{$name}]" value="{$img[$name] ?? ''}" placeholder="{$desc}" />
                {/foreach}
            </div>
        </dd>
        {/foreach}
        {/if}
    </div>
    <div class="upload_img_btn" id="upload-images{$append}">
        <i></i><p>上传图片</p>
    </div>
    <div class="upload_img_btn" id="serverImgList{$append}" style="margin-left: 15px;">
        <i></i><p>服务器图片</p>
    </div>
    <div class="layui-clear"></div>
    <div class="upload-image-points">
        {if !empty($imgSize)}
        <div class="layui-form-mid layui-word-aux">注:图片最佳尺寸为: {$imgSize} 数字0表示不限制</div>
        {else /}
        <div class="layui-form-mid layui-word-aux">请上传大小合适的图片</div>
        {/if}
    </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 append = $('.append-val').val();

    $(document).on("click", ".layer-photos", function(e) {
        layer.photos({
            photos: {
                "data": [{
                    "src": e.target.src
                }]
            },
            anim: 5
        });
    });

    $(document).ready(function() {
        var numId = $('#upload_img_list{$append}>dd').length;
        $(".upload_img_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/image')}";
        layui.use(['upload', 'element'], function() {
            var upload = layui.upload;
            var element = layui.element;
            upload.render({
                elem: '#upload-images{$append}',
                url: uploadUrl,
                data: {_token:_token},
                field: 'image',
                multiple: true,
                before: function(obj) {
                    layer.msg('图片上传中...', {
                        icon: 16,
                        shade: 0.01,
                        time: 0
                    })
                },
                done: function(res) {
                    if(res.code === 0){
                        layer.close(layer.msg()); //关闭上传提示窗口
                        //调用多图上传方法,其中res.imgid为后台返回的一个随机数字
                        let fieldList = generateFiledHtml(numId);
                        $('#upload_img_list{$append}').append('<dd class="item_img" id="img_'+ append + numId +'">'+
                        '<div class="imgs"><div class="operate"><i onclick="UPLOAD_IMG_DEL(this)" class="close layui-icon"></i></div>'+
                        '<img src="' +res.data.thumb_src +'"></div>'+
                        '<input type="hidden" name="{$fieldName}['+numId+'][src]" value="'+ res.data.src +'" />'+
                        '<div class="info">'+ fieldList +'</div></dd>');
                        numId++;
                        $(window).trigger("resize");
                    }else{
                        layer.msg(res.msg);
                    }
                }
            })

            $('#serverImgList{$append}').click(function(){
                var fieldName = "{$fieldName}";
                var html = '';
                $.ajax('/manager/file/list',{
                    data:{
                        type:'img',
                        page:1,
                        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="serverImgsList"><ul id="selectable">'
                                $.each(data.data,function(i,item){
                                    html += '<li><img src="'+item.src+'" data-box="upload_img_list{$append}" onclick="imgListUrl(this, ' + numId + ',\''+ fieldName +'\')"></li>'
                                })
                                html += '</ul></div>';
                                if(data.data.length >= 30){
                                    html += '<div class="serverMore"><a data-box="upload_img_list{$append}" onclick="imgsList(this, ' + numId + ',\''+ fieldName +'\')">加载更多</a></div>'
                                }
                                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('.serverImgsList ul li img').attr('data-id',index)
                                        layero.find('.serverMore a').attr('data-id',index)
                                    }
                                });
                                numId++;
                            }else{
                                layer.msg('暂无数据')
                            }
                        }
                    },
                    error:function(xhr,type,errorThrown){

                    }
                });

            })

        });
    });
    function imgListUrl(obj, numId, fieldName) {
        console.log(fieldName);
        let fieldList = generateFiledHtml(numId, fieldName);
        let imTpl = '<dd class="item_img" id="img_'+ append + numId +'">'+
                '<div class="imgs"><div class="operate"><i onclick="UPLOAD_IMG_DEL(this)" class="close layui-icon"></i></div>'+
                '<img src="' + $(obj).attr('src') +'"></div>'+
                '<input type="hidden" name="'+fieldName+'['+numId+'][src]" value="'+ $(obj).attr('src') +'" />'+
                '<div class="info">' + fieldList + '</div></dd>';
        numId++;
        $('#'+$(obj).attr('data-box')).append(imTpl);
        parent.layer.close($(obj).attr('data-id'));
    }

    function generateFiledHtml(numId, fieldName) {
        let fieldList = '';
        {foreach $fields as $name => $desc}
        fieldList += '<input type="text" class="layui-input" name="'+ fieldName +'['+numId+'][{$name}]" value="" placeholder="{$desc}" />';
        {/foreach}
        return fieldList;
    }

    var page = 2
    function imgsList(obj, numId, fieldName) {
        $.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><img src="'+item.src+'" data-id="'+$(obj).attr('data-id')+'" data-box="'+$(obj).attr('data-box')+'" onclick="imgListUrl(this, ' + numId + ', \''+ fieldName +'\')"></li>'
                        })
                        $(obj).parent().parent().find('.serverImgsList 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_IMG_DEL(divs) {
        $(divs).closest('dd.item_img').remove()
    };
</script>