|  |  |  | 
|---|
|  |  |  | import com.ruoyi.system.dto.AddProcurementDto; | 
|---|
|  |  |  | import com.ruoyi.system.mapper.*; | 
|---|
|  |  |  | import com.ruoyi.system.model.*; | 
|---|
|  |  |  | import com.ruoyi.system.query.ClinicProcurementReportQuery; | 
|---|
|  |  |  | import com.ruoyi.system.query.TErpGoodsQuery; | 
|---|
|  |  |  | import com.ruoyi.system.query.TErpProcurementQuery; | 
|---|
|  |  |  | import com.ruoyi.system.service.TErpGoodsService; | 
|---|
|  |  |  | 
|---|
|  |  |  | import org.springframework.stereotype.Service; | 
|---|
|  |  |  | import org.springframework.transaction.annotation.Propagation; | 
|---|
|  |  |  | import org.springframework.transaction.annotation.Transactional; | 
|---|
|  |  |  | import org.springframework.util.CollectionUtils; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import javax.annotation.Resource; | 
|---|
|  |  |  | import javax.net.ssl.SSLContext; | 
|---|
|  |  |  | 
|---|
|  |  |  | import java.math.RoundingMode; | 
|---|
|  |  |  | import java.security.PrivateKey; | 
|---|
|  |  |  | import java.security.cert.X509Certificate; | 
|---|
|  |  |  | import java.time.LocalDateTime; | 
|---|
|  |  |  | import java.util.ArrayList; | 
|---|
|  |  |  | import java.util.List; | 
|---|
|  |  |  | import java.util.Map; | 
|---|
|  |  |  | 
|---|
|  |  |  | @Resource | 
|---|
|  |  |  | private TErpSupplierOutboundGoodsMapper erpSupplierOutboundGoodsMapper; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Resource | 
|---|
|  |  |  | private TCrmWarehouseMapper crmWarehouseMapper; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public PageInfo<TErpProcurementVo> pageList(TErpProcurementQuery query, SysUser user) { | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | Integer roleType = user.getRoleType(); | 
|---|
|  |  |  | String supplierClinicId = null; | 
|---|
|  |  |  | List<String> supplierClinicId = null; | 
|---|
|  |  |  | if (roleType == 6) { | 
|---|
|  |  |  | // 供应商 | 
|---|
|  |  |  | TCrmSupplier crmSupplier = crmSupplierMapper.selectOne(Wrappers.lambdaQuery(TCrmSupplier.class) | 
|---|
|  |  |  | .eq(TCrmSupplier::getUserId, user.getUserId()) | 
|---|
|  |  |  |  | 
|---|
|  |  |  | TCrmWarehouse warehouse = crmWarehouseMapper.selectOne(Wrappers.lambdaQuery(TCrmWarehouse.class) | 
|---|
|  |  |  | .eq(TCrmWarehouse::getUserId, user.getUserId()) | 
|---|
|  |  |  | .last("LIMIT 1")); | 
|---|
|  |  |  | supplierClinicId = crmSupplier.getId(); | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | // 供应商 | 
|---|
|  |  |  | supplierClinicId = crmSupplierMapper.selectList(Wrappers.lambdaQuery(TCrmSupplier.class) | 
|---|
|  |  |  | .eq(TCrmSupplier::getWarehouseId, warehouse.getId())).stream().map(TCrmSupplier::getId).collect(Collectors.toList()); | 
|---|
|  |  |  | String sTime = null; | 
|---|
|  |  |  | String eTime = null; | 
|---|
|  |  |  | if (query.getTime() != null && !query.getTime().isEmpty()) { | 
|---|
|  |  |  | 
|---|
|  |  |  | BigDecimal all = BigDecimal.ZERO; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | for (AddProcurementDto addProcurementDto : value) { | 
|---|
|  |  |  | BigDecimal multiply = addProcurementDto.getSalesAmount().multiply(BigDecimal.valueOf(addProcurementDto.getPurchaseCount())); | 
|---|
|  |  |  | BigDecimal multiply = addProcurementDto.getGoodsSalesAmount().multiply(BigDecimal.valueOf(addProcurementDto.getPurchaseCount())); | 
|---|
|  |  |  | all = all.add(multiply); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | tErpProcurement.setPayMoney(all); | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | BigDecimal add = BigDecimal.ZERO; | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | BigDecimal supplierCommissionPrice = BigDecimal.ZERO; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | for (AddProcurementDto dto : value) { | 
|---|
|  |  |  | TErpProcurementGoods tErpProcurementGoods = new TErpProcurementGoods(); | 
|---|
|  |  |  | tErpProcurementGoods.setProcurementId(tErpProcurement.getId()); | 
|---|
|  |  |  | 
|---|
|  |  |  | tErpProcurementGoods.setQuasiNumber(goods.getQuasiNumber()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | TErpGoodsUnit tErpGoodsUnit = erpGoodsUnitMapper.selectById(goods.getPackingUnitId()); | 
|---|
|  |  |  | tErpProcurementGoods.setUnitName(tErpGoodsUnit.getUnitName()); | 
|---|
|  |  |  | if(tErpGoodsUnit!=null){ | 
|---|
|  |  |  | tErpProcurementGoods.setUnitName(tErpGoodsUnit.getUnitName()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | tErpProcurementGoods.setPurchasePrice(dto.getGoodsSalesAmount()); | 
|---|
|  |  |  | tErpProcurementGoods.setSalesAmount(dto.getSalesAmount()); | 
|---|
|  |  |  | tErpProcurementGoods.setTotalPrice(dto.getGoodsSalesAmount().multiply(new BigDecimal(dto.getPurchaseCount()))); | 
|---|
|  |  |  | 
|---|
|  |  |  | tErpProcurementGoods.setSupplierId(supplierClinicId); | 
|---|
|  |  |  | tErpProcurementGoods.setRecvMerchantNo(supplier.getRecvMerchantNo()); | 
|---|
|  |  |  | tErpProcurementGoods.setSupplierMoney(dto.getSalesAmount().subtract(dto.getPlatformCommissionPrice())); | 
|---|
|  |  |  | supplierCommissionPrice = supplierCommissionPrice.add(tErpProcurementGoods.getSupplierMoney().multiply(BigDecimal.valueOf(dto.getPurchaseCount()))); | 
|---|
|  |  |  | if (tErpProcurementGoods.getSupplierMoney().doubleValue() < 0) { | 
|---|
|  |  |  | throw new RuntimeException("平台抽成不能大于售卖价格"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | if (tErpProcurement.getMoney().doubleValue() < 0) { | 
|---|
|  |  |  | throw new RuntimeException("金额设置错误,请联系平台管理员"); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | tErpProcurement.setSupplierMoney(supplierCommissionPrice); | 
|---|
|  |  |  | this.save(tErpProcurement); | 
|---|
|  |  |  | tErpProcurementGoods1.forEach(e -> e.setProcurementId(tErpProcurement.getId())); | 
|---|
|  |  |  | erpProcurementGoodsService.saveBatch(tErpProcurementGoods1); | 
|---|
|  |  |  | 
|---|
|  |  |  | detailProcurementNextVO.setTotalPrice(tErpProcurement.getPayMoney()); | 
|---|
|  |  |  | detailProcurementNextVO.setId(tErpProcurementGoods.getId()); | 
|---|
|  |  |  | detailProcurementNextVO.setPurchasePrice(tErpProcurementGoods.getPurchasePrice()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | List<TErpSupplierOutboundGoods> tErpSupplierOutboundGoods = erpSupplierOutboundGoodsMapper.selectList(new LambdaQueryWrapper<TErpSupplierOutboundGoods>().eq(TErpSupplierOutboundGoods::getProcurementGoodsId, tErpProcurementGoods.getId())); | 
|---|
|  |  |  | if(!tErpSupplierOutboundGoods.isEmpty()){ | 
|---|
|  |  |  | ArrayList<DetailProcurementNextThreeVO> detailProcurementNextThreeVOS = new ArrayList<>(); | 
|---|
|  |  |  | List<String> collect = tErpSupplierOutboundGoods.stream().map(TErpSupplierOutboundGoods::getWarehousingBatchId).collect(Collectors.toList()); | 
|---|
|  |  |  | List<TErpSupplierWarehousingBatch> tErpSupplierWarehousingBatches = erpSupplierWarehousingBatchMapper.selectBatchIds(collect); | 
|---|
|  |  |  | for (TErpSupplierOutboundGoods tErpSupplierOutboundGood : tErpSupplierOutboundGoods) { | 
|---|
|  |  |  | List<TErpSupplierWarehousingBatch> collect1 = tErpSupplierWarehousingBatches.stream().filter(e -> e.getId().equals(tErpSupplierOutboundGood.getWarehousingBatchId())).collect(Collectors.toList()); | 
|---|
|  |  |  | for (TErpSupplierWarehousingBatch tErpSupplierWarehousingBatch : collect1) { | 
|---|
|  |  |  | DetailProcurementNextThreeVO detailProcurementNextThreeVO = new DetailProcurementNextThreeVO(); | 
|---|
|  |  |  | detailProcurementNextThreeVO.setBatchNumber(tErpSupplierWarehousingBatch.getBatchNumber()); | 
|---|
|  |  |  | detailProcurementNextThreeVO.setProductionDate(tErpSupplierWarehousingBatch.getProductionDate()); | 
|---|
|  |  |  | detailProcurementNextThreeVO.setExpirationDate(tErpSupplierWarehousingBatch.getExpiryDate()); | 
|---|
|  |  |  | detailProcurementNextThreeVO.setNum(tErpSupplierOutboundGood.getOutboundCount()); | 
|---|
|  |  |  | detailProcurementNextThreeVOS.add(detailProcurementNextThreeVO); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | detailProcurementNextVO.setDetailProcurementNextThreeVOS(detailProcurementNextThreeVOS); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | detailProcurementNextVOS.add(detailProcurementNextVO); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | detailProcurementVO.setList(detailProcurementNextVOS); | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | @Transactional(rollbackFor = Exception.class, propagation = Propagation.REQUIRED) | 
|---|
|  |  |  | public void detailProcurementSend(String clinicSupplierId, SysUser user, String id) { | 
|---|
|  |  |  | public void detailProcurementSend(List<String> clinicSupplierId, SysUser user, String id,String logisticsNumber) { | 
|---|
|  |  |  | // 查出这个采购的下级商品 | 
|---|
|  |  |  | List<TErpProcurementGoods> list = erpProcurementGoodsService.list(new QueryWrapper<TErpProcurementGoods>().eq("procurement_id", id)); | 
|---|
|  |  |  | List<TErpSupplierWarehousing> tErpSupplierWarehousings = erpSupplierWarehousingMapper.selectList(new LambdaQueryWrapper<TErpSupplierWarehousing>() | 
|---|
|  |  |  | .eq(TErpSupplierWarehousing::getSupplierId, clinicSupplierId).in(TErpSupplierWarehousing::getGoodsId, list.stream().map(TErpProcurementGoods::getGoodsId).collect(Collectors.toList())) | 
|---|
|  |  |  | .in(TErpSupplierWarehousing::getSupplierId, clinicSupplierId).in(TErpSupplierWarehousing::getGoodsId, list.stream().map(TErpProcurementGoods::getGoodsId).collect(Collectors.toList())) | 
|---|
|  |  |  | .orderByAsc(BaseModel::getCreateTime)); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | if(tErpSupplierWarehousings.isEmpty()){ | 
|---|
|  |  |  | 
|---|
|  |  |  | if(count>=purchaseCount){ | 
|---|
|  |  |  | // 添加出库记录 | 
|---|
|  |  |  | TErpSupplierOutbound tErpSupplierOutbound= new TErpSupplierOutbound(); | 
|---|
|  |  |  | tErpSupplierOutbound.setSupplierId(clinicSupplierId); | 
|---|
|  |  |  | tErpSupplierOutbound.setSupplierId(tErpSupplierWarehousing.getSupplierId()); | 
|---|
|  |  |  | tErpSupplierOutbound.setWarehouseId(tErpSupplierWarehousing.getWarehouseId()); | 
|---|
|  |  |  | tErpSupplierOutbound.setOutboundType(7); | 
|---|
|  |  |  | //TODO 确定这个是采购价还是销售价格 | 
|---|
|  |  |  | 
|---|
|  |  |  | tErpSupplierOutboundGoods.setWarehousingBatchId(warehousingBatch.getId()); | 
|---|
|  |  |  | tErpSupplierOutboundGoods.setOutboundCount(purchaseCount); | 
|---|
|  |  |  | tErpSupplierOutboundGoods.setTotalPrice(tErpProcurementGoods.getPurchasePrice().multiply(new BigDecimal(purchaseCount))); | 
|---|
|  |  |  | tErpSupplierOutboundGoods.setProcurementGoodsId(tErpProcurementGoods.getId()); | 
|---|
|  |  |  | erpSupplierOutboundGoodsMapper.insert(tErpSupplierOutboundGoods); | 
|---|
|  |  |  | continue outer; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | purchaseCount = purchaseCount - count; | 
|---|
|  |  |  | // 添加出库记录 | 
|---|
|  |  |  | TErpSupplierOutbound tErpSupplierOutbound= new TErpSupplierOutbound(); | 
|---|
|  |  |  | tErpSupplierOutbound.setSupplierId(clinicSupplierId); | 
|---|
|  |  |  | tErpSupplierOutbound.setSupplierId(tErpSupplierWarehousing.getSupplierId()); | 
|---|
|  |  |  | tErpSupplierOutbound.setWarehouseId(tErpSupplierWarehousing.getWarehouseId()); | 
|---|
|  |  |  | tErpSupplierOutbound.setOutboundType(7); | 
|---|
|  |  |  | //TODO 确定这个是采购价还是销售价格 | 
|---|
|  |  |  | 
|---|
|  |  |  | tErpSupplierOutboundGoods.setWarehousingBatchId(warehousingBatch.getId()); | 
|---|
|  |  |  | tErpSupplierOutboundGoods.setOutboundCount(purchaseCount); | 
|---|
|  |  |  | tErpSupplierOutboundGoods.setTotalPrice(tErpProcurementGoods.getPurchasePrice().multiply(new BigDecimal(purchaseCount))); | 
|---|
|  |  |  | tErpSupplierOutboundGoods.setProcurementGoodsId(tErpProcurementGoods.getId()); | 
|---|
|  |  |  | erpSupplierOutboundGoodsMapper.insert(tErpSupplierOutboundGoods); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | TErpProcurement byId = this.getById(id); | 
|---|
|  |  |  | byId.setStatus(4); | 
|---|
|  |  |  | byId.setSendTime(LocalDateTime.now()); | 
|---|
|  |  |  | byId.setLogisticsNumber(logisticsNumber); | 
|---|
|  |  |  | this.updateById(byId); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | return this.baseMapper.supplierThirtyMoneyProcurementStatistics(supplierAndClinicId, startTime, endTime, roleType); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public Integer supplierSalesStatisticsTypeCount(String supplierId) { | 
|---|
|  |  |  | return this.baseMapper.supplierSalesStatisticsTypeCount(supplierId); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public Integer supplierSalesStatisticsCount(String supplierId) { | 
|---|
|  |  |  | return this.baseMapper.supplierSalesStatisticsCount(supplierId); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public BigDecimal supplierSalesStatisticsMoney(String supplierId, String startTime, String endTime) { | 
|---|
|  |  |  | return this.baseMapper.supplierSalesStatisticsMoney(supplierId,startTime, endTime); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public List<SupplierSalesStatisticsGoodsTypeVO> supplierSalesStatisticsGoodsType(String supplierId, String startTime, String endTime) { | 
|---|
|  |  |  | return this.baseMapper.supplierSalesStatisticsGoodsType(supplierId,startTime, endTime); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public List<SupplierSalesStatisticsGoodsCountVO> supplierSalesStatisticsGoodsCount(String supplierId, String startTime, String endTime, String goodsName) { | 
|---|
|  |  |  | return this.baseMapper.supplierSalesStatisticsGoodsCount(supplierId,startTime, endTime,goodsName); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public List<SupplierSalesStatisticsGoodsCountVO> supplierSalesStatisticsGoodsCountMonth(String supplierId, String startTime, String endTime, String goodsName) { | 
|---|
|  |  |  | return this.baseMapper.supplierSalesStatisticsGoodsCountMonth(supplierId,startTime, endTime,goodsName); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public PageInfo<ClinicProcurementReportVO> clinicProcurementReport(ClinicProcurementReportQuery query) { | 
|---|
|  |  |  | PageInfo<ClinicProcurementReportVO> pageInfo = new PageInfo<>(query.getPageNum(), query.getPageSize()); | 
|---|
|  |  |  | List<ClinicProcurementReportVO> list = this.baseMapper.clinicProcurementReport(query, pageInfo); | 
|---|
|  |  |  | if(CollectionUtils.isEmpty(list)){ | 
|---|
|  |  |  | return pageInfo; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<String> procurementIds = list.stream().map(TErpProcurement::getId).collect(Collectors.toList()); | 
|---|
|  |  |  | List<TErpProcurementGoods> erpProcurementGoods = erpProcurementGoodsMapper.selectList(new QueryWrapper<TErpProcurementGoods>().lambda().in(TErpProcurementGoods::getProcurementId, procurementIds)); | 
|---|
|  |  |  | for (ClinicProcurementReportVO clinicProcurementReportVO : list) { | 
|---|
|  |  |  | List<TErpProcurementGoods> procurementGoods = erpProcurementGoods.stream().filter(tErpProcurementGoods -> tErpProcurementGoods.getProcurementId().equals(clinicProcurementReportVO.getId())).collect(Collectors.toList()); | 
|---|
|  |  |  | if(!CollectionUtils.isEmpty(procurementGoods)){ | 
|---|
|  |  |  | int sum = procurementGoods.stream().mapToInt(TErpProcurementGoods::getPurchaseCount).sum(); | 
|---|
|  |  |  | clinicProcurementReportVO.setProcurementGoodsNum(sum); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | pageInfo.setRecords(list); | 
|---|
|  |  |  | return pageInfo; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|