From 4b1272a80a39ba3eb33f1fb7f9893a7e2b6084a9 Mon Sep 17 00:00:00 2001 From: admin <weikou2014> Date: 星期一, 14 一月 2019 13:19:51 +0800 Subject: [PATCH] 消息的显示层实体表示 --- fanli/src/main/java/com/yeshi/fanli/service/impl/user/UserActiveLogServiceImpl.java | 212 +++++++++++++++++++++++++++++++++++----------------- 1 files changed, 142 insertions(+), 70 deletions(-) diff --git a/fanli/src/main/java/com/yeshi/fanli/service/impl/user/UserActiveLogServiceImpl.java b/fanli/src/main/java/com/yeshi/fanli/service/impl/user/UserActiveLogServiceImpl.java index c411a14..76c1b5a 100644 --- a/fanli/src/main/java/com/yeshi/fanli/service/impl/user/UserActiveLogServiceImpl.java +++ b/fanli/src/main/java/com/yeshi/fanli/service/impl/user/UserActiveLogServiceImpl.java @@ -1,6 +1,6 @@ package com.yeshi.fanli.service.impl.user; -import java.text.DecimalFormat; +import java.math.BigDecimal; import java.text.SimpleDateFormat; import java.util.ArrayList; import java.util.Date; @@ -16,6 +16,7 @@ import com.yeshi.fanli.dao.mybatis.user.UserActiveLogMapper; import com.yeshi.fanli.entity.bus.user.UserActiveLog; import com.yeshi.fanli.service.inter.user.UserActiveLogService; +import com.yeshi.fanli.util.MoneyBigDecimalUtil; @Service public class UserActiveLogServiceImpl implements UserActiveLogService { @@ -40,31 +41,14 @@ @Override public UserActiveLog getUserLatestActiveInfo(Long uid) { - return userActiveLogMapper.selectLatestByUid(uid); } @Override - public List<Object> countSameDayByChannel(String channel, Integer type, String years, + public List<Map<String, Object>> countSameDayByChannel(String channel, Integer type, String years, String startTime, String endTime) throws Exception{ - List<Map<String, Object>> list = userActiveLogMapper.countSameDayByChannel(channel, type, years, - startTime, endTime); - - if (list == null || list.size() == 0) { - return null; - } - - switch (type){ - case 1: // 鎸夊ぉ澶勭悊 - return dayFactory(startTime, endTime, list); - case 2: // 鎸夋湀澶勭悊 - return monthFactory(list); - case 3: - return yearFactory(list); - default: - return null; - } + return userActiveLogMapper.countSameDayByChannel(channel, type, years, startTime, endTime); } @Override @@ -89,56 +73,135 @@ } } - @Override - public List<Object> getBuyProportion(String channel, Integer type, String years, - String startTime, String endTime) throws Exception{ + public List<Map<String, Object>> countOneWeekUserInfo(String channel, String startTime, String endTime, + Integer orderNumber) throws Exception { - List<Object> countList = countSameDayByChannel(channel, type, years, startTime, endTime); + // 鏃堕棿鍒楄〃 + List<String> dateList = new ArrayList<String>(); + // 缁撴灉鍒楄〃 + List<Map<String, Object>> resultList = new ArrayList<Map<String,Object>>(); - if (countList == null || countList.size() == 0) { - return null; - } + String middleDay = ""; + for (int i = 0; i < 100 ; i++) { + if (i == 0) { + middleDay = startTime; + } else { + middleDay = DateUtil.plusDay(i, startTime); + } + + dateList.add(middleDay); + + if (middleDay.equals(endTime)) { + break; // 鏃堕棿缁撴潫 + } + } - List<Object> countListBuy= countSameDayAndBuyGoodsByChannel(channel, type, years, startTime, endTime); - - List<Object> listObject = new ArrayList<Object>(); - - for (Object object: countList) { + for (String nowDate: dateList) { + // 鍔犲叆7澶� + String plusDay = DateUtil.plusDay(7, nowDate); - float rate = 0; + // 鎵ц鏌ヨ 骞惰繑鍥炵粨鏋� + Map<String, BigDecimal> map= userActiveLogMapper.countOneWeekUserInfo(channel, nowDate, plusDay, orderNumber); - Map<String, Object> mapObject = new HashMap<String, Object>(); + // 姣斾緥 + BigDecimal proportion = null; - Map<String, Object> map = (Map<String, Object>) object; - Object createDate = map.get("createDate"); - Object sameDayNum = map.get("sameDayNum"); - - long totle = Long.parseLong(sameDayNum.toString()); - if (totle > 0 && countListBuy != null && countListBuy.size() > 0) { - for (int j = 0; j < countListBuy.size(); j++) { - Map<String, Object> mapBuy = (Map<String, Object>) countListBuy.get(j); - Object createDate2 = mapBuy.get("createDate"); - if (createDate.toString().equals(createDate2.toString())) { - Object buyNum = mapBuy.get("sameDayNum"); - long totleBuy = Long.parseLong(buyNum.toString()); - rate = (float)totleBuy/totle; - break; - } + if (map != null) { + // 鏂板鐢ㄦ埛 + BigDecimal totalUser = map.get("totalUser"); + // 瀛樺湪璁㈠崟鐨勬柊澧炵敤鎴� + BigDecimal orderUser = map.get("orderUser"); + + try { + proportion = MoneyBigDecimalUtil.sub(orderUser, totalUser); + } catch (Exception e) { + e.printStackTrace(); } } - DecimalFormat df = new DecimalFormat("0.00");//鏍煎紡鍖栧皬鏁� - mapObject.put("sameDayNum", df.format(rate*100)); - mapObject.put("createDate", createDate); - listObject.add(mapObject); + if (proportion == null) { + proportion = new BigDecimal(0); + } + + Map<String, Object> result = new HashMap<String, Object>(); + result.put("showValue", MoneyBigDecimalUtil.mul(proportion, new BigDecimal(100))); + result.put("showDate", nowDate); + + resultList.add(result); } - return listObject; + return resultList; + + } + + + @Override + public List<Object> getBuyProportion(String channel, Integer type, String years, + String startTime, String endTime, Integer orderNum) throws Exception{ +// +// // 缁熻娓犻亾褰撴棩鏂板鐢ㄦ埛 +// List<Object> countList = countSameDayByChannel(channel, type, years, startTime, endTime); +// +// if (countList == null || countList.size() == 0) { +// return null; +// } +// +// // 缁熻娓犻亾褰撴棩鏂板鐢ㄦ埛瀛樺湪涓嬪崟鐨勭敤鎴锋暟閲� +// List<Object> countListBuy= null; +// if (orderNum <= 1){ +// countListBuy = countSameDayAndBuyGoodsByChannel(channel, type, years, startTime, endTime); +// } +// +// if (countListBuy == null){ +// new ArrayList<Object>(); +// } +// +// List<Object> listObject = new ArrayList<Object>(); +// +// for (Object object: countList) { +// +// float rate = 0; +// +// Map<String, Object> mapObject = new HashMap<String, Object>(); +// +// Map<String, Object> map = (Map<String, Object>) object; +// Object createDate = map.get("showDate"); +// Object sameDayNum = map.get("showValue"); +// +// long totle = Long.parseLong(sameDayNum.toString()); +// if (totle > 0 && countListBuy != null && countListBuy.size() > 0) { +// for (int j = 0; j < countListBuy.size(); j++) { +// Map<String, Object> mapBuy = (Map<String, Object>) countListBuy.get(j); +// Object createDate2 = mapBuy.get("showDate"); +// if (createDate.toString().equals(createDate2.toString())) { +// Object buyNum = mapBuy.get("showValue"); +// long totleBuy = Long.parseLong(buyNum.toString()); +// rate = (float)totleBuy/totle; +// break; +// } +// } +// } +// +// DecimalFormat df = new DecimalFormat("0.00");//鏍煎紡鍖栧皬鏁� +// mapObject.put("showValue", df.format(rate*100)); +// mapObject.put("showDate", createDate); +// listObject.add(mapObject); +// } +// +// return listObject; + return null; } - + /** + * 澶╂暟鏍煎紡 + * @param startTime + * @param endTime + * @param list + * @return + * @throws Exception + */ public List<Object> dayFactory(String startTime, String endTime, List<Map<String, Object>> list) throws Exception { List<Object> listObject = new ArrayList<Object>(); @@ -146,10 +209,10 @@ if (startTime.equals(endTime)) { Map<String, Object> map = list.get(0); - Object sameDayNum = map.get("sameDayNum"); + Object sameDayNum = map.get("showValue"); if (sameDayNum == null) { - map.put("sameDayNum", 0); + map.put("showValue", 0); } listObject.add(map); @@ -170,10 +233,10 @@ for (int j = 0; j < list.size(); j++) { Map<String, Object> map = list.get(j); - Object createDate = map.get("createDate"); + Object createDate = map.get("showDate"); String month = createDate.toString(); if (plusDay.equalsIgnoreCase(month)) { - sameDayNum = map.get("sameDayNum"); + sameDayNum = map.get("showValue"); break; } } @@ -181,13 +244,13 @@ if (sameDayNum == null) { sameDayNum = 0; } - mapObject.put("sameDayNum", sameDayNum); + mapObject.put("showValue", sameDayNum); SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd"); SimpleDateFormat sdf2 = new SimpleDateFormat("yyyy/MM/dd"); Date parseDate = sdf.parse(plusDay.toString()); - mapObject.put("createDate", sdf2.format(parseDate)); + mapObject.put("showDate", sdf2.format(parseDate)); listObject.add(mapObject); @@ -199,7 +262,11 @@ return listObject; } - + /** + * 鏈堜唤鏍煎紡 + * @param list + * @return + */ public List<Object> monthFactory(List<Map<String, Object>> list) { List<Object> listObject = new ArrayList<Object>(); @@ -209,10 +276,10 @@ Object sameDayNum = null; for (int j = 0; j < list.size(); j++) { Map<String, Object> map = list.get(j); - Object createDate = map.get("createDate"); + Object createDate = map.get("showDate"); String month = createDate.toString(); if ((i+"").equalsIgnoreCase(month) || i == Integer.parseInt(month)) { - sameDayNum = map.get("sameDayNum"); + sameDayNum = map.get("showValue"); break; } } @@ -220,29 +287,34 @@ if (sameDayNum == null) { sameDayNum = 0; } - mapObject.put("sameDayNum", sameDayNum); + mapObject.put("showValue", sameDayNum); - mapObject.put("createDate", i + "鏈�"); + mapObject.put("showDate", i + "鏈�"); listObject.add(mapObject); } return listObject; } + /** + * 骞翠唤鏍煎紡 + * @param list + * @return + */ public List<Object> yearFactory(List<Map<String, Object>> list) { List<Object> listObject = new ArrayList<Object>(); for (int i = 0; i < list.size(); i++) { Map<String, Object> map = list.get(i); - Object sameDayNum = map.get("sameDayNum"); - Object createDate = map.get("createDate"); + Object sameDayNum = map.get("showValue"); + Object createDate = map.get("showDate"); if (sameDayNum == null) { sameDayNum = 0; } - map.put("sameDayNum", sameDayNum); - map.put("createDate", createDate + "骞�"); + map.put("showValue", sameDayNum); + map.put("showDate", createDate + "骞�"); listObject.add(map); } -- Gitblit v1.8.0