Browse Source

新增水标价格

zhuyiyi 4 months ago
parent
commit
6e785f1e61

+ 63 - 1
src/main/java/lingtao/net/service/ProductService.java

@@ -4763,13 +4763,75 @@ public class ProductService {
                 area = length * width;
 
                 return getAreaCenterPrice(count_list, count, area, prices, areas, number);
+            case "水标":
+                return getShuibiaoPrice(dto, length, width);
             default:
                 break;
         }
         return null;
     }
 
-    private List<Product> getAreaCenterPrice(int[] count_list, int count, double area, int[][] prices, double[] areas, int number) {
+    private List<Product> getShuibiaoPrice(Product dto, double length, double width) {
+        List<String> craft_list = dto.getCraft() == null ? new ArrayList<>() : Arrays.asList(dto.getCraft());
+        int count = dto.getCount();
+        int number = dto.getNumber();
+        int[][] prices = new int[][]{};
+        if (craft_list.size() > 0) {
+            if (craft_list.contains("单面") && craft_list.contains("亮膜")) {
+                prices = new int[][]{
+                        {387, 387, 387, 387, 387, 387, 387, 387, 387, 387, 387, 387, 387, 400},
+                        {387, 387, 387, 387, 387, 387, 387, 387, 387, 387, 387, 387, 387, 405},
+                        {387, 387, 387, 387, 387, 387, 387, 420, 470, 524, 577, 634, 697, 757},
+                        {387, 387, 400, 470, 540, 624, 710, 797, 894, 1000, 1107, 1224, 1344, 1470},
+                        {387, 487, 580, 680, 790, 910, 1040, 1177, 1324, 1477, 1640, 1494, 1640, 1794},
+                        {517, 780, 937, 1104, 1290, 1487, 1700, 1587, 1787, 1997, 2220, 2454, 2700, 2960},
+                        {987, 1520, 1504, 1780, 2084, 2404, 2757, 3130, 3527, 3950, 4394, 4864, 5357, 5877},
+                };
+            }
+            if (craft_list.contains("双面") && craft_list.contains("亮膜")) {
+                prices = new int[][]{
+                        {720, 720, 720, 720, 720, 720, 720, 720, 720, 720, 720, 720, 720, 720},
+                        {720, 720, 720, 720, 720, 720, 720, 720, 720, 720, 720, 720, 720, 720},
+                        {720, 720, 720, 720, 720, 720, 720, 720, 724, 724, 734, 807, 884, 967},
+                        {720, 720, 720, 724, 724, 790, 904, 1020, 1144, 1277, 1417, 1567, 1724, 1887},
+                        {720, 724, 737, 864, 1007, 1167, 1330, 1507, 1694, 1897, 2107, 1944, 2137, 2340},
+                        {724, 994, 1197, 1414, 1654, 1910, 2187, 2070, 2330, 2607, 2900, 3207, 3530, 3874},
+                        {1264, 1947, 1960, 2320, 2717, 3144, 3604, 4094, 4617, 5167, 5754, 6370, 7020, 7700},
+
+                };
+            }
+            if (craft_list.contains("单面") && craft_list.contains("哑膜")) {
+                prices = new int[][]{
+                        {387, 387, 387, 387, 387, 387, 387, 387, 387, 387, 387, 387, 387, 387},
+                        {387, 387, 387, 387, 387, 387, 387, 387, 387, 387, 387, 387, 387, 404},
+                        {387, 387, 387, 387, 387, 387, 387, 427, 477, 527, 584, 640, 704, 767},
+                        {387, 387, 404, 474, 547, 630, 717, 810, 904, 1010, 1120, 1237, 1357, 1487},
+                        {387, 494, 587, 687, 800, 924, 1054, 1190, 1337, 1494, 1660, 1514, 1660, 1817},
+                        {520, 790, 947, 1117, 1304, 1507, 1724, 1610, 1810, 2024, 2250, 2487, 2737, 3004},
+                        {997, 1537, 1524, 1804, 2110, 2440, 2794, 3174, 3577, 4004, 4454, 4934, 5434, 5960},
+                };
+            }
+            if (craft_list.contains("双面") && craft_list.contains("哑膜")) {
+                prices = new int[][]{
+                        {730, 730, 730, 730, 730, 730, 730, 730, 730, 730, 730, 730, 730, 730},
+                        {730, 730, 730, 730, 730, 730, 730, 730, 730, 730, 730, 730, 730, 730},
+                        {730, 730, 730, 730, 730, 730, 730, 730, 730, 730, 744, 820, 897, 980},
+                        {730, 730, 730, 730, 730, 800, 914, 1037, 1164, 1297, 1440, 1590, 1750, 1914},
+                        {730, 730, 747, 880, 1024, 1180, 1347, 1530, 1724, 1924, 2137, 1977, 2174, 2380},
+                        {730, 1010, 1214, 1437, 1677, 1937, 2220, 2104, 2370, 2654, 2950, 3264, 3594, 3940},
+                        {1284, 1977, 1994, 2360, 2767, 3197, 3667, 4164, 4697, 5257, 5857, 6480, 7144, 7834},
+                };
+            }
+            int[] count_list = new int[]{200, 500, 1000, 2000, 3000, 5000, 10000};
+            double[] areas = new double[]{16, 25, 30.25, 36, 42.25, 49, 56.25, 64, 72.25, 81, 90.25, 100, 110.25, 121};
+            double area = length * width;
+            return getAreaCenterPrice(count_list, count, area, prices, areas, number);
+        }
+        return new ArrayList<>();
+    }
+
+    private List<Product> getAreaCenterPrice(int[] count_list, int count, double area, int[][] prices,
+                                             double[] areas, int number) {
         List<Product> priceList = new ArrayList<>();
         for (int i = 0; i < count_list.length; i++) {
             int count_item = count_list[i];

+ 2 - 2
src/main/webapp/views/product/pet.jsp

@@ -209,8 +209,8 @@
                 });
                 return false;
             }
