Explorar el Código

新增帆布袋,外卖盒,方巾

zhuyiyi hace 2 meses
padre
commit
1633d9b102

+ 136 - 0
src/main/java/lingtao/net/service/ProductService.java

@@ -4741,12 +4741,148 @@ public class ProductService {
                 return getbadgePrice(dto, width, length);
                 return getbadgePrice(dto, width, length);
             case "冰箱贴":
             case "冰箱贴":
                 return getfridgePrice(dto, width, length);
                 return getfridgePrice(dto, width, length);
+            case "帆布袋":
+                return getCanvasBagPrice(dto, width, length);
+            case "外卖盒":
+                return getTakeoutBoxPrice(dto, width, length);
+            case "方巾纸":
+                return getHandkerPrice(dto, width, length);
             default:
             default:
                 break;
                 break;
         }
         }
         return null;
         return null;
     }
     }
 
 
+    private List<Product> getHandkerPrice(Product dto, Double width, Double length) {
+        List<String> carft_list = dto.getCraft() == null ? new ArrayList<>() : Arrays.asList(dto.getCraft());
+        List<Product> priceList = new ArrayList<>();
+        int maxCount = 10;
+        int count = dto.getCount();
+        int number = dto.getNumber();
+        int[] counts = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
+        int base = 0;
+        if (width == 23) {
+            base = 1;
+        }
+        if (width == 27) {
+            base = 2;
+        }
+        double[][] prices = {
+                {118, 236, 350, 450, 480, 576, 672, 768, 864, 900},
+                {0, 0, 340, 450, 570, 684, 798, 912, 1026, 1040},
+                {0, 0, 350, 460, 810, 972, 1134, 1296, 1458, 1780},
+        };
+        Product pro = new Product();
+
+        for (int i = 0; i < counts.length; i++) {
+            int itemCount = counts[i];
+            if (itemCount < count) {
+                continue;
+            }
+            if (priceList.size() > 2) {
+                break;
+            }
+            pro = new Product();
+            pro.setCount(itemCount);
+            pro.setPrice(Math.ceil(prices[base][i] * number));
+            pro.setNumber(number);
+            priceList.add(pro);
+        }
+        if (priceList.size() == 0 && count > maxCount) {
+            double basePrice = prices[base][prices[base].length - 1];
+            pro = new Product();
+            pro.setCount(count);
+            pro.setPrice(Math.ceil(basePrice / maxCount * count * number));
+            pro.setNumber(number);
+            priceList.add(pro);
+        }
+
+        return priceList;
+    }
+
+    private List<Product> getTakeoutBoxPrice(Product dto, Double width, Double length) {
+        List<String> carft_list = dto.getCraft() == null ? new ArrayList<>() : Arrays.asList(dto.getCraft());
+        List<Product> priceList = new ArrayList<>();
+        int count = dto.getCount();
+        int number = dto.getNumber();
+        double[] prices = {2500, 4800, 7200, 12000};
+
+        if (dto.getPcount() == 3) {
+            prices = new double[]{6000, 12000, 18000, 27000};
+        }
+        if (dto.getPcount() == 4) {
+            prices = new double[]{3600, 7200, 10800, 17750};
+        }
+
+        int[] counts = {10000, 20000, 30000, 50000};
+        Product pro = new Product();
+        for (int i = 0; i < counts.length; i++) {
+            if (counts[i] < count) {
+                continue;
+            }
+            pro = new Product();
+            pro.setCount(counts[i]);
+            pro.setPrice(Math.ceil(prices[i] * number));
+            pro.setNumber(number);
+            priceList.add(pro);
+        }
+        return priceList;
+    }
+
+    private double getListNumber(int[] counts, int count, double[] numbers) {
+        for (int j = 0; j < counts.length; j++) {
+            if (counts[j] <= count) {
+                continue;
+            }
+            return numbers[j];
+        }
+        return 0.0;
+    }
+
+    private List<Product> getCanvasBagPrice(Product dto, Double width, Double length) {
+        List<String> carft_list = dto.getCraft() == null ? new ArrayList<>() : Arrays.asList(dto.getCraft());
+        List<Product> priceList = new ArrayList<>();
+        int count = dto.getCount();
+        //布钱
+        int[] counts = {5, 10, 20, 30, 50, 100, 200, 500, 1000, 5000, 10000};
+        double[][] unit_prices = {
+                {50, 34, 18, 12, 7.9, 4.5, 4, 3.6, 3.5, 3.3, 3},
+                {50, 35, 19, 13, 7.9, 4.4, 4.2, 3.6, 3.3, 3.1, 3},
+                {55, 38, 22, 15, 9.2, 4.8, 4.5, 4, 3.6, 3.4, 3.3}
+        };
+        int base = 2;
+        if (width <= 27 && length <= 33 || length <= 27 && width <= 33) {
+            base = 0;
+        }
+        if (width <= 30 && length <= 35 || length <= 30 && width <= 35) {
+            base = 1;
+        }
+        int number = dto.getNumber();
+        //布钱 +人工+印刷+手提
+        Product pro = null;
+        for (int i = 0; i < counts.length; i++) {
+            int itemCount = counts[i];
+            if (itemCount < count) {
+                continue;
+            }
+            if (priceList.size() > 2) {
+                break;
+            }
+            if (priceList.size() == 0 && itemCount != count) {
+                pro = new Product();
+                pro.setCount(count);
+                pro.setPrice(Math.ceil(unit_prices[base][i] * count * number));
+                priceList.add(pro);
+            }
+            pro = new Product();
+            pro.setCount(itemCount);
+            pro.setPrice(Math.ceil(unit_prices[base][i] * itemCount * number));
+            priceList.add(pro);
+
+        }
+        return priceList;
+    }
+
     private List<Product> getfridgePrice(Product dto, Double width, Double length) {
     private List<Product> getfridgePrice(Product dto, Double width, Double length) {
         List<String> carft_list = dto.getCraft() == null ? new ArrayList<>() : Arrays.asList(dto.getCraft());
         List<String> carft_list = dto.getCraft() == null ? new ArrayList<>() : Arrays.asList(dto.getCraft());
         List<Product> priceList = new ArrayList<>();
         List<Product> priceList = new ArrayList<>();

+ 71 - 42
src/main/webapp/views/product/badge.jsp

@@ -79,7 +79,7 @@
                        class="layui-input">
                        class="layui-input">
             </div>
             </div>
             <p>
             <p>
-                工艺
+                工艺<span style="font-size: 14px; color: red">PET印刷只能做固定3*3cm尺寸</span>
             </p>
             </p>
             <div class="layui-form-item" id='z4_craft'>
             <div class="layui-form-item" id='z4_craft'>
                 <div class="layui-input-block">
                 <div class="layui-input-block">
@@ -93,7 +93,9 @@
                     底托颜色:
                     底托颜色:
                     <input type="checkbox" name="craft" lay-filter="ui_craft" value="金色" title="金色" checked>
                     <input type="checkbox" name="craft" lay-filter="ui_craft" value="金色" title="金色" checked>
                     <input type="checkbox" name="craft" lay-filter="ui_craft" value="银色" title="银色">
                     <input type="checkbox" name="craft" lay-filter="ui_craft" value="银色" title="银色">
-                    <input type="checkbox" name="craft" lay-filter="ui_craft" value="黑色" title="黑色">
+                    <span style="display: none">
+                        <input type="checkbox" name="craft" lay-filter="ui_craft" value="黑色" title="黑色">
+                    </span>
                 </div>
                 </div>
                 <div class="layui-input-block">
                 <div class="layui-input-block">
                     配件:
                     配件:
@@ -151,7 +153,8 @@
         if (craft_list.includes("UV印刷")) {
         if (craft_list.includes("UV印刷")) {
             remark = "预计发货时间:<br>发货地:浙江    <br>快递:中通  顺丰特快 <br>10-12天发货";
             remark = "预计发货时间:<br>发货地:浙江    <br>快递:中通  顺丰特快 <br>10-12天发货";
         }
         }
-        $("#remark").empty().append(remark);
+        $("#remark").empty();
+        $("#remark").append(remark);
     }
     }
 
 
     layui.use(['table', 'form', 'carousel'], function () {
     layui.use(['table', 'form', 'carousel'], function () {
@@ -162,50 +165,60 @@
 
 
         //建造实例
         //建造实例
         ins = carousel.render({});
         ins = carousel.render({});
-        var html = " ";
-        var remark = " ";
-        const carft_list1 = ["金色", "银色"];
+
+        const carft_list1 = ["金色", "银色", "黑色"];
 
 
         const carft_list2 = ["别针", "蝴蝶扣", "磁铁"];
         const carft_list2 = ["别针", "蝴蝶扣", "磁铁"];
 
 
         const carft_list3 = ["UV印刷", "PET印刷"];
         const carft_list3 = ["UV印刷", "PET印刷"];
-        // 清空轮播图
-        $("#carousel").empty();
-        $("#remark").empty();
-        $(".ui_feb").show();
-        $(".ui_feb select").attr("disabled", false);
-        $.ajax({
-            url: "${pageContext.request.contextPath}/getImgs",
-            type: "GET",
-            data: {
+        getImages()
+
+        function getImages() {
+            // 清空轮播图
+            let html = " ";
+            let remark = " ";
+            $("#carousel").empty();
+            $("#remark").empty();
+            $(".ui_feb").show();
+            $(".ui_feb select").attr("disabled", false);
+            let params = {
                 proTypeValue: $("#proTypeValue").val(),
                 proTypeValue: $("#proTypeValue").val(),
                 kindValue: $('input[name="kindValue"]').val()
                 kindValue: $('input[name="kindValue"]').val()
-            },
-            success: function (result) {
-                for (let i = 0; i < result.length; i++) {
-                    // 只留一个remark
-                    remark = "";
-                    html += '<div><img style="width:100%;height: 100%;object-fit: contain" src="' + result[i].imgUrl + '"></div>';
-                    remark += '<div><span>' + result[i].remark + '<span/></div>';
-                }
-                $("#carousel").append(html);
-                // 如果没有说明,就不显示null
-                if (remark.indexOf("null") < 0) {
-                    $("#remark").append(remark);
-                }
-                // 如果没有轮播图就隐藏
-                if (result.length == 0) {
-                    document.getElementById("test1").style.display = "none";   //隐藏
-                } else {
-                    document.getElementById("test1").style.display = "block";   //显示
-                    ins.reload({
-                        elem: '#test1',
-                        width: result[0].imgWidth,  //设置容器宽度
-                        height: result[0].imgHeight
-                    });
-                }
             }
             }
-        });
+            if ($("input[name='craft'][value='UV印刷']:checked").length > 0) {
+                params.craftValue = "UV";
+            }
+            $.ajax({
+                url: "${pageContext.request.contextPath}/getImgs",
+                type: "GET",
+                data: params,
+                success: function (result) {
+                    for (let i = 0; i < result.length; i++) {
+                        // 只留一个remark
+                        remark = "";
+                        html += '<div><img style="width:100%;height: 100%;object-fit: contain" src="' + result[i].imgUrl + '"></div>';
+                        remark = '<div><span>' + result[0].remark + '<span/></div>';
+                    }
+                    $("#carousel").append(html);
+                    // 如果没有说明,就不显示null
+                    if (remark.indexOf("null") < 0) {
+                        $("#remark").append(remark);
+                    }
+                    // 如果没有轮播图就隐藏
+                    if (result.length == 0) {
+                        document.getElementById("test1").style.display = "none";   //隐藏
+                    } else {
+                        document.getElementById("test1").style.display = "block";   //显示
+                        ins.reload({
+                            elem: '#test1',
+                            width: result[0].imgWidth,  //设置容器宽度
+                            height: result[0].imgHeight
+                        });
+                    }
+                }
+            });
+        }
+
         form.on('select(kind)', function (val) {
         form.on('select(kind)', function (val) {
             $("input[name='craft'][value='UV印刷']").prop("checked", true);
             $("input[name='craft'][value='UV印刷']").prop("checked", true);
             $("input[name='craft'][value='PET印刷']").parent().show();
             $("input[name='craft'][value='PET印刷']").parent().show();
@@ -216,7 +229,8 @@
                 $("input[name='craft'][value='PET印刷']").prop("disabled", true);
                 $("input[name='craft'][value='PET印刷']").prop("disabled", true);
             }
             }
             form.render();
             form.render();
-            changeRemark()
+            getImages()
+            // changeRemark()
         })
         })
         form.on("select(count_select)", function (val) {
         form.on("select(count_select)", function (val) {
             $("#count").val(val.value);
             $("#count").val(val.value);
@@ -249,10 +263,25 @@
                 form.render();
                 form.render();
                 return false;
                 return false;
             }
             }
+            if (data.value == "UV印刷") {
+
+                $("input[name='craft'][value='黑色']").parent().show();
+                $("input[name='craft'][value='黑色']").prop("disabled", false);
+            }
+            if (data.value == "PET印刷") {
+                $("input[name='craft'][value='金色']").prop("checked", true);
+                $("input[name='craft'][value='银色']").prop("checked", false);
+                $("input[name='craft'][value='黑色']").parent().hide();
+                $("input[name='craft'][value='黑色']").prop("disabled", true);
+
+                $("input[name='craft'][value='黑色']").prop("checked", false);
+            }
             if (craft_list.includes("PET印刷") > 0) {
             if (craft_list.includes("PET印刷") > 0) {
                 $("#size").val("3*3")
                 $("#size").val("3*3")
             }
             }
-            changeRemark()
+            getImages();
+            form.render();
+            // changeRemark()
         })
         })
         form.on('checkbox(peijian)', function (data) {
         form.on('checkbox(peijian)', function (data) {
             let craft_list = [];
             let craft_list = [];

+ 395 - 0
src/main/webapp/views/product/canvasBag.jsp

@@ -0,0 +1,395 @@
+<%@ page language="java" contentType="text/html; charset=UTF-8"
+         pageEncoding="UTF-8" %>
+<%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
+<!DOCTYPE html>
+<html>
+<head>
+    <meta charset="UTF-8">
+    <title>Insert title here</title>
+    <%@include file="/views/common.jsp" %>
+</head>
+<body>
+<style>
+    #z4_craft .layui-form-select .layui-edge {
+        right: 20px;
+    }
+</style>
+<div class="big_box">
+    <div class="left_div">
+        <h1 class="h1">帆布袋</h1> <span style="color:red;font-weight:700;"></span>
+        <hr>
+        <form class="layui-form">
+            <input type="hidden" name="proTypeValue" id="proTypeValue" class="layui-input" value="帆布袋"/>
+            <p>
+                材质
+            </p>
+            <div class="layui-form-item">
+                <select name="kind" class="select" lay-search lay-filter="kind">
+                    <option value="1">帆布袋</option>
+                </select>
+            </div>
+            <div class="layui-form-item">
+                <div class="layui-input-inline">
+                    <p>
+                        宽:
+                    </p>
+                    <div class="layui-form-item">
+                        <input type="text" name="width" id="width" class="layui-input" autocomplete="off">
+                    </div>
+                </div>
+                <div class="layui-input-inline">
+                    <p>
+                        高:
+                    </p>
+                    <div class="layui-form-item">
+                        <input type="text" name="length" id="length" class="layui-input" autocomplete="off">
+                    </div>
+                </div>
+            </div>
+
+            <p>
+                数量(个)
+            </p>
+            <div class="layui-form-item">
+                <input type="text" name="count" id="count" class="layui-input">
+            </div>
+            <p>
+                款数
+            </p>
+            <div class="layui-form-item">
+                <input type="text" placeholder="请输入整数" autocomplete="off" name="number" id="number" value="1"
+                       class="layui-input" lay-verify="number">
+            </div>
+            <p>
+                款式
+            </p>
+            <div class="layui-form-item">
+                <select name="notePaperKind" class="select" lay-search lay-filter="kind">
+                    <option value="无底无侧">无底无侧</option>
+                </select>
+            </div>
+            <p>
+                客户旺旺
+            </p>
+            <div class="layui-form-item">
+                <input type="text" placeholder="请输入客户旺旺号" autocomplete="off" name="wangwang" id="wangwang"
+                       class="layui-input">
+            </div>
+            <p>
+                工艺
+            </p>
+            <div class="layui-form-item" id='z4_craft'>
+                <div class="layui-input-block">
+                    印刷工艺:
+                    <input type="checkbox" name="craft" lay-filter="ui_craft" value="彩色印刷" title="彩色印刷" checked>
+
+                </div>
+                <div class="layui-input-block">
+                    印面工艺:
+                    <input type="checkbox" name="craft" lay-filter="ui_craft" value="单面" title="单面" checked>
+                    <input type="checkbox" name="craft" lay-filter="ui_craft" value="双面" title="双面">
+                </div>
+                <div class="layui-input-block">
+                    布料颜色:
+                    <input type="checkbox" name="craft" lay-filter="ui_craft" value="纯白色" title="纯白色" checked>
+                    <input type="checkbox" name="craft" lay-filter="ui_craft" value="米黄色" title="米黄色">
+                </div>
+                <div class="layui-input-block">
+                    配件:
+                    <input type="checkbox" class="peijian" name="craft" lay-filter="peijian" value="帆布绳"
+                           title="帆布绳" checked>
+                    <input type="checkbox" class="peijian" name="craft" lay-filter="peijian" value="织带绳"
+                           title="织带绳">
+                    <span class="layui-inline" style="width: 200px;display: none ">
+                        <select name="s_color">
+                            <option value="红色">红色</option>
+                            <option value="蓝色">蓝色</option>
+                            <option value="绿色">绿色</option>
+                            <option value="黄色">黄色</option>
+                            <option value="黑色">黑色</option>
+                            <option value="橙色">橙色</option>
+                            <option value="粉色">粉色</option>
+                        </select>
+                    </span>
+                </div>
+            </div>
+            <hr>
+            <div class="layui-form-item">
+                <button class="layui-btn" lay-submit="" lay-filter="acount_btn">计算</button>
+                <button type="reset" class="layui-btn layui-btn-primary">重置</button>
+            </div>
+            <h2>计算结果-
+                <button type="button" class="layui-btn layui-btn-primary layui-btn-sm copyResult"
+                        onclick="copyResult()">点击复制
+                </button>
+            </h2>
+            <div>
+                <textarea rows="11" cols="75" id="span_result" readonly="readonly"></textarea>
+                <%@include file="../acountExpressFee.jsp" %>
+            </div>
+            <div>
+                <table class="layui-hide" id="priceTable" lay-filter="priceTable"></table>
+            </div>
+        </form>
+    </div>
+    <div class="right_div" style="margin-left:50px;">
+        <div class="layui-carousel" id="test1">
+            <div carousel-item id="carousel"></div>
+            <br>
+            <div id="remark" style="font-size:20px;color:red"></div>
+        </div>
+    </div>
+</div>
+</body>
+<%@include file="/views/copyResult.jsp" %>
+<script>
+
+    layui.use(['table', 'form', 'carousel'], function () {
+        var form = layui.form; //只有执行了这一步,部分表单元素才会自动修饰成功
+        var carousel = layui.carousel;
+        var table = layui.table;
+
+
+        //建造实例
+        ins = carousel.render({});
+        var html = " ";
+        var remark = " ";
+        const carft_list1 = ["单面", "双面"];
+
+        const carft_list2 = ["纯白色", "米黄色"];
+
+        const carft_list3 = ["帆布绳", "织带绳"];
+        // 清空轮播图
+        $("#carousel").empty();
+        $("#remark").empty();
+        $(".ui_feb").show();
+        $(".ui_feb select").attr("disabled", false);
+        $.ajax({
+            url: "${pageContext.request.contextPath}/getImgs",
+            type: "GET",
+            data: {
+                proTypeValue: $("#proTypeValue").val(),
+                kindValue: $('input[name="kindValue"]').val()
+            },
+            success: function (result) {
+                for (let i = 0; i < result.length; i++) {
+                    // 只留一个remark
+                    remark = "";
+                    html += '<div><img style="width:100%;height: 100%;object-fit: contain" src="' + result[i].imgUrl + '"></div>';
+                    remark += '<div><span>' + result[i].remark + '<span/></div>';
+                }
+                $("#carousel").append(html);
+                // 如果没有说明,就不显示null
+                if (remark.indexOf("null") < 0) {
+                    $("#remark").append(remark);
+                }
+                // 如果没有轮播图就隐藏
+                if (result.length == 0) {
+                    document.getElementById("test1").style.display = "none";   //隐藏
+                } else {
+                    document.getElementById("test1").style.display = "block";   //显示
+                    ins.reload({
+                        elem: '#test1',
+                        width: result[0].imgWidth,  //设置容器宽度
+                        height: result[0].imgHeight
+                    });
+                }
+            }
+        });
+
+        form.on('checkbox(ui_craft)', function (data) {
+            let craft_list = [];
+            craft_list.push($("select[name='craft'] option:selected").val());
+            $("input[name='craft']:checked").each(function () {
+                    if (!$(this).is(':disabled')) {
+                        craft_list.push($(this).val());
+                    }
+                }
+            );
+            if (!craft_list.includes("彩色印刷")) {
+                $(data.elem).prop("checked", true);
+                layer.msg("印刷工艺不能取消", {offset: ['300px', '300px']}, function () {
+                });
+                form.render();
+                return false;
+            }
+            const carft1 = carft_list1.filter(craft => craft_list.includes(craft));
+            if (carft1.length > 1) {
+                $(data.elem).prop("checked", false);
+                layer.msg("印面不能同时选择", {offset: ['300px', '300px']}, function () {
+                });
+                form.render();
+                return false;
+            }
+            const carft2 = carft_list2.filter(craft => craft_list.includes(craft));
+            if (carft2.length > 1) {
+                $(data.elem).prop("checked", false);
+                layer.msg("布料颜色工艺不能同时选择", {offset: ['300px', '300px']}, function () {
+                });
+                form.render();
+                return false;
+            }
+
+        })
+        form.on('checkbox(peijian)', function (data) {
+            let craft_list = [];
+            $(".peijian:checked").each(function () {
+                    if (!$(this).is(':disabled')) {
+                        craft_list.push($(this).val());
+                    }
+                }
+            );
+            const carft3 = carft_list3.filter(craft => craft_list.includes(craft));
+            if (carft3.length > 1) {
+                $(data.elem).next().attr("class", "layui-unselect layui-form-checkbox");
+                $(data.elem).prop("checked", false);
+                layer.msg('配件只能选择一种!', {offset: ['300px', '300px']}, {icon: 5});
+                form.render();
+                return false;
+            }
+            if (data.value == '织带绳') {
+                if (data.elem.checked) {
+                    $("select[name='s_color']").parent().show();
+                    $("select[name='s_color']").prop("disabled", false)
+                } else {
+                    $("select[name='s_color']").parent().hide();
+                    $("select[name='s_color']").prop("disabled", true)
+                }
+            }
+
+        })
+
+        // 点击计算,计算价格
+        form.on('submit(acount_btn)', function (data) {
+            var number = $("#number").val();
+            let width = $("#width").val();
+            let height = $("#length").val();
+            var size = width + "*" + height;
+            var count = $("#count").val();
+            var kind = $("select[name='kind'] option:selected").text();
+            var craft = [];
+
+            craft.push($("select[name='notePaperKind'] option:selected").val());
+            $("input:checkbox[name='craft']:checked").each(function (i) {
+                // 没有被禁用的工艺加到arr中
+                if (!$(this).is(':disabled')) {
+                    if ($(this).val() == '织带绳') {
+                        craft.push($(this).val());
+                        craft.push($("select[name='s_color'] option:selected").val() + $(this).val());
+                    } else {
+                        craft.push($(this).val());
+                    }
+                }
+            });
+            if ((width.split("*")[0] < 20 || width.split("*")[1] > 48)) {
+                layer.msg('宽度限于大于等于20CM小于等于48CM!', {offset: ['300px', '300px']}, function () {
+                });
+                return false;
+            }
+
+            const carft1 = carft_list1.filter(item => craft.includes(item));
+            if (carft1.length == 0) {
+                layer.msg("请选择印面工艺", {offset: ['300px', '300px']}, function () {
+                });
+                return false;
+            }
+            const carft2 = carft_list2.filter(item => craft.includes(item));
+            if (carft2.length == 0) {
+                layer.msg("请选择布料颜色", {offset: ['300px', '300px']}, function () {
+                });
+                return false;
+            }
+            const carft3 = carft_list3.filter(item => craft.includes(item));
+            if (carft3.length == 0) {
+                layer.msg("请选择配件", {offset: ['300px', '300px']}, function () {
+                });
+                return false;
+            }
+            craft = craft.filter(item => item != "织带绳")
+            $.ajax({
+                url: "${path}/getThanSum",
+                type: "GET",
+                data: $(".big_box form").serialize(),
+                success: function (result) {
+                    if (result.code == 100) {
+                        layer.msg(result.msg, {offset: ['300px', '300px']}, function () {
+                        });
+                        return false;
+                    }
+                    var data = result.data.proList;
+
+                    var span_result = '帆布袋 ' + ' - ' + size + ' CM (同款内容)\n';
+
+                    span_result += `工艺:` + craft.join(",") + '\n';
+
+                    if (number > 1) {
+                        for (let i = 0; i < data.length; i++) {
+                            span_result += number + '款 各' + data[i].count + "个,共" + data[i].price + "元" + '\n'
+                            data[i].number = number;
+                        }
+                    } else {
+                        for (let i = 0; i < data.length; i++) {
+                            span_result += number + '款 ' + data[i].count + "个,共" + data[i].price + "元" + '\n'
+                            data[i].number = number;
+                        }
+                    }
+
+                    span_result += '包邮,免费设计呢~(偏远地区需补邮费)'
+                    $("#span_result").val(span_result);
+
+                    //计算完自动复制文本
+                    var e = document.getElementById("span_result");//对象是content
+                    if (e.value != "") {
+                        e.select();//选择对象
+                        document.execCommand("Copy");//执行浏览器复制命令
+                    }
+
+                    //生成表格
+                    table.render({
+                        elem: '#priceTable',
+                        even: true, //隔行变色
+                        data: data, // 赋值已知数据
+                        width: 500,
+                        cols: [[
+                            {
+                                field: 'number',
+                                width: '12%',
+                                align: "center",
+                                title: '款数'
+                            }, {
+                                field: 'count',
+                                width: '16%',
+                                align: "center",
+                                title: '数量'
+                            }, {
+                                field: 'price',
+                                width: '16%',
+                                align: "center",
+                                title: '报价'
+                            }, {
+                                field: 'wangwang',
+                                align: "center",
+                                width: '16%',
+                                title: '折扣价'
+                            }, {
+                                field: 'wangwang',
+                                align: "center",
+                                width: '19%',
+                                title: '跳楼价'
+                            }, {
+                                field: 'weight',
+                                width: '21%',
+                                align: "center",
+                                title: '重量(kg)'
+                            }
+                        ]],
+                        done: function () {
+                        }
+                    });
+                }
+            });
+            return false;
+        });
+    });
+</script>
+</html>

+ 316 - 0
src/main/webapp/views/product/handkerchiefPaper.jsp

@@ -0,0 +1,316 @@
+<%@ page language="java" contentType="text/html; charset=UTF-8"
+         pageEncoding="UTF-8" %>
+<%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
+<!DOCTYPE html>
+<html>
+<head>
+    <meta charset="UTF-8">
+    <title>Insert title here</title>
+    <%@include file="/views/common.jsp" %>
+</head>
+<body>
+<style>
+    #z4_craft .layui-form-select .layui-edge {
+        right: 20px;
+    }
+</style>
+<div class="big_box">
+    <div class="left_div">
+        <h1 class="h1">方巾纸</h1> <span style="color:red;font-weight:700;"></span>
+        <hr>
+        <form class="layui-form">
+            <input type="hidden" name="proTypeValue" id="proTypeValue" class="layui-input" value="方巾纸"/>
+            <p>
+                材质
+            </p>
+            <div class="layui-form-item">
+                <select name="kind" class="select" lay-search>
+                    <option value="1">15克木浆纸</option>
+                </select>
+            </div>
+            <p>
+                尺寸
+            </p>
+            <div class="layui-form-item">
+                <select name="size" class="layui-form-select" lay-filter="pcount_filter">
+                    <option value="22*22">22*22cm</option>
+                    <option value="23*23">23*23cm</option>
+                    <option value="27*27">27*27cm</option>
+                </select>
+            </div>
+            <p>
+                印刷颜色
+            </p>
+            <div class="layui-form-item">
+                <select name="craft" class="layui-form-select">
+                    <option value="黑色">黑色</option>
+                    <option value="咖啡色">咖啡色</option>
+                    <option value="浅绿色">浅绿色</option>
+                    <option value="深绿色">深绿色</option>
+                    <option value="蓝色">蓝色</option>
+                    <option value="橘色">橘色</option>
+                    <option value="黄色">黄色</option>
+                    <option value="红色">红色</option>
+                </select>
+            </div>
+            <p>
+                数量(箱)
+            </p>
+            <div class="layui-form-item">
+                <input type="text" name="count" id="count" class="layui-input">
+            </div>
+            <p>
+                款数
+            </p>
+            <div class="layui-form-item">
+                <input type="text" placeholder="请输入整数" autocomplete="off" name="number" id="number" value="1"
+                       class="layui-input" lay-verify="number">
+            </div>
+            <p>
+                客户旺旺
+            </p>
+            <div class="layui-form-item">
+                <input type="text" placeholder="请输入客户旺旺号" autocomplete="off" name="wangwang" id="wangwang"
+                       class="layui-input">
+            </div>
+            <p>
+                工艺
+            </p>
+            <div class="layui-form-item" id='z4_craft'>
+                <div class="layui-input-block">
+                    印面工艺:
+                    <input type="checkbox" name="craft" lay-filter="ui_craft" value="单面" title="单面" checked readonly>
+                </div>
+                <div class="layui-input-block">
+                    裁切工艺:
+                    <input type="checkbox" name="craft" lay-filter="ui_craft" value="方形" title="方形" checked readonly>
+                </div>
+            </div>
+            <hr>
+            <div class="layui-form-item">
+                <button class="layui-btn" lay-submit="" lay-filter="acount_btn">计算</button>
+                <button type="reset" class="layui-btn layui-btn-primary">重置</button>
+            </div>
+            <h2>计算结果-
+                <button type="button" class="layui-btn layui-btn-primary layui-btn-sm copyResult"
+                        onclick="copyResult()">点击复制
+                </button>
+            </h2>
+            <div>
+                <textarea rows="11" cols="75" id="span_result" readonly="readonly"></textarea>
+                <%@include file="../acountExpressFee.jsp" %>
+            </div>
+            <div>
+                <table class="layui-hide" id="priceTable" lay-filter="priceTable"></table>
+            </div>
+        </form>
+    </div>
+    <div class="right_div" style="margin-left:50px;">
+        <div class="layui-carousel" id="test1">
+            <div carousel-item id="carousel"></div>
+            <br>
+            <div id="remark" style="font-size:20px;color:red"></div>
+        </div>
+    </div>
+</div>
+</body>
+<%@include file="/views/copyResult.jsp" %>
+<script>
+    layui.use(['table', 'form', 'carousel'], function () {
+        var form = layui.form; //只有执行了这一步,部分表单元素才会自动修饰成功
+        var carousel = layui.carousel;
+        var table = layui.table;
+
+
+        //建造实例
+        ins = carousel.render({});
+        var html = " ";
+        var remark = " ";
+        const carft_list1 = ["单面", "双面"];
+
+        // 清空轮播图
+        $("#carousel").empty();
+        $("#remark").empty();
+        $(".ui_feb").show();
+        $(".ui_feb select").attr("disabled", false);
+        $.ajax({
+            url: "${pageContext.request.contextPath}/getImgs",
+            type: "GET",
+            data: {
+                proTypeValue: $("#proTypeValue").val(),
+                kindValue: $('input[name="kindValue"]').val()
+            },
+            success: function (result) {
+                for (let i = 0; i < result.length; i++) {
+                    // 只留一个remark
+                    remark = "";
+                    html += '<div><img style="width:100%;height: 100%;object-fit: contain" src="' + result[i].imgUrl + '"></div>';
+                    remark += '<div><span>' + result[i].remark + '<span/></div>';
+                }
+                $("#carousel").append(html);
+                // 如果没有说明,就不显示null
+                if (remark.indexOf("null") < 0) {
+                    $("#remark").append(remark);
+                }
+                // 如果没有轮播图就隐藏
+                if (result.length == 0) {
+                    document.getElementById("test1").style.display = "none";   //隐藏
+                } else {
+                    document.getElementById("test1").style.display = "block";   //显示
+                    ins.reload({
+                        elem: '#test1',
+                        width: result[0].imgWidth,  //设置容器宽度
+                        height: result[0].imgHeight
+                    });
+                }
+            }
+        });
+        form.on('select(pcount_filter)', function (data) {
+            if (data.value == 1) {
+                $("#size").val("12.8*10.5*6.5")
+            }
+            if (data.value == 3) {
+                $("#size").val("21.5*16*6.5")
+            }
+            if (data.value == 5) {
+                $("#size").val("16.5*13.5*5")
+            }
+        })
+        form.on('checkbox(ui_craft)', function (data) {
+            let craft_list = [];
+            $(data.elem).prop("checked", true);
+            layer.msg("工艺不能取消", {offset: ['300px', '300px']}, function () {
+            });
+            form.render();
+            return false;
+            craft_list.push($("select[name='craft'] option:selected").val());
+            $("input[name='craft']:checked").each(function () {
+                    if (!$(this).is(':disabled')) {
+                        craft_list.push($(this).val());
+                    }
+                }
+            );
+        })
+
+        // 点击计算,计算价格
+        form.on('submit(acount_btn)', function (data) {
+            var number = $("#number").val();
+            var size = $("select[name='size'] option:selected").val();
+            var count = $("#count").val();
+            var kind = $("select[name='kind'] option:selected").text();
+            var craft = [];
+            if (size == "") {
+                layer.msg('请填写尺寸!', {offset: ['300px', '300px']}, function () {
+                });
+                return false;
+            }
+            craft.push($("select[name='craft'] option:selected").val());
+            $("input:checkbox[name='craft']:checked").each(function (i) {
+                // 没有被禁用的工艺加到arr中
+                if (!$(this).is(':disabled')) {
+
+                    craft.push($(this).val());
+                }
+            });
+
+            const carft1 = carft_list1.filter(item => craft.includes(item));
+            if (carft1.length == 0) {
+                layer.msg("请选择印面工艺", {offset: ['300px', '300px']}, function () {
+                });
+                return false;
+            }
+            if (size == "23*23" || size == "27*27") {
+                if(count < 3){
+                    layer.msg("23*23、27*27尺寸3箱起做", {offset: ['300px', '300px']}, function () {
+                    });
+                    return false;
+                }
+            }
+
+            $.ajax({
+                url: "${path}/getThanSum",
+                type: "GET",
+                data: $(".big_box form").serialize(),
+                success: function (result) {
+                    if (result.code == 100) {
+                        layer.msg(result.msg, {offset: ['300px', '300px']}, function () {
+                        });
+                        return false;
+                    }
+                    var data = result.data.proList;
+
+                    var span_result = '方巾纸 - ' + kind + ' - ' + size + ' CM (同款内容)\n';
+
+                    span_result += `工艺:` + craft.join(",") + '\n';
+
+                    if (number > 1) {
+                        for (let i = 0; i < data.length; i++) {
+                            span_result += number + '款 各' + data[i].count + "箱,共" + data[i].price + "元" + '\n'
+                            data[i].number = number;
+                        }
+                    } else {
+                        for (let i = 0; i < data.length; i++) {
+                            span_result += number + '款 ' + data[i].count + "箱,共" + data[i].price + "元" + '\n'
+                            data[i].number = number;
+                        }
+                    }
+
+                    span_result += '包邮,免费设计呢~(偏远地区需补邮费)'
+                    $("#span_result").val(span_result);
+
+                    //计算完自动复制文本
+                    var e = document.getElementById("span_result");//对象是content
+                    if (e.value != "") {
+                        e.select();//选择对象
+                        document.execCommand("Copy");//执行浏览器复制命令
+                    }
+
+                    //生成表格
+                    table.render({
+                        elem: '#priceTable',
+                        even: true, //隔行变色
+                        data: data, // 赋值已知数据
+                        width: 500,
+                        cols: [[
+                            {
+                                field: 'number',
+                                width: '12%',
+                                align: "center",
+                                title: '款数'
+                            }, {
+                                field: 'count',
+                                width: '16%',
+                                align: "center",
+                                title: '数量'
+                            }, {
+                                field: 'price',
+                                width: '16%',
+                                align: "center",
+                                title: '报价'
+                            }, {
+                                field: 'wangwang',
+                                align: "center",
+                                width: '16%',
+                                title: '折扣价'
+                            }, {
+                                field: 'wangwang',
+                                align: "center",
+                                width: '19%',
+                                title: '跳楼价'
+                            }, {
+                                field: 'weight',
+                                width: '21%',
+                                align: "center",
+                                title: '重量(kg)'
+                            }
+                        ]],
+                        done: function () {
+                        }
+                    });
+                }
+            });
+            return false;
+        });
+    });
+</script>
+</html>

+ 311 - 0
src/main/webapp/views/product/takeoutBox.jsp

@@ -0,0 +1,311 @@
+<%@ page language="java" contentType="text/html; charset=UTF-8"
+         pageEncoding="UTF-8" %>
+<%@taglib prefix="c" uri="http://java.sun.com/jsp/jstl/core" %>
+<!DOCTYPE html>
+<html>
+<head>
+    <meta charset="UTF-8">
+    <title>Insert title here</title>
+    <%@include file="/views/common.jsp" %>
+</head>
+<body>
+<style>
+    #z4_craft .layui-form-select .layui-edge {
+        right: 20px;
+    }
+</style>
+<div class="big_box">
+    <div class="left_div">
+        <h1 class="h1">外卖盒</h1> <span style="color:red;font-weight:700;"></span>
+        <hr>
+        <form class="layui-form">
+            <input type="hidden" name="proTypeValue" id="proTypeValue" class="layui-input" value="外卖盒"/>
+            <p>
+                材质
+            </p>
+            <div class="layui-form-item">
+                <select name="kind" class="select" lay-search>
+                    <option value="1">350克白卡纸</option>
+                </select>
+            </div>
+            <p>
+                尺寸
+            </p>
+            <div class="layui-form-item">
+                <select name="pcount" class="layui-form-select" lay-filter="pcount_filter">
+                    <option value="1">一号盒</option>
+                    <option value="3">三号盒</option>
+                    <option value="5">五号盒</option>
+                </select>
+            </div>
+            <p>
+                尺寸(长宽高)
+            </p>
+            <div class="layui-form-item">
+                <input type="text" name="size" id="size" value="12.8*10.5*6.5" placeholder="格式:长*宽" value=""
+                       class="layui-input"
+                       autocomplete="off" readonly>
+            </div>
+            <p>
+                数量(个)
+            </p>
+            <div class="layui-form-item">
+                <select name="count" class="layui-form-select">
+                    <option value="10000">10000</option>
+                    <option value="20000">20000</option>
+                    <option value="30000">30000</option>
+                    <option value="50000">50000</option>
+                </select>
+            </div>
+            <p>
+                款数
+            </p>
+            <div class="layui-form-item">
+                <input type="text" placeholder="请输入整数" autocomplete="off" name="number" id="number" value="1"
+                       class="layui-input" lay-verify="number">
+            </div>
+            <p>
+                客户旺旺
+            </p>
+            <div class="layui-form-item">
+                <input type="text" placeholder="请输入客户旺旺号" autocomplete="off" name="wangwang" id="wangwang"
+                       class="layui-input">
+            </div>
+            <p>
+                工艺
+            </p>
+            <div class="layui-form-item" id='z4_craft'>
+                <div class="layui-input-block">
+                    印面工艺:
+                    <input type="checkbox" name="craft" lay-filter="ui_craft" value="单面" title="单面" checked readonly>
+                </div>
+                <div class="layui-input-block">
+                    印刷工艺:
+                    <input type="checkbox" name="craft" lay-filter="ui_craft" value="彩色印刷" title="彩色印刷" checked
+                           readonly>
+                </div>
+                <div class="layui-input-block">
+                    内部工艺:
+                    <input type="checkbox" name="craft" lay-filter="ui_craft" value="淋膜" title="淋膜" checked readonly>
+                </div>
+            </div>
+            <hr>
+            <div class="layui-form-item">
+                <button class="layui-btn" lay-submit="" lay-filter="acount_btn">计算</button>
+                <button type="reset" class="layui-btn layui-btn-primary">重置</button>
+            </div>
+            <h2>计算结果-
+                <button type="button" class="layui-btn layui-btn-primary layui-btn-sm copyResult"
+                        onclick="copyResult()">点击复制
+                </button>
+            </h2>
+            <div>
+                <textarea rows="11" cols="75" id="span_result" readonly="readonly"></textarea>
+                <%@include file="../acountExpressFee.jsp" %>
+            </div>
+            <div>
+                <table class="layui-hide" id="priceTable" lay-filter="priceTable"></table>
+            </div>
+        </form>
+    </div>
+    <div class="right_div" style="margin-left:50px;">
+        <div class="layui-carousel" id="test1">
+            <div carousel-item id="carousel"></div>
+            <br>
+            <div id="remark" style="font-size:20px;color:red"></div>
+        </div>
+    </div>
+</div>
+</body>
+<%@include file="/views/copyResult.jsp" %>
+<script>
+    layui.use(['table', 'form', 'carousel'], function () {
+        var form = layui.form; //只有执行了这一步,部分表单元素才会自动修饰成功
+        var carousel = layui.carousel;
+        var table = layui.table;
+
+
+        //建造实例
+        ins = carousel.render({});
+        var html = " ";
+        var remark = " ";
+        const carft_list1 = ["单面", "双面"];
+
+        // 清空轮播图
+        $("#carousel").empty();
+        $("#remark").empty();
+        $(".ui_feb").show();
+        $(".ui_feb select").attr("disabled", false);
+        $.ajax({
+            url: "${pageContext.request.contextPath}/getImgs",
+            type: "GET",
+            data: {
+                proTypeValue: $("#proTypeValue").val(),
+                kindValue: $('input[name="kindValue"]').val()
+            },
+            success: function (result) {
+                for (let i = 0; i < result.length; i++) {
+                    // 只留一个remark
+                    remark = "";
+                    html += '<div><img style="width:100%;height: 100%;object-fit: contain" src="' + result[i].imgUrl + '"></div>';
+                    remark += '<div><span>' + result[i].remark + '<span/></div>';
+                }
+                $("#carousel").append(html);
+                // 如果没有说明,就不显示null
+                if (remark.indexOf("null") < 0) {
+                    $("#remark").append(remark);
+                }
+                // 如果没有轮播图就隐藏
+                if (result.length == 0) {
+                    document.getElementById("test1").style.display = "none";   //隐藏
+                } else {
+                    document.getElementById("test1").style.display = "block";   //显示
+                    ins.reload({
+                        elem: '#test1',
+                        width: result[0].imgWidth,  //设置容器宽度
+                        height: result[0].imgHeight
+                    });
+                }
+            }
+        });
+        form.on('select(pcount_filter)', function (data) {
+            if (data.value == 1) {
+                $("#size").val("12.8*10.5*6.5")
+            }
+            if (data.value == 3) {
+                $("#size").val("21.5*16*6.5")
+            }
+            if (data.value == 5) {
+                $("#size").val("16.5*13.5*5")
+            }
+        })
+        form.on('checkbox(ui_craft)', function (data) {
+            let craft_list = [];
+            $(data.elem).prop("checked", true);
+            layer.msg("工艺不能取消", {offset: ['300px', '300px']}, function () {
+            });
+            form.render();
+            return false;
+            craft_list.push($("select[name='craft'] option:selected").val());
+            $("input[name='craft']:checked").each(function () {
+                    if (!$(this).is(':disabled')) {
+                        craft_list.push($(this).val());
+                    }
+                }
+            );
+        })
+
+        // 点击计算,计算价格
+        form.on('submit(acount_btn)', function (data) {
+            var number = $("#number").val();
+            var size = $("#size").val();
+            var count = $("#count").val();
+            var kind = $("select[name='kind'] option:selected").text();
+            var craft = [];
+            if (size == "") {
+                layer.msg('请填写尺寸!', {offset: ['300px', '300px']}, function () {
+                });
+                return false;
+            }
+            $("input:checkbox[name='craft']:checked").each(function (i) {
+                // 没有被禁用的工艺加到arr中
+                if (!$(this).is(':disabled')) {
+
+                    craft.push($(this).val());
+                }
+            });
+
+            const carft1 = carft_list1.filter(item => craft.includes(item));
+            if (carft1.length == 0) {
+                layer.msg("请选择印面工艺", {offset: ['300px', '300px']}, function () {
+                });
+                return false;
+            }
+
+            $.ajax({
+                url: "${path}/getThanSum",
+                type: "GET",
+                data: $(".big_box form").serialize(),
+                success: function (result) {
+                    if (result.code == 100) {
+                        layer.msg(result.msg, {offset: ['300px', '300px']}, function () {
+                        });
+                        return false;
+                    }
+                    var data = result.data.proList;
+
+                    var span_result = '外面盒 - ' + kind + ' - ' + size + ' CM (同款内容)\n';
+
+                    span_result += `工艺:` + craft.join(",") + '\n';
+
+                    if (number > 1) {
+                        for (let i = 0; i < data.length; i++) {
+                            span_result += number + '款 各' + data[i].count + "个,共" + data[i].price + "元" + '\n'
+                            data[i].number = number;
+                        }
+                    } else {
+                        for (let i = 0; i < data.length; i++) {
+                            span_result += number + '款 ' + data[i].count + "ge,共" + data[i].price + "元" + '\n'
+                            data[i].number = number;
+                        }
+                    }
+
+                    span_result += '包邮,免费设计呢~(偏远地区需补邮费)'
+                    $("#span_result").val(span_result);
+
+                    //计算完自动复制文本
+                    var e = document.getElementById("span_result");//对象是content
+                    if (e.value != "") {
+                        e.select();//选择对象
+                        document.execCommand("Copy");//执行浏览器复制命令
+                    }
+
+                    //生成表格
+                    table.render({
+                        elem: '#priceTable',
+                        even: true, //隔行变色
+                        data: data, // 赋值已知数据
+                        width: 500,
+                        cols: [[
+                            {
+                                field: 'number',
+                                width: '12%',
+                                align: "center",
+                                title: '款数'
+                            }, {
+                                field: 'count',
+                                width: '16%',
+                                align: "center",
+                                title: '数量'
+                            }, {
+                                field: 'price',
+                                width: '16%',
+                                align: "center",
+                                title: '报价'
+                            }, {
+                                field: 'wangwang',
+                                align: "center",
+                                width: '16%',
+                                title: '折扣价'
+                            }, {
+                                field: 'wangwang',
+                                align: "center",
+                                width: '19%',
+                                title: '跳楼价'
+                            }, {
+                                field: 'weight',
+                                width: '21%',
+                                align: "center",
+                                title: '重量(kg)'
+                            }
+                        ]],
+                        done: function () {
+                        }
+                    });
+                }
+            });
+            return false;
+        });
+    });
+</script>
+</html>