From bf052072dbce8c74f1eeff6adb4af1c73e94ffce Mon Sep 17 00:00:00 2001 From: yujian <yujian@163.com> Date: 星期一, 18 五月 2020 14:52:57 +0800 Subject: [PATCH] iso版本改为81 --- fanli/src/main/java/com/yeshi/fanli/controller/client/v2/DynamicControllerV2.java | 480 +++++++++++++++++++++++++++++++++++++++++++++++++++++------ 1 files changed, 429 insertions(+), 51 deletions(-) diff --git a/fanli/src/main/java/com/yeshi/fanli/controller/client/v2/DynamicControllerV2.java b/fanli/src/main/java/com/yeshi/fanli/controller/client/v2/DynamicControllerV2.java index 2763715..4c4c8ce 100644 --- a/fanli/src/main/java/com/yeshi/fanli/controller/client/v2/DynamicControllerV2.java +++ b/fanli/src/main/java/com/yeshi/fanli/controller/client/v2/DynamicControllerV2.java @@ -12,6 +12,7 @@ import javax.annotation.Resource; +import org.apache.commons.beanutils.PropertyUtils; import org.springframework.core.task.TaskExecutor; import org.springframework.stereotype.Controller; import org.springframework.web.bind.annotation.RequestMapping; @@ -28,6 +29,8 @@ import com.yeshi.fanli.dto.jd.JDCouponInfo; import com.yeshi.fanli.entity.accept.AcceptData; import com.yeshi.fanli.entity.bus.clazz.GoodsClass; +import com.yeshi.fanli.entity.bus.homemodule.CommonShareInfo; +import com.yeshi.fanli.entity.bus.homemodule.CommonShareInfo.CommonShareInfoEnum; import com.yeshi.fanli.entity.bus.homemodule.Special; import com.yeshi.fanli.entity.bus.homemodule.SpecialLabel; import com.yeshi.fanli.entity.bus.homemodule.SwiperPicture; @@ -35,7 +38,6 @@ import com.yeshi.fanli.entity.bus.user.UserInfo; import com.yeshi.fanli.entity.common.JumpDetailV2; import com.yeshi.fanli.entity.dynamic.CommentInfo; -import com.yeshi.fanli.entity.dynamic.CommentInfo.CommentInfoEnum; import com.yeshi.fanli.entity.dynamic.DynamicInfo; import com.yeshi.fanli.entity.dynamic.GoodsEvaluate; import com.yeshi.fanli.entity.dynamic.GoodsEvaluate.EvaluateEnum; @@ -55,6 +57,7 @@ import com.yeshi.fanli.service.inter.dynamic.GoodsEvaluateService; import com.yeshi.fanli.service.inter.goods.ShareGoodsService; import com.yeshi.fanli.service.inter.goods.TaoBaoGoodsBriefService; +import com.yeshi.fanli.service.inter.homemodule.CommonShareInfoService; import com.yeshi.fanli.service.inter.homemodule.SpecialService; import com.yeshi.fanli.service.inter.homemodule.SwiperPictureService; import com.yeshi.fanli.service.inter.order.config.HongBaoManageService; @@ -75,6 +78,8 @@ import com.yeshi.fanli.util.taobao.TaoBaoUtil; import com.yeshi.fanli.vo.dynamic.ArticleVO; import com.yeshi.fanli.vo.goods.GoodsDetailVO; +import com.yeshi.fanli.vo.homemodule.BannerVO; +import com.yeshi.fanli.vo.homemodule.SpecialVO; import com.yeshi.fanli.vo.msg.ClientTextStyleVO; import net.sf.json.JSONArray; @@ -136,13 +141,17 @@ @Resource private ShareGoodsService shareGoodsService; - + @Resource private DailyCountMomentsService dailyCountMomentsService; + @Resource + private CommonShareInfoService commonShareInfoService; + + + @Resource(name = "taskExecutor") private TaskExecutor executor; - private final static long TYPE_REXIAO = 1;// 鐑攢 private final static long TYPE_TUIJIAN = 2;// 鎺ㄨ崘 @@ -258,7 +267,7 @@ list.add(map.get(TYPE_FAQUAN)); list.add(map.get(TYPE_HUODONG)); // list.add(map.get(TYPE_XUEYUAN)); - // list.add(map.get(TYPE_SUCAI)); + list.add(map.get(TYPE_SUCAI)); } else if (VersionUtil.greaterThan_2_0_6(acceptData.getPlatform(), acceptData.getVersion())) { // 2.0.6杩斿洖鐑攢+娲诲姩+鎺ㄨ崘+瀛﹂櫌+閭�璇� list.add(map.get(TYPE_REXIAO)); @@ -362,7 +371,7 @@ listKey.add("special_channel_pdd"); } - List<Special> list = specialService.listByPlaceKeyHasLabel((page - 1) * Constant.PAGE_SIZE, Constant.PAGE_SIZE, + List<SpecialVO> list = specialService.listByPlaceKeyHasLabel((page - 1) * Constant.PAGE_SIZE, Constant.PAGE_SIZE, listKey, platformCode, Integer.parseInt(acceptData.getVersion())); long time = System.currentTimeMillis(); @@ -371,31 +380,31 @@ for (int i = 0; i < list.size(); i++) { Special special = list.get(i); if (special.getState() == 1L) { - list.remove(i--); - } else { - if (special.getStartTime() != null && special.getEndTime() != null) + continue; + } + + // 鏄惁娲诲姩宸茶繃鏈� + if (special.getStartTime() != null && special.getEndTime() != null) { + if (time < special.getStartTime().getTime() || time > special.getEndTime().getTime()) { + continue; + } else { special.setTimeTask(true); - else - special.setTimeTask(false); - - if (special.isTimeTask()) { - if (time < special.getStartTime().getTime() || time > special.getEndTime().getTime()) { - list.remove(i--); - } else// 璁剧疆鍊掕鏃� - { - special.setCountDownTime((special.getEndTime().getTime() - time) / 1000); - } - } - - List<SpecialLabel> listLabels = special.getListLabels(); - if (listLabels != null && !listLabels.isEmpty()) { - List<ClientTextStyleVO> labels = new ArrayList<>(); - for (SpecialLabel specialLabel : listLabels) { - labels.add(new ClientTextStyleVO(specialLabel.getName(), specialLabel.getBgColor())); - } - special.setLabels(labels); + special.setCountDownTime((special.getEndTime().getTime() - time) / 1000); } } + + + + // 璁剧疆鏍囩 + List<SpecialLabel> listLabels = special.getListLabels(); + if (listLabels != null && !listLabels.isEmpty()) { + List<ClientTextStyleVO> labels = new ArrayList<>(); + for (SpecialLabel specialLabel : listLabels) { + labels.add(new ClientTextStyleVO(specialLabel.getName(), specialLabel.getBgColor())); + } + special.setLabels(labels); + } + } long count = specialService.countByPlaceKeyList(listKey, platformCode, @@ -523,18 +532,18 @@ JSONObject data = new JSONObject(); if (page == 1 && !search) { - List<SwiperPicture> banners = swiperPictureService.getByBannerCardAndVersion("article_banners", + List<BannerVO> banners = swiperPictureService.getByBannerCardAndVersion("article_banners", acceptData.getPlatform(), Integer.parseInt(acceptData.getVersion())); if (banners == null) banners = new ArrayList<>(); data.put("banners", gson.toJson(banners)); - List<Special> listSpecial = specialService.listByVersion(0, Integer.MAX_VALUE, "article_specials", + List<SpecialVO> listSpecial = specialService.listByVersion(0, Integer.MAX_VALUE, "article_specials", acceptData.getPlatform(), Integer.parseInt(acceptData.getVersion())); if (listSpecial == null) listSpecial = new ArrayList<>(); - for (Special special : listSpecial) { + for (SpecialVO special : listSpecial) { boolean needLogin = special.isJumpLogin(); JumpDetailV2 jumpDetail = special.getJumpDetail(); if (jumpDetail != null) { @@ -606,7 +615,6 @@ */ @RequestMapping(value = "getDynamicList", method = RequestMethod.POST) public void getDynamicListNew(AcceptData acceptData, Integer page, Long cid, String subId, PrintWriter out) { - try { int type = 1; if (cid == TYPE_FAQUAN) { @@ -614,11 +622,61 @@ } else if (cid == TYPE_SUCAI) { type = 2; } + List<GoodsEvaluate> listNew = new ArrayList<GoodsEvaluate>(); List<GoodsEvaluate> list = goodsEvaluateService.queryMaterialsCache((page - 1) * Constant.PAGE_SIZE, Constant.PAGE_SIZE, type); - if (list == null) { - list = new ArrayList<>(); + + if (!VersionUtil.greaterThan_2_1_1(acceptData.getPlatform(), acceptData.getVersion())) { + listNew.addAll(list); + } else if (list.size() > 0) { // 娲诲姩鍥剧墖涓嶅厑璁歌烦杞� + for (GoodsEvaluate goodsEvaluate : list) { + if (goodsEvaluate.getType() != EvaluateEnum.activity) { + listNew.add(goodsEvaluate); + continue; + } + + GoodsEvaluate evaluateNew = new GoodsEvaluate(); + try { + PropertyUtils.copyProperties(evaluateNew, goodsEvaluate); + } catch (Exception e) { + e.printStackTrace(); + continue; + } + // 璺宠浆杩囨浮椤� + String jumpLink = configService.get(ConfigKeyEnum.activityDetailLink.getKey()) + "?type=%s&id=%s"; + jumpLink = String.format(jumpLink, "circle", evaluateNew.getId()); + evaluateNew.setJumpLink(jumpLink); + + // 鍥剧墖鏁伴噺 + if (evaluateNew.getImgList() != null && evaluateNew.getImgList().size() > 0) { + int size = evaluateNew.getImgList().size(); + List<ImgInfo> listInfoNew = new ArrayList<ImgInfo>(); + + for (ImgInfo imgInfo : goodsEvaluate.getImgList()) { + if (imgInfo.getType() != ImgEnum.activity) { + listInfoNew.add(imgInfo); + continue; + } + ImgInfo infoNew = new ImgInfo(); + try { + PropertyUtils.copyProperties(infoNew, imgInfo); + } catch (Exception e) { + e.printStackTrace(); + continue; + } + infoNew.setType(ImgEnum.img); + // 鍥剧墖澶т簬涓�寮犳椂 鏄剧ず涔濆鏍煎浘 + if (size > 1) { + infoNew.setW(1); + infoNew.setH(1); + } + listInfoNew.add(infoNew); + } + evaluateNew.setImgList(listInfoNew); + } + listNew.add(evaluateNew); + } } GsonBuilder gsonBuilder = new GsonBuilder().excludeFieldsWithoutExposeAnnotation(); @@ -638,7 +696,7 @@ return new JsonPrimitive(""); } else { // 淇濈暀2浣嶅皬鏁� - return new JsonPrimitive(MoneyBigDecimalUtil.getWithNoZera(value)+""); + return new JsonPrimitive(MoneyBigDecimalUtil.getWithNoZera(value) + ""); } } }).registerTypeAdapter(Date.class, new JsonSerializer<Date>() { @@ -699,7 +757,7 @@ JSONArray jsonArray = new JSONArray(); - String listStr = gson.toJson(list); + String listStr = gson.toJson(listNew); JSONArray array = JSONArray.fromObject(listStr); for (int i = 0; i < array.size(); i++) { Object object = array.get(i); @@ -842,7 +900,8 @@ if (imgInfo.getGoodsVO() != null) if (imgInfo.getGoodsVO().getGoodsId().longValue() == goodsId.longValue() && imgInfo.getGoodsVO().getGoodsType() == goodsType.intValue()) { - String jumpLink = getJumpLink(imgInfo.getGoodsVO(), user, relationId, inviteCode, imgInfo.getUrl()); + String jumpLink = getJumpLink(imgInfo.getGoodsVO(), user, relationId, inviteCode, + imgInfo.getUrl()); if (!StringUtil.isNullOrEmpty(jumpLink)) { list.add(jumpLink); } @@ -852,7 +911,8 @@ } else if (type == 2 || type == 3) { for (ImgInfo imgInfo : imgs) { if (imgInfo.getGoodsVO() != null) { - String jumpLink = getJumpLink(imgInfo.getGoodsVO(), user, relationId, inviteCode, imgInfo.getUrl() ); + String jumpLink = getJumpLink(imgInfo.getGoodsVO(), user, relationId, inviteCode, + imgInfo.getUrl()); if (!StringUtil.isNullOrEmpty(jumpLink)) { list.add(jumpLink); } @@ -870,7 +930,7 @@ else if (imgInfo.getType() == ImgEnum.activity) if (!StringUtil.isNullOrEmpty(imgInfo.getActivityPic())) { list.add(imgInfo.getActivityPic()); - }else if(!StringUtil.isNullOrEmpty(imgInfo.getUrl())){ + } else if (!StringUtil.isNullOrEmpty(imgInfo.getUrl())) { list.add(imgInfo.getUrl()); } } @@ -885,7 +945,7 @@ if (type == 3) { shareCount++; goodsEvaluateService.addShareNum(id); - + executor.execute(new Runnable() { @Override public void run() { // 娣诲姞姣忔棩缁熻 @@ -909,7 +969,8 @@ } } - private String getJumpLink(GoodsDetailVO goodsVO, UserInfo user, String relationId, String inviteCode, String mainPic) { + private String getJumpLink(GoodsDetailVO goodsVO, UserInfo user, String relationId, String inviteCode, + String mainPic) { String jumpLink = null; if (goodsVO.getGoodsType() == Constant.SOURCE_TYPE_TAOBAO) { TaoBaoLink taoBaoLink = null; @@ -919,7 +980,7 @@ e.printStackTrace(); } jumpLink = ShareControllerV2.getERCodeContentNew( - configService.get(ConfigKeyEnum.quickShareTBCommentText.getKey()), taoBaoLink.getGoods(), + configService.get(ConfigKeyEnum.taobaoShareQrcodeText.getKey()), taoBaoLink.getGoods(), TaoBaoUtil.filterTaoToken(taoBaoLink.getTaoToken())); } else if (goodsVO.getGoodsType() == Constant.SOURCE_TYPE_JD) { JDGoods jdGoods = jdGoodsCacheUtil.getGoodsInfo(goodsVO.getGoodsId()); @@ -948,8 +1009,10 @@ return null; } + + /** - * 璇勮澶嶅埗 + * 璇勮澶嶅埗-H5 * * @param acceptData * @param id @@ -1006,8 +1069,7 @@ } String newText = text; // 闈為�氱敤鍒搁渶瑕侀獙璇� - if ((comment != null && comment.getTypeEnum() != CommentInfoEnum.currencyCoupon) - || goodsEvaluate.getType() == EvaluateEnum.activity) { + if (comment != null && (comment.getNeedSpin() == null || comment.getNeedSpin())) { try { newText = convertLinkManager.convertLinkFromText(text, uid, true); } catch (ConvertLinkExceptionException e) { @@ -1021,26 +1083,24 @@ return; } } - - + // 鏇挎崲浠锋牸 if (goodsEvaluate.getType() == EvaluateEnum.single) { GoodsDetailVO goods = goodsEvaluate.getGoods(); - newText = newText.replace("[鍘熶环]", MoneyBigDecimalUtil.getWithNoZera(goods.getZkPrice()) +""); + newText = newText.replace("[鍘熶环]", MoneyBigDecimalUtil.getWithNoZera(goods.getZkPrice()) + ""); if (!goods.isHasCoupon()) { newText = newText.replace("棰嗗埜鎶㈣喘", "鎶㈣喘"); newText = newText.replace("銆愬埜鍚庝环銆慬鍒稿悗浠穄鍏�", ""); } else { - newText = newText.replace("[鍒稿悗浠穄", MoneyBigDecimalUtil.getWithNoZera(goods.getCouponPrice())+""); + newText = newText.replace("[鍒稿悗浠穄", MoneyBigDecimalUtil.getWithNoZera(goods.getCouponPrice()) + ""); } newText.replace("\r\n\r\n", "\r\n").replace("\r\n\r\n", "\r\n").replace("\r\n\r\n", "\r\n"); } - - + JSONObject data = new JSONObject(); data.put("text", newText); out.print(JsonUtil.loadTrueResult(data)); - + executor.execute(new Runnable() { @Override public void run() { // 娣诲姞姣忔棩缁熻 @@ -1048,5 +1108,323 @@ } }); } + + + + + /** + * 璇勮澶嶅埗-涓撻 + * + * @param acceptData + * @param id + * @param out + */ + @RequestMapping(value = "copySpecialComment", method = RequestMethod.POST) + public void copySpecialComment(AcceptData acceptData, Long uid, Long id, PrintWriter out) { + if (uid == null || id == null) { + out.print(JsonUtil.loadFalseResult("鍙傛暟涓嶈兘涓虹┖")); + return; + } + CommonShareInfo shareInfo = commonShareInfoService.getByPidAndType(id, CommonShareInfoEnum.special.name()); + if (shareInfo == null || StringUtil.isNullOrEmpty(shareInfo.getComment())) { + out.print(JsonUtil.loadFalseResult("璇ュ唴瀹瑰凡涓嶅瓨鍦�")); + return; + } + + UserInfo user = userInfoService.getUserByIdWithMybatis(uid); + if (user == null) { + out.print(JsonUtil.loadFalseResult("鐢ㄦ埛鏈櫥褰�")); + return; + } + + if (user != null && user.getState() != UserInfo.STATE_NORMAL) { + out.print(JsonUtil.loadFalseResult(Constant.CODE_FORBIDDEN_USER, Constant.FORBIDDEN_USER_REASON_DESC)); + return; + } + + UserExtraTaoBaoInfo taoBaoInfo = userExtraTaoBaoInfoService.getByUid(uid); + String relationId = null; + if (taoBaoInfo != null && taoBaoInfo.getRelationId() != null && taoBaoInfo.getRelationValid() != null + && taoBaoInfo.getRelationValid() == true) + relationId = taoBaoInfo.getRelationId(); + + if (StringUtil.isNullOrEmpty(relationId)) { + out.print(JsonUtil.loadFalseResult(2, "娣樺疂鏈巿鏉冿紝璇峰墠寰�\"鎴戠殑\"缁戝畾娣樺疂璐﹀彿")); + return; + } + + String text = shareInfo.getComment(); + String newText = text; + if (shareInfo.getNeedSpin() != null && shareInfo.getNeedSpin()) { + try { + newText = convertLinkManager.convertLinkFromText(text, uid, true); + } catch (ConvertLinkExceptionException e) { + if (e.getCode() != ConvertLinkExceptionException.CODE_NONE) { + out.print(JsonUtil.loadFalseResult("璇勮鐢熸垚澶辫触")); + return; + } + } catch (Exception e) { + LogHelper.errorDetailInfo(e); + out.print(JsonUtil.loadFalseResult("璇勮鐢熸垚澶辫触")); + return; + } + } + + JSONObject data = new JSONObject(); + data.put("text", newText); + out.print(JsonUtil.loadTrueResult(data)); + } + + + + + + @RequestMapping(value = "getActivityDetail") + public void getActivityDetail(String callback, AcceptData acceptData, Long uid, String type, String id, PrintWriter out) { + if (uid == null || StringUtil.isNullOrEmpty(id) || StringUtil.isNullOrEmpty(type)) { + JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("鍙傛暟涓嶈兘涓虹┖")); + return; + } + + String title = ""; + String comment = ""; + String params = ""; + JumpDetailV2 jumpDetail = null; + List<String> imgs = new ArrayList<>(); + if ("circle".equalsIgnoreCase(type)) { // 鍙戝湀娲诲姩 + GoodsEvaluate evaluate = goodsEvaluateService.getById(id); + if (evaluate == null) { + JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("璇ユ椿鍔ㄥ凡涓嬫灦")); + return; + } + + title = evaluate.getTitle(); + List<CommentInfo> comments = evaluate.getComments(); + if (comments != null && comments.size() > 0) { + comment = comments.get(0).getContent(); + } + + String jumpLink = null; + if (!StringUtil.isNullOrEmpty(evaluate.getJumpLink())) { + jumpLink = evaluate.getJumpLink(); + } + + List<ImgInfo> imgList = evaluate.getImgList(); + if (imgList != null && imgList.size() > 0) { + for (ImgInfo imgInfo : imgList) { + if (!StringUtil.isNullOrEmpty(imgInfo.getUrl()) + && (imgInfo.getType() == ImgEnum.img || imgInfo.getType() == ImgEnum.activity)) { + imgs.add(imgInfo.getUrl()); + } + + if (imgInfo.getType() == ImgEnum.img || imgInfo.getType() == ImgEnum.activity) { + if (StringUtil.isNullOrEmpty(jumpLink) && !StringUtil.isNullOrEmpty(imgInfo.getActivityUrl())) { + jumpLink = imgInfo.getActivityUrl(); + } + } + } + } + + int platformCode = Constant.getPlatformCode(acceptData.getPlatform()); + jumpDetail = jumpDetailV2Service.getByTypeCache("web", platformCode, Integer.parseInt(acceptData.getVersion())); + JSONObject inner = new JSONObject(); + inner.put("url", jumpLink); + params = inner.toString(); + } else { + long pid = Long.parseLong(id); + if (CommonShareInfoEnum.special.name().equalsIgnoreCase(type)) { + Special special = specialService.selectByPrimaryKey(pid); + if (special == null) { + JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("璇ユ椿鍔ㄥ凡涓嬫灦")); + return; + } + + params = special.getParams(); + jumpDetail = special.getJumpDetail(); + if (!StringUtil.isNullOrEmpty(special.getPicture())) { + imgs.add(special.getPicture()); + } + } else if (CommonShareInfoEnum.banner.name().equalsIgnoreCase(type)) { + SwiperPicture swiper = swiperPictureService.selectByPrimaryKey(pid); + if (swiper == null) { + JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("璇ユ椿鍔ㄥ凡涓嬫灦")); + return; + } + params = swiper.getParams(); + jumpDetail = swiper.getJumpDetail(); + if (!StringUtil.isNullOrEmpty(swiper.getSrc())) { + imgs.add(swiper.getSrc()); + } + } + CommonShareInfo shareInfo = commonShareInfoService.getByPidAndType(pid, type); + if (shareInfo != null && !StringUtil.isNullOrEmpty(shareInfo.getComment())) { + comment = shareInfo.getComment(); + } + } + + if (!StringUtil.isNullOrEmpty(comment)) { // 鏇挎崲娣樺疂瀹樻柟娲诲姩 + List<String> activityIdList = convertLinkManager.getTaoBaoOfficialActivityId(comment); + for (String st : activityIdList) + comment = comment.replace(st, ""); + } + + JSONObject data = new JSONObject(); + data.put("title", title); + data.put("comment", comment); + data.put("params", params); + data.put("jumpDetail", jumpDetail); + data.put("imgs", imgs); + JsonUtil.printMode(out, callback, JsonUtil.loadTrueResult(data)); + } + + + + /** + * 璇勮澶嶅埗-涓撻 + * + * @param acceptData + * @param id + * @param out + */ + @RequestMapping(value = "copyShareComment") + public void copyShareComment(String callback, AcceptData acceptData, Long uid, String id, + String type, PrintWriter out) { + if (uid == null || StringUtil.isNullOrEmpty(id) || StringUtil.isNullOrEmpty(type)) { + JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("鍙傛暟涓嶈兘涓虹┖")); + return; + } + + if ("circle".equalsIgnoreCase(type)) { // 鍙戝湀娲诲姩 + copyActivityComment(callback, acceptData, uid, id, out); + return; + } + + long pid = Long.parseLong(id); + CommonShareInfo shareInfo = commonShareInfoService.getByPidAndType(pid, type); + if (shareInfo == null || StringUtil.isNullOrEmpty(shareInfo.getComment())) { + JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("璇ュ唴瀹瑰凡涓嶅瓨鍦�")); + return; + } + + UserInfo user = userInfoService.getUserByIdWithMybatis(uid); + if (user == null) { + JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("鐢ㄦ埛鏈櫥褰�")); + return; + } + + if (user != null && user.getState() != UserInfo.STATE_NORMAL) { + JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult(Constant.CODE_FORBIDDEN_USER, Constant.FORBIDDEN_USER_REASON_DESC)); + return; + } + + UserExtraTaoBaoInfo taoBaoInfo = userExtraTaoBaoInfoService.getByUid(uid); + String relationId = null; + if (taoBaoInfo != null && taoBaoInfo.getRelationId() != null && taoBaoInfo.getRelationValid() != null + && taoBaoInfo.getRelationValid() == true) + relationId = taoBaoInfo.getRelationId(); + + if (StringUtil.isNullOrEmpty(relationId)) { + JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult(2, "娣樺疂鏈巿鏉冿紝璇峰墠寰�\"鎴戠殑\"缁戝畾娣樺疂璐﹀彿")); + return; + } + + String text = shareInfo.getComment(); + String newText = text; + if (shareInfo.getNeedSpin() != null && shareInfo.getNeedSpin()) { + try { + newText = convertLinkManager.convertLinkFromText(text, uid, true); + } catch (ConvertLinkExceptionException e) { + if (e.getCode() != ConvertLinkExceptionException.CODE_NONE) { + JsonUtil.printMode(out, callback,JsonUtil.loadFalseResult("璇勮鐢熸垚澶辫触")); + return; + } + } catch (Exception e) { + LogHelper.errorDetailInfo(e); + JsonUtil.printMode(out, callback,JsonUtil.loadFalseResult("璇勮鐢熸垚澶辫触")); + return; + } + } + + JSONObject data = new JSONObject(); + data.put("text", newText); + JsonUtil.printMode(out, callback, JsonUtil.loadTrueResult(data)); + } + + /** + * 璇勮澶嶅埗 + * + * @param acceptData + * @param id + * @param out + */ + private void copyActivityComment(String callback, AcceptData acceptData, Long uid, String id, PrintWriter out) { + if (StringUtil.isNullOrEmpty(id)) { + JsonUtil.printMode(out, callback,JsonUtil.loadFalseResult("id涓嶈兘涓虹┖")); + return; + } + + GoodsEvaluate goodsEvaluate = goodsEvaluateService.getById(id); + if (goodsEvaluate == null) { + JsonUtil.printMode(out, callback,JsonUtil.loadFalseResult("璇ュ唴瀹瑰凡涓嶅瓨鍦�")); + return; + } + + UserInfo user = userInfoService.getUserByIdWithMybatis(uid); + if (user == null) { + JsonUtil.printMode(out, callback,JsonUtil.loadFalseResult("鐢ㄦ埛鏈櫥褰�")); + return; + } + + if (user != null && user.getState() != UserInfo.STATE_NORMAL) { + JsonUtil.printMode(out, callback,JsonUtil.loadFalseResult(Constant.CODE_FORBIDDEN_USER, Constant.FORBIDDEN_USER_REASON_DESC)); + return; + } + + UserExtraTaoBaoInfo taoBaoInfo = userExtraTaoBaoInfoService.getByUid(uid); + String relationId = null; + if (taoBaoInfo != null && taoBaoInfo.getRelationId() != null && taoBaoInfo.getRelationValid() != null + && taoBaoInfo.getRelationValid() == true) + relationId = taoBaoInfo.getRelationId(); + + if (StringUtil.isNullOrEmpty(relationId)) { + JsonUtil.printMode(out, callback,JsonUtil.loadFalseResult(2, "娣樺疂鏈巿鏉冿紝璇峰墠寰�\"鎴戠殑\"缁戝畾娣樺疂璐﹀彿")); + return; + } + + String text = ""; + CommentInfo comment = null; + List<CommentInfo> comments = goodsEvaluate.getComments(); + if (comments != null && comments.size() > 0) { + CommentInfo info = comments.get(0); + text = info.getContent(); + comment = info; + } + + String newText = text; // 闈為�氱敤鍒搁渶瑕侀獙璇� + if (comment != null && (comment.getNeedSpin() == null || comment.getNeedSpin())) { + try { + newText = convertLinkManager.convertLinkFromText(text, uid, true); + } catch (ConvertLinkExceptionException e) { + if (e.getCode() != ConvertLinkExceptionException.CODE_NONE) { + JsonUtil.printMode(out, callback,JsonUtil.loadFalseResult("璇勮鐢熸垚澶辫触")); + return; + } + } catch (Exception e) { + LogHelper.errorDetailInfo(e); + JsonUtil.printMode(out, callback,JsonUtil.loadFalseResult("璇勮鐢熸垚澶辫触")); + return; + } + } + JSONObject data = new JSONObject(); + data.put("text", newText); + JsonUtil.printMode(out, callback,JsonUtil.loadTrueResult(data)); + + executor.execute(new Runnable() { + @Override + public void run() { // 娣诲姞姣忔棩缁熻 + dailyCountMomentsService.addCopyComment(); + } + }); + } } -- Gitblit v1.8.0