| | |
| | | |
| | | import com.alibaba.fastjson.JSONObject; |
| | | import com.java110.core.annotation.Java110Cmd; |
| | | import com.java110.core.annotation.Java110Transactional; |
| | | import com.java110.core.context.ICmdDataFlowContext; |
| | | import com.java110.core.event.cmd.Cmd; |
| | | import com.java110.core.event.cmd.CmdEvent; |
| | | import com.java110.core.factory.GenerateCodeFactory; |
| | | import com.java110.doc.annotation.*; |
| | | import com.java110.dto.RoomDto; |
| | | import com.java110.dto.UnitDto; |
| | | import com.java110.dto.owner.OwnerRoomRelDto; |
| | | import com.java110.intf.community.IRoomV1InnerServiceSMO; |
| | | import com.java110.intf.community.IUnitInnerServiceSMO; |
| | | import com.java110.intf.user.IOwnerRoomRelV1InnerServiceSMO; |
| | | import com.java110.po.owner.OwnerRoomRelPo; |
| | | import com.java110.po.room.RoomPo; |
| | | import com.java110.utils.cache.MappingCache; |
| | | import com.java110.utils.constant.CommonConstant; |
| | | 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 org.springframework.beans.factory.annotation.Autowired; |
| | | |
| | | import java.util.List; |
| | | |
| | | |
| | | @Java110CmdDoc(title = "添加房屋", |
| | | description = "对应后台 添加房屋功能", |
| | | httpMethod = "post", |
| | | url = "http://{ip}:{port}/app/room.saveRoom", |
| | | resource = "communityDoc", |
| | | author = "吴学文", |
| | | serviceCode = "room.saveRoom", |
| | | seq = 13 |
| | | ) |
| | | |
| | | @Java110ParamsDoc(params = { |
| | | @Java110ParamDoc(name = "communityId", length = 30, remark = "小区ID"), |
| | | @Java110ParamDoc(name = "roomNum", length = 64, remark = "房号"), |
| | | @Java110ParamDoc(name = "layer", length = 12, remark = "层数"), |
| | | @Java110ParamDoc(name = "unitId", length = 30, remark = "单元ID"), |
| | | @Java110ParamDoc(name = "section", length = 12, remark = "房屋个数"), |
| | | @Java110ParamDoc(name = "apartment", length = 12, remark = "固定 10102"), |
| | | @Java110ParamDoc(name = "builtUpArea", length = 12, remark = "建筑面积"), |
| | | @Java110ParamDoc(name = "feeCoefficient", length = 12, remark = "算费系数 固定1"), |
| | | @Java110ParamDoc(name = "state", length = 12, remark = "状态 2002\t未销售"), |
| | | @Java110ParamDoc(name = "roomSubType", length = 12, remark = "房屋类型 110\t住宅\n" + |
| | | "120\t办公室\n" + |
| | | "119\t宿舍"), |
| | | @Java110ParamDoc(name = "roomArea", length = 12, remark = "室内面积"), |
| | | @Java110ParamDoc(name = "roomRent", length = 12, remark = "办公室 或者宿舍 时租金"), |
| | | @Java110ParamDoc(name = "remark", length = 512, remark = "备注"), |
| | | }) |
| | | |
| | | @Java110ResponseDoc( |
| | | params = { |
| | | @Java110ParamDoc(name = "code", type = "int", length = 11, defaultValue = "0", remark = "返回编号,0 成功 其他失败"), |
| | | @Java110ParamDoc(name = "msg", type = "String", length = 250, defaultValue = "成功", remark = "描述"), |
| | | } |
| | | ) |
| | | |
| | | @Java110ExampleDoc( |
| | | reqBody = "{\n" + |
| | | "\t\"roomNum\": \"88488\",\n" + |
| | | "\t\"layer\": \"1\",\n" + |
| | | "\t\"unitId\":\"123123123\",\n" + |
| | | "\t\"section\": \"0\",\n" + |
| | | "\t\"apartment\": \"10102\",\n" + |
| | | "\t\"builtUpArea\": \"110\",\n" + |
| | | "\t\"feeCoefficient\": \"1.00\",\n" + |
| | | "\t\"state\": \"2002\",\n" + |
| | | "\t\"remark\": \"sdf\",\n" + |
| | | "\t\"roomSubType\": \"110\",\n" + |
| | | "\t\"roomArea\": \"110\",\n" + |
| | | "\t\"roomRent\": \"0\",\n" + |
| | | "\t\"communityId\": \"2022121921870161\",\n" + |
| | | "}", |
| | | resBody = "{\"code\":0,\"msg\":\"成功\"}" |
| | | ) |
| | | |
| | | @Java110Cmd(serviceCode = "room.saveRoom") |
| | | public class SaveRoomCmd extends Cmd { |
| | |
| | | |
| | | @Autowired |
| | | private IRoomV1InnerServiceSMO roomV1InnerServiceSMOImpl; |
| | | |
| | | @Autowired |
| | | private IOwnerRoomRelV1InnerServiceSMO ownerRoomRelV1InnerServiceSMOImpl; |
| | | |
| | | @Override |
| | | public void validate(CmdEvent event, ICmdDataFlowContext context, JSONObject reqJson) throws CmdException { |
| | |
| | | reqJson.put("roomRent", reqJson.getString("builtUpArea")); |
| | | } |
| | | |
| | | if (!RoomDto.STATE_FREE.equals(reqJson.getString("state"))) { |
| | | Assert.hasKeyAndValue(reqJson, "ownerId", "未包含业主信息"); |
| | | } |
| | | |
| | | /*if (!"1010".equals(reqJson.getString("apartment")) && !"2020".equals(reqJson.getString("apartment"))) { |
| | | throw new IllegalArgumentException("不是有效房屋户型 传入数据错误"); |
| | | }*/ |
| | |
| | | if (!"2001".equals(reqJson.getString("state")) |
| | | && !"2002".equals(reqJson.getString("state")) |
| | | && !"2003".equals(reqJson.getString("state")) |
| | | && !"2004".equals(reqJson.getString("state"))) { |
| | | && !"2004".equals(reqJson.getString("state")) |
| | | && !"2005".equals(reqJson.getString("state")) |
| | | && !"2009".equals(reqJson.getString("state"))) { |
| | | throw new IllegalArgumentException("不是有效房屋状态 传入数据错误"); |
| | | } |
| | | |
| | |
| | | } |
| | | |
| | | @Override |
| | | @Java110Transactional |
| | | public void doCmd(CmdEvent event, ICmdDataFlowContext context, JSONObject reqJson) throws CmdException { |
| | | if ("0".equals(reqJson.getString("unitNum"))) { // 处理为商铺 |
| | | reqJson.put("roomType", RoomDto.ROOM_TYPE_SHOPS); |
| | | } else { |
| | | reqJson.put("roomType", RoomDto.ROOM_TYPE_ROOM); |
| | | } |
| | | |
| | | |
| | | reqJson.put("roomId", GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_roomId)); |
| | | reqJson.put("userId", context.getReqHeaders().get(CommonConstant.HTTP_USER_ID)); |
| | | RoomPo roomPo = BeanConvertUtil.covertBean(reqJson, RoomPo.class); |
| | | roomV1InnerServiceSMOImpl.saveRoom(roomPo); |
| | | |
| | | if (RoomDto.STATE_FREE.equals(roomPo.getState())) { |
| | | return; |
| | | } |
| | | |
| | | |
| | | if (!reqJson.containsKey("startTime")) { |
| | | reqJson.put("startTime", DateUtil.getNow(DateUtil.DATE_FORMATE_STRING_A)); |
| | | } |
| | | if (!reqJson.containsKey("endTime")) { |
| | | reqJson.put("endTime", "2037-01-01 00:00:00"); |
| | | } |
| | | OwnerRoomRelPo ownerRoomRelPo = new OwnerRoomRelPo(); |
| | | ownerRoomRelPo.setRelId(GenerateCodeFactory.getGeneratorId(GenerateCodeFactory.CODE_PREFIX_relId)); |
| | | ownerRoomRelPo.setRoomId(roomPo.getRoomId()); |
| | | ownerRoomRelPo.setOwnerId(reqJson.getString("ownerId")); |
| | | ownerRoomRelPo.setStartTime(reqJson.getString("startTime")); |
| | | ownerRoomRelPo.setEndTime(reqJson.getString("endTime")); |
| | | ownerRoomRelPo.setState("2001"); |
| | | ownerRoomRelPo.setRemark("添加房屋直接绑定"); |
| | | ownerRoomRelPo.setOperate("ADD"); |
| | | ownerRoomRelPo.setUserId("-1"); |
| | | int flag = ownerRoomRelV1InnerServiceSMOImpl.saveOwnerRoomRel(ownerRoomRelPo); |
| | | |
| | | if (flag < 1) { |
| | | throw new CmdException("添加业主房屋关系"); |
| | | } |
| | | |
| | | |
| | | } |
| | | } |