|
@@ -1,5 +1,7 @@
|
|
|
package com.qs.mp.admin.service.impl;
|
|
|
|
|
|
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
|
|
+import com.baomidou.mybatisplus.core.conditions.update.LambdaUpdateWrapper;
|
|
|
import com.baomidou.mybatisplus.core.toolkit.CollectionUtils;
|
|
|
import com.qs.mp.admin.domain.CouponPkg;
|
|
|
import com.qs.mp.admin.domain.CouponPkgItem;
|
|
@@ -9,6 +11,7 @@ import com.qs.mp.admin.mapper.CouponPkgMapper;
|
|
|
import com.qs.mp.admin.service.ICouponPkgItemService;
|
|
|
import com.qs.mp.admin.service.ICouponPkgService;
|
|
|
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
|
|
+import com.qs.mp.common.enums.CouponPkgStatusEnum;
|
|
|
import com.qs.mp.common.exception.ServiceException;
|
|
|
import org.springframework.beans.BeanUtils;
|
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
@@ -17,6 +20,7 @@ import org.springframework.transaction.annotation.Transactional;
|
|
|
|
|
|
import java.util.ArrayList;
|
|
|
import java.util.List;
|
|
|
+import java.util.Objects;
|
|
|
|
|
|
/**
|
|
|
* <p>
|
|
@@ -33,6 +37,47 @@ public class CouponPkgServiceImpl extends ServiceImpl<CouponPkgMapper, CouponPkg
|
|
|
private ICouponPkgItemService couponPkgItemService;
|
|
|
|
|
|
|
|
|
+ @Override
|
|
|
+ @Transactional(rollbackFor = Exception.class)
|
|
|
+ public boolean updateCouponPkg(CouponPkgParam couponPkgParam) {
|
|
|
+
|
|
|
+ if (Objects.isNull(couponPkgParam.getId()) || couponPkgParam.getId() == 0) {
|
|
|
+ throw new ServiceException("券包ID不正确");
|
|
|
+ }
|
|
|
+
|
|
|
+ if (!CouponPkgStatusEnum.PUT_INIT.getValue().equals(couponPkgParam.getStatus())) {
|
|
|
+ throw new ServiceException("券包只有待上架才可编辑");
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ List<CouponPkgItemParam> couponPkgItemList = couponPkgParam.getCouponPkgItemList();
|
|
|
+ if (CollectionUtils.isEmpty(couponPkgItemList)) {
|
|
|
+ throw new ServiceException("券包明细不能为空");
|
|
|
+ }
|
|
|
+
|
|
|
+ // 清除券包明细
|
|
|
+ couponPkgItemService.remove(new LambdaQueryWrapper<CouponPkgItem>()
|
|
|
+ .eq(CouponPkgItem::getCouponPkgId, couponPkgParam.getId()));
|
|
|
+
|
|
|
+ // 更新券包
|
|
|
+ CouponPkg couponPkg = new CouponPkg();
|
|
|
+ BeanUtils.copyProperties(couponPkgParam, couponPkg);
|
|
|
+ this.updateById(couponPkg);
|
|
|
+
|
|
|
+ // 创建券包明细
|
|
|
+ List<CouponPkgItem> params = new ArrayList<>();
|
|
|
+ for (CouponPkgItemParam couponPkgItemParam : couponPkgItemList) {
|
|
|
+ CouponPkgItem param = new CouponPkgItem();
|
|
|
+ param.setCouponPkgId(couponPkg.getId());
|
|
|
+ param.setCouponId(couponPkgItemParam.getCouponId());
|
|
|
+ param.setCouponNum(couponPkgItemParam.getCouponNum());
|
|
|
+ params.add(param);
|
|
|
+ }
|
|
|
+ couponPkgItemService.saveBatch(params);
|
|
|
+
|
|
|
+ return true;
|
|
|
+ }
|
|
|
+
|
|
|
@Override
|
|
|
@Transactional(rollbackFor = Exception.class)
|
|
|
public boolean create(CouponPkgParam couponPkgParam) {
|
|
@@ -51,6 +96,7 @@ public class CouponPkgServiceImpl extends ServiceImpl<CouponPkgMapper, CouponPkg
|
|
|
CouponPkgItem param = new CouponPkgItem();
|
|
|
param.setCouponPkgId(couponPkg.getId());
|
|
|
param.setCouponId(couponPkgItemParam.getCouponId());
|
|
|
+ param.setCouponNum(couponPkgItemParam.getCouponNum());
|
|
|
params.add(param);
|
|
|
}
|
|
|
couponPkgItemService.saveBatch(params);
|