From 6009c2c07cd32a76b32c8d63a5a017be695c5ea5 Mon Sep 17 00:00:00 2001
From: admin <weikou2014>
Date: 星期一, 26 八月 2019 15:19:33 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/div' into div

---
 fanli/src/main/java/com/yeshi/fanli/service/impl/user/UserSystemCouponServiceImpl.java |  132 +++++++++++++++++++++++++++++++++++--------
 1 files changed, 106 insertions(+), 26 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 43b17bc..9f625c4 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
@@ -191,7 +191,7 @@
 
 	@Override
 	@Transactional
-	public void insertUserCoupon(Long uid, String couponType, String source)
+	public void insertUserCoupon(Long uid, String couponType, String source, BigDecimal percent)
 			throws UserSystemCouponException, Exception {
 
 		if (couponType == null || uid == null) {
@@ -204,8 +204,12 @@
 			coupon = systemCouponService.getCouponByType(couponType);
 		} else if (couponType.equals(CouponTypeEnum.rebatePercentCoupon.name())) {
 			// 闅忔満濂栧姳鍒�
-			randomRewardCoupon(1, uid, source);
-			return;
+			if (percent == null || percent.compareTo(new BigDecimal(0)) < 1) {
+				randomRewardCoupon(1, uid, source);
+				return;
+			}  else {
+				coupon = systemCouponService.getCouponByTypeAndPercent(couponType, percent);
+			}
 		}
 		
 		if (coupon == null) {
@@ -224,9 +228,16 @@
 			stateActivated = 0;
 		}
 
+		Integer expiryDay = null;
+		if (stateActivated == 0) 
+			expiryDay = coupon.getActivateDay();
+			
+		if (expiryDay == null || expiryDay == 0) 
+			expiryDay = coupon.getExpiryDay();
+		
 		// 缁撴潫鏃ユ湡
 		// 浠婂ぉ鍦ㄥ唴  鍑忓幓涓�澶�
-		String endDay = DateUtil.plusDay(coupon.getExpiryDay() - 1, new Date());
+		String endDay = DateUtil.plusDay(expiryDay - 1, new Date());
 		SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd");
 		Date endTime = format.parse(endDay);
 
@@ -1658,9 +1669,18 @@
 		} else if (couponType == CouponTypeEnum.welfareFreeCoupon.name() && threeSaleSerivce.countSuccessFirstTeam(uid) <= 0) {
 			stateActivated = 0;  // 鏃犱笅绾ч槦鍛� --寰呮縺娲�
 		} 
-
+		
+		
+		Integer expiryDay = null;
+		if (stateActivated == 0) 
+			expiryDay = coupon.getActivateDay();
+			
+		if (expiryDay == null || expiryDay == 0) 
+			expiryDay = coupon.getExpiryDay();
+		
+			
 		//  璁$畻缁撴潫鏃ユ湡锛氫粖澶╁湪鍐�  鍑忓幓涓�澶�
-		String endDay = DateUtil.plusDay(coupon.getExpiryDay() - 1, new Date());
+		String endDay = DateUtil.plusDay(expiryDay - 1, new Date());
 		SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd");
 		Date endTime = format.parse(endDay);
 
@@ -1709,7 +1729,12 @@
 				continue; // 鍒镐俊鎭笉瀹屾暣
 			}
 
-			userCouponVO.setSource("鏉ユ簮锛�" + userCouponVO.getSource());
+			String source = userCouponVO.getSource();
+			if (source != null && "濂栧姳鍒稿ぉ澶╂娊".equals(source)) {
+				source = "澶╁ぉ鎶�";
+			}
+			
+			userCouponVO.setSource("鏉ユ簮锛�" + source);
 			userCouponVO.setCouponName(systemCoupon.getName());
 			userCouponVO.setCouponEffect(systemCoupon.getEffect());
 			userCouponVO.setCouponRule(systemCoupon.getRule());
@@ -1787,6 +1812,8 @@
 				give = false;
 			}
 			
