|
|
@ -0,0 +1,287 @@
|
|
|
|
|
|
|
|
package jnpf.purchasement.service.impl;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
import jnpf.purchasement.entity.*;
|
|
|
|
|
|
|
|
import jnpf.purchasement.mapper.PurchasementMapper;
|
|
|
|
|
|
|
|
import jnpf.purchasement.service.*;
|
|
|
|
|
|
|
|
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
|
|
|
|
|
|
|
import jnpf.util.RandomUtil;
|
|
|
|
|
|
|
|
import java.math.BigDecimal;
|
|
|
|
|
|
|
|
import cn.hutool.core.util.ObjectUtil;
|
|
|
|
|
|
|
|
import jnpf.permission.model.authorize.AuthorizeConditionModel;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
import jnpf.purchasement.model.purchasement.PurchasementPagination;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
import jnpf.permission.service.AuthorizeService;
|
|
|
|
|
|
|
|
import java.lang.reflect.Field;
|
|
|
|
|
|
|
|
import com.baomidou.mybatisplus.annotation.TableField;
|
|
|
|
|
|
|
|
import java.util.stream.Collectors;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
import org.springframework.stereotype.Service;
|
|
|
|
|
|
|
|
import com.baomidou.mybatisplus.core.metadata.IPage;
|
|
|
|
|
|
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
|
|
|
|
|
|
import org.springframework.transaction.annotation.Transactional;
|
|
|
|
|
|
|
|
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
|
|
|
|
|
|
|
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
|
|
|
|
|
|
|
|
import java.text.SimpleDateFormat;
|
|
|
|
|
|
|
|
import jnpf.util.*;
|
|
|
|
|
|
|
|
import java.util.*;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
|
|
|
*
|
|
|
|
|
|
|
|
* purchasement
|
|
|
|
|
|
|
|
* 版本: V3.2.0
|
|
|
|
|
|
|
|
* 版权: LINKAGE-BOOT
|
|
|
|
|
|
|
|
* 作者: LINKAGE-BOOT研发团队
|
|
|
|
|
|
|
|
* 日期: 2023-02-20
|
|
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
@Service
|
|
|
|
|
|
|
|
public class PurchasementServiceImpl extends ServiceImpl<PurchasementMapper, PurchasementEntity> implements PurchasementService{
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@Autowired
|
|
|
|
|
|
|
|
private UserProvider userProvider;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@Autowired
|
|
|
|
|
|
|
|
private AuthorizeService authorizeService;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@Autowired
|
|
|
|
|
|
|
|
private Purchasement_item0Service purchasement_item0Service;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
|
|
|
public List<PurchasementEntity> getList(PurchasementPagination purchasementPagination){
|
|
|
|
|
|
|
|
String userId=userProvider.get().getUserId();
|
|
|
|
|
|
|
|
List<String> AllIdList =new ArrayList();
|
|
|
|
|
|
|
|
int total=0;
|
|
|
|
|
|
|
|
int purchasementNum =0;
|
|
|
|
|
|
|
|
QueryWrapper<PurchasementEntity> purchasementQueryWrapper=new QueryWrapper<>();
|
|
|
|
|
|
|
|
int purchasement_item0Num =0;
|
|
|
|
|
|
|
|
QueryWrapper<Purchasement_item0Entity> purchasement_item0QueryWrapper=new QueryWrapper<>();
|
|
|
|
|
|
|
|
boolean pcPermission = false;
|
|
|
|
|
|
|
|
boolean appPermission = false;
|
|
|
|
|
|
|
|
boolean isPc = ServletUtil.getHeader("jnpf-origin").equals("pc");
|
|
|
|
|
|
|
|
if(isPc && pcPermission){
|
|
|
|
|
|
|
|
if (!userProvider.get().getIsAdministrator()){
|
|
|
|
|
|
|
|
Object purchasementObj=authorizeService.getCondition(new AuthorizeConditionModel(purchasementQueryWrapper,purchasementPagination.getMenuId(),"purchasement"));
|
|
|
|
|
|
|
|
if (ObjectUtil.isEmpty(purchasementObj)){
|
|
|
|
|
|
|
|
return new ArrayList<>();
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
purchasementQueryWrapper = (QueryWrapper<PurchasementEntity>)purchasementObj;
|
|
|
|
|
|
|
|
purchasementNum++;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
Object purchasement_item0Obj=authorizeService.getCondition(new AuthorizeConditionModel(purchasement_item0QueryWrapper,purchasementPagination.getMenuId(),"purchasement_item0"));
|
|
|
|
|
|
|
|
if (ObjectUtil.isEmpty(purchasement_item0Obj)){
|
|
|
|
|
|
|
|
return new ArrayList<>();
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
purchasement_item0QueryWrapper = (QueryWrapper<Purchasement_item0Entity>)purchasement_item0Obj;
|
|
|
|
|
|
|
|
purchasement_item0Num++;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
if(!isPc && appPermission){
|
|
|
|
|
|
|
|
if (!userProvider.get().getIsAdministrator()){
|
|
|
|
|
|
|
|
Object purchasementObj=authorizeService.getCondition(new AuthorizeConditionModel(purchasementQueryWrapper,purchasementPagination.getMenuId(),"purchasement"));
|
|
|
|
|
|
|
|
if (ObjectUtil.isEmpty(purchasementObj)){
|
|
|
|
|
|
|
|
return new ArrayList<>();
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
purchasementQueryWrapper = (QueryWrapper<PurchasementEntity>)purchasementObj;
|
|
|
|
|
|
|
|
purchasementNum++;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Object purchasement_item0Obj=authorizeService.getCondition(new AuthorizeConditionModel(purchasement_item0QueryWrapper,purchasementPagination.getMenuId(),"purchasement_item0"));
|
|
|
|
|
|
|
|
if (ObjectUtil.isEmpty(purchasement_item0Obj)){
|
|
|
|
|
|
|
|
return new ArrayList<>();
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
purchasement_item0QueryWrapper = (QueryWrapper<Purchasement_item0Entity>)purchasement_item0Obj;
|
|
|
|
|
|
|
|
purchasement_item0Num++;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
if(StringUtil.isNotEmpty(purchasementPagination.getDocumentno())){
|
|
|
|
|
|
|
|
purchasementNum++;
|
|
|
|
|
|
|
|
purchasementQueryWrapper.lambda().like(PurchasementEntity::getDocumentno,purchasementPagination.getDocumentno());
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if(StringUtil.isNotEmpty(purchasementPagination.getSuppliername())){
|
|
|
|
|
|
|
|
purchasementNum++;
|
|
|
|
|
|
|
|
purchasementQueryWrapper.lambda().like(PurchasementEntity::getSuppliername,purchasementPagination.getSuppliername());
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if(StringUtil.isNotEmpty(purchasementPagination.getCreatorUserName())){
|
|
|
|
|
|
|
|
purchasementNum++;
|
|
|
|
|
|
|
|
purchasementQueryWrapper.lambda().like(PurchasementEntity::getCreatorUserName,purchasementPagination.getCreatorUserName());
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if(AllIdList.size()>0){
|
|
|
|
|
|
|
|
purchasementQueryWrapper.lambda().in(PurchasementEntity::getId, AllIdList);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
//排序
|
|
|
|
|
|
|
|
if(StringUtil.isEmpty(purchasementPagination.getSidx())){
|
|
|
|
|
|
|
|
purchasementQueryWrapper.lambda().orderByDesc(PurchasementEntity::getCreatorTime);
|
|
|
|
|
|
|
|
}else{
|
|
|
|
|
|
|
|
try {
|
|
|
|
|
|
|
|
String sidx = purchasementPagination.getSidx();
|
|
|
|
|
|
|
|
PurchasementEntity purchasementEntity = new PurchasementEntity();
|
|
|
|
|
|
|
|
Field declaredField = purchasementEntity.getClass().getDeclaredField(sidx);
|
|
|
|
|
|
|
|
declaredField.setAccessible(true);
|
|
|
|
|
|
|
|
String value = declaredField.getAnnotation(TableField.class).value();
|
|
|
|
|
|
|
|
purchasementQueryWrapper="asc".equals(purchasementPagination.getSort().toLowerCase())?purchasementQueryWrapper.orderByAsc(value):purchasementQueryWrapper.orderByDesc(value);
|
|
|
|
|
|
|
|
} catch (NoSuchFieldException e) {
|
|
|
|
|
|
|
|
e.printStackTrace();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
if((total>0 && AllIdList.size()>0) || total==0){
|
|
|
|
|
|
|
|
Page<PurchasementEntity> page=new Page<>(purchasementPagination.getCurrentPage(), purchasementPagination.getPageSize());
|
|
|
|
|
|
|
|
IPage<PurchasementEntity> userIPage=this.page(page, purchasementQueryWrapper);
|
|
|
|
|
|
|
|
return purchasementPagination.setData(userIPage.getRecords(),userIPage.getTotal());
|
|
|
|
|
|
|
|
}else{
|
|
|
|
|
|
|
|
List<PurchasementEntity> list = new ArrayList();
|
|
|
|
|
|
|
|
return purchasementPagination.setData(list, list.size());
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
|
|
|
public List<PurchasementEntity> getTypeList(PurchasementPagination purchasementPagination,String dataType){
|
|
|
|
|
|
|
|
String userId=userProvider.get().getUserId();
|
|
|
|
|
|
|
|
List<String> AllIdList =new ArrayList();
|
|
|
|
|
|
|
|
int total=0;
|
|
|
|
|
|
|
|
int purchasementNum =0;
|
|
|
|
|
|
|
|
QueryWrapper<PurchasementEntity> purchasementQueryWrapper=new QueryWrapper<>();
|
|
|
|
|
|
|
|
int purchasement_item0Num =0;
|
|
|
|
|
|
|
|
QueryWrapper<Purchasement_item0Entity> purchasement_item0QueryWrapper=new QueryWrapper<>();
|
|
|
|
|
|
|
|
boolean pcPermission = false;
|
|
|
|
|
|
|
|
boolean appPermission = false;
|
|
|
|
|
|
|
|
boolean isPc = ServletUtil.getHeader("jnpf-origin").equals("pc");
|
|
|
|
|
|
|
|
if(isPc && pcPermission){
|
|
|
|
|
|
|
|
if (!userProvider.get().getIsAdministrator()){
|
|
|
|
|
|
|
|
Object purchasementObj=authorizeService.getCondition(new AuthorizeConditionModel(purchasementQueryWrapper,purchasementPagination.getMenuId(),"purchasement"));
|
|
|
|
|
|
|
|
if (ObjectUtil.isEmpty(purchasementObj)){
|
|
|
|
|
|
|
|
return new ArrayList<>();
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
purchasementQueryWrapper = (QueryWrapper<PurchasementEntity>)purchasementObj;
|
|
|
|
|
|
|
|
purchasementNum++;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
Object purchasement_item0Obj=authorizeService.getCondition(new AuthorizeConditionModel(purchasement_item0QueryWrapper,purchasementPagination.getMenuId(),"purchasement_item0"));
|
|
|
|
|
|
|
|
if (ObjectUtil.isEmpty(purchasement_item0Obj)){
|
|
|
|
|
|
|
|
return new ArrayList<>();
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
purchasement_item0QueryWrapper = (QueryWrapper<Purchasement_item0Entity>)purchasement_item0Obj;
|
|
|
|
|
|
|
|
purchasement_item0Num++;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
if(!isPc && appPermission){
|
|
|
|
|
|
|
|
if (!userProvider.get().getIsAdministrator()){
|
|
|
|
|
|
|
|
Object purchasementObj=authorizeService.getCondition(new AuthorizeConditionModel(purchasementQueryWrapper,purchasementPagination.getMenuId(),"purchasement"));
|
|
|
|
|
|
|
|
if (ObjectUtil.isEmpty(purchasementObj)){
|
|
|
|
|
|
|
|
return new ArrayList<>();
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
purchasementQueryWrapper = (QueryWrapper<PurchasementEntity>)purchasementObj;
|
|
|
|
|
|
|
|
purchasementNum++;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
Object purchasement_item0Obj=authorizeService.getCondition(new AuthorizeConditionModel(purchasement_item0QueryWrapper,purchasementPagination.getMenuId(),"purchasement_item0"));
|
|
|
|
|
|
|
|
if (ObjectUtil.isEmpty(purchasement_item0Obj)){
|
|
|
|
|
|
|
|
return new ArrayList<>();
|
|
|
|
|
|
|
|
} else {
|
|
|
|
|
|
|
|
purchasement_item0QueryWrapper = (QueryWrapper<Purchasement_item0Entity>)purchasement_item0Obj;
|
|
|
|
|
|
|
|
purchasement_item0Num++;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
if(StringUtil.isNotEmpty(purchasementPagination.getDocumentno())){
|
|
|
|
|
|
|
|
purchasementNum++;
|
|
|
|
|
|
|
|
purchasementQueryWrapper.lambda().like(PurchasementEntity::getDocumentno,purchasementPagination.getDocumentno());
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if(StringUtil.isNotEmpty(purchasementPagination.getSuppliername())){
|
|
|
|
|
|
|
|
purchasementNum++;
|
|
|
|
|
|
|
|
purchasementQueryWrapper.lambda().like(PurchasementEntity::getSuppliername,purchasementPagination.getSuppliername());
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if(StringUtil.isNotEmpty(purchasementPagination.getCreatorUserName())){
|
|
|
|
|
|
|
|
purchasementNum++;
|
|
|
|
|
|
|
|
purchasementQueryWrapper.lambda().like(PurchasementEntity::getCreatorUserName,purchasementPagination.getCreatorUserName());
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if(AllIdList.size()>0){
|
|
|
|
|
|
|
|
purchasementQueryWrapper.lambda().in(PurchasementEntity::getId, AllIdList);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
//排序
|
|
|
|
|
|
|
|
if(StringUtil.isEmpty(purchasementPagination.getSidx())){
|
|
|
|
|
|
|
|
purchasementQueryWrapper.lambda().orderByDesc(PurchasementEntity::getCreatorTime);
|
|
|
|
|
|
|
|
}else{
|
|
|
|
|
|
|
|
try {
|
|
|
|
|
|
|
|
String sidx = purchasementPagination.getSidx();
|
|
|
|
|
|
|
|
PurchasementEntity purchasementEntity = new PurchasementEntity();
|
|
|
|
|
|
|
|
Field declaredField = purchasementEntity.getClass().getDeclaredField(sidx);
|
|
|
|
|
|
|
|
declaredField.setAccessible(true);
|
|
|
|
|
|
|
|
String value = declaredField.getAnnotation(TableField.class).value();
|
|
|
|
|
|
|
|
purchasementQueryWrapper="asc".equals(purchasementPagination.getSort().toLowerCase())?purchasementQueryWrapper.orderByAsc(value):purchasementQueryWrapper.orderByDesc(value);
|
|
|
|
|
|
|
|
} catch (NoSuchFieldException e) {
|
|
|
|
|
|
|
|
e.printStackTrace();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
if("0".equals(dataType)){
|
|
|
|
|
|
|
|
if((total>0 && AllIdList.size()>0) || total==0){
|
|
|
|
|
|
|
|
Page<PurchasementEntity> page=new Page<>(purchasementPagination.getCurrentPage(), purchasementPagination.getPageSize());
|
|
|
|
|
|
|
|
IPage<PurchasementEntity> userIPage=this.page(page, purchasementQueryWrapper);
|
|
|
|
|
|
|
|
return purchasementPagination.setData(userIPage.getRecords(),userIPage.getTotal());
|
|
|
|
|
|
|
|
}else{
|
|
|
|
|
|
|
|
List<PurchasementEntity> list = new ArrayList();
|
|
|
|
|
|
|
|
return purchasementPagination.setData(list, list.size());
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}else{
|
|
|
|
|
|
|
|
return this.list(purchasementQueryWrapper);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
|
|
|
public PurchasementEntity getInfo(String id){
|
|
|
|
|
|
|
|
QueryWrapper<PurchasementEntity> queryWrapper=new QueryWrapper<>();
|
|
|
|
|
|
|
|
queryWrapper.lambda().eq(PurchasementEntity::getId,id);
|
|
|
|
|
|
|
|
return this.getOne(queryWrapper);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
|
|
|
public void create(PurchasementEntity entity){
|
|
|
|
|
|
|
|
this.save(entity);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
|
|
|
public boolean update(String id, PurchasementEntity entity){
|
|
|
|
|
|
|
|
entity.setId(id);
|
|
|
|
|
|
|
|
return this.updateById(entity);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
|
|
|
public void delete(PurchasementEntity entity){
|
|
|
|
|
|
|
|
if(entity!=null){
|
|
|
|
|
|
|
|
this.removeById(entity.getId());
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
//子表方法
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
|
|
|
public List<Purchasement_item0Entity> GetPurchasement_item0List(String id){
|
|
|
|
|
|
|
|
QueryWrapper<Purchasement_item0Entity> queryWrapper = new QueryWrapper<>();
|
|
|
|
|
|
|
|
queryWrapper.lambda().eq(Purchasement_item0Entity::getPurchasementId, id);
|
|
|
|
|
|
|
|
return purchasement_item0Service.list(queryWrapper);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
//列表子表数据方法
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}
|