package project.web.admin.controller.report; import java.io.IOException; import java.math.BigDecimal; import java.util.Date; import java.util.Map; import javax.servlet.http.HttpServletRequest; import org.apache.commons.lang3.ObjectUtils; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.web.bind.annotation.RequestMapping; import org.springframework.web.bind.annotation.RestController; import org.springframework.web.servlet.ModelAndView; import kernel.exception.BusinessException; import kernel.util.DateUtils; import kernel.util.StringUtils; import kernel.web.Page; import kernel.web.PageActionSupport; import project.web.admin.service.report.AdminAllStatisticsService; /** * 交易所_总充提报表 */ @RestController public class ExchangeAdminAllStatisticsController extends PageActionSupport { private Logger logger = LoggerFactory.getLogger(ExchangeAdminAllStatisticsController.class); @Autowired private AdminAllStatisticsService adminAllStatisticsService; private final String action = "normal/exchangeAdminAllStatisticsAction!"; @RequestMapping(action + "list.action") public ModelAndView list(HttpServletRequest request) { String start_time = request.getParameter("start_time"); String end_time = request.getParameter("end_time"); String para_time = request.getParameter("para_time"); ModelAndView modelAndView = new ModelAndView(); int pageNo = 1; int pageSize = 30; Page page = null; try { pageNo = this.checkAndSetPageNo(request.getParameter("pageNo")); if (null == start_time && null == end_time && null == para_time) { end_time = DateUtils.format(new Date(), DateUtils.DF_yyyyMMdd); start_time = DateUtils.format(DateUtils.getMonthStart(new Date()), DateUtils.DF_yyyyMMdd); } if ("day".equals(para_time)) { // 当天 end_time = DateUtils.format(new Date(), DateUtils.DF_yyyyMMdd); start_time = end_time; } else if ("week".equals(para_time)) { // 往前推7天 end_time = DateUtils.format(new Date(), DateUtils.DF_yyyyMMdd); start_time = DateUtils.format(DateUtils.addDate(new Date(), -7), DateUtils.DF_yyyyMMdd); } else if ("month".equals(para_time)) { // 往前推一月 end_time = DateUtils.format(new Date(), DateUtils.DF_yyyyMMdd); start_time = DateUtils.format(DateUtils.addMonth(new Date(), -1), DateUtils.DF_yyyyMMdd); } else if ("all".equals(para_time)) { // 所有数据 end_time = null; start_time = null; } page = this.adminAllStatisticsService.pagedQuery(pageNo, pageSize, start_time, end_time, this.getLoginPartyId()); Map sumdata = this.adminAllStatisticsService.sumDatas(start_time, end_time, this.getLoginPartyId()); if(ObjectUtils.isNotEmpty(sumdata)) { sumdata.put("recharge", new BigDecimal(sumdata.get("recharge").toString())); sumdata.put("recharge_usdt", new BigDecimal(sumdata.get("recharge_usdt").toString())); } modelAndView.addObject("sumdata", sumdata); } catch (BusinessException e) { modelAndView.addObject("error", e.getMessage()); return modelAndView; } catch (Throwable t) { logger.error(" error ", t); modelAndView.addObject("error", "[ERROR] " + t.getMessage()); return modelAndView; } modelAndView.addObject("pageNo", pageNo); modelAndView.addObject("pageSize", pageSize); modelAndView.addObject("page", page); modelAndView.addObject("start_time", start_time); modelAndView.addObject("end_time", end_time); modelAndView.addObject("para_time", para_time); modelAndView.setViewName("statistics_all_list"); return modelAndView; } /** * 导出订单数据到文件 */ @RequestMapping(action + "exportData.action") public ModelAndView exportData(HttpServletRequest request) { String pageNo = request.getParameter("pageNo"); String start_time = request.getParameter("start_time"); String end_time = request.getParameter("end_time"); String para_time = request.getParameter("para_time"); ModelAndView modelAndView = new ModelAndView(); try { this.checkAndSetPageNo(pageNo); if (null == start_time && null == end_time && null == para_time) { end_time = DateUtils.format(new Date(), DateUtils.DF_yyyyMMdd); start_time = DateUtils.format(DateUtils.getMonthStart(new Date()), DateUtils.DF_yyyyMMdd); } if ("day".equals(para_time)) { // 当天 end_time = DateUtils.format(new Date(), DateUtils.DF_yyyyMMdd); start_time = end_time; } else if ("week".equals(para_time)) { // 往前推7天 end_time = DateUtils.format(new Date(), DateUtils.DF_yyyyMMdd); start_time = DateUtils.format(DateUtils.addDate(new Date(), -7), DateUtils.DF_yyyyMMdd); } else if ("month".equals(para_time)) { // 往前推一月 end_time = DateUtils.format(new Date(), DateUtils.DF_yyyyMMdd); start_time = DateUtils.format(DateUtils.addMonth(new Date(), -1), DateUtils.DF_yyyyMMdd); } else if ("all".equals(para_time)) { // 所有数据 end_time = null; start_time = null; } String error = this.adminAllStatisticsService.loadExportData(this.getResponse(), 30, start_time, end_time, this.getLoginPartyId()); if (!StringUtils.isNullOrEmpty(error)) { throw new BusinessException(error); } } catch (BusinessException e) { modelAndView.addObject("error", e.getMessage()); return modelAndView; } catch (IOException e) { logger.error("export fail:{}", e); modelAndView.addObject("error", "程序错误,导出异常"); return modelAndView; } catch (Throwable t) { logger.error(" error ", t); modelAndView.addObject("error", "[ERROR] " + t.getMessage()); return modelAndView; } modelAndView.addObject("start_time", start_time); modelAndView.addObject("end_time", end_time); modelAndView.addObject("para_time", para_time); modelAndView.setViewName("statistics_all_list"); return modelAndView; } }