From bbe0a2fd03063316e50cf141986bda984599bbda Mon Sep 17 00:00:00 2001 From: 935090232@qq.com <ak473600000> Date: Tue, 22 Feb 2022 23:41:42 +0800 Subject: [PATCH] Merge branch 'developer' --- zq-erp/src/main/java/com/matrix/system/shopXcx/api/action/WxSalesmanAction.java | 165 +++++++++++++++++++++++++++---------------------------- 1 files changed, 81 insertions(+), 84 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 b45b7a8..a2ecabf 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 @@ -3,9 +3,6 @@ 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.matrix.biz.bean.BizUser; -import com.matrix.biz.dao.BizUserDao; -import com.matrix.component.redis.RedisUserLoginUtils; import com.matrix.component.tools.ImageUtil; import com.matrix.component.tools.WxacodeUtil; import com.matrix.core.pojo.AjaxResult; @@ -18,11 +15,15 @@ import com.matrix.system.common.bean.BusParameterSettings; import com.matrix.system.common.constance.AppConstance; import com.matrix.system.common.dao.BusParameterSettingsDao; +import com.matrix.system.common.init.UserCacheManager; import com.matrix.system.common.interceptor.HostInterceptor; import com.matrix.system.fenxiao.constant.FenxiaoSettingConstant; import com.matrix.system.fenxiao.dao.ShopSalesmanApplyDao; import com.matrix.system.fenxiao.entity.ShopSalesmanApply; import com.matrix.system.fenxiao.service.ShopSalesmanApplyService; +import com.matrix.system.hive.bean.SysVipInfo; +import com.matrix.system.hive.dao.SysVipInfoDao; +import com.matrix.system.hive.plugin.util.CollectionUtils; import com.matrix.system.shopXcx.api.WeChatApiTools; import com.matrix.system.shopXcx.dao.ShopProductDao; import com.matrix.system.shopXcx.vo.SalesmanApplyCondition; @@ -40,7 +41,6 @@ import java.awt.*; import java.awt.image.BufferedImage; import java.io.File; -import java.util.HashMap; import java.util.List; import java.util.Map; import java.util.stream.Collectors; @@ -65,10 +65,10 @@ ShopSalesmanApplyService shopSalesmanApplyService; @Autowired - private RedisUserLoginUtils redisUserLoginUtils; + private UserCacheManager userCacheManager; @Autowired - private BizUserDao bizUserDao; + private SysVipInfoDao sysVipInfoDao; @Autowired WeChatApiTools weChatApiTools; @@ -91,13 +91,10 @@ BusParameterSettings fxSwith = busParameterSettingsDao.selectCompanyParamByCode(FenxiaoSettingConstant.FX_SWITCH, HostInterceptor.getCompanyId()); BusParameterSettings fxModel = busParameterSettingsDao.selectCompanyParamByCode(FenxiaoSettingConstant.FX_MODEL, HostInterceptor.getCompanyId()); AjaxResult ajaxResult = AjaxResult.buildSuccessInstance("查询成功"); - ajaxResult.putInMap("fxSwith",fxSwith.getParamValue()); - ajaxResult.putInMap("fxModel",fxModel.getParamValue()); + ajaxResult.putInMap("fxSwith", fxSwith.getParamValue()); + ajaxResult.putInMap("fxModel", fxModel.getParamValue()); return ajaxResult; } - - - @ApiOperation(value = "申请成为推广员", notes = "传入参数invitationId 邀请人openId ,非必填 例: {invitationId:openId}") @@ -106,21 +103,21 @@ }) @PostMapping(value = "/applyToBeAnSalesman") @Transactional - public AjaxResult applyToBeAnSalesman(@RequestBody Map<String,String> param) { - BizUser loginUser = redisUserLoginUtils.getLoginUser(BizUser.class); - String invitationId = param.get("invitationId"); - if(StringUtils.isNotBlank(invitationId)){ - BizUser invitationUser = bizUserDao.findByOpenId(invitationId); - if(invitationUser!=null && invitationUser.getOpenId().equals(loginUser.getOpenId())) { + public AjaxResult applyToBeAnSalesman(@RequestBody Map<String, String> param) { + SysVipInfo loginUser = userCacheManager.getLoginUser(); + Long invitationId=null; + if(StringUtils.isNotBlank(param.get("invitationId"))){ + invitationId = Long.parseLong(param.get("invitationId")); + + SysVipInfo invitationUser = sysVipInfoDao.selectById(invitationId); + if (invitationUser != null && invitationUser.getId().equals(loginUser.getId())) { return AjaxResult.buildFailInstance("不能邀请自己成为推广员"); } } - - ShopSalesmanApply shopSalesmanApply= shopSalesmanApplyService.applyToBeAnSalesman(loginUser.getOpenId(),"",invitationId,ShopSalesmanApply.APPLY_WAY_SELF); - loginUser=bizUserDao.selectById(loginUser.getUserId()); - redisUserLoginUtils.updateUserInfo(loginUser); + ShopSalesmanApply shopSalesmanApply = shopSalesmanApplyService.applyToBeAnSalesman(loginUser.getId(), null, invitationId, ShopSalesmanApply.APPLY_WAY_SELF); + loginUser = sysVipInfoDao.selectById(loginUser.getId()); + userCacheManager.updateUserInfo(loginUser); return AjaxResult.buildSuccessInstance(shopSalesmanApply); - } @@ -132,49 +129,51 @@ }) @GetMapping(value = "/queryApplyProgress") public AjaxResult queryApplyProgress() { - BizUser loginUser = redisUserLoginUtils.getLoginUser(BizUser.class); + SysVipInfo loginUser = userCacheManager.getLoginUser(); QueryWrapper<ShopSalesmanApply> queryWrapper = new QueryWrapper<>(); - queryWrapper.eq("user_id",loginUser.getOpenId()); - queryWrapper.eq("apply_status",ShopSalesmanApply.APPLY_STATUS_DSH); + queryWrapper.eq("user_id", loginUser.getId()); + queryWrapper.eq("apply_status", ShopSalesmanApply.APPLY_STATUS_DSH); ShopSalesmanApply shopSalesmanApply = salesmanApplyDao.selectOne(queryWrapper); return AjaxResult.buildSuccessInstance(shopSalesmanApply); } - @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)) { + public AjaxResult bindingParentSalesman(@RequestBody Map<String, Long> param) { + Long invitationId = param.get("invitationId"); + + + + SysVipInfo invitationUser = sysVipInfoDao.selectById(invitationId); + if (invitationUser == null) { return AjaxResult.buildFailInstance("请求参数错误"); } - - BizUser loginUser = redisUserLoginUtils.getLoginUser(BizUser.class); - if(invitationId.equals(loginUser.getOpenId())){ - return AjaxResult.buildFailInstance("不能绑定自己"); + SysVipInfo loginUser = userCacheManager.getLoginUser(); + if (invitationId.equals(loginUser.getId())) { + return AjaxResult.buildSuccessInstance("不能绑定自己"); } - if(loginUser.getIsSales()==null || loginUser.getIsSales()==2){ - return AjaxResult.buildFailInstance("只有分销员才能绑定客户"); - } - loginUser = bizUserDao.selectById(loginUser.getUserId()); - if (loginUser.getIsSales() == null || loginUser.getIsSales() == BizUser.NOT_SALES) { - if (StringUtils.isBlank(loginUser.getParentOpenId())) { - Map<String, Object> updateParam = new HashMap<>(); - updateParam.put("userId", loginUser.getUserId()); - updateParam.put("parentOpenId", invitationId); - bizUserDao.updateByMap(updateParam); + loginUser = sysVipInfoDao.selectById(loginUser.getId()); + if (loginUser.getIsSales() == 1) { + return AjaxResult.buildSuccessInstance("只有非分销员才能被绑定成客户"); + } + if (loginUser.getRecommendId()!=null) { + return AjaxResult.buildSuccessInstance("已经被绑定"); + } else { + if (loginUser.getRecommendId()==null) { + sysVipInfoDao.bindingRecommend(invitationUser.getId(),loginUser.getId()); return AjaxResult.buildSuccessInstance("绑定成功"); } else { return AjaxResult.buildSuccessInstance("已经存在上级"); } - } else { - return AjaxResult.buildSuccessInstance("分销员不能被绑定"); } + + } @@ -182,32 +181,32 @@ @PostMapping(value = "/getInvitationPoster") AjaxResult getInvitationPoster() { try { - BizUser loginUser = redisUserLoginUtils.getLoginUser(BizUser.class); + SysVipInfo loginUser = userCacheManager.getLoginUser(); String baseSavePath = PropertiesUtil.getString(AppConstance.FILES_TORAGE_PATH); // 图片访问URL String baseSaveUrl = PropertiesUtil.getString(AppConstance.NGINX_URL); //目标海报物理存储路径 - String targetImg=MD5Util.strToMD5(loginUser.getOpenId()) +"haibao.png"; - String targetImgPath=baseSavePath+"wxacode" + File.separatorChar+targetImg ; + String targetImg = MD5Util.strToMD5(loginUser.getOpenId()) + "haibao.png"; + String targetImgPath = baseSavePath + "wxacode" + File.separatorChar + targetImg; String urlPath = baseSaveUrl + "/" + "wxacode" + "/" + targetImg; - String qrcodeSavePath = WxacodeUtil.getWxacode(loginUser.getOpenId() + "", "pages/distributorCenter/applyFor/applyFor", MD5Util.strToMD5(loginUser.getOpenId())+"qrcode" - ,weChatApiTools.getAppid(loginUser.getCompanyId()),weChatApiTools.getSecret(loginUser.getCompanyId())); + String qrcodeSavePath = WxacodeUtil.getWxacode(loginUser.getId() + "", "pages/distributorCenter/applyFor/applyFor", MD5Util.strToMD5(loginUser.getOpenId()) + "qrcode" + , weChatApiTools.getAppid(loginUser.getCompanyId()), weChatApiTools.getSecret(loginUser.getCompanyId())); BufferedImage qrcordImgBuf = ImageIO.read(new File(qrcodeSavePath)); //获取海报 BusParameterSettings posterSetting = busParameterSettingsDao.selectCompanyParamByCode(FenxiaoSettingConstant.FX_TG_POSTER, loginUser.getCompanyId()); - String posterPath=baseSavePath+"wxacode" + File.separatorChar+MD5Util.strToMD5(loginUser.getOpenId())+"poster.png"; - ImageUtil.downloadPicture(posterSetting.getParamValue(),posterPath); + String posterPath = baseSavePath + "wxacode" + File.separatorChar + MD5Util.strToMD5(loginUser.getOpenId()) + "poster.png"; + ImageUtil.downloadPicture(posterSetting.getParamValue(), posterPath); BufferedImage posterImgBuf = ImageIO.read(new File(posterPath)); //获取用户头像 - String userPhotoPath=baseSavePath+"wxacode" + File.separatorChar+MD5Util.strToMD5(loginUser.getOpenId())+"userPhoto.png"; - ImageUtil.downloadPicture(loginUser.getAvatarUrl(),userPhotoPath); + String userPhotoPath = baseSavePath + "wxacode" + File.separatorChar + MD5Util.strToMD5(loginUser.getOpenId()) + "userPhoto.png"; + ImageUtil.downloadPicture(loginUser.getAvatarUrl(), userPhotoPath); BufferedImage userPhotoImgBuf = ImageIO.read(new File(userPhotoPath)); @@ -215,18 +214,18 @@ //绘制背景+产品 Graphics2D g = backgroundImgBuf.createGraphics(); g.setColor(Color.WHITE); - g.fillRect(0,0,700,900); - g.drawImage(posterImgBuf,0,0,700, 700,null); + g.fillRect(0, 0, 700, 900); + g.drawImage(posterImgBuf, 0, 0, 700, 700, null); - g.drawImage(userPhotoImgBuf,20,720,80,80,null); + g.drawImage(userPhotoImgBuf, 20, 720, 80, 80, null); - g.drawImage(qrcordImgBuf,500,720,150,150,null); + g.drawImage(qrcordImgBuf, 500, 720, 150, 150, null); - g.setRenderingHint(RenderingHints.KEY_TEXT_ANTIALIASING,RenderingHints.VALUE_TEXT_ANTIALIAS_LCD_HRGB); + g.setRenderingHint(RenderingHints.KEY_TEXT_ANTIALIASING, RenderingHints.VALUE_TEXT_ANTIALIAS_LCD_HRGB); g.setFont(new Font("WenQuanYi Micro Hei", Font.BOLD, 24)); g.setColor(Color.BLACK); - g.drawString(loginUser.getNickName()+"邀请你一起推广赚佣金",120,750); + g.drawString(loginUser.getNickName() + "邀请你一起推广赚佣金", 120, 750); g.dispose(); ImageIO.write(backgroundImgBuf, "png", new File(targetImgPath)); @@ -234,7 +233,7 @@ return AjaxResult.buildSuccessInstance(urlPath); } catch (Exception e) { LogUtil.error("推广二维码生成错误:{}", e, ""); - return AjaxResult.buildFailInstance("二维码生成失败"); + return AjaxResult.buildFailInstance("二维码生成失败"); } } @@ -246,10 +245,10 @@ @ApiResponse(code = 200, message = "ok", response = SalesmanVo.class) }) AjaxResult getInvitationuserList(@RequestBody BasePageQueryDto pageDto) { - BizUser loginUser = redisUserLoginUtils.getLoginUser(BizUser.class); - Page<SalesmanVo> page=new Page<>(pageDto.getPageNum(),pageDto.getPageSize()); - IPage<SalesmanVo> shopSalesmanApplyIPage = salesmanApplyDao.selectInvitationuserInPage(page, loginUser.getOpenId(),pageDto.getKeywords()); - AjaxResult result=AjaxResult.buildSuccessInstance(shopSalesmanApplyIPage.getRecords()); + SysVipInfo loginUser = userCacheManager.getLoginUser(); + Page<SalesmanVo> page = new Page<>(pageDto.getPageNum(), pageDto.getPageSize()); + IPage<SalesmanVo> shopSalesmanApplyIPage = salesmanApplyDao.selectInvitationuserInPage(page, loginUser.getId(), pageDto.getKeywords()); + AjaxResult result = AjaxResult.buildSuccessInstance(shopSalesmanApplyIPage.getRecords()); return result; } @@ -260,8 +259,8 @@ @ApiResponse(code = 200, message = "ok", response = SalesmanCenterInfo.class) }) AjaxResult getSalesmanCenterInfo() { - BizUser loginUser = redisUserLoginUtils.getLoginUser(BizUser.class); - SalesmanCenterInfo salesmanCenterInfo= salesmanApplyDao.selectSalesmanCenterInfo(loginUser.getOpenId()); + SysVipInfo loginUser = userCacheManager.getLoginUser(); + SalesmanCenterInfo salesmanCenterInfo = salesmanApplyDao.selectSalesmanCenterInfo(loginUser.getId()); return AjaxResult.buildSuccessInstance(salesmanCenterInfo); } @@ -271,43 +270,41 @@ @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(); + SysVipInfo loginUser = userCacheManager.getLoginUser(); + VerificationResult ableToBeAnSalesman = shopSalesmanApplyService.isAbleToBeAnSalesman(loginUser.getId(), 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()){ + switch (applyCondition.getParamValue()) { case FenxiaoSettingConstant.FX_APPLY_CONDITION_WTJ: applyConditionInfo.setCondition("您已满足申请条件"); break; case FenxiaoSettingConstant.FX_APPLY_CONDITION_XFZDCP: - applyConditionInfo.setCondition("消费指定产品确认收货"); + applyConditionInfo.setCondition("消费指定产品并确认收货"); List<String> strings = StringUtils.strToColl(applyCondition.getParamValue1(), ","); - applyConditionInfo.setProductList( - shopProductDao.selectByIds( - strings.stream().map(i -> Integer.parseInt(i + "")).collect(Collectors.toList()))); + List<Integer> ids = strings.stream().filter(i -> StringUtils.isNotBlank(i)).map(i -> Integer.parseInt(i + "")).distinct().collect(Collectors.toList()); + if (CollectionUtils.isNotEmpty(ids)) { + applyConditionInfo.setProductList(shopProductDao.selectByIds(ids)); + } else { + return AjaxResult.buildFailInstance("未配置消费产品,请联系管理员"); + } + break; case FenxiaoSettingConstant.FX_APPLY_CONDITION_XFRYCP: //判断用户是否有确认收货的产品 - applyConditionInfo.setCondition("消费任意产品确认收货"); + applyConditionInfo.setCondition("消费任意产品并确认收货"); break; case FenxiaoSettingConstant.FX_APPLY_CONDITION_XCZDJE: - Double zdje=Double.parseDouble(applyCondition.getParamValue2()); - applyConditionInfo.setCondition("消费满"+zdje+"元确认收货"); + Double zdje = Double.parseDouble(applyCondition.getParamValue2()); + applyConditionInfo.setCondition("消费满" + zdje + "元确认收货"); applyConditionInfo.setMinAmount(zdje); } return AjaxResult.buildSuccessInstance(applyConditionInfo); } - - - - - - } -- Gitblit v1.9.1