From 1e28ac69827ff7578a418a79bd95aff2c6637f5c Mon Sep 17 00:00:00 2001
From: yujian <yujian@163.com>
Date: 星期日, 28 六月 2020 16:47:00 +0800
Subject: [PATCH] 2.1.3

---
 fanli/src/main/java/com/yeshi/fanli/service/impl/user/UserSystemCouponServiceImpl.java |  134 +++++++++++++++++++++++++++++++++++++++++---
 1 files changed, 123 insertions(+), 11 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 38dc60c..4a103ec 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
@@ -1,6 +1,7 @@
 package com.yeshi.fanli.service.impl.user;
 
 import java.math.BigDecimal;
+import java.text.ParseException;
 import java.text.SimpleDateFormat;
 import java.util.ArrayList;
 import java.util.Date;
@@ -317,6 +318,97 @@
 		return userSystemCoupon;
 	}
 
+	
+	@Override
+	@Transactional(rollbackFor = Exception.class)
+	public UserSystemCoupon freeCouponWinBySystem(Long uid, CouponTypeEnum typeEnum, String source, int num, boolean notify,
+			Integer expiryDay) throws UserSystemCouponException, Exception {
+		if (typeEnum == null || uid == null || StringUtil.isNullOrEmpty(source) || num < 1) {
+			throw new UserSystemCouponException(1, "鍙傛暟涓嶆纭�");
+		}
+
+		SystemCoupon coupon = systemCouponService.getCouponByType(typeEnum.name());
+		if (coupon == null) {
+			throw new UserSystemCouponException(1, "鍒哥被鍨嬩笉姝g‘");
+		}
+
+		// 婵�娲荤姸鎬�
+		int stateActivated = 0;
+		// 鑷喘鍏嶅崟鍒搞�佽禒閫佸厤鍗曞埜鍙洿鎺ヤ娇鐢�
+		if (coupon.getType() == CouponTypeEnum.freeCouponBuy || coupon.getType() == CouponTypeEnum.freeCouponGive) {
+			stateActivated = 1;
+		}
+
+		// 鏈夋晥鏃堕暱
+		if (expiryDay == null) {
+			if (stateActivated == 0)
+				expiryDay = coupon.getActivateDay();
+			if (expiryDay == null || expiryDay == 0)
+				expiryDay = coupon.getExpiryDay();
+		}
+
+		// 璁$畻缁撴潫鏃ユ湡
+		Date nowTime = new Date();
+		String endDay = DateUtil.plusDay(expiryDay - 1, nowTime);
+		SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
+		if (endDay != null && endDay.trim().length() > 0) {
+			endDay += " 23:59:59";
+		}
+		Date endTime = format.parse(endDay);
+
+		UserSystemCoupon userSystemCoupon = null;
+		for (int i = 0; i < num; i++) {
+			UserSystemCoupon userCoupon = new UserSystemCoupon();
+			userCoupon.setUid(uid);
+			userCoupon.setSource(source);
+			userCoupon.setSystemCoupon(coupon);
+			userCoupon.setState(UserSystemCoupon.STATE_CAN_USE);
+			userCoupon.setStateActivated(stateActivated);
+			userCoupon.setStartTime(nowTime);
+			userCoupon.setEndTime(endTime);
+			userCoupon.setCreateTime(nowTime);
+			userCoupon.setUpdateTime(nowTime);
+			userSystemCouponMapper.insertSelective(userCoupon);
+			// 闇�瑕佹縺娲诲埜
+			if (typeEnum == CouponTypeEnum.freeCoupon) {
+				userSystemCouponActivateService.addActivateRecord(userCoupon.getId());
+			}
+
+			if (num == 1) {
+				userSystemCoupon = userCoupon;
+			}
+		}
+
+		executor.execute(new Runnable() {
+			@Override
+			public void run() {
+				if (notify) { // 娑堟伅鎺ㄩ��
+					try {
+						userOtherMsgNotificationService.freeCouponWinMsg(uid, typeEnum.getDesc(), source, num, "鎴愬姛鑾峰緱",
+								nowTime, endTime);
+					} catch (Exception e) {
+						e.printStackTrace();
+					}
+				}
+
+				// 绂忓埄涓績绾㈢偣
+				UserInfoExtra extra = userInfoExtraService.getUserInfoExtra(uid);
+				if (extra != null) {
+					UserInfoExtra updateExtra = new UserInfoExtra();
+					updateExtra.setId(extra.getId());
+					if (extra.getCouponNews() == null) {
+						updateExtra.setCouponNews(1);
+					} else {
+						updateExtra.setCouponNews(extra.getCouponNews() + 1);
+					}
+					userInfoExtraService.updateByPrimaryKeySelective(updateExtra);
+				}
+			}
+		});
+
+		return userSystemCoupon;
+	}
+	
 	@Override
 	@Transactional(rollbackFor = Exception.class)
 	public UserSystemCoupon rewardCouponWin(Long uid, String source, int num, boolean notify, BigDecimal percent)
