From 8d08ca6bdfc3dd61b0aaa7daa27308c3d59f0df1 Mon Sep 17 00:00:00 2001 From: xiaoyong931011 <15274802129@163.com> Date: Wed, 14 Jul 2021 15:03:11 +0800 Subject: [PATCH] 202107014 --- gc-user/src/main/java/com/xzx/gc/user/service/DistribService.java | 93 +++++++++++++++++++++++ gc-user/src/main/java/com/xzx/gc/user/dto/ViewSettingDto.java | 2 gc-user/src/main/java/com/xzx/gc/user/vo/ViewSettingVo.java | 24 +++++- gc-user/src/main/resources/mapper/user/RedPaperRuleMapper.xml | 4 + gc-user/src/main/java/com/xzx/gc/user/mapper/RedPaperRuleMapper.java | 2 gc-user/src/main/java/com/xzx/gc/user/dto/UpdateSettingDto.java | 31 +++++++ gc-user/src/main/java/com/xzx/gc/user/controller/AdminDistribController.java | 48 +++++++++++ 7 files changed, 195 insertions(+), 9 deletions(-) diff --git a/gc-user/src/main/java/com/xzx/gc/user/controller/AdminDistribController.java b/gc-user/src/main/java/com/xzx/gc/user/controller/AdminDistribController.java index 341cad8..fa68dcb 100644 --- a/gc-user/src/main/java/com/xzx/gc/user/controller/AdminDistribController.java +++ b/gc-user/src/main/java/com/xzx/gc/user/controller/AdminDistribController.java @@ -1,9 +1,19 @@ package com.xzx.gc.user.controller; +import cn.hutool.core.util.ObjectUtil; +import cn.hutool.core.util.StrUtil; +import com.xzx.gc.common.Result; +import com.xzx.gc.common.constant.CommonEnum; import com.xzx.gc.common.constant.Constants; +import com.xzx.gc.common.dto.log.OperationAppLog; import com.xzx.gc.common.request.BaseController; +import com.xzx.gc.entity.JhyInfo; +import com.xzx.gc.entity.RedPaperRule; import com.xzx.gc.model.JsonResult; +import com.xzx.gc.user.dto.ExamineJwyDto; +import com.xzx.gc.user.dto.UpdateSettingDto; import com.xzx.gc.user.dto.ViewSettingDto; +import com.xzx.gc.user.mapper.RedPaperRuleMapper; import com.xzx.gc.user.service.DistribService; import com.xzx.gc.user.vo.ViewSettingVo; import io.swagger.annotations.Api; @@ -15,12 +25,18 @@ import org.springframework.web.bind.annotation.RequestBody; import org.springframework.web.bind.annotation.RestController; +import javax.annotation.Resource; +import javax.servlet.http.HttpServletRequest; + @RestController @Api(tags = {"分銷系統管理"}) public class AdminDistribController extends BaseController { - @Autowired + @Resource private DistribService distribService; + + @Resource + private RedPaperRuleMapper redPaperRuleMapper; /** * 查看分銷系統设置详情 @@ -29,10 +45,36 @@ @ApiResponses({@ApiResponse( code = 200, message = "success", response = ViewSettingVo.class)}) @ApiOperation(value="分銷系統管理-查看分銷系統设置详情", notes="test: 仅0有正确返回") public JsonResult<ViewSettingVo> viewSetting(@RequestBody ViewSettingDto viewSettingDto) { - Long id = viewSettingDto.getId(); - ViewSettingVo viewSettingVo = distribService.viewSetting(id); + ViewSettingVo viewSettingVo = distribService.viewSetting("分销规则"); return JsonResult.success(viewSettingVo); } + /** + * 更新分銷系統设置 + */ + @PostMapping(Constants.ADMIN_VIEW_PREFIX + "/jhy/updateSetting.json") + @ApiOperation(value="分銷系統管理--更新分銷系統设置", notes="test: 仅0有正确返回") + public JsonResult updateSetting(@RequestBody UpdateSettingDto model, HttpServletRequest request) { + + RedPaperRule redPaperRule = redPaperRuleMapper.selectByRuleName("分销规则"); + if(ObjectUtil.isEmpty(redPaperRule)){ + distribService.addSetting(model); + OperationAppLog build = OperationAppLog.builder().appPrograme(CommonEnum.后台.getValue()).opreateName(getAdminName(request)) + .methodName(Constants.USER_MODUL_NAME).operateAction("分銷系統管理--新增分銷系統设置").build(); + mqUtil.sendApp(build); + }else{ + Integer id = model.getId(); + if(redPaperRule.getId() != id){ + return JsonResult.failMessage("规则不存在!"); + } + distribService.updateSetting(model); + OperationAppLog build = OperationAppLog.builder().appPrograme(CommonEnum.后台.getValue()).opreateName(getAdminName(request)) + .methodName(Constants.USER_MODUL_NAME).operateAction("分銷系統管理--更新分銷系統设置-" + model.getId()).build(); + mqUtil.sendApp(build); + } + return JsonResult.success("操作成功!"); + } + + } diff --git a/gc-user/src/main/java/com/xzx/gc/user/dto/UpdateSettingDto.java b/gc-user/src/main/java/com/xzx/gc/user/dto/UpdateSettingDto.java new file mode 100644 index 0000000..5ba5dee --- /dev/null +++ b/gc-user/src/main/java/com/xzx/gc/user/dto/UpdateSettingDto.java @@ -0,0 +1,31 @@ +package com.xzx.gc.user.dto; + +import io.swagger.annotations.ApiModelProperty; +import lombok.Data; + +import java.math.BigDecimal; + +@Data +public class UpdateSettingDto { + + @ApiModelProperty(value = "Id,没有可以不传") + private Integer id; + + //首单奖励(FristReward)元 + @ApiModelProperty(value = "首单奖励(FristReward)元") + private BigDecimal fristReward; + + //团员在完成首单后,(orderNumFrist)笔单内,可以固定积分(regularPoint)+环保币(regularMoneyPercent)方式进行返佣团长 + @ApiModelProperty(value = "团员在完成首单后,(orderNumFrist)笔单内,可以固定积分(regularPoint)+环保币(regularMoneyPercent)方式进行返佣团长") + private Integer orderNumFrist; + private Integer regularPoint; + private BigDecimal regularMoneyPercent; + + //团员完成(FinishOrderNum)单后,团员每完成一单团长获得(pointReward)积分: + @ApiModelProperty(value = "团员完成(FinishOrderNum)单后,团员每完成一单团长获得(pointReward)积分:") + private Integer finishOrderNum; + private Integer pointReward; + + @ApiModelProperty("0:不启用,1:启用") + private Short status; +} diff --git a/gc-user/src/main/java/com/xzx/gc/user/dto/ViewSettingDto.java b/gc-user/src/main/java/com/xzx/gc/user/dto/ViewSettingDto.java index caa7cd2..8c579e2 100644 --- a/gc-user/src/main/java/com/xzx/gc/user/dto/ViewSettingDto.java +++ b/gc-user/src/main/java/com/xzx/gc/user/dto/ViewSettingDto.java @@ -1,9 +1,9 @@ package com.xzx.gc.user.dto; +import com.xzx.gc.annotation.Query; import lombok.Data; @Data public class ViewSettingDto { - private Long id; } diff --git a/gc-user/src/main/java/com/xzx/gc/user/mapper/RedPaperRuleMapper.java b/gc-user/src/main/java/com/xzx/gc/user/mapper/RedPaperRuleMapper.java index ac8ca35..95d9dc8 100644 --- a/gc-user/src/main/java/com/xzx/gc/user/mapper/RedPaperRuleMapper.java +++ b/gc-user/src/main/java/com/xzx/gc/user/mapper/RedPaperRuleMapper.java @@ -7,4 +7,6 @@ public interface RedPaperRuleMapper extends GcMapper<RedPaperRule> { RedPaperRule getOne(@Param("now") String now, @Param("ruleType") String ruleType, @Param("partnerId") String partnerId); + + RedPaperRule selectByRuleName(@Param("ruleStr")String ruleStr); } \ No newline at end of file diff --git a/gc-user/src/main/java/com/xzx/gc/user/service/DistribService.java b/gc-user/src/main/java/com/xzx/gc/user/service/DistribService.java index c363462..ee9cedf 100644 --- a/gc-user/src/main/java/com/xzx/gc/user/service/DistribService.java +++ b/gc-user/src/main/java/com/xzx/gc/user/service/DistribService.java @@ -1,16 +1,107 @@ package com.xzx.gc.user.service; +import cn.hutool.core.util.ObjectUtil; +import cn.hutool.core.util.StrUtil; +import com.xzx.gc.entity.RedPaperRule; +import com.xzx.gc.model.JsonResult; +import com.xzx.gc.user.dto.UpdateSettingDto; +import com.xzx.gc.user.mapper.RedPaperRuleMapper; import com.xzx.gc.user.vo.ViewSettingVo; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; + +import javax.annotation.Resource; +import java.math.BigDecimal; +import java.util.List; @Service @Transactional public class DistribService { + @Resource + private RedPaperRuleMapper redPaperRuleMapper; - public ViewSettingVo viewSetting(Long id) { + public ViewSettingVo viewSetting(String ruleStr) { ViewSettingVo viewSettingVo = new ViewSettingVo(); + RedPaperRule redPaperRule = redPaperRuleMapper.selectByRuleName(ruleStr); + if(ObjectUtil.isEmpty(redPaperRule)){ + viewSettingVo.setFristReward(BigDecimal.ZERO); + viewSettingVo.setOrderNumFrist(0); + viewSettingVo.setRegularPoint(0); + viewSettingVo.setRegularMoneyPercent(BigDecimal.ZERO); + viewSettingVo.setFinishOrderNum(0); + viewSettingVo.setPointReward(0); + viewSettingVo.setStatus((short) 0); + }else{ + String shareRatio = redPaperRule.getShareRatio(); + if(StrUtil.isNotEmpty(shareRatio)){ + List<String> shareRatios = StrUtil.split(shareRatio,',',false,false); + if(ObjectUtil.isNotEmpty(shareRatios)){ + viewSettingVo.setId(redPaperRule.getId()); + viewSettingVo.setFristReward(StrUtil.isEmpty(shareRatios.get(0))?BigDecimal.ZERO:new BigDecimal(shareRatios.get(0))); + viewSettingVo.setOrderNumFrist(StrUtil.isEmpty(shareRatios.get(1))?0:Integer.parseInt(shareRatios.get(1))); + viewSettingVo.setRegularPoint(StrUtil.isEmpty(shareRatios.get(2))?0:Integer.parseInt(shareRatios.get(2))); + viewSettingVo.setRegularMoneyPercent(StrUtil.isEmpty(shareRatios.get(3))?BigDecimal.ZERO:new BigDecimal(shareRatios.get(3))); + viewSettingVo.setFinishOrderNum(StrUtil.isEmpty(shareRatios.get(4))?0:Integer.parseInt(shareRatios.get(4))); + viewSettingVo.setPointReward(StrUtil.isEmpty(shareRatios.get(5))?0:Integer.parseInt(shareRatios.get(5))); + viewSettingVo.setStatus(redPaperRule.getStatus()); + } + }else{ + viewSettingVo.setId(redPaperRule.getId()); + viewSettingVo.setFristReward(BigDecimal.ZERO); + viewSettingVo.setOrderNumFrist(0); + viewSettingVo.setRegularPoint(0); + viewSettingVo.setRegularMoneyPercent(BigDecimal.ZERO); + viewSettingVo.setFinishOrderNum(0); + viewSettingVo.setPointReward(0); + viewSettingVo.setStatus((short) 0); + } + } return viewSettingVo; } + + public void addSetting(UpdateSettingDto model) { + RedPaperRule redPaperRule = new RedPaperRule(); + StringBuffer stringBuffer = new StringBuffer(); + BigDecimal fristReward = ObjectUtil.isEmpty(model.getFristReward()) ? BigDecimal.ZERO : model.getFristReward(); + stringBuffer.append(fristReward+","); + int orderNumFrist = ObjectUtil.isEmpty(model.getOrderNumFrist()) ? 0 : model.getOrderNumFrist(); + stringBuffer.append(orderNumFrist+","); + int regularPoint = ObjectUtil.isEmpty(model.getRegularPoint()) ? 0 : model.getRegularPoint(); + stringBuffer.append(regularPoint+","); + BigDecimal regularMoneyPercent = ObjectUtil.isEmpty(model.getRegularMoneyPercent()) ? BigDecimal.ZERO : model.getRegularMoneyPercent(); + stringBuffer.append(regularMoneyPercent+","); + int finishOrderNum = ObjectUtil.isEmpty(model.getFinishOrderNum()) ? 0 : model.getFinishOrderNum(); + stringBuffer.append(finishOrderNum+","); + int pointReward = ObjectUtil.isEmpty(model.getPointReward()) ? 0 : model.getPointReward(); + stringBuffer.append(pointReward); + redPaperRule.setStatus((short) 0); + redPaperRule.setRuleName("分销规则"); + redPaperRule.setSharingProfitType("frist_reward,order_num_frist,regular_point,regular_money_percent,finish_order_num,point_reward"); + redPaperRule.setShareRatio(stringBuffer.toString()); + redPaperRuleMapper.insert(redPaperRule); + } + + public void updateSetting(UpdateSettingDto model) { + RedPaperRule redPaperRule = redPaperRuleMapper.selectByPrimaryKey(model.getId()); + if(ObjectUtil.isNotEmpty(redPaperRule)){ + StringBuffer stringBuffer = new StringBuffer(); + BigDecimal fristReward = ObjectUtil.isEmpty(model.getFristReward()) ? BigDecimal.ZERO : model.getFristReward(); + stringBuffer.append(fristReward+","); + int orderNumFrist = ObjectUtil.isEmpty(model.getOrderNumFrist()) ? 0 : model.getOrderNumFrist(); + stringBuffer.append(orderNumFrist+","); + int regularPoint = ObjectUtil.isEmpty(model.getRegularPoint()) ? 0 : model.getRegularPoint(); + stringBuffer.append(regularPoint+","); + BigDecimal regularMoneyPercent = ObjectUtil.isEmpty(model.getRegularMoneyPercent()) ? BigDecimal.ZERO : model.getRegularMoneyPercent(); + stringBuffer.append(regularMoneyPercent+","); + int finishOrderNum = ObjectUtil.isEmpty(model.getFinishOrderNum()) ? 0 : model.getFinishOrderNum(); + stringBuffer.append(finishOrderNum+","); + int pointReward = ObjectUtil.isEmpty(model.getPointReward()) ? 0 : model.getPointReward(); + stringBuffer.append(pointReward); + redPaperRule.setStatus(model.getStatus()); + redPaperRule.setSharingProfitType("frist_reward,order_num_frist,regular_point,regular_money_percent,finish_order_num,point_reward"); + redPaperRule.setShareRatio(stringBuffer.toString()); + redPaperRuleMapper.updateByPrimaryKey(redPaperRule); + } + } } diff --git a/gc-user/src/main/java/com/xzx/gc/user/vo/ViewSettingVo.java b/gc-user/src/main/java/com/xzx/gc/user/vo/ViewSettingVo.java index 2a32835..49fc677 100644 --- a/gc-user/src/main/java/com/xzx/gc/user/vo/ViewSettingVo.java +++ b/gc-user/src/main/java/com/xzx/gc/user/vo/ViewSettingVo.java @@ -1,6 +1,7 @@ package com.xzx.gc.user.vo; import io.swagger.annotations.ApiModel; +import io.swagger.annotations.ApiModelProperty; import lombok.Data; import java.math.BigDecimal; @@ -9,9 +10,24 @@ @ApiModel(value = "ViewSettingVo", description = "后台分销系统设置接口返回参数类") public class ViewSettingVo { - //首单奖励 - private BigDecimal FristReward; + private Integer id; - //团员在完成首单后,(请输入订单数量)笔单内,可以固定积分+环保币方式进行返佣团长 - private Integer orderNum; + //首单奖励(FristReward)元 + @ApiModelProperty(value = "首单奖励(FristReward)元") + private BigDecimal fristReward; + + //团员在完成首单后,(orderNumFrist)笔单内,可以固定积分(regularPoint)+环保币(regularMoneyPercent)方式进行返佣团长 + @ApiModelProperty(value = "团员在完成首单后,(orderNumFrist)笔单内,可以固定积分(regularPoint)+环保币(regularMoneyPercent)方式进行返佣团长") + private Integer orderNumFrist; + private Integer regularPoint; + private BigDecimal regularMoneyPercent; + + //团员完成(FinishOrderNum)单后,团员每完成一单团长获得(pointReward)积分: + @ApiModelProperty(value = "团员完成(FinishOrderNum)单后,团员每完成一单团长获得(pointReward)积分:") + private Integer finishOrderNum; + private Integer pointReward; + + @ApiModelProperty("开关0:已经关闭,1:正常") + private Short status; + } diff --git a/gc-user/src/main/resources/mapper/user/RedPaperRuleMapper.xml b/gc-user/src/main/resources/mapper/user/RedPaperRuleMapper.xml index a8b55be..6bcc8b1 100644 --- a/gc-user/src/main/resources/mapper/user/RedPaperRuleMapper.xml +++ b/gc-user/src/main/resources/mapper/user/RedPaperRuleMapper.xml @@ -17,4 +17,8 @@ </if> limit 1 </select> + + <select id="selectByRuleName" resultType="com.xzx.gc.entity.RedPaperRule"> + select * from xzx_user_redpaper_rule where rule_name = #{ruleStr} + </select> </mapper> \ No newline at end of file -- Gitblit v1.9.1