From 1823b680b950e4c3a26acced18fe0629b2139c53 Mon Sep 17 00:00:00 2001 From: yujian <yujian@123.com> Date: 星期四, 15 八月 2019 09:29:33 +0800 Subject: [PATCH] 福利中心 --- fanli/src/main/java/com/yeshi/fanli/service/impl/user/UserSystemCouponServiceImpl.java | 234 +++++++++++++++++++++++++++++++++++++++------------------- 1 files changed, 157 insertions(+), 77 deletions(-) diff --git a/fanli/src/main/java/com/yeshi/fanli/service/impl/user/UserSystemCouponServiceImpl.java b/fanli/src/main/java/com/yeshi/fanli/service/impl/user/UserSystemCouponServiceImpl.java index 558e90f..6ad928c 100644 --- a/fanli/src/main/java/com/yeshi/fanli/service/impl/user/UserSystemCouponServiceImpl.java +++ b/fanli/src/main/java/com/yeshi/fanli/service/impl/user/UserSystemCouponServiceImpl.java @@ -20,6 +20,8 @@ import com.yeshi.fanli.entity.bus.user.DeviceLotteryRecord; import com.yeshi.fanli.entity.bus.user.HongBaoV2; import com.yeshi.fanli.entity.bus.user.Order; +import com.yeshi.fanli.entity.bus.user.TokenRecord; +import com.yeshi.fanli.entity.bus.user.TokenRecord.TokenTypeEnum; import com.yeshi.fanli.entity.bus.user.UserInfo; import com.yeshi.fanli.entity.bus.user.UserInfoExtra; import com.yeshi.fanli.entity.bus.user.UserSystemCoupon; @@ -48,6 +50,7 @@ import com.yeshi.fanli.service.inter.push.PushCouponRecordService; import com.yeshi.fanli.service.inter.push.PushCouponService; import com.yeshi.fanli.service.inter.user.DeviceLotteryRecordService; +import com.yeshi.fanli.service.inter.user.TokenRecordService; import com.yeshi.fanli.service.inter.user.UserInfoExtraService; import com.yeshi.fanli.service.inter.user.UserInfoService; import com.yeshi.fanli.service.inter.user.UserMoneyDetailService; @@ -56,6 +59,7 @@ import com.yeshi.fanli.util.Constant; import com.yeshi.fanli.util.MoneyBigDecimalUtil; import com.yeshi.fanli.util.RedisManager; +import com.yeshi.fanli.util.account.UserUtil; import com.yeshi.fanli.util.factory.UserMoneyDetailFactory; import com.yeshi.fanli.util.taobao.TaoBaoUtil; import com.yeshi.fanli.vo.msg.ClientTextStyleVO; @@ -133,6 +137,9 @@ @Resource private PushCouponRecordService pushCouponRecordService; + + @Resource + private TokenRecordService tokenRecordService; @Override @@ -1636,7 +1643,7 @@ @Override @Transactional - public void exchangeCoupon(Long uid, String couponType, String source, boolean give, BigDecimal percent) throws UserSystemCouponException, Exception { + public void exchangeCoupon(Long uid, String couponType, String source, BigDecimal percent) throws UserSystemCouponException, Exception { if (couponType == null || uid == null) { throw new UserSystemCouponException(1, "鍙傛暟涓嶆纭�"); } @@ -1667,30 +1674,28 @@ UserSystemCoupon userCoupon = new UserSystemCoupon(); userCoupon.setUid(uid); userCoupon.setSource(source); - userCoupon.setGive(give); userCoupon.setSystemCoupon(coupon); - userCoupon.setState(UserSystemCoupon.STATE_CAN_USE); userCoupon.setStateActivated(stateActivated); userCoupon.setStartTime(new Date()); userCoupon.setEndTime(endTime); + userCoupon.setGive(false); userCoupon.setCreateTime(new Date()); userCoupon.setUpdateTime(new Date()); + userCoupon.setState(UserSystemCoupon.STATE_CAN_USE); + insertSelective(userCoupon); } @Transactional @Override - public List<UserSystemCouponVO> getCouponList(long start, int count, Long uid)throws UserSystemCouponException, Exception { - if (uid == null) { - return null; - } - + public List<UserSystemCouponVO> getCouponList(long start, int count, Long uid) + throws UserSystemCouponException, Exception { // 鏇存柊杩囨湡鍒� updateCounponInvalid(uid); // 閫�鍥炲埜 sendBackTimeOutCoupon(uid); - + List<UserSystemCouponVO> listVO = userSystemCouponMapper.getUserCouponVOList(start, count, uid); if (listVO == null || listVO.size() == 0) { return listVO; @@ -1702,7 +1707,7 @@ if (userInfoExtra != null) { inviteCode = userInfoExtra.getInviteCode(); } - + for (UserSystemCouponVO userCouponVO : listVO) { SystemCoupon systemCoupon = userCouponVO.getSystemCoupon(); if (systemCoupon != null && systemCoupon.getId() != null) { @@ -1718,73 +1723,6 @@ userCouponVO.setCouponEffect(systemCoupon.getEffect()); userCouponVO.setCouponRule(systemCoupon.getRule()); userCouponVO.setCouponRuleLink(systemCoupon.getRuleLink()); - - Integer state = userCouponVO.getState(); - // 鍒稿け鏁堝浘鐗囨浛鎹� - if (UserSystemCoupon.STATE_END_USE == state || UserSystemCoupon.STATE_OVERDUE == state) { - userCouponVO.setCouponPicture(systemCoupon.getPictureInvalid()); - } else { - userCouponVO.setCouponPicture(systemCoupon.getPicture()); - } - - Map<String, Object> jumpBtn = null; - CouponTypeEnum type = systemCoupon.getType(); - Integer stateActivated = userCouponVO.getStateActivated(); - - // 鐘舵�佸緟婵�娲� -涓斿彲浣跨敤 - if (UserSystemCoupon.STATE_CAN_USE == state && (stateActivated == null || stateActivated == 0)) { - userCouponVO.setState(0); - userCouponVO.setCouponEffect("寰呮縺娲�"); - if (CouponTypeEnum.freeCoupon == type) { - List<String> listTip = new ArrayList<String>(); - listTip.add("鏈厤鍗曞埜鐢卞ソ鍙嬭禒閫侊紝浠庤幏璧犳棩璧�60澶╁唴闇�浜х敓3绗旇繑鍒╄鍗曪紱"); - listTip.add("杩斿埄璁㈠崟鈥滃凡鍒拌处鈥濆悗锛屾柟鑳借涓鸿鍗曚骇鐢熸垚鍔燂紱"); - listTip.add("婊¤冻鏉′欢鍚庯紝绯荤粺灏嗚嚜鍔ㄦ縺娲伙紝骞跺湪娑堟伅-鍏跺畠娑堟伅涓彁閱掋��"); - } else if (CouponTypeEnum.welfareFreeCoupon == type) { - // 鏈縺娲昏鍒� - userCouponVO.setCouponRule(systemCoupon.getRemark()); - - jumpBtn = new HashMap<String, Object>(); - if (inviteCode != null && inviteCode.trim().length() > 0) { - jumpBtn.put("jumpDetail", jumpDetailV2Service.getByTypeCache("invite_friends")); - } else { - jumpBtn.put("jumpDetail", jumpDetailV2Service.getByTypeCache("invite_activate")); - } - } - } else if (stateActivated == 1) { - // 鏄剧ず瑙勫垯 - userCouponVO.setCouponRule(systemCoupon.getRule()); - - if (UserSystemCoupon.STATE_CAN_USE == state) { - Map<String, Object> jumpLink = new HashMap<String, Object>(); - - if (CouponTypeEnum.freeCoupon == type || CouponTypeEnum.welfareFreeCoupon == type) { - // 鍏嶅崟鍒搞�� 绂忓埄鍏嶅崟鍒� - - // 鍏嶅崟鍟嗗搧鍒楄〃 - jumpLink.put("url", configService.get("free_goods_list")); - - jumpBtn = new HashMap<String, Object>(); - jumpBtn.put("params", jumpLink); - jumpBtn.put("jumpDetail", jumpDetailV2Service.getByTypeCache("web")); - - } else if (CouponTypeEnum.rebatePercentCoupon == type) { - // 杩斿埄濂栧姳鍒�- 璺宠浆鑷宠鍗曞埌璐︾晫闈� - jumpLink.put("state", "2"); - - jumpBtn = new HashMap<String, Object>(); - jumpBtn.put("params", jumpLink); - // 璺宠浆璁㈠崟鍒楄〃 - jumpBtn.put("jumpDetail", jumpDetailV2Service.getByTypeCache("orderList")); - } - - } else if (UserSystemCoupon.STATE_IN_USE == state) { - // 浣跨敤涓� - userCouponVO.setInUseExplain(configService.get("free_coupon_using-help")); - } - } - - userCouponVO.setJumpBtn(jumpBtn); String couponTerm = "鏈夋晥鏈燂細"; Date startTime = userCouponVO.getStartTime(); @@ -1794,6 +1732,13 @@ couponTerm = couponTerm + sdf.format(startTime) + "-" + sdf.format(endTime); } userCouponVO.setCouponTerm(couponTerm); + + Integer state = userCouponVO.getState(); + if (UserSystemCoupon.STATE_END_USE == state || UserSystemCoupon.STATE_OVERDUE == state) { + userCouponVO.setCouponPicture(systemCoupon.getPictureInvalid()); + } else { + userCouponVO.setCouponPicture(systemCoupon.getPicture()); + } if (UserSystemCoupon.STATE_CAN_USE == state) { int differentDays = 0; @@ -1810,7 +1755,142 @@ remainDays.put("fontColor", "#F14242"); userCouponVO.setRemainDays(remainDays); } + + Map<String, Object> jumpBtn = null; + CouponTypeEnum type = systemCoupon.getType(); + Integer stateActivated = userCouponVO.getStateActivated(); + + // 鏈縺娲� + if (stateActivated == null || stateActivated == 0) { + userCouponVO.setCouponEffect("寰呮縺娲�"); + userCouponVO.setCouponRule(systemCoupon.getRemark()); + if (UserSystemCoupon.STATE_CAN_USE == state) { + state = 0; + userCouponVO.setState(state); + if (CouponTypeEnum.freeCoupon == type) { + List<String> listTip = new ArrayList<String>(); + listTip.add("鏈厤鍗曞埜鐢卞ソ鍙嬭禒閫侊紝浠庤幏璧犳棩璧�60澶╁唴闇�浜х敓3绗旇繑鍒╄鍗曪紱"); + listTip.add("杩斿埄璁㈠崟鈥滃凡鍒拌处鈥濆悗锛屾柟鑳借涓鸿鍗曚骇鐢熸垚鍔燂紱"); + listTip.add("婊¤冻鏉′欢鍚庯紝绯荤粺灏嗚嚜鍔ㄦ縺娲伙紝骞跺湪娑堟伅-鍏跺畠娑堟伅涓彁閱掋��"); + userCouponVO.setTips(listTip); + userCouponVO.setPopup(true); + } else if (CouponTypeEnum.welfareFreeCoupon == type) { + jumpBtn = new HashMap<String, Object>(); + if (inviteCode != null && inviteCode.trim().length() > 0) { + jumpBtn.put("jumpDetail", jumpDetailV2Service.getByTypeCache("invite_friends")); + } else { + jumpBtn.put("jumpDetail", jumpDetailV2Service.getByTypeCache("invite_activate")); + } + } + } + } + + if (UserSystemCoupon.STATE_IN_USE == state && (CouponTypeEnum.freeCouponBuy == type + || CouponTypeEnum.freeCoupon == type || CouponTypeEnum.welfareFreeCoupon == type)) { + userCouponVO.setInUseExplain(configService.get("free_coupon_using-help")); + } + + // 鏄惁宸茶禒閫� + Boolean give = userCouponVO.getGive(); + if (give == null) { + give = false; + } + + if (UserSystemCoupon.STATE_CAN_USE == state) { + Map<String, Object> jumpLink = new HashMap<String, Object>(); + if (CouponTypeEnum.freeCouponGive == type) { + userCouponVO.setState(UserSystemCoupon.STATE_GIVE_ONLY); + } else if (CouponTypeEnum.freeCoupon == type || CouponTypeEnum.welfareFreeCoupon == type + || CouponTypeEnum.freeCouponBuy == type) { + jumpLink.put("url", configService.get("free_goods_list")); + jumpBtn = new HashMap<String, Object>(); + jumpBtn.put("params", jumpLink); + jumpBtn.put("jumpDetail", jumpDetailV2Service.getByTypeCache("web")); + } else if (CouponTypeEnum.rebatePercentCoupon == type) { + // 鍙娇鐢ㄣ�� 鍙禒閫� + userCouponVO.setState(UserSystemCoupon.STATE_USE_GIVE); + + // 杩斿埄濂栧姳鍒�- 璺宠浆鑷宠鍗曞埌璐︾晫闈� + jumpLink.put("state", "2"); + jumpBtn = new HashMap<String, Object>(); + jumpBtn.put("params", jumpLink); + jumpBtn.put("jumpDetail", jumpDetailV2Service.getByTypeCache("orderList")); + } + } else if (UserSystemCoupon.STATE_IN_USE == state) { + if (CouponTypeEnum.freeCouponGive == type) { + userCouponVO.setState(UserSystemCoupon.STATE_GIVE_IN); + } + + if (give && CouponTypeEnum.rebatePercentCoupon == type) { + userCouponVO.setState(UserSystemCoupon.STATE_GIVE_IN); + } + } else if (UserSystemCoupon.STATE_END_USE == state) { + if (CouponTypeEnum.freeCouponGive == type) { + userCouponVO.setState(UserSystemCoupon.STATE_GIVE_END); + } + + if (give && CouponTypeEnum.rebatePercentCoupon == type) { + userCouponVO.setState(UserSystemCoupon.STATE_GIVE_END); + } + } + userCouponVO.setJumpBtn(jumpBtn); } return listVO; } + + + @Transactional + @Override + public String giveCoupon(Long uid, Long id) throws UserSystemCouponException { + UserSystemCoupon userSystemCoupon = userSystemCouponMapper.selectByPrimaryKey(id); + if (userSystemCoupon == null) + throw new UserSystemCouponException(1, "璇ュ埜宸蹭笉瀛樺湪"); + + SystemCoupon systemCoupon = userSystemCoupon.getSystemCoupon(); + if (systemCoupon == null) + throw new UserSystemCouponException(1, "璇ュ埜宸蹭笉瀛樺湪"); + + systemCoupon = systemCouponService.selectByPrimaryKey(systemCoupon.getId()); + if (systemCoupon == null) + throw new UserSystemCouponException(1, "璇ュ埜宸插け鏁�"); + + Integer state = userSystemCoupon.getState(); + if (state == UserSystemCoupon.STATE_OVERDUE) + throw new UserSystemCouponException(1, "璇ュ埜宸茶繃鏈�"); + + if (state == UserSystemCoupon.STATE_END_USE) + throw new UserSystemCouponException(1, "璇ュ埜浣跨敤/璧犻�佹垚鍔�"); + + CouponTypeEnum type = systemCoupon.getType(); + if (type != CouponTypeEnum.freeCouponGive && type != CouponTypeEnum.rebatePercentCoupon ) + throw new UserSystemCouponException(1, "璇ュ埜涓嶆敮鎸佽禒閫�"); + + + Date startTime = new Date(); + Date endTime = DateUtil.plusDayDate(3, new Date()); + + long num = 10000 + (long) (Math.random() * 10000); + String token = UserUtil.getInviteCode(num); + + TokenRecord tokenRecord = new TokenRecord(); + tokenRecord.setUid(uid); + tokenRecord.setIdentify(id+""); + tokenRecord.setType(TokenTypeEnum.coupon); + tokenRecord.setEndTime(endTime); + tokenRecord.setStartTime(startTime); + tokenRecord.setToken(token); + tokenRecord.setState(state); + tokenRecordService.insertSelective(tokenRecord); + + + String tips = "閫佺粰浣犱竴寮犺繑鍒╁鍔卞埜蹇幓棰嗗彇鍚э紝澶嶅埗鏈潯娑堟伅[&%s&]锛屾墦寮�[杩斿埄鍒竇App棰嗗彇锛屼娇鐢ㄥ悗鍙杩斿埄鍔犲�嶃�俓r\n" + +"----------------------------\r\n" + + "涓嬭浇[杩斿埄鍒竇App閾炬帴:http://t.cn/2H7AXAH\r\n" + + "PS锛氬彛浠ゅ皢浼�24灏忔椂鍐呭け鏁堬紝璇峰強鏃堕鍙栥��"; + + tips = String.format(tips, token); + + return tips; + } + } -- Gitblit v1.8.0