From 4e34319c9d3f57bd20e12e45e8ecbae8e0435591 Mon Sep 17 00:00:00 2001 From: Hentua <wangdoubleone@gmail.com> Date: Sun, 04 Jun 2023 00:28:04 +0800 Subject: [PATCH] fix --- src/main/java/cc/mrbird/febs/mall/service/impl/SystemServiceImpl.java | 39 +++++++++++++++++++++++++++++++++++++++ 1 files changed, 39 insertions(+), 0 deletions(-) diff --git a/src/main/java/cc/mrbird/febs/mall/service/impl/SystemServiceImpl.java b/src/main/java/cc/mrbird/febs/mall/service/impl/SystemServiceImpl.java index c702346..dbef327 100644 --- a/src/main/java/cc/mrbird/febs/mall/service/impl/SystemServiceImpl.java +++ b/src/main/java/cc/mrbird/febs/mall/service/impl/SystemServiceImpl.java @@ -1,15 +1,25 @@ package cc.mrbird.febs.mall.service.impl; +import cc.mrbird.febs.common.exception.FebsException; import cc.mrbird.febs.mall.dto.CashOutSettingDto; import cc.mrbird.febs.mall.entity.DataDictionaryCustom; +import cc.mrbird.febs.mall.entity.MallBonusRecord; +import cc.mrbird.febs.mall.entity.MallSystemSetting; import cc.mrbird.febs.mall.mapper.DataDictionaryCustomMapper; +import cc.mrbird.febs.mall.mapper.MallBonusRecordMapper; +import cc.mrbird.febs.mall.mapper.MallSystemSettingMapper; import cc.mrbird.febs.mall.service.ICommonService; import cc.mrbird.febs.mall.service.ISystemService; +import cn.hutool.core.bean.BeanUtil; import com.alibaba.fastjson.JSONObject; +import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import lombok.RequiredArgsConstructor; import lombok.extern.slf4j.Slf4j; import org.springframework.stereotype.Service; +import org.springframework.transaction.annotation.Transactional; +import java.math.BigDecimal; +import java.util.Date; import java.util.LinkedHashMap; import java.util.List; import java.util.Map; @@ -25,12 +35,41 @@ private final DataDictionaryCustomMapper dictionaryCustomMapper; private final ICommonService commonService; + private final MallSystemSettingMapper mallSystemSettingMapper; + private final MallBonusRecordMapper mallBonusRecordMapper; @Override + @Transactional(rollbackFor = Exception.class) public void bonusSystemSetting(Map<String, Object> map) { for (Map.Entry<String, Object> entry : map.entrySet()) { if (entry.getValue() instanceof String) { dictionaryCustomMapper.updateDicValueByTypeAndCode(null, entry.getKey(), (String) entry.getValue()); + } else if (entry.getValue() instanceof LinkedHashMap) { + LinkedHashMap<String, Object> bonusSettingMap = (LinkedHashMap<String, Object>) entry.getValue(); + LambdaQueryWrapper<MallSystemSetting> update = new LambdaQueryWrapper<>(); + update.eq(MallSystemSetting::getId, bonusSettingMap.get("id")) + .eq(MallSystemSetting::getRevision, bonusSettingMap.get("revision")); + + MallSystemSetting old = mallSystemSettingMapper.selectById(1L); + MallSystemSetting setting = new MallSystemSetting(); + setting.setRevision((Integer) bonusSettingMap.get("revision") + 1); + setting.setId(Long.parseLong(bonusSettingMap.get("id").toString())); + setting.setAllBonus(new BigDecimal(bonusSettingMap.get("allBonus").toString())); + setting.setAgentBonus(new BigDecimal(bonusSettingMap.get("agentBonus").toString())); + setting.setPartnerBonus(new BigDecimal(bonusSettingMap.get("partnerBonus").toString())); + int i = mallSystemSettingMapper.update(setting, update); + if (i == 0) { + throw new FebsException("请刷新页面"); + } + + if (old.getAllBonus().compareTo(setting.getAllBonus()) != 0 || old.getAgentBonus().compareTo(setting.getAgentBonus()) != 0 || old.getPartnerBonus().compareTo(setting.getPartnerBonus()) != 0) { + MallBonusRecord record = new MallBonusRecord(); + record.setAmount(BigDecimal.ZERO); + record.setType(999); + record.setComment(JSONObject.toJSONString(old) + "-" + JSONObject.toJSONString(setting)); + record.setCreateTime(new Date()); + mallBonusRecordMapper.insert(record); + } } else { List<LinkedHashMap<String, Object>> value = (List<LinkedHashMap<String, Object>>) entry.getValue(); -- Gitblit v1.9.1