admin
2019-06-21 7f943e54f259c7ff69c7591dbd6803171126b01e
fanli/src/main/java/com/yeshi/fanli/controller/admin/OrderAdminController.java
@@ -15,6 +15,12 @@
import com.google.gson.Gson;
import com.google.gson.reflect.TypeToken;
import com.yeshi.fanli.controller.admin.utils.AdminUtils;
import com.yeshi.fanli.entity.bus.user.HongBaoV2;
import com.yeshi.fanli.entity.money.UserMoneyDetail;
import com.yeshi.fanli.entity.money.UserMoneyDetail.UserMoneyDetailTypeEnum;
import com.yeshi.fanli.entity.order.CommonOrder;
import com.yeshi.fanli.entity.taobao.TaoBaoWeiQuanDrawBack;
import com.yeshi.fanli.entity.taobao.TaoBaoWeiQuanOrder;
import com.yeshi.fanli.exception.order.CommonOrderException;
import com.yeshi.fanli.service.inter.count.HongBaoV2CountService;
import com.yeshi.fanli.service.inter.count.TaoBaoOrderCountService;
@@ -22,6 +28,9 @@
import com.yeshi.fanli.service.inter.order.CommonOrderService;
import com.yeshi.fanli.service.inter.order.OrderService;
import com.yeshi.fanli.service.inter.taobao.TaoBaoOrderService;
import com.yeshi.fanli.service.inter.taobao.TaoBaoWeiQuanDrawBackService;
import com.yeshi.fanli.service.inter.taobao.TaoBaoWeiQuanOrderService;
import com.yeshi.fanli.service.inter.user.UserMoneyDetailService;
import com.yeshi.fanli.tag.PageEntity;
import com.yeshi.fanli.util.Constant;
import com.yeshi.fanli.util.StringUtil;
@@ -36,7 +45,6 @@
   @Resource
   private OrderService orderService;
   @Resource
   private HongBaoV2CountService hongBaoV2CountService;
