From 83c4dd24f674b5f2c3d10ab98d04e8562202449b Mon Sep 17 00:00:00 2001 From: xuhy <3313886187@qq.com> Date: 星期五, 27 十二月 2024 21:31:00 +0800 Subject: [PATCH] Merge remote-tracking branch 'origin/master' --- manage/src/main/java/com/jilongda/manage/controller/TOrderController.java | 127 +++++++++++++++++++++++++++++++++++++++-- 1 files changed, 119 insertions(+), 8 deletions(-) diff --git a/manage/src/main/java/com/jilongda/manage/controller/TOrderController.java b/manage/src/main/java/com/jilongda/manage/controller/TOrderController.java index 9a6a437..0f8c184 100644 --- a/manage/src/main/java/com/jilongda/manage/controller/TOrderController.java +++ b/manage/src/main/java/com/jilongda/manage/controller/TOrderController.java @@ -8,10 +8,14 @@ import com.jilongda.manage.authority.service.SecUserService; import com.jilongda.manage.dto.TOrderDTO; import com.jilongda.manage.model.*; +import com.jilongda.manage.query.TModelQuery; import com.jilongda.manage.query.TOptometryQuery; +import com.jilongda.manage.query.TOrderQuery; import com.jilongda.manage.service.*; import com.jilongda.manage.utils.LoginInfoUtil; +import com.jilongda.manage.vo.TModelVO; import com.jilongda.manage.vo.TOptometryVO; +import com.jilongda.manage.vo.TOrderListVO; import com.jilongda.manage.vo.TOrderVO; import io.swagger.annotations.Api; import io.swagger.annotations.ApiOperation; @@ -21,6 +25,7 @@ import org.springframework.validation.annotation.Validated; import org.springframework.web.bind.annotation.*; +import java.math.BigDecimal; import java.util.*; import java.util.stream.Collectors; @@ -55,6 +60,56 @@ private TFrameGoodsService frameGoodsService; @Autowired private TLensGoodsService lensGoodsService; + @Autowired + private TModelService modelService; + @Autowired + private TLensSeriesService lensSeriesService; + @Autowired + private TBrandService brandService; + @Autowired + private TOptometryService optometryService; + @ApiOperation(value = "销售订单分页列表") + @PostMapping(value = "/pageList") + public ApiResult<PageInfo<TOrderListVO>> pageList(@RequestBody TOrderQuery query) { + if (StringUtils.hasLength(query.getStartTime())){ + query.setStartTime(query.getStartTime()+" 00:00:00"); + query.setEndTime(query.getEndTime()+" 23:59:59"); + } + List<Integer> orderIds = new ArrayList<>(); + List<Integer> collect = tAppUserService.lambdaQuery() + .eq(StringUtils.hasLength(query.getWxName()), TAppUser::getName, query.getWxName()) + .eq(StringUtils.hasLength(query.getPhone()), TAppUser::getName, query.getPhone()).list() + .stream().map(TAppUser::getId).collect(Collectors.toList()); + if (StringUtils.hasLength(query.getWxName())||StringUtils.hasLength(query.getPhone())){ + query.setUserIds(collect); + if (collect.isEmpty())return ApiResult.success(new PageInfo<>()); + } + List<Integer> collect1 = orderGoodsService.lambdaQuery() + .eq(StringUtils.hasLength(query.getBrandLens()), TOrderGoods::getBrandName, query.getBrandLens()) + .eq(StringUtils.hasLength(query.getSeries()), TOrderGoods::getSeriesName, query.getSeries()) + .eq((query.getType() != null), TOrderGoods::getType, query.getType()) + .eq(StringUtils.hasLength(query.getRefractiveIndex()), TOrderGoods::getRefractiveIndex, query.getRefractiveIndex()).list() + .stream().map(TOrderGoods::getOrderId).collect(Collectors.toList()); + if (StringUtils.hasLength(query.getBrandLens())||StringUtils.hasLength(query.getSeries())||query.getType() != null|| + StringUtils.hasLength(query.getRefractiveIndex())){ + orderIds.addAll(collect1); + } + List<Integer> collect2 = orderGoodsService.lambdaQuery() + .eq(StringUtils.hasLength(query.getBrandFrame()), TOrderGoods::getBrandName, query.getBrandFrame()) + .eq(StringUtils.hasLength(query.getModelName()), TOrderGoods::getModelName, query.getModelName()) + .eq(StringUtils.hasLength(query.getColor()), TOrderGoods::getColor, query.getColor()).list() + .stream().map(TOrderGoods::getOrderId).collect(Collectors.toList()); + if (StringUtils.hasLength(query.getBrandFrame())||StringUtils.hasLength(query.getModelName())|| + StringUtils.hasLength(query.getColor())){ + orderIds.addAll(collect2); + } + if (StringUtils.hasLength(query.getBrandFrame())||StringUtils.hasLength(query.getModelName())|| + StringUtils.hasLength(query.getColor())||StringUtils.hasLength(query.getBrandLens())||StringUtils.hasLength(query.getSeries())||query.getType() != null|| + StringUtils.hasLength(query.getRefractiveIndex())){ + if (orderIds.isEmpty())return ApiResult.success(new PageInfo<>()); + } + return ApiResult.success(orderService.pageList(query)); + } @ApiOperation(value = "查询用户信息") @GetMapping(value = "/getUserById") public ApiResult getUserById(@RequestParam Integer userId) { @@ -102,7 +157,9 @@ if(Objects.nonNull(user)){ dto.setStoreId(user.getStoreId()); } + orderService.save(dto); + List<TOptometryDetail> optometryDetails = dto.getOptometryDetails(); if (!CollectionUtils.isEmpty(optometryDetails)){ for (TOptometryDetail optometryDetail : optometryDetails) { @@ -110,26 +167,80 @@ } optometryDetailService.saveBatch(optometryDetails); } + List<TOrderGoods> orderGoods = dto.getOrderGoods(); + List<TLensGoods> tLensGoods = new ArrayList<>(); + List<TFrameGoods> tFrameGoods = new ArrayList<>(); for (TOrderGoods orderGood : orderGoods) { orderGood.setOrderId(dto.getId()); + if (StringUtils.hasLength(orderGood.getSeriesName())){ + // 镜片 + String rLens = orderGood.getRLens(); + String[] split = rLens.split(","); + TBrand one1 = brandService.lambdaQuery().eq(TBrand::getName, orderGood.getBrandName()) + .eq(TBrand::getType, 2).one(); + TLensSeries one2 = lensSeriesService.lambdaQuery().eq(TLensSeries::getName, orderGood.getSeriesName()) + .eq(TLensSeries::getBrandId, one1.getId()).one(); + TLensGoods one = lensGoodsService.lambdaQuery() + .eq(StringUtils.hasLength(orderGood.getSeriesName()),TLensGoods::getSeriesId, one2.getId()) + .eq(StringUtils.hasLength(orderGood.getRefractiveIndex()),TLensGoods::getRefractiveIndex, orderGood.getRefractiveIndex()) + .eq(orderGood.getType()!=null,TLensGoods::getLensType, orderGood.getType()) + .eq(split.length>0,TLensGoods::getBallMirror, split[0]) + .eq(split.length>=2,TLensGoods::getColumnMirror, split[1]) + .one(); + if (one!=null){ + if (one.getTotal()-1<0){ + return ApiResult.failed("库存不足"); + } + // 减少对应库存 + one.setTotal(one.getTotal()-1); + tLensGoods.add(one); + }else { + return ApiResult.failed("商品不存在"); + } + }else{ + TModel one1 = modelService.lambdaQuery().eq(TModel::getName, orderGood.getModelName()) + .eq(TModel::getColor, orderGood.getColor()).one(); + BigDecimal cost = one1.getCost(); + orderGood.setCost(cost); + TFrameGoods one = frameGoodsService.lambdaQuery() + .eq(TFrameGoods::getModelId, one1.getId()) + .eq(TFrameGoods::getColor, orderGood.getColor()).one(); + if (one!=null){ + if (one.getTotal()-1<0){ + return ApiResult.failed("库存不足"); + } + // 增加对应库存 + one.setTotal(one.getTotal()-1); + tFrameGoods.add(one); + }else{ + return ApiResult.failed("商品不存在"); + } + } } - // TODO 周哥 补库存 - + orderGoodsService.saveBatch(orderGoods); + lensGoodsService.updateBatchById(tLensGoods); + frameGoodsService.updateBatchById(tFrameGoods); return ApiResult.success(); } @ApiOperation(value = "销售订单详情") @GetMapping(value = "/getOrderDetailById") public ApiResult getOrderDetailById(@RequestParam Integer orderId) { + TOrder byId = orderService.getById(orderId); TOrderVO orderVO = orderService.getOrderDetailById(orderId); - - // TODO 周哥 商品信息集合 - - // TODO 周哥 验光处方 判断是关联或者手动 - - + List<TOrderGoods> list = orderGoodsService.lambdaQuery().eq(TOrderGoods::getOrderId, orderId).list(); + orderVO.setOrderGoods(list); + if (byId.getOptometryId()!=null){ + // 选择验光单 + List<TOptometryDetail> list1 = optometryDetailService.lambdaQuery().eq(TOptometryDetail::getOptometryId, byId.getOptometryId()).list(); + orderVO.setOptometryDetails(list1); + }else{ + // 手动填写验光单 + List<TOptometryDetail> list1 = optometryDetailService.lambdaQuery().eq(TOptometryDetail::getOrderId, orderId).list(); + orderVO.setOptometryDetails(list1); + } return ApiResult.success(orderVO); } -- Gitblit v1.7.1