AccountServiceImpl.java 19.4 KB
Newer Older
licc's avatar
licc committed
1 2
package cn.wisenergy.service.app.impl;

licc's avatar
licc committed
3
import cn.wisenergy.common.utils.DateUtil;
licc's avatar
licc committed
4
import cn.wisenergy.common.utils.R;
licc's avatar
licc committed
5
import cn.wisenergy.mapper.*;
licc's avatar
licc committed
6
import cn.wisenergy.model.app.*;
licc's avatar
licc committed
7

licc's avatar
licc committed
8
import cn.wisenergy.model.enums.MemberPercentEnum;
licc's avatar
licc committed
9
import cn.wisenergy.model.enums.RebateStatusEnum;
licc's avatar
licc committed
10
import cn.wisenergy.model.enums.TradeRecordEnum;
11
import cn.wisenergy.model.enums.TradeStatusEnum;
licc's avatar
licc committed
12
import cn.wisenergy.model.vo.TeamPerformanceSortVo;
licc's avatar
licc committed
13
import cn.wisenergy.service.Manager.PublicManager;
licc's avatar
licc committed
14
import cn.wisenergy.service.app.AccountService;
licc's avatar
licc committed
15
import cn.wisenergy.service.Manager.AccountManager;
licc's avatar
licc committed
16 17 18
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import lombok.extern.slf4j.Slf4j;

licc's avatar
licc committed
19
import org.apache.commons.lang3.StringUtils;
licc's avatar
licc committed
20
import org.springframework.beans.factory.annotation.Autowired;
licc's avatar
licc committed
21
import org.springframework.stereotype.Service;
licc's avatar
licc committed
22
import org.springframework.util.CollectionUtils;
licc's avatar
licc committed
23

licc's avatar
licc committed
24
import java.math.BigDecimal;
licc's avatar
licc committed
25
import java.util.*;
licc's avatar
licc committed
26 27


licc's avatar
licc committed
28 29 30
/**
 * @author 86187
 */
licc's avatar
licc committed
31 32
@Slf4j
@Service
licc's avatar
licc committed
33
public class AccountServiceImpl extends ServiceImpl<AccountMapper, AccountInfo> implements AccountService {
licc's avatar
licc committed
34

licc's avatar
licc committed
35 36
    @Autowired
    private UsersMapper usersMapper;
licc's avatar
licc committed
37

licc's avatar
licc committed
38 39 40 41
    @Autowired
    private AccountMapper accountMapper;

    @Autowired
licc's avatar
licc committed
42
    private MemberPercentMapper memberPercentMapper;
licc's avatar
licc committed
43 44 45

