package com.doumee.service.business.impl;
|
|
import com.doumee.core.constants.ResponseStatus;
|
import com.doumee.core.exception.BusinessException;
|
import com.doumee.core.model.LoginUserInfo;
|
import com.doumee.core.model.PageData;
|
import com.doumee.core.model.PageWrap;
|
import com.doumee.core.utils.Constants;
|
import com.doumee.core.utils.Utils;
|
import com.doumee.dao.business.YwBuildingMapper;
|
import com.doumee.dao.business.YwProjectMapper;
|
import com.doumee.dao.business.model.YwBuilding;
|
import com.doumee.dao.business.model.YwProject;
|
import com.doumee.service.business.YwBuildingService;
|
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
import com.baomidou.mybatisplus.core.conditions.update.UpdateWrapper;
|
import com.baomidou.mybatisplus.core.metadata.IPage;
|
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
import com.github.yulichang.wrapper.MPJLambdaWrapper;
|
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.stereotype.Service;
|
import org.springframework.util.CollectionUtils;
|
|
import java.util.Date;
|
import java.util.List;
|
|
/**
|
* 运维楼宇信息表Service实现
|
* @author 江蹄蹄
|
* @date 2024/11/19 16:07
|
*/
|
@Service
|
public class YwBuildingServiceImpl implements YwBuildingService {
|
|
@Autowired
|
private YwBuildingMapper ywBuildingMapper;
|
@Autowired
|
private YwProjectMapper ywProjectMapper;
|
|
@Override
|
public Integer create(YwBuilding model) {
|
if(model.getProjectId()==null){
|
throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"对不起,请选择正确的项目信息!");
|
}
|
YwProject ywProject = ywProjectMapper.selectById(model.getProjectId());
|
if(ywProject ==null ||Constants.equalsInteger(ywProject.getIsdeleted(),Constants.ONE)){
|
throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"对不起,请选择正确的项目信息!");
|
}
|
model.setCreator(model.getLoginUserInfo().getId());
|
model.setIsdeleted(Constants.ZERO);
|
model.setCreateDate(new Date());
|
model.setStatus(Constants.ZERO);
|
model.setEditDate(model.getCreateDate());
|
model.setEditor(model.getCreator());
|
ywBuildingMapper.insert(model);
|
return model.getId();
|
}
|
|
@Override
|
public void deleteById(Integer id, LoginUserInfo user) {
|
YwBuilding model = new YwBuilding();
|
model.setId(id);
|
model.setEditDate(new Date());
|
model.setEditor(user.getId());
|
model.setIsdeleted(Constants.ONE);
|
ywBuildingMapper.updateById(model);
|
}
|
|
@Override
|
public void delete(YwBuilding ywBuilding) {
|
UpdateWrapper<YwBuilding> deleteWrapper = new UpdateWrapper<>(ywBuilding);
|
ywBuildingMapper.delete(deleteWrapper);
|
}
|
|
@Override
|
public void deleteByIdInBatch(List<Integer> ids, LoginUserInfo user) {
|
if (CollectionUtils.isEmpty(ids)) {
|
return;
|
}
|
for(Integer id : ids){
|
this.deleteById(id,user);
|
}
|
}
|
|
@Override
|
public void updateById(YwBuilding model) {
|
model.setEditDate(new Date());
|
model.setEditor(model.getLoginUserInfo().getId());
|
ywBuildingMapper.updateById(model);
|
}
|
|
@Override
|
public void updateByIdInBatch(List<YwBuilding> ywBuildings) {
|
if (CollectionUtils.isEmpty(ywBuildings)) {
|
return;
|
}
|
for (YwBuilding ywBuilding: ywBuildings) {
|
this.updateById(ywBuilding);
|
}
|
}
|
|
@Override
|
public YwBuilding findById(Integer id) {
|
return ywBuildingMapper.selectById(id);
|
}
|
|
@Override
|
public YwBuilding findOne(YwBuilding ywBuilding) {
|
QueryWrapper<YwBuilding> wrapper = new QueryWrapper<>(ywBuilding);
|
return ywBuildingMapper.selectOne(wrapper);
|
}
|
|
@Override
|
public List<YwBuilding> findList(YwBuilding ywBuilding) {
|
ywBuilding.setIsdeleted(Constants.ZERO);
|
QueryWrapper<YwBuilding> wrapper = new QueryWrapper<>(ywBuilding);
|
return ywBuildingMapper.selectList(wrapper);
|
}
|
|
@Override
|
public PageData<YwBuilding> findPage(PageWrap<YwBuilding> pageWrap) {
|
IPage<YwBuilding> page = new Page<>(pageWrap.getPage(), pageWrap.getCapacity());
|
MPJLambdaWrapper<YwBuilding> queryWrapper = new MPJLambdaWrapper<>();
|
queryWrapper.selectAll(YwBuilding.class )
|
.selectAs(YwProject::getName,YwBuilding::getProjectName)
|
.leftJoin(YwProject.class,YwProject::getId,YwBuilding::getProjectId);
|
Utils.MP.blankToNull(pageWrap.getModel());
|
pageWrap.getModel().setIsdeleted(Constants.ZERO);
|
queryWrapper.select(" (select count(1) from yw_room a where a.isdeleted=0 and a.BUILDING_ID=t.id) as roomNum "+
|
",(select count(1) from yw_room a where a.isdeleted=0 and a.BUILDING_ID=t.id and a.IS_INVESTMENT=1) as roomRentNum");
|
if (pageWrap.getModel().getId() != null) {
|
queryWrapper.eq(YwBuilding::getId, pageWrap.getModel().getId());
|
}
|
if (pageWrap.getModel().getCreator() != null) {
|
queryWrapper.eq(YwBuilding::getCreator, pageWrap.getModel().getCreator());
|
}
|
if (pageWrap.getModel().getCreateDate() != null) {
|
queryWrapper.ge(YwBuilding::getCreateDate, Utils.Date.getStart(pageWrap.getModel().getCreateDate()));
|
queryWrapper.le(YwBuilding::getCreateDate, Utils.Date.getEnd(pageWrap.getModel().getCreateDate()));
|
}
|
if (pageWrap.getModel().getEditor() != null) {
|
queryWrapper.eq(YwBuilding::getEditor, pageWrap.getModel().getEditor());
|
}
|
if (pageWrap.getModel().getEditDate() != null) {
|
queryWrapper.ge(YwBuilding::getEditDate, Utils.Date.getStart(pageWrap.getModel().getEditDate()));
|
queryWrapper.le(YwBuilding::getEditDate, Utils.Date.getEnd(pageWrap.getModel().getEditDate()));
|
}
|
if (pageWrap.getModel().getIsdeleted() != null) {
|
queryWrapper.eq(YwBuilding::getIsdeleted, pageWrap.getModel().getIsdeleted());
|
}
|
if (pageWrap.getModel().getName() != null) {
|
queryWrapper.eq(YwBuilding::getName, pageWrap.getModel().getName());
|
}
|
if (pageWrap.getModel().getRemark() != null) {
|
queryWrapper.eq(YwBuilding::getRemark, pageWrap.getModel().getRemark());
|
}
|
if (pageWrap.getModel().getStatus() != null) {
|
queryWrapper.eq(YwBuilding::getStatus, pageWrap.getModel().getStatus());
|
}
|
if (pageWrap.getModel().getSortnum() != null) {
|
queryWrapper.eq(YwBuilding::getSortnum, pageWrap.getModel().getSortnum());
|
}
|
if (pageWrap.getModel().getImgurl() != null) {
|
queryWrapper.eq(YwBuilding::getImgurl, pageWrap.getModel().getImgurl());
|
}
|
if (pageWrap.getModel().getCode() != null) {
|
queryWrapper.eq(YwBuilding::getCode, pageWrap.getModel().getCode());
|
}
|
if (pageWrap.getModel().getAddr() != null) {
|
queryWrapper.eq(YwBuilding::getAddr, pageWrap.getModel().getAddr());
|
}
|
if (pageWrap.getModel().getArea() != null) {
|
queryWrapper.eq(YwBuilding::getArea, pageWrap.getModel().getArea());
|
}
|
if (pageWrap.getModel().getCqArea() != null) {
|
queryWrapper.eq(YwBuilding::getCqArea, pageWrap.getModel().getCqArea());
|
}
|
if (pageWrap.getModel().getRentArea() != null) {
|
queryWrapper.eq(YwBuilding::getRentArea, pageWrap.getModel().getRentArea());
|
}
|
if (pageWrap.getModel().getOnFloor() != null) {
|
queryWrapper.eq(YwBuilding::getOnFloor, pageWrap.getModel().getOnFloor());
|
}
|
if (pageWrap.getModel().getUnderFloor() != null) {
|
queryWrapper.eq(YwBuilding::getUnderFloor, pageWrap.getModel().getUnderFloor());
|
}
|
if (pageWrap.getModel().getProjectId() != null) {
|
queryWrapper.eq(YwBuilding::getProjectId, pageWrap.getModel().getProjectId());
|
}
|
for(PageWrap.SortData sortData: pageWrap.getSorts()) {
|
if (sortData.getDirection().equalsIgnoreCase(PageWrap.DESC)) {
|
queryWrapper.orderByDesc(sortData.getProperty());
|
} else {
|
queryWrapper.orderByAsc(sortData.getProperty());
|
}
|
}
|
return PageData.from(ywBuildingMapper.selectJoinPage(page,YwBuilding.class, queryWrapper));
|
}
|
|
@Override
|
public long count(YwBuilding ywBuilding) {
|
QueryWrapper<YwBuilding> wrapper = new QueryWrapper<>(ywBuilding);
|
return ywBuildingMapper.selectCount(wrapper);
|
}
|
}
|