From 80fd41ea0dc602ac3ca33778f17fce5bc2e817b1 Mon Sep 17 00:00:00 2001
From: doum <doum>
Date: 星期五, 16 一月 2026 18:58:33 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 server/dmmall_service/src/main/java/com/doumee/service/business/impl/ShopServiceImpl.java |  436 +++++++++++++++++++++++++++++++++++++++++++++++++-----
 1 files changed, 396 insertions(+), 40 deletions(-)

diff --git a/server/dmmall_service/src/main/java/com/doumee/service/business/impl/ShopServiceImpl.java b/server/dmmall_service/src/main/java/com/doumee/service/business/impl/ShopServiceImpl.java
index fba01ff..ee8f7e8 100644
--- a/server/dmmall_service/src/main/java/com/doumee/service/business/impl/ShopServiceImpl.java
+++ b/server/dmmall_service/src/main/java/com/doumee/service/business/impl/ShopServiceImpl.java
@@ -2,6 +2,8 @@
 
 import com.baomidou.mybatisplus.core.conditions.Wrapper;
 import com.doumee.biz.system.SystemDictDataBiz;
+import com.doumee.config.Jwt.JwtPayLoad;
+import com.doumee.config.Jwt.JwtTokenUtil;
 import com.doumee.config.listener.event.VisitEvent;
 import com.doumee.core.model.LoginUserInfo;
 import com.doumee.core.constants.ResponseStatus;
@@ -10,9 +12,10 @@
 import com.doumee.core.model.PageWrap;
 import com.doumee.core.utils.Constants;
 import com.doumee.core.utils.Utils;
-import com.doumee.dao.business.MemberMapper;
-import com.doumee.dao.business.ShopJoinMapper;
-import com.doumee.dao.business.ShopMapper;
+import com.doumee.dao.business.*;
+import com.doumee.dao.business.join.GoodsorderJoinMapper;
+import com.doumee.dao.business.join.MemberJoinMapper;
+import com.doumee.dao.business.*;
 import com.doumee.dao.business.join.ProductLabelJoinMapper;
 import com.doumee.dao.business.model.*;
 import com.doumee.dao.business.model.Labels;
@@ -21,19 +24,22 @@
 import com.doumee.dao.business.model.ShopScan;
 import com.doumee.dao.system.SystemUserMapper;
 import com.doumee.dao.system.model.SystemUser;
-import com.doumee.dao.web.dto.CouponDTO;
-import com.doumee.dao.web.dto.MemberDTO;
-import com.doumee.dao.web.dto.MultiFileDTO;
+import com.doumee.dao.web.dto.*;
 import com.doumee.dao.web.dto.shop.*;
+import com.doumee.dao.web.request.MyCustomerRequest;
+import com.doumee.dao.web.request.SaleReportRequest;
+import com.doumee.dao.web.response.*;
 import com.doumee.service.business.*;
 import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
 import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper;
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import org.apache.commons.collections.MapUtils;
+import org.apache.commons.lang3.RandomStringUtils;
 import org.apache.shiro.SecurityUtils;
 import com.github.yulichang.wrapper.MPJLambdaWrapper;
 import org.apache.commons.lang3.StringUtils;
+import org.apache.xpath.operations.Bool;
 import org.checkerframework.checker.units.qual.C;
 import org.springframework.beans.BeanUtils;
 import org.springframework.beans.factory.annotation.Autowired;
@@ -58,6 +64,12 @@
 
     @Autowired
     private ShopMapper shopMapper;
+    @Autowired
+    private GoodsMapper goodsMapper;
+    @Autowired
+    private GoodsSkuMapper goodsSkuMapper;
+    @Autowired
+    private ShopGoodsRelationMapper shopGoodsRelationMapper;
 
     @Autowired
     private ShopCommentService shopCommentService;
@@ -82,10 +94,13 @@
     private SystemDictDataBiz systemDictDataBiz;
 
     @Autowired
-    private MemberMapper memberMapper;
+    private MemberJoinMapper memberJoinMapper;
 
     @Autowired
     private SystemUserMapper systemUserMapper;