    @Autowired
    private AccountManager accountManager;
licc's avatar
licc committed
46

licc's avatar
licc committed
47 48 49
    @Autowired
    private PublicManager publicManager;

licc's avatar
licc committed
50 51 52
    @Autowired
    private TradeRecordMapper tradeRecordMapper;

licc's avatar
licc committed
53 54 55
    @Autowired
    private TeamPerformanceMapper teamPerformanceMapper;

licc's avatar
licc committed
56 57 58
    @Autowired
    private ProgressPrizeMapper progressPrizeMapper;

licc's avatar
licc committed
59 60 61
    @Autowired
    private LastAccountMapper lastAccountMapper;

licc's avatar
licc committed
62 63 64
    @Autowired
    private OrderMapper orderMapper;

licc's avatar
licc committed
65
    private static final String PATTERN = "yyyy-MM";
licc's avatar
licc committed
66

licc's avatar
licc committed
67 68
    private static final Integer TWENTY = 20;

licc's avatar
licc committed
69
    @Override
licc's avatar
licc committed
70 71 72 73
    public R<Boolean> orderRebate() {

        //获取返佣订单
        List<OrderInfo> list=orderMapper.getListBySuccessTime(new Date());
licc's avatar
licc committed
74 75 76 77 78
        log.info("shop-mall[]AccountServiceImpl[]orderRebate[]input.param.list:{}", list.size());
        if (CollectionUtils.isEmpty(list)) {
            return R.ok(0, true);
        }

licc's avatar
licc committed
79
        //1、遍历订单,订单状态是未返佣,完成时间小于当前时间 --返佣
licc's avatar
licc committed
80 81 82
        for (OrderInfo orderInfo : list) {
            long successTime = orderInfo.getSuccessTime().getTime();
            long time = System.currentTimeMillis();
licc's avatar
licc committed
83
            if (RebateStatusEnum.NO_REBATE.getCode().equals(orderInfo.getRebateStatus()) && successTime <= time) {
licc's avatar
licc committed
84
                //获取用户信息
licc's avatar
licc committed
85
                User user = usersMapper.getByUserId(orderInfo.getBuyerId());
licc's avatar
licc committed
86 87 88 89 90 91 92 93 94 95 96
                if (null == user) {
                    continue;
                }

                //获取账户信息
                AccountInfo accountInfo = accountMapper.getByUserId(user.getUserId());
                if (null == accountInfo) {
                    continue;
                }

                //获取返佣比例
licc's avatar
licc committed
97
                MemberPercent memberpercent = memberPercentMapper.getByLevelAndType(user.getUserLevel(), MemberPercentEnum.REBATE.getCode());
licc's avatar
licc committed
98
                if (null == memberpercent) {
licc's avatar
licc committed
99 100 101 102
                    continue;
                }

                //修改订单状态为已返佣,账户可用金额增加
licc's avatar
licc committed
103
                accountManager.updateOrderAddMoney(orderInfo, accountInfo, memberpercent);
licc's avatar
licc committed
104 105 106
            }
        }
        return R.ok(0, true);
licc's avatar
licc committed
107
    }
licc's avatar
licc committed
108 109

    @Override
licc's avatar
licc committed
110
    public R<AccountInfo> getByUserId(String userId) {
licc's avatar
licc committed
111 112 113
        AccountInfo accountInfo = accountMapper.getByUserId(userId);
        return R.ok(accountInfo);
    }
licc's avatar
licc committed
114 115 116 117 118 119 120 121

    @Override
    public R<Boolean> performanceCount(List<OrderInfo> list) {
        log.info("shop-mall[]AccountServiceImpl[]performanceCount[]input.param.list:{}", list.size());
        if (CollectionUtils.isEmpty(list)) {
            return R.ok(0, true);
        }

licc's avatar
licc committed
122 123 124
        Date date = new Date();
        String yearMonth = DateUtil.convertDateToStr(date, PATTERN);

licc's avatar
licc committed
125 126 127
        //计算当月所有订单成交额
        BigDecimal totalMoney = new BigDecimal(0);
        for (OrderInfo orderInfo : list) {
licc's avatar
licc committed
128
            //判断是否是本月
licc's avatar
licc committed
129 130 131 132 133 134
            boolean bool = publicManager.isThisMonth(orderInfo.getCreateTime(), PATTERN);
            if (bool && orderInfo.getMonthlyTaskStatus() == 0) {
                totalMoney = totalMoney.add(orderInfo.getPayment());
            }
        }

135
        //遍历订单  订单状态创建时间,当月时间小于当前时间
licc's avatar
licc committed
136 137 138
        for (OrderInfo orderInfo : list) {
            long createTime = orderInfo.getCreated().getTime();
            long time = System.currentTimeMillis();
139
            if (createTime <= time) {
licc's avatar
licc committed
140 141 142 143 144 145
                //获取用户信息
                User user = usersMapper.selectById(orderInfo.getBuyerId());
                if (null == user) {
                    continue;
                }

licc's avatar
licc committed
146 147 148
                List<TeamPerformance> teamPerformances = new ArrayList<>();

                //获取团队业绩信息
licc's avatar
licc committed
149
                TeamPerformance teamPerformance = teamPerformanceMapper.getByUserIdAndTime(user.getUserId(), yearMonth);
licc's avatar
licc committed
150
                if (null == teamPerformance) {
licc's avatar
licc committed
151 152 153
                    continue;
                }

licc's avatar
licc committed
154 155 156 157
                //1、统计当前用户月度业绩
                BigDecimal userCount = teamPerformance.getMonthTeamPerformance().add(orderInfo.getPayment());
                teamPerformance.setMonthTeamPerformance(userCount);
                teamPerformances.add(teamPerformance);
licc's avatar
licc committed
158

159
                //2、获取当前用户的上级用户列表 todo 邀请码等于一个固定值,停止 等于两个值  七位XXXXXXX 和 7777777
licc's avatar
licc committed
160 161
                List<User> userList = getByList(user.getUserId());
                if (CollectionUtils.isEmpty(userList)) {
licc's avatar
licc committed
162 163 164
                    continue;
                }

licc's avatar
licc committed
165 166
                for (User userInfo : userList) {
                    //3、统计当前用户上级月度绩效
licc's avatar
licc committed
167
                    TeamPerformance team = teamPerformanceMapper.getByUserIdAndTime(userInfo.getUserId(), yearMonth);
licc's avatar
licc committed
168 169 170 171 172 173 174 175 176 177 178 179
                    if (null == team) {
                        continue;
                    }
                    //1、统计当前用户月度绩效
                    BigDecimal monthCount = team.getMonthTeamPerformance().add(orderInfo.getPayment());
                    team.setMonthTeamPerformance(monthCount);
                    teamPerformances.add(team);
                }

                //4、更新账户月度绩效
                accountManager.updateAccountPerformanceMonth(teamPerformances);
            }
licc's avatar
licc committed
180 181 182 183 184 185
        }
        //5、获取所有用户,如果会员等级是黄金以上,计算月度收益
        List<User> userList = usersMapper.getAllGoldUser();
        if (CollectionUtils.isEmpty(userList)) {
            return R.ok(0, true);
        }
licc's avatar
licc committed
186 187 188 189

        boolean bool = monthlyIncome(totalMoney, userList);
        if (!bool) {
            return R.ok(1, false);
licc's avatar
licc committed
190 191
        }
        return R.ok(0, true);
licc's avatar
licc committed
192

licc's avatar
licc committed
193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209
    }

