<div class="layui-fluid layui-anim febs-anim" id="febs-order" lay-title="订单列表"> 
 | 
    <div class="layui-row febs-container"> 
 | 
        <div class="layui-col-md12"> 
 | 
            <div class="layui-card"> 
 | 
                <div class="layui-card-body febs-table-full"> 
 | 
                    <form class="layui-form layui-table-form" lay-filter="user-table-form"> 
 | 
                        <div class="layui-form-item"> 
 | 
                            <div class="layui-col-md10"> 
 | 
                                <div class="layui-inline"> 
 | 
                                    <div class="layui-input-inline"> 
 | 
                                        <input type="text" placeholder="用户名" name="name" autocomplete="off" class="layui-input"> 
 | 
                                    </div> 
 | 
                                </div> 
 | 
                                <div class="layui-inline"> 
 | 
                                    <div class="layui-input-inline"> 
 | 
                                        <input type="text" placeholder="商品名称" name="goodsName" autocomplete="off" class="layui-input"> 
 | 
                                    </div> 
 | 
                                </div> 
 | 
                                <div class="layui-inline"> 
 | 
                                    <div class="layui-input-inline"> 
 | 
                                        <input type="text" placeholder="订单编号" name="orderNo" autocomplete="off" class="layui-input"> 
 | 
                                    </div> 
 | 
                                </div> 
 | 
                                <div class="layui-inline"> 
 | 
                                    <label class="layui-form-label layui-form-label-sm">订单状态</label> 
 | 
                                    <div class="layui-input-inline"> 
 | 
                                        <select name="status"> 
 | 
                                            <option value="">请选择</option> 
 | 
                                            <option value="1">待支付</option> 
 | 
                                            <option value="2">待发货</option> 
 | 
                                            <option value="3">待收货</option> 
 | 
                                            <option value="4">已完成</option> 
 | 
                                            <option value="5">退款中</option> 
 | 
                                            <option value="6">已退款</option> 
 | 
                                            <option value="7">已取消</option> 
 | 
                                        </select> 
 | 
                                    </div> 
 | 
                                </div> 
 | 
                                <div class="layui-inline"> 
 | 
                                    <label class="layui-form-label layui-form-label-sm">支付状态</label> 
 | 
                                    <div class="layui-input-inline"> 
 | 
                                        <select name="payResult"> 
 | 
                                            <option value="">请选择</option> 
 | 
                                            <option value="1">成功</option> 
 | 
                                            <option value="2">未成功</option> 
 | 
                                        </select> 
 | 
                                    </div> 
 | 
                                </div> 
 | 
                                <div class="layui-inline"> 
 | 
                                    <label class="layui-form-label layui-form-label-sm">开始时间</label> 
 | 
                                    <div class="layui-input-inline"> 
 | 
                                        <input type="text" name="startTime" id="febs-form-group-date-start" lay-verify="date" 
 | 
                                               placeholder="yyyy-MM-dd" autocomplete="off" class="layui-input"> 
 | 
                                    </div> 
 | 
                                </div> 
 | 
                                <div class="layui-inline"> 
 | 
                                    <label class="layui-form-label layui-form-label-sm">结束时间</label> 
 | 
                                    <div class="layui-input-inline"> 
 | 
                                        <input type="text" name="endTime" id="febs-form-group-date-end" lay-verify="date" 
 | 
                                               placeholder="yyyy-MM-dd" autocomplete="off" class="layui-input"> 
 | 
                                    </div> 
 | 
                                </div> 
 | 
                            </div> 
 | 
  
 | 
                            <div class="layui-col-md2 layui-col-sm12 layui-col-xs12 table-action-area"> 
 | 
                                <div class="layui-btn layui-btn-sm layui-btn-primary febs-button-blue-plain table-action" id="query"> 
 | 
                                    <i class="layui-icon"></i> 
 | 
                                </div> 
 | 
                                <div class="layui-btn layui-btn-sm layui-btn-primary febs-button-green-plain table-action" id="reset"> 
 | 
                                    <i class="layui-icon"></i> 
 | 
                                </div> 
 | 
                            </div> 
 | 
                        </div> 
 | 
                    </form> 
 | 
                    <table lay-filter="orderTable" lay-data="{id: 'orderTable'}"></table> 
 | 
                    <style type="text/css"> 
 | 
                        .layui-table-cell{ 
 | 
                            text-align:center; 
 | 
                            height: auto; 
 | 
                            white-space: nowrap; /*文本不会换行,在同一行显示*/ 
 | 
                            overflow: hidden; /*超出隐藏*/ 
 | 
                            text-overflow: ellipsis; /*省略号显示*/ 
 | 
                        } 
 | 
                        .layui-table img{ 
 | 
                            max-width:100px 
 | 
                        } 
 | 
                    </style> 
 | 
                </div> 
 | 
            </div> 
 | 
        </div> 
 | 
    </div> 
 | 