+			SimpleDateFormat sdf = new SimpleDateFormat("yyyy.MM.dd");
+			
 			if (UserSystemCoupon.STATE_CAN_USE == state) {
 				Map<String, Object> jumpLink = new HashMap<String, Object>();
 				if (CouponTypeEnum.freeCouponGive == type) {
@@ -1809,27 +1836,33 @@
 				}
 			} else if (UserSystemCoupon.STATE_IN_USE == state && give) {
 				userCouponVO.setCouponEffect("璧犻�佷腑");
+				userCouponVO.setCouponRule(systemCoupon.getRemark());
 				String tips = null;
+				
+				TokenTypeEnum tokenType = null;
 				if (CouponTypeEnum.freeCouponGive == type) {
 					userCouponVO.setState(UserSystemCoupon.STATE_GIVE_IN);
 					tips = configService.get("give_free_coupon_tips");
+					tokenType = TokenTypeEnum.freeCoupon;
 				}
 				
 				if (CouponTypeEnum.rebatePercentCoupon == type) {
 					userCouponVO.setState(UserSystemCoupon.STATE_GIVE_IN);
 					tips = configService.get("give_free_coupon_tips");
+					tokenType = TokenTypeEnum.rebatePercentCoupon;
 				}
 				
-				if (!StringUtil.isNullOrEmpty(tips)) {
+				if (!StringUtil.isNullOrEmpty(tips) && tokenType != null) {
 					UserSystemCouponGiveRecord record = userSystemCouponGiveRecordService.getRecordByUidAndCouponId(uid, userCouponVO.getId());
 					if (record != null) {
-						TokenRecord tokenRecord = tokenRecordService.getNearByTypeAndIdentify(CouponTypeEnum.freeCoupon.name(), record.getId().toString());
+						TokenRecord tokenRecord = tokenRecordService.getNearByTypeAndIdentify(tokenType.name(), record.getId().toString());
 						if (tokenRecord != null && !StringUtil.isNullOrEmpty(tokenRecord.getToken())) {
 							String projectChineseName = Constant.systemCommonConfig.getProjectChineseName();
 							while(tips.contains("{APP鍚嶇О}")) {
 								tips = tips.replace("{APP鍚嶇О}", projectChineseName);
 							}
 							tips = tips.replace("{鍙d护}", tokenRecord.getToken()).replace("{涓嬭浇閾炬帴}", configService.get("app_down_link"));
+							userCouponVO.setGiveTips(tips);
 						}
 						
 						Date endTimeGive = record.getEndTime();
@@ -1839,19 +1872,35 @@
 							remainDays.put("fontColor", "#F14242");
 							userCouponVO.setRemainDays(remainDays);
 						}
-					}
-				} else {
-					tips = "";
-				}
-				userCouponVO.setGiveTips(tips);
-			} else if (UserSystemCoupon.STATE_END_USE == state) {
-				if (give && CouponTypeEnum.freeCouponGive == type) {
+					} 
+				} 
+			} else if (give && UserSystemCoupon.STATE_END_USE == state) {
+				userCouponVO.setCouponRule(systemCoupon.getRemark());
+				if (CouponTypeEnum.freeCouponGive == type) {
 					userCouponVO.setState(UserSystemCoupon.STATE_GIVE_END);
 				}
 				
-				if (give && CouponTypeEnum.rebatePercentCoupon == type) {
+				if (CouponTypeEnum.rebatePercentCoupon == type) {
 					userCouponVO.setState(UserSystemCoupon.STATE_GIVE_END);
 				}
+				
+				Date useTime = userCouponVO.getUseTime();
+				if (useTime != null) {
+					Map<String, Object> remainDays = new HashMap<String, Object>();
+					remainDays.put("content", "浜�" + sdf.format(useTime) + "鎴愬姛璧犻��");
+					remainDays.put("fontColor", "#999999");
+					userCouponVO.setRemainDays(remainDays);
+				}
+			}else if (UserSystemCoupon.STATE_OVERDUE == state) {
+				if (endTime != null) {
+					Map<String, Object> remainDays = new HashMap<String, Object>();
+					remainDays.put("content", "浜�" + sdf.format(endTime) + "杩囨湡");
+					remainDays.put("fontColor", "#999999");
+					userCouponVO.setRemainDays(remainDays);
+				}
+				
+				if(give)
+					userCouponVO.setCouponRule(systemCoupon.getRemark());
 			}
 			userCouponVO.setJumpBtn(jumpBtn);
 		}
@@ -1861,7 +1910,7 @@
 	
 	@Transactional
 	@Override
