Your Name 3 lat temu
rodzic
commit
65f31b6b5d

+ 1 - 0
java110-bean/src/main/java/com/java110/dto/reserveGoods/ReserveGoodsDto.java

@@ -16,6 +16,7 @@ import java.util.Date;
  **/
 public class ReserveGoodsDto extends ReserveParamsDto implements Serializable {
 
+
     private String endDate;
     private String goodsId;
     private String sort;

+ 2 - 0
java110-bean/src/main/java/com/java110/dto/reserveParams/ReserveParamsDto.java

@@ -16,6 +16,8 @@ import java.util.List;
  * add by wuxw 2019/4/24
  **/
 public class ReserveParamsDto extends PageDto implements Serializable {
+    public static final String PARAM_WAY_DAY = "1";
+    public static final String PARAM_WAY_WEEK = "2";
 
     private String paramWay;
     private String paramsId;

+ 1 - 1
java110-db/src/main/resources/mapper/store/ReserveGoodsV1ServiceDaoImplMapper.xml

@@ -21,7 +21,7 @@
         statusCd,t.sort,t.type,t.img_url,t.img_url imgUrl,t.catalog_id,t.catalog_id catalogId,t.params_id,t.params_id
         paramsId,t.price,t.state,t.community_id,t.community_id communityId,t.goods_name,t.goods_name
         goodsName,t.start_date,DATE_FORMAT(t.start_date,'%Y-%m-%d') startDate,t.goods_desc,t.goods_desc goodsDesc,t.create_time createTime,
-        rp.param_way paramWay,rp.max_quantity  maxQuantity,rp.name paramsName,rp.start_time startTime,
+        rp.param_way paramWay,rp.param_way_text paramWayText,rp.max_quantity  maxQuantity,rp.name paramsName,rp.start_time startTime,
         rp.hours_max_quantity hoursMaxQuantity
         from reserve_goods t
         left join reserve_params rp on t.params_id = rp.params_id and rp.status_cd='0'

+ 70 - 12
service-store/src/main/java/com/java110/store/cmd/reserveOrder/SaveReserveGoodsOrderCmd.java

@@ -25,21 +25,30 @@ import com.java110.core.event.cmd.CmdEvent;
 import com.java110.core.factory.GenerateCodeFactory;
 import com.java110.dto.communitySpacePerson.CommunitySpacePersonDto;
 import com.java110.dto.communitySpacePersonTime.CommunitySpacePersonTimeDto;
+import com.java110.dto.reserveGoods.ReserveGoodsDto;
 import com.java110.dto.reserveGoodsOrderTime.ReserveGoodsOrderTimeDto;
+import com.java110.dto.reserveParams.ReserveParamsDto;
 import com.java110.intf.store.IReserveGoodsOrderTimeV1InnerServiceSMO;
 import com.java110.intf.store.IReserveGoodsOrderV1InnerServiceSMO;
+import com.java110.intf.store.IReserveGoodsV1InnerServiceSMO;
 import com.java110.po.communitySpacePersonTime.CommunitySpacePersonTimePo;
 import com.java110.po.reserveGoodsOrder.ReserveGoodsOrderPo;
 import com.java110.po.reserveGoodsOrderTime.ReserveGoodsOrderTimePo;
 import com.java110.utils.exception.CmdException;
 import com.java110.utils.util.Assert;
 import com.java110.utils.util.BeanConvertUtil;
+import com.java110.utils.util.DateUtil;
 import com.java110.utils.util.StringUtil;
 import com.java110.vo.ResultVo;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.slf4j.Logger;
 import org.slf4j.LoggerFactory;
 
+import java.awt.color.CMMException;
+import java.util.Arrays;
+import java.util.Calendar;
+import java.util.List;
+
 /**
  * 类表述:保存
  * 服务编码:reserveGoodsOrder.saveReserveGoodsOrder
@@ -63,6 +72,9 @@ public class SaveReserveGoodsOrderCmd extends Cmd {
     @Autowired
     private IReserveGoodsOrderTimeV1InnerServiceSMO reserveGoodsOrderTimeV1InnerServiceSMOImpl;
 
+    @Autowired
+    private IReserveGoodsV1InnerServiceSMO reserveGoodsV1InnerServiceSMOImpl;
+
     @Override
     public void validate(CmdEvent event, ICmdDataFlowContext cmdDataFlowContext, JSONObject reqJson) {
         Assert.hasKeyAndValue(reqJson, "goodsId", "请求报文中未包含goodsId");
@@ -75,28 +87,74 @@ public class SaveReserveGoodsOrderCmd extends Cmd {
         Assert.hasKeyAndValue(reqJson, "communityId", "请求报文中未包含communityId");
         Assert.hasKeyAndValue(reqJson, "extOrderId", "请求报文中未包含extOrderId");
 
-        if(!reqJson.containsKey("openTimes")){
+        //校验是否可以预约
+        ReserveGoodsDto reserveGoodsDto = new ReserveGoodsDto();
+        reserveGoodsDto.setGoodsId(reqJson.getString("goodsId"));
+        List<ReserveGoodsDto> reserveGoodsDtos = reserveGoodsV1InnerServiceSMOImpl.queryReserveGoodss(reserveGoodsDto);
+        if ("1001".equals(reqJson.getString("type"))) {
+            Assert.listOnlyOne(reserveGoodsDtos, "就餐不存在");
+        } else {
+            Assert.listOnlyOne(reserveGoodsDtos, "服务不存在");
+        }
+
+        checkAppointmentTime(reqJson, reserveGoodsDtos.get(0));
+
+        if (!reqJson.containsKey("times")) {
             cmdDataFlowContext.setResponseEntity(ResultVo.success());
-            return ;
+            return;
         }
 
-        JSONArray openTimes = reqJson.getJSONArray("openTimes");
+        JSONArray openTimes = reqJson.getJSONArray("times");
 
-        if(openTimes == null || openTimes.size() <1){
+        if (openTimes == null || openTimes.size() < 1) {
             cmdDataFlowContext.setResponseEntity(ResultVo.success());
-            return ;
+            return;
         }
         ReserveGoodsOrderTimeDto reserveGoodsOrderTimeDto = null;
         int flag = 0;
-        for(int timeIndex = 0 ;timeIndex < openTimes.size(); timeIndex++) {
+        int quantity = 0;
+        for (int timeIndex = 0; timeIndex < openTimes.size(); timeIndex++) {
             reserveGoodsOrderTimeDto = new ReserveGoodsOrderTimeDto();
             reserveGoodsOrderTimeDto.setCommunityId(reqJson.getString("communityId"));
             reserveGoodsOrderTimeDto.setAppointmentTime(reqJson.getString("appointmentTime"));
             reserveGoodsOrderTimeDto.setHours(openTimes.getJSONObject(timeIndex).getString("hours"));
             reserveGoodsOrderTimeDto.setGoodsId(reqJson.getString("goodsId"));
             flag = reserveGoodsOrderTimeV1InnerServiceSMOImpl.queryReserveGoodsOrderTimesCount(reserveGoodsOrderTimeDto);
-            if(flag > 0){
-                throw new CmdException(reqJson.getString("appointmentTime")+","+openTimes.getJSONObject(timeIndex).getString("hours")+"已经被预约");
+            if (flag > 0) {
+                throw new CmdException(reqJson.getString("appointmentTime") + "," + openTimes.getJSONObject(timeIndex).getString("hours") + "已经被预约");
+            }
+
+            quantity = Integer.parseInt(openTimes.getJSONObject(timeIndex).getString("quantity"));
+            if (quantity > Integer.parseInt(reserveGoodsDtos.get(0).getHoursMaxQuantity())) {
+                throw new CmdException("预约数量超过设定数量");
+            }
+        }
+    }
+
+    private void checkAppointmentTime(JSONObject reqJson, ReserveGoodsDto reserveGoodsDto) {
+        Calendar calendar = Calendar.getInstance();
+        calendar.setTime(DateUtil.getDateFromStringB(reqJson.getString("appointmentTime")));
+        int day;
+        String[] days = reserveGoodsDto.getParamWayText().split(",");
+
+        if (ReserveParamsDto.PARAM_WAY_DAY.equals(reserveGoodsDto.getParamWay())) {
+            day = calendar.get(Calendar.DAY_OF_MONTH);
+            if (!Arrays.asList(days).contains(day + "")) {
+                throw new CmdException(reqJson.getString("appointmentTime") + "不能预约");
+            }
+        } else {
+            day = calendar.get(Calendar.DAY_OF_WEEK);
+            boolean isFirstSunday = (calendar.getFirstDayOfWeek() == Calendar.SUNDAY);
+            //获取周几
+            //若一周第一天为星期天,则-1
+            if (isFirstSunday) {
+                day = day - 1;
+                if (day == 0) {
+                    day = 7;
+                }
+            }
+            if (!Arrays.asList(days).contains(day + "")) {
+                throw new CmdException(reqJson.getString("appointmentTime") + "不能预约");
             }
         }
     }
@@ -106,10 +164,10 @@ public class SaveReserveGoodsOrderCmd extends Cmd {
     public void doCmd(CmdEvent event, ICmdDataFlowContext cmdDataFlowContext, JSONObject reqJson) throws CmdException {
         ReserveGoodsOrderPo reserveGoodsOrderPo = BeanConvertUtil.covertBean(reqJson, ReserveGoodsOrderPo.class);
         reserveGoodsOrderPo.setOrderId(GenerateCodeFactory.getGeneratorId(CODE_PREFIX_ID));
-        if(StringUtil.isEmpty(reserveGoodsOrderPo.getExtOrderId())){
+        if (StringUtil.isEmpty(reserveGoodsOrderPo.getExtOrderId())) {
             reserveGoodsOrderPo.setExtOrderId("-1");
         }
-        if(StringUtil.isEmpty(reserveGoodsOrderPo.getState())){
+        if (StringUtil.isEmpty(reserveGoodsOrderPo.getState())) {
             reserveGoodsOrderPo.setState(CommunitySpacePersonDto.STATE_W);
         }
         int flag = reserveGoodsOrderV1InnerServiceSMOImpl.saveReserveGoodsOrder(reserveGoodsOrderPo);
@@ -118,10 +176,10 @@ public class SaveReserveGoodsOrderCmd extends Cmd {
             throw new CmdException("保存数据失败");
         }
 
-        JSONArray openTimes = reqJson.getJSONArray("openTimes");
+        JSONArray openTimes = reqJson.getJSONArray("times");
 
         ReserveGoodsOrderTimePo reserveGoodsOrderTimePo = null;
-        for(int timeIndex = 0 ;timeIndex < openTimes.size(); timeIndex++) {
+        for (int timeIndex = 0; timeIndex < openTimes.size(); timeIndex++) {
             reserveGoodsOrderTimePo = new ReserveGoodsOrderTimePo();
             reserveGoodsOrderTimePo.setCommunityId(reserveGoodsOrderPo.getCommunityId());
             reserveGoodsOrderTimePo.setGoodsId(reserveGoodsOrderPo.getGoodsId());