</div> 
 | 
<!-- 表格操作栏 start --> 
 | 
<script type="text/html" id="user-option"> 
 | 
    <span shiro:lacksPermission="user:view,user:update,user:delete"> 
 | 
        <span class="layui-badge-dot febs-bg-orange"></span> 无权限 
 | 
    </span> 
 | 
    <a lay-event="edit" shiro:hasPermission="user:update"><i 
 | 
            class="layui-icon febs-edit-area febs-blue"></i></a> 
 | 
</script> 
 | 
<script type="text/html" id="tableToolBar"> 
 | 
    <div class="layui-btn-container"> 
 | 
        <button class="layui-btn layui-btn-sm layui-btn-primary febs-button-blue-plain" lay-event="exportDeliver">导出未发货订单</button> 
 | 
        <button class="layui-btn layui-btn-sm layui-btn-primary febs-button-blue-plain" id="importDeliver" lay-event="importDeliver">导入发货</button> 
 | 
        <button class="layui-btn layui-btn-sm layui-btn-primary febs-button-blue-plain" lay-event="exportDeliverDone">导出已发货订单</button> 
 | 
<!--        <button type="button" class="layui-btn layui-btn-sm layui-btn-primary febs-button-blue-plain" onclick="print('tool(orderTable)')">layui自定义打印表格</button>--> 
 | 
        <button id="printSelect" type="button" class="layui-btn layui-btn-sm layui-btn-primary febs-button-blue-plain">自定义打印</button> 
 | 
<!--        <button class="layui-btn layui-btn-sm layui-btn-primary febs-button-blue-plain" lay-event="getCheckData">获取选中行数据</button>--> 
 | 
<!--        <button class="layui-btn layui-btn-sm layui-btn-primary febs-button-blue-plain" lay-event="getCheckLength">获取选中数目</button>--> 
 | 
<!--        <button class="layui-btn layui-btn-sm layui-btn-primary febs-button-blue-plain" lay-event="isAll">验证是否全选</button>--> 
 | 
    </div> 
 | 
</script> 
 | 
<!-- 表格操作栏 end --> 
 | 
