yujian
2020-06-09 22b671ca55de7f03304538c4f9366884f552cc1e
订单
1个文件已修改
168 ■■■■■ 已修改文件
fanli/src/main/java/com/yeshi/fanli/controller/client/v2/UserOrderControllerV2.java 168 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
fanli/src/main/java/com/yeshi/fanli/controller/client/v2/UserOrderControllerV2.java
@@ -25,6 +25,7 @@
import com.google.gson.JsonPrimitive;
import com.google.gson.JsonSerializationContext;
import com.google.gson.JsonSerializer;
import com.yeshi.fanli.dto.order.SearchFilterOrder;
import com.yeshi.fanli.dto.order.UserTeamLevel;
import com.yeshi.fanli.entity.accept.AcceptData;
import com.yeshi.fanli.entity.bus.user.HongBaoV2;
@@ -163,51 +164,36 @@
    private ThreeSaleDetailService threeSaleDetailService;
    /**
     * 订单列表
     * 处理搜索条件
     * 
     * @param acceptData
     * @param page
     * @param uid
     * @param state
     *            状态:0全部 1-未到账 2-已到账 3-已失效 4已收货
     * @param type
     *            类型:1-返利订单 2-分享订单 3-邀请订单
     * @param orderState
     *            1有效订单 2 维权订单 3失效订单
     * @param orderNo
     *            订单号
     * @param startTime
     *            起始时间
     * @param endTime
     *            结束时间
     * @param slotTime
     *            时间段:1-最近三天 2-最近七天 3最近半月 4本月 5近三月 6近半年
     * @param dateType
     *            1-今日 2-昨天 3-本月 4-上个月 |
     * @param source
     *             页面来源:welfareCore-福利中心、bonus -奖金统计(我的界面)
     * @param out
     * @param filter
     */
    @RequestMapping(value = "getOrderList", method = RequestMethod.POST)
    public void getOrderList(AcceptData acceptData, Integer page, Long uid, Integer state, String type,
            Integer orderState, String orderNo, String startTime, String endTime, Integer slotTime, Integer dateType,
            Integer goodsType, String source, PrintWriter out) {
        if (uid == null) {
            out.print(JsonUtil.loadFalseResult(1, "用户未登录"));
            return;
    private void handleSearchFilter(SearchFilterOrder filter) {
        Integer goodsType = filter.getGoodsType();
        if (goodsType != null && goodsType == 0) {
            goodsType = null;
            filter.setGoodsType(goodsType);
        }
        if (page == null || page < 1)
            page = 1;
        // 搜索内容、订单号
        if (!StringUtil.isNullOrEmpty(orderNo)
                && VersionUtil.greaterThan_2_0_6(acceptData.getPlatform(), acceptData.getVersion())) {
            searchOrder(acceptData, orderNo, page, uid, out);
            return;
        List<Integer> listSource = new ArrayList<>();
        if (goodsType != null) {
            listSource.add(goodsType);
        }
        filter.setListSource(listSource);
        // 订单类型
        String type = filter.getType();
        Integer orderType = null;
        if (StringUtil.isNullOrEmpty(type)) {
            orderType = null;
        } else if (!"0".equalsIgnoreCase(type)) {
            orderType = Integer.parseInt(type);
        }
        filter.setOrderType(orderType);
        // 转换状态
        Integer orderState = filter.getOrderState();
        Integer state = filter.getState();
        if (state != null) {
            if (state == 0) {
                state = null; // 所有
@@ -222,19 +208,14 @@
        if (state != null && orderState != null && (orderState == 2 || orderState == 3)) {
            state = null;
        }
        // 订单类型
        Integer orderType = null;
        if (StringUtil.isNullOrEmpty(type)) {
            orderType = null;
        } else if (!"0".equalsIgnoreCase(type)) {
            orderType = Integer.parseInt(type);
        }
        if (goodsType != null && goodsType == 0)
            goodsType = null;
        filter.setState(state);
        filter.setOrderState(orderState);
        // 筛选时间
        Integer dateType = filter.getDateType();
        String startTime = filter.getStartTime();
        String endTime = filter.getEndTime();
        Integer slotTime = filter.getSlotTime();
        if (slotTime != null) {
            try {
                SimpleDateFormat sd = new SimpleDateFormat("yyyy-MM-dd");
@@ -268,33 +249,81 @@
                e.printStackTrace();
            }
        }
        filter.setDateType(dateType);
        filter.setStartTime(startTime);
        if (endTime != null && endTime.trim().length() > 0) {
            endTime += " 23:59:59";
        }
        filter.setEndTime(endTime);
        List<Integer> listSource = new ArrayList<>();
        if (goodsType != null) {
            listSource.add(goodsType);
        }
    /**
     * 订单列表
     *
     * @param acceptData
     * @param page
     * @param uid
     * @param state      状态:0全部 1-未到账 2-已到账 3-已失效 4已收货
     * @param type       类型:1-返利订单 2-分享订单 3-邀请订单
     * @param orderState 1有效订单 2 维权订单 3失效订单
     * @param orderNo    订单号
     * @param startTime  起始时间
     * @param endTime    结束时间
     * @param slotTime   时间段:1-最近三天 2-最近七天 3最近半月 4本月 5近三月 6近半年
     * @param dateType   1-今日 2-昨天 3-本月 4-上个月 |
     * @param source     页面来源:welfareCore-福利中心、bonus -奖金统计(我的界面)
     * @param out
     */
    @RequestMapping(value = "getOrderList", method = RequestMethod.POST)
    public void getOrderList(AcceptData acceptData, Integer page, SearchFilterOrder filter, PrintWriter out) {
        Long uid = filter.getUid();
        if (uid == null) {
            out.print(JsonUtil.loadFalseResult(1, "用户未登录"));
            return;
        }
        if (page == null || page < 1)
            page = 1;
        handleSearchFilter(filter);
        String startTime = filter.getStartTime();
        String endTime = filter.getEndTime();
        Integer orderType = filter.getOrderType();
        Integer dateType = filter.getDateType();
        Integer state = filter.getState();
        List<Integer> listSource = filter.getListSource();
        Integer orderState = filter.getOrderState();
        try {
            boolean notBackSuVip = false;
            if (!VersionUtil.greaterThan_2_1_2(acceptData.getPlatform(), acceptData.getVersion())) {
                notBackSuVip = true;
                if (listSource.size() == 0) {
                    listSource.add(Constant.SOURCE_TYPE_TAOBAO);
                    listSource.add(Constant.SOURCE_TYPE_JD);
                    listSource.add(Constant.SOURCE_TYPE_PDD);
                }
            }
            // 搜索内容、订单号
            String orderNo = filter.getOrderNo();
            if (!StringUtil.isNullOrEmpty(orderNo)
                    && VersionUtil.greaterThan_2_0_6(acceptData.getPlatform(), acceptData.getVersion())) {
                searchOrder(acceptData, orderNo, page, uid, listSource, out);
                return;
            }
            // 筛选结果顶部统计
            String validMoney = "0.00";
            String invalidMoney = "0.00";
            if (page == 1) {
                BigDecimal predictMoney = hongBaoV2CountService.getRewardMoneyByToSearch(uid, dateType, orderType, 1,
                        orderNo, state, startTime, endTime, listSource, notBackSuVip);
                BigDecimal predictMoney = hongBaoV2CountService.getRewardMoneyByToSearch(uid, filter.getDateType(),
                        orderType, 1, orderNo, state, startTime, endTime, listSource);
                if (predictMoney != null)
                    validMoney = predictMoney.setScale(2, BigDecimal.ROUND_DOWN).toString();
                BigDecimal postSaleMoney = hongBaoV2CountService.getRewardMoneyByToSearch(uid, dateType, orderType, 2,
                        orderNo, state, startTime, endTime, listSource, notBackSuVip);
                BigDecimal postSaleMoney = hongBaoV2CountService.getRewardMoneyByToSearch(uid, filter.getDateType(),
                        orderType, 2, orderNo, state, startTime, endTime, listSource);
                if (postSaleMoney != null)
                    invalidMoney = postSaleMoney.setScale(2, BigDecimal.ROUND_DOWN).toString();
@@ -311,10 +340,10 @@
            List<CommonOrderVO> list = null;
            if (VersionUtil.greaterThan_2_1(acceptData.getPlatform(), acceptData.getVersion())) {
                list = commonOrderService.getOrderList(acceptData, page, uid, state, orderType, orderState, orderNo,
                        startTime, endTime, dateType, listSource, notBackSuVip);
                        startTime, endTime, dateType, listSource);
                count = commonOrderService.countOrderList(uid, state, orderType, orderState, orderNo, startTime,
                        endTime, dateType, listSource, notBackSuVip);
                        endTime, dateType, listSource);
            } else {
                list = commonOrderService.getOrderByUid(acceptData, page, uid, state, orderType, orderState, orderNo,
                        startTime, endTime, dateType, listSource);
@@ -348,20 +377,19 @@
    /**
     * 搜索订单
     *
     * @param key
     * @param out
     */
    private void searchOrder(AcceptData acceptData, String key, Integer page, Long uid, PrintWriter out) {
    private void searchOrder(AcceptData acceptData, String key, Integer page, Long uid, List<Integer> listSource, PrintWriter out) {
        try {
            long count = 0;
            List<CommonOrderVO> list = null;
            if (NumberUtil.isNumeric(key.replace("-", ""))) {
                if (VersionUtil.greaterThan_2_1_2(acceptData.getPlatform(), acceptData.getVersion())) {
                    commonOrderService.getOrderList(acceptData, page, uid, null, null, null, key, null, null, null,
                            null, false);
                    commonOrderService.getOrderList(acceptData, page, uid, null, null, null, key, null, null, null,listSource);
                } else
                    list = commonOrderService.getOrderByUid(acceptData, page, uid, null, null, null, key, null, null,
                            null, null);
                    list = commonOrderService.getOrderByUid(acceptData, page, uid, null, null, null, key, null, null, null, listSource);
            }
            if (list == null || list.size() == 0) {
@@ -393,9 +421,7 @@
     * 用户订单统计
     * 
     * @param acceptData
     * @param uid
     *            用户id
     *    type 类型:0全部、1淘宝 2京东、拼多多
     * @param uid        用户id type 类型:0全部、1淘宝 2京东、拼多多
     * @param out
     */
    @RequestMapping(value = "getOrderCount", method = RequestMethod.POST)
@@ -463,6 +489,7 @@
    /**
     * 统计奖金
     *
     * @param acceptData
     * @param uid
     * @param dateType  1-今日 2-昨天 3-本月 4-上个月
@@ -528,6 +555,7 @@
    /**
     * 返利说明
     *
     * @param acceptData
     * @param uid
     * @param orderNo
@@ -801,9 +829,7 @@
     * 用户订单统计
     * 
     * @param acceptData
     * @param uid
     *            用户id
     *    type 类型:0全部、1淘宝 2京东、拼多多
     * @param uid        用户id type 类型:0全部、1淘宝 2京东、拼多多
     * @param out
     */
    @RequestMapping(value = "teamOrderSearch")