From 5af3e49dd60158bfe819135f7cbb45438ca015e2 Mon Sep 17 00:00:00 2001 From: jiangping <jp@doumee.com> Date: 星期二, 15 七月 2025 15:18:30 +0800 Subject: [PATCH] Merge remote-tracking branch 'origin/master' --- server/services/src/main/java/com/doumee/service/business/impl/ReceiveWeightServiceImpl.java | 112 ++++++++++++++++++++++++++++++------------------------- 1 files changed, 61 insertions(+), 51 deletions(-) diff --git a/server/services/src/main/java/com/doumee/service/business/impl/ReceiveWeightServiceImpl.java b/server/services/src/main/java/com/doumee/service/business/impl/ReceiveWeightServiceImpl.java index 14fd298..48f288f 100644 --- a/server/services/src/main/java/com/doumee/service/business/impl/ReceiveWeightServiceImpl.java +++ b/server/services/src/main/java/com/doumee/service/business/impl/ReceiveWeightServiceImpl.java @@ -1,20 +1,31 @@ package com.doumee.service.business.impl; +import com.doumee.core.constants.Constants; +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.Utils; import com.doumee.dao.business.ReceiveWeightMapper; +import com.doumee.dao.business.model.Category; import com.doumee.dao.business.model.ReceiveWeight; +import com.doumee.dao.system.model.SystemUser; import com.doumee.service.business.ReceiveWeightService; 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.apache.shiro.SecurityUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Service; +import org.springframework.transaction.annotation.Transactional; import org.springframework.util.CollectionUtils; +import java.util.Date; import java.util.List; +import java.util.Objects; /** * 鎺ュ崟鏉冮噸閰嶇疆琛⊿ervice瀹炵幇 @@ -28,14 +39,35 @@ private ReceiveWeightMapper receiveWeightMapper; @Override + @Transactional(rollbackFor = {Exception.class,BusinessException.class}) public Integer create(ReceiveWeight receiveWeight) { + if(Objects.isNull(receiveWeight) + || Objects.isNull(receiveWeight.getReceiveMin()) + || Objects.isNull(receiveWeight.getReceiveMax()) + || Objects.isNull(receiveWeight.getLevel()) + || Objects.isNull(receiveWeight.getDelayTime()) + || receiveWeight.getLevel() < 1 || receiveWeight.getLevel() > 10 + ){ + throw new BusinessException(ResponseStatus.BAD_REQUEST); + } + LoginUserInfo loginUserInfo = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal(); + receiveWeight.setCreateTime(new Date()); + receiveWeight.setCreateUser(loginUserInfo.getId()); + receiveWeight.setUpdateTime(receiveWeight.getCreateTime()); + receiveWeight.setUpdateUser(loginUserInfo.getId()); + receiveWeight.setDeleted(Constants.ZERO); + //鏌ヨ浼樺厛绾ф槸鍚﹀凡瀛樺湪 + if(receiveWeightMapper.selectCount(new QueryWrapper<ReceiveWeight>().lambda() + .eq(ReceiveWeight::getDeleted,Constants.ZERO).eq(ReceiveWeight::getLevel,receiveWeight.getLevel()))>Constants.ZERO){ + throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"浼樺厛绾у凡瀛樺湪"); + } receiveWeightMapper.insert(receiveWeight); return receiveWeight.getId(); } @Override public void deleteById(Integer id) { - receiveWeightMapper.deleteById(id); + receiveWeightMapper.update(new UpdateWrapper<ReceiveWeight>().lambda().set(ReceiveWeight::getDeleted,Constants.ONE).eq(ReceiveWeight::getId,id)); } @Override @@ -53,7 +85,27 @@ } @Override + @Transactional(rollbackFor = {Exception.class,BusinessException.class}) public void updateById(ReceiveWeight receiveWeight) { + if(Objects.isNull(receiveWeight) + || Objects.isNull(receiveWeight.getId()) + || Objects.isNull(receiveWeight.getReceiveMin()) + || Objects.isNull(receiveWeight.getReceiveMax()) + || Objects.isNull(receiveWeight.getLevel()) + || Objects.isNull(receiveWeight.getDelayTime()) + || receiveWeight.getLevel() < 1 || receiveWeight.getLevel() > 10 + ){ + throw new BusinessException(ResponseStatus.BAD_REQUEST); + } + LoginUserInfo loginUserInfo = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal(); + receiveWeight.setUpdateTime(receiveWeight.getCreateTime()); + receiveWeight.setUpdateUser(loginUserInfo.getId()); + receiveWeight.setDeleted(Constants.ZERO); + //鏌ヨ浼樺厛绾ф槸鍚﹀凡瀛樺湪 + if(receiveWeightMapper.selectCount(new QueryWrapper<ReceiveWeight>().lambda().ne(ReceiveWeight::getId,receiveWeight.getId()) + .eq(ReceiveWeight::getDeleted,Constants.ZERO).eq(ReceiveWeight::getLevel,receiveWeight.getLevel()))>Constants.ZERO){ + throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"浼樺厛绾у凡瀛樺湪"); + } receiveWeightMapper.updateById(receiveWeight); } @@ -87,57 +139,15 @@ @Override public PageData<ReceiveWeight> findPage(PageWrap<ReceiveWeight> pageWrap) { IPage<ReceiveWeight> page = new Page<>(pageWrap.getPage(), pageWrap.getCapacity()); - QueryWrapper<ReceiveWeight> queryWrapper = new QueryWrapper<>(); + MPJLambdaWrapper<ReceiveWeight> queryWrapper = new MPJLambdaWrapper<>(); Utils.MP.blankToNull(pageWrap.getModel()); - if (pageWrap.getModel().getId() != null) { - queryWrapper.lambda().eq(ReceiveWeight::getId, pageWrap.getModel().getId()); - } - if (pageWrap.getModel().getDeleted() != null) { - queryWrapper.lambda().eq(ReceiveWeight::getDeleted, pageWrap.getModel().getDeleted()); - } - if (pageWrap.getModel().getStatus() != null) { - queryWrapper.lambda().eq(ReceiveWeight::getStatus, pageWrap.getModel().getStatus()); - } - if (pageWrap.getModel().getCreateUser() != null) { - queryWrapper.lambda().eq(ReceiveWeight::getCreateUser, pageWrap.getModel().getCreateUser()); - } - if (pageWrap.getModel().getCreateTime() != null) { - queryWrapper.lambda().ge(ReceiveWeight::getCreateTime, Utils.Date.getStart(pageWrap.getModel().getCreateTime())); - queryWrapper.lambda().le(ReceiveWeight::getCreateTime, Utils.Date.getEnd(pageWrap.getModel().getCreateTime())); - } - if (pageWrap.getModel().getUpdateUser() != null) { - queryWrapper.lambda().eq(ReceiveWeight::getUpdateUser, pageWrap.getModel().getUpdateUser()); - } - if (pageWrap.getModel().getUpdateTime() != null) { - queryWrapper.lambda().ge(ReceiveWeight::getUpdateTime, Utils.Date.getStart(pageWrap.getModel().getUpdateTime())); - queryWrapper.lambda().le(ReceiveWeight::getUpdateTime, Utils.Date.getEnd(pageWrap.getModel().getUpdateTime())); - } - if (pageWrap.getModel().getRemark() != null) { - queryWrapper.lambda().eq(ReceiveWeight::getRemark, pageWrap.getModel().getRemark()); - } - if (pageWrap.getModel().getReceiveMax() != null) { - queryWrapper.lambda().eq(ReceiveWeight::getReceiveMax, pageWrap.getModel().getReceiveMax()); - } - if (pageWrap.getModel().getReceiveMin() != null) { - queryWrapper.lambda().eq(ReceiveWeight::getReceiveMin, pageWrap.getModel().getReceiveMin()); - } - if (pageWrap.getModel().getLevel() != null) { - queryWrapper.lambda().eq(ReceiveWeight::getLevel, pageWrap.getModel().getLevel()); - } - if (pageWrap.getModel().getDelayTime() != null) { - queryWrapper.lambda().eq(ReceiveWeight::getDelayTime, pageWrap.getModel().getDelayTime()); - } - if (pageWrap.getModel().getSortnum() != null) { - queryWrapper.lambda().eq(ReceiveWeight::getSortnum, pageWrap.getModel().getSortnum()); - } - for(PageWrap.SortData sortData: pageWrap.getSorts()) { - if (sortData.getDirection().equalsIgnoreCase(PageWrap.DESC)) { - queryWrapper.orderByDesc(sortData.getProperty()); - } else { - queryWrapper.orderByAsc(sortData.getProperty()); - } - } - return PageData.from(receiveWeightMapper.selectPage(page, queryWrapper)); + queryWrapper.selectAll(ReceiveWeight.class) + .selectAs(SystemUser::getRealname,ReceiveWeight::getUpdateUserName) + .leftJoin(SystemUser.class,SystemUser::getId,ReceiveWeight::getUpdateUser) + .eq(ReceiveWeight::getDeleted,Constants.ZERO) + .orderByDesc(ReceiveWeight::getLevel); + PageData<ReceiveWeight> result =PageData.from(receiveWeightMapper.selectJoinPage(page, ReceiveWeight.class,queryWrapper)); + return result; } @Override -- Gitblit v1.9.3