package com.ruoyi.order.controller; import cn.afterturn.easypoi.excel.ExcelExportUtil; import cn.afterturn.easypoi.excel.entity.ExportParams; import com.alibaba.fastjson2.JSONObject; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.core.metadata.IPage; import com.ruoyi.account.api.feignClient.AppUserClient; import com.ruoyi.account.api.model.AppUser; import com.ruoyi.common.core.domain.R; import com.ruoyi.common.core.utils.StringUtils; import com.ruoyi.common.core.utils.WebUtils; import com.ruoyi.common.core.utils.poi.ExcelUtil; import com.ruoyi.common.core.web.controller.BaseController; import com.ruoyi.common.core.web.page.PageInfo; import com.ruoyi.common.core.web.page.TableDataInfo; import com.ruoyi.common.security.service.TokenService; import com.ruoyi.order.dto.ConfirmOrderDTO; import com.ruoyi.order.enums.OrderStatus; import com.ruoyi.order.export.ChargeOrderExport; import com.ruoyi.order.mapper.OrderMapper; import com.ruoyi.order.model.ChargeOrder; import com.ruoyi.order.model.Order; import com.ruoyi.order.service.ChargeOrderService; import com.ruoyi.order.service.OrderService; import com.ruoyi.order.util.payment.wechat.PayMoneyUtil; import com.ruoyi.order.util.payment.wx.WechatPayService; import com.ruoyi.order.util.payment.wx.vo.PayResult; import com.ruoyi.order.util.vo.ShopAnalysisVO; import com.ruoyi.order.vo.*; import com.ruoyi.other.api.domain.BaseSetting; import com.ruoyi.other.api.domain.Goods; import com.ruoyi.other.api.domain.Shop; import com.ruoyi.other.api.dto.ShopAnalysisDTO; import com.ruoyi.other.api.feignClient.BaseSettingClient; import com.ruoyi.other.api.feignClient.ShopClient; import com.ruoyi.system.api.feignClient.SysUserClient; import com.ruoyi.system.api.model.LoginUser; import io.swagger.annotations.Api; import io.swagger.annotations.ApiImplicitParam; import io.swagger.annotations.ApiImplicitParams; import io.swagger.annotations.ApiOperation; import org.apache.poi.ss.usermodel.Workbook; import org.springframework.util.CollectionUtils; import org.springframework.web.bind.annotation.*; import org.springframework.web.multipart.MultipartFile; import javax.annotation.Resource; import javax.servlet.ServletOutputStream; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import java.io.IOException; import java.io.PrintWriter; import java.math.BigDecimal; import java.net.URLEncoder; import java.time.LocalDate; import java.time.LocalDateTime; import java.time.LocalTime; import java.util.*; import java.util.stream.Collectors; /** *

* 前端控制器 *

* * @author luodangjia * @since 2024-11-21 */ @Api(tags = "订单") @RestController @RequestMapping("/order") public class OrderController extends BaseController { @Resource private OrderService orderService; @Resource private ChargeOrderService chargeOrderService; @Resource private TokenService tokenService; @Resource private BaseSettingClient baseSettingClient; @Resource private OrderMapper orderMapper; @Resource private SysUserClient sysUserClient; @Resource private AppUserClient appUserClient; @Resource private ShopClient shopClient; @Resource private PayMoneyUtil payMoneyUtil; @Resource private WechatPayService wechatPayService; @ResponseBody @PostMapping("/confirmOrder") @ApiOperation(value = "确定订单", tags = {"商城-订单-小程序-确定订单"}) public R confirmOrder(@RequestBody ConfirmOrderDTO confirmOrderDTO) { ConfirmOrderVo confirmOrderVo = orderService.confirmOrder(confirmOrderDTO.getGoodId(),confirmOrderDTO.getType()); return R.ok(confirmOrderVo); } @ResponseBody @PostMapping("/orderPayment") @ApiOperation(value = "订单支付", tags = {"商城-订单支付-小程序-订单支付"}) public R orderPayment(@RequestBody OrderPayment orderPayment){ return orderService.orderPayment(orderPayment); } /** * 订单支付回调通知 */ @ResponseBody @PostMapping("/orderPaymentCallback") public void orderPaymentCallback(HttpServletRequest request, HttpServletResponse response){ // String jsonString = JSONObject.toJSONString(uniPayCallbackResult); System.err.println("1111111111111"); PayResult payResult= null; try { payResult = wechatPayService.processNotify(request); } catch (Exception e) { throw new RuntimeException(e); } System.out.println("1111111111111111111111"); // System.out.println(jsonString); R callback = orderService.orderPaymentCallback(payResult); if(callback.getCode() == 200){ response.setStatus(200); PrintWriter out = null; try { out = response.getWriter(); } catch (IOException e) { throw new RuntimeException(e); } out.println("success"); out.flush(); out.close(); } } /** * 我的订单列表 */ @ApiOperation(value = "我的订单列表", tags = {"小程序-个人中心-我的订单-我的订单列表"}) @ApiImplicitParams({ @ApiImplicitParam(value = "订单状态", name = "status", required = true, dataType = "int"), }) @GetMapping("/getMyOrderList") public TableDataInfo getMyOrderList(@RequestParam(value = "status",required = false) Integer status) { startPage(); LoginUser loginUserApplet = tokenService.getLoginUserApplet(); return getDataTable(orderService.selectOrderListByUserId(status, loginUserApplet.getUserid())); } /** * 通过订单ids获取订单列表 */ @PostMapping("/getOrderListByIds") public R> getOrderListByIds(@RequestBody List ids) { return R.ok(orderService.listByIds(ids)); } /** * 订单详情 */ @ApiOperation(value = "订单详情", tags = {"小程序-个人中心-我的订单-订单详情"}) @ApiImplicitParams({ @ApiImplicitParam(value = "订单id", name = "orderId", required = true, dataType = "int"), }) @GetMapping("/detail/{orderId}") public R detail(@PathVariable("orderId") Long orderId) { return R.ok(orderService.getOrderDetail(orderId)); } /** * 扫码校验 */ @ApiOperation(value = "扫码校验", tags = {"小程序-个人中心-门店管理-扫码校验"}) @GetMapping("/check/{orderNumber}/{shopId}") public R check(@PathVariable("orderNumber") String orderNumber, @PathVariable("shopId") Integer shopId) { LoginUser loginUserApplet = tokenService.getLoginUserApplet(); Order order = orderService.getOne(new LambdaQueryWrapper() .eq(Order::getId, orderNumber)); return R.ok(orderService.check(order, shopId, loginUserApplet.getUserid())); } /** * 订单核销 */ @ApiOperation(value = "订单核销", tags = {"小程序-个人中心-门店管理-订单核销"}) @GetMapping("/writeOff") public R writeOff(@RequestParam("id") String id, @RequestParam("shopId") Integer shopId) { orderService.writeOff(id, shopId); return R.ok(); } @GetMapping("/getShopOrderList") @ApiOperation(value = "获取订单列表", tags = {"门店后台-订单管理-获取订单列表"}) public R> getShopOrderList(@RequestParam(value = "content",required = false) String content , @RequestParam(value = "status",required = false) Integer status, @RequestParam("shopId") Integer shopId, @RequestParam("pageNum") Integer pageNum, @RequestParam("pageSize") Integer pageSize) { return R.ok(orderService.getShopOrderList(content,status,shopId,pageNum,pageSize)); } @PostMapping("/importExpress") @ApiOperation(value = "2.0新增导入订单", tags = {"门店后台-订单管理-2.0新增导入订单"}) public R importExpress(@RequestParam("file") MultipartFile file) { /* JSONObject jsonObject = JSONObject.parseObject(url); String url2 = jsonObject.getString("url");*/ if (file.isEmpty()) { return R.fail("请选择要上传的文件"); } return orderService.importExpress(file); } @ApiOperation(value = "2.0订单导入模板下载", tags = {"门店后台-订单管理-2.0订单导入模板下载"}) @GetMapping("/importOrder") public void importOrder() { List orderExports = new ArrayList<>(); Workbook workbook = ExcelExportUtil.exportExcel(new ExportParams(), OrderExport.class, orderExports); HttpServletResponse response = WebUtils.response(); ServletOutputStream outputStream = null; try { String fileName = URLEncoder.encode("订单导入模板.xls", "utf-8"); response.setHeader("Content-Disposition", "attachment;filename=" + fileName); response.setHeader("content-Type", "application/vnd.ms-excel"); response.setHeader("Pragma", "no-cache"); response.setHeader("Cache-Control", "no-cache"); outputStream = response.getOutputStream(); workbook.write(outputStream); } catch (IOException e) { e.printStackTrace(); System.out.println("订单导入模板下载失败!"); } finally { try { outputStream.close(); } catch (IOException e) { e.printStackTrace(); } } } @PutMapping("/shopCancelOrder/{orderId}") @ApiOperation(value = "取消订单", tags = {"门店后台-订单管理-取消订单"}) public R shopCancelOrder(@PathVariable("orderId") Long orderId) { return orderService.shopCancelOrder(orderId); } /** * 取消订单 */ @ApiOperation(value = "取消订单小程序", tags = {"小程序-个人中心-我的订单-取消订单小程序"}) @ApiImplicitParams({ @ApiImplicitParam(value = "订单id", name = "orderId", required = true, dataType = "int"), }) @GetMapping("/cancel/{orderId}") public R cancel(@PathVariable("orderId") Long orderId) { return orderService.cancel(orderId); } /** * 确认收货 */ @ApiOperation(value = "确认收货", tags = {"小程序-个人中心-我的订单-确认收货"}) @ApiImplicitParams({ @ApiImplicitParam(value = "订单id", name = "orderId", required = true, dataType = "int"), }) @GetMapping("/confirm/{orderId}") public R confirm(@PathVariable("orderId") Long orderId) { R baseSettingR = baseSettingClient.getBaseSetting(5); if (R.isError(baseSettingR)) { return R.fail("售后设置获取失败"); } BaseSetting baseSetting = baseSettingR.getData(); if (baseSetting == null) { return R.fail("售后设置获取失败"); } String content = baseSetting.getContent(); JSONObject jsonObject = JSONObject.parseObject(content); Long days = jsonObject.getLong("days"); Order order = orderService.getById(orderId); order.setAfterSaleTime(LocalDateTime.now().plusDays(days)); order.setOrderStatus(OrderStatus.COMPLETED.getCode()); orderService.updateById(order); return R.ok(); } /** * 更新订单状态 */ @ApiOperation(value = "更新订单状态", tags = {"后台-订单管理-更新订单状态"}) @ApiImplicitParams({ @ApiImplicitParam(value = "订单对象", name = "order", required = true, dataType = "Order"), }) @PostMapping("/updateOrderStatus") public R updateOrderStatus(@RequestBody Order order) { Order order1 = orderService.getById(order.getId()); order1.setOrderStatus(order.getOrderStatus()); order1.setOldOrderStatus(order.getOldOrderStatus()); orderService.updateById(order1); return R.ok(); } @PostMapping("/getLastOrder") public R getLastOrder(@RequestParam("appUserId") Long appUserId) { Order one = orderService.lambdaQuery().eq(Order::getAppUserId, appUserId).orderByDesc(Order::getCreateTime).last("limit 1").one(); return R.ok(one); } @PostMapping("/byUserId") public R> byUserId(@RequestParam("appUserId") Long appUserId, @RequestParam("shopId") Integer shopId) { List list = orderService.lambdaQuery() .eq(Order::getAppUserId, appUserId) .eq(null != shopId && -1 != shopId, Order::getShopId, shopId) .eq(Order::getPayStatus, 2) .isNull(Order::getRefundStatus) .eq(Order::getDelFlag, 0) .notIn(Order::getOrderStatus, 5, 6).list(); return R.ok(list); } @PostMapping("/byShopId") public R> byShopId(@RequestParam("shopId") Integer shopId) { return R.ok(orderService.lambdaQuery().isNotNull(Order::getEndTime).eq(Order::getShopId, shopId).list()); } @PostMapping("/byShopIdAndUserId") public R> byShopIdAndUserId(@RequestParam("appUserId") Long appUserId, @RequestParam("shopId") Integer shopId) { List list = orderService.lambdaQuery().isNotNull(Order::getEndTime) .eq(null != shopId && -1 != shopId, Order::getShopId, shopId) .eq(Order::getAppUserId, appUserId) .eq(Order::getPayStatus, 2) .isNull(Order::getRefundStatus) .eq(Order::getDelFlag, 0) .notIn(Order::getOrderStatus, 5, 6).list(); return R.ok(list); } @PutMapping("/cancelOrder/{orderId}") @ApiOperation(value = "取消订单操作", tags = {"后台-订单管理-取消订单操作"}) public R cancelOrder(@PathVariable("orderId") Long orderId) { return orderService.cancelOrder(orderId); } @PutMapping("/receivingOperation/{orderId}") @ApiOperation(value = "收货操作", tags = {"管理后台-订单管理-收货操作"}) public R receivingOperation(@PathVariable("orderId") Long orderId) { return orderService.receivingOperation(orderId); } @GetMapping("/getOrderInfo/{orderId}") @ApiOperation(value = "查询订单详情", tags = {"管理后台-订单管理-查询订单详情"}) public R getOrderInfo(@PathVariable("orderId") Long orderId) { OrderInfoVo orderInfo = orderService.getOrderInfo(orderId); return R.ok(orderInfo); } @GetMapping("/getOrderPageList") // @ApiOperation(value = "获取订单列表后台", tags = {"管理后台-订单管理-获取订单列表后台"}) public R> getOrderPageList(OrderPageList orderPageList) { return R.ok(orderService.getOrderPageList(orderPageList)); } @PostMapping("/queryOrderPageList") @ApiOperation(value = "获取订单列表后台", tags = {"管理后台-订单管理-获取订单列表后台"}) public R> queryOrderPageList(@RequestBody OrderPageList orderPageList) { return R.ok(orderService.getOrderPageList(orderPageList)); } /** * 订单统计 */ /* @GetMapping("/getOrderStatistics") //@ApiOperation(value = "订单统计", tags = {"管理后台-首页统计"}) public R getOrderStatistics(@RequestParam("startTime") String startTime, @RequestParam("endTime") String endTime) { Long userid = tokenService.getLoginUser().getUserid(); SysUser sysUser = sysUserClient.getSysUser(userid).getData(); LambdaQueryWrapper wrapper = new LambdaQueryWrapper() .in(Order::getOrderStatus, Arrays.asList(1, 2, 3, 4, 7, 8)) .eq(Order::getPayStatus, 2) .eq(Order::getDelFlag, 0) .between(Order::getCreateTime, LocalDateTime.parse(startTime, DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss")), LocalDateTime.parse(endTime, DateTimeFormatter.ofPattern("yyyy-MM-dd HH:mm:ss"))) .orderByAsc(Order::getCreateTime); if(sysUser.getRoleType() == 2){ //门店只拥有服务订单和自提商品订单 wrapper.eq(Order::getShopId, sysUser.getObjectId()).eq(Order::getOrderType, 1).or().eq(Order::getOrderType, 2).eq(Order::getDistributionMode, 1); } List orderList = orderService.list(wrapper); Map> map = orderList.stream() .collect(Collectors.groupingBy( item -> item.getCreateTime().format(DateTimeFormatter.ofPattern("yyyy-MM-dd")), TreeMap::new, // 使用 TreeMap 按键排序 Collectors.toList() )); List orderStatisticsDetails = new ArrayList<>(); map.forEach((key, value) -> { int serviceTotal = 0; int singleTotal = 0; int total = 0; BigDecimal totalMoney = BigDecimal.ZERO; BigDecimal serviceTotalMoney = BigDecimal.ZERO; BigDecimal singleTotalMoney = BigDecimal.ZERO; OrderStatisticsDetail orderStatisticsDetail = new OrderStatisticsDetail(); for (Order order : value) { if (order.getOrderType().equals(1)) { serviceTotal++; serviceTotalMoney = serviceTotalMoney.add(order.getTotalAmount()); total++; totalMoney = totalMoney.add(order.getTotalAmount()); } else if (order.getOrderType().equals(2)) { singleTotal++; singleTotalMoney = singleTotalMoney.add(order.getTotalAmount()); total++; totalMoney = totalMoney.add(order.getTotalAmount()); } } orderStatisticsDetail.setDate(key); orderStatisticsDetail.setServiceTotal(serviceTotal); orderStatisticsDetail.setSingleTotal(singleTotal); orderStatisticsDetail.setTotal(total); orderStatisticsDetail.setServiceTotalMoney(serviceTotalMoney); orderStatisticsDetail.setSingleTotalMoney(singleTotalMoney); orderStatisticsDetail.setTotalMoney(totalMoney); orderStatisticsDetails.add(orderStatisticsDetail); }); Integer shopId = null; if (sysUser.getRoleType() == 2) { shopId = sysUser.getObjectId(); } OrderStatistics orderStatistics = orderMapper.getOrderStatistics(startTime, endTime, shopId); if (null != orderStatistics) { SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd"); List sortedDetails = orderStatisticsDetails.stream() .sorted(Comparator.comparing((OrderStatisticsDetail detail) -> { try { return dateFormat.parse(detail.getDate()); } catch (ParseException e) { throw new RuntimeException(e); } })) .collect(Collectors.toList()); orderStatistics.setOrderStatisticsDetailList(sortedDetails); } return R.ok(orderStatistics); } */ /** * 订单取消支付回退 */ @ResponseBody @PostMapping("/refundPayMoneyCallback") public String refundPayMoneyCallback( @RequestBody(required = false) String xmlData) { R callback = orderService.refundPayMoneyCallback(xmlData); if (callback.getCode() == 200) { return ""; }else { System.err.println("支付回退错误:"+callback.getMsg()); return ""; } } /** * 获取商品销售数量 * * @return */ @PostMapping(value = "/getList") R> getList(@RequestParam("siteId") Integer siteId) { List list = chargeOrderService.lambdaQuery().eq(ChargeOrder::getPowerStationId, siteId).list(); return R.ok(list); } /** * 获取商品销售数量 * * @param goodsId * @return */ @PostMapping("/getGoodsSaleNum") public R getGoodsSaleNum(@RequestParam("goodsId") Integer goodsId, @RequestParam("type") Integer type) { Integer goodsSaleNum = orderService.getGoodsSaleNum(goodsId, type, null); return R.ok(goodsSaleNum); } /** * 获取门店销售订单数量 * * @param shopId 门店id * @param type 1:服务订单,2:单品订单 * @return */ @PostMapping("/getShopSaleNum") public R getShopSaleNum(@RequestParam("shopId") Integer shopId, @RequestParam("type") Integer type) { Integer shopSaleNum = orderService.getShopSaleNum(shopId, type); return R.ok(shopSaleNum); } @PostMapping("/getShopSaleNumByShopIds") public R getShopSaleNumByShopIds(@RequestBody OrderSaleNum orderSaleNum) { Integer shopSaleNum = orderService.getShopSaleNumByShopIds(orderSaleNum.getShopIds(), orderSaleNum.getType()); return R.ok(shopSaleNum); } /** * 获取所有在指定门店消费的用户id * * @param shopId * @return */ @PostMapping("/getAppUserByShoppingShop") public R> getAppUserByShoppingShop(@RequestParam("shopId") Integer shopId) { List list = orderService.list(new LambdaQueryWrapper().eq(Order::getShopId, shopId).eq(Order::getDelFlag, 0) .eq(Order::getPayStatus, 2).in(Order::getOrderStatus, Arrays.asList(1, 2, 3, 4, 7, 8))); Set collect = list.stream().map(Order::getAppUserId).collect(Collectors.toSet()); return R.ok(collect); } /** * 获取指定门店的核销订单 */ @GetMapping("/getRedeemedOrdersByShop") public R> getRedeemedOrdersByShop(@RequestParam("shopId") Integer shopId) { return R.ok(orderService.list(new LambdaQueryWrapper() .isNotNull(Order::getEndTime) .eq(Order::getShopId, shopId))); } /* *//** * 获取订单快递明细 * * @param id * @return *//* @GetMapping("/getOrderExpress/{id}") //@ApiOperation(value = "获取订单快递明细", tags = {"小程序-订单管理"}) public R getOrderExpress(@PathVariable("id") Long id) { Order order = orderService.getById(id); String expressResult = order.getExpressResult(); if (StringUtils.isNotEmpty(expressResult)) { MapTrackKD100Vo mapTrackKD100Vo = JSON.parseObject(expressResult, MapTrackKD100Vo.class); return R.ok(mapTrackKD100Vo); } return R.ok(); } */ /** * 根据id获取订单详情 * * @param id * @return */ @PostMapping("/getOrderById") public R getOrderById(@RequestParam("id") Long id) { Order order = orderService.getById(id); return R.ok(order); } /** * 修改订单 * * @param order * @return */ @PostMapping("/editOrder") public R editOrder(@RequestBody Order order) { orderService.updateById(order); return R.ok(); } /** * 导出订单信息 */ @GetMapping("/exportExpress") public void exportExpress(HttpServletResponse response, OrderPageList orderPage) { /* //搜索条件,用户姓名 if (StringUtils.isNotEmpty(orderPage.getUserName())) { List data = appUserClient.getAppUserByNameNoFilter(orderPage.getUserName()).getData(); List collect = data.stream().map(AppUser::getId).collect(Collectors.toList()); if (CollectionUtils.isEmpty(collect)) { return; } if (null != orderPage.getAppUserIds()) { List appUserIds = orderPage.getAppUserIds(); appUserIds.addAll(collect); orderPage.setAppUserIds(appUserIds); } else { orderPage.setAppUserIds(collect); } }*/ //搜索条件,用户电话 if (StringUtils.isNotEmpty(orderPage.getPhone())) { List data = appUserClient.getAppUserByPhoneNoFilter(orderPage.getPhone()).getData(); List collect = data.stream().map(AppUser::getId).collect(Collectors.toList()); if (CollectionUtils.isEmpty(collect)) { return; } if (null != orderPage.getAppUserIds()) { List appUserIds = orderPage.getAppUserIds(); if (!containsAny(appUserIds, collect)) { return; } appUserIds.addAll(collect); orderPage.setAppUserIds(appUserIds); } else { orderPage.setAppUserIds(collect); } } if (null != orderPage.getAppUserIds()) { orderPage.setAppUserIds(orderPage.getAppUserIds().stream().distinct().collect(Collectors.toList())); } //搜索条件 店铺名称 if (StringUtils.isNotEmpty(orderPage.getShopName())){ List shopSet = new ArrayList<>(shopClient.getShopIdByName(orderPage.getShopName()).getData()); if (CollectionUtils.isEmpty(shopSet)) { return ; } if (null != orderPage.getShopIds()) { List shopIds = orderPage.getShopIds(); if (!containsIntegerAny(shopIds, shopSet)) { return ; } shopIds.addAll(shopSet); orderPage.setShopIds(shopIds); } else { orderPage.setShopIds(shopSet); } } if (null != orderPage.getShopIds()) { orderPage.setShopIds(orderPage.getShopIds().stream().distinct().collect(Collectors.toList())); } List orderExportList = orderMapper.getOrderExportList(orderPage); orderExportList.forEach(orderExport -> { Long appUserId = orderExport.getAppUserId(); AppUser appUserById = appUserClient.getAppUserById(appUserId); if (null != appUserById) { orderExport.setUserName(appUserById.getName()); orderExport.setPhone(appUserById.getPhone()); } String goodJson = orderExport.getGoodJson(); if (StringUtils.isNotEmpty(goodJson) && !"NULL".equals(goodJson)) { Goods goods = JSONObject.parseObject(goodJson, Goods.class); orderExport.setGoodsName(goods.getName()); /* orderExport.setCompanyCostPrice(goods.getOperatingCost()); orderExport.setSupplierCostPrice(goods.getShopCost());*/ } }); List data = shopClient.getAllShop().getData(); // 转化为map Map shopMap = data.stream().collect(Collectors.toMap(Shop::getId, shop -> shop)); for (OrderExport orderExport : orderExportList) { Shop shop = shopMap.get(orderExport.getShopId()); if (shop!=null){ orderExport.setShopName(shop.getName()); } } ExcelUtil util = new ExcelUtil(OrderExport.class); util.exportExcel(response, orderExportList, "订单数据"); } /** * 判断 list1 是否包含 list2 中的至少一个元素 * * @param list1 第一个列表 * @param list2 第二个列表 * @return 如果 list1 包含 list2 中的至少一个元素,返回 true;否则返回 false */ private boolean containsAny(List list1, List list2) { // 将 list1 转换为 HashSet 以提高查询效率 Set set1 = new HashSet<>(list1); // 遍历 list2,检查是否有元素存在于 set1 中 for (Long element : list2) { if (set1.contains(element)) { return true; } } // 如果没有找到共同元素,返回 false return false; } /** * 判断 list1 是否包含 list2 中的至少一个元素 * * @param list1 第一个列表 * @param list2 第二个列表 * @return 如果 list1 包含 list2 中的至少一个元素,返回 true;否则返回 false */ private boolean containsIntegerAny(List list1, List list2) { // 将 list1 转换为 HashSet 以提高查询效率 Set set1 = new HashSet<>(list1); // 遍历 list2,检查是否有元素存在于 set1 中 for (Integer element : list2) { if (set1.contains(element)) { return true; } } // 如果没有找到共同元素,返回 false return false; } /** * 获取用户订单数量 * * @param appUserId * @return */ @PostMapping("/getOrderCountByAppUserId") public R getOrderCountByAppUserId(@RequestParam("id") Long appUserId) { long count = orderService.count(new LambdaQueryWrapper().eq(Order::getDelFlag, 0) .eq(Order::getAppUserId, appUserId) .in(Order::getOrderStatus, Arrays.asList(1, 2, 3, 4, 7, 8)) .eq(Order::getPayStatus, 2) ); return R.ok(count); } /** * 工作台统计 */ @PostMapping("/homeStatistics/getShopAnalysis") @ApiOperation(value = "店铺分析", tags = {"后台-工作台-店铺统计"}) public R getShopAnalysis(@RequestBody ShopAnalysisDTO shopAnalysisDTO) { ShopAnalysisVO shopAnalysisVO = new ShopAnalysisVO(); if (shopAnalysisDTO.getStartTime() == null || shopAnalysisDTO.getEndTime() == null) { LocalDate now = LocalDate.now(); shopAnalysisDTO.setStartTime(now.minusDays(6)); // 7天前 shopAnalysisDTO.setEndTime(now); } else if (shopAnalysisDTO.getStartTime().isAfter(shopAnalysisDTO.getEndTime())) { return R.fail("开始时间不能大于结束时间"); } /* // 限制最大查询范围不超过3个月(可选) else if (Duration.between(shopAnalysisDTO.getStartTime(), shopAnalysisDTO.getEndTime()).toDays() > 90) { return R.fail("查询时间范围不能超过90天"); }*/ //订单统计 QueryWrapper queryWrapper = new QueryWrapper<>(); queryWrapper.select("count(*) as total","SUM(total_amount) as total_money"); queryWrapper.eq("del_flag", 0); queryWrapper.in("order_status", Arrays.asList(3,4,8));//待核销 已完成 已评价 queryWrapper.eq("pay_status",2); queryWrapper.ge("create_time", shopAnalysisDTO.getStartTime().atStartOfDay()); queryWrapper.le("create_time", shopAnalysisDTO.getEndTime().atTime(LocalTime.MAX)); if (null!=shopAnalysisDTO.getShopId()){ queryWrapper.eq("shop_id", shopAnalysisDTO.getShopId()); } Map result = orderService.getMap(queryWrapper); if (result == null || result.get("total") == null) { shopAnalysisVO.setTotal(0); }else { shopAnalysisVO.setTotal(Integer.valueOf(result.get("total").toString())); } if (result == null || result.get("total_money") == null) { shopAnalysisVO.setTotalMoney(BigDecimal.ZERO); }else { shopAnalysisVO.setTotalMoney(new BigDecimal(result.get("total_money").toString())); } //收益分析 Map shopResult =shopClient.getIncomeAnalysis(shopAnalysisDTO).getData(); if (shopResult!=null){ if (shopResult.get("balance")==null||shopResult.get("canWithdrawMoney")==null){ shopAnalysisVO.setCanWithdrawMoney(BigDecimal.ZERO); shopAnalysisVO.setFreezeMoney(BigDecimal.ZERO); }else { shopAnalysisVO.setCanWithdrawMoney(new BigDecimal(shopResult.get("canWithdrawMoney").toString())); shopAnalysisVO.setFreezeMoney(new BigDecimal(shopResult.get("balance").toString()).subtract(shopAnalysisVO.getCanWithdrawMoney())); } if (shopResult.get("withdrawMoney")==null){ shopAnalysisVO.setWithdrawMoney(BigDecimal.ZERO); }else { shopAnalysisVO.setWithdrawMoney(new BigDecimal(shopResult.get("withdrawMoney").toString())); } if (shopResult.get("withdrawAuditMoney")==null){ shopAnalysisVO.setWithdrawAuditMoney(BigDecimal.ZERO); }else { shopAnalysisVO.setWithdrawAuditMoney(new BigDecimal(shopResult.get("withdrawAuditMoney").toString())); } }else { shopAnalysisVO.setCanWithdrawMoney(BigDecimal.ZERO); shopAnalysisVO.setFreezeMoney(BigDecimal.ZERO); shopAnalysisVO.setWithdrawMoney(BigDecimal.ZERO); shopAnalysisVO.setWithdrawAuditMoney(BigDecimal.ZERO); } //折线图 List orderStatisticsDetailList=orderService.getOrderListGroupByDate(shopAnalysisDTO.getStartTime(), shopAnalysisDTO.getEndTime(),shopAnalysisDTO.getShopId()); shopAnalysisVO.setOrderStatisticsDetailList(orderStatisticsDetailList); return R.ok(shopAnalysisVO); } /** * 统计用户总消费积分数和现金支付金额 */ @GetMapping("/getConsumeScoreAndPayAmount") R> getConsumeScoreAndPayAmount(@RequestParam(value = "userId",required = false) Long userId){ QueryWrapper queryWrapper = new QueryWrapper<>(); // 条件构造 统计充值积分 queryWrapper.select("SUM(point) as total_points","SUM(payment_amount) as payment_amounts"); queryWrapper.eq("del_flag", 0); queryWrapper.in("order_status", Arrays.asList(3,4,8));//待核销 已完成 已评价 queryWrapper.eq("pay_status",2); if (userId != null) { queryWrapper.eq("app_user_id", userId); } return R.ok(orderService.getMap(queryWrapper)); } /** * 获取商户RSA加密公钥 */ @GetMapping("/getRsaPublicKey") public R getRsaPublicKey(){ wechatPayService.getRsaPublicKey(); return R.ok(); } }