From 50456bf27ba8e0a121b8cbf950a3c821264e5dcf Mon Sep 17 00:00:00 2001
From: KKSU <15274802129@163.com>
Date: Mon, 25 Dec 2023 15:51:05 +0800
Subject: [PATCH] 富文本框输入版本变化
---
 src/main/resources/templates/febs/views/modules/order/orderList.html |  252 ++++++++++++++++++++++++++++++++++++++++++++-----
 1 files changed, 223 insertions(+), 29 deletions(-)
diff --git a/src/main/resources/templates/febs/views/modules/order/orderList.html b/src/main/resources/templates/febs/views/modules/order/orderList.html
index 565bdba..1c8c545 100644
--- a/src/main/resources/templates/febs/views/modules/order/orderList.html
+++ b/src/main/resources/templates/febs/views/modules/order/orderList.html
@@ -42,10 +42,10 @@
                                 <div class="layui-inline">
                                     <label class="layui-form-label layui-form-label-sm">配送方式</label>
                                     <div class="layui-input-inline">
-                                        <select name="deliveryType">
+                                        <select name="isHome">
                                             <option value="">请选择</option>
-                                            <option value="1">自提</option>
-                                            <option value="2">快递</option>
+                                            <option value="1">送货上门</option>
+                                            <option value="2">自提</option>
                                         </select>
                                     </div>
                                 </div>
@@ -58,6 +58,20 @@
                                             <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>
 
@@ -100,6 +114,10 @@
 <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="exportDeliverOne">导出待发货订单,系统自动发货</button>
+        <button class="layui-btn layui-btn-sm layui-btn-primary febs-button-blue-plain" lay-event="confirmOrder">确认到货</button>
+        <button class="layui-btn layui-btn-sm layui-btn-primary febs-button-blue-plain" lay-event="printSelect">自定义打印</button>
+        <button class="layui-btn layui-btn-sm layui-btn-primary febs-button-blue-plain" lay-event="goodsStatistics">统计商品份数</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="exportDeliverTwo">导出未发货订单(快递)</button>-->
 <!--        <button class="layui-btn layui-btn-sm layui-btn-primary febs-button-blue-plain" id="importDeliver" lay-event="importDeliver">导入发货</button>-->
     </div>
@@ -107,7 +125,7 @@
 <!-- 表格操作栏 end -->
 <script data-th-inline="none" type="text/javascript">
     // 引入组件并初始化
