|  |  |  | 
|---|
|  |  |  | 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); | 
|---|
|  |  |  | 
|---|
|  |  |  | 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()))); | 
|---|
|  |  |  | 
|---|
|  |  |  | 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); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|