From 3954537f11c1c6fbfc62a6233102c530e3202ba1 Mon Sep 17 00:00:00 2001 From: wzy <wzy19931122ai@163.com> Date: Sat, 10 Jul 2021 14:25:55 +0800 Subject: [PATCH] Merge branch 'data_move' of http://120.27.238.55:7000/r/beauty-erp into data_move --- zq-erp/src/main/java/com/matrix/system/shopXcx/api/action/WxSalesmanAction.java | 100 ++++++++++++++++++++++++++++++++++++++++++------- 1 files changed, 85 insertions(+), 15 deletions(-) diff --git a/zq-erp/src/main/java/com/matrix/system/shopXcx/api/action/WxSalesmanAction.java b/zq-erp/src/main/java/com/matrix/system/shopXcx/api/action/WxSalesmanAction.java index c9373ec..d2d94e3 100644 --- a/zq-erp/src/main/java/com/matrix/system/shopXcx/api/action/WxSalesmanAction.java +++ b/zq-erp/src/main/java/com/matrix/system/shopXcx/api/action/WxSalesmanAction.java @@ -10,6 +10,7 @@ import com.matrix.component.tools.WxacodeUtil; import com.matrix.core.pojo.AjaxResult; import com.matrix.core.pojo.BasePageQueryDto; +import com.matrix.core.pojo.VerificationResult; import com.matrix.core.tools.LogUtil; import com.matrix.core.tools.MD5Util; import com.matrix.core.tools.PropertiesUtil; @@ -23,6 +24,8 @@ import com.matrix.system.fenxiao.entity.ShopSalesmanApply; import com.matrix.system.fenxiao.service.ShopSalesmanApplyService; import com.matrix.system.shopXcx.api.WeChatApiTools; +import com.matrix.system.shopXcx.dao.ShopProductDao; +import com.matrix.system.shopXcx.vo.SalesmanApplyCondition; import com.matrix.system.shopXcx.vo.SalesmanCenterInfo; import com.matrix.system.shopXcx.vo.SalesmanVo; import io.swagger.annotations.Api; @@ -37,8 +40,11 @@ import java.awt.*; import java.awt.image.BufferedImage; import java.io.File; +import java.util.Date; import java.util.HashMap; +import java.util.List; import java.util.Map; +import java.util.stream.Collectors; /** * @author wzy @@ -66,6 +72,10 @@ private BizUserDao bizUserDao; @Autowired WeChatApiTools weChatApiTools; + + @Autowired + ShopProductDao shopProductDao; + @ApiOperation(value = "查询推广计划", notes = "") @GetMapping(value = "/getTgPlan") @@ -100,15 +110,18 @@ public AjaxResult applyToBeAnSalesman(@RequestBody Map<String,String> param) { BizUser loginUser = redisUserLoginUtils.getLoginUser(BizUser.class); String invitationId = param.get("invitationId"); - BizUser invitationUser = bizUserDao.findByOpenId(invitationId); - if(invitationUser.getOpenId().equals(loginUser.getOpenId())){ - return AjaxResult.buildFailInstance("不能邀请自己成为推广员"); - }else{ - ShopSalesmanApply shopSalesmanApply= shopSalesmanApplyService.applyToBeAnSalesman(loginUser.getOpenId(),"",invitationId,ShopSalesmanApply.APPLY_WAY_SELF); - loginUser=bizUserDao.selectById(loginUser.getUserId()); - redisUserLoginUtils.updateUserInfo(loginUser); - return AjaxResult.buildSuccessInstance(shopSalesmanApply); + if(StringUtils.isNotBlank(invitationId)){ + BizUser invitationUser = bizUserDao.findByOpenId(invitationId); + if(invitationUser!=null && invitationUser.getOpenId().equals(loginUser.getOpenId())) { + return AjaxResult.buildFailInstance("不能邀请自己成为推广员"); + } } + + ShopSalesmanApply shopSalesmanApply= shopSalesmanApplyService.applyToBeAnSalesman(loginUser.getOpenId(),"",invitationId,ShopSalesmanApply.APPLY_WAY_SELF); + loginUser=bizUserDao.selectById(loginUser.getUserId()); + redisUserLoginUtils.updateUserInfo(loginUser); + return AjaxResult.buildSuccessInstance(shopSalesmanApply); + } @@ -129,33 +142,47 @@ } - @ApiOperation(value = "绑定下级客户,当客户点击分销员分销的产品时调用", notes = "传入参数invitationId 必须 分销员openId 例: {invitationId:openId}") + @ApiOperation(value = "绑定下级客户,当客户点击分销员分销的产品时调用", notes = "传入参数invitationId 必须 分销员userId例: {invitationId:userId}") @ApiResponses({ @ApiResponse(code = 200, message = "ok", response = Map.class) }) @PostMapping(value = "/bindingParentSalesman") public AjaxResult bindingParentSalesman(@RequestBody Map<String,String> param) { String invitationId = param.get("invitationId"); + + if (StringUtils.isBlank(invitationId)) { + return AjaxResult.buildFailInstance("请求参数错误"); + } + BizUser invitationUser = bizUserDao.selectById(Long.parseLong(invitationId)); + if (invitationUser==null) { return AjaxResult.buildFailInstance("请求参数错误"); } BizUser loginUser = redisUserLoginUtils.getLoginUser(BizUser.class); - loginUser = bizUserDao.selectById(loginUser.getUserId()); - if (loginUser.getIsSales() == null || loginUser.getIsSales() == BizUser.NOT_SALES) { - if (StringUtils.isBlank(loginUser.getParentOpenId())) { + if(invitationId.equals(loginUser.getUserId())){ + return AjaxResult.buildSuccessInstance("不能绑定自己"); + } + loginUser = bizUserDao.selectById(loginUser.getUserId()); + if(loginUser.getIsSales()==1){ + return AjaxResult.buildSuccessInstance("只有非分销员才能被绑定成客户"); + }else{ + if (StringUtils.isBlank(loginUser.getParentOpenId())) { Map<String, Object> updateParam = new HashMap<>(); updateParam.put("userId", loginUser.getUserId()); - updateParam.put("parentOpenId", invitationId); + updateParam.put("parentOpenId", invitationUser.getOpenId()); + updateParam.put("bindingParentTime",new Date()); bizUserDao.updateByMap(updateParam); return AjaxResult.buildSuccessInstance("绑定成功"); } else { return AjaxResult.buildSuccessInstance("已经存在上级"); } - } else { - return AjaxResult.buildSuccessInstance("分销员不能被绑定"); } + + + + } @@ -246,6 +273,49 @@ return AjaxResult.buildSuccessInstance(salesmanCenterInfo); } + @ApiOperation(value = "查询分销员申请条件", notes = "") + @PostMapping(value = "/getSalesmanApplyCondition") + @ApiResponses({ + @ApiResponse(code = 200, message = "ok", response = SalesmanApplyCondition.class) + }) + AjaxResult getSalesmanApplyCondition() { + BizUser loginUser = redisUserLoginUtils.getLoginUser(BizUser.class); + VerificationResult ableToBeAnSalesman = shopSalesmanApplyService.isAbleToBeAnSalesman(loginUser.getOpenId(),loginUser.getCompanyId()); + SalesmanApplyCondition applyConditionInfo=new SalesmanApplyCondition(); + applyConditionInfo.setIsAbleApply(ableToBeAnSalesman.isJudgeResult()); + applyConditionInfo.setMsg(ableToBeAnSalesman.getMsg()); + + //申请条件 + BusParameterSettings applyCondition = busParameterSettingsDao.selectCompanyParamByCode(FenxiaoSettingConstant.FX_APPLY_CONDITION, loginUser.getCompanyId()); + switch (applyCondition.getParamValue()){ + case FenxiaoSettingConstant.FX_APPLY_CONDITION_WTJ: + applyConditionInfo.setCondition("您已满足申请条件"); + break; + case FenxiaoSettingConstant.FX_APPLY_CONDITION_XFZDCP: + applyConditionInfo.setCondition("消费指定产品并确认收货"); + List<String> strings = StringUtils.strToColl(applyCondition.getParamValue1(), ","); + applyConditionInfo.setProductList( + shopProductDao.selectByIds( + strings.stream().filter(i->StringUtils.isNotBlank(i)).map(i -> Integer.parseInt(i + "")).distinct().collect(Collectors.toList()))); + break; + case FenxiaoSettingConstant.FX_APPLY_CONDITION_XFRYCP: + //判断用户是否有确认收货的产品 + applyConditionInfo.setCondition("消费任意产品并确认收货"); + break; + case FenxiaoSettingConstant.FX_APPLY_CONDITION_XCZDJE: + Double zdje=Double.parseDouble(applyCondition.getParamValue2()); + applyConditionInfo.setCondition("消费满"+zdje+"元确认收货"); + applyConditionInfo.setMinAmount(zdje); + } + + return AjaxResult.buildSuccessInstance(applyConditionInfo); + } + + + + + + } -- Gitblit v1.9.1