From 26b5b1a6bbbb5ff64dc2ec73cf8b11f1aa61c1c5 Mon Sep 17 00:00:00 2001
From: yujian <yujian>
Date: 星期二, 14 五月 2019 11:03:25 +0800
Subject: [PATCH] Merge branch 'div_8'

---
 fanli/src/main/java/com/yeshi/fanli/controller/client/UserMsgController.java |  129 ++++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 126 insertions(+), 3 deletions(-)

diff --git a/fanli/src/main/java/com/yeshi/fanli/controller/client/UserMsgController.java b/fanli/src/main/java/com/yeshi/fanli/controller/client/UserMsgController.java
index a253fb5..2e9f90c 100644
--- a/fanli/src/main/java/com/yeshi/fanli/controller/client/UserMsgController.java
+++ b/fanli/src/main/java/com/yeshi/fanli/controller/client/UserMsgController.java
@@ -30,10 +30,12 @@
 import com.google.gson.JsonPrimitive;
 import com.google.gson.JsonSerializationContext;
 import com.google.gson.JsonSerializer;
+import com.yeshi.fanli.dto.msg.MsgCommonDTO;
 import com.yeshi.fanli.entity.accept.AcceptData;
 import com.yeshi.fanli.entity.bus.homemodule.Special;
 import com.yeshi.fanli.entity.bus.lable.QualityFactory;
 import com.yeshi.fanli.entity.bus.msg.MsgAccountDetail;
+import com.yeshi.fanli.entity.bus.msg.MsgDeviceReadState;
 import com.yeshi.fanli.entity.bus.msg.MsgInviteDetail;
 import com.yeshi.fanli.entity.bus.msg.MsgMoneyDetail;
 import com.yeshi.fanli.entity.bus.msg.MsgOrderDetail;
@@ -43,6 +45,8 @@
 import com.yeshi.fanli.entity.common.JumpDetailV2;
 import com.yeshi.fanli.entity.goods.CommonGoods;
 import com.yeshi.fanli.entity.goods.RecommendUserGoods;
+import com.yeshi.fanli.entity.push.DeviceActive;
+import com.yeshi.fanli.entity.push.PushGoods;
 import com.yeshi.fanli.entity.taobao.TaoBaoGoodsBrief;
 import com.yeshi.fanli.entity.taobao.TaoBaoSearchResult;
 import com.yeshi.fanli.exception.goods.CommonGoodsException;
@@ -56,12 +60,15 @@
 import com.yeshi.fanli.service.inter.homemodule.SpecialService;
 import com.yeshi.fanli.service.inter.lable.QualityFactoryService;
 import com.yeshi.fanli.service.inter.msg.MsgAccountDetailService;
+import com.yeshi.fanli.service.inter.msg.MsgConfigService;
+import com.yeshi.fanli.service.inter.msg.MsgDeviceReadStateService;
 import com.yeshi.fanli.service.inter.msg.MsgInviteDetailService;
 import com.yeshi.fanli.service.inter.msg.MsgMoneyDetailService;
 import com.yeshi.fanli.service.inter.msg.MsgOrderDetailService;
 import com.yeshi.fanli.service.inter.msg.MsgOtherDetailService;
 import com.yeshi.fanli.service.inter.msg.UserMsgReadStateService;
 import com.yeshi.fanli.service.inter.msg.UserSystemMsgService;
+import com.yeshi.fanli.service.inter.push.DeviceActiveService;
 import com.yeshi.fanli.service.inter.push.PushGoodsService;
 import com.yeshi.fanli.service.inter.user.UserCustomSettingsService;
 import com.yeshi.fanli.service.inter.user.UserInfoService;
@@ -134,6 +141,15 @@
 
 	@Resource
 	private PushGoodsService pushGoodsService;
+
+	@Resource
+	private DeviceActiveService deviceActiveService;
+
+	@Resource
+	private MsgConfigService msgConfigService;
+
+	@Resource
+	private MsgDeviceReadStateService msgDeviceReadStateService;
 
 	// 娑堟伅鐨勭被鍨�
 	final static String MSG_TYPE_ORDER = "order";
