From e260d06750811a6be0ad1abb85634ced13cc7d94 Mon Sep 17 00:00:00 2001
From: admin <weikou2014>
Date: 星期三, 27 二月 2019 10:28:34 +0800
Subject: [PATCH] 其他消息表结构修改

---
 fanli/src/main/java/com/yeshi/fanli/service/impl/user/UserSystemCouponServiceImpl.java |  103 ++++++++++++++++++++++++++++++++++++++++++---------
 1 files changed, 85 insertions(+), 18 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 f2a951f..e7f8f74 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
@@ -18,6 +18,7 @@
 import com.yeshi.fanli.entity.bus.user.HongBaoV2;
 import com.yeshi.fanli.entity.bus.user.Order;
 import com.yeshi.fanli.entity.bus.user.UserInfo;
+import com.yeshi.fanli.entity.bus.user.UserInfoExtra;
 import com.yeshi.fanli.entity.bus.user.UserSystemCoupon;
 import com.yeshi.fanli.entity.bus.user.UserSystemCouponRecord;
 import com.yeshi.fanli.entity.common.JumpDetailV2;
@@ -30,11 +31,13 @@
 import com.yeshi.fanli.service.inter.config.ConfigService;
 import com.yeshi.fanli.service.inter.config.SystemCouponService;
 import com.yeshi.fanli.service.inter.hongbao.HongBaoV2Service;
+import com.yeshi.fanli.service.inter.hongbao.ThreeSaleSerivce;
 import com.yeshi.fanli.service.inter.msg.UserMoneyMsgNotificationService;
 import com.yeshi.fanli.service.inter.order.CommonOrderService;
 import com.yeshi.fanli.service.inter.order.HongBaoOrderService;
 import com.yeshi.fanli.service.inter.order.OrderHongBaoMapService;
 import com.yeshi.fanli.service.inter.order.OrderService;
+import com.yeshi.fanli.service.inter.user.UserInfoExtraService;
 import com.yeshi.fanli.service.inter.user.UserInfoService;
 import com.yeshi.fanli.service.inter.user.UserMoneyDetailService;
 import com.yeshi.fanli.service.inter.user.UserSystemCouponRecordService;
@@ -90,6 +93,12 @@
 
 	@Resource
 	private UserMoneyMsgNotificationService userMoneyMsgNotificationService;
+	
+	@Resource
+	private UserInfoExtraService userInfoExtraService;
+	
+	@Resource
+	private ThreeSaleSerivce threeSaleSerivce;
 
 	// 鍒稿け鏁堝浘鐗�
 	public final static String PIC_INVALID = "http://192.168.1.200/icon/mian_invalid.png";
@@ -130,6 +139,49 @@
 	}
 
 	@Override
+	public void insertUserCoupon(Long uid, String couponType,String source)throws UserSystemCouponException,Exception{
+		
+		if (couponType == null || uid == null) {
+			throw new UserSystemCouponException(1, "鍙傛暟涓嶆纭�");
+		} 
+		
+		SystemCoupon coupon= systemCouponService.getCouponByType(couponType);
+		if (coupon == null) {
+			throw new UserSystemCouponException(1, "鍒哥被鍨嬩笉姝g‘");
+		} 
+		
+		int stateActivated = 1;
+		if (coupon.getType() == CouponTypeEnum.welfareFreeCoupon) {
+			// 绂忓埄鍒哥姸鎬�
+			long countSuccess = threeSaleSerivce.countSuccessFirstTeam(uid);
+			// 娌℃湁涓嬬骇闃熷憳 --寰呮縺娲�
+			if (countSuccess == 0) {
+				stateActivated = 0;
+			}
+		}
+		
+		// 缁撴潫鏃ユ湡
+		String endDay = DateUtil.plusDay(coupon.getExpiryDay(), new Date());
+		SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd");
+		Date endTime = format.parse(endDay);
+		
+		UserSystemCoupon userCoupon = new UserSystemCoupon();
+		userCoupon.setUid(uid);
+		userCoupon.setSource(source);
+		userCoupon.setSystemCoupon(coupon);
+		userCoupon.setState(UserSystemCoupon.STATE_CAN_USE);
+		userCoupon.setStateActivated(stateActivated);
+		userCoupon.setStartTime(new Date());
+		userCoupon.setEndTime(endTime);
+		userCoupon.setCreateTime(new Date());
+		userCoupon.setUpdateTime(new Date());
+		// 鎻掑叆鏁版嵁搴�
+		insertSelective(userCoupon);
+	}
+
+	
+	
+	@Override
 	public List<UserSystemCouponVO> getUserCouponVOList(long start, int count, Long uid)
 			throws UserSystemCouponException, Exception {
 
@@ -143,7 +195,7 @@
 		}
 
 		// 鏁版嵁缁勭粐
