From dcd5d07d5d648b48f6f04cd79b6e8c5b780dcff7 Mon Sep 17 00:00:00 2001
From: admin <weikou2014>
Date: 星期三, 27 二月 2019 16:59:40 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 fanli/src/main/java/com/yeshi/fanli/service/impl/user/UserSystemCouponServiceImpl.java |  227 ++++++++++++++++++++++++++++++++++++++++++++++++++++----
 1 files changed, 210 insertions(+), 17 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 f4effdd..8adeccd 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
@@ -11,6 +11,7 @@
 
 import javax.annotation.Resource;
 
+import org.springframework.core.task.TaskExecutor;
 import org.springframework.stereotype.Service;
 import org.springframework.transaction.annotation.Transactional;
 import org.yeshi.utils.DateUtil;
@@ -27,6 +28,7 @@
 import com.yeshi.fanli.entity.order.CommonOrder;
 import com.yeshi.fanli.entity.system.SystemCoupon;
 import com.yeshi.fanli.entity.system.SystemCoupon.CouponTypeEnum;
+import com.yeshi.fanli.exception.user.UserInfoExtraException;
 import com.yeshi.fanli.exception.user.UserSystemCouponException;
 import com.yeshi.fanli.log.LogHelper;
 import com.yeshi.fanli.service.inter.common.JumpDetailV2Service;
