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