更新了写真预约模块
This commit is contained in:
parent
c515ca0b32
commit
41c9434e07
|
@ -19,6 +19,7 @@ import com.cultural.heritage.model.entity.AppointmentDate;
|
||||||
import com.cultural.heritage.model.entity.Good;
|
import com.cultural.heritage.model.entity.Good;
|
||||||
import com.cultural.heritage.model.entity.PendingServiceGood;
|
import com.cultural.heritage.model.entity.PendingServiceGood;
|
||||||
import com.cultural.heritage.model.entity.TimePeriod;
|
import com.cultural.heritage.model.entity.TimePeriod;
|
||||||
|
import com.cultural.heritage.model.vo.appointment.AppointmentDateTimePeriodVO;
|
||||||
import com.cultural.heritage.service.common.CommonService;
|
import com.cultural.heritage.service.common.CommonService;
|
||||||
import com.cultural.heritage.service.good.AppointmentDateService;
|
import com.cultural.heritage.service.good.AppointmentDateService;
|
||||||
import com.cultural.heritage.service.good.GoodService;
|
import com.cultural.heritage.service.good.GoodService;
|
||||||
|
@ -319,4 +320,65 @@ public class AppointmentDateController {
|
||||||
return ResultUtils.success(true);
|
return ResultUtils.success(true);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Web端管理员批量添加预约日期
|
||||||
|
* @param appointmentDateSingleAddRequestList 预约日期添加请求体列表
|
||||||
|
* @return 是否添加成功
|
||||||
|
*/
|
||||||
|
@PostMapping("/addBatch")
|
||||||
|
@Operation(summary = "Web端管理员批量添加预约日期", description = "参数:预约日期添加请求体列表,权限:管理员(admin, boss),方法名:addBatchAppointmentDate")
|
||||||
|
@Transactional(rollbackFor = Exception.class)
|
||||||
|
@AuthCheck(mustRole = UserConstant.ADMIN_ROLE)
|
||||||
|
public BaseResponse<Boolean> addBatchAppointmentDate(@RequestBody List<AppointmentDateSingleAddRequest> appointmentDateSingleAddRequestList) {
|
||||||
|
if (appointmentDateSingleAddRequestList == null || appointmentDateSingleAddRequestList.isEmpty()) {
|
||||||
|
throw new BusinessException(ErrorCode.PARAMS_ERROR);
|
||||||
|
}
|
||||||
|
Long goodId = appointmentDateSingleAddRequestList.get(0).getGoodId();
|
||||||
|
Good good = goodService.getById(goodId);
|
||||||
|
ThrowUtils.throwIf(good == null, ErrorCode.OPERATION_ERROR, "当前商品不存在");
|
||||||
|
|
||||||
|
// 批量添加当前商品的预约日期
|
||||||
|
List<AppointmentDate> appointmentDateList = commonService.convertList(appointmentDateSingleAddRequestList, AppointmentDate.class);
|
||||||
|
boolean save = appointmentDateService.saveBatch(appointmentDateList);
|
||||||
|
ThrowUtils.throwIf(!save, ErrorCode.OPERATION_ERROR, "预约日期批量添加失败");
|
||||||
|
|
||||||
|
// 批量添加当前预约日期的预约时间段
|
||||||
|
List<TimePeriod> timePeriods = new ArrayList<>();
|
||||||
|
for (int i = 0; i < appointmentDateList.size(); i++) {
|
||||||
|
Long appointmentDateId = appointmentDateList.get(i).getId();
|
||||||
|
List<TimePeriodAddRequest> timePeriodAddRequestList = appointmentDateSingleAddRequestList.get(i).getTimePeriodAddRequestList();
|
||||||
|
List<TimePeriod> timePeriodList = timePeriodAddRequestList.stream().map(timePeriodAddRequest -> {
|
||||||
|
TimePeriod timePeriod = new TimePeriod();
|
||||||
|
BeanUtils.copyProperties(timePeriodAddRequest, timePeriod);
|
||||||
|
timePeriod.setAppointmentDateId(appointmentDateId);
|
||||||
|
return timePeriod;
|
||||||
|
}).toList();
|
||||||
|
timePeriods.addAll(timePeriodList);
|
||||||
|
}
|
||||||
|
boolean result = timePeriodService.saveBatch(timePeriods);
|
||||||
|
ThrowUtils.throwIf(!result, ErrorCode.OPERATION_ERROR, "批量添加预约时间段失败");
|
||||||
|
|
||||||
|
// 批量插入服务类商品待处理记录
|
||||||
|
List<AppointmentDateTimePeriodVO> appointmentDateTimePeriodVOList = appointmentDateService.queryAppointmentDateDetailById(good.getId());
|
||||||
|
List<PendingServiceGood> pendingServiceGoodList = new ArrayList<>();
|
||||||
|
for (AppointmentDateTimePeriodVO appointmentDateTimePeriodVO : appointmentDateTimePeriodVOList) {
|
||||||
|
PendingServiceGood pendingServiceGood = new PendingServiceGood();
|
||||||
|
BeanUtils.copyProperties(appointmentDateTimePeriodVO, pendingServiceGood);
|
||||||
|
pendingServiceGood.setId(null);
|
||||||
|
pendingServiceGood.setGoodImg(good.getGoodImg());
|
||||||
|
pendingServiceGood.setPrice(good.getPrice());
|
||||||
|
pendingServiceGood.setReservationDate(appointmentDateTimePeriodVO.getSpecificDate());
|
||||||
|
pendingServiceGood.setAppointmentDateId(appointmentDateTimePeriodVO.getId());
|
||||||
|
pendingServiceGoodList.add(pendingServiceGood);
|
||||||
|
}
|
||||||
|
boolean batch = pendingServiceGoodService.saveBatch(pendingServiceGoodList);
|
||||||
|
ThrowUtils.throwIf(!batch, ErrorCode.OPERATION_ERROR, "服务类商品待处理记录批量插入失败");
|
||||||
|
|
||||||
|
|
||||||
|
return ResultUtils.success(true);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,6 +2,7 @@ package com.cultural.heritage.controller.order;
|
||||||
|
|
||||||
|
|
||||||
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
||||||
|
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
||||||
import com.cultural.heritage.annotation.AuthCheck;
|
import com.cultural.heritage.annotation.AuthCheck;
|
||||||
import com.cultural.heritage.common.BaseResponse;
|
import com.cultural.heritage.common.BaseResponse;
|
||||||
import com.cultural.heritage.common.ErrorCode;
|
import com.cultural.heritage.common.ErrorCode;
|
||||||
|
@ -61,12 +62,16 @@ public class PendingServiceGoodController {
|
||||||
@PostMapping("/list/advance/detail")
|
@PostMapping("/list/advance/detail")
|
||||||
@Operation(summary = "Web端管理员查询预约情况", description = "参数:订单查询请求体,权限:管理员(admin, boss),方法名:listOrder")
|
@Operation(summary = "Web端管理员查询预约情况", description = "参数:订单查询请求体,权限:管理员(admin, boss),方法名:listOrder")
|
||||||
@AuthCheck(mustRole = UserConstant.ADMIN_ROLE)
|
@AuthCheck(mustRole = UserConstant.ADMIN_ROLE)
|
||||||
public BaseResponse<List<PendingServiceGoodVO>> listBookingOrderDetail(@RequestBody BookingOrderQueryRequest bookingOrderQueryRequest) {
|
public BaseResponse<Page<PendingServiceGoodVO>> listBookingOrderDetail(@RequestBody BookingOrderQueryRequest bookingOrderQueryRequest) {
|
||||||
if (bookingOrderQueryRequest == null) {
|
if (bookingOrderQueryRequest == null) {
|
||||||
throw new BusinessException(ErrorCode.PARAMS_ERROR);
|
throw new BusinessException(ErrorCode.PARAMS_ERROR);
|
||||||
}
|
}
|
||||||
QueryWrapper<PendingServiceGood> queryWrapper = pendingServiceGoodService.getQueryWrapper(bookingOrderQueryRequest);
|
QueryWrapper<PendingServiceGood> queryWrapper = pendingServiceGoodService.getQueryWrapper(bookingOrderQueryRequest);
|
||||||
List<PendingServiceGood> pendingServiceGoodList = pendingServiceGoodService.list(queryWrapper);
|
long current = bookingOrderQueryRequest.getCurrent();
|
||||||
|
long pageSize = bookingOrderQueryRequest.getPageSize();
|
||||||
|
Page<PendingServiceGood> page = pendingServiceGoodService.page(new Page<>(current, pageSize), queryWrapper);
|
||||||
|
|
||||||
|
List<PendingServiceGood> pendingServiceGoodList = page.getRecords();
|
||||||
// 获取服务类待处理订单
|
// 获取服务类待处理订单
|
||||||
List<PendingServiceOrder> pendingServiceOrderList = commonService.findByFieldInTargetField(pendingServiceGoodList, pendingServiceOrderService, PendingServiceGood::getId, "pendingId");
|
List<PendingServiceOrder> pendingServiceOrderList = commonService.findByFieldInTargetField(pendingServiceGoodList, pendingServiceOrderService, PendingServiceGood::getId, "pendingId");
|
||||||
// 封装成服务类待处理订单VO
|
// 封装成服务类待处理订单VO
|
||||||
|
@ -83,16 +88,24 @@ public class PendingServiceGoodController {
|
||||||
map.put(pendingId, pendingServiceOrderVOList);
|
map.put(pendingId, pendingServiceOrderVOList);
|
||||||
}
|
}
|
||||||
|
|
||||||
List<PendingServiceGoodVO> pendingServiceGoodVOList = pendingServiceGoodList.stream().map(pendingServiceGood -> {
|
List<PendingServiceGoodVO> pendingServiceGoodVOList = new ArrayList<>();
|
||||||
|
for (PendingServiceGood pendingServiceGood : pendingServiceGoodList) {
|
||||||
PendingServiceGoodVO pendingServiceGoodVO = new PendingServiceGoodVO();
|
PendingServiceGoodVO pendingServiceGoodVO = new PendingServiceGoodVO();
|
||||||
BeanUtils.copyProperties(pendingServiceGood, pendingServiceGoodVO);
|
BeanUtils.copyProperties(pendingServiceGood, pendingServiceGoodVO);
|
||||||
Long goodId = pendingServiceGood.getId();
|
Long goodId = pendingServiceGood.getId();
|
||||||
List<PendingServiceOrderVO> pendingServiceOrderVOList = map.get(goodId);
|
List<PendingServiceOrderVO> pendingServiceOrderVOList = map.get(goodId);
|
||||||
|
if (pendingServiceOrderVOList == null) continue;
|
||||||
pendingServiceGoodVO.setPendingServiceOrderVOList(pendingServiceOrderVOList);
|
pendingServiceGoodVO.setPendingServiceOrderVOList(pendingServiceOrderVOList);
|
||||||
return pendingServiceGoodVO;
|
pendingServiceGoodVOList.add(pendingServiceGoodVO);
|
||||||
}).toList();
|
}
|
||||||
|
|
||||||
return ResultUtils.success(pendingServiceGoodVOList);
|
Page<PendingServiceGoodVO> voPage = new Page<>();
|
||||||
|
voPage.setRecords(pendingServiceGoodVOList);
|
||||||
|
voPage.setTotal(page.getTotal());
|
||||||
|
voPage.setSize(page.getSize());
|
||||||
|
voPage.setCurrent(page.getCurrent());
|
||||||
|
voPage.setPages(page.getPages());
|
||||||
|
return ResultUtils.success(voPage);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -6,9 +6,12 @@ import com.cultural.heritage.constant.MqConstant;
|
||||||
import com.cultural.heritage.constant.OrderStatusConstant;
|
import com.cultural.heritage.constant.OrderStatusConstant;
|
||||||
import com.cultural.heritage.exception.ThrowUtils;
|
import com.cultural.heritage.exception.ThrowUtils;
|
||||||
import com.cultural.heritage.model.entity.Order;
|
import com.cultural.heritage.model.entity.Order;
|
||||||
|
import com.cultural.heritage.model.entity.PendingServiceOrder;
|
||||||
import com.cultural.heritage.model.entity.UserCoupon;
|
import com.cultural.heritage.model.entity.UserCoupon;
|
||||||
|
import com.cultural.heritage.service.common.CommonService;
|
||||||
import com.cultural.heritage.service.good.UserCouponService;
|
import com.cultural.heritage.service.good.UserCouponService;
|
||||||
import com.cultural.heritage.service.order.OrderService;
|
import com.cultural.heritage.service.order.OrderService;
|
||||||
|
import com.cultural.heritage.service.order.PendingServiceOrderService;
|
||||||
import com.cultural.heritage.utils.MultiDelayMessage;
|
import com.cultural.heritage.utils.MultiDelayMessage;
|
||||||
import jakarta.annotation.Resource;
|
import jakarta.annotation.Resource;
|
||||||
import org.springframework.amqp.rabbit.annotation.Exchange;
|
import org.springframework.amqp.rabbit.annotation.Exchange;
|
||||||
|
@ -34,6 +37,14 @@ public class OrderStatusListener {
|
||||||
private UserCouponService userCouponService;
|
private UserCouponService userCouponService;
|
||||||
|
|
||||||
|
|
||||||
|
@Resource
|
||||||
|
private PendingServiceOrderService pendingServiceOrderService;
|
||||||
|
|
||||||
|
|
||||||
|
@Resource
|
||||||
|
private CommonService commonService;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
@RabbitListener(bindings = @QueueBinding(
|
@RabbitListener(bindings = @QueueBinding(
|
||||||
value = @Queue(MqConstant.DELAY_ORDER_QUEUE),
|
value = @Queue(MqConstant.DELAY_ORDER_QUEUE),
|
||||||
|
@ -79,6 +90,14 @@ public class OrderStatusListener {
|
||||||
boolean result = userCouponService.updateById(userCoupon);
|
boolean result = userCouponService.updateById(userCoupon);
|
||||||
ThrowUtils.throwIf(!result, ErrorCode.OPERATION_ERROR, "优惠券状态更新失败");
|
ThrowUtils.throwIf(!result, ErrorCode.OPERATION_ERROR, "优惠券状态更新失败");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
boolean isGeneral = orderService.isGeneralGood(order.getOrderType());
|
||||||
|
if (!isGeneral) {
|
||||||
|
UpdateWrapper<PendingServiceOrder> pendingServiceOrderUpdateWrapper = new UpdateWrapper<>();
|
||||||
|
pendingServiceOrderUpdateWrapper.eq("orderNumber", order.getOrderNumber()).set("orderStatus", OrderStatusConstant.TRANSACTION_CLOSED);
|
||||||
|
boolean updateBatch = orderService.update(updateWrapper);
|
||||||
|
ThrowUtils.throwIf(!updateBatch, ErrorCode.OPERATION_ERROR, "订单状态批量更新失败");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
package com.cultural.heritage.model.dto.order;
|
package com.cultural.heritage.model.dto.order;
|
||||||
|
|
||||||
|
import com.cultural.heritage.common.PageRequest;
|
||||||
import io.swagger.v3.oas.annotations.media.Schema;
|
import io.swagger.v3.oas.annotations.media.Schema;
|
||||||
import lombok.AllArgsConstructor;
|
import lombok.AllArgsConstructor;
|
||||||
import lombok.Data;
|
import lombok.Data;
|
||||||
|
@ -11,8 +12,8 @@ import java.io.Serializable;
|
||||||
@Data
|
@Data
|
||||||
@AllArgsConstructor
|
@AllArgsConstructor
|
||||||
@NoArgsConstructor
|
@NoArgsConstructor
|
||||||
@Schema(description = "服务类商品预约情况查询请求体", requiredProperties = {"goodId", "quantity"})
|
@Schema(description = "服务类商品预约情况查询请求体", requiredProperties = {"goodId", "quantity", "sortField", "sortOrder"})
|
||||||
public class BookingOrderQueryRequest implements Serializable {
|
public class BookingOrderQueryRequest extends PageRequest implements Serializable {
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* 商品id
|
* 商品id
|
||||||
|
|
Loading…
Reference in New Issue
Block a user