+
+    @Autowired
+    private GoodsorderJoinMapper goodsorderJoinMapper;
 
     @Autowired
     private ProductLabelJoinMapper productLabelJoinMapper;
@@ -101,9 +116,14 @@
 
     @Autowired
     private ShopNewsService shopNewsService;
+    @Autowired
+    private LabelsMapper labelsMapper;
 
     @Autowired
     private MultifileService multifileService;
+
+    @Autowired
+    private IntegralMapper integralMapper;
 
 
     @Override
@@ -112,44 +132,68 @@
         isCreateParamValid(shop,user);
         shop.setCreator(user.getId());
         shop.setCreateDate(new Date());
+        shop.setEditor(user.getId());
+        shop.setEditDate(shop.getCreateDate());
         shop.setIsdeleted(Constants.ZERO);
         shop.setStatus(Constants.ZERO);
         shop.setIsrec(Constants.ONE);
         shop.setOrigin(Constants.ONE);
+        shop.setSaleType(Constants.formatIntegerNum(shop.getSaleType()));
+        String salt = RandomStringUtils.randomAlphabetic(6);
+
+        shop.setPassword(shop.getCode()+"@123456");
+        // 鐢熸垚瀵嗙爜
+        shop.setPassword(Utils.Secure.encryptPassword(shop.getPassword(), salt));
+        shop.setSalt(salt);
         shopMapper.insert(shop);
         return shop.getId();
     }
 
     public void isCreateParamValid(Shop shop , LoginUserInfo user){
-        if(StringUtils.isBlank(shop.getName())||
-        StringUtils.isBlank(shop.getImgurl())||
-                shop.getMemberId()==null
-        ){
-            throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(), ResponseStatus.BAD_REQUEST.getMessage());
+        try {
+            String[] ss = shop.getLocationInfo().split(",");
+            shop.setLatitude(BigDecimal.valueOf(Double.parseDouble(ss[0])));
+            shop.setLongitude(BigDecimal.valueOf(Double.parseDouble(ss[1])));
+        }catch (Exception e){
         }
-        Member member=memberMapper.selectById(shop.getMemberId());
-
-        if(Objects.isNull(member)){
-            throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"搴楅摵璐熻矗浜轰笉瀛樺湪");
+        if(StringUtils.isBlank(shop.getUsername())
+                ||  StringUtils.isBlank(shop.getPhone())
+                ||  StringUtils.isBlank(shop.getBusinessImg())
+                ||  StringUtils.isBlank(shop.getStartTime())
+                ||   shop.getLatitude()==null
+                ||   shop.getLongitude()==null
+                ||   shop.getBigAreaId()==null
+                ||   shop.getAreaId()==null
+                ||  StringUtils.isBlank(shop.getRealname())
+                ||  StringUtils.isBlank(shop.getName())
+                ||  StringUtils.isBlank(shop.getCode())){
+            throw  new BusinessException(ResponseStatus.BAD_REQUEST);
         }
+        if(AreasServiceImpl.getAddressByAreaId(shop.getAreaId()) ==null){
 
-        Shop query=new Shop();
-        query.setIsdeleted(Constants.ZERO);
-        query.setMemberId(shop.getMemberId());
-        if(shop.getId()!=null){
-            Shop result= shopMapper.selectOne(new QueryWrapper<>(query)
-            .last("limit 1")
-            );
-            if(!Constants.equalsInteger(result.getId(),shop.getId())){
-                throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"搴楅摵璐熻矗浜哄凡琚叧鑱旓紝璇蜂粠鏂伴�夋嫨璐熻矗浜�");
-            }
-        }else{
-            List<Shop> result= shopMapper.selectList(new QueryWrapper<>(query));
-            if(org.apache.commons.collections.CollectionUtils.isNotEmpty(result)){
-                throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"搴楅摵璐熻矗浜哄凡瀛樺湪锛岃浠庢柊閫夋嫨璐熻矗浜�");
-            }
+            throw  new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"璇烽�夋嫨姝g‘鐨勭渷甯傚尯淇℃伅~");
         }