@@ -58,6 +60,9 @@
 @Service
 public class UserSystemCouponServiceImpl implements UserSystemCouponService {
 
+	@Resource(name = "taskExecutor")
+	private TaskExecutor executor;
+	
 	@Resource
 	private UserSystemCouponMapper userSystemCouponMapper;
 
@@ -185,6 +190,22 @@
 		// 鎻掑叆鏁版嵁搴�
 		insertSelective(userCoupon);
 		
+		executor.execute(new Runnable() {
+			@Override
+			public void run() {
+				UserInfoExtra userInfoExtra = userInfoExtraService.getUserInfoExtra(uid);
+				// 娣诲姞涓�鏉℃秷鎭�
+				if (userInfoExtra != null) {
+					userInfoExtra.setCouponNews(userInfoExtra.getCouponNews() + 1);
+					try {
+						userInfoExtraService.saveUserInfoExtra(userInfoExtra);
+					} catch (UserInfoExtraException e) {
+						e.printStackTrace();
+					}
+				}
+				
+			}
+		});
 		
 		// 娑堟伅鎺ㄩ��
 		try {
@@ -218,7 +239,7 @@
 		// 鏇存柊杩囨湡鍒�
 		updateCounponInvalid(uid);
 		// 閫�鍥炲埜
-		sendBackCoupon(uid);
+		sendBackTimeOutCoupon(uid);
 		
 		List<UserSystemCouponVO> listVO = userSystemCouponMapper.getUserCouponVOList(start, count, uid);
 		if (listVO == null || listVO.size() == 0) {
@@ -465,7 +486,7 @@
 		// 鏇存柊杩囨湡鍒�
 		updateCounponInvalid(uid);
 		// 閫�鍥炲埜
-		sendBackCoupon(uid);
+		sendBackTimeOutCoupon(uid);
 				
 		// 璁㈠崟鐩稿叧鐨勫埜
 		List<SystemCoupon> couponList = systemCouponService.getOrderCouponList();
@@ -485,7 +506,7 @@
 		// 鏇存柊杩囨湡鍒�
 		updateCounponInvalid(uid);
 		// 閫�鍥炲埜
-		sendBackCoupon(uid);
+		sendBackTimeOutCoupon(uid);
 		
 		// 鍟嗗搧鐩稿叧鐨勫埜
 		List<SystemCoupon> couponList = systemCouponService.getGoodsCouponList();
@@ -718,17 +739,20 @@
 		}
 		
 		// 鑾峰彇濂栧姳閲戦
-		Map<String, BigDecimal> map = orderHongBaoMapService.getCouponHongbaoByOrderNo(orderNo, uid);
-
+		BigDecimal couponMoney = orderHongBaoMapService.getCouponHongbaoByOrderNo(orderNo, uid);
+		
 		UserSystemCouponRecordVO userRecordVO = new UserSystemCouponRecordVO();
 		userRecordVO.setCouponMoneyState("宸插埌璐�");
 		userRecordVO.setCommonOrder(commonOrderVO);
-		userRecordVO.setCouponName("濂栧姳閲�: 楼" + map.get("couponMoney").setScale(2, BigDecimal.ROUND_DOWN));
+		userRecordVO.setCouponName("濂栧姳閲�: 楼" + couponMoney.setScale(2, BigDecimal.ROUND_DOWN));
 
 		// 姣斾緥
 		BigDecimal percent = baseCoupon.getPercent();
-		BigDecimal hongBao = map.get("totalMoney").setScale(2, BigDecimal.ROUND_DOWN);
-		userRecordVO.setCouponEffect("杩斿埄楼" + hongBao + "宸茶繑" + percent + "%");
+		BigDecimal hongBao = commonOrderVO.getHongBao();
+		if (hongBao == null) {
+			hongBao = new BigDecimal(0);
+		}
+		userRecordVO.setCouponEffect("杩斿埄楼" + hongBao.setScale(2, BigDecimal.ROUND_DOWN) + "宸茶繑" + percent + "%");
 
 		// 璺宠浆绂忓埄涓績
 		JumpDetailV2 welfareCore = jumpDetailV2Service.getByTypeCache("welfareCore");
@@ -963,10 +987,70 @@
 		if (systemCoupon == null) {
 			return;
 		}
-		// 婵�娲荤鍒╁厤鍗曞埜
-		userSystemCouponMapper.activateCouponByType(uid, systemCoupon.getId());
+		
+		// 寰呮椿绂忓埄鍏嶅崟鍒�
+		List<UserSystemCoupon> list = userSystemCouponMapper.getCouponByTypeAndNotActivated(uid, systemCoupon.getId());
+		if (list == null || list.size() == 0) {
+			return;
+		}
+		
+		for (UserSystemCoupon userSystemCoupon: list) {
+			// 婵�娲�
+			userSystemCoupon.setStateActivated(1);
+			userSystemCoupon.setUpdateTime(new Date());
+			userSystemCouponMapper.updateByPrimaryKeySelective(userSystemCoupon);
+			
+			// 娑堟伅鎺ㄩ��
+			try {
+				userOtherMsgNotificationService.welfareCouponGet(userSystemCoupon);
+			} catch(Exception e) {
+				try {
+					LogHelper.errorDetailInfo(e);
+				} catch (Exception e1) {
+					e1.printStackTrace();
+				}
+			}
+		}
 	}
 	
+	@Override
+	public void updateStateByDrawback(String orderNo) throws Exception {
+		
+		if (orderNo == null || orderNo.trim().length() == 0) {
+			return;
+		}
+
+		UserSystemCouponRecord record = userSystemCouponRecordService.getRecordByOrderNo(orderNo, null);
+		if (record == null) {
+			return;
+		}
+		
+		record.setOrderNo(orderNo);
+		record.setUpdateTime(new Date());
+		record.setState(UserSystemCouponRecord.STATE_FAIL_DRAWBACK);
+		userSystemCouponRecordService.updateByPrimaryKeySelective(record);
+		
+		// 鍒搁��鍥�
+		sendBackCoupon(record.getUserSystemCoupon());
+	}
+	
+	@Override
+	public void updateStateByArrivalAccount(String orderNo) throws Exception {
+		
+		if (orderNo == null || orderNo.trim().length() == 0) {
+			return;
+		}
+
+		UserSystemCouponRecord record = userSystemCouponRecordService.getRecordByOrderNo(orderNo, 2);
+		if (record == null) {
+			return;
+		}
+		
+		record.setOrderNo(orderNo);
+		record.setUpdateTime(new Date());
+		record.setState(UserSystemCouponRecord.STATE_SUCCESS);
+		userSystemCouponRecordService.updateByPrimaryKeySelective(record);
+	}
 
 	@Override
 	public void updateCounponInvalid(Long uid) {
@@ -1011,9 +1095,9 @@
 	}
 	
 	@Override
-	public void  sendBackCoupon(Long uid) {
+	public void  sendBackTimeOutCoupon(Long uid) {
 		// 瓒呰繃120绉� 鏈鍖归厤鐨勫埜
-		List<UserSystemCouponRecord> list = userSystemCouponRecordService.getCouponByUsingTimeOut(uid, 120);
+		List<UserSystemCouponRecord> list = userSystemCouponRecordService.getCouponByUsingTimeOut(uid, 120L);
 		if (list == null || list.size() == 0) {
 			return;
 		}
@@ -1025,9 +1109,6 @@
 			userSystemCouponRecordService.updateByPrimaryKeySelective(couponRecord);
 			
 			UserSystemCoupon userSystemCoupon = couponRecord.getUserSystemCoupon();
-			// 鐘舵�佸垵濮嬪寲
-			userSystemCoupon.setState(UserSystemCoupon.STATE_CAN_USE);
-			userSystemCoupon.setUseTime(null);
 			
 			int expiryDay = 15;
 			
@@ -1046,16 +1127,128 @@
 			} catch (ParseException e) {
 				e.printStackTrace();
 			}
-			
+			// 鐘舵�佸垵濮嬪寲
+			userSystemCoupon.setState(UserSystemCoupon.STATE_CAN_USE);
+			userSystemCoupon.setUseTime(null);
+						
 			// 鏈夋晥鏈熸椂闂撮噸鏂板畾涔�
 			userSystemCoupon.setStartTime(new Date());
 			userSystemCoupon.setEndTime(endTime);
 			userSystemCoupon.setUpdateTime(new Date());
 			userSystemCouponMapper.updateByPrimaryKey(userSystemCoupon);
 		}
-		
 	}
 	