<script data-th-inline="none" type="text/javascript"> 
 | 
    // 引入组件并初始化 
 | 
    layui.use([ 'jquery', 'form', 'table', 'febs', 'upload','laydate'], function () { 
 | 
        var $ = layui.jquery, 
 | 
            febs = layui.febs, 
 | 
            form = layui.form, 
 | 
            table = layui.table, 
 | 
            upload = layui.upload, 
 | 
            $view = $('#febs-order'), 
 | 
            $query = $view.find('#query'), 
 | 
            $reset = $view.find('#reset'), 
 | 
            $searchForm = $view.find('form'), 
 | 
            $add = $view.find('#add'), 
 | 
            sortObject = {field: 'phone', type: null}, 
 | 
            laydate = layui.laydate, 
 | 
            tableIns; 
 | 
  
 | 
        //日期范围 
 | 
        laydate.render({ 
 | 
            elem: '#febs-form-group-date-start' 
 | 
        }); 
 | 
  
 | 
        laydate.render({ 
 | 
            elem: '#febs-form-group-date-end' 
 | 
        }); 
 | 
  
 | 
        form.render(); 
 | 
  
 | 
        // 表格初始化 
 | 
        initTable(); 
 | 
  
 | 
        table.on('toolbar(orderTable)', function(obj){ 
 | 
            var event = obj.event; 
 | 
  
 | 
            if (event == 'exportDeliver') { 
 | 
                window.location.href = ctx + "admin/order/exportOrderList?orderType=1&status=2"; 
 | 
            } 
 | 
  
 | 
            if (event == 'exportDeliverDone') { 
 | 
                window.location.href = ctx + "admin/order/exportOrderList?orderType=1&status=3"; 
 | 
            } 
 | 
        }); 
 | 
  
 | 
        upload.render({ 
 | 
            elem: '#importDeliver' 
 | 
            ,url: 'admin/order/importDeliver' //此处配置你自己的上传接口即可 
 | 
            ,accept: 'file' //普通文件 
 | 
            ,done: function(res){ 
 | 
                console.log("123"); 
 | 
            } 
 | 
        }); 
 | 
  
 | 
        // 初始化表格操作栏各个按钮功能 
 | 
        table.on('tool(orderTable)', function (obj) { 
 | 
            var data = obj.data, 
 | 
                layEvent = obj.event; 
 | 
            if (layEvent === 'deliverGoods') { 
 | 
                febs.modal.open('发货', 'modules/order/deliverGoods/' + data.id, { 
 | 
                    btn: ['确认', '取消'], 
 | 
                    yes: function (index, layero) { 
 | 
                        $('#deliver-update').find('#submit').trigger('click'); 
 | 
                    }, 
 | 
                    btn2: function () { 
 | 
                        layer.closeAll(); 
 | 
                    } 
 | 
                }); 
 | 
            } 
 | 
            if (layEvent === 'seeOrder') { 
 | 
                febs.modal.open( '订单详情', 'modules/order/orderDetail/' + data.id, { 
 | 
                    maxmin: true, 
 | 
                }); 
 | 
            } 
 | 
            if (layEvent === 'cancelOrder') { 
 | 
                febs.modal.confirm('取消订单', '确认取消订单?', function () { 
 | 
                    cancelOrder(data.id); 
 | 
                }); 
 | 
            } 
 | 
            if (layEvent === 'takeGoods') { 
 | 
                febs.modal.confirm('自提商品', '确认自提商品?', function () { 
 | 
                    takeGoods(data.id); 
 | 
                }); 
 | 
            } 
 | 
            if (layEvent === 'delOrder') { 
 | 
                febs.modal.confirm('删除订单', '确认删除订单?', function () { 
 | 
                    delOrder(data.id); 
 | 
                }); 
 | 
            } 
 | 
            if (layEvent === 'seePayImage') { 
 | 
                var t = $view.find('#seePayImage'+data.id+''); 
 | 
                //页面层 
 | 
                layer.open({ 
 | 
                    type: 1, 
 | 
                    title: "支付凭证", 
 | 
                    skin: 'layui-layer-rim', //加上边框 
 | 
                    area: ['80%', '80%'], //宽高 
 | 
                    shadeClose: true, //开启遮罩关闭 
 | 
                    end: function (index, layero) { 
 | 
                        return false; 
 | 
                    }, 
 | 
                    content: '<div style="text-align:center"><img src="' + $(t).attr('src') + '" /></div>' 
 | 
                }); 
 | 
            } 
 | 
        }); 
 | 
  
 | 
        function takeGoods(id) { 
 | 
            febs.get(ctx + 'admin/order/takeGoods/' + id, null, function () { 
 | 
                febs.alert.success('操作成功'); 
 | 
                $query.click(); 
 | 
            }); 
 | 
        } 
 | 
  
 | 
        function cancelOrder(id) { 
 | 
            febs.get(ctx + 'admin/order/cancelOrder/' + id, null, function () { 
 | 
                febs.alert.success('操作成功'); 
 | 
                $query.click(); 
 | 
            }); 
 | 
        } 
 | 
  
 | 
        function delOrder(id) { 
 | 
            febs.get(ctx + 'admin/order/delOrder/' + id, null, function () { 
 | 
                febs.alert.success('操作成功'); 
 | 
                $query.click(); 
 | 
            }); 
 | 
        } 
 | 
  
 | 
        // 查询按钮 
 | 
        $query.on('click', function () { 
 | 
            var params = $.extend(getQueryParams(), {field: sortObject.field, order: sortObject.type}); 
 | 
            tableIns.reload({where: params, page: {curr: 1}}); 
 | 
        }); 
 | 
  
 | 
        // 刷新按钮 
 | 
        $reset.on('click', function () { 
 | 
            $searchForm[0].reset(); 
 | 
            sortObject.type = 'null'; 
 | 
            tableIns.reload({where: getQueryParams(), page: {curr: 1}, initSort: sortObject}); 
 | 
        }); 
 | 
  
 | 
        $add.on('click', function () { 
 | 
            febs.view.tab.change("/modules/goods/goodsAddNew/"); 
 | 
        }); 
 | 
  
 | 
        function initTable() { 
 | 
            tableIns = febs.table.init({ 
 | 
                elem: $view.find('table'), 
 | 
                id: 'orderTable', 
 | 
                url: ctx + 'admin/order/orderList?orderType=1', 
 | 
                defaultToolbar: [], 
 | 
                toolbar: '#tableToolBar', 
 | 
                totalRow: true ,// 开启合计行 
 | 
                cols: [[ 
 | 
                        {type: 'checkbox',fixed: 'left'}, 
 | 
                        {field: 'orderNo', title: '订单编号', minWidth: 120,align:'left', totalRowText: '合计:'}, 
 | 
                        {field: 'memberName', title: '购买人', minWidth: 120,align:'left'}, 
 | 
                        {field: 'memberPhone', title: '账号', minWidth: 120,align:'left'}, 
 | 
                        {field: 'memberBindPhone', title: '联系方式', minWidth: 120,align:'left'}, 
 | 
                        {field: 'goodsName', title: '商品信息', minWidth: 200,align:'left'}, 
 | 
                        {field: 'remark', title: '备注', minWidth: 200,align:'left'}, 
 | 
                        {field: 'amount', title: '订单金额', minWidth: 120,align:'left',totalRow: '{{= parseInt(d.amount) }}'}, 
 | 
                        {field: 'deliverType', title: '配送方式', 
 | 
                            templet: function (d) { 
 | 
                                if (d.deliverType === 1) { 
 | 
                                    return '<span style="color:green;">快递寄送</span>' 
 | 
                                } else if (d.deliverType === 2) { 
 | 
                                    return '<span style="color:blue;">到店自提</span>' 
 | 
                                }else{ 
 | 
                                    return '<span style="color:green;">快递寄送</span>' 
 | 
                                } 
 | 
                            }, minWidth: 120,align:'center'}, 
 | 
                    {field: 'status', title: '状态', 
 | 
                        templet: function (d) { 
 | 
                            if (d.status === 1) { 
 | 
                                return '<span style="color:red;">待支付</span>' 
 | 
                            } else if (d.status === 2) { 
 | 
                                return '<span style="color:green;">待发货</span>' 
 | 
                            }else if (d.status === 3) { 
 | 
                                return '<span style="color:green;">待收货</span>' 
 | 
                            }else if (d.status === 4) { 
 | 
                                return '<span style="color:green;">已完成</span>' 
 | 
                            }else if (d.status === 5) { 
 | 
                                return '<span style="color:green;">退款中</span>' 
 | 
                            }else if (d.status === 6) { 
 | 
                                return '<span style="color:green;">已退款</span>' 
 | 
                            }else if (d.status === 7) { 
 | 
                                return '<span style="color:green;">已取消</span>' 
 | 
                            }else{ 
 | 
                                return '' 
 | 
                            } 
 | 
                        }, minWidth: 80,align:'center'}, 
 | 
                        {field: 'carriage', title: '运费', minWidth: 120,align:'left'}, 
 | 
                        {field: 'orderTime', title: '下单时间', minWidth: 200,align:'left'}, 
 | 
                        {field: 'payMethod', title: '支付方式', minWidth: 120,align:'left'}, 
 | 
                        {field: 'payTime', title: '支付时间', minWidth: 200,align:'left'}, 
 | 
                        {field: 'payOrderNo', title: '支付订单号', minWidth: 200,align:'left'}, 
 | 
                        {title: '操作', 
 | 
                            templet: function (d) { 
 | 
                                    if (d.status === 2) { 
 | 
                                        if(d.deliverType ===2){ 
 | 
                                            return '<button class="layui-btn layui-btn-normal layui-btn-xs layui-btn-success" lay-event="takeGoods" shiro:hasPermission="user:update">自提</button>' 
 | 
                                            +'<button class="layui-btn layui-btn-normal layui-btn-xs" lay-event="seeOrder" shiro:hasPermission="user:update">详情</button>' 
 | 
                                        }else{ 
 | 
                                            return '<button class="layui-btn layui-btn-normal layui-btn-xs layui-btn-success" lay-event="deliverGoods" shiro:hasPermission="user:update">发货</button>' 
 | 
                                                +'<button class="layui-btn layui-btn-normal layui-btn-xs" lay-event="seeOrder" shiro:hasPermission="user:update">详情</button>' 
 | 
                                        } 
 | 
                                    }else if(d.status === 7){ 
 | 
                                        return '<button class="layui-btn layui-btn-normal layui-btn-xs" lay-event="seeOrder" shiro:hasPermission="user:update">详情</button>' 
 | 
                                            +'<button class="layui-btn layui-btn-xs layui-btn-normal layui-btn-danger" lay-event="delOrder" shiro:hasPermission="user:update">删除</button>' 
 | 
                                    }else{ 
 | 
                                        return '<button class="layui-btn layui-btn-normal layui-btn-xs " lay-event="seeOrder" shiro:hasPermission="user:update">详情</button>' 
 | 
                                    } 
 | 
                                // } 
 | 
                            },minWidth: 200,align:'center', fixed:'right'} 
 | 
                ]] 
 | 
            }); 
 | 
        } 
 | 
  
 | 
        // 获取查询参数 
 | 
        function getQueryParams() { 
 | 
            let startTimestr = $searchForm.find('input[name="startTime"]').val().trim(); 
 | 
            let endTimeStr = $searchForm.find('input[name="endTime"]').val().trim(); 
 | 
            if(startTimestr != '' && endTimeStr != '' && startTimestr >= endTimeStr){ 
 | 
                febs.alert.warn('开始时间需要小于结束时间'); 
 | 
                return{}; 
 | 
            } 
 | 
            return { 
 | 
                startTime: $searchForm.find('input[name="startTime"]').val().trim(), 
 | 
                endTime: $searchForm.find('input[name="endTime"]').val().trim(), 
 | 
                name: $searchForm.find('input[name="name"]').val().trim(), 
 | 
                orderNo: $searchForm.find('input[name="orderNo"]').val().trim(), 
 | 
                goodsName: $searchForm.find('input[name="goodsName"]').val().trim(), 
 | 
                payResult: $searchForm.find("select[name='payResult']").val(), 
 | 
                status: $searchForm.find("select[name='status']").val(), 
 | 
            }; 
 | 
        } 
 | 
  
 | 
        /* 
 | 
         * layui打印表格自定义函数 
 | 
         */ 
 | 
        function print(tablelayid) { 
 | 
            var v = document.createElement("div"); 
 | 
            var f = ["<head>", "<style>", "body{font-size: 12px; color: #666;}", 
 | 
                "table{width: 100%; border-collapse: collapse; border-spacing: 0;}", 
 | 
                "th,td{line-height: 20px; padding: 9px 15px; border: 1px solid #ccc; text-align: left; font-size: 12px; color: #666;}", 
 | 
                "a{color: #666; text-decoration:none;}", "*.layui-hide{display: none}", "</style>", "</head>" 
 | 
            ].join(""); 
 | 
            $(v).append($(".layui-table-box").find(".layui-table-header").html()); 
 | 
            $(v).find("tr").after($("[lay-id=\"" + tablelayid + "\"] .layui-table-body.layui-table-main table").html()); 
 | 
            $(v).find("th.layui-table-patch").remove(); 
 | 
            $(v).find(".layui-table-col-special").remove(); 
 | 
            var h = window.open("打印窗口", "_blank"); 
 | 
            h.document.write(f + $(v).prop("outerHTML")); 
 | 
            h.document.close(); 
 | 
            h.print(); 
 | 
            h.close(); 
 | 
        } 
 | 
  
 | 
        /* 监听打印选中行按钮 */ 
 | 
        $('#printSelect').click(function() { 
 | 
            layui.use(['table', 'layer'], function() { 
 | 
                var table = layui.table, 
 | 
                    layer = layui.layer; 
 | 
  
 | 
                var checkStatus = table.checkStatus('orderTable') 
 | 
                console.log(checkStatus) 
 | 
                // 判断是否选中数据 
 | 
                if (checkStatus.data.length === 0) { 
 | 
                    layer.msg('请选择数据', { 
 | 
                        icon: 2 
 | 
                    }) 
 | 
                } else { 
 | 
                    printSelect(checkStatus.data) 
 | 
                } 
 | 
            }) 
 | 
        }) 
 | 
        /* 
 | 
         * [自定义打印选中行数据] 
 | 
         * @param  {[type]}  allData [传入选中行] 
 | 
         */ 
 | 
        function printSelect(allData) { 
 | 
            //用于包含内容 
 | 
            var v = document.createElement("div"); 
 | 
            //页面头部,导入css  ,media="print"表示打印时使用该样式 
 | 
            var f = ["<head>", "<style>", "div{font-size:16px;}", ".main{width:100%;height:100%}", 
 | 
                ".main div{width:100%;display:inline-block;}", "</style>", "</head>" 
 | 
            ].join(""); 
 | 
            var contentHtml = ""; 
 | 
            for (let i = 0; i < allData.length; i++) { 
 | 
                let statusStr = ''; 
 | 
                let data = allData[i] 
 | 
                if (data.status === 1) { 
 | 
                    statusStr = "待支付"; 
 | 
                } else if (data.status === 2) { 
 | 
                    statusStr = "待发货"; 
 | 
                }else if (data.status === 3) { 
 | 
                    statusStr = "待收货"; 
 | 
                }else if (data.status === 4) { 
 | 
                    statusStr = "已完成"; 
 | 
                }else if (data.status === 5) { 
 | 
                    statusStr = "退款中"; 
 | 
                    return '<span style="color:green;">退款中</span>' 
 | 
                }else if (data.status === 6) { 
 | 
                    statusStr = "已退款"; 
 | 
                    return '<span style="color:green;">已退款</span>' 
 | 
                }else if (data.status === 7) { 
 | 
                    statusStr = "已取消"; 
 | 
                }else{ 
 | 
                    statusStr = ""; 
 | 
                } 
 | 
  
 | 
                let payTimeStr = ''; 
 | 
                if(data.payTime == '' || data.payTime == null){ 
 | 
                    payTimeStr = ""; 
 | 
                }else{ 
 | 
                    payTimeStr = data.payTime; 
 | 
                } 
 | 
  
 | 
                let payMethodStr = ''; 
 | 
                if(data.payMethod == '' || data.payMethod == null){ 
 | 
                    payMethodStr = ""; 
 | 
                }else{ 
 | 
                    payMethodStr = data.payMethod; 
 | 
                } 
 | 
                var template = 
 | 
                    "<div class='main'>" + 
 | 
                    "<div style='text-align: center;font-size: 22px;font-weight: bold;margin-bottom: 30px'>订单详情</div>" + 
 | 
                    "<div>编号:" + data.orderNo + "</div><br><br>" + 
 | 
                    "<div>商品:" + data.goodsName + "</div><br><br>" + 
 | 
                    "<div>金额:" + data.amount + "</div><br><br>" + 
 | 
                    "<div>账号:" + data.memberPhone + "</div><br><br>" + 
 | 
                    "<div>购买人:" + data.memberName + "</div><br><br>" + 
 | 
                    "<div>联系方式:" + data.memberBindPhone + "</div><br><br>" + 
 | 
                    "<div>地址:" + data.address + "</div><br><br>" + 
 | 
                    "<div>状态:" + statusStr + "</div><br><br>" + 
 | 
                    "<div>下单时间:" + payTimeStr + "</div><br><br>" + 
 | 
                    "<div>支付方式:" + payMethodStr + "</div><br><br>" + 
 | 
                    "<div>备注:" + data.remark + "</div><br><br>" + 
 | 
                    "</div>" 
 | 
  
 | 
                contentHtml += template; 
 | 
            } 
 | 
  
 | 
            //contentHtml为已拼凑好的内容 
 | 
            $(v).append(contentHtml) 
 | 
            //新建窗口 
 | 
            var h = window.open("打印窗口", "_blank"); 
 | 
            //写入拼凑内容 
 | 
            h.document.write(f + $(v).prop("outerHTML")); 
 | 
            //调用打印 
 | 
            h.print(); 
 | 
            //关闭页面 
 | 
            h.close(); 
 | 
        } 
 | 
  
 | 
    }) 
 | 
</script> 
 |