-
+        if(labelsMapper.selectById(shop.getBigAreaId()) ==null){
+            throw  new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"璇烽�夋嫨姝g‘鐨勫尯鍩熶俊鎭瘇");
+        }
+        if(shopMapper.selectCount(new QueryWrapper<Shop>().lambda()
+                .eq(Shop::getName,shop.getName())
+                .ne(shop.getId()!=null,Shop::getId,shop.getId())
+                .eq(Shop::getIsdeleted,Constants.ZERO))>0){
+            throw  new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"缁忛攢鍟嗗悕绉伴噸澶嶏紝璇疯繑鍥炰慨鏀箏");
+        }
+        if(shopMapper.selectCount(new QueryWrapper<Shop>().lambda()
+                .eq(Shop::getCode,shop.getCode())
+                .ne(shop.getId()!=null,Shop::getId,shop.getId())
+                .eq(Shop::getIsdeleted,Constants.ZERO))>0){
+            throw  new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"闂ㄥ簵ID閲嶅锛岃杩斿洖淇敼~");
+        }
+        if(shopMapper.selectCount(new QueryWrapper<Shop>().lambda()
+                .eq(Shop::getUsername,shop.getUsername())
+                .ne(shop.getId()!=null,Shop::getId,shop.getId())
+                .eq(Shop::getIsdeleted,Constants.ZERO))>0){
+            throw  new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"鐧诲綍璐﹀彿閲嶅锛岃杩斿洖淇敼~");
+        }
     }
 
     @Override
@@ -180,7 +224,7 @@
     @Override
     public void updateById(Shop shop) {
         LoginUserInfo user = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal();
-        if(shop.getId()==null){
+        if(shop.getId()==null ){
             throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(), ResponseStatus.BAD_REQUEST.getMessage());
         }
         isCreateParamValid(shop,user);
@@ -279,6 +323,10 @@
         if(Objects.nonNull(shop)&&StringUtils.isNotBlank(shop.getImgurl())){
             shop.setImgFullUrl(path+shop.getImgurl());
         }
+        shop.setAreas(AreasServiceImpl.getAddressByAreaId(shop.getAreaId()));
+        if(shop.getLatitude()!=null && shop.getLongitude()!=null){
+            shop.setLocationInfo(shop.getLatitude().doubleValue()+","+shop.getLongitude().doubleValue());
+        }
         MPJLambdaWrapper<ProductLabel> queryproduct = new MPJLambdaWrapper<>();
         queryproduct.selectAs(Labels::getName,ProductLabel::getLablesName);
         queryproduct.eq(ProductLabel::getIsdeleted,Constants.ZERO);
@@ -297,6 +345,7 @@
 
     @Override
     public List<Shop> findList(Shop shop) {
+        shop.setIsdeleted(Constants.ZERO);
         QueryWrapper<Shop> wrapper = new QueryWrapper<>(shop);
         return shopMapper.selectList(wrapper);
     }
@@ -308,24 +357,39 @@
         Utils.MP.blankToNull(pageWrap.getModel());
 
         queryWrapper.selectAll(Shop.class);
+        if(pageWrap.getModel().getGoodsId()!=null){
+            //鏌ヨ鏌愬晢鍝佺殑渚涜揣浠�
+            queryWrapper.select("(select s.price from shop_goods_relation s where s.ISDELETED=0 and s.shop_id = t.id and s.GOODS_ID="+pageWrap.getModel().getGoodsId()+") as goodsPrice ");
+        }
+        queryWrapper.selectAs(Labels::getName,Shop::getBigAreaName);
         queryWrapper.selectAs(Member::getNickname,Shop::getNickName);
         queryWrapper.selectAs(Member::getImgurl,Shop::getMemberImgurl);
         queryWrapper.selectAs(Member::getPhone,Shop::getMemberPhone);
 
         queryWrapper.leftJoin(Member.class,Member::getId,Shop::getMemberId);
+        queryWrapper.leftJoin(Labels.class,Labels::getId,Shop::getBigAreaId);
 
         queryWrapper.eq(Shop::getIsdeleted, Constants.ZERO);
-
-        queryWrapper.and(StringUtils.isNotBlank(pageWrap.getModel().getName()),s->s.like(Shop::getName,pageWrap.getModel().getName()));
+        queryWrapper.like(StringUtils.isNotBlank(pageWrap.getModel().getCode()) ,Shop::getCode,pageWrap.getModel().getCode());
+        queryWrapper.like(StringUtils.isNotBlank(pageWrap.getModel().getUsername()) ,Shop::getName,pageWrap.getModel().getUsername());
+        queryWrapper.like(StringUtils.isNotBlank(pageWrap.getModel().getName()) ,Shop::getName,pageWrap.getModel().getName());
+        queryWrapper.eq(pageWrap.getModel().getSaleType()!=null, Shop::getSaleType, pageWrap.getModel().getSaleType());
         queryWrapper.eq(pageWrap.getModel().getStatus()!=null, Shop::getStatus, pageWrap.getModel().getStatus());
         queryWrapper.eq(pageWrap.getModel().getIsrec()!=null, Shop::getIsrec, pageWrap.getModel().getIsrec());
-        queryWrapper.orderByDesc(Shop::getCreateDate);
+        if(pageWrap.getModel().getGoodsId()!=null){
+            queryWrapper.orderByAsc("goodsPrice");
+        }
+        queryWrapper.orderByDesc(Shop::getId);
         IPage<Shop> result = shopJoinMapper.selectJoinPage(page, Shop.class, queryWrapper);
-
         String path = systemDictDataBiz.queryByCode(Constants.OSS, Constants.RESOURCE_PATH).getCode()
                 + systemDictDataBiz.queryByCode(Constants.OSS, Constants.SHOP_FILE).getCode();
         for(Shop model:result.getRecords()){
             model.setImgFullUrl(path);
+            model.setAreas( AreasServiceImpl.getAddressByAreaId(model.getAreaId()));
+            if(model.getLatitude()!=null && model.getLongitude()!=null){
+                model.setLocationInfo(model.getLatitude().doubleValue()+","+model.getLongitude().doubleValue());
+            }
+
         }
         return PageData.from(result );
     }