+	@Override
+	public boolean updateCouponRecordUsed(Long uid, String orderNo, BigDecimal payment,
+			Long auctionId) throws  Exception{
+		
+		boolean isfree = false;
+		
+		if (uid == null || payment == null || auctionId == null || orderNo == null || 
+				orderNo.trim().length() == 0 ) {
+			throw new Exception("浼犻�掑弬鏁颁笉鑳戒负绌�");
+		}
+		
+		// 鏌ヨ绛夊緟鍖归厤鐨勫埜璁板綍
+		List<UserSystemCouponRecord> list = userSystemCouponRecordService.getRecordByState(uid, UserSystemCouponRecord.STATE_WAIT);
+		if (list == null || list.size() == 0) {
+			return  isfree;
+		}
+		
+		// 鍖归厤
+		boolean matching = false;
+		UserSystemCouponRecord record = null;
+		
+		for (UserSystemCouponRecord userSystemCouponRecord : list) {
+			Long goodId = userSystemCouponRecord.getGoodId();
+			if (auctionId.equals(goodId)) {
+				matching = true; // 鍖归厤鎴愬姛
+				record = userSystemCouponRecord;
+				break;
+			}
+		}
+		
+		// 鍟嗗搧鍖归厤鎴愬姛
+		if (matching) {
+			
+			record.setOrderNo(orderNo);
+			record.setUpdateTime(new Date());
+			
+			UserSystemCoupon userSystemCoupon = record.getUserSystemCoupon();
+			
+			if (payment.compareTo(new BigDecimal(10)) > 0) {
+				// 鏇存柊璁板綍 -- 閲戦涓嶅尮閰�  澶�10鍏�
+				record.setState(UserSystemCouponRecord.STATE_FAIL_RULE);
+				userSystemCouponRecordService.updateByPrimaryKeySelective(record);
+				
+				// 閫�鍥炲埜
+				sendBackCoupon(userSystemCoupon);
+				
+			} else {
+				// 鍏嶅崟鍖归厤鎴愬姛
+				isfree = true;
+				
+				//鏇存柊璁板綍--鍏嶅崟涓�
+				record.setState(UserSystemCouponRecord.STATE_FREE_ON);
+				userSystemCouponRecordService.updateByPrimaryKeySelective(record);
+				
+				// 鍒哥粨鏉熶娇鐢�
+				userSystemCoupon.setState(UserSystemCoupon.STATE_END_USE);
+				userSystemCoupon.setUpdateTime(new Date());
+				userSystemCouponMapper.updateByPrimaryKeySelective(userSystemCoupon);
+				
+				SystemCoupon systemCoupon = userSystemCoupon.getSystemCoupon();
+				
+				SystemCoupon baseCoupon = systemCouponService.selectByPrimaryKey(systemCoupon.getId());
+				if (baseCoupon == null) {
+					// 鍒稿凡浣跨敤
+					userOtherMsgNotificationService.freeSheetCouponUsed(userSystemCoupon);
+				} else 	if (baseCoupon.getType() != CouponTypeEnum.welfareFreeCoupon) {
+					userOtherMsgNotificationService.welfareCouponUsed(userSystemCoupon);
+				} else if (baseCoupon.getType() != CouponTypeEnum.freeCoupon) {
+					userOtherMsgNotificationService.freeSheetCouponUsed(userSystemCoupon);
+				} 
+			}
+		}
+		
+		return isfree;
+	}
+	
+	/**
+	 * 閫�鍥炲埜 鍒濆鏁版嵁
+	 * @param userSystemCoupon
+	 */
+	public void sendBackCoupon(UserSystemCoupon userSystemCoupon) throws Exception{
+
+		int expiryDay = 15;
+
+		SystemCoupon systemCoupon = userSystemCoupon.getSystemCoupon();
+		SystemCoupon coupon = systemCouponService.selectByPrimaryKey(systemCoupon.getId());
+		if (coupon != null) {
+			expiryDay = coupon.getExpiryDay();
+		}
+
+		// 缁撴潫鏃ユ湡
+		Date endTime = null;
+		try {
+			String endDay = DateUtil.plusDay(expiryDay, new Date());
+			SimpleDateFormat format = new SimpleDateFormat("yyyy-MM-dd");
+			endTime = format.parse(endDay);
+		} catch (ParseException e) {
+			e.printStackTrace();
+		}
+		// 鐘舵�佸垵濮嬪寲
+		userSystemCoupon.setState(UserSystemCoupon.STATE_CAN_USE);
+		userSystemCoupon.setUseTime(null);
+		// 鏈夋晥鏈熸椂闂撮噸鏂板畾涔�
+		userSystemCoupon.setStartTime(new Date());
+		userSystemCoupon.setEndTime(endTime);
+		
+		userSystemCoupon.setUpdateTime(new Date());
+		
+		userSystemCouponMapper.updateByPrimaryKey(userSystemCoupon);
+	}
 	
 	
 	

--
Gitblit v1.8.0