add CampaignQuotaService
This commit is contained in:
parent
2f43434b67
commit
58b460e122
@ -0,0 +1,23 @@
|
|||||||
|
package com.pudonghot.yo.cms.controller;
|
||||||
|
|
||||||
|
import com.wacai.tigon.form.FormList;
|
||||||
|
import org.springframework.stereotype.Controller;
|
||||||
|
import com.pudonghot.yo.model.domain.CampaignQuota;
|
||||||
|
import com.wacai.tigon.web.controller.BaseCrudController;
|
||||||
|
import org.springframework.web.bind.annotation.RequestMapping;
|
||||||
|
import com.pudonghot.yo.cms.form.create.FormCreateCampaignQuota;
|
||||||
|
import com.pudonghot.yo.cms.form.update.FormUpdateCampaignQuota;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author Donghuang
|
||||||
|
* @date Oct 14, 2021 14:24:45
|
||||||
|
*/
|
||||||
|
@Controller
|
||||||
|
@RequestMapping("/campaign-quota")
|
||||||
|
public class CampaignQuotaController
|
||||||
|
extends BaseCrudController<Integer,
|
||||||
|
CampaignQuota,
|
||||||
|
FormList,
|
||||||
|
FormCreateCampaignQuota,
|
||||||
|
FormUpdateCampaignQuota> {
|
||||||
|
}
|
@ -0,0 +1,30 @@
|
|||||||
|
package com.pudonghot.yo.cms.form.create;
|
||||||
|
|
||||||
|
import lombok.Getter;
|
||||||
|
import lombok.Setter;
|
||||||
|
import javax.validation.constraints.Min;
|
||||||
|
import com.pudonghot.yo.model.DailyTime;
|
||||||
|
import javax.validation.constraints.NotNull;
|
||||||
|
import com.pudonghot.yo.cms.form.BaseCreateForm;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author Donghuang
|
||||||
|
* @date Oct 14, 2021 14:24:45
|
||||||
|
*/
|
||||||
|
@Getter
|
||||||
|
@Setter
|
||||||
|
public class FormCreateCampaignQuota extends BaseCreateForm {
|
||||||
|
private static final long serialVersionUID = 1L;
|
||||||
|
|
||||||
|
@Min(1)
|
||||||
|
@NotNull
|
||||||
|
private Integer campaignId;
|
||||||
|
@NotNull
|
||||||
|
private DailyTime dailyFrom;
|
||||||
|
@NotNull
|
||||||
|
private DailyTime dailyTo;
|
||||||
|
|
||||||
|
@Min(1)
|
||||||
|
@NotNull
|
||||||
|
private Integer quota;
|
||||||
|
}
|
@ -0,0 +1,27 @@
|
|||||||
|
package com.pudonghot.yo.cms.form.update;
|
||||||
|
|
||||||
|
import lombok.Getter;
|
||||||
|
import lombok.Setter;
|
||||||
|
import com.pudonghot.yo.model.DailyTime;
|
||||||
|
import javax.validation.constraints.Min;
|
||||||
|
import javax.validation.constraints.NotNull;
|
||||||
|
import com.pudonghot.yo.cms.form.BaseUpdateForm;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author Donghuang
|
||||||
|
* @date Oct 14, 2021 14:24:45
|
||||||
|
*/
|
||||||
|
@Getter
|
||||||
|
@Setter
|
||||||
|
public class FormUpdateCampaignQuota extends BaseUpdateForm {
|
||||||
|
private static final long serialVersionUID = 1L;
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
private DailyTime dailyFrom;
|
||||||
|
@NotNull
|
||||||
|
private DailyTime dailyTo;
|
||||||
|
|
||||||
|
@Min(1)
|
||||||
|
@NotNull
|
||||||
|
private Integer quota;
|
||||||
|
}
|
@ -0,0 +1,17 @@
|
|||||||
|
package com.pudonghot.yo.cms.service;
|
||||||
|
|
||||||
|
import com.pudonghot.yo.model.domain.CampaignQuota;
|
||||||
|
import com.wacai.tigon.service.BaseCrudByFormService;
|
||||||
|
import com.pudonghot.yo.cms.form.create.FormCreateCampaignQuota;
|
||||||
|
import com.pudonghot.yo.cms.form.update.FormUpdateCampaignQuota;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author Donghuang
|
||||||
|
* @date Oct 14, 2021 14:24:45
|
||||||
|
*/
|
||||||
|
public interface CampaignQuotaService
|
||||||
|
extends BaseCrudByFormService<Integer,
|
||||||
|
CampaignQuota,
|
||||||
|
FormCreateCampaignQuota,
|
||||||
|
FormUpdateCampaignQuota> {
|
||||||
|
}
|
@ -0,0 +1,65 @@
|
|||||||
|
package com.pudonghot.yo.cms.service.impl;
|
||||||
|
|
||||||
|
import lombok.val;
|
||||||
|
import org.springframework.util.Assert;
|
||||||
|
import me.chyxion.tigon.mybatis.Search;
|
||||||
|
import com.pudonghot.yo.model.DailyTime;
|
||||||
|
import org.springframework.stereotype.Service;
|
||||||
|
import com.pudonghot.yo.model.domain.CampaignQuota;
|
||||||
|
import com.pudonghot.yo.mapper.CampaignQuotaMapper;
|
||||||
|
import com.pudonghot.yo.cms.service.CampaignQuotaService;
|
||||||
|
import com.pudonghot.yo.cms.form.create.FormCreateCampaignQuota;
|
||||||
|
import com.pudonghot.yo.cms.form.update.FormUpdateCampaignQuota;
|
||||||
|
import com.wacai.tigon.service.support.BaseCrudByFormServiceSupport;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author Donghuang
|
||||||
|
* @date Oct 14, 2021 14:24:45
|
||||||
|
*/
|
||||||
|
@Service
|
||||||
|
public class CampaignQuotaServiceImpl
|
||||||
|
extends BaseCrudByFormServiceSupport<Integer,
|
||||||
|
CampaignQuota,
|
||||||
|
FormCreateCampaignQuota,
|
||||||
|
FormUpdateCampaignQuota,
|
||||||
|
CampaignQuotaMapper>
|
||||||
|
implements CampaignQuotaService {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
protected void beforeCreate(final FormCreateCampaignQuota form, final CampaignQuota model) {
|
||||||
|
super.beforeCreate(form, model);
|
||||||
|
validateDailyTime(form.getCampaignId(), form.getDailyFrom(), form.getDailyTo());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
protected void beforeUpdate(final FormUpdateCampaignQuota form, final CampaignQuota model) {
|
||||||
|
super.beforeUpdate(form, model);
|
||||||
|
validateDailyTime(model.getCampaignId(), form.getDailyFrom(), form.getDailyTo());
|
||||||
|
}
|
||||||
|
|
||||||
|
void validateDailyTime(final Integer campaignId, final DailyTime dailyFrom, final DailyTime dailyTo) {
|
||||||
|
Assert.state(dailyFrom.getSecondOfDay() < dailyTo.getSecondOfDay(),
|
||||||
|
() -> "无效开始时间[" + dailyFrom + "]和结束时间[" + dailyTo + "],开始时间须小于结束时间");
|
||||||
|
|
||||||
|
mapper.scan(128, new Search(CampaignQuota.CAMPAIGN_ID, campaignId), item -> {
|
||||||
|
val itemDailyFrom = item.getDailyFrom();
|
||||||
|
val itemDailyTo = item.getDailyTo();
|
||||||
|
|
||||||
|
val secondOfDay1 = dailyFrom.getSecondOfDay();
|
||||||
|
Assert.state(!(secondOfDay1 > itemDailyFrom.getSecondOfDay()
|
||||||
|
&& secondOfDay1 < itemDailyTo.getSecondOfDay()),
|
||||||
|
() -> "开始时间[" + dailyFrom + "]与区间[" + itemDailyFrom + ", " + itemDailyTo + "]重叠");
|
||||||
|
|
||||||
|
val secondOfDay2 = dailyTo.getSecondOfDay();
|
||||||
|
Assert.state(!(secondOfDay2 > itemDailyFrom.getSecondOfDay()
|
||||||
|
&& secondOfDay2 < itemDailyTo.getSecondOfDay()),
|
||||||
|
() -> "结束时间[" + dailyTo + "]与区间[" + itemDailyFrom + ", " + itemDailyTo + "]重叠");
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
@ -0,0 +1,11 @@
|
|||||||
|
package com.pudonghot.yo.mapper;
|
||||||
|
|
||||||
|
import me.chyxion.tigon.mybatis.BaseMapper;
|
||||||
|
import com.pudonghot.yo.model.domain.CampaignQuota;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author Donghuang
|
||||||
|
* @date Oct 14, 2021 14:24:45
|
||||||
|
*/
|
||||||
|
public interface CampaignQuotaMapper extends BaseMapper<Integer, CampaignQuota> {
|
||||||
|
}
|
@ -0,0 +1,12 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<!--
|
||||||
|
/**
|
||||||
|
* @author Donghuang
|
||||||
|
* @date Oct 14, 2021 14:24:45
|
||||||
|
*/
|
||||||
|
-->
|
||||||
|
<!DOCTYPE mapper PUBLIC
|
||||||
|
"-//mybatis.org//DTD Mapper 3.0//EN"
|
||||||
|
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
|
||||||
|
<mapper namespace="com.pudonghot.yo.mapper.CampaignQuotaMapper">
|
||||||
|
</mapper>
|
@ -0,0 +1,25 @@
|
|||||||
|
package com.pudonghot.yo.mapper;
|
||||||
|
|
||||||
|
import org.junit.Test;
|
||||||
|
import org.junit.runner.RunWith;
|
||||||
|
import me.chyxion.tigon.mybatis.Search;
|
||||||
|
import org.springframework.boot.test.context.SpringBootTest;
|
||||||
|
import org.springframework.beans.factory.annotation.Autowired;
|
||||||
|
import org.springframework.test.context.junit4.SpringJUnit4ClassRunner;
|
||||||
|
import org.springframework.test.context.junit4.AbstractTransactionalJUnit4SpringContextTests;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author Donghuang
|
||||||
|
* @date Oct 14, 2021 14:24:45
|
||||||
|
*/
|
||||||
|
@RunWith(SpringJUnit4ClassRunner.class)
|
||||||
|
@SpringBootTest(classes = TestDriver.class)
|
||||||
|
public class CampaignQuotaMapperTest extends AbstractTransactionalJUnit4SpringContextTests {
|
||||||
|
@Autowired
|
||||||
|
private CampaignQuotaMapper mapper;
|
||||||
|
|
||||||
|
@Test
|
||||||
|
public void mapperTest() {
|
||||||
|
mapper.list(new Search().limit(8));
|
||||||
|
}
|
||||||
|
}
|
@ -13,7 +13,7 @@ import com.fasterxml.jackson.annotation.JsonCreator;
|
|||||||
* @date Jul 19, 2020 11:18:45
|
* @date Jul 19, 2020 11:18:45
|
||||||
*/
|
*/
|
||||||
@Getter
|
@Getter
|
||||||
public class DailyTime implements Serializable {
|
public class DailyTime implements Comparable<DailyTime>, Serializable {
|
||||||
private static final long serialVersionUID = 1L;
|
private static final long serialVersionUID = 1L;
|
||||||
@JsonValue
|
@JsonValue
|
||||||
private final String text;
|
private final String text;
|
||||||
@ -61,4 +61,12 @@ public class DailyTime implements Serializable {
|
|||||||
public String toString() {
|
public String toString() {
|
||||||
return text;
|
return text;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* {@inheritDoc}
|
||||||
|
*/
|
||||||
|
@Override
|
||||||
|
public int compareTo(final DailyTime o) {
|
||||||
|
return secondOfDay - o.secondOfDay;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -0,0 +1,26 @@
|
|||||||
|
package com.pudonghot.yo.model.domain;
|
||||||
|
|
||||||
|
import lombok.Getter;
|
||||||
|
import lombok.Setter;
|
||||||
|
import me.chyxion.tigon.mybatis.Table;
|
||||||
|
import com.pudonghot.yo.model.DailyTime;
|
||||||
|
import me.chyxion.tigon.mybatis.NotUpdate;
|
||||||
|
import lombok.experimental.FieldNameConstants;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @author Donghuang
|
||||||
|
* @date Oct 14, 2021 14:24:45
|
||||||
|
*/
|
||||||
|
@Getter
|
||||||
|
@Setter
|
||||||
|
@Table("br_campaign_quota")
|
||||||
|
@FieldNameConstants(prefix = "")
|
||||||
|
public class CampaignQuota extends BaseDomain {
|
||||||
|
private static final long serialVersionUID = 1L;
|
||||||
|
|
||||||
|
@NotUpdate
|
||||||
|
private Integer campaignId;
|
||||||
|
private DailyTime dailyFrom;
|
||||||
|
private DailyTime dailyTo;
|
||||||
|
private Integer quota;
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user