|
@@ -1,14 +1,12 @@
|
|
package com.fjhx.purchase.service.invoice.impl;
|
|
package com.fjhx.purchase.service.invoice.impl;
|
|
|
|
|
|
import cn.hutool.core.bean.BeanUtil;
|
|
import cn.hutool.core.bean.BeanUtil;
|
|
-import com.baomidou.dynamic.datasource.annotation.DS;
|
|
|
|
import com.baomidou.dynamic.datasource.annotation.DSTransactional;
|
|
import com.baomidou.dynamic.datasource.annotation.DSTransactional;
|
|
import com.baomidou.mybatisplus.core.toolkit.CollectionUtils;
|
|
import com.baomidou.mybatisplus.core.toolkit.CollectionUtils;
|
|
import com.baomidou.mybatisplus.core.toolkit.ObjectUtils;
|
|
import com.baomidou.mybatisplus.core.toolkit.ObjectUtils;
|
|
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
|
|
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
|
|
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
|
import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
|
|
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
|
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
|
-import com.fjhx.common.constant.SourceConstant;
|
|
|
|
import com.fjhx.file.utils.ObsFileUtil;
|
|
import com.fjhx.file.utils.ObsFileUtil;
|
|
import com.fjhx.purchase.entity.invoice.dto.InvoiceSelectDto;
|
|
import com.fjhx.purchase.entity.invoice.dto.InvoiceSelectDto;
|
|
import com.fjhx.purchase.entity.invoice.po.Invoice;
|
|
import com.fjhx.purchase.entity.invoice.po.Invoice;
|
|
@@ -20,6 +18,7 @@ import com.fjhx.purchase.service.invoice.InvoiceDetailsService;
|
|
import com.fjhx.purchase.service.invoice.InvoiceService;
|
|
import com.fjhx.purchase.service.invoice.InvoiceService;
|
|
import com.fjhx.supply.entity.supplier.po.SupplierInfo;
|
|
import com.fjhx.supply.entity.supplier.po.SupplierInfo;
|
|
import com.fjhx.supply.service.supplier.SupplierInfoService;
|
|
import com.fjhx.supply.service.supplier.SupplierInfoService;
|
|
|
|
+import com.ruoyi.common.utils.SecurityUtils;
|
|
import com.ruoyi.common.utils.StringUtils;
|
|
import com.ruoyi.common.utils.StringUtils;
|
|
import com.ruoyi.common.utils.wrapper.IWrapper;
|
|
import com.ruoyi.common.utils.wrapper.IWrapper;
|
|
import com.ruoyi.common.utils.wrapper.SqlField;
|
|
import com.ruoyi.common.utils.wrapper.SqlField;
|
|
@@ -30,6 +29,7 @@ import org.springframework.stereotype.Service;
|
|
import java.math.BigDecimal;
|
|
import java.math.BigDecimal;
|
|
import java.util.List;
|
|
import java.util.List;
|
|
import java.util.Map;
|
|
import java.util.Map;
|
|
|
|
+import java.util.Objects;
|
|
import java.util.stream.Collectors;
|
|
import java.util.stream.Collectors;
|
|
|
|
|
|
|
|
|
|
@@ -59,23 +59,28 @@ public class InvoiceServiceImpl extends ServiceImpl<InvoiceMapper, Invoice> impl
|
|
@Override
|
|
@Override
|
|
public Page<InvoiceVo> getPage(InvoiceSelectDto dto) {
|
|
public Page<InvoiceVo> getPage(InvoiceSelectDto dto) {
|
|
IWrapper<Invoice> wrapper = getWrapper();
|
|
IWrapper<Invoice> wrapper = getWrapper();
|
|
- wrapper.orderByDesc("t1", Invoice::getCreateTime);
|
|
|
|
- if(ObjectUtils.isNotEmpty(dto.getInvoiceType())){
|
|
|
|
- wrapper.eq("t1", Invoice::getType,dto.getInvoiceType());
|
|
|
|
|
|
+ if (ObjectUtils.isNotEmpty(dto.getInvoiceType())) {
|
|
|
|
+ wrapper.eq("t1", Invoice::getType, dto.getInvoiceType());
|
|
}
|
|
}
|
|
- if(StringUtils.isNotEmpty(dto.getKeyword())){
|
|
|
|
|
|
+ if (StringUtils.isNotEmpty(dto.getKeyword())) {
|
|
wrapper.keyword(dto.getKeyword(), new SqlField("t1.purchaseCodes"));
|
|
wrapper.keyword(dto.getKeyword(), new SqlField("t1.purchaseCodes"));
|
|
}
|
|
}
|
|
|
|
+ //权限过滤:发票-子公司看自己的,总公司看全部
|
|
|
|
+ Long companyId = SecurityUtils.getCompanyId();
|
|
|
|
+ if (!Objects.equals(companyId, 100L)) {
|
|
|
|
+ wrapper.eq(Invoice::getCompanyId, companyId);
|
|
|
|
+ }
|
|
|
|
+ wrapper.orderByDesc("t1", Invoice::getCreateTime);
|
|
Page<InvoiceVo> page = this.baseMapper.getPage(dto.getPage(), wrapper);
|
|
Page<InvoiceVo> page = this.baseMapper.getPage(dto.getPage(), wrapper);
|
|
List<InvoiceVo> list = page.getRecords();
|
|
List<InvoiceVo> list = page.getRecords();
|
|
- if(CollectionUtils.isNotEmpty(list)){
|
|
|
|
|
|
+ if (CollectionUtils.isNotEmpty(list)) {
|
|
List<Long> supplyIds = list.stream().map(InvoiceVo::getSupplyId).collect(Collectors.toList());
|
|
List<Long> supplyIds = list.stream().map(InvoiceVo::getSupplyId).collect(Collectors.toList());
|
|
- List<SupplierInfo> supplierInfoList = supplierInfoService.list(Wrappers.<SupplierInfo>query().lambda().in(SupplierInfo::getId,supplyIds));
|
|
|
|
- Map<Long,List<SupplierInfo>> supplyMap = supplierInfoList.stream().distinct().collect(Collectors.groupingBy(SupplierInfo::getId));
|
|
|
|
- if(MapUtils.isNotEmpty(supplyMap)){
|
|
|
|
- for(InvoiceVo p:list){
|
|
|
|
- List<SupplierInfo> supplys = supplyMap.getOrDefault(p.getSupplyId(),null);
|
|
|
|
- p.setSupplyName(supplys==null?null:supplys.get(0).getName());
|
|
|
|
|
|
+ List<SupplierInfo> supplierInfoList = supplierInfoService.list(Wrappers.<SupplierInfo>query().lambda().in(SupplierInfo::getId, supplyIds));
|
|
|
|
+ Map<Long, List<SupplierInfo>> supplyMap = supplierInfoList.stream().distinct().collect(Collectors.groupingBy(SupplierInfo::getId));
|
|
|
|
+ if (MapUtils.isNotEmpty(supplyMap)) {
|
|
|
|
+ for (InvoiceVo p : list) {
|
|
|
|
+ List<SupplierInfo> supplys = supplyMap.getOrDefault(p.getSupplyId(), null);
|
|
|
|
+ p.setSupplyName(supplys == null ? null : supplys.get(0).getName());
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|