-		listDataFactory(listVO);
+		listDataFactory(listVO, uid);
 
 		return listVO;
 	}
@@ -153,7 +205,7 @@
 	 * 
 	 * @param listVO
 	 */
-	public void listDataFactory(List<UserSystemCouponVO> listVO) throws Exception{
+	public void listDataFactory(List<UserSystemCouponVO> listVO, Long uid) throws Exception{
 
 		for (UserSystemCouponVO userCouponVO : listVO) {
 
@@ -174,21 +226,18 @@
 			userCouponVO.setCouponEffect(systemCoupon.getEffect());
 			userCouponVO.setCouponRule(systemCoupon.getRule());
 
-			// 浣跨敤涓姸鎬� 鏀瑰彉涓哄凡浣跨敤
+			// 浣跨敤鐘舵��
 			Integer state = userCouponVO.getState();
-			if (UserSystemCoupon.STATE_IN_USE == state) {
-				state = UserSystemCoupon.STATE_END_USE;
-				userCouponVO.setState(state);
-			}
 
 			// 鎸夐挳璺宠浆
-
 			Map<String, Object> jumpBtn = null;
+			
 			Integer stateActivated = userCouponVO.getStateActivated();
+			
 			if (stateActivated == null || stateActivated == 0) {
 				// 鏄剧ず瑙勫垯
 				userCouponVO.setCouponRule(systemCoupon.getRemark());
-				systemCoupon.setEffect("寰呮縺娲�");
+				userCouponVO.setCouponEffect("寰呮縺娲�");
 
 				// 鐘舵�佹湭婵�娲� -涓旀湭琚娇鐢�
 				if (UserSystemCoupon.STATE_CAN_USE == state) {
@@ -197,9 +246,21 @@
 
 				jumpBtn = new HashMap<String, Object>();
 				Map<String, Object> jumpLink = new HashMap<String, Object>();
-				jumpLink.put("url", configService.get("invite_activation_url"));
+				
+				UserInfoExtra userInfoExtra = userInfoExtraService.getUserInfoExtra(uid);
+				
+				// 閭�璇烽槦鍛樼晫闈�
+				if (userInfoExtra != null && userInfoExtra.getInviteCode() != null
+						&& userInfoExtra.getInviteCode().trim().length() > 0) {
+					// 閭�璇锋縺娲绘垚鍔熺晫闈�
+					jumpLink.put("url", configService.get("invite_activation_success_url") + "?alert=true");
+				} else {
+					// 婵�娲婚個璇风爜鐣岄潰
+					jumpLink.put("url", configService.get("invite_activation_url"));
+				}
+				
 				jumpBtn.put("params", jumpLink);
-				jumpBtn.put("jumpDetail", jumpDetailV2Service.getByTypeCache("invite"));
+				jumpBtn.put("jumpDetail", jumpDetailV2Service.getByTypeCache("invite_web"));
 
 			} else if (stateActivated == 1) {
 				// 鏄剧ず瑙勫垯
@@ -220,21 +281,26 @@
 						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_END_USE == state || UserSystemCoupon.STATE_OVERDUE == state) {
-					userCouponVO.setCouponPicture(PIC_INVALID);
+					
+				} else if (UserSystemCoupon.STATE_IN_USE == state) {
+					// 浣跨敤涓�
+					userCouponVO.setInUseExplain(configService.get("free_coupon_using-help"));
 				}
-
 			}
+			
+			// 鍒稿け鏁堝浘鐗囨浛鎹�
+			if (UserSystemCoupon.STATE_END_USE == state || UserSystemCoupon.STATE_OVERDUE == state) {
+				userCouponVO.setCouponPicture(PIC_INVALID);
+			}
+			
 			userCouponVO.setJumpBtn(jumpBtn);
 
 			String couponTerm = "鏈夋晥鏈燂細";
@@ -255,7 +321,6 @@
 						differentDays = 0;
 					}
 				}
-
 				// 鍓╀綑澶╂暟
 				Map<String, Object> remainDays = new HashMap<String, Object>();
 				remainDays.put("content", "杩樺墿" + differentDays + "澶╄繃鏈�");
@@ -822,4 +887,6 @@
 		return userRecordVO;
 	}
 
+	
+	
 }

--
Gitblit v1.8.0