@@ -555,10 +571,74 @@
 				UserCommonMsgVO.TYPE_KEFU, "", false, null, null));
 
 		// 鎺ㄨ崘璁板綍
+		DeviceActive deviceActive = deviceActiveService.getDeviceByDeviceAndPlatform(acceptData.getDevice(),
+				acceptData.getDevice(), acceptData.getPlatform());
+		if (deviceActive != null) {
+			// 璁惧娉ㄥ唽鏃堕棿
+			Date createTime = deviceActive.getCreateTime();
+			List<PushGoods> list = pushGoodsService.listHistoryByPushTime(0, 1, uid, createTime);
+			if (list != null && list.size() > 0) {
+				MsgDeviceReadState state = msgDeviceReadStateService.getByDeviceAndPlatformAndType(
+						UserCommonMsgVO.TYPE_ZHUSHOU, acceptData.getDevice(),
+						acceptData.getPlatform().equalsIgnoreCase("android") ? 1 : 2);
+				boolean read=false;
+				if (state != null && state.getReadTime() != null
+						&&  list.get(0).getCreateTime().getTime() < state.getReadTime().getTime())
+					read = true;
+				
+				commonMsgList.add(new UserCommonMsgVO("http://img.flqapp.com/resource/msg/icon_recommend.png", "鎺ㄨ崘璁板綍",
+						list.get(0).getCreateTime(), UserCommonMsgVO.TYPE_RECOMMEND, list.get(0).getContent(), read,
+						jumpDetailV2Service.getByTypeCache("recommend_list"), null));
+			}
+		}
+
+		long currentTime = System.currentTimeMillis();
+		// 杩斿埄鍒稿皬鍔╂墜
+		MsgCommonDTO zhuShouMsg = msgConfigService.getZhuShouMsg();
+		if (zhuShouMsg != null) {
+
+			boolean read = false;
+
+			MsgDeviceReadState state = msgDeviceReadStateService.getByDeviceAndPlatformAndType(
+					UserCommonMsgVO.TYPE_ZHUSHOU, acceptData.getDevice(),
+					acceptData.getPlatform().equalsIgnoreCase("android") ? 1 : 2);
+			if (state != null && state.getReadTime() != null
+					&& zhuShouMsg.getUpdateTime().getTime() < state.getReadTime().getTime())
+				read = true;
+			// 鏌ヨ鏄惁宸茶
+
+			if ((zhuShouMsg.getStartTime() != null && currentTime < zhuShouMsg.getStartTime().getTime())
+					|| (zhuShouMsg.getEndTime() != null && currentTime > zhuShouMsg.getEndTime().getTime())) {
+				// 涓嶆樉绀�
+			} else
+				commonMsgList.add(new UserCommonMsgVO(zhuShouMsg.getIcon(), zhuShouMsg.getTitle(),
+						zhuShouMsg.getUpdateTime(), UserCommonMsgVO.TYPE_ZHUSHOU, zhuShouMsg.getContent(), read,
+						zhuShouMsg.getJumpDetail(), zhuShouMsg.getParams()));
+		}
+
+		// 瀹樺浠诲姟
+		if (uid != null) {
+			MsgCommonDTO guanXuanMsg = msgConfigService.getGuanXuanMsg();
+			if (guanXuanMsg != null) {
+				boolean read = false;
+				UserMsgUnReadNum num = userMsgReadStateService.getReadStateByUid(uid);
+				if (num != null && (num.getGuanXuanReadTime() != null
+						&& guanXuanMsg.getUpdateTime().getTime() < num.getGuanXuanReadTime().getTime()))
+					read = true;
+				// 鏌ヨ鏄惁宸茶
+				if ((guanXuanMsg.getStartTime() != null && currentTime < guanXuanMsg.getStartTime().getTime())
+						|| (guanXuanMsg.getEndTime() != null && currentTime > guanXuanMsg.getEndTime().getTime())) {
+					// 涓嶆樉绀�
+				} else
+					commonMsgList.add(new UserCommonMsgVO(guanXuanMsg.getIcon(), guanXuanMsg.getTitle(),
+							guanXuanMsg.getUpdateTime(), UserCommonMsgVO.TYPE_GUANXUAN, guanXuanMsg.getContent(), read,
+							guanXuanMsg.getJumpDetail(), guanXuanMsg.getParams()));
+			}
+		}
+
+		//
+
 		// list = pushGoodsService.listHistoryByPushTime(0, 1, uid, createTime);