@@ -498,16 +562,16 @@
         memberCoupon.setShopId(shopId);
         memberCoupon.setType(Constants.ZERO);
         memberCoupon.setStatus(Constants.ONE);
-        Integer shopCouponUseCount = memberCouponService.count(memberCoupon);
+        long shopCouponUseCount = memberCouponService.count(memberCoupon);
 
         ShopFollow shopFollow = new ShopFollow();
         shopFollow.setObjId(shopId);
         shopFollow.setObjType(Constants.ZERO);
-        Integer shopFansCount = shopFollowService.count(shopFollow);
+        long shopFansCount = shopFollowService.count(shopFollow);
 
         ShopNews shopNews = new ShopNews();
         shopNews.setShopId(shopId);
-        Integer shopNewCount = shopNewsService.count(shopNews);
+        long shopNewCount = shopNewsService.count(shopNews);
         ShopDataStatisticsDTO shopDataStatisticsDTO = new ShopDataStatisticsDTO();
         shopDataStatisticsDTO.setShopCouponUseCount(shopCouponUseCount)
                 .setShopFansCount(shopFansCount).setShopNewCount(shopNewCount);
@@ -530,4 +594,296 @@
         shopScan.setMemberId(shop.getMemberId());
         shopScanService.create(shopScan);
     }
