Browse Source

四种商品价格及阶梯价格

master
dimengzhe 1 year ago
parent
commit
a0411a680b
  1. 5
      src/main/java/com/yxt/yythmall/api/lpkgoods/LpkGoods.java
  2. 29
      src/main/java/com/yxt/yythmall/biz/shoppingcart/ShoppingCartService.java

5
src/main/java/com/yxt/yythmall/api/lpkgoods/LpkGoods.java

@ -3,6 +3,7 @@ package com.yxt.yythmall.api.lpkgoods;
import com.baomidou.mybatisplus.annotation.TableName; import com.baomidou.mybatisplus.annotation.TableName;
import com.fasterxml.jackson.annotation.JsonFormat; import com.fasterxml.jackson.annotation.JsonFormat;
import io.swagger.annotations.ApiModel; import io.swagger.annotations.ApiModel;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data; import lombok.Data;
import java.util.Date; import java.util.Date;
@ -41,4 +42,8 @@ public class LpkGoods {
private String brandName; // 品牌名称'; private String brandName; // 品牌名称';
private Long categoryId; // 类别ID'; private Long categoryId; // 类别ID';
private String categoryName; // 类别名称'; private String categoryName; // 类别名称';
@ApiModelProperty("阶梯重量")
private String stepWeight;
@ApiModelProperty("阶梯价格")
private String stepPrice;
} }

29
src/main/java/com/yxt/yythmall/biz/shoppingcart/ShoppingCartService.java

