package com.yeshi.fanli.service.impl.count;
|
|
import java.math.BigDecimal;
|
import java.text.SimpleDateFormat;
|
import java.util.ArrayList;
|
import java.util.Date;
|
import java.util.List;
|
|
import javax.annotation.Resource;
|
|
import org.springframework.stereotype.Service;
|
import org.yeshi.utils.DateUtil;
|
|
import com.yeshi.fanli.dao.mybatis.HongBaoV2CountMapper;
|
import com.yeshi.fanli.dao.mybatis.order.CommonOrderGoodsMapper;
|
import com.yeshi.fanli.dao.mybatis.order.CommonOrderMapper;
|
import com.yeshi.fanli.dao.mybatis.order.HongBaoOrderMapper;
|
import com.yeshi.fanli.dao.mybatis.order.OrderMapper;
|
import com.yeshi.fanli.dao.mybatis.taobao.TaoBaoOrderMapper;
|
import com.yeshi.fanli.dao.mybatis.taobao.TaoBaoWeiQuanOrderMapper;
|
import com.yeshi.fanli.dto.ChartTDO;
|
import com.yeshi.fanli.entity.bus.user.HongBaoV2;
|
import com.yeshi.fanli.service.inter.count.HongBaoV2CountService;
|
import com.yeshi.fanli.service.inter.order.CommonOrderService;
|
import com.yeshi.fanli.service.inter.user.UserInfoService;
|
import com.yeshi.fanli.vo.order.HongBaoV2VO;
|
|
@Service
|
public class HongBaoV2CountServiceImpl implements HongBaoV2CountService {
|
|
@Resource
|
private HongBaoV2CountMapper hongBaoV2CountMapper;
|
|
@Resource
|
private TaoBaoOrderMapper taoBaoOrderMapper;
|
|
@Resource
|
private CommonOrderMapper commonOrderMapper;
|
|
@Resource
|
private CommonOrderGoodsMapper commonOrderGoodsMapper;
|
|
@Resource
|
private HongBaoOrderMapper hongBaoOrderMapper;
|
|
@Resource
|
private OrderMapper orderMapper;
|
|
@Resource
|
private CommonOrderService commonOrderService;
|
|
@Resource
|
private UserInfoService userInfoService;
|
|
@Resource
|
private TaoBaoWeiQuanOrderMapper taoBaoWeiQuanOrderMapper;
|
|
public List<ChartTDO> dayFactory(String startTime, String endTime, List<ChartTDO> list)
|
throws Exception {
|
|
List<ChartTDO> listObject = new ArrayList<ChartTDO>();
|
|
if (startTime.equals(endTime)) {
|
ChartTDO chartTDO = list.get(0);
|
String total = chartTDO.getShowValue();
|
if (total == null) {
|
chartTDO.setShowValue("0");
|
}
|
listObject.add(chartTDO);
|
return listObject;
|
}
|
|
String plusDay = "";
|
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
|
SimpleDateFormat sdf2 = new SimpleDateFormat("yyyy/MM/dd");
|
for (int i = 0; i < 1000; i++) {
|
if (i == 0) {
|
plusDay = startTime;
|
} else {
|
plusDay = DateUtil.plusDay(i, startTime);
|
}
|
|
String total = null;
|
ChartTDO chart = new ChartTDO();
|
for (int j = 0; j < list.size(); j++) {
|
ChartTDO chartTDO = list.get(j);
|
String createDate = chartTDO.getShowDate();
|
String month = createDate.toString();
|
if (plusDay.equalsIgnoreCase(month)) {
|
total = chartTDO.getShowValue();
|
break;
|
}
|
}
|
|
if (total == null) {
|
total = "0";
|
}
|
chart.setShowValue(total);
|
Date parseDate = sdf.parse(plusDay.toString());
|
chart.setShowDate(sdf2.format(parseDate));
|
listObject.add(chart);
|
|
if (plusDay.equals(endTime)) {
|
break; // 时间结束
|
}
|
}
|
|
return listObject;
|
}
|
|
public List<ChartTDO> monthFactory(List<ChartTDO> list) {
|
List<ChartTDO> listObject = new ArrayList<ChartTDO>();
|
// 12 个月处理
|
for (int i = 1; i <= 12; i++) {
|
|
String total = null;
|
for (int j = 0; j < list.size(); j++) {
|
ChartTDO chartTDO = list.get(j);
|
String createDate = chartTDO.getShowDate();
|
String month = createDate.toString();
|
if ((i + "").equalsIgnoreCase(month) || i == Integer.parseInt(month)) {
|
total = chartTDO.getShowValue();
|
break;
|
}
|
}
|
|
if (total == null) {
|
total = "0";
|
}
|
|
ChartTDO mapObject = new ChartTDO();
|
mapObject.setShowValue(total);
|
mapObject.setShowDate(i + "月");
|
listObject.add(mapObject);
|
}
|
return listObject;
|
}
|
|
public List<ChartTDO> yearFactory(List<ChartTDO> list) {
|
List<ChartTDO> listObject = new ArrayList<ChartTDO>();
|
for (int i = 0; i < list.size(); i++) {
|
ChartTDO chartTDO = list.get(i);
|
String showValue = chartTDO.getShowValue();
|
if (showValue == null) {
|
showValue = "0";
|
}
|
chartTDO.setShowValue(showValue);
|
listObject.add(chartTDO);
|
}
|
return listObject;
|
}
|
|
@Override
|
public List<ChartTDO> countHongBaoMoney(String channel, Integer dateType, Integer state, String year,
|
String startTime, String endTime) throws Exception {
|
return hongBaoV2CountMapper.countHongBaoMoney(channel, dateType, state, year, startTime, endTime);
|
}
|
|
@Override
|
public List<ChartTDO> countHongBaoNum(String channel, Integer dateType, Integer state, String year,
|
String startTime, String endTime) throws Exception {
|
return hongBaoV2CountMapper.countHongBaoNum(channel, dateType, state, year, startTime, endTime);
|
}
|
|
@Override
|
public List<ChartTDO> countHongBaoType(Integer dateType, Integer type, String year, String startTime,
|
String endTime) throws Exception {
|
return hongBaoV2CountMapper.countHongBaoType(dateType, type, year, startTime, endTime);
|
}
|
|
@Override
|
public List<ChartTDO> getProportionByType(Integer dateType, Integer type, String year, String startTime,
|
String endTime) throws Exception {
|
|
List<ChartTDO> result_list = null;
|
|
List<ChartTDO> listTotal = hongBaoV2CountMapper.countHongBaoTotalNum(dateType, year, startTime,
|
endTime);
|
if (listTotal == null || listTotal.size() == 0) {
|
return result_list;
|
}
|
|
List<ChartTDO> type_list = hongBaoV2CountMapper.countHongBaoType(dateType, type, year, startTime,
|
endTime);
|
|
if (type_list == null || type_list.size() == 0) {
|
return null;
|
}
|
|
switch (dateType) {
|
case 1: // 按天处理
|
result_list = dayFactory(startTime, endTime, type_list);
|
break;
|
case 2: // 按月处理
|
result_list = monthFactory(type_list);
|
break;
|
case 3:
|
result_list = yearFactory(type_list);
|
break;
|
default:
|
break;
|
}
|
|
for (int i = 0; i < result_list.size(); i++) {
|
float proportion = 0;
|
ChartTDO chartTDO = result_list.get(i);
|
String showDate = chartTDO.getShowDate();
|
for (int j = 0; j < listTotal.size(); j++) {
|
ChartTDO innerChart = result_list.get(j);
|
String innerDate = innerChart.getShowDate();
|
if (innerDate != null && innerDate.equals(showDate)) {
|
String innerValue = innerChart.getShowValue();
|
long innerData = Long.parseLong(innerValue);
|
String showValue = chartTDO.getShowValue();
|
long showData = Long.parseLong(showValue);
|
if (showData > 0) {
|
proportion = innerData / showData;
|
}
|
break; // 结束内部循环
|
}
|
}
|
chartTDO.setShowValue(proportion+"");
|
}
|
return result_list;
|
}
|
|
@Override
|
public BigDecimal countMoneyByUidAndState(Long uid, Integer state) {
|
return hongBaoV2CountMapper.countMoneyByUidAndState(uid, state);
|
}
|
|
@Override
|
public Integer countNumberByUidAndState(Long uid, Integer state) {
|
return hongBaoV2CountMapper.countNumberByUidAndState(uid, state);
|
}
|
|
@Override
|
public int getTotalTiChengCount(Long uid) {
|
return hongBaoV2CountMapper.getTotalTiChengCount(uid);
|
}
|
|
@Override
|
public long getHongBaoCount(Long uid,Integer type) {
|
return hongBaoV2CountMapper.getHongBaoCount(uid, type);
|
}
|
|
@Override
|
public long countValidNumberByUid(Long uid, Integer dateType) {
|
return hongBaoV2CountMapper.countValidNumberByUid(uid, dateType);
|
}
|
|
@Override
|
public BigDecimal countWillGetMoneyByUid(Long uid) {
|
return hongBaoV2CountMapper.countWillGetMoneyByUid(uid);
|
}
|
|
@Override
|
public Date getLastHongBaoTime(Long uid) {
|
return hongBaoV2CountMapper.getLastHongBaoTime(uid);
|
}
|
|
@Override
|
public List<ChartTDO> count24HOderByChannel(String channel, Integer type, String years, String startTime,
|
String endTime) throws Exception {
|
return hongBaoV2CountMapper.count24HOderByChannel(channel, type, years, startTime, endTime);
|
}
|
|
@Override
|
public List<HongBaoV2VO> listShareAndInviteMoney(long start, int count, String date) {
|
return hongBaoV2CountMapper.listShareAndInviteMoney(start, count, date);
|
}
|
|
@Override
|
public Integer countNumberByUid(Long uid) {
|
long count = hongBaoV2CountMapper.countNumberByUid(uid);
|
return (int) count;
|
}
|
|
@Override
|
public BigDecimal countRebateCouponMoney() {
|
return hongBaoV2CountMapper.countRebateCouponMoney();
|
}
|
|
@Override
|
public long countRebateOrder(Long uid) {
|
return hongBaoV2CountMapper.countRebateOrder(uid);
|
}
|
|
|
@Override
|
public long countShareOrInviteOrder(Long uid) {
|
return hongBaoV2CountMapper.countShareOrInviteOrder(uid);
|
}
|
|
|
@Override
|
public BigDecimal sumAlreadyGetMoneyByUid(Long uid, List<Integer> typeList, Date minGetTime, Date maxGetTime) {
|
return hongBaoV2CountMapper.sumAlreadyGetMoneyByUid(uid, typeList, minGetTime, maxGetTime);
|
}
|
|
@Override
|
public long countAlreadyGetMoneyByUid(Long uid, List<Integer> typeList, Date minGetTime, Date maxGetTime) {
|
return hongBaoV2CountMapper.countAlreadyGetMoneyByUid(uid, typeList, minGetTime, maxGetTime);
|
}
|
|
@Override
|
public BigDecimal getOrderRewardByTeamUid(Long uid, Long teamUid, Date endTime) {
|
return hongBaoV2CountMapper.getOrderRewardByTeamUid(uid, teamUid, endTime);
|
}
|
|
@Override
|
public BigDecimal getOrderRewardByTeamUidTheMonth(Long uid, Long teamUid) {
|
return hongBaoV2CountMapper.getOrderRewardByTeamUidTheMonth(uid, teamUid);
|
}
|
|
@Override
|
public BigDecimal getRewardMoneyBySelf(Long uid) {
|
List<Integer> list = new ArrayList<Integer>();
|
list.add(HongBaoV2.TYPE_ZIGOU);
|
return hongBaoV2CountMapper.getRewardMoneyByUid(uid, list);
|
}
|
|
@Override
|
public BigDecimal getRewardMoneyByShare(Long uid) {
|
List<Integer> list = new ArrayList<Integer>();
|
list.add(HongBaoV2.TYPE_SHARE_GOODS);
|
return hongBaoV2CountMapper.getRewardMoneyByUid(uid, list);
|
}
|
|
|
@Override
|
public BigDecimal getRewardMoneyByInvite(Long uid) {
|
List<Integer> list = new ArrayList<Integer>();
|
list.add(HongBaoV2.TYPE_YIJI);
|
list.add(HongBaoV2.TYPE_ERJI);
|
list.add(HongBaoV2.TYPE_SHARE_YIJI);
|
list.add(HongBaoV2.TYPE_SHARE_ERJI);
|
return hongBaoV2CountMapper.getRewardMoneyByUid(uid, list);
|
}
|
|
@Override
|
public long countValidOrderTeamUserByUid(Long uid, Long time, BigDecimal payment) {
|
return hongBaoV2CountMapper.countValidOrderTeamUserByUid(uid, time, payment);
|
}
|
|
@Override
|
public BigDecimal getRewardMoneyByDate(Long uid, Integer dateType, Integer hbType, Integer orderState) {
|
return hongBaoV2CountMapper.getRewardMoneyByDate(uid, dateType, hbType, orderState);
|
}
|
|
}
|