340 lines
15 KiB
Java
340 lines
15 KiB
Java
package com.jsh.erp.service.depot;
|
||
|
||
import com.alibaba.fastjson.JSONObject;
|
||
import com.baomidou.mybatisplus.core.toolkit.StringUtils;
|
||
import com.jsh.erp.constants.BusinessConstants;
|
||
import com.jsh.erp.constants.ExceptionConstants;
|
||
import com.jsh.erp.datasource.entities.*;
|
||
import com.jsh.erp.datasource.mappers.*;
|
||
import com.jsh.erp.exception.BusinessRunTimeException;
|
||
import com.jsh.erp.service.log.LogService;
|
||
import com.jsh.erp.service.user.UserService;
|
||
import com.jsh.erp.utils.StringUtil;
|
||
import org.slf4j.Logger;
|
||
import org.slf4j.LoggerFactory;
|
||
import org.springframework.stereotype.Service;
|
||
import org.springframework.transaction.annotation.Transactional;
|
||
import org.springframework.web.context.request.RequestContextHolder;
|
||
import org.springframework.web.context.request.ServletRequestAttributes;
|
||
|
||
import javax.annotation.Resource;
|
||
import javax.servlet.http.HttpServletRequest;
|
||
import java.util.Date;
|
||
import java.util.List;
|
||
import java.util.Map;
|
||
|
||
@Service
|
||
public class DepotService {
|
||
private Logger logger = LoggerFactory.getLogger(DepotService.class);
|
||
|
||
@Resource
|
||
private DepotMapper depotMapper;
|
||
|
||
@Resource
|
||
private DepotMapperEx depotMapperEx;
|
||
@Resource
|
||
private UserService userService;
|
||
@Resource
|
||
private LogService logService;
|
||
@Resource
|
||
private DepotHeadMapperEx depotHeadMapperEx;
|
||
@Resource
|
||
private DepotItemMapperEx depotItemMapperEx;
|
||
|
||
public Depot getDepot(long id)throws Exception {
|
||
Depot result=null;
|
||
try{
|
||
result=depotMapper.selectByPrimaryKey(id);
|
||
}catch(Exception e){
|
||
logger.error("异常码[{}],异常提示[{}],异常[{}]",
|
||
ExceptionConstants.DATA_READ_FAIL_CODE,ExceptionConstants.DATA_READ_FAIL_MSG,e);
|
||
throw new BusinessRunTimeException(ExceptionConstants.DATA_READ_FAIL_CODE,
|
||
ExceptionConstants.DATA_READ_FAIL_MSG);
|
||
}
|
||
return result;
|
||
}
|
||
|
||
public List<Depot> getDepot()throws Exception {
|
||
DepotExample example = new DepotExample();
|
||
example.createCriteria().andDeleteFlagNotEqualTo(BusinessConstants.DELETE_FLAG_DELETED);
|
||
List<Depot> list=null;
|
||
try{
|
||
list=depotMapper.selectByExample(example);
|
||
}catch(Exception e){
|
||
logger.error("异常码[{}],异常提示[{}],异常[{}]",
|
||
ExceptionConstants.DATA_READ_FAIL_CODE,ExceptionConstants.DATA_READ_FAIL_MSG,e);
|
||
throw new BusinessRunTimeException(ExceptionConstants.DATA_READ_FAIL_CODE,
|
||
ExceptionConstants.DATA_READ_FAIL_MSG);
|
||
}
|
||
return list;
|
||
}
|
||
|
||
public List<Depot> getAllList()throws Exception {
|
||
DepotExample example = new DepotExample();
|
||
example.createCriteria().andDeleteFlagNotEqualTo(BusinessConstants.DELETE_FLAG_DELETED);
|
||
example.setOrderByClause("sort");
|
||
List<Depot> list=null;
|
||
try{
|
||
list=depotMapper.selectByExample(example);
|
||
}catch(Exception e){
|
||
logger.error("异常码[{}],异常提示[{}],异常[{}]",
|
||
ExceptionConstants.DATA_READ_FAIL_CODE,ExceptionConstants.DATA_READ_FAIL_MSG,e);
|
||
throw new BusinessRunTimeException(ExceptionConstants.DATA_READ_FAIL_CODE,
|
||
ExceptionConstants.DATA_READ_FAIL_MSG);
|
||
}
|
||
return list;
|
||
}
|
||
|
||
public List<Depot> select(String name, Integer type, String remark, int offset, int rows)throws Exception {
|
||
List<Depot> list=null;
|
||
try{
|
||
list=depotMapperEx.selectByConditionDepot(name, type, remark, offset, rows);
|
||
}catch(Exception e){
|
||
logger.error("异常码[{}],异常提示[{}],异常[{}]",
|
||
ExceptionConstants.DATA_READ_FAIL_CODE,ExceptionConstants.DATA_READ_FAIL_MSG,e);
|
||
throw new BusinessRunTimeException(ExceptionConstants.DATA_READ_FAIL_CODE,
|
||
ExceptionConstants.DATA_READ_FAIL_MSG);
|
||
}
|
||
return list;
|
||
}
|
||
|
||
public Long countDepot(String name, Integer type, String remark)throws Exception {
|
||
Long result=null;
|
||
try{
|
||
result=depotMapperEx.countsByDepot(name, type, remark);
|
||
}catch(Exception e){
|
||
logger.error("异常码[{}],异常提示[{}],异常[{}]",
|
||
ExceptionConstants.DATA_READ_FAIL_CODE,ExceptionConstants.DATA_READ_FAIL_MSG,e);
|
||
throw new BusinessRunTimeException(ExceptionConstants.DATA_READ_FAIL_CODE,
|
||
ExceptionConstants.DATA_READ_FAIL_MSG);
|
||
}
|
||
return result;
|
||
}
|
||
|
||
@Transactional(value = "transactionManager", rollbackFor = Exception.class)
|
||
public int insertDepot(String beanJson, HttpServletRequest request)throws Exception {
|
||
Depot depot = JSONObject.parseObject(beanJson, Depot.class);
|
||
int result=0;
|
||
try{
|
||
result=depotMapper.insertSelective(depot);
|
||
}catch(Exception e){
|
||
logger.error("异常码[{}],异常提示[{}],异常[{}]",
|
||
ExceptionConstants.DATA_WRITE_FAIL_CODE,ExceptionConstants.DATA_WRITE_FAIL_MSG,e);
|
||
throw new BusinessRunTimeException(ExceptionConstants.DATA_WRITE_FAIL_CODE,
|
||
ExceptionConstants.DATA_WRITE_FAIL_MSG);
|
||
}
|
||
return result;
|
||
}
|
||
|
||
@Transactional(value = "transactionManager", rollbackFor = Exception.class)
|
||
public int updateDepot(String beanJson, Long id) throws Exception{
|
||
Depot depot = JSONObject.parseObject(beanJson, Depot.class);
|
||
depot.setId(id);
|
||
int result=0;
|
||
try{
|
||
result= depotMapper.updateByPrimaryKeySelective(depot);
|
||
}catch(Exception e){
|
||
logger.error("异常码[{}],异常提示[{}],异常[{}]",
|
||
ExceptionConstants.DATA_WRITE_FAIL_CODE,ExceptionConstants.DATA_WRITE_FAIL_MSG,e);
|
||
throw new BusinessRunTimeException(ExceptionConstants.DATA_WRITE_FAIL_CODE,
|
||
ExceptionConstants.DATA_WRITE_FAIL_MSG);
|
||
}
|
||
return result;
|
||
}
|
||
|
||
@Transactional(value = "transactionManager", rollbackFor = Exception.class)
|
||
public int deleteDepot(Long id)throws Exception {
|
||
int result=0;
|
||
try{
|
||
result= depotMapper.deleteByPrimaryKey(id);
|
||
}catch(Exception e){
|
||
logger.error("异常码[{}],异常提示[{}],异常[{}]",
|
||
ExceptionConstants.DATA_WRITE_FAIL_CODE,ExceptionConstants.DATA_WRITE_FAIL_MSG,e);
|
||
throw new BusinessRunTimeException(ExceptionConstants.DATA_WRITE_FAIL_CODE,
|
||
ExceptionConstants.DATA_WRITE_FAIL_MSG);
|
||
}
|
||
return result;
|
||
}
|
||
|
||
@Transactional(value = "transactionManager", rollbackFor = Exception.class)
|
||
public int batchDeleteDepot(String ids) throws Exception{
|
||
List<Long> idList = StringUtil.strToLongList(ids);
|
||
DepotExample example = new DepotExample();
|
||
example.createCriteria().andIdIn(idList);
|
||
int result=0;
|
||
try{
|
||
result= depotMapper.deleteByExample(example);
|
||
}catch(Exception e){
|
||
logger.error("异常码[{}],异常提示[{}],异常[{}]",
|
||
ExceptionConstants.DATA_WRITE_FAIL_CODE,ExceptionConstants.DATA_WRITE_FAIL_MSG,e);
|
||
throw new BusinessRunTimeException(ExceptionConstants.DATA_WRITE_FAIL_CODE,
|
||
ExceptionConstants.DATA_WRITE_FAIL_MSG);
|
||
}
|
||
return result;
|
||
}
|
||
|
||
public int checkIsNameExist(Long id, String name)throws Exception {
|
||
DepotExample example = new DepotExample();
|
||
example.createCriteria().andIdNotEqualTo(id).andNameEqualTo(name).andDeleteFlagNotEqualTo(BusinessConstants.DELETE_FLAG_DELETED);
|
||
List<Depot> list=null;
|
||
try{
|
||
list= depotMapper.selectByExample(example);
|
||
}catch(Exception e){
|
||
logger.error("异常码[{}],异常提示[{}],异常[{}]",
|
||
ExceptionConstants.DATA_READ_FAIL_CODE,ExceptionConstants.DATA_READ_FAIL_MSG,e);
|
||
throw new BusinessRunTimeException(ExceptionConstants.DATA_READ_FAIL_CODE,
|
||
ExceptionConstants.DATA_READ_FAIL_MSG);
|
||
}
|
||
return list==null?0:list.size();
|
||
}
|
||
|
||
public List<Depot> findUserDepot()throws Exception{
|
||
DepotExample example = new DepotExample();
|
||
example.createCriteria().andTypeEqualTo(0).andDeleteFlagNotEqualTo(BusinessConstants.DELETE_FLAG_DELETED);
|
||
example.setOrderByClause("Sort");
|
||
List<Depot> list=null;
|
||
try{
|
||
list= depotMapper.selectByExample(example);
|
||
}catch(Exception e){
|
||
logger.error("异常码[{}],异常提示[{}],异常[{}]",
|
||
ExceptionConstants.DATA_READ_FAIL_CODE,ExceptionConstants.DATA_READ_FAIL_MSG,e);
|
||
throw new BusinessRunTimeException(ExceptionConstants.DATA_READ_FAIL_CODE,
|
||
ExceptionConstants.DATA_READ_FAIL_MSG);
|
||
}
|
||
return list;
|
||
}
|
||
|
||
public List<Depot> findGiftByType(Integer type)throws Exception{
|
||
DepotExample example = new DepotExample();
|
||
example.createCriteria().andTypeEqualTo(type);
|
||
example.setOrderByClause("Sort");
|
||
List<Depot> list=null;
|
||
try{
|
||
list= depotMapper.selectByExample(example);
|
||
}catch(Exception e){
|
||
logger.error("异常码[{}],异常提示[{}],异常[{}]",
|
||
ExceptionConstants.DATA_READ_FAIL_CODE,ExceptionConstants.DATA_READ_FAIL_MSG,e);
|
||
throw new BusinessRunTimeException(ExceptionConstants.DATA_READ_FAIL_CODE,
|
||
ExceptionConstants.DATA_READ_FAIL_MSG);
|
||
}
|
||
return list;
|
||
}
|
||
|
||
public List<DepotEx> getDepotList(Map<String, Object> parameterMap)throws Exception {
|
||
List<DepotEx> list=null;
|
||
try{
|
||
list= depotMapperEx.getDepotList(parameterMap);
|
||
}catch(Exception e){
|
||
logger.error("异常码[{}],异常提示[{}],异常[{}]",
|
||
ExceptionConstants.DATA_READ_FAIL_CODE,ExceptionConstants.DATA_READ_FAIL_MSG,e);
|
||
throw new BusinessRunTimeException(ExceptionConstants.DATA_READ_FAIL_CODE,
|
||
ExceptionConstants.DATA_READ_FAIL_MSG);
|
||
}
|
||
return list;
|
||
}
|
||
@Transactional(value = "transactionManager", rollbackFor = Exception.class)
|
||
public int batchDeleteDepotByIds(String ids)throws Exception {
|
||
logService.insertLog(BusinessConstants.LOG_INTERFACE_NAME_DEPOT,
|
||
new StringBuffer(BusinessConstants.LOG_OPERATION_TYPE_DELETE).append(ids).toString(),
|
||
((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getRequest());
|
||
User userInfo=userService.getCurrentUser();
|
||
String [] idArray=ids.split(",");
|
||
int result=0;
|
||
try{
|
||
result= depotMapperEx.batchDeleteDepotByIds(new Date(),userInfo==null?null:userInfo.getId(),idArray);
|
||
}catch(Exception e){
|
||
logger.error("异常码[{}],异常提示[{}],异常[{}]",
|
||
ExceptionConstants.DATA_WRITE_FAIL_CODE,ExceptionConstants.DATA_WRITE_FAIL_MSG,e);
|
||
throw new BusinessRunTimeException(ExceptionConstants.DATA_WRITE_FAIL_CODE,
|
||
ExceptionConstants.DATA_WRITE_FAIL_MSG);
|
||
}
|
||
return result;
|
||
}
|
||
/**
|
||
* create by: qiankunpingtai
|
||
* website:https://qiankunpingtai.cn
|
||
* description:
|
||
* 正常删除,要考虑数据完整性,进行完整性校验
|
||
* create time: 2019/4/10 16:52
|
||
* @Param: ids
|
||
* @return int
|
||
*/
|
||
@Transactional(value = "transactionManager", rollbackFor = Exception.class)
|
||
public int batchDeleteDepotByIdsNormal(String ids) throws Exception {
|
||
/**
|
||
* 校验
|
||
* 1、单据主表 jsh_depothead
|
||
* 2、单据子表 jsh_depotitem
|
||
* 是否有相关数据
|
||
* */
|
||
int deleteTotal=0;
|
||
if(StringUtils.isEmpty(ids)){
|
||
return deleteTotal;
|
||
}
|
||
String [] idArray=ids.split(",");
|
||
|
||
/**
|
||
* 校验单据主表 jsh_depothead
|
||
* */
|
||
List<DepotHead> depotHeadList=null;
|
||
try{
|
||
depotHeadList= depotHeadMapperEx.getDepotHeadListByDepotIds(idArray);
|
||
}catch(Exception e){
|
||
logger.error("异常码[{}],异常提示[{}],异常[{}]",
|
||
ExceptionConstants.DATA_READ_FAIL_CODE,ExceptionConstants.DATA_READ_FAIL_MSG,e);
|
||
throw new BusinessRunTimeException(ExceptionConstants.DATA_READ_FAIL_CODE,
|
||
ExceptionConstants.DATA_READ_FAIL_MSG);
|
||
}
|
||
if(depotHeadList!=null&&depotHeadList.size()>0){
|
||
logger.error("异常码[{}],异常提示[{}],参数,DepotIds[{}]",
|
||
ExceptionConstants.DELETE_FORCE_CONFIRM_CODE,ExceptionConstants.DELETE_FORCE_CONFIRM_MSG,ids);
|
||
throw new BusinessRunTimeException(ExceptionConstants.DELETE_FORCE_CONFIRM_CODE,
|
||
ExceptionConstants.DELETE_FORCE_CONFIRM_MSG);
|
||
}
|
||
/**
|
||
* 校验单据子表 jsh_depotitem
|
||
* */
|
||
List<DepotItem> depotItemList=null;
|
||
try{
|
||
depotItemList= depotItemMapperEx.getDepotItemListListByDepotIds(idArray);
|
||
}catch(Exception e){
|
||
logger.error("异常码[{}],异常提示[{}],异常[{}]",
|
||
ExceptionConstants.DATA_READ_FAIL_CODE,ExceptionConstants.DATA_READ_FAIL_MSG,e);
|
||
throw new BusinessRunTimeException(ExceptionConstants.DATA_READ_FAIL_CODE,
|
||
ExceptionConstants.DATA_READ_FAIL_MSG);
|
||
}
|
||
if(depotItemList!=null&&depotItemList.size()>0){
|
||
logger.error("异常码[{}],异常提示[{}],参数,DepotIds[{}]",
|
||
ExceptionConstants.DELETE_FORCE_CONFIRM_CODE,ExceptionConstants.DELETE_FORCE_CONFIRM_MSG,ids);
|
||
throw new BusinessRunTimeException(ExceptionConstants.DELETE_FORCE_CONFIRM_CODE,
|
||
ExceptionConstants.DELETE_FORCE_CONFIRM_MSG);
|
||
}
|
||
/**
|
||
* 校验通过执行删除操作
|
||
* */
|
||
deleteTotal= batchDeleteDepotByIds(ids);
|
||
return deleteTotal;
|
||
|
||
}
|
||
|
||
@Transactional(value = "transactionManager", rollbackFor = Exception.class)
|
||
public int updateDepotIsDefault(Boolean isDefault, Long depotID) throws Exception{
|
||
logService.insertLog(BusinessConstants.LOG_INTERFACE_NAME_DEPOT,BusinessConstants.LOG_OPERATION_TYPE_EDIT+depotID,
|
||
((ServletRequestAttributes) RequestContextHolder.getRequestAttributes()).getRequest());
|
||
Depot depot = new Depot();
|
||
depot.setIsdefault(isDefault);
|
||
DepotExample example = new DepotExample();
|
||
example.createCriteria().andIdEqualTo(depotID);
|
||
int result=0;
|
||
try{
|
||
result = depotMapper.updateByExampleSelective(depot, example);
|
||
}catch(Exception e){
|
||
logger.error("异常码[{}],异常提示[{}],异常[{}]",
|
||
ExceptionConstants.DATA_WRITE_FAIL_CODE,ExceptionConstants.DATA_WRITE_FAIL_MSG,e);
|
||
throw new BusinessRunTimeException(ExceptionConstants.DATA_WRITE_FAIL_CODE,
|
||
ExceptionConstants.DATA_WRITE_FAIL_MSG);
|
||
}
|
||
return result;
|
||
}
|
||
}
|