    /**
     * 获取用户的商机信息
     *
     * @param userId 用户id
     * @return
     */
    @Override
    public List<User> getByList(String userId) {
        List<User> list = new ArrayList<>();

        getUser(list, userId);

        return list;
    }

licc's avatar
licc committed
210 211 212
    @Override
    public R<Boolean> progressPrizeCount() {
        log.info("shop-mall[]AccountServiceImpl[]performanceCount[]input.method");
licc's avatar
licc committed
213 214
        Date date = new Date();
        String yearMonth = DateUtil.convertDateToStr(date, PATTERN);
licc's avatar
licc committed
215 216

        //1、判断当前月是否是业绩开始的第一个月
licc's avatar
licc committed
217
        List<TeamPerformance> teamPerformances = teamPerformanceMapper.getByBeforeTime(yearMonth);
licc's avatar
licc committed
218

licc's avatar
licc committed
219
        //获取当月所有人业绩总额
licc's avatar
licc committed
220
        Double totalMoney = teamPerformanceMapper.countByTime(yearMonth);
licc's avatar
licc committed
221
        double number = Math.floor(totalMoney / 3980 / 12);
licc's avatar
licc committed
222 223 224 225
        //2、集合为空 是业绩开始的第一个月
        if (CollectionUtils.isEmpty(teamPerformances)) {
            if (number != 0) {
                //获取月业绩前20用户
licc's avatar
licc committed
226
                List<TeamPerformance> list = teamPerformanceMapper.userTwenty(yearMonth);
licc's avatar
licc committed
227 228 229 230 231
                if (CollectionUtils.isEmpty(list)) {
                    return R.ok(0, true);
                }

                //获取20名进步最大的月业绩和
licc's avatar
licc committed
232
                Double twentyTotal = teamPerformanceMapper.countTwenty(yearMonth);
licc's avatar
licc committed
233 234
                List<AccountInfo> accountInfoList = new ArrayList<>();
                List<TradeRecord> tradeRecordList = new ArrayList<>();
licc's avatar
licc committed
235 236 237 238 239 240 241 242 243 244 245 246
                for (TeamPerformance user : list) {
                    //获取最大进步奖 百分比
                    MemberPercent memberPercent = memberPercentMapper.getByLevelAndType(user.getUserLevel(), 3);

                    //计算收益
                    double userTeamPerformance = user.getMonthTeamPerformance().doubleValue();
                    double percent = memberPercent.getPercent().doubleValue();

                    double income = number * 3980 * percent * userTeamPerformance / twentyTotal;

                    //获取账户信息
                    AccountInfo accountInfo = accountMapper.getByUserId(user.getUserId());
licc's avatar
licc committed
247
                    accountInfo.setEarningsMonth(new BigDecimal(income));
licc's avatar
licc committed
248
                    accountInfoList.add(accountInfo);
249 250 251 252 253 254 255

                    //添加交易流水记录
                    TradeRecord tradeRecord = new TradeRecord();
                    tradeRecord.setUserId(user.getUserId());
                    tradeRecord.setTradeType(TradeRecordEnum.PROGRESS_PRIZE.getCode());
                    tradeRecord.setTradeNo(null);
                    tradeRecord.setStatus(TradeStatusEnum.ALREADY_SETTLE_ACCOUNTS.getCode());
licc's avatar
licc committed
256 257 258 259 260 261 262
                    tradeRecordList.add(tradeRecord);
                }

                //更新账户信息,添加交易流水记录
                boolean bool = accountManager.updateAccountAddRecord(accountInfoList, tradeRecordList);
                if (!bool) {
                    return R.ok(1, false);
licc's avatar
licc committed
263 264 265 266 267 268 269 270 271 272 273 274
                }
            }
            return R.ok(0, true);
        }

        //3、集合不为空 不是业绩开始的第一个月
        //获取用户列表
        List<User> userList = usersMapper.findAll();
        if (CollectionUtils.isEmpty(userList)) {
            return R.ok(0, true);
        }

licc's avatar
licc committed
275 276
        //4计算每个用户本月的业绩增长率
        List<TeamPerformanceSortVo> listVo = progressPrizeStatistics(userList);
licc's avatar
licc committed
277

licc's avatar
licc committed
278
        //5、如果集合大于20 ,取前二十名,小于,取全部
licc's avatar
licc committed
279
        if (listVo.size() >= TWENTY) {
licc's avatar
licc committed
280
            //取排名前20的
licc's avatar
licc committed
281
            listVo.subList(0, TWENTY);
licc's avatar
licc committed
282

licc's avatar
licc committed
283 284 285
            //计算前20的总业绩
            double total = listVo.stream().mapToDouble(TeamPerformanceSortVo::getMonthPerformance).sum();
            totalPerformanceIncome(listVo, number, total);
licc's avatar
licc committed
286 287
            return R.ok(0, true);
        } else {
licc's avatar
licc committed
288 289 290
            //计算用户数少于20的总业绩
            double total = listVo.stream().mapToDouble(TeamPerformanceSortVo::getMonthPerformance).sum();
            totalPerformanceIncome(listVo, number, total);
licc's avatar
licc committed
291 292
        }
        return R.ok(0, true);
licc's avatar
licc committed
293 294
    }

licc's avatar
licc committed
295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318
    @Override
    public void mirrorImage() {
        //1、把账户表account_info复制给表account_image  CREATE TABLE table_2  SELECT * FROM table_1;
        lastAccountMapper.copyTable("account_info", "account_image");

        //删除上月备份
        lastAccountMapper.deleteTable("account_backup");

        //备份
        lastAccountMapper.copyTable("account_info", "account_backup");

        //2、把上月账户表last_month_account 复制给month_account_image
        lastAccountMapper.copyTable("last_month_account", "month_account_image");

        //3、删除last_month_account
        lastAccountMapper.deleteTable("last_month_account");

        //4、把account_image 更名为 last_month_account  rename table table_2 to table_1;
        lastAccountMapper.updateTableName("account_image", "last_month_account");

        //5、删除month_account_image   DROP table table_2;
        lastAccountMapper.deleteTable("month_account_image");
    }

licc's avatar
licc committed
319 320 321 322 323 324 325 326
    public void getUser(List<User> list, String userId) {
        User user = usersMapper.getByUserId(userId);
        list.add(user);
        if (null != user && StringUtils.isBlank(user.getBeInvitedCode())) {
            User userInfo = usersMapper.getByBeInvitedCode(user.getBeInvitedCode());
            getUser(list, userInfo.getUserId());
        }
    }
licc's avatar
licc committed
327

licc's avatar
licc committed
328 329 330
    /**
     * 如果会员等级是黄金以上,计算月度收益
     *
licc's avatar
licc committed
331 332
     * @param totalMoney 月金额总额
     * @param userList   用户列表
licc's avatar
licc committed
333 334
     * @return
     */
licc's avatar
licc committed
335
    private boolean monthlyIncome(BigDecimal totalMoney, List<User> userList) {
licc's avatar
licc committed
336
        double total = totalMoney.doubleValue();
licc's avatar
licc committed
337 338 339
        Date date = new Date();
        String yearMonth = DateUtil.convertDateToStr(date, PATTERN);

licc's avatar
licc committed
340 341
        //当月所有人订单成交总金额/3980/12  向下整
        double moneyMonth = Math.floor(total / 3980 / 12);
licc's avatar
licc committed
342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377
        List<AccountInfo> accountInfoList = new ArrayList<>();
        List<TradeRecord> tradeRecordList = new ArrayList<>();
        for (User user : userList) {
            if (moneyMonth != 0) {
                //获取等级优惠百分比
                MemberPercent memberPercent = memberPercentMapper.getByLevelAndType(user.getUserLevel(), 2);
                if (null != memberPercent) {
                    //获取本月团队总金额
                    TeamPerformance teamPerformance = teamPerformanceMapper.getByUserIdAndTime(user.getUserId(), yearMonth);

                    //获取该等级团队总金额
                    Double teamTotal = teamPerformanceMapper.countTeamMoney(user.getUserLevel(), yearMonth);
                    if (null != teamPerformance && null != teamTotal) {
                        double month = teamPerformance.getMonthTeamPerformance().doubleValue();
                        double percent = memberPercent.getPercent().doubleValue();
                        //计算收益
                        double income = moneyMonth * 3980 * percent * month / teamTotal;

                        //获取账户信息
                        AccountInfo accountInfo = accountMapper.getByUserId(user.getUserId());
                        BigDecimal bigDecimal = new BigDecimal(income);
                        BigDecimal performanceMonth = accountInfo.getEarningsMonth().add(bigDecimal);
                        accountInfo.setEarningsMonth(performanceMonth);

                        BigDecimal performanceTotal = accountInfo.getEarningsMonth().add(bigDecimal);
                        accountInfo.setEarningsMonth(performanceTotal);
                        accountInfoList.add(accountInfo);


                        //5、添加交易流水记录
                        TradeRecord tradeRecord = new TradeRecord();
                        tradeRecord.setUserId(user.getUserId());
                        tradeRecord.setTradeType(TradeRecordEnum.ORDER_REBATE.getCode());
                        tradeRecord.setTradeNo(null);
                        tradeRecord.setStatus(TradeStatusEnum.NO_SETTLE_ACCOUNTS.getCode());
                        tradeRecordList.add(tradeRecord);
licc's avatar
licc committed
378
                    }
licc's avatar
licc committed
379 380 381
                }
            }
        }
licc's avatar
licc committed
382 383
        //更新账户信息,新增交易流水记录
        return accountManager.updateAccountAddRecord(accountInfoList, tradeRecordList);
licc's avatar
licc committed
384 385
    }

licc's avatar
licc committed
386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423
    /**
     * 统计每个用户本月业绩增长率
     *
     * @param userList 用户列表
     * @return 每个用户本月业绩增长率
     */
    private List<TeamPerformanceSortVo> progressPrizeStatistics(List<User> userList) {
        Date date = new Date();
        String yearMonth = DateUtil.convertDateToStr(date, PATTERN);

        //遍历 计算业绩增长率
        List<TeamPerformanceSortVo> listVo = new ArrayList<>();
        for (User user : userList) {
            TeamPerformanceSortVo teamVo = new TeamPerformanceSortVo();
            double growthRate;
            //获取当月业绩
            TeamPerformance teamPerformance = teamPerformanceMapper.getByUserIdAndTime(user.getUserId(), yearMonth);

            //获取上月业绩
            Calendar cal = Calendar.getInstance();
            cal.setTime(new Date());
            cal.add(Calendar.MONTH, -1);
            Date lastDate = cal.getTime();
            String lastMonthTime = DateUtil.convertDateToStr(lastDate, PATTERN);
            TeamPerformance lastMonth = teamPerformanceMapper.getByUserIdAndTime(user.getUserId(), lastMonthTime);
            if (null == teamPerformance || null == lastMonth) {
                growthRate = 0.00;
            } else {
                double month = teamPerformance.getMonthTeamPerformance().doubleValue();
                double last = lastMonth.getMonthTeamPerformance().doubleValue();
                if (last >= month) {
                    growthRate = 0.00;
                } else {
                    growthRate = (month - last) / month;
                }
            }
            teamVo.setGrowthRate(growthRate);
            double monthPerformance;
licc's avatar
licc committed
424
            assert teamPerformance != null;
licc's avatar
licc committed
425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451
            if (null == teamPerformance.getMonthTeamPerformance()) {
                monthPerformance = 0.00;
            } else {
                monthPerformance = teamPerformance.getMonthTeamPerformance().doubleValue();
            }
            teamVo.setMonthPerformance(monthPerformance);
            teamVo.setUserId(user.getUserId());
            teamVo.setTeamPerformance(teamPerformance);
            listVo.add(teamVo);
        }

        //对集合进行排序
        listVo.sort(Comparator.comparing(TeamPerformanceSortVo::getGrowthRate).reversed());
        return listVo;
    }

