From 0d22020f783fca5c96935512154fd1f91661d434 Mon Sep 17 00:00:00 2001
From: yj <Administrator@192>
Date: 星期一, 09 三月 2020 16:44:24 +0800
Subject: [PATCH] 取消邀请码发布 邀请码激活
---
fanli/src/main/java/com/yeshi/fanli/service/impl/user/UserActiveLogServiceImpl.java | 352 +++++++++++-----------------------------------------------
1 files changed, 68 insertions(+), 284 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 dad8a40..108380c 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,13 +1,8 @@
package com.yeshi.fanli.service.impl.user;
-import java.math.BigDecimal;
-import java.text.DecimalFormat;
-import java.text.SimpleDateFormat;
-import java.util.ArrayList;
+import java.text.ParseException;
import java.util.Date;
-import java.util.HashMap;
import java.util.List;
-import java.util.Map;
import javax.annotation.Resource;
@@ -15,15 +10,24 @@
import org.yeshi.utils.DateUtil;
import com.yeshi.fanli.dao.mybatis.user.UserActiveLogMapper;
+import com.yeshi.fanli.dao.user.UserActiveNumHistoryDao;
import com.yeshi.fanli.entity.bus.user.UserActiveLog;
+import com.yeshi.fanli.entity.bus.user.UserActiveNumHistory;
import com.yeshi.fanli.service.inter.user.UserActiveLogService;
-import com.yeshi.fanli.util.MoneyBigDecimalUtil;
+import com.yeshi.fanli.service.inter.user.UserInfoExtraService;
+import com.yeshi.fanli.util.TimeUtil;
@Service
public class UserActiveLogServiceImpl implements UserActiveLogService {
@Resource
private UserActiveLogMapper userActiveLogMapper;
+
+ @Resource
+ private UserActiveNumHistoryDao userActiveNumHistoryDao;
+
+ @Resource
+ private UserInfoExtraService userInfoExtraService;
@Override
public void addUserActiveLog(UserActiveLog userActiveLog) {
@@ -37,306 +41,86 @@
userActiveLog.setCreateTime(new Date());
userActiveLog.setUpdateTime(new Date());
userActiveLogMapper.insertSelective(userActiveLog);
+ // 鏇存柊鏈�鏂版椿璺冩椂闂�
+ userInfoExtraService.updateActiveTime(userActiveLog.getUid() , new Date());
+ } else if (latestLog != null) {
+ // 濡傛灉璁惧 锛岀増鏈紝娓犻亾鏈夊彉鍖栧垯闇�瑕佹洿鏀�
+ String oldIdentify = latestLog.getDevice() + "#" + latestLog.getVersionCode() + "#"
+ + latestLog.getChannel();
+ String newIdentify = userActiveLog.getDevice() + "#" + userActiveLog.getVersionCode() + "#"
+ + userActiveLog.getChannel();
+ if (!oldIdentify.equalsIgnoreCase(newIdentify)) {// 璁惧淇℃伅鍙樺寲瑕佽褰曚俊鎭�
+ userActiveLog.setCreateTime(new Date());
+ userActiveLog.setUpdateTime(new Date());
+ userActiveLogMapper.insertSelective(userActiveLog);
+ // 鏇存柊鏈�鏂版椿璺冩椂闂�
+ userInfoExtraService.updateActiveTime(userActiveLog.getUid() , new Date());
+ }
}
}
@Override
public UserActiveLog getUserLatestActiveInfo(Long uid) {
-
return userActiveLogMapper.selectLatestByUid(uid);
}
-
@Override
- public List<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;
- }
- }
-
- @Override
- public List<Object> countSameDayAndBuyGoodsByChannel(String channel, Integer type, String years,
- String startTime, String endTime) throws Exception {
- List<Map<String, Object>> list = userActiveLogMapper.countSameDayAndBuyGoodsByChannel(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;
- }
- }
-
- @Override
- public List<Map<String, Object>> countOneWeekUserInfo(String channel, String startTime, String endTime,
- Integer orderNumber) throws Exception {
-
- // 鏃堕棿鍒楄〃
- List<String> dateList = new ArrayList<String>();
- // 缁撴灉鍒楄〃
- List<Map<String, Object>> resultList = new ArrayList<Map<String,Object>>();
-
- 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; // 鏃堕棿缁撴潫
- }
- }
-
- for (String nowDate: dateList) {
- // 鍔犲叆7澶�
- String plusDay = DateUtil.plusDay(7, nowDate);
-
- // 鎵ц鏌ヨ 骞惰繑鍥炵粨鏋�
- Map<String, BigDecimal> map= userActiveLogMapper.countOneWeekUserInfo(channel, nowDate, plusDay, orderNumber);
-
- // 姣斾緥
- BigDecimal proportion = null;
-
- if (map != null) {
- // 鏂板鐢ㄦ埛
- BigDecimal totalUser = map.get("totalUser");
- // 瀛樺湪璁㈠崟鐨勬柊澧炵敤鎴�
- BigDecimal orderUser = map.get("orderUser");
-
- try {
- proportion = MoneyBigDecimalUtil.sub(orderUser, totalUser);
- } catch (Exception e) {
- e.printStackTrace();
- }
- }
-
- 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 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;
+ public UserActiveLog getFirstActiveInfo(Long uid) {
+ return userActiveLogMapper.selectFirstActiveInfo(uid);
}
-
- /**
- * 澶╂暟鏍煎紡
- * @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>();
-
- if (startTime.equals(endTime)) {
-
- Map<String, Object> map = list.get(0);
- Object sameDayNum = map.get("showValue");
-
- if (sameDayNum == null) {
- map.put("showValue", 0);
- }
- listObject.add(map);
-
- return listObject;
- }
+ @Override
+ public List<UserActiveNumHistory> query(Date startTime, Date endTime){
+ // 閲嶆柊鏌ヨ缁熻浠婃棩浠ュ強绌虹己
+ initUserActiveNumCount();
+ return userActiveNumHistoryDao.query(startTime, endTime);
+ }
+
+
+ // 鍒濆鍖栫粺璁�
+ private void initUserActiveNumCount() {
+ UserActiveNumHistory history = userActiveNumHistoryDao.getMaxDate();
+ Date lastDay = null;
+ if (history != null && history.getDay() != null)
+ lastDay = history.getDay();
- String plusDay = "";
- for (int i = 0; i < 1000 ; i++) {
- if (i == 0) {
- plusDay = startTime;
- } else {
- plusDay = DateUtil.plusDay(i, startTime);
- }
+ Date today = new Date();
+ try {
+ if (lastDay == null)
+ lastDay = TimeUtil.parse("2018-09-01");
+ int betweenDays = DateUtil.daysBetween2(lastDay, today);
- Map<String, Object> mapObject = new HashMap<String, Object>();
- Object sameDayNum = null;
-
- for (int j = 0; j < list.size(); j++) {
- Map<String, Object> map = list.get(j);
- Object createDate = map.get("showDate");
- String month = createDate.toString();
- if (plusDay.equalsIgnoreCase(month)) {
- sameDayNum = map.get("showValue");
- break;
+ // 缁熻浠婃棩涔嬪墠鐨�
+ if (betweenDays > 0) {
+ for (int i = 1; i <= betweenDays; i++ ) {
+ addUserActiveNumHistory(DateUtil.plusDay(i, lastDay));
}
}
-
- if (sameDayNum == null) {
- sameDayNum = 0;
- }
- 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("showDate", sdf2.format(parseDate));
-
- listObject.add(mapObject);
-
- if (plusDay.equals(endTime)) {
- break; // 鏃堕棿缁撴潫
- }
+ // 閲嶆柊缁熻浠婃棩
+ addUserActiveNumHistory(TimeUtil.getGernalTime(today.getTime()));
+ } catch (Exception e) {
+ //
}
-
- return listObject;
}
- /**
- * 鏈堜唤鏍煎紡
- * @param list
- * @return
+ /*
+ * 缁熻褰撳ぉ娲昏穬鐢ㄦ埛涓湁澶氬皯涓敤鎴锋槸90澶╁墠鎵嶆椿璺冭繃锛屾湡闂翠粠鏈椿璺冪殑鐢ㄦ埛鏁伴噺銆�
*/
- public List<Object> monthFactory(List<Map<String, Object>> list) {
+ @Override
+ public void addUserActiveNumHistory(String date){
+ int num = userActiveLogMapper.countActiveNumByDate(date);
- List<Object> listObject = new ArrayList<Object>();
- // 12 涓湀澶勭悊
- for (int i = 1; i <= 12; i++) {
- Map<String, Object> mapObject = new HashMap<String, Object>();
- Object sameDayNum = null;
- for (int j = 0; j < list.size(); j++) {
- Map<String, Object> map = list.get(j);
- Object createDate = map.get("showDate");
- String month = createDate.toString();
- if ((i+"").equalsIgnoreCase(month) || i == Integer.parseInt(month)) {
- sameDayNum = map.get("showValue");
- break;
- }
- }
-
- if (sameDayNum == null) {
- sameDayNum = 0;
- }
- mapObject.put("showValue", sameDayNum);
-
- mapObject.put("showDate", i + "鏈�");
-
- listObject.add(mapObject);
+ UserActiveNumHistory history = new UserActiveNumHistory();
+ history.setId(date);
+ history.setNum(num);
+ try {
+ history.setDay(TimeUtil.parse(date));
+ } catch (ParseException e) {
+ e.printStackTrace();
}
- return listObject;
+ userActiveNumHistoryDao.save(history);
}
- /**
- * 骞翠唤鏍煎紡
- * @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("showValue");
- Object createDate = map.get("showDate");
-
- if (sameDayNum == null) {
- sameDayNum = 0;
- }
- map.put("showValue", sameDayNum);
- map.put("showDate", createDate + "骞�");
-
- listObject.add(map);
- }
-
- return listObject;
- }
}
--
Gitblit v1.8.0