From 9dedfa92c34c92d42230e151766726a8e4a7806f Mon Sep 17 00:00:00 2001
From: yujian <yujian>
Date: 星期五, 01 三月 2019 15:10:39 +0800
Subject: [PATCH] 邀请队员免单券 活动跳转地址修改

---
 fanli/src/main/java/com/yeshi/fanli/service/impl/user/UserSystemCouponServiceImpl.java |  113 +++++++++++++++++++++++++++++++++++++-------------------
 1 files changed, 74 insertions(+), 39 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 65905f6..48a3737 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
@@ -118,9 +118,6 @@
 	private UserOtherMsgNotificationService userOtherMsgNotificationService;
 	
 
-	// 鍒稿け鏁堝浘鐗�
-	public final static String PIC_INVALID = "http://192.168.1.200/icon/mian_invalid.png";
-
 	@Override
 	public int insertSelective(UserSystemCoupon record) {
 		return userSystemCouponMapper.insertSelective(record);
@@ -202,7 +199,13 @@
 				UserInfoExtra userInfoExtra = userInfoExtraService.getUserInfoExtra(uid);
 				// 娣诲姞涓�鏉℃秷鎭�
 				if (userInfoExtra != null) {
-					userInfoExtra.setCouponNews(userInfoExtra.getCouponNews() + 1);
+					if (userInfoExtra.getCouponNews() == null) {
+						userInfoExtra.setCouponNews(1);
+					} else {
+						userInfoExtra.setCouponNews(userInfoExtra.getCouponNews() + 1);
+					}
+					
+					
 					try {
 						userInfoExtraService.saveUserInfoExtra(userInfoExtra);
 					} catch (UserInfoExtraException e) {
@@ -215,11 +218,11 @@
 		
 		// 娑堟伅鎺ㄩ��
 		try {
-			if (coupon.getType() != CouponTypeEnum.welfareFreeCoupon) {
+			if (coupon.getType() == CouponTypeEnum.welfareFreeCoupon) {
 				userOtherMsgNotificationService.welfareCouponGet(userCoupon);
-			} else if (coupon.getType() != CouponTypeEnum.freeCoupon) {
+			} else if (coupon.getType() == CouponTypeEnum.freeCoupon) {
 				userOtherMsgNotificationService.freeSheetCouponGet(userCoupon);
-			} else if (coupon.getType() != CouponTypeEnum.rebatePercentCoupon) {
+			} else if (coupon.getType() == CouponTypeEnum.rebatePercentCoupon) {
 				userOtherMsgNotificationService.rewardCouponGet(userCoupon,coupon.getPercent().intValue());
 			}
 			
@@ -283,10 +286,14 @@
 			userCouponVO.setCouponPicture(systemCoupon.getPicture());
 			userCouponVO.setCouponEffect(systemCoupon.getEffect());
 			userCouponVO.setCouponRule(systemCoupon.getRule());
+			userCouponVO.setCouponPictureInvalid(systemCoupon.getPictureInvalid());
 
 			// 浣跨敤鐘舵��
 			Integer state = userCouponVO.getState();
-
+			
+			// 鍒哥被鍨�
+			CouponTypeEnum type = systemCoupon.getType();
+			
 			// 鎸夐挳璺宠浆
 			Map<String, Object> jumpBtn = null;
 			
@@ -327,7 +334,6 @@
 				if (UserSystemCoupon.STATE_CAN_USE == state) {
 					Map<String, Object> jumpLink = new HashMap<String, Object>();
 
-					CouponTypeEnum type = systemCoupon.getType();
 					if (CouponTypeEnum.freeCoupon == type || CouponTypeEnum.welfareFreeCoupon == type) {
 						// 鍏嶅崟鍒搞�� 绂忓埄鍏嶅崟鍒�
 						
@@ -356,8 +362,8 @@
 			
 			// 鍒稿け鏁堝浘鐗囨浛鎹�
 			if (UserSystemCoupon.STATE_END_USE == state || UserSystemCoupon.STATE_OVERDUE == state) {
-				userCouponVO.setCouponPicture(PIC_INVALID);
-			}
+				userCouponVO.setCouponPicture(systemCoupon.getPictureInvalid());
+			} 
 			
 			userCouponVO.setJumpBtn(jumpBtn);
 
@@ -423,15 +429,8 @@
 			userCouponVO.setCouponName(systemCoupon.getName());
 			userCouponVO.setCouponEffect(systemCoupon.getEffect());
 			userCouponVO.setCouponRule(systemCoupon.getRule());
+			userCouponVO.setCouponPictureInvalid(systemCoupon.getPictureInvalid());
 
-			Integer stateActivated = userCouponVO.getStateActivated();
-			if (stateActivated == null || stateActivated == 0) {
-				userCouponVO.setState(0);
-				userCouponVO.setCouponEffect("寰呮縺娲�");
-				userCouponVO.setCouponPicture(PIC_INVALID); // 鏈縺娲诲浘鐗�
-			} else {
-				userCouponVO.setCouponPicture(systemCoupon.getPicture());
-			}
 
 			int differentDays = 0;
 			String couponTerm = "鏈夋晥鏈燂細";
@@ -453,7 +452,23 @@
 			// 鍓╀綑澶╂暟
 			Map<String, Object> remainDays = new HashMap<String, Object>();
 			remainDays.put("content", "杩樺墿" + differentDays + "澶╄繃鏈�");
-			remainDays.put("fontColor", "#F14242");
+			String  remainDaysFontColor = "";
+			
+			Integer stateActivated = userCouponVO.getStateActivated();
+			if (stateActivated == null || stateActivated == 0) {
+				userCouponVO.setState(0);
+				userCouponVO.setCouponEffect("寰呮縺娲�");
+				userCouponVO.setCouponPicture(systemCoupon.getPictureInvalid());
+				
+				remainDaysFontColor = "#CCCCCC";
+				
+			} else {
+				userCouponVO.setCouponPicture(systemCoupon.getPicture());
+				
+				remainDaysFontColor = "#F14242";
+			}
+			
+			remainDays.put("fontColor", remainDaysFontColor);
 			userCouponVO.setRemainDays(remainDays);
 		}
 
@@ -541,7 +556,14 @@
 					for (UserSystemCouponVO userCouponVO: list) {
 						// 鏄剧ず涓嶈兘浣跨敤
 						userCouponVO.setState(0);
-						userCouponVO.setCouponPicture(PIC_INVALID);
+						userCouponVO.setCouponPicture(userCouponVO.getCouponPictureInvalid());
+						
+						Map<String, Object> map = userCouponVO.getRemainDays();
+						if (map != null) {
+							map.put("fontColor", "#CCCCCC");
+						}
+						userCouponVO.setRemainDays(map);
+						
 					}
 				}
 			}
@@ -603,10 +625,10 @@
 		
 		// 娑堟伅鎺ㄩ��
 		try {
-			if (baseCoupon.getType() != CouponTypeEnum.welfareFreeCoupon) {
-//				userOtherMsgNotificationService.welfareCouponUsing(userSystemCoupon,order);
-			} else if (baseCoupon.getType() != CouponTypeEnum.freeCoupon) {
-//				userOtherMsgNotificationService.freeSheetCouponUsing(userSystemCoupon);
+			if (baseCoupon.getType() == CouponTypeEnum.welfareFreeCoupon) {
+				//userOtherMsgNotificationService.welfareCouponUsing(userSystemCoupon,order.get);
+			} else if (baseCoupon.getType() == CouponTypeEnum.freeCoupon) {
+				//userOtherMsgNotificationService.freeSheetCouponUsing(userSystemCoupon);
 			}
 			
 		} catch(Exception e) {
@@ -1067,7 +1089,7 @@
 		userSystemCouponRecordService.updateByPrimaryKeySelective(record);
 		
 		// 鍒搁��鍥�
-		sendBackCoupon(record.getUserSystemCoupon());
+		sendBackCoupon(record.getUserSystemCoupon(), record);
 	}
 	
 	@Transactional
@@ -1087,6 +1109,13 @@
 		record.setUpdateTime(new Date());
 		record.setState(UserSystemCouponRecord.STATE_SUCCESS);
 		userSystemCouponRecordService.updateByPrimaryKeySelective(record);
+		
+		// 娑堟伅鎺ㄩ��
+		if (CouponTypeEnum.welfareFreeCoupon.name().equals(record.getCouponType())) {
+			userOtherMsgNotificationService.welfareCouponUsed(record.getUserSystemCoupon(), orderNo);
+		} else if (CouponTypeEnum.freeCoupon.name().equals(record.getCouponType())) {
+			userOtherMsgNotificationService.freeSheetCouponUsed(record.getUserSystemCoupon(), orderNo);
+		} 
 	}
 
 	@Transactional
@@ -1114,11 +1143,11 @@
 			
 			// 娑堟伅鎺ㄩ��
 			try {
-				if (baseCoupon.getType() != CouponTypeEnum.welfareFreeCoupon) {
+				if (baseCoupon.getType() == CouponTypeEnum.welfareFreeCoupon) {
 					userOtherMsgNotificationService.welfareCouponAlreadyOutOfDate(userSystemCoupon);
-				} else if (baseCoupon.getType() != CouponTypeEnum.freeCoupon) {
+				} else if (baseCoupon.getType() == CouponTypeEnum.freeCoupon) {
 					userOtherMsgNotificationService.freeSheetCouponAlreadyOutOfDate(userSystemCoupon);
-				} else if (baseCoupon.getType() != CouponTypeEnum.rebatePercentCoupon) {
+				} else if (baseCoupon.getType() == CouponTypeEnum.rebatePercentCoupon) {
 					userOtherMsgNotificationService.rewardCouponAlreadyOutOfDate(userSystemCoupon);
 				}
 				
@@ -1223,7 +1252,7 @@
 				userSystemCouponRecordService.updateByPrimaryKeySelective(record);
 				
 				// 閫�鍥炲埜
-				sendBackCoupon(userSystemCoupon);
+				sendBackCoupon(userSystemCoupon, record);
 				
 			} else {
 				// 鍏嶅崟鍖归厤鎴愬姛
@@ -1238,16 +1267,15 @@
 				userSystemCoupon.setUpdateTime(new Date());
 				userSystemCouponMapper.updateByPrimaryKeySelective(userSystemCoupon);
 				
-				SystemCoupon systemCoupon = userSystemCoupon.getSystemCoupon();
+				String couponType = record.getCouponType();
+				if (couponType == null || couponType.trim().length() == 0) {
+					throw new Exception("鍒哥被鍨嬫湭琚褰�");
+				}
 				
-				SystemCoupon baseCoupon = systemCouponService.selectByPrimaryKey(systemCoupon.getId());
-				if (baseCoupon == null) {
-					// 鍒稿凡浣跨敤
-					userOtherMsgNotificationService.freeSheetCouponUsed(userSystemCoupon, orderNo);
-				} else 	if (baseCoupon.getType() != CouponTypeEnum.welfareFreeCoupon) {
+			 	if (CouponTypeEnum.welfareFreeCoupon.name().equals(couponType)) {
 					userOtherMsgNotificationService.welfareCouponUsing(userSystemCoupon,orderNo,payment);
-				} else if (baseCoupon.getType() != CouponTypeEnum.freeCoupon) {
-					userOtherMsgNotificationService.freeSheetCouponUsed(userSystemCoupon,orderNo);
+				} else if (CouponTypeEnum.freeCoupon.name().equals(couponType)) {
+					userOtherMsgNotificationService.freeSheetCouponUsing(userSystemCoupon, orderNo, payment);
 				} 
 			}
 		}
@@ -1259,7 +1287,7 @@
 	 * 閫�鍥炲埜 鍒濆鏁版嵁
 	 * @param userSystemCoupon
 	 */
-	public void sendBackCoupon(UserSystemCoupon userSystemCoupon) throws Exception{
+	public void sendBackCoupon(UserSystemCoupon userSystemCoupon, UserSystemCouponRecord record) throws Exception{
 
 		int expiryDay = 15;
 
@@ -1288,6 +1316,13 @@
 		userSystemCoupon.setUpdateTime(new Date());
 		
 		userSystemCouponMapper.updateByPrimaryKey(userSystemCoupon);
+		
+		
+		if (CouponTypeEnum.welfareFreeCoupon.name().equals(record.getCouponType())) {
+			userOtherMsgNotificationService.welfareCouponDrawBack(userSystemCoupon, record.getOrderNo());
+		} else if (CouponTypeEnum.freeCoupon.name().equals(record.getCouponType())) {
+			userOtherMsgNotificationService.freeSheetCouponDrawBack(userSystemCoupon, record.getOrderNo());
+		} 
 	}
 	
 	

--
Gitblit v1.8.0