@@ -53,9 +61,18 @@
   @Resource
   private TaoBaoOrderCountService taoBaoOrderCountService;
   @Resource
   private TaoBaoWeiQuanDrawBackService taoBaoWeiQuanDrawBackService;
   @Resource
   private TaoBaoWeiQuanOrderService taoBaoWeiQuanOrderService;
   @Resource
   private UserMoneyDetailService userMoneyDetailService;
   
   /**
    * 统计历史订单-淘宝订单
    *
    * @param callback
    * @param request
    * @param out
@@ -88,9 +105,9 @@
      }
   }
   
   /**
    * 查询所有用户订单列表
    *
    * @param callback
    * @param pageIndex
    * @param pageSize
@@ -104,10 +121,8 @@
    * @param out
    */
   @RequestMapping(value = "getUserOrderList")
   public void getUserOrderList(String callback, Integer pageIndex, Integer pageSize, Integer keyType,
         String key, Integer state, Integer type, Integer orderState, String startTime, String endTime,
         PrintWriter out) {
   public void getUserOrderList(String callback, Integer pageIndex, Integer pageSize, Integer keyType, String key,
         Integer state, Integer type, Integer orderState, String startTime, String endTime, PrintWriter out) {
      if (pageIndex == null || pageIndex < 1) {
         pageIndex = 1;
@@ -132,13 +147,63 @@
         long count = 0;
         // 查询列表
         List<CommonOrderVO> list = commonOrderService.listQuery((pageIndex - 1) * pageSize, pageSize,
               keyType, key, state, type, orderState, startTime, endTime);
         List<CommonOrderVO> list = commonOrderService.listQuery((pageIndex - 1) * pageSize, pageSize, keyType, key,
               state, type, orderState, startTime, endTime);
         if (list != null && list.size() > 0) {
            // 统计总数
            count = commonOrderService.countQuery(keyType, key, state, type, orderState, startTime, endTime);
         }
         // 查询是否维权
         for (CommonOrderVO order : list) {
            // 查询是否维权
            TaoBaoWeiQuanOrder weiQuanOrder = taoBaoWeiQuanOrderService.listByorderItemId(order.getTradeId());
            if (weiQuanOrder != null)// 有维权
            {
               order.setState(CommonOrder.STATE_WQ);
               TaoBaoWeiQuanDrawBack drawBack = taoBaoWeiQuanDrawBackService
                     .selectByOrderItemId(weiQuanOrder.getOrderItemId());
               if (drawBack != null) {// 已经退款
                  order.setWeiQuanState(weiQuanOrder.getState());
                  // 计算退款资金
                  UserMoneyDetail detail = null;
                  switch (order.getHongBaoType()) {
                  case HongBaoV2.TYPE_ZIGOU:
                     detail = userMoneyDetailService.selectByTypeAndUidAndIdentifyCode(
                           UserMoneyDetailTypeEnum.fanliWeiQuan, Long.parseLong(order.getUserId()),
                           drawBack.getId());
                     if (detail == null)
                        detail = userMoneyDetailService.selectByTypeAndUidAndIdentifyCode(
                              UserMoneyDetailTypeEnum.weiQuan, Long.parseLong(order.getUserId()),
                              drawBack.getId());
                     break;
                  case HongBaoV2.TYPE_YIJI:
                  case HongBaoV2.TYPE_ERJI:
                  case HongBaoV2.TYPE_SHARE_YIJI:
                  case HongBaoV2.TYPE_SHARE_ERJI:
                     detail = userMoneyDetailService.selectByTypeAndUidAndIdentifyCode(
                           UserMoneyDetailTypeEnum.inviteWeiQuan, Long.parseLong(order.getUserId()),
                           drawBack.getId());
                     break;
                  case HongBaoV2.TYPE_SHARE_GOODS:
                     detail = userMoneyDetailService.selectByTypeAndUidAndIdentifyCode(
                           UserMoneyDetailTypeEnum.shareWeiQuan, Long.parseLong(order.getUserId()),
                           drawBack.getId());
                     break;
                  }
                  if (detail != null) {
                     // 退款成功
                     order.setWeiQuanBackMoney(detail.getMoney().abs().toString());
                  } else {// 尚未退款
                     order.setWeiQuanBackMoney("-" + order.getHongBao());
                  }
               } else {// 尚未退款
                  order.setWeiQuanBackMoney("-" + order.getHongBao());
               }
            }
         }
         
         int totalPage = (int) (count % pageSize == 0 ? count / pageSize : count / pageSize + 1);
@@ -158,10 +223,9 @@
      }
   }
   /**
    * 查询订单列表用户uid
    *
    * @param callback
    * @param pageIndex
    * @param pageSize
@@ -175,8 +239,8 @@
    * @param out
    */
   @RequestMapping(value = "getHistoryOrder")
   public void getHistoryOrder(String callback, Integer pageIndex, Integer pageSize, Long uid, Integer state, Integer type,
         Integer orderState,   String orderNo, String startTime, String endTime, PrintWriter out) {
   public void getHistoryOrder(String callback, Integer pageIndex, Integer pageSize, Long uid, Integer state,
         Integer type, Integer orderState, String orderNo, String startTime, String endTime, PrintWriter out) {
      if (uid == null) {
         JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("uid不能为空"));
@@ -206,13 +270,13 @@
         long count = 0;
         // 查询列表
         List<CommonOrderVO> list = commonOrderService.listQueryByUid((pageIndex - 1) * pageSize, pageSize ,
               uid, state, type, orderState, orderNo, startTime, endTime, null);
         List<CommonOrderVO> list = commonOrderService.listQueryByUid((pageIndex - 1) * pageSize, pageSize, uid,
               state, type, orderState, orderNo, startTime, endTime, null);
         if (list != null && list.size() > 0) {
            // 统计总数
            count = commonOrderService.countQueryByUid(uid, state, type, orderState, orderNo, startTime,
                  endTime, null);
            count = commonOrderService.countQueryByUid(uid, state, type, orderState, orderNo, startTime, endTime,
                  null);
         }
         
         int totalPage = (int) (count % pageSize == 0 ? count / pageSize : count / pageSize + 1);
@@ -251,8 +315,8 @@
    * @param out
    */
   @RequestMapping(value = "get24HOderChannelCharts")
   public void get24HOderChannelCharts(String callback, String channelArray, Integer dateType,
         String year, String startTime, String endTime, PrintWriter out) {
   public void get24HOderChannelCharts(String callback, String channelArray, Integer dateType, String year,
         String startTime, String endTime, PrintWriter out) {
      String validateMsg = AdminUtils.validateParams(dateType, startTime, endTime);
      if (validateMsg != null) {
@@ -265,18 +329,17 @@
         endTime = null;
      }
      List<String> channelList = null;
      if (channelArray != null && channelArray.trim().length() > 0) {
         Gson gson = new Gson();
         channelList = gson.fromJson(channelArray, new TypeToken<ArrayList<String>>() {}.getType());
         channelList = gson.fromJson(channelArray, new TypeToken<ArrayList<String>>() {
         }.getType());
      }
      if (channelList == null || channelList.size() == 0) {
         channelList = new ArrayList<String>();
         channelList.add("all");
      }
      
      if (dateType == 1 && year != null) {
         year = null; // 设置为空
@@ -307,8 +370,8 @@
         JSONArray line_list = new JSONArray();
         
         for (String channel : channelList) {
            List<Map<String, Object>> list = hongBaoV2CountService.count24HOderByChannel(channel, dateType, year, startTime, endTime);
            List<Map<String, Object>> list = hongBaoV2CountService.count24HOderByChannel(channel, dateType, year,
                  startTime, endTime);
            
            if ("all".equalsIgnoreCase(channel)) {
               channel = "总计";
@@ -332,7 +395,6 @@
            line_list.add(innerList);
         }
         JSONObject data = new JSONObject();
         if (objectDate != null) {
            data.put("xAxis_list", gson.toJson(objectDate));
@@ -350,21 +412,24 @@
      }
   }
   /**
    * 统计提现申请总次数
    *
    * @param callback
    * @param channelArray 渠道名 为空是统计所有
    * @param dateType     显示视图:日-1 、月-2、 年-3
    * @param state 状态:  1-未到账 2-已到账  3-已失效
    * @param channelArray
    *            渠道名 为空是统计所有
    * @param dateType
    *            显示视图:日-1 、月-2、 年-3
    * @param state
    *            状态: 1-未到账 2-已到账 3-已失效
    * @param year 
    * @param startTime
    * @param endTime
    * @param out
    */
   @RequestMapping(value = "getHongBaoNum")
   public void getHongBaoNum(String callback,String channelArray, Integer dateType, Integer state,
         String year, String startTime, String endTime, PrintWriter out) {
   public void getHongBaoNum(String callback, String channelArray, Integer dateType, Integer state, String year,
         String startTime, String endTime, PrintWriter out) {
      String validateMsg = AdminUtils.validateParams(dateType, startTime, endTime);
      if (validateMsg != null) {
@@ -383,18 +448,22 @@
   /**
    * 统计提现申请总金额
    *
    * @param callback
    * @param channelArray 渠道名 为空是统计所有
    * @param dateType     显示视图:日-1 、月-2、 年-3
    * @param state 状态:  1-未到账 2-已到账  3-已失效
    * @param channelArray
    *            渠道名 为空是统计所有
    * @param dateType
    *            显示视图:日-1 、月-2、 年-3
    * @param state
    *            状态: 1-未到账 2-已到账 3-已失效
    * @param year 
    * @param startTime
    * @param endTime
    * @param out
    */
   @RequestMapping(value = "getHongBaoMoney")
   public void getHongBaoMoney(String callback,String channelArray, Integer dateType, Integer state,
         String year, String startTime, String endTime, PrintWriter out) {
   public void getHongBaoMoney(String callback, String channelArray, Integer dateType, Integer state, String year,
         String startTime, String endTime, PrintWriter out) {
      String validateMsg = AdminUtils.validateParams(dateType, startTime, endTime);
      if (validateMsg != null) {
@@ -412,15 +481,9 @@
      }
   }
   /**
    * 统计红包信息
    *
    * @param channelArray
    * @param dateType
    * @param state
@@ -430,26 +493,25 @@
    * @return
    * @throws Exception
    */
   public JSONObject countHistoryHongBao(String channelArray, Integer dateType, Integer state, String year, String startTime,
         String endTime, int countType) throws Exception {
   public JSONObject countHistoryHongBao(String channelArray, Integer dateType, Integer state, String year,
         String startTime, String endTime, int countType) throws Exception {
      if (dateType != 1 && (!StringUtil.isNullOrEmpty(startTime) || !StringUtil.isNullOrEmpty(endTime))) {
         startTime = null;
         endTime = null;
      }
      List<String> channelList = null;
      if (channelArray != null && channelArray.trim().length() > 0) {
         Gson gson = new Gson();
         channelList = gson.fromJson(channelArray, new TypeToken<ArrayList<String>>() {}.getType());
         channelList = gson.fromJson(channelArray, new TypeToken<ArrayList<String>>() {
         }.getType());
      }
      if (channelList == null || channelList.size() == 0) {
         channelList = new ArrayList<String>();
         channelList.add("all");
      }
      
      if (dateType == 1 && year != null) {
         year = null; // 设置为空
@@ -479,11 +541,9 @@
      for (String channel : channelList) {
         List<Map<String, Object>> list = null;
         if (countType == 1 ) {
            list = hongBaoV2CountService.countHongBaoNum(channel, dateType, state, year,
                  startTime, endTime);
            list = hongBaoV2CountService.countHongBaoNum(channel, dateType, state, year, startTime, endTime);
         } else if (countType == 2) {
            list = hongBaoV2CountService.countHongBaoMoney(channel, dateType, state, year,
                  startTime, endTime);
            list = hongBaoV2CountService.countHongBaoMoney(channel, dateType, state, year, startTime, endTime);
         }
         
         if ("all".equalsIgnoreCase(channel)) {
@@ -508,7 +568,6 @@
         line_list.add(innerList);
      }
      JSONObject data = new JSONObject();
      if (objectDate != null) {
         data.put("xAxis_list", gson.toJson(objectDate));
@@ -521,20 +580,22 @@
      return data;
   }
   /**
    * 分类型订单数与比例 
    *
    * @param callback
    * @param dateType 日 -1 月-2 年-3
    * @param type     返利订单-1  分享订单-2  邀请订单-3
    * @param dateType
    *            日 -1 月-2 年-3
    * @param type
    *            返利订单-1 分享订单-2 邀请订单-3
    * @param year
    * @param startTime
    * @param endTime
    * @param out
    */
   @RequestMapping(value = "getTypeNumber")
   public void getTypeNumber(String callback, Integer dateType, String typeArray, String year,
         String startTime, String endTime, PrintWriter out) {
   public void getTypeNumber(String callback, Integer dateType, String typeArray, String year, String startTime,
         String endTime, PrintWriter out) {
      
      String validateMsg = AdminUtils.validateParams(dateType, startTime, endTime);
      if (validateMsg != null) {
@@ -547,18 +608,17 @@
         endTime = null;
      }
      List<Integer> channelList = null;
      if (typeArray != null && typeArray.trim().length() > 0) {
         Gson gson = new Gson();
         channelList = gson.fromJson(typeArray, new TypeToken<ArrayList<Integer>>() {}.getType());
         channelList = gson.fromJson(typeArray, new TypeToken<ArrayList<Integer>>() {
         }.getType());
      }
      if (channelList == null || channelList.size() == 0) {
         JsonUtil.printMode(out, callback, JsonUtil.loadFalseResult("订单类型不能为空"));
         return;
      }
      
      if (dateType == 1 && year != null) {
         year = null; // 设置为空
@@ -586,13 +646,11 @@
      
      try {
         JSONArray line_list = new JSONArray();
         for (Integer type : channelList) {
            
            List<Map<String, Object>> list = hongBaoV2CountService.countHongBaoType(dateType,
                  type, year, startTime, endTime);
            List<Map<String, Object>> list = hongBaoV2CountService.countHongBaoType(dateType, type, year, startTime,
                  endTime);
            
            JSONObject innerList = new JSONObject();
            if (type == 1) {
@@ -618,7 +676,6 @@
            line_list.add(innerList);
         }
         JSONObject data = new JSONObject();
         if (objectDate != null) {
            data.put("xAxis_list", gson.toJson(objectDate));
@@ -638,6 +695,7 @@
   
   /**
    * 订单跟踪准确率(返利券用户订单/淘宝联盟订单)
    *
    * @param callback
    * @param dateType
    * @param year
@@ -646,9 +704,8 @@
    * @param out
    */
   @RequestMapping(value = "getTrackAccuracyRate")
   public void getTrackAccuracyRate(String callback, Integer dateType, String year,
         String startTime, String endTime, PrintWriter out) {
   public void getTrackAccuracyRate(String callback, Integer dateType, String year, String startTime, String endTime,
         PrintWriter out) {
      if (dateType != 1 && (!StringUtil.isNullOrEmpty(startTime) || !StringUtil.isNullOrEmpty(endTime))) {
         startTime = null;
@@ -683,8 +740,8 @@
         
         JSONArray line_list = new JSONArray();
         
         List<Map<String, Object>> list = commonOrderCountService.getTrackAccuracyRate(dateType,
                year, startTime, endTime);
         List<Map<String, Object>> list = commonOrderCountService.getTrackAccuracyRate(dateType, year, startTime,
               endTime);
         
         JSONObject innerList = new JSONObject();
         innerList.put("name", "总计");
@@ -703,7 +760,6 @@
         
         line_list.add(innerList);
         JSONObject data = new JSONObject();
         if (objectDate != null) {
            data.put("xAxis_list", gson.toJson(objectDate));
@@ -720,11 +776,12 @@
      }
   }
   
   /**
    * 当前未收货订单数
    *
    * @param callback
    * @param type 订单状态-暂未使用
    * @param type
    *            订单状态-暂未使用
    * @param out
    */
   @RequestMapping(value = "getHistoryUnreceived")
@@ -744,10 +801,9 @@
      }
   }
   
   /**
    * 维权订单数
    *
    * @param callback
    * @param dateType
    * @param year
@@ -756,8 +812,8 @@
    * @param out
    */
   @RequestMapping(value = "getWeiQaunOrderNumber")
   public void getWeiQaunOrderNumber(String callback, Integer dateType, String year,
         String startTime, String endTime, PrintWriter out) {
   public void getWeiQaunOrderNumber(String callback, Integer dateType, String year, String startTime, String endTime,
         PrintWriter out) {
      
      String validateMsg = AdminUtils.validateParams(dateType, startTime, endTime);
      if (validateMsg != null) {
@@ -774,9 +830,9 @@
      }
   }
   
   /**
    * 维权订单金额
    *
    * @param callback
    * @param dateType
    * @param year
@@ -785,8 +841,8 @@
    * @param out
    */
   @RequestMapping(value = "getWeiQaunOrderMoney")
   public void getWeiQaunOrderMoney(String callback, Integer dateType, String year,
         String startTime, String endTime, PrintWriter out) {
   public void getWeiQaunOrderMoney(String callback, Integer dateType, String year, String startTime, String endTime,
         PrintWriter out) {
      
      String validateMsg = AdminUtils.validateParams(dateType, startTime, endTime);
      if (validateMsg != null) {
@@ -803,10 +859,9 @@
      }
   }
   
   /**
    * 统计红包信息
    *
    * @param channelArray
    * @param dateType
    * @param state
@@ -816,8 +871,8 @@
    * @return
    * @throws Exception
    */
   public JSONObject countWeiQaunOrder(Integer dateType, String year, String startTime,
         String endTime, int countType) throws Exception {
   public JSONObject countWeiQaunOrder(Integer dateType, String year, String startTime, String endTime, int countType)
         throws Exception {
      if (dateType != 1 && (!StringUtil.isNullOrEmpty(startTime) || !StringUtil.isNullOrEmpty(endTime))) {
         startTime = null;
@@ -856,7 +911,6 @@
         list = commonOrderCountService.countWeiQaunOrderMoney(dateType, year, startTime, endTime);
      }
      
      JSONObject innerList = new JSONObject();
      innerList.put("name", "总计");
@@ -873,7 +927,6 @@
      }
      
      line_list.add(innerList);
      JSONObject data = new JSONObject();
      if (objectDate != null) {