@ -15,6 +15,7 @@ import com.yxt.yythmall.api.empcardbuildrecord.EmpCardBuildRecordQuery;
import com.yxt.yythmall.api.empcardbuildrecord.EmpCardBuildRecordVo; import com.yxt.yythmall.api.empcardbuildrecord.EmpCardBuildRecordVo;
import com.yxt.yythmall.api.lpkcustomer.LpkCustomer; import com.yxt.yythmall.api.lpkcustomer.LpkCustomer;
import com.yxt.yythmall.api.lpkgiftcard.LpkGiftCardQuery; import com.yxt.yythmall.api.lpkgiftcard.LpkGiftCardQuery;
import com.yxt.yythmall.api.lpkgoods.LpkGoods;
import com.yxt.yythmall.api.ordorder.OrdOrderDto; import com.yxt.yythmall.api.ordorder.OrdOrderDto;
import com.yxt.yythmall.api.ordorderdetails.OrdOrderDetailVo; import com.yxt.yythmall.api.ordorderdetails.OrdOrderDetailVo;
import com.yxt.yythmall.api.shoppingcart.ShoppingCart; import com.yxt.yythmall.api.shoppingcart.ShoppingCart;
@ -23,6 +24,7 @@ import com.yxt.yythmall.api.shoppingcart.ShoppingCartQuery;
import com.yxt.yythmall.api.shoppingcart.ShoppingCartVo; import com.yxt.yythmall.api.shoppingcart.ShoppingCartVo;
import com.yxt.yythmall.biz.empcard.EmpCardService; import com.yxt.yythmall.biz.empcard.EmpCardService;
import com.yxt.yythmall.biz.lpkcustomer.LpkCustomerService; import com.yxt.yythmall.biz.lpkcustomer.LpkCustomerService;
import com.yxt.yythmall.biz.lpkgoods.LpkGoodsService;
import org.springframework.beans.BeanUtils; import org.springframework.beans.BeanUtils;
import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service; import org.springframework.stereotype.Service;
@ -41,6 +43,8 @@ public class ShoppingCartService extends MybatisBaseService<ShoppingCartMapper,
private FileUploadComponent fileUploadComponent; private FileUploadComponent fileUploadComponent;
@Autowired @Autowired
LpkCustomerService lpkCustomerService; LpkCustomerService lpkCustomerService;
@Autowired
private LpkGoodsService lpkGoodsService;
public ResultBean save(ShoppingCartDto dto) { public ResultBean save(ShoppingCartDto dto) {
ResultBean rb = ResultBean.fireFail(); ResultBean rb = ResultBean.fireFail();
@ -64,6 +68,7 @@ public class ShoppingCartService extends MybatisBaseService<ShoppingCartMapper,
baseMapper.insert(entity); baseMapper.insert(entity);
return rb.success().setMsg("成功"); return rb.success().setMsg("成功");
} }
public ResultBean<List<ShoppingCartVo>> shoppingCartList(ShoppingCartQuery query) { public ResultBean<List<ShoppingCartVo>> shoppingCartList(ShoppingCartQuery query) {
ResultBean rb = ResultBean.fireFail(); ResultBean rb = ResultBean.fireFail();
ShoppingCart entity = new ShoppingCart(); ShoppingCart entity = new ShoppingCart();
@ -75,6 +80,7 @@ public class ShoppingCartService extends MybatisBaseService<ShoppingCartMapper,
return rb.success().setData(list).setMsg("成功"); return rb.success().setData(list).setMsg("成功");
} }
public ResultBean minusShoppingCart(ShoppingCartDto dto) { public ResultBean minusShoppingCart(ShoppingCartDto dto) {
ResultBean rb = ResultBean.fireFail(); ResultBean rb = ResultBean.fireFail();
ShoppingCart entity = new ShoppingCart(); ShoppingCart entity = new ShoppingCart();
@ -91,21 +97,41 @@ public class ShoppingCartService extends MybatisBaseService<ShoppingCartMapper,
// baseMapper.insert(entity); // baseMapper.insert(entity);
return rb.success().setMsg("成功"); return rb.success().setMsg("成功");
} }
public ResultBean delShoppingCart(String sid) { public ResultBean delShoppingCart(String sid) {
ResultBean rb = ResultBean.fireFail(); ResultBean rb = ResultBean.fireFail();
ShoppingCart entity = new ShoppingCart(); ShoppingCart entity = new ShoppingCart();
baseMapper.delete(new QueryWrapper<ShoppingCart>().eq("sid ", sid)); baseMapper.delete(new QueryWrapper<ShoppingCart>().eq("sid ", sid));
return rb.success().setMsg("成功"); return rb.success().setMsg("成功");
} }
public ResultBean getGoodsWeight(ShoppingCartQuery query) { public ResultBean getGoodsWeight(ShoppingCartQuery query) {
ResultBean rb = new ResultBean().fail(); ResultBean rb = new ResultBean().fail();
List<ShoppingCartVo> list = baseMapper.ShoppingCartList(query.getCustomerSid(), query.getBrandId()); List<ShoppingCartVo> list = baseMapper.ShoppingCartList(query.getCustomerSid(), query.getBrandId());
double price = 0; double price = 0;
double weight = 0; double weight = 0;
for (ShoppingCartVo vo : list) { for (ShoppingCartVo vo : list) {
LpkGoods lpkGoods = lpkGoodsService.fetchBySid(vo.getGoodsSid());
String stepWeight = lpkGoods.getStepWeight();
String stepPrice = lpkGoods.getStepPrice();
if (new BigDecimal(stepPrice).compareTo(BigDecimal.ZERO) == 0) {
stepPrice = vo.getJPrice();
}
if ("北京3号白菜".equals(vo.getGoodsName())
|| "玲珑黄白菜".equals(vo.getGoodsName())
|| "V7土豆".equals(vo.getGoodsName())
|| "黄金薯土豆".equals(vo.getGoodsName())) {
BigDecimal weightW = new BigDecimal(vo.getWeight());
if (weightW.compareTo(new BigDecimal(stepWeight)) >= 0) {
price = Double.valueOf(stepPrice) * Double.valueOf(vo.getGoodsNumber()) + price;
weight = Double.valueOf(vo.getWeight()) * Double.valueOf(vo.getGoodsNumber()) + price;
}
} else {
price = Double.valueOf(vo.getPrice()) * Double.valueOf(vo.getGoodsNumber()) + price; price = Double.valueOf(vo.getPrice()) * Double.valueOf(vo.getGoodsNumber()) + price;
weight = Double.valueOf(vo.getWeight()) * Double.valueOf(vo.getGoodsNumber()) + weight; weight = Double.valueOf(vo.getWeight()) * Double.valueOf(vo.getGoodsNumber()) + weight;
} }
}
ShoppingCartVo vo = new ShoppingCartVo(); ShoppingCartVo vo = new ShoppingCartVo();
// vo.setText("1.20斤起订量。\n" + // vo.setText("1.20斤起订量。\n" +
// "2.新用户正好20斤5折。\n" + // "2.新用户正好20斤5折。\n" +
@ -117,6 +143,7 @@ public class ShoppingCartService extends MybatisBaseService<ShoppingCartMapper,
vo = price(vo); vo = price(vo);
return rb.success().setData(vo); return rb.success().setData(vo);
} }
private ShoppingCartVo price(ShoppingCartVo vo) { private ShoppingCartVo price(ShoppingCartVo vo) {
int weight = Integer.parseInt(vo.getTotalWeight()); int weight = Integer.parseInt(vo.getTotalWeight());
LpkCustomer lpkCustomer = lpkCustomerService.getOne(new QueryWrapper<LpkCustomer>().eq("sid", vo.getCustomerSid())); LpkCustomer lpkCustomer = lpkCustomerService.getOne(new QueryWrapper<LpkCustomer>().eq("sid", vo.getCustomerSid()));
@ -181,8 +208,10 @@ public class ShoppingCartService extends MybatisBaseService<ShoppingCartMapper,
} }
return vo; return vo;
} }
/** /**
* 去除多余.0 * 去除多余.0
*
* @param num * @param num
* @return * @return
*/ */

Loading…
Cancel
Save