|
@@ -1,10 +1,28 @@
|
|
|
package com.qs.mp.common.service.impl;
|
|
|
|
|
|
+import com.qs.mp.admin.domain.param.ShippingTemplateParam;
|
|
|
+import com.qs.mp.admin.domain.param.ShippingTemplateRuleAreaParam;
|
|
|
+import com.qs.mp.admin.domain.param.ShippingTemplateRuleParam;
|
|
|
import com.qs.mp.common.domain.ShippingTemplate;
|
|
|
+import com.qs.mp.common.domain.ShippingTemplateRule;
|
|
|
+import com.qs.mp.common.domain.ShippingTemplateRuleArea;
|
|
|
+import com.qs.mp.common.exception.ServiceException;
|
|
|
import com.qs.mp.common.mapper.ShippingTemplateMapper;
|
|
|
+import com.qs.mp.common.service.IShippingTemplateRuleAreaService;
|
|
|
+import com.qs.mp.common.service.IShippingTemplateRuleService;
|
|
|
import com.qs.mp.common.service.IShippingTemplateService;
|
|
|
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
|
|
+import org.apache.commons.lang3.StringUtils;
|
|
|
+import org.springframework.beans.BeanUtils;
|
|
|
+import org.springframework.beans.factory.annotation.Autowired;
|
|
|
import org.springframework.stereotype.Service;
|
|
|
+import org.springframework.transaction.annotation.Transactional;
|
|
|
+import org.springframework.util.Assert;
|
|
|
+import org.springframework.util.CollectionUtils;
|
|
|
+
|
|
|
+import java.util.ArrayList;
|
|
|
+import java.util.List;
|
|
|
+import java.util.Objects;
|
|
|
|
|
|
/**
|
|
|
* <p>
|
|
@@ -17,4 +35,89 @@ import org.springframework.stereotype.Service;
|
|
|
@Service
|
|
|
public class ShippingTemplateServiceImpl extends ServiceImpl<ShippingTemplateMapper, ShippingTemplate> implements IShippingTemplateService {
|
|
|
|
|
|
+ @Autowired
|
|
|
+ private IShippingTemplateRuleService shippingTemplateRuleService;;
|
|
|
+
|
|
|
+ @Autowired
|
|
|
+ private IShippingTemplateRuleAreaService shippingTemplateRuleAreaService;
|
|
|
+
|
|
|
+ @Override
|
|
|
+ @Transactional(rollbackFor = Exception.class)
|
|
|
+ public boolean create(ShippingTemplateParam shippingTemplateParam) {
|
|
|
+
|
|
|
+ // 校验运费模板参数
|
|
|
+ this.checkCreateShippingTemplateParam(shippingTemplateParam);
|
|
|
+
|
|
|
+ // 新增运费模板
|
|
|
+ ShippingTemplate shippingTemplate = new ShippingTemplate();
|
|
|
+ BeanUtils.copyProperties(shippingTemplateParam, shippingTemplate);
|
|
|
+ this.save(shippingTemplate);
|
|
|
+
|
|
|
+ // 新增运费模板规则
|
|
|
+ List<ShippingTemplateRuleParam> shippingTemplateRuleList = shippingTemplateParam.getShippingTemplateRuleList();
|
|
|
+ for (ShippingTemplateRuleParam shippingTemplateRuleParam : shippingTemplateRuleList) {
|
|
|
+ ShippingTemplateRule shippingTemplateRule = new ShippingTemplateRule();
|
|
|
+ BeanUtils.copyProperties(shippingTemplateRuleParam, shippingTemplateRule);
|
|
|
+ shippingTemplateRule.setShippingTemplateId(shippingTemplate.getId());
|
|
|
+ shippingTemplateRuleService.save(shippingTemplateRule);
|
|
|
+
|
|
|
+ // 新增运费模板规则地区
|
|
|
+ List<ShippingTemplateRuleAreaParam> shippingTemplateRuleAreaList = shippingTemplateRuleParam.getShippingTemplateRuleAreaList();
|
|
|
+ List<ShippingTemplateRuleArea> params = new ArrayList<>();
|
|
|
+ for (ShippingTemplateRuleAreaParam shippingTemplateRuleAreaParam : shippingTemplateRuleAreaList) {
|
|
|
+ ShippingTemplateRuleArea param = new ShippingTemplateRuleArea();
|
|
|
+ BeanUtils.copyProperties(shippingTemplateRuleAreaParam, param);
|
|
|
+ param.setShippingTemplateRuleId(shippingTemplateRule.getId());
|
|
|
+ params.add(param);
|
|
|
+ }
|
|
|
+ shippingTemplateRuleAreaService.saveBatch(params);
|
|
|
+ }
|
|
|
+ return true;
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 校验运费模板参数
|
|
|
+ * @param shippingTemplateParam 运费模板入参类
|
|
|
+ */
|
|
|
+ private void checkCreateShippingTemplateParam(ShippingTemplateParam shippingTemplateParam) {
|
|
|
+
|
|
|
+ if (StringUtils.isBlank(shippingTemplateParam.getTitle())) {
|
|
|
+ throw new ServiceException("运费模板标题不能为空");
|
|
|
+ }
|
|
|
+
|
|
|
+ List<ShippingTemplateRuleParam> shippingTemplateRuleList = shippingTemplateParam.getShippingTemplateRuleList();
|
|
|
+ if (CollectionUtils.isEmpty(shippingTemplateRuleList)) {
|
|
|
+ throw new ServiceException("运费模板规则不能为空");
|
|
|
+ }
|
|
|
+
|
|
|
+ for (ShippingTemplateRuleParam shippingTemplateRuleParam : shippingTemplateRuleList) {
|
|
|
+ List<ShippingTemplateRuleAreaParam> shippingTemplateRuleAreaList = shippingTemplateRuleParam.getShippingTemplateRuleAreaList();
|
|
|
+ if (CollectionUtils.isEmpty(shippingTemplateRuleAreaList)) {
|
|
|
+ throw new ServiceException("运费模板规则区域不能为空");
|
|
|
+ }
|
|
|
+
|
|
|
+ for (ShippingTemplateRuleAreaParam shippingTemplateRuleAreaParam : shippingTemplateRuleAreaList) {
|
|
|
+
|
|
|
+ if (StringUtils.isBlank(shippingTemplateRuleAreaParam.getProvince())) {
|
|
|
+ throw new ServiceException("省份不能为空");
|
|
|
+ }
|
|
|
+
|
|
|
+ if (Objects.isNull(shippingTemplateRuleAreaParam.getProvinceId())) {
|
|
|
+ throw new ServiceException("省份ID不能为空");
|
|
|
+ }
|
|
|
+
|
|
|
+ if (StringUtils.isBlank(shippingTemplateRuleAreaParam.getCity())) {
|
|
|
+ throw new ServiceException("城市不能为空");
|
|
|
+ }
|
|
|
+
|
|
|
+ if (Objects.isNull(shippingTemplateRuleAreaParam.getCityId())) {
|
|
|
+ throw new ServiceException("城市ID不能为空");
|
|
|
+ }
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ }
|
|
|
}
|