| package com.stylefeng.guns.modular.system.controller.general; | 
|   | 
| import com.baomidou.mybatisplus.mapper.EntityWrapper; | 
| import com.stylefeng.guns.core.base.controller.BaseController; | 
| import com.stylefeng.guns.core.shiro.ShiroKit; | 
| import com.stylefeng.guns.modular.system.controller.resp.RevenueExpenditureResp; | 
| import com.stylefeng.guns.modular.system.controller.resp.TDriverCommissionResp; | 
| import com.stylefeng.guns.modular.system.controller.util.ExcelUtil; | 
| import com.stylefeng.guns.modular.system.model.TBranchOffice; | 
| import com.stylefeng.guns.modular.system.model.TDriver; | 
| import com.stylefeng.guns.modular.system.service.ITBranchOfficeService; | 
| import io.swagger.annotations.ApiImplicitParam; | 
| import io.swagger.annotations.ApiImplicitParams; | 
| import io.swagger.annotations.ApiOperation; | 
| import org.apache.poi.hssf.usermodel.HSSFWorkbook; | 
| import org.springframework.stereotype.Controller; | 
| import org.springframework.web.bind.annotation.RequestMapping; | 
| import org.springframework.web.bind.annotation.ResponseBody; | 
| import org.springframework.ui.Model; | 
| import org.springframework.web.bind.annotation.PathVariable; | 
| import org.springframework.beans.factory.annotation.Autowired; | 
| import com.stylefeng.guns.core.log.LogObjectHolder; | 
| import org.springframework.web.bind.annotation.RequestParam; | 
| import com.stylefeng.guns.modular.system.model.TRevenue; | 
| import com.stylefeng.guns.modular.system.service.ITRevenueService; | 
|   | 
| import javax.servlet.http.HttpServletResponse; | 
| import java.io.OutputStream; | 
| import java.math.BigDecimal; | 
| import java.text.DateFormat; | 
| import java.text.SimpleDateFormat; | 
| import java.util.Date; | 
| import java.util.List; | 
| import java.util.Objects; | 
|   | 
| /** | 
|  * 控制器 | 
|  * | 
|  * @author fengshuonan | 
|  * @Date 2023-03-13 09:49:19 | 
|  */ | 
| @Controller | 
| @RequestMapping("/tRevenue") | 
| public class TRevenueController extends BaseController { | 
|   | 
|     private String PREFIX = "/system/tRevenue/"; | 
|   | 
|     @Autowired | 
|     private ITRevenueService tRevenueService; | 
|     @Autowired | 
|     private ITBranchOfficeService branchOfficeService; | 
|   | 
|     /** | 
|      * 跳转到首页 | 
|      */ | 
|     @RequestMapping("") | 
|     public String index(Model model) { | 
|         model.addAttribute("branchOfficeList",branchOfficeService.selectList(new EntityWrapper<TBranchOffice>().eq("status",1))); | 
|         return PREFIX + "tRevenue.html"; | 
|     } | 
|   | 
|     /** | 
|      * 跳转到添加 | 
|      */ | 
|     @RequestMapping("/tRevenue_add") | 
|     public String tRevenueAdd() { | 
|         return PREFIX + "tRevenue_add.html"; | 
|     } | 
|   | 
|     /** | 
|      * 跳转到修改 | 
|      */ | 
|     @RequestMapping("/tRevenue_update/{tRevenueId}") | 
|     public String tRevenueUpdate(@PathVariable Integer tRevenueId, Model model) { | 
|         TRevenue tRevenue = tRevenueService.selectById(tRevenueId); | 
|         model.addAttribute("item",tRevenue); | 
|         LogObjectHolder.me().set(tRevenue); | 
|         return PREFIX + "tRevenue_edit.html"; | 
|     } | 
|   | 
|     /** | 
|      * 跳转到佣金提现详情 | 
|      */ | 
|     @RequestMapping("/commissionDetail") | 
|     public String commissionDetail(String code, Model model) { | 
|         tRevenueService.commissionDetail(code,model); | 
|         return PREFIX + "tRevenueCommissionDetail.html"; | 
|     } | 
|   | 
|     /** | 
|      * 跳转到余额提现详情 | 
|      */ | 
|     @RequestMapping("/balanceDetail") | 
|     public String balanceDetail(String code, Model model) { | 
|         tRevenueService.balanceDetail(code,model); | 
|         return PREFIX + "tRevenueBalanceDetail.html"; | 
|     } | 
|   | 
|     /** | 
|      * 跳转到支付订单详情 | 
|      */ | 
|     @RequestMapping("/orderDetail") | 
|     public String orderDetail(String code, Model model) { | 
|         tRevenueService.orderDetail(code,model); | 
|         return PREFIX + "tRevenueOrderDetail.html"; | 
|     } | 
|   | 
|     /** | 
|      * 获取列表 | 
|      */ | 
|     @RequestMapping(value = "/list") | 
|     @ResponseBody | 
|     public Object list(String code,Integer businessType,Integer payType,String driverName,String businessTime,Integer branchOfficeId) { | 
|         return tRevenueService.getPageList(code,businessType,payType,driverName,businessTime,branchOfficeId); | 
|     } | 
|   | 
|     /** | 
|      * 获取列表 | 
|      */ | 
|     @RequestMapping(value = "/list-back") | 
|     @ResponseBody | 
|     public Object listBack(String condition) { | 
|         return tRevenueService.selectList(null); | 
|     } | 
|   | 
|     /** | 
|      * 新增 | 
|      */ | 
|     @RequestMapping(value = "/add") | 
|     @ResponseBody | 
|     public Object add(TRevenue tRevenue) { | 
|         tRevenueService.insert(tRevenue); | 
|         return SUCCESS_TIP; | 
|     } | 
|   | 
|     /** | 
|      * 删除 | 
|      */ | 
|     @RequestMapping(value = "/delete") | 
|     @ResponseBody | 
|     public Object delete(@RequestParam Integer tRevenueId) { | 
|         tRevenueService.deleteById(tRevenueId); | 
|         return SUCCESS_TIP; | 
|     } | 
|   | 
|     /** | 
|      * 修改 | 
|      */ | 
|     @RequestMapping(value = "/update") | 
|     @ResponseBody | 
|     public Object update(TRevenue tRevenue) { | 
|         tRevenueService.updateById(tRevenue); | 
|         return SUCCESS_TIP; | 
|     } | 
|   | 
|     /** | 
|      * 详情 | 
|      */ | 
|     @RequestMapping(value = "/detail/{tRevenueId}") | 
|     @ResponseBody | 
|     public Object detail(@PathVariable("tRevenueId") Integer tRevenueId) { | 
|         return tRevenueService.selectById(tRevenueId); | 
|     } | 
|   | 
|     @ApiOperation(value = "导出收支明细列表",notes="导出收支明细列表") | 
|     @RequestMapping(value = "/export") | 
|     @ResponseBody | 
|     public void export(String code,Integer businessType,Integer payType,String driverName,String businessTime,Integer branchOfficeId, HttpServletResponse response) { | 
|         try { | 
|             Date date = new Date(); | 
|             DateFormat format = new SimpleDateFormat("yyyyMMdd"); | 
|             String time1 = format.format(date); | 
|             String fileName = "RevenueExpenditureDetailsInfo"+time1+".xls"; | 
|             String[] title = new String[] {"订单号","交易时间","交易类型","司机姓名","司机电话", | 
|                     "支付类型","金额","佣金提成","优惠券","余额","状态"}; | 
|             List<RevenueExpenditureResp> pageList = tRevenueService.getPageList(code, businessType, payType, driverName, businessTime,branchOfficeId); | 
|   | 
|             String[][] values = new String[pageList.size()][]; | 
|             for (int i = 0; i < pageList.size(); i++) { | 
|                 RevenueExpenditureResp d = pageList.get(i); | 
|                 values[i] = new String[title.length]; | 
|                 values[i][0] = d.getCode(); | 
|                 values[i][1] = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(d.getBusinessTime()); | 
|                 Integer businessType1 = d.getBusinessType(); | 
|                 if(1 == businessType1){ | 
|                     values[i][2] = "支付订单"; | 
|                 }else if (11 == businessType1){ | 
|                     values[i][2] = "佣金提现"; | 
|                 }else if (12 == businessType1){ | 
|                     values[i][2] = "余额提现"; | 
|                 } | 
|                 values[i][3] = d.getDriverName(); | 
|                 values[i][4] = d.getDriverPhone(); | 
|                 Integer payType1 = d.getPayType(); | 
|                 if(1 == payType1){ | 
|                     values[i][5] = "微信支付"; | 
|                 }else if (2 == payType1){ | 
|                     values[i][5] = "余额支付"; | 
|                 }else if (3 == payType1){ | 
|                     values[i][5] = "线下收款"; | 
|                 } | 
|                 values[i][6] = String.valueOf(Objects.isNull(d.getAmount())? BigDecimal.ZERO :d.getAmount()); | 
|                 values[i][7] = String.valueOf(Objects.isNull(d.getCommissionAmount())? BigDecimal.ZERO :d.getCommissionAmount()); | 
|                 values[i][8] = String.valueOf(Objects.isNull(d.getDiscountedPrice())? BigDecimal.ZERO :d.getDiscountedPrice()); | 
|                 values[i][9] = String.valueOf(Objects.isNull(d.getAccountBalance())? BigDecimal.ZERO :d.getAccountBalance()); | 
|                 Integer state = d.getState(); | 
|                 if(2 == state){ | 
|                     values[i][10] = "完成"; | 
|                 }else if(108 == state){ | 
|                     values[i][10] = "完成"; | 
|                 }else if(109 == state){ | 
|                     values[i][10] = "完成"; | 
|                 } | 
|             } | 
|             HSSFWorkbook wb = ExcelUtil.getHSSFWorkbook("Variance"+time1, title, values, null); | 
|             ExcelUtil.setResponseHeader(response, fileName); | 
|             OutputStream os = response.getOutputStream(); | 
|             wb.write(os); | 
|             os.flush(); | 
|             os.close(); | 
|         } catch (Exception e) { | 
|             e.printStackTrace(); | 
|         } | 
|     } | 
| } |