KKSU
2024-03-15 b87c5549fe471167882192944db3f2d6b729476c
src/main/java/cc/mrbird/febs/mall/service/impl/AdminMallGoodsService.java
@@ -2,16 +2,24 @@
import cc.mrbird.febs.common.entity.FebsResponse;
import cc.mrbird.febs.common.entity.QueryRequest;
import cc.mrbird.febs.common.enumerates.DataDictionaryEnum;
import cc.mrbird.febs.common.utils.AppContants;
import cc.mrbird.febs.common.utils.RedisUtils;
import cc.mrbird.febs.mall.conversion.MallGoodsConversion;
import cc.mrbird.febs.mall.conversion.TzInfoConversion;
import cc.mrbird.febs.mall.dto.*;
import cc.mrbird.febs.mall.entity.*;
import cc.mrbird.febs.mall.mapper.*;
import cc.mrbird.febs.mall.service.AsyncCjService;
import cc.mrbird.febs.mall.service.IAdminMallGoodsService;
import cc.mrbird.febs.mall.vo.*;
import cn.hutool.core.bean.BeanUtil;
import cn.hutool.core.collection.CollUtil;
import cn.hutool.core.util.ObjectUtil;
import cn.hutool.core.util.StrUtil;
import cn.hutool.json.JSONObject;
import cn.hutool.json.JSONUtil;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
@@ -21,10 +29,8 @@
import org.springframework.transaction.annotation.Transactional;
import java.math.BigDecimal;
import java.util.ArrayList;
import java.util.HashSet;
import java.util.List;
import java.util.Set;
import java.util.*;
import java.util.stream.Collectors;
@Slf4j
@Service
@@ -38,6 +44,12 @@
    private final MallGoodsStyleMapper mallGoodsStyleMapper;
    private final MallGoodsImagesMapper mallGoodsImagesMapper;
    private final MallShoppingCartMapper mallShoppingCartMapper;
    private final RedisUtils redisUtils;
    private final CjItemMapper cjItemMapper;
    private final CjInfoMapper cjInfoMapper;
    private final TzInfoMapper tzInfoMapper;
    private final DataDictionaryCustomMapper dataDictionaryCustomMapper;
    private final AsyncCjService asyncCjService;
    @Override
    public IPage<AdminMallGoodsVo> getCategoryListInPage(MallGoods mallGoods, QueryRequest request) {
@@ -341,7 +353,7 @@
        }
        BeanUtil.copyProperties(mallGoodsUpdateDto, mallGoods);
        if (mallGoods.getHasCarriage() == 2) {
        if (mallGoodsUpdateDto.getHasCarriage() == 2) {
            mallGoods.setCarriage(BigDecimal.ZERO);
        }
@@ -473,5 +485,76 @@
        return mallGoodsMapper.getAllGoodsTree();
    }
    @Override
    public FebsResponse goodsHot(Long id) {
        MallGoods mallGoods = mallGoodsMapper.selectById(id);
        if (ObjectUtil.isEmpty(mallGoods)) {
            return new FebsResponse().fail().message("商品不存在,请刷新当前页面");
        }
        mallGoods.setIsHot(MallGoods.ISHOT_STATE_YES);
        mallGoodsMapper.updateById(mallGoods);
        return new FebsResponse().success();
    }
    @Override
    public FebsResponse goodsNotHot(Long id) {
        MallGoods mallGoods = mallGoodsMapper.selectById(id);
        if (ObjectUtil.isEmpty(mallGoods)) {
            return new FebsResponse().fail().message("商品不存在,请刷新当前页面");
        }
        mallGoods.setIsHot(MallGoods.ISHOT_STATE_NO);
        mallGoodsMapper.updateById(mallGoods);
        return new FebsResponse().success();
    }
    @Override
    public IPage<TzInfo> getTzListInPage(TzInfo tzInfo, QueryRequest request) {
        Page<TzInfo> page = new Page<>(request.getPageNum(), request.getPageSize());
        IPage<TzInfo> adminMallGoodsVos = this.baseMapper.getTzListInPage(page, tzInfo);
        List<TzInfo> records = adminMallGoodsVos.getRecords();
        String kjNo = redisUtils.getString(AppContants.KJ_RECORD_NO);
        QueryWrapper<CjInfo> objectQueryWrapper = new QueryWrapper<>();
        objectQueryWrapper.eq("kj_no",kjNo);
        List<CjInfo> cjInfos = cjInfoMapper.selectList(objectQueryWrapper);
        if(CollUtil.isNotEmpty(cjInfos)){
            List<Long> collect = cjInfos.stream().map(CjInfo::getId).collect(Collectors.toList());
            List<CjItem> cjItems = cjItemMapper.selectSumAmountByInfoId(collect);
            for(TzInfo tzInfo1 : records){
                List<CjItem> collect1 = cjItems.stream().filter(cjItem -> cjItem.getTzCode().equals(tzInfo1.getTzCode())).collect(Collectors.toList());
                if(CollUtil.isNotEmpty(collect1)){
                    BigDecimal reduce = collect1.stream().map(CjItem::getAmount).reduce(BigDecimal.ZERO, BigDecimal::add);
                    tzInfo1.setTzAmount(reduce);
                }else{
                    tzInfo1.setTzAmount(BigDecimal.ZERO);
                }
            }
        }
        return adminMallGoodsVos;
    }
    @Override
    public FebsResponse tzUpdate(TzInfo tzInfo) {
        Long id = tzInfo.getId();
        TzInfo tzInfo1 = tzInfoMapper.selectById(id);
        if(ObjectUtil.isEmpty(tzInfo1)){
            return new FebsResponse().fail().message("设置失败");
        }
        tzInfo1.setTzCode(tzInfo.getTzCode());
        tzInfo1.setTzPercent(tzInfo.getTzPercent());
        tzInfoMapper.updateById(tzInfo1);
        if(ObjectUtil.isNotEmpty(tzInfo.getIsRecommend())){
            dataDictionaryCustomMapper.updateDicValueByTypeAndCode(
                    DataDictionaryEnum.OPEN_PRICE.getType(),
                    DataDictionaryEnum.OPEN_PRICE.getCode(),
                    tzInfo.getIsRecommend()
            );
        }
        asyncCjService.tzInfo();
        return new FebsResponse().success().message("操作成功");
    }
}