-    layui.use([ 'jquery', 'form', 'table', 'febs', 'formSelects', 'upload'], function () {
+    layui.use([ 'jquery', 'form', 'table', 'febs', 'formSelects', 'upload','laydate'], function () {
         var $ = layui.jquery,
             febs = layui.febs,
             form = layui.form,
@@ -120,7 +138,18 @@
             $add = $view.find('#add'),
             sortObject = {field: 'phone', type: null},
             formSelects = layui.formSelects,
+            laydate = layui.laydate,
             tableIns;
+
+        //日期范围
+        laydate.render({
+            elem: '#febs-form-group-date-start'
+        });
+
+        laydate.render({
+            elem: '#febs-form-group-date-end'
+        });
+
 
         form.render();
 
@@ -142,13 +171,101 @@
 
         table.on('toolbar(orderTable)', function(obj){
             var event = obj.event;
+            var id = obj.config.id;
+            var checkStatus = table.checkStatus(id);
+            if(event === 'printSelect'){
+                var checkStatus = table.checkStatus('orderTable')
+                console.log(checkStatus)
+                // 判断是否选中数据
+                if (checkStatus.data.length === 0) {
+                    layer.msg('请选择数据', {
+                        icon: 2
+                    })
+                } else {
+                    printSelect(checkStatus.data)
+                }
+            }
+            if(event === 'goodsStatistics'){
+                var data = checkStatus.data;
+                let statistics = 0;
+                for(let i = 0;i < data.length;i++){
+                        statistics = statistics+ "," + data[i].id;
+                }
+                if(statistics == null || statistics == ""){
+                    febs.alert.warn('请选择需要统计的订单');
+                    return;
+                }
+                febs.modal.open( '商品数量统计', 'modules/order/goodsStatistics/'+statistics, {
+                    maxmin: true,
+                });
+                // febs.get(ctx + 'admin/order/goodsStatistics?orderIds='+ids, null, function () {
+                //     febs.alert.success('操作成功');
+                //     $query.click();
+                // });
+                // window.location.href = ctx + "admin/order/confirmOrder?takeUniqueCode="+uniqueCodeValue+"&orderIds="+ids;
+            }
+            if(event === 'confirmOrder'){
+                let uniqueCodeValue = $searchForm.find("select[name='uniqueCode']").val();
+                // if(uniqueCodeValue == '' || uniqueCodeValue == null){
+                //     febs.alert.warn('请选择团长');
+                //     return;
+                // }
+                var data = checkStatus.data;
+                let ids = "";
+                for(let i = 0;i < data.length;i++){
+                    if(data[i].status != 3){
+                        febs.alert.warn('请选择待收货的订单');
+                        return;
+                    }else if(data[i].deliveryState != 2){
+                        febs.alert.warn('请选择配送中的订单');
+                        return;
+                    }else{
+                        ids = ids + data[i].id+",";
+                    }
+                }
+                // layer.alert(layui.util.escape(JSON.stringify(data)));
+                console.log(ids);
+                if(ids == null || ids == ""){
+                    febs.alert.warn('请选择确认到货的订单');
+                    return;
+                }
+                febs.get(ctx + 'admin/order/confirmOrder?takeUniqueCode='+uniqueCodeValue+'&orderIds='+ids, null, function () {
+                    febs.alert.success('操作成功');
+                    $query.click();
+                });
+                // window.location.href = ctx + "admin/order/confirmOrder?takeUniqueCode="+uniqueCodeValue+"&orderIds="+ids;
+            }
             if (event == 'exportDeliverOne') {
                 let uniqueCodeValue = $searchForm.find("select[name='uniqueCode']").val();
                 if(uniqueCodeValue == '' || uniqueCodeValue == null){
                     febs.alert.warn('请选择团长');
                     return;
                 }
-                window.location.href = ctx + "admin/order/exportOrderListOne?orderType=1&status=2&deliveryType=1&takeUniqueCode="+uniqueCodeValue;
+                var data = checkStatus.data;
+                let ids = "";
+                for(let i = 0;i < data.length;i++){
+                    if(data[i].status != 2){
+                        febs.alert.warn('请选择待发货的订单');
+                        return;
+                    }else if(data[i].deliveryState != 1){
+                        febs.alert.warn('请选择待配送的订单');
+                        return;
+                    }else{
+                        ids = ids + data[i].id+",";
+                    }
+                }
+                // layer.alert(layui.util.escape(JSON.stringify(data)));
+                console.log(ids);
+                if(ids == null || ids == ""){
+                    febs.alert.warn('请选择待发货的订单');
+                    return;
+                }
+                window.location.href = ctx + "admin/order/exportOrderListOne?orderType=1&status=2&deliveryType=1&takeUniqueCode="+uniqueCodeValue+'&orderIds='+ids;
+                febs.get(ctx + 'admin/order/deliverOrder?takeUniqueCode='+uniqueCodeValue+'&orderIds='+ids, null, function () {
+                    febs.alert.success('操作成功');
+                    $query.click();
+
+                });
             }
 
             if (event == 'exportDeliverTwo') {
@@ -169,17 +286,6 @@
         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 === 'deliverGoods') {
                 febs.modal.open('发货', 'modules/order/deliverGoods/' + data.id, {
                     btn: ['确认', '取消'],
@@ -250,23 +356,25 @@
                 defaultToolbar: [],
                 toolbar: '#tableToolBar',
                 cols: [[
+                        {type: 'checkbox', fixed: 'left'},
                         {field: 'orderNo', title: '订单编号', minWidth: 200,align:'left'},
-                        {field: 'memberName', title: '购买人', minWidth: 120,align:'left'},
+                        {field: 'memberName', title: '购买人', minWidth: 100,align:'left'},
                         {field: 'memberPhone', title: '联系方式', minWidth: 120,align:'left'},
                         // {field: 'memberBindPhone', title: '联系方式', minWidth: 120,align:'left'},
-                        {field: 'amount', title: '订单金额', minWidth: 120,align:'left'},
-                        // {field: 'carriage', title: '运费', minWidth: 120,align:'left'},
+                        {field: 'goodsName', title: '商品', minWidth: 160,align:'left'},
+                        {field: 'amount', title: '订单金额', minWidth: 80,align:'left'},
+                        {field: 'leaderName', title: '团长', minWidth: 120,align:'left'},
                         {field: 'orderTime', title: '下单时间', minWidth: 200,align:'left'},
-                        {field: 'deliveryType', title: '配送方式',
+                        {field: 'isHome', title: '配送方式',
                             templet: function (d) {
-                                if (d.deliveryType === 1) {
+                                if (d.isHome === 2) {
                                     return '<span style="color:dodgerblue;">自提</span>'
-                                } else if (d.deliveryType === 2) {
-                                    return '<span style="color:forestgreen;">快递</span>'
+                                } else if (d.isHome === 1) {
+                                    return '<span style="color:forestgreen;">送货上门</span>'
                                 }else{
                                     return ''
                                 }
-                            }, minWidth: 120,align:'center'},
+                            }, minWidth: 100,align:'center'},
                         {field: 'status', title: '状态',
                             templet: function (d) {
                                 if (d.status === 1) {
@@ -298,10 +406,10 @@
                             }else{
                                 return ''
                             }
-                        }, minWidth: 120,align:'center'},
-                        {field: 'payMethod', title: '支付方式', minWidth: 120,align:'left'},
-                        {field: 'payTime', title: '支付时间', minWidth: 200,align:'left'},
-                        {field: 'wxOrderNo', title: '支付订单号', minWidth: 200,align:'left'},
+                        }, minWidth: 80,align:'center'},
+                        {field: 'payMethod', title: '支付方式', minWidth: 100,align:'left'},
+                        {field: 'payTime', title: '支付时间', minWidth: 120,align:'left'},
+                        {field: 'wxOrderNo', title: '支付订单号', minWidth: 120,align:'left'},
                         {title: '操作',
                             templet: function (d) {
                                         return '<button class="layui-btn layui-btn-normal layui-btn-xs" lay-event="seeOrder" shiro:hasPermission="user:update">详情</button>'
@@ -312,15 +420,101 @@
 
         // 获取查询参数
         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(),
                 payResult: $searchForm.find("select[name='payResult']").val(),
                 status: $searchForm.find("select[name='status']").val(),
-                deliveryType: $searchForm.find("select[name='deliveryType']").val(),
+                isHome: $searchForm.find("select[name='isHome']").val(),
                 uniqueCode: $searchForm.find("select[name='uniqueCode']").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:8px;}", ".main{width:100%;height:20%}",
+                ".main div{width:100%;display:inline-block;}", "</style>", "</head>"
+            ].join("");
+            var contentHtml = "";
+            for (let i = 0; i < allData.length; i++) {
+                let data = allData[i]
+                var template =
+                    "<div class='main'>" +
+                    // "<div style='text-align: center;font-size: 22px;font-weight: bold;margin-bottom: 30px'>订单详情</div>" +
+                    "<div>姓名:" + data.name + "</div><br><br>" +
+                    "<div>电话:" + data.phone + "</div><br><br>" +
+                    "<div>地址:" + data.address + "</div><br><br>" +
+                    "<div>编号:" + data.orderNo + "</div><br><br>" +
+                    "<div>商品:" + data.goodsName + "</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>
\ No newline at end of file
--
Gitblit v1.9.1