-		commonMsgList.add(new UserCommonMsgVO("http://img.flqapp.com/resource/msg/icon_recommend.png", "鎺ㄨ崘璁板綍",
-				new Date(), UserCommonMsgVO.TYPE_RECOMMEND, "闃叉补闃叉按闃叉疆锛屾薄娓嶄竴鎶瑰嵆鍑�锛屼粠鑳冨埌蹇冪殑鏆栨剰", false,
-				jumpDetailV2Service.getByTypeCache("recommend_list"), null));
 
 		// 1銆佹椿鍔ㄥ尯鍩�
 		List<Special> listSpecial = specialService.listByPlaceKey("msg_activities");
@@ -766,6 +846,16 @@
 			return;
 		}
 
+		// 鍒濆鍖栬鍙栫姸鎬�
+		msgDeviceReadStateService.initReadState(acceptData.getDevice(),
+				"android".equalsIgnoreCase(acceptData.getPlatform()) ? 1 : 2, UserCommonMsgVO.TYPE_RECOMMEND);
+		msgDeviceReadStateService.initReadState(acceptData.getDevice(),
+				"android".equalsIgnoreCase(acceptData.getPlatform()) ? 1 : 2, UserCommonMsgVO.TYPE_ZHUSHOU);
+
+		// 璁剧疆璁惧娑堟伅鎵�鏈夊凡璇�
+		msgDeviceReadStateService.setAllMsgRead(acceptData.getDevice(),
+				"android".equalsIgnoreCase(acceptData.getPlatform()) ? 1 : 2);
+
 		UserMsgUnReadNum num = userMsgReadStateService.getReadStateByUid(uid);
 		int totalNum = num.getTypeAccount() + num.getTypeInvite() + num.getTypeMoney() + num.getTypeOrder()
 				+ num.getTypeScore() + num.getTypeSystem() + num.getTypeOther();
@@ -777,4 +867,37 @@
 		out.print(JsonUtil.loadTrueResult(""));
 	}
 
+	/**
+	 * 闃呰閫氱敤娑堟伅
+	 * 
+	 * @param acceptData
+	 * @param uid
+	 * @param out
+	 */
+	@RequestMapping(value = "readCommonMsg", method = RequestMethod.POST)
+	public void readCommonMsg(AcceptData acceptData, Long uid, String type, PrintWriter out) {
+		if (StringUtil.isNullOrEmpty(type)) {
+			out.print(JsonUtil.loadFalseResult(2, "璇蜂笂浼爐ype"));
+			return;
+		}
+		if (type.equalsIgnoreCase(UserCommonMsgVO.TYPE_GUANXUAN)) {
+			if (uid != null) {
+				UserMsgUnReadNum num = userMsgReadStateService.getReadStateByUid(uid);
+				UserMsgUnReadNum update = new UserMsgUnReadNum();
+				update.setId(num.getId());
+				update.setGuanXuanReadTime(new Date());
+				update.setUpdateTime(new Date());
+				userMsgReadStateService.updateSelective(update);
+			}
+
+		} else if (type.equalsIgnoreCase(UserCommonMsgVO.TYPE_RECOMMEND)) {
+			msgDeviceReadStateService.setDeviceMsgRead(UserCommonMsgVO.TYPE_RECOMMEND, acceptData.getDevice(),
+					(acceptData.getPlatform().equalsIgnoreCase("android") ? 1 : 2));
+		} else if (type.equalsIgnoreCase(UserCommonMsgVO.TYPE_ZHUSHOU)) {
+			msgDeviceReadStateService.setDeviceMsgRead(UserCommonMsgVO.TYPE_ZHUSHOU, acceptData.getDevice(),
+					(acceptData.getPlatform().equalsIgnoreCase("android") ? 1 : 2));
+		}
+		out.print(JsonUtil.loadTrueResult(""));
+	}
+
 }

--
Gitblit v1.8.0