    /**
     * 统计用户最大进步奖收益
     *
     * @param listVo 用户增长率列表
     * @param number 个人业绩
     * @param total  总业绩
     */
    private void totalPerformanceIncome(List<TeamPerformanceSortVo> listVo, double number, double total) {
        //要更新的账户列表
        List<AccountInfo> updateAccountList = new ArrayList<>();

licc's avatar
licc committed
452 453 454 455
        BigDecimal sum = new BigDecimal(0);
        for (int i = 0; i < listVo.size(); i++) {
            String userId = listVo.get(i).getTeamPerformance().getUserId();
            Integer userLevel = listVo.get(i).getTeamPerformance().getUserLevel();
licc's avatar
licc committed
456 457 458 459
            //获取最大进步奖 百分比
            MemberPercent memberPercent = memberPercentMapper.getByLevelAndType(userLevel, 3);

            //计算收益
licc's avatar
licc committed
460
            double userTeamPerformance = listVo.get(i).getTeamPerformance().getMonthTeamPerformance().doubleValue();
licc's avatar
licc committed
461 462 463 464 465 466
            double percent = memberPercent.getPercent().doubleValue();

            double income = number * 3980 * percent * userTeamPerformance / total;

            //获取账户信息
            AccountInfo accountInfo = accountMapper.getByUserId(userId);
licc's avatar
licc committed
467 468 469 470 471 472 473
            BigDecimal bigDecimal;
            if (i == listVo.size() - 1) {
                bigDecimal = new BigDecimal(total).subtract(sum);
            } else {
                bigDecimal = accountInfo.getEarningsMonth().add(new BigDecimal(income));
                sum = sum.add(new BigDecimal(income));
            }
licc's avatar
licc committed
474 475 476 477 478 479 480 481 482
            accountInfo.setEarningsMonth(bigDecimal);
            updateAccountList.add(accountInfo);
        }

        //判断本月是否有最大进步奖数据 无,新增  有,修改或删除
        Date date = new Date();
        String yearMonth = DateUtil.convertDateToStr(date, PATTERN);
        List<ProgressPrize> prizes = progressPrizeMapper.getByYearMonth(yearMonth);

licc's avatar
licc committed
483
        //修改或保存最大进步奖信息
licc's avatar
licc committed
484
        accountManager.updateOrSavePrize(listVo, updateAccountList, prizes);
licc's avatar
licc committed
485
    }
licc's avatar
licc committed
486
}