@ -17,8 +17,6 @@
package com.logpm.basicdata.service.impl ;
import com.alibaba.fastjson.JSONObject ;
import com.baomidou.mybatisplus.core.conditions.Wrapper ;
import com.baomidou.mybatisplus.core.metadata.IPage ;
@ -35,6 +33,8 @@ import com.logpm.basicdata.service.IBasicdataGoodsAllocationService;
import com.logpm.basicdata.service.IBasicdataGoodsShelfService ;
import com.logpm.basicdata.vo.BasicdataGoodsShelfVO ;
import lombok.AllArgsConstructor ;
import lombok.extern.log4j.Log4j ;
import lombok.extern.log4j.Log4j2 ;
import org.springblade.common.utils.FileUtil ;
import org.springblade.common.utils.QRCodeUtil ;
import org.springblade.common.utils.TemplateUtil ;
@ -66,6 +66,7 @@ import java.util.concurrent.TimeUnit;
* /
@Service
@AllArgsConstructor
@Log4j2
public class BasicdataGoodsShelfServiceImpl extends BaseServiceImpl < BasicdataGoodsShelfMapper , BasicdataGoodsShelfEntity > implements IBasicdataGoodsShelfService {
private BasicdataGoodsShelfMapper basicdataGoodsShelfMapper ;
@ -77,7 +78,6 @@ public class BasicdataGoodsShelfServiceImpl extends BaseServiceImpl<BasicdataGoo
private IBasicdataGoodsAllocationService basicdataGoodsAllocationService ;
@Override
public IPage < BasicdataGoodsShelfVO > selectBasicdataGoodsShelfPage ( IPage < BasicdataGoodsShelfVO > page , BasicdataGoodsShelfVO basicdataGoodsShelfVO ) {
return page . setRecords ( baseMapper . selectBasicdataGoodsShelfPage ( page , basicdataGoodsShelfVO ) ) ;
@ -94,8 +94,8 @@ public class BasicdataGoodsShelfServiceImpl extends BaseServiceImpl<BasicdataGoo
}
@Override
public IPage < BasicdataGoodsShelfVO > getGoodsShelfList ( IPage < Object > page , Map < String , Object > basicdataGoodsShelf ) {
IPage < BasicdataGoodsShelfVO > basicdataGoodsShelfVOIPage = basicdataGoodsShelfMapper . getGoodsShelfList ( page , basicdataGoodsShelf ) ;
public IPage < BasicdataGoodsShelfVO > getGoodsShelfList ( IPage < Object > page , Map < String , Object > basicdataGoodsShelf ) {
IPage < BasicdataGoodsShelfVO > basicdataGoodsShelfVOIPage = basicdataGoodsShelfMapper . getGoodsShelfList ( page , basicdataGoodsShelf ) ;
// redisUtil.set("aaa","aaa");
// WebUtil.getResponseEncodedHtmlEscape()
return basicdataGoodsShelfVOIPage ;
@ -105,63 +105,70 @@ public class BasicdataGoodsShelfServiceImpl extends BaseServiceImpl<BasicdataGoo
@Override
@Transactional ( rollbackFor = Exception . class )
public boolean insertGoodsshelf ( BasicdataGoodsShelfDTO basicdataGoodsShelfDTO ) {
log . info ( "传入>>>>>>>>>>>>>>>>>>{}" , basicdataGoodsShelfDTO ) ;
//维护仓库、货区数据
boolean result = false ;
//这里新增货架必须有仓库和货区的信息否则视为信息不合法
if ( Func . isEmpty ( basicdataGoodsShelfDTO ) ) {
if ( Func . isEmpty ( basicdataGoodsShelfDTO ) ) {
return result ;
}
if ( Objects . isNull ( basicdataGoodsShelfDTO . getWarehouseId ( ) ) & Objects . isNull ( basicdataGoodsShelfDTO . getGoodsAreaId ( ) ) ) {
log . error ( "仓库货区信息不合法" ) ;
throw new RuntimeException ( "请完善货区信息!!!" ) ;
}
BasicdataGoodsShelfEntity basicdataGoodsShelfEntity = new BasicdataGoodsShelfEntity ( ) ;
BeanUtils . copyProperties ( basicdataGoodsShelfDTO , basicdataGoodsShelfEntity ) ;
BasicdataGoodsShelfEntity basicdataGoodsShelfEntity = new BasicdataGoodsShelfEntity ( ) ;
BeanUtils . copyProperties ( basicdataGoodsShelfDTO , basicdataGoodsShelfEntity ) ;
BladeUser user = AuthUtil . getUser ( ) ;
Long userId = user . getUserId ( ) ;
basicdataGoodsShelfEntity . setCreateTime ( new Date ( ) ) ;
basicdataGoodsShelfEntity . setCreateDept ( Long . valueOf ( user . getDeptId ( ) ) ) ;
basicdataGoodsShelfEntity . setCreateUser ( userId ) ;
//数据状态默认正常
basicdataGoodsShelfEntity . setStatus ( 1 ) ;
//货架添加删除状态为正常
basicdataGoodsShelfEntity . setIsDeleted ( 0 ) ;
//货架添加初始未满
basicdataGoodsShelfEntity . setGoodsShelfStatus ( 1 ) ;
//货架添加默认启用
basicdataGoodsShelfEntity . setEnableStatus ( 1 ) ;
// BladeUser user = AuthUtil.getUser();
// Long userId = user.getUserId();
// basicdataGoodsShelfEntity.setCreateTime(new Date());
// basicdataGoodsShelfEntity.setCreateDept( Long.valueOf(user.getDeptId()));
// basicdataGoodsShelfEntity.setCreateUser(userId);
// //数据状态默认正常
// basicdataGoodsShelfEntity.setStatus(1);
// //货架添加删除状态为正常
// basicdataGoodsShelfEntity.setIsDeleted(0);
// //货架添加初始未满
// basicdataGoodsShelfEntity.setGoodsShelfStatus(1);
// //货架添加默认启用
// basicdataGoodsShelfEntity.setEnableStatus(1);
//获取租户编码规则
String code = basicTenantCodeClient . shelfCode ( user . getTenantId ( ) , "8" ) ;
//远程feign调用获取租户的货架码编码规则
String shelfCode = code + "--" + basicdataGoodsShelfEntity . getGoodsShelfName ( ) ;
basicdataGoodsShelfEntity . setQrCode ( shelfCode ) ;
result = this . save ( basicdataGoodsShelfEntity ) ;
//这里需要根据货架的列数和层数进行货位信息的生成
Integer rowNum = basicdataGoodsShelfEntity . getRowNum ( ) ;
Integer storeyNum = basicdataGoodsShelfEntity . getStoreyNum ( ) ;
//查询租户对应的库位码前缀规则
String allocationCode = basicTenantCodeClient . shelfCode ( user . getTenantId ( ) , "5" ) ;
for ( Integer i = 0 ; i < rowNum ; i + + ) {
for ( Integer j = 0 ; j < storeyNum ; j + + ) {
BasicdataGoodsAllocationEntity basicdataGoodsAllocationEntity = new BasicdataGoodsAllocationEntity ( ) ;
//设置所在列
basicdataGoodsAllocationEntity . setColumnNum ( i + 1 ) ;
//设置所在层
basicdataGoodsAllocationEntity . setLayerNum ( j + 1 ) ;
int row = i + 1 ;
int layer = j + 1 ;
basicdataGoodsAllocationEntity . setQrCode ( allocationCode + "-" + row + "-" + layer ) ;
basicdataGoodsAllocationEntity . setWarehouseId ( basicdataGoodsShelfEntity . getWarehouseId ( ) ) ;
basicdataGoodsAllocationEntity . setGoodsAreaId ( basicdataGoodsShelfEntity . getGoodsAreaId ( ) ) ;
basicdataGoodsAllocationEntity . setGoodsShelfId ( basicdataGoodsShelfEntity . getId ( ) ) ;
basicdataGoodsAllocationEntity . setGoodsAllocationName ( row + "-" + "-" + layer + "-货位" ) ;
basicdataGoodsAllocationEntity . setAllocationStatuc ( "1" ) ;
basicdataGoodsAllocationEntity . setEnableStatus ( "1" ) ;
basicdataGoodsAllocationService . save ( basicdataGoodsAllocationEntity ) ;
}
}
//获取租户编码规则
// String code = basicTenantCodeClient.shelfCode(user.getTenantId(),"8");
//远程feign调用获取租户的货架码编码规则
//查询货区
//查询当前登录人仓库
BladeUser user = AuthUtil . getUser ( ) ;
log . info ( "当前登陆人>>>>>>>>>>>>{}" , user ) ;
String shelfCode = basicdataGoodsShelfDTO . getGoodsAreaName ( ) ;
basicdataGoodsShelfEntity . setQrCode ( shelfCode ) ;
basicdataGoodsShelfEntity . setGoodsShelfName ( shelfCode ) ;
result = this . save ( basicdataGoodsShelfEntity ) ;
//这里需要根据货架的列数和层数进行货位信息的生成
Integer rowNum = basicdataGoodsShelfEntity . getRowNum ( ) ;
Integer storeyNum = basicdataGoodsShelfEntity . getStoreyNum ( ) ;
//查询租户对应的库位码前缀规则
//String allocationCode = basicTenantCodeClient.shelfCode(user.getTenantId(),"5");
// for (Integer i = 0; i < rowNum; i++) {
// for (Integer j = 0; j < storeyNum; j++) {
// BasicdataGoodsAllocationEntity basicdataGoodsAllocationEntity = new BasicdataGoodsAllocationEntity();
// //设置所在列
// basicdataGoodsAllocationEntity.setColumnNum(i + 1);
// //设置所在层
// basicdataGoodsAllocationEntity.setLayerNum(j + 1);
// int row = i + 1;
// int layer = j + 1;
// basicdataGoodsAllocationEntity.setQrCode(allocationCode + "-" + row + "-" + layer);
// basicdataGoodsAllocationEntity.setWarehouseId(basicdataGoodsShelfEntity.getWarehouseId());
// basicdataGoodsAllocationEntity.setGoodsAreaId(basicdataGoodsShelfEntity.getGoodsAreaId());
// basicdataGoodsAllocationEntity.setGoodsShelfId(basicdataGoodsShelfEntity.getId());
// basicdataGoodsAllocationEntity.setGoodsAllocationName(row + "-" + "-" + layer + "-货位");
// basicdataGoodsAllocationEntity.setAllocationStatuc("1");
// basicdataGoodsAllocationEntity.setEnableStatus("1");
// basicdataGoodsAllocationService.save(basicdataGoodsAllocationEntity);
// }
// }
return result ;
}
@ -169,31 +176,32 @@ public class BasicdataGoodsShelfServiceImpl extends BaseServiceImpl<BasicdataGoo
@Transactional
public boolean updateGoodsShelfInfo ( BasicdataGoodsShelfDTO basicdataGoodsShelfDTO ) {
boolean result = false ;
if ( Func . isEmpty ( basicdataGoodsShelfDTO ) ) {
log . error ( "参数异常:[" + basicdataGoodsShelfDTO + "]" ) ;
if ( Func . isEmpty ( basicdataGoodsShelfDTO ) ) {
log . error ( "参数异常:[" + basicdataGoodsShelfDTO + "]" ) ;
return result ;
}
BasicdataGoodsShelfEntity goodsShelfEntity = this . getById ( basicdataGoodsShelfDTO . getId ( ) ) ;
BeanUtils . copyProperties ( basicdataGoodsShelfDTO , goodsShelfEntity ) ;
result = SqlHelper . retBool ( basicdataGoodsShelfMapper . updateById ( goodsShelfEntity ) ) ;
BeanUtils . copyProperties ( basicdataGoodsShelfDTO , goodsShelfEntity ) ;
result = SqlHelper . retBool ( basicdataGoodsShelfMapper . updateById ( goodsShelfEntity ) ) ;
return result ;
}
@Override
public BasicdataGoodsShelfVO getGoodsShelfDetail ( BasicdataGoodsShelfDTO basicdataGoodsShelfDTO ) {
BasicdataGoodsShelfVO basicdataGoodsShelf = basicdataGoodsShelfMapper . getGoodsShelfDetail ( basicdataGoodsShelfDTO ) ;
BasicdataGoodsShelfVO basicdataGoodsShelf = basicdataGoodsShelfMapper . getGoodsShelfDetail ( basicdataGoodsShelfDTO ) ;
return basicdataGoodsShelf ;
}
@Override
public boolean removeGoodsShelf ( List < String > ids ) {
if ( Func . isEmpty ( ids ) ) {
log . error ( "参数错误:{}" + ids ) ;
if ( Func . isEmpty ( ids ) ) {
log . error ( "参数错误:{}" + ids ) ;
return false ;
}
boolean result = false ;
for ( String id : ids ) {
result = SqlHelper . retBool ( basicdataGoodsShelfMapper . removeGoodsShelf ( id ) ) ;
if ( ! result ) {
if ( ! result ) {
TransactionAspectSupport . currentTransactionStatus ( ) . setRollbackOnly ( ) ;
return false ;
}
@ -202,7 +210,6 @@ public class BasicdataGoodsShelfServiceImpl extends BaseServiceImpl<BasicdataGoo
}
@Override
public R < ? > getQrRCodeImg ( String qrCode , HttpServletResponse response ) {
String filename = null ;
@ -210,8 +217,8 @@ public class BasicdataGoodsShelfServiceImpl extends BaseServiceImpl<BasicdataGoo
filename = QRCodeUtil . createCodeToFile ( qrCode ) ;
} catch ( Exception e ) {
e . printStackTrace ( ) ;
log . error ( "二维码图片生成失败+{" + e . getMessage ( ) + "}" ) ;
} finally {
log . error ( "二维码图片生成失败+{" + e . getMessage ( ) + "}" ) ;
} finally {
File file = new File ( filename ) ;
file . delete ( ) ;
}
@ -224,19 +231,19 @@ public class BasicdataGoodsShelfServiceImpl extends BaseServiceImpl<BasicdataGoo
String templateByUrl = null ;
StringBuffer buffer = new StringBuffer ( ) ;
//待删除文件列表
List < String > list = new ArrayList < > ( ) ;
List < String > list = new ArrayList < > ( ) ;
for ( String id : ids ) {
BasicdataGoodsShelfEntity basicdataGoodsShelfEntity = basicdataGoodsShelfMapper . selectById ( id ) ;
String templateId = basicdataGoodsShelfEntity . getTemplateId ( ) ;
BasicPrintTemplateEntity template = basicPrintTemplateClient . getTemplate ( templateId ) ;
if ( Func . isEmpty ( basicdataGoodsShelfEntity ) ) {
return R . fail ( "货架信息异常+{" + basicdataGoodsShelfEntity + "}" ) ;
if ( Func . isEmpty ( basicdataGoodsShelfEntity ) ) {
return R . fail ( "货架信息异常+{" + basicdataGoodsShelfEntity + "}" ) ;
}
Map < String , Object > map = JSONObject . parseObject ( JSONObject . toJSONString ( basicdataGoodsShelfEntity ) , Map . class ) ;
Map < String , Object > map = JSONObject . parseObject ( JSONObject . toJSONString ( basicdataGoodsShelfEntity ) , Map . class ) ;
String qrCode = ( String ) map . get ( "qrCode" ) ;
String filename = QRCodeUtil . createCodeToFile ( qrCode ) ;
list . add ( filename ) ;
map . put ( "img" , filename ) ;
map . put ( "img" , filename ) ;
try {
templateByUrl = TemplateUtil . getTemplateByUrl ( template . getFileName ( ) , map , template . getTemplateUrl ( ) ) ;
} catch ( Exception e ) {
@ -246,32 +253,32 @@ public class BasicdataGoodsShelfServiceImpl extends BaseServiceImpl<BasicdataGoo
buffer . append ( templateByUrl ) ;
}
ScheduledThreadPoolExecutor scheduledThreadPoolExecutor = new ScheduledThreadPoolExecutor ( 5 ) ;
scheduledThreadPoolExecutor . schedule ( new FileUtil ( list ) , 30 , TimeUnit . SECONDS ) ;
scheduledThreadPoolExecutor . schedule ( new FileUtil ( list ) , 30 , TimeUnit . SECONDS ) ;
return R . data ( buffer . toString ( ) ) ;
}
@Override
public R < ? > getShowTemplate ( Map < String , Object > params , HttpServletResponse response ) {
public R < ? > getShowTemplate ( Map < String , Object > params , HttpServletResponse response ) {
String tenantId = AuthUtil . getTenantId ( ) ;
String templateId = ( String ) params . get ( "templateId" ) ;
BasicPrintTemplateEntity template = basicPrintTemplateClient . getTemplate ( templateId ) ;
String qrCode = ( String ) params . get ( "qrCode" ) ;
if ( Func . isBlank ( qrCode ) ) {
log . error ( "参数异常:+{" + qrCode + "}" ) ;
if ( Func . isBlank ( qrCode ) ) {
log . error ( "参数异常:+{" + qrCode + "}" ) ;
return R . fail ( "服务器正忙!!!" ) ;
}
String filename = QRCodeUtil . createCodeToFile ( qrCode ) ;
params . put ( "img" , "/" + filename ) ;
ServletOutputStream os = null ;
params . put ( "img" , "/" + filename ) ;
ServletOutputStream os = null ;
try {
BufferedImage image = TemplateUtil . turnImage ( template . getTemplateName ( ) , params , template . getTemplateUrl ( ) , template . getTemplateWidth ( ) , template . getTemplateHeight ( ) ) ;
BufferedImage image = TemplateUtil . turnImage ( template . getTemplateName ( ) , params , template . getTemplateUrl ( ) , template . getTemplateWidth ( ) , template . getTemplateHeight ( ) ) ;
os = response . getOutputStream ( ) ;
ImageIO . write ( image , "png" , os ) ;
ImageIO . write ( image , "png" , os ) ;
os . flush ( ) ;
} catch ( IOException e ) {
e . printStackTrace ( ) ;
log . error ( "获取响应流失败+{" + e . getMessage ( ) + "}" ) ;
} finally {
log . error ( "获取响应流失败+{" + e . getMessage ( ) + "}" ) ;
} finally {
File file = new File ( filename ) ;
file . delete ( ) ;
try {