@@ -550,27 +642,24 @@
 	}
 
 	@Override
-	public List<UserSystemCouponVO> getEnableListByCouponId(Long uid, Integer activated, List<SystemCoupon> couponList)
-			throws UserSystemCouponException, Exception {
-
+	public List<UserSystemCouponVO> getEnableListByCouponId(Long uid, Integer activated, List<SystemCoupon> couponList) {
 		List<Long> listCouponId = new ArrayList<Long>();
 		for (SystemCoupon systemCoupon : couponList) {
 			listCouponId.add(systemCoupon.getId());
 		}
 
 		List<UserSystemCouponVO> listVO = userSystemCouponMapper.getEnableListByCouponId(uid, activated, listCouponId);
-
 		if (listVO == null || listVO.size() == 0) {
 			return null;
 		}
-
+		
+		SimpleDateFormat sdf = new SimpleDateFormat("yyyy.MM.dd");
+		SimpleDateFormat sdf2 = new SimpleDateFormat("yyyy-MM-dd");
 		for (UserSystemCouponVO userCouponVO : listVO) {
-
 			SystemCoupon systemCoupon = userCouponVO.getSystemCoupon();
 			if (systemCoupon == null) {
 				continue; // 鍒镐俊鎭笉瀹屾暣
 			}
-
 			for (SystemCoupon coupon : couponList) {
 				if (coupon.getId().equals(systemCoupon.getId()) || coupon.getId() == systemCoupon.getId()) {
 					systemCoupon = coupon;
@@ -596,11 +685,15 @@
 			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);
 
-				SimpleDateFormat sdf2 = new SimpleDateFormat("yyyy-MM-dd");
-				differentDays = DateUtil.daysBetween(sdf2.format(new Date()), sdf2.format(endTime)) + 1;
+			
+				try {
+					differentDays = DateUtil.daysBetween(sdf2.format(new Date()), sdf2.format(endTime)) + 1;
+				} catch (ParseException e) {
+					e.printStackTrace();
+				}
 				if (differentDays < 0) {
 					differentDays = 0;
 				}
@@ -679,6 +772,24 @@
 
 	@Transactional(rollbackFor = Exception.class)
 	@Override
+	public List<UserSystemCouponVO> getFreeCouponList(Long uid) {
+		// 杩囨湡鍒�
+		updateInvalidSate(uid);
+
+		// 閫�鍥炲埜
+		sendBackTimeOutCoupon(uid);
+
+		// 鍟嗗搧鐩稿叧鐨勫埜
+		List<SystemCoupon> couponList = systemCouponService.getGoodsCouponList();
+		if (couponList == null || couponList.size() == 0) {
+			return null;
+		}
+		return getEnableListByCouponId(uid, null, couponList);
+	}
+
+	
+	@Transactional(rollbackFor = Exception.class)
+	@Override
 	public List<UserSystemCouponVO> getGoodsCouponList(Long uid, Long auctionId)
 			throws UserSystemCouponException, Exception {
 
@@ -728,7 +839,7 @@
 
 		return list;
 	}
-
+	
 	@Override
 	public long countUsableFreeCouponForBuy(Long uid) {
 		if (uid == null)
@@ -2493,4 +2604,5 @@
 		}
 	}
 
+
 }

--
Gitblit v1.8.0