From 8f45af9d6cdae97f4f265d2f2a123d990cf1bb1d Mon Sep 17 00:00:00 2001 From: admin <weikou2014> Date: 星期一, 06 五月 2019 17:57:07 +0800 Subject: [PATCH] 设备未读消息处理,分类BUG修改 --- fanli/src/main/java/com/yeshi/fanli/controller/client/UserMsgController.java | 94 +++++++++++++++++++++++++++++++++++++++++----- 1 files changed, 83 insertions(+), 11 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 9171e8b..542d64b 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; @@ -58,6 +60,8 @@ 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; @@ -140,6 +144,12 @@ @Resource private DeviceActiveService deviceActiveService; + + @Resource + private MsgConfigService msgConfigService; + + @Resource + private MsgDeviceReadStateService msgDeviceReadStateService; // 娑堟伅鐨勭被鍨� final static String MSG_TYPE_ORDER = "order"; @@ -574,6 +584,50 @@ } } + 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); @@ -784,6 +838,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(); @@ -803,20 +867,28 @@ * @param out */ @RequestMapping(value = "readCommonMsg", method = RequestMethod.POST) - public void readCommonMsg(AcceptData acceptData, Long uid, PrintWriter out) { - if (uid == null) { - out.print(JsonUtil.loadFalseResult(1, "鐢ㄦ埛鏈櫥褰�")); + 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); + } - UserMsgUnReadNum num = userMsgReadStateService.getReadStateByUid(uid); - int totalNum = num.getTypeAccount() + num.getTypeInvite() + num.getTypeMoney() + num.getTypeOrder() - + num.getTypeScore() + num.getTypeSystem() + num.getTypeOther(); - if (totalNum == 0) { - out.print(JsonUtil.loadFalseResult(1, "娌℃湁鏈娑堟伅")); - return; - } else - userMsgReadStateService.setAllMsgRead(uid); + } 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_RECOMMEND, acceptData.getDevice(), + (acceptData.getPlatform().equalsIgnoreCase("android") ? 1 : 2)); + } out.print(JsonUtil.loadTrueResult("")); } -- Gitblit v1.8.0