From 241a49f9653aa83d1dcd9bf646208da3157df35a Mon Sep 17 00:00:00 2001 From: 935090232@qq.com <ak473600000> Date: Mon, 05 Apr 2021 22:48:14 +0800 Subject: [PATCH] 合并BizUser表与SysVipInfo表 大部分逻辑已经修正 可能存在问题的 1、拼团秒杀 2、分享图 3、分销结算 --- zq-erp/src/main/java/com/matrix/system/shopXcx/api/action/WxSalesmanAction.java | 142 +++++++++++++++++++++------------------------- 1 files changed, 65 insertions(+), 77 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 4f0b0d9..7e39d58 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,8 +3,8 @@ 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.system.hive.bean.SysVipInfo; +import com.matrix.system.hive.dao.SysVipInfoDao; import com.matrix.component.redis.RedisUserLoginUtils; import com.matrix.component.tools.ImageUtil; import com.matrix.component.tools.WxacodeUtil; @@ -70,7 +70,7 @@ private RedisUserLoginUtils redisUserLoginUtils; @Autowired - private BizUserDao bizUserDao; + private SysVipInfoDao sysVipInfoDao; @Autowired WeChatApiTools weChatApiTools; @@ -93,13 +93,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}") @@ -108,21 +105,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 = redisUserLoginUtils.getLoginUser(SysVipInfo.class); + 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()); + ShopSalesmanApply shopSalesmanApply = shopSalesmanApplyService.applyToBeAnSalesman(loginUser.getId(), null, invitationId, ShopSalesmanApply.APPLY_WAY_SELF); + loginUser = sysVipInfoDao.selectById(loginUser.getId()); redisUserLoginUtils.updateUserInfo(loginUser); return AjaxResult.buildSuccessInstance(shopSalesmanApply); - } @@ -134,10 +131,10 @@ }) @GetMapping(value = "/queryApplyProgress") public AjaxResult queryApplyProgress() { - BizUser loginUser = redisUserLoginUtils.getLoginUser(BizUser.class); + SysVipInfo loginUser = redisUserLoginUtils.getLoginUser(SysVipInfo.class); 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); } @@ -148,42 +145,39 @@ @ApiResponse(code = 200, message = "ok", response = Map.class) }) @PostMapping(value = "/bindingParentSalesman") - public AjaxResult bindingParentSalesman(@RequestBody Map<String,String> param) { - String invitationId = param.get("invitationId"); + public AjaxResult bindingParentSalesman(@RequestBody Map<String, Long> param) { + Long invitationId = param.get("invitationId"); - if (StringUtils.isBlank(invitationId)) { - return AjaxResult.buildFailInstance("请求参数错误"); - } - BizUser invitationUser = bizUserDao.selectById(Long.parseLong(invitationId)); - if (invitationUser==null) { + + SysVipInfo invitationUser = sysVipInfoDao.selectById(invitationId); + if (invitationUser == null) { return AjaxResult.buildFailInstance("请求参数错误"); } - BizUser loginUser = redisUserLoginUtils.getLoginUser(BizUser.class); - if(invitationId.equals(loginUser.getUserId())){ + SysVipInfo loginUser = redisUserLoginUtils.getLoginUser(SysVipInfo.class); + if (invitationId.equals(loginUser.getId())) { return AjaxResult.buildSuccessInstance("不能绑定自己"); } - loginUser = bizUserDao.selectById(loginUser.getUserId()); - if(loginUser.getIsSales()==1){ + loginUser = sysVipInfoDao.selectById(loginUser.getId()); + if (loginUser.getIsSales() == 1) { return AjaxResult.buildSuccessInstance("只有非分销员才能被绑定成客户"); - }if (StringUtils.isNotBlank(loginUser.getParentOpenId())){ + } + if (loginUser.getRecommendId()!=null) { return AjaxResult.buildSuccessInstance("已经被绑定"); - }else{ - if (StringUtils.isBlank(loginUser.getParentOpenId())) { + } else { + if (loginUser.getRecommendId()==null) { Map<String, Object> updateParam = new HashMap<>(); - updateParam.put("userId", loginUser.getUserId()); - updateParam.put("parentOpenId", invitationUser.getOpenId()); - updateParam.put("bindingParentTime",new Date()); - bizUserDao.updateByMap(updateParam); + updateParam.put("id", loginUser.getId()); + loginUser.setRecommendId(invitationUser.getId()); + loginUser.setBindingParentTime(new Date()); + sysVipInfoDao.update(loginUser); return AjaxResult.buildSuccessInstance("绑定成功"); } else { return AjaxResult.buildSuccessInstance("已经存在上级"); } } - - } @@ -193,32 +187,32 @@ @PostMapping(value = "/getInvitationPoster") AjaxResult getInvitationPoster() { try { - BizUser loginUser = redisUserLoginUtils.getLoginUser(BizUser.class); + SysVipInfo loginUser = redisUserLoginUtils.getLoginUser(SysVipInfo.class); 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.getUserId() + "", "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)); @@ -226,18 +220,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)); @@ -245,7 +239,7 @@ return AjaxResult.buildSuccessInstance(urlPath); } catch (Exception e) { LogUtil.error("推广二维码生成错误:{}", e, ""); - return AjaxResult.buildFailInstance("二维码生成失败"); + return AjaxResult.buildFailInstance("二维码生成失败"); } } @@ -257,10 +251,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 = redisUserLoginUtils.getLoginUser(SysVipInfo.class); + 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; } @@ -271,8 +265,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 = redisUserLoginUtils.getLoginUser(SysVipInfo.class); + SalesmanCenterInfo salesmanCenterInfo = salesmanApplyDao.selectSalesmanCenterInfo(loginUser.getId()); return AjaxResult.buildSuccessInstance(salesmanCenterInfo); } @@ -282,15 +276,15 @@ @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 = redisUserLoginUtils.getLoginUser(SysVipInfo.class); + 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; @@ -298,9 +292,9 @@ applyConditionInfo.setCondition("消费指定产品并确认收货"); List<String> strings = StringUtils.strToColl(applyCondition.getParamValue1(), ","); List<Integer> ids = strings.stream().filter(i -> StringUtils.isNotBlank(i)).map(i -> Integer.parseInt(i + "")).distinct().collect(Collectors.toList()); - if(CollectionUtils.isNotEmpty(ids)){ + if (CollectionUtils.isNotEmpty(ids)) { applyConditionInfo.setProductList(shopProductDao.selectByIds(ids)); - }else{ + } else { return AjaxResult.buildFailInstance("未配置消费产品,请联系管理员"); } @@ -310,19 +304,13 @@ 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