-	public String giveCoupon(Long uid, Long id) throws UserSystemCouponException {
+	public UserSystemCouponVO giveCoupon(Long uid, Long id) throws UserSystemCouponException {
 		UserSystemCoupon userSystemCoupon = userSystemCouponMapper.selectByPrimaryKey(id);
 		if (userSystemCoupon == null)
 			throw new UserSystemCouponException(1, "璇ュ埜宸蹭笉瀛樺湪");
@@ -1875,11 +1924,8 @@
 			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, "璇ュ埜浣跨敤/璧犻�佹垚鍔�");
+		if (state != UserSystemCoupon.STATE_CAN_USE) 
+			throw new UserSystemCouponException(1, "璇ュ埜宸茶浣跨敤鎴栬禒閫�");
 		
 		CouponTypeEnum type = systemCoupon.getType();
 		if (type != CouponTypeEnum.freeCouponGive && type != CouponTypeEnum.rebatePercentCoupon )
@@ -1911,7 +1957,8 @@
 					tips = tips.replace("{APP鍚嶇О}", projectChineseName);
 				}
 				tips = tips.replace("{鍙d护}", tokenRecord.getToken()).replace("{涓嬭浇閾炬帴}", configService.get("app_down_link"));
-				return tips;
+				
+				return createUserCouponVOo(userSystemCoupon, systemCoupon, record, tips);
 			}
 		}
 		
@@ -1960,7 +2007,40 @@
 			tips = tips.replace("{APP鍚嶇О}", projectChineseName);
 		}
 		tips = tips.replace("{鍙d护}", token).replace("{涓嬭浇閾炬帴}", configService.get("app_down_link"));
-		return tips;
+		
+		return createUserCouponVOo(userSystemCoupon, systemCoupon, giveRecord, tips);
+	}
+	
+	
+	private UserSystemCouponVO createUserCouponVOo(UserSystemCoupon userSystemCoupon, SystemCoupon systemCoupon, 
+			UserSystemCouponGiveRecord record, String tips) {
+		UserSystemCouponVO userCouponVO = new UserSystemCouponVO();
+		userCouponVO.setId(userSystemCoupon.getId());
+		userCouponVO.setUid(userSystemCoupon.getUid());
+		userCouponVO.setSource("鏉ユ簮锛�" + userSystemCoupon.getSource());
+		userCouponVO.setCouponName(systemCoupon.getName());
+		userCouponVO.setCouponEffect("璧犻�佷腑");
+		userCouponVO.setState(UserSystemCoupon.STATE_GIVE_IN);
+		userCouponVO.setCouponRule(systemCoupon.getRemark());
+		userCouponVO.setCouponRuleLink(systemCoupon.getRuleLink());
+		userCouponVO.setCouponPicture(systemCoupon.getPicture());
+		userCouponVO.setGiveTips(tips);
+		
+		String couponTerm = "鏈夋晥鏈燂細";
+		Date startTime = userCouponVO.getStartTime();
+		Date endTime = userCouponVO.getEndTime();
+		if (endTime != null && startTime != null) {
+			SimpleDateFormat sdf = new SimpleDateFormat("yyyy.MM.dd");
+			couponTerm = couponTerm + sdf.format(startTime) + "-" + sdf.format(endTime);
+		}
+		userCouponVO.setCouponTerm(couponTerm);
+		
+		Map<String, Object> remainDays = new HashMap<String, Object>();
+		remainDays.put("content", "鍓╀綑23鏃�59鍒嗚繃鏈�");
+		remainDays.put("fontColor", "#F14242");
+		userCouponVO.setRemainDays(remainDays);
+		
+		return userCouponVO;
 	}
 
 	
@@ -2025,7 +2105,7 @@
 			
 			// 閫�鍥炴秷鎭�
 			String beiZhu = "璇峰埌鎴戠殑-绂忓埄涓績鏌ョ湅";
-			SimpleDateFormat sd = new SimpleDateFormat("yyyy.MM.dd HH.mm");
+			SimpleDateFormat sd = new SimpleDateFormat("yyyy.MM.dd HH:mm");
 			MsgOtherGiveContentDTO msgOther = new MsgOtherGiveContentDTO();
 			msgOther.setType(MsgOtherGiveContentDTO.TYEP_COUPON);
 			msgOther.setTitle("璧犻��" + systemCoupon.getName() + "閫�鍥�");

--
Gitblit v1.8.0