+
+    @Override
+    public void resetPwd(Shop dto) {
+        // 鏌ヨ鐢ㄦ埛
+        Shop shop = findById(dto.getId());
+        if (shop == null) {
+            throw new BusinessException(ResponseStatus.DATA_EMPTY);
+        }
+        // 淇敼瀵嗙爜
+        Shop updateUserDto = new Shop();
+        updateUserDto.setId(dto.getId());
+        updateUserDto.setPassword(Utils.Secure.encryptPassword( shop.getCode()+"@123456", shop.getSalt()));
+        shopMapper.updateById(updateUserDto);
+    }
+
+
+    /**
+     * 鐢ㄦ埛涓嬪崟鏌ヨ鍙�夋嫨鐨勮嚜鎻愮粡閿�鍟�
+     * @param dto
+     * @return
+     */
+    @Override
+    public List<Shop> getShopList(ShopListDTO dto){
+        Boolean isArea = false;
+        if(Objects.nonNull(dto)&&StringUtils.isNotBlank(dto.getLat())
+        && StringUtils.isNotBlank(dto.getLgt())){
+            isArea = true;
+        }
+
+        List<Shop> shopList = shopJoinMapper.selectList(new MPJLambdaWrapper<Shop>()
+                .selectAll(Shop.class)
+                .select(" CONVERT( ST_Distance_Sphere ( POINT ( LONGITUDE, LATITUDE ), POINT ( "+dto.getLgt()+", "+dto.getLat()+" )) /1000,DECIMAL(15,2))",Shop::getDistance)
+                .leftJoin(Areas.class,Areas::getId,Shop::getAreaId)
+                .eq(Objects.nonNull(dto.getCityId()),Areas::getParentId,dto.getCityId())
+                .like(Objects.nonNull(dto.getShopName()),Shop::getName,dto.getShopName())
+                .orderByDesc(!isArea,Shop::getId)
+                .orderByAsc(isArea,Shop::getDistance)
+        );
+        String path = systemDictDataBiz.queryByCode(Constants.OSS, Constants.RESOURCE_PATH).getCode()
+                + systemDictDataBiz.queryByCode(Constants.OSS, Constants.SHOP_FILE).getCode();
+        for(Shop model:shopList){
+            model.setImgFullUrl(path+model.getImgurl());
+
+        }
+        return shopList;
+    }
+
+
+
+    /**
+     * 鏍规嵁openid鑾峰彇鏄惁缁戝畾浜嗗晢鎴�
+     * @param dto
+     * @return
+     */
+    @Override
+    public AccountResponse shopOpenidLogin(ShopLoginDTO dto){
+        Shop shop = shopMapper.selectOne(new QueryWrapper<Shop>().lambda().eq(Shop::getOpenId, dto.getOpenid())
+                .eq(Shop::getIsdeleted,Constants.ZERO)
+                .last("limit 1")
+        );
+        AccountResponse accountResponse = new AccountResponse();
+        accountResponse.setOpenid(dto.getOpenid());
+        if(Objects.nonNull(shop)){
+            if(Objects.isNull(dto.getMemberId())
+                    && ( Objects.isNull(shop.getMemberId())
+                    || !Constants.equalsInteger(shop.getMemberId(),dto.getMemberId()))){
+                shopMapper.update(null,new UpdateWrapper<Shop>().lambda()
+                        .set(Shop::getMemberId,dto.getMemberId())
+                        .eq(Shop::getId,shop.getId())
+                );
+            }
+            JwtPayLoad payLoad = new JwtPayLoad(Constants.SHOP_PREFIX+shop.getId());
+            String token = JwtTokenUtil.generateToken(payLoad);
+            accountResponse.setToken(token);
+        }
+        return accountResponse;
+    }
+
+
+    /**
+     * 鍟嗘埛璐﹀彿瀵嗙爜鐧诲綍
+     * @param dto
+     * @return
+     */
+    @Override
+    public AccountResponse shopPasswordLogin(ShopLoginDTO dto){
+        if(StringUtils.isBlank(dto.getUserName())
+                || StringUtils.isBlank(dto.getPassword())
+                || StringUtils.isBlank(dto.getOpenid())
+        ){
+            throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"鐢ㄦ埛鍚嶆垨瀵嗙爜涓嶈兘涓虹┖");
+        }
+        Shop shop = shopMapper.selectOne(new QueryWrapper<Shop>().lambda().eq(Shop::getUsername, dto.getUserName())
+                .eq(Shop::getIsdeleted,Constants.ZERO)
+                .last("limit 1")
+        );
+        if(shop==null){
+            throw new BusinessException(ResponseStatus.ACCOUNT_INCORRECT);
+        }
+        //鍔犲瘑瀵嗙爜
+        String pwd = Utils.Secure.encryptPassword( dto.getPassword(), shop.getSalt());
+        if(!pwd.equals(shop.getPassword())){
+            throw new BusinessException(ResponseStatus.ACCOUNT_INCORRECT);
+        }
+        //鍒涘缓token
+        JwtPayLoad payLoad = new JwtPayLoad(Constants.SHOP_PREFIX+shop.getId());
+        String token = JwtTokenUtil.generateToken(payLoad);
+        AccountResponse accountResponse = new AccountResponse();
+        accountResponse.setToken(token);
+        shopMapper.update(null,new UpdateWrapper<Shop>().lambda()
+                .set(Shop::getOpenId,dto.getOpenid())
+                .set(Shop::getMemberId,dto.getMemberId())
+                .eq(Shop::getId,shop.getId())
+        );
+        shopMapper.update(null,new UpdateWrapper<Shop>().lambda()
+                .set(Shop::getOpenId,null)
+                .eq(Shop::getOpenId,dto.getOpenid())
+                .ne(Shop::getId,shop.getId())
+        );
+        return accountResponse;
+    }
+
+
+
+
+    @Override
+    public ShopInfoResponse getShopInfo(Integer shopId){
+        ShopInfoResponse response = new ShopInfoResponse();
+        Shop shop = shopMapper.selectById(shopId);
+        if(Objects.isNull(shop)){
+            throw new BusinessException(ResponseStatus.DATA_EMPTY);
+        }
+        String path = systemDictDataBiz.queryByCode(Constants.OSS, Constants.RESOURCE_PATH).getCode()
+                + systemDictDataBiz.queryByCode(Constants.OSS, Constants.SHOP_FILE).getCode();
+        BeanUtils.copyProperties(shop,response);
+        response.setImgurl(path + shop.getImgurl());
+        response.setIdcardImg(path + shop.getIdcardImg());
+        response.setIdcardImgBack(path + shop.getIdcardImgBack());
+        response.setBusinessImg(path + shop.getBusinessImg());
+
+        return response;
+    }
+
+
+    @Override
+    public List<MyCustomerResponse> myCustomer(MyCustomerRequest request, Integer shopId){
+        List<Member>  memberList = memberJoinMapper.selectJoinList(Member.class,
+                new MPJLambdaWrapper<Member>()
+                        .selectAll(Member.class)
+                        .eq(Member::getIsdeleted,Constants.ZERO)
+                        .eq(Member::getBindShopId,shopId)
+                        .and(StringUtils.isNotBlank(request.getMemberIfo()),i->i.like(Member::getPhone,request.getMemberIfo()).or().like(Member::getNickname,request.getMemberIfo()))
+        );
+        List<MyCustomerResponse> responseList = new ArrayList<>();
+        if(com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(memberList)){
+            String path = systemDictDataBiz.queryByCode(Constants.OSS, Constants.RESOURCE_PATH).getCode()
+                    + systemDictDataBiz.queryByCode(Constants.OSS, Constants.MEMBER_FILE).getCode();
+            memberList.forEach(member -> {
+                MyCustomerResponse response = new MyCustomerResponse();
+                response.setNickName(member.getNickname());
+                response.setPhone(member.getPhone().replaceAll("(\\d{3})\\d{4}(\\d{4})","$1****$2"));
+                response.setBindShopDate(member.getBindShopDate());
+                response.setImgFullUrl(StringUtils.isNotBlank(member.getImgurl())?path + member.getImgurl():"");
+                responseList.add(response);
+            });
+        }
+        return responseList;
+    }
+
+
+
+    @Override
+    public SaleReportResponse saleReport(SaleReportRequest request,String shopId){
+        SaleReportResponse saleReportResponse = new SaleReportResponse();
+        saleReportResponse.setSaleTotal(BigDecimal.ZERO);
+        saleReportResponse.setOrderNum(Constants.ZERO);
+        saleReportResponse.setProfitTotal(BigDecimal.ZERO);
+
+        List<Goodsorder> goodsorderList = goodsorderJoinMapper.selectJoinList(Goodsorder.class,
+                new MPJLambdaWrapper<Goodsorder>()
+                        .selectAll(Goodsorder.class)
+                        .selectAs(Member::getPhone,Goodsorder::getPhone)
+                        .selectAs(Member::getNickname,Goodsorder::getNickName)
+                        .select(" select ifnull(sum(g.SHOP_SETTLEMENT),0) from goodsorder_detail g where t.id = g.ORDER_ID   ",Goodsorder::getShopSettlement)
+                        .leftJoin(Member.class,Member::getId,Goodsorder::getMemberId)
+                        .eq(Goodsorder::getIsdeleted,Constants.ZERO)
+                        .eq(Goodsorder::getDistributionShopId,shopId)
+                        //浠婃棩
+                        .apply(Constants.equalsInteger(request.getDateType(),Constants.ZERO), " DATE(t.CREATE_DATE) = DATE(NOW())  ")
+                        //褰撴湀
+                        .apply(Constants.equalsInteger(request.getDateType(),Constants.ONE), " DATE_FORMAT(t.CREATE_DATE, '%Y-%m') = DATE_FORMAT(NOW(), '%Y-%m')")
+                        //涓婃湀
+                        .apply(Constants.equalsInteger(request.getDateType(),Constants.TWO), "  DATE_FORMAT(t.CREATE_DATE, '%Y-%m') = DATE_FORMAT(DATE_SUB(CURDATE(), INTERVAL 1 MONTH), '%Y-%m') ")
+                        //鍥哄畾鏈堜唤
+                        .apply(Constants.equalsInteger(request.getDateType(),Constants.THREE)&&StringUtils.isNotBlank(request.getStartDate()), " DATE_FORMAT(t.CREATE_DATE, '%Y-%m') = DATE_FORMAT(DATE_SUB('"+request.getStartDate()+"', INTERVAL 1 MONTH), '%Y-%m') ")
+                        //鑷畾涔夋棩鏈�
+                        .apply(Constants.equalsInteger(request.getDateType(),Constants.FOUR)&&StringUtils.isNotBlank(request.getStartDate()), "  t.CREATE_DATE >= '"+request.getStartDate()+" 00:00:00'")
+                        .apply(Constants.equalsInteger(request.getDateType(),Constants.FOUR)&&StringUtils.isNotBlank(request.getEndDate()), "  t.CREATE_DATE <= '"+request.getEndDate()+" 23:59:59'")
+                        .ne(Goodsorder::getStatus,Constants.OrderStatus.CLOSE.getKey())
+                        .orderByDesc(Goodsorder::getId)
+        );
+        if (com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(goodsorderList)) {
+            saleReportResponse.setSaleTotal(goodsorderList.stream().map(i->i.getPrice().subtract(i.getMailPrice())).reduce(BigDecimal.ZERO, BigDecimal::add));
+            saleReportResponse.setOrderNum(goodsorderList.size());
+            if(Constants.equalsInteger(request.getQueryType(),Constants.ONE)){
+                List<SaleReportOrderResponse> list = new ArrayList<>();
+                goodsorderList.stream().forEach(goodsorder -> {
+                    SaleReportOrderResponse response = new SaleReportOrderResponse();
+                    response.setId(goodsorder.getId());
+                    response.setCode(goodsorder.getCode());
+                    response.setPrice(goodsorder.getPrice());
+                    response.setMailPrice(goodsorder.getMailPrice());
+                    response.setCreateDate(goodsorder.getCreateDate());
+                    response.setNickName(goodsorder.getNickName());
+                    response.setPhone(goodsorder.getPhone().replaceAll("(\\d{3})\\d{4}(\\d{4})", "$1****$2"));
+                    response.setShopSettlement(goodsorder.getShopSettlement());
+                    list.add(response);
+                });
+
+                saleReportResponse.setSaleReportOrderResponseList(list);
+            }
+        }
+        List<Integral> integralList = integralMapper.selectList(new QueryWrapper<Integral>().lambda()
+                .eq(Integral::getIsdeleted,Constants.ZERO)
+                .eq(Integral::getMemberId,shopId)
+                .eq(Integral::getUserType,Constants.TWO)
+                .eq(Integral::getType,Constants.ZERO)
+                .eq(Integral::getObjType,Constants.IntegralObjType.ORDER_DONE_AMOUNT.getKey())
+                //浠婃棩
+                .apply(Constants.equalsInteger(request.getDateType(),Constants.ZERO), " DATE(CREATE_DATE) = DATE(NOW())  ")
+                //褰撴湀
+                .apply(Constants.equalsInteger(request.getDateType(),Constants.ONE), " DATE_FORMAT(CREATE_DATE, '%Y-%m') = DATE_FORMAT(NOW(), '%Y-%m')")
+                //涓婃湀
+                .apply(Constants.equalsInteger(request.getDateType(),Constants.TWO), "  DATE_FORMAT(CREATE_DATE, '%Y-%m') = DATE_FORMAT(DATE_SUB(CURDATE(), INTERVAL 1 MONTH), '%Y-%m') ")
+                //鍥哄畾鏈堜唤
+                .apply(Constants.equalsInteger(request.getDateType(),Constants.THREE)&&StringUtils.isNotBlank(request.getStartDate()), " DATE_FORMAT(CREATE_DATE, '%Y-%m') = DATE_FORMAT(DATE_SUB('"+request.getStartDate()+"', INTERVAL 1 MONTH), '%Y-%m') ")
+                //鑷畾涔夋棩鏈�
+                .apply(Constants.equalsInteger(request.getDateType(),Constants.FOUR)&&StringUtils.isNotBlank(request.getStartDate()), "  CREATE_DATE >= '"+request.getStartDate()+" 00:00:00'")
+                .apply(Constants.equalsInteger(request.getDateType(),Constants.FOUR)&&StringUtils.isNotBlank(request.getEndDate()), "  CREATE_DATE <= '"+request.getEndDate()+" 23:59:59'")
+        );
+        if (com.github.xiaoymin.knife4j.core.util.CollectionUtils.isNotEmpty(integralList)) {
+            saleReportResponse.setProfitTotal(integralList.stream().map(i->i.getNum()).reduce(BigDecimal.ZERO, BigDecimal::add));
+        }
+        return  saleReportResponse;
+    }
+
+
+
+
+
+
+
+    @Override
+    @Transactional
+    public  String setGoodsPrice(Shop dto){
+        // 鏌ヨ鐢ㄦ埛
+        Shop shop = shopMapper.selectById(dto.getId());
+        if (shop == null) {
+            throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"瀵逛笉璧凤紝渚涢攢鍟嗕俊鎭煡璇㈡棤鏁堬紒");
+        }
+        GoodsSku queryGoodsSku=new GoodsSku();
+        queryGoodsSku.setGoodsId(dto.getGoodsId());
+        queryGoodsSku.setIsdeleted(Constants.ZERO);
+        List<GoodsSku> goodsSkuList=goodsSkuMapper.selectList(new QueryWrapper<>(queryGoodsSku));
+        if(goodsSkuList==null || goodsSkuList.size() ==0){
+            throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"瀵逛笉璧凤紝璇风‘璁ゅ晢鍝佷俊鎭湁鏁堜笖銆愰攢鍞环銆戝凡璁剧疆锛�");
+        }
+        //榛樿sku淇℃伅
+        GoodsSku goodsSku = goodsSkuList.get(0);
+        if(Constants.formatBigdecimal(goodsSku.getPrice()).compareTo(Constants.formatBigdecimal(dto.getGoodsPrice())) >=0){
+            throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"瀵逛笉璧凤紝渚涜揣浠蜂笉鍏佽澶т簬鍟嗗搧閿�鍞环锛�");
+        }
+        LoginUserInfo user = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal();
+        //鍏堝垹闄ゅ師鏉ョ殑鏁版嵁
+        shopGoodsRelationMapper.delete(new QueryWrapper<ShopGoodsRelation>().lambda()
+                .eq(ShopGoodsRelation::getGoodsId,dto.getGoodsId())
+                .eq(ShopGoodsRelation::getShopId,shop.getId())
+         );
+        ShopGoodsRelation add =new ShopGoodsRelation();
+        add.setCreator(user.getId());
+        add.setCreateDate(new Date());
+        add.setIsdeleted(Constants.ZERO);
+        add.setEditor(add.getCreator());
+        add.setEditDate(add.getCreateDate());
+        add.setShopId(dto.getId());
+        add.setGoodsId(dto.getGoodsId());
+        add.setGoodsSkuId(goodsSku.getId());
+        add.setPrice(dto.getGoodsPrice());
+        add.setStatus(Constants.ZERO);
+        shopGoodsRelationMapper.insert(add);
+        return "鎿嶄綔鎴愬姛";
+    }
 }

--
Gitblit v1.9.3