修改双胶纸价格,新增刻字车贴

This commit is contained in:
2025-08-11 14:39:36 +08:00
parent 5261b455e8
commit d60df8d3e2
5 changed files with 367 additions and 7 deletions
@@ -1122,6 +1122,12 @@ public class ProductService {
} }
} }
} }
for (int i = 0; i < priceList.size(); i++) {
if (priceList.get(i).getCount() == 500) {
priceList.get(i).setPrice(Math.floor(priceList.get(i + 1).getPrice() - 5));
}
}
// +棉绳钱 1分5一条 // +棉绳钱 1分5一条
for (Product product : priceList) { for (Product product : priceList) {
if (!StringUtils.isEmpty(dto.getCraftSheng()) && dto.getCraftSheng().contains("棉绳")) { if (!StringUtils.isEmpty(dto.getCraftSheng()) && dto.getCraftSheng().contains("棉绳")) {
@@ -4649,12 +4655,43 @@ public class ProductService {
return getShuibiaoPrice(dto, length, width); return getShuibiaoPrice(dto, length, width);
case "镭射吊牌": case "镭射吊牌":
return getLeiseDiaoPrice(dto, length, width); return getLeiseDiaoPrice(dto, length, width);
case "刻字车贴":
return getCheTiePrice(dto, length, width);
default: default:
break; break;
} }
return null; return null;
} }
private List<Product> getCheTiePrice(Product dto, double length, double width) {
double minPrice = 35;
length = length / 100;
width = width / 100;
double area = length * width;
double basePrice = 0;
if (area < 1) {
basePrice = 166;
} else if (area < 2) {
basePrice = 160;
} else if (area < 5) {
basePrice = 150;
} else if (area < 10) {
basePrice = 120;
} else {
basePrice = 100;
}
List<Product> priceList = new ArrayList<>();
Product pro = new Product();
double price = basePrice * dto.getCount() * area * dto.getNumber();
if (area <= 0.25) {
price = basePrice * dto.getCount() * area + dto.getNumber() + 6;
}
pro.setPrice(Math.ceil(Math.max(price, minPrice)));
pro.setCount(dto.getCount());
priceList.add(pro);
return priceList;
}
private List<Product> getLeiseDiaoPrice(Product dto, double length, double width) { private List<Product> getLeiseDiaoPrice(Product dto, double length, double width) {
double[] prices = new double[]{170, 233, 370, 537, 643, 843, 1613, 3117, 4847}; double[] prices = new double[]{170, 233, 370, 537, 643, 843, 1613, 3117, 4847};
int[] count_list = new int[]{500, 1000, 2000, 3000, 4000, 5000, 10000, 20000, 30000}; int[] count_list = new int[]{500, 1000, 2000, 3000, 4000, 5000, 10000, 20000, 30000};
@@ -1045,9 +1045,9 @@ public class PriceUtils {
if (countArr[i] < count || list.size() > 3) { if (countArr[i] < count || list.size() > 3) {
continue; continue;
} }
if (countArr[i] == 500) { /*if (countArr[i] == 500) {
continue; continue;
} }*/
pro = new Product(); pro = new Product();
if (countArr[i] == 500) { if (countArr[i] == 500) {
shengzi = 20; shengzi = 20;
+322
View File
@@ -0,0 +1,322 @@
<%@ 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">
<input type="text" name="count" id="count" placeholder="请输入整数" class="layui-input" autocomplete="off">
</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="直角裁切">
<input type="checkbox" name="craft" lay-filter="ui_craft" value="异形模切" title="异形模切" checked>
</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] < 25 || size.split("*")[1] < 25)) {
layer.msg("【刻字车贴】尺寸不能小于25*25 cm", {offset: ['300px', '300px']}, function () {
});
return false;
}
if ((size.split("*")[0] > 120 || size.split("*")[1] > 1000) && (size.split("*")[0] > 120 || size.split("*")[1] > 1000)) {
layer.msg("【刻字车贴】尺寸不能大于120*1000 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>
@@ -70,6 +70,7 @@
</p> </p>
<div class="layui-form-item diycount"> <div class="layui-form-item diycount">
<select name="count" class="select"> <select name="count" class="select">
<option value="500">500</option>
<option value="1000">1000</option> <option value="1000">1000</option>
<option value="2000">2000</option> <option value="2000">2000</option>
<option value="5000">5000</option> <option value="5000">5000</option>
+5 -5
View File
@@ -1345,11 +1345,11 @@
} }
var craftTiao = [$('input[name="craftTiao"]:checked').val()]; var craftTiao = [$('input[name="craftTiao"]:checked').val()];
if (craftTiao == '双喷') { if (craftTiao == '双喷') {
if ($("#bannerSize").val() > 500 || $("#diySizeCoupon").val() > 160) { // if ($("#bannerSize").val() > 500 || $("#diySizeCoupon").val() > 160) {
layer.msg('条幅双喷不能超过50*1.6米!', {offset: ['300px', '300px']}, function () { // layer.msg('条幅双喷不能超过50*1.6米!', {offset: ['300px', '300px']}, function () {
}); // });
return false; // return false;
} // }
} }
// $("#bannerSize").val($("#bannerSize").val()+'*'+$("#width").val()) // $("#bannerSize").val($("#bannerSize").val()+'*'+$("#width").val())
} }