|
@@ -0,0 +1,205 @@
|
|
|
+package com.tourism.webadmin.back.controller;
|
|
|
+
|
|
|
+import cn.dev33.satoken.annotation.SaCheckPermission;
|
|
|
+import com.tourism.common.log.annotation.OperationLog;
|
|
|
+import com.tourism.common.log.model.constant.SysOperationLogType;
|
|
|
+import com.github.pagehelper.page.PageMethod;
|
|
|
+import com.tourism.webadmin.back.vo.*;
|
|
|
+import com.tourism.webadmin.back.dto.*;
|
|
|
+import com.tourism.webadmin.back.model.*;
|
|
|
+import com.tourism.webadmin.back.service.*;
|
|
|
+import com.tourism.common.core.object.*;
|
|
|
+import com.tourism.common.core.util.*;
|
|
|
+import com.tourism.common.core.constant.*;
|
|
|
+import com.tourism.common.core.annotation.MyRequestBody;
|
|
|
+import com.github.xiaoymin.knife4j.annotations.ApiOperationSupport;
|
|
|
+import io.swagger.v3.oas.annotations.tags.Tag;
|
|
|
+import lombok.extern.slf4j.Slf4j;
|
|
|
+import org.springframework.beans.factory.annotation.Autowired;
|
|
|
+import org.springframework.web.bind.annotation.*;
|
|
|
+
|
|
|
+import java.util.*;
|
|
|
+
|
|
|
+/**
|
|
|
+ * 拼团设置主表操作控制器类。
|
|
|
+ *
|
|
|
+ * @author 吃饭睡觉
|
|
|
+ * @date 2024-09-06
|
|
|
+ */
|
|
|
+@Tag(name = "拼团设置主表管理接口")
|
|
|
+@Slf4j
|
|
|
+@RestController
|
|
|
+@RequestMapping("/admin/app/tourProjectGroupPurchase")
|
|
|
+public class TourProjectGroupPurchaseController {
|
|
|
+
|
|
|
+ @Autowired
|
|
|
+ private TourProjectGroupPurchaseService tourProjectGroupPurchaseService;
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 新增拼团设置主表数据。
|
|
|
+ *
|
|
|
+ * @param tourProjectGroupPurchaseDto 新增对象。
|
|
|
+ * @return 应答结果对象,包含新增对象主键Id。
|
|
|
+ */
|
|
|
+ @ApiOperationSupport(ignoreParameters = {
|
|
|
+ "tourProjectGroupPurchaseDto.id",
|
|
|
+ "tourProjectGroupPurchaseDto.endTimeStart",
|
|
|
+ "tourProjectGroupPurchaseDto.endTimeEnd",
|
|
|
+ "tourProjectGroupPurchaseDto.travelStartTimeStart",
|
|
|
+ "tourProjectGroupPurchaseDto.travelStartTimeEnd",
|
|
|
+ "tourProjectGroupPurchaseDto.travelEndTimeStart",
|
|
|
+ "tourProjectGroupPurchaseDto.travelEndTimeEnd",
|
|
|
+ "tourProjectGroupPurchaseDto.maxCountStart",
|
|
|
+ "tourProjectGroupPurchaseDto.maxCountEnd",
|
|
|
+ "tourProjectGroupPurchaseDto.adultPriceStart",
|
|
|
+ "tourProjectGroupPurchaseDto.adultPriceEnd",
|
|
|
+ "tourProjectGroupPurchaseDto.childrenPriceStart",
|
|
|
+ "tourProjectGroupPurchaseDto.childrenPriceEnd"})
|
|
|
+ @SaCheckPermission("tourProjectGroupPurchase.add")
|
|
|
+ @OperationLog(type = SysOperationLogType.ADD)
|
|
|
+ @PostMapping("/add")
|
|
|
+ public ResponseResult<Long> add(@MyRequestBody TourProjectGroupPurchaseDto tourProjectGroupPurchaseDto) {
|
|
|
+ String errorMessage = MyCommonUtil.getModelValidationError(tourProjectGroupPurchaseDto, false);
|
|
|
+ if (errorMessage != null) {
|
|
|
+ return ResponseResult.error(ErrorCodeEnum.DATA_VALIDATED_FAILED, errorMessage);
|
|
|
+ }
|
|
|
+ TourProjectGroupPurchase tourProjectGroupPurchase = MyModelUtil.copyTo(tourProjectGroupPurchaseDto, TourProjectGroupPurchase.class);
|
|
|
+ tourProjectGroupPurchase = tourProjectGroupPurchaseService.saveNew(tourProjectGroupPurchase);
|
|
|
+ return ResponseResult.success(tourProjectGroupPurchase.getId());
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 更新拼团设置主表数据。
|
|
|
+ *
|
|
|
+ * @param tourProjectGroupPurchaseDto 更新对象。
|
|
|
+ * @return 应答结果对象。
|
|
|
+ */
|
|
|
+ @ApiOperationSupport(ignoreParameters = {
|
|
|
+ "tourProjectGroupPurchaseDto.endTimeStart",
|
|
|
+ "tourProjectGroupPurchaseDto.endTimeEnd",
|
|
|
+ "tourProjectGroupPurchaseDto.travelStartTimeStart",
|
|
|
+ "tourProjectGroupPurchaseDto.travelStartTimeEnd",
|
|
|
+ "tourProjectGroupPurchaseDto.travelEndTimeStart",
|
|
|
+ "tourProjectGroupPurchaseDto.travelEndTimeEnd",
|
|
|
+ "tourProjectGroupPurchaseDto.maxCountStart",
|
|
|
+ "tourProjectGroupPurchaseDto.maxCountEnd",
|
|
|
+ "tourProjectGroupPurchaseDto.adultPriceStart",
|
|
|
+ "tourProjectGroupPurchaseDto.adultPriceEnd",
|
|
|
+ "tourProjectGroupPurchaseDto.childrenPriceStart",
|
|
|
+ "tourProjectGroupPurchaseDto.childrenPriceEnd"})
|
|
|
+ @SaCheckPermission("tourProjectGroupPurchase.update")
|
|
|
+ @OperationLog(type = SysOperationLogType.UPDATE)
|
|
|
+ @PostMapping("/update")
|
|
|
+ public ResponseResult<Void> update(@MyRequestBody TourProjectGroupPurchaseDto tourProjectGroupPurchaseDto) {
|
|
|
+ String errorMessage = MyCommonUtil.getModelValidationError(tourProjectGroupPurchaseDto, true);
|
|
|
+ if (errorMessage != null) {
|
|
|
+ return ResponseResult.error(ErrorCodeEnum.DATA_VALIDATED_FAILED, errorMessage);
|
|
|
+ }
|
|
|
+ TourProjectGroupPurchase tourProjectGroupPurchase = MyModelUtil.copyTo(tourProjectGroupPurchaseDto, TourProjectGroupPurchase.class);
|
|
|
+ TourProjectGroupPurchase originalTourProjectGroupPurchase = tourProjectGroupPurchaseService.getById(tourProjectGroupPurchase.getId());
|
|
|
+ if (originalTourProjectGroupPurchase == null) {
|
|
|
+ // NOTE: 修改下面方括号中的话述
|
|
|
+ errorMessage = "数据验证失败,当前 [数据] 并不存在,请刷新后重试!";
|
|
|
+ return ResponseResult.error(ErrorCodeEnum.DATA_NOT_EXIST, errorMessage);
|
|
|
+ }
|
|
|
+ if (!tourProjectGroupPurchaseService.update(tourProjectGroupPurchase, originalTourProjectGroupPurchase)) {
|
|
|
+ return ResponseResult.error(ErrorCodeEnum.DATA_NOT_EXIST);
|
|
|
+ }
|
|
|
+ return ResponseResult.success();
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 删除拼团设置主表数据。
|
|
|
+ *
|
|
|
+ * @param id 删除对象主键Id。
|
|
|
+ * @return 应答结果对象。
|
|
|
+ */
|
|
|
+ @SaCheckPermission("tourProjectGroupPurchase.delete")
|
|
|
+ @OperationLog(type = SysOperationLogType.DELETE)
|
|
|
+ @PostMapping("/delete")
|
|
|
+ public ResponseResult<Void> delete(@MyRequestBody Long id) {
|
|
|
+ if (MyCommonUtil.existBlankArgument(id)) {
|
|
|
+ return ResponseResult.error(ErrorCodeEnum.ARGUMENT_NULL_EXIST);
|
|
|
+ }
|
|
|
+ return this.doDelete(id);
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 批量删除拼团设置主表数据。
|
|
|
+ *
|
|
|
+ * @param idList 待删除对象的主键Id列表。
|
|
|
+ * @return 应答结果对象。
|
|
|
+ */
|
|
|
+ @SaCheckPermission("tourProjectGroupPurchase.delete")
|
|
|
+ @OperationLog(type = SysOperationLogType.DELETE_BATCH)
|
|
|
+ @PostMapping("/deleteBatch")
|
|
|
+ public ResponseResult<Void> deleteBatch(@MyRequestBody List<Long> idList) {
|
|
|
+ if (MyCommonUtil.existBlankArgument(idList)) {
|
|
|
+ return ResponseResult.error(ErrorCodeEnum.ARGUMENT_NULL_EXIST);
|
|
|
+ }
|
|
|
+ for (Long id : idList) {
|
|
|
+ ResponseResult<Void> responseResult = this.doDelete(id);
|
|
|
+ if (!responseResult.isSuccess()) {
|
|
|
+ return responseResult;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ return ResponseResult.success();
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 列出符合过滤条件的拼团设置主表列表。
|
|
|
+ *
|
|
|
+ * @param tourProjectGroupPurchaseDtoFilter 过滤对象。
|
|
|
+ * @param orderParam 排序参数。
|
|
|
+ * @param pageParam 分页参数。
|
|
|
+ * @return 应答结果对象,包含查询结果集。
|
|
|
+ */
|
|
|
+ @SaCheckPermission("tourProjectGroupPurchase.view")
|
|
|
+ @PostMapping("/list")
|
|
|
+ public ResponseResult<MyPageData<TourProjectGroupPurchaseVo>> list(
|
|
|
+ @MyRequestBody TourProjectGroupPurchaseDto tourProjectGroupPurchaseDtoFilter,
|
|
|
+ @MyRequestBody MyOrderParam orderParam,
|
|
|
+ @MyRequestBody MyPageParam pageParam) {
|
|
|
+ if (pageParam != null) {
|
|
|
+ PageMethod.startPage(pageParam.getPageNum(), pageParam.getPageSize(), pageParam.getCount());
|
|
|
+ }
|
|
|
+ TourProjectGroupPurchase tourProjectGroupPurchaseFilter = MyModelUtil.copyTo(tourProjectGroupPurchaseDtoFilter, TourProjectGroupPurchase.class);
|
|
|
+ String orderBy = MyOrderParam.buildOrderBy(orderParam, TourProjectGroupPurchase.class);
|
|
|
+ List<TourProjectGroupPurchase> tourProjectGroupPurchaseList =
|
|
|
+ tourProjectGroupPurchaseService.getTourProjectGroupPurchaseListWithRelation(tourProjectGroupPurchaseFilter, orderBy);
|
|
|
+ return ResponseResult.success(MyPageUtil.makeResponseData(tourProjectGroupPurchaseList, TourProjectGroupPurchaseVo.class));
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 查看指定拼团设置主表对象详情。
|
|
|
+ *
|
|
|
+ * @param id 指定对象主键Id。
|
|
|
+ * @return 应答结果对象,包含对象详情。
|
|
|
+ */
|
|
|
+ @SaCheckPermission("tourProjectGroupPurchase.view")
|
|
|
+ @GetMapping("/view")
|
|
|
+ public ResponseResult<TourProjectGroupPurchaseVo> view(@RequestParam Long id) {
|
|
|
+ TourProjectGroupPurchase tourProjectGroupPurchase = tourProjectGroupPurchaseService.getByIdWithRelation(id, MyRelationParam.full());
|
|
|
+ if (tourProjectGroupPurchase == null) {
|
|
|
+ return ResponseResult.error(ErrorCodeEnum.DATA_NOT_EXIST);
|
|
|
+ }
|
|
|
+ TourProjectGroupPurchaseVo tourProjectGroupPurchaseVo = MyModelUtil.copyTo(tourProjectGroupPurchase, TourProjectGroupPurchaseVo.class);
|
|
|
+ return ResponseResult.success(tourProjectGroupPurchaseVo);
|
|
|
+ }
|
|
|
+
|
|
|
+ private ResponseResult<Void> doDelete(Long id) {
|
|
|
+ String errorMessage;
|
|
|
+ // 验证关联Id的数据合法性
|
|
|
+ TourProjectGroupPurchase originalTourProjectGroupPurchase = tourProjectGroupPurchaseService.getById(id);
|
|
|
+ if (originalTourProjectGroupPurchase == null) {
|
|
|
+ // NOTE: 修改下面方括号中的话述
|
|
|
+ errorMessage = "数据验证失败,当前 [对象] 并不存在,请刷新后重试!";
|
|
|
+ return ResponseResult.error(ErrorCodeEnum.DATA_NOT_EXIST, errorMessage);
|
|
|
+ }
|
|
|
+ if (!tourProjectGroupPurchaseService.remove(id)) {
|
|
|
+ errorMessage = "数据操作失败,删除的对象不存在,请刷新后重试!";
|
|
|
+ return ResponseResult.error(ErrorCodeEnum.DATA_NOT_EXIST, errorMessage);
|
|
|
+ }
|
|
|
+ return ResponseResult.success();
|
|
|
+ }
|
|
|
+}
|