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