-            if ((size.split("*")[0] > 10 || size.split("*")[1] > 15) && (size.split("*")[0] > 15 || size.split("*")[1] > 10)) {
-                layer.msg("【PET透卡】尺寸不能大于10*15 cm", {offset: ['300px', '300px']}, function () {
+            if ((size.split("*")[0] > 58.7 || size.split("*")[1] > 42.4) && (size.split("*")[0] > 42.4 || size.split("*")[1] > 58.7)) {
+                layer.msg("【PET透卡】尺寸不能大于58.7*42.4 cm", {offset: ['300px', '300px']}, function () {
                 });
                 return false;
             }

+ 330 - 0
src/main/webapp/views/product/waterGauge.jsp

@@ -0,0 +1,330 @@
+<%@ 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>
+<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="ui_bq_name" id="ui_bq_name" lay-filter="ui_fb_name" class="select" lay-search>
+                    <option value="1">珠光膜不干胶</option>
+                </select>
+            </div>
+            <p>
+                尺寸(CM/厘米) <span style="font-size: 14px; color: red">输入格式: 长 * 宽</span>
+            </p>
+            <div class="layui-form-item" id="ui_size">
+                <input type="text" name="size" id="size" placeholder="格式:长*宽" class="layui-input" autocomplete="off">
+            </div>
+
+            <p>
+                数量(个)
+            </p>
+            <div class="layui-form-item">
+                <select name="count" class="select">
+                    <option value="200">200</option>
+                    <option value="500">500</option>
+                    <option value="1000">1000</option>
+                    <option value="2000">2000</option>
+                    <option value="3000">3000</option>
+                    <option value="5000">5000</option>
+                    <option value="10000">10000</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">
+                <div class="layui-input-block" style="display:inline-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" style="display:inline-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" style="display:inline-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>
+            <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;
+        const carft_list2 = ["直角裁切", "异形模切"];
+        const carft_list1 = ["哑膜", "亮膜"];
+        const carft_list = ["单面", "双面"];
+
+        //建造实例
+        ins = carousel.render({});
+        var html = " ";
+        var remark = " ";
+        // 清空轮播图
+        $("#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:' + result[0].imgWidth + 'px" 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 = [];
+            $("input[name='craft']:checked").each(function () {
+                    if (!$(this).is(':disabled')) {
+                        craft_list.push($(this).val());
+                    }
+                }
+            );
+            const carft = carft_list.filter(craft => craft_list.includes(craft));
+            if (carft.length > 1) {
+                $(data.elem).prop("checked", false);
+                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('submit(acount_btn)', function (data) {
+            var number = $("#number").val();
+            var size = $("#size").val();
+            var count = $("#count").val();
+            var kind = $("#ui_bq_name option:selected").text();
+            var craft = [];
+            if (size == "") {
+                layer.msg('请填写尺寸!', {offset: ['300px', '300px']}, function () {
+                });
+                return false;
+            }
+            /*if ((size.split("*")[0] < 5 || size.split("*")[1] < 4.5) && (size.split("*")[0] < 4.5 || size.split("*")[1] < 5)) {
+                layer.msg("【PET透卡】尺寸不能小于5*4.5 cm", {offset: ['300px', '300px']}, function () {
+                });
+                return false;
+            }
+            if ((size.split("*")[0] > 58.7 || size.split("*")[1] > 42.4) && (size.split("*")[0] > 42.4 || size.split("*")[1] > 58.7)) {
+                layer.msg("【PET透卡】尺寸不能大于58.7*42.4 cm", {offset: ['300px', '300px']}, function () {
+                });
+                return false;
+            }*/
+            $("input:checkbox[name='craft']:checked").each(function (i) {
+                // 没有被禁用的工艺加到arr中
+                if (!$(this).is(':disabled')) {
+                    craft.push($(this).val());
+                }
+            });
+            const carft0 = carft_list.filter(item => craft.includes(item));
+            if (carft0.length == 0) {
+                layer.msg("请选择印面工艺", {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;
+            }
+
+            $.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>