|  |  |  | 
|---|
|  |  |  | import java.math.RoundingMode; | 
|---|
|  |  |  | import java.security.PrivateKey; | 
|---|
|  |  |  | import java.security.cert.X509Certificate; | 
|---|
|  |  |  | import java.time.LocalDateTime; | 
|---|
|  |  |  | import java.util.ArrayList; | 
|---|
|  |  |  | import java.util.Collections; | 
|---|
|  |  |  | import java.util.List; | 
|---|
|  |  |  | import java.util.Map; | 
|---|
|  |  |  | import java.util.stream.Collectors; | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Resource | 
|---|
|  |  |  | private TErpSupplierOutboundGoodsMapper erpSupplierOutboundGoodsMapper; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Resource | 
|---|
|  |  |  | private TCrmWarehouseMapper crmWarehouseMapper; | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 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()) { | 
|---|
|  |  |  | 
|---|
|  |  |  | sTime = split[0] + " 00:00:00"; | 
|---|
|  |  |  | eTime = split[1] + " 23:59:59"; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | PageInfo<TErpProcurementVo> pageInfo = new PageInfo<>(query.getPageNum(), query.getPageSize()); | 
|---|
|  |  |  | if(supplierClinicId.isEmpty()){ | 
|---|
|  |  |  | return pageInfo; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<TErpProcurementVo> list = this.baseMapper.pageListWarehouse(query, pageInfo, user, sTime, eTime, supplierClinicId); | 
|---|
|  |  |  | //            if (list.isEmpty()) { | 
|---|
|  |  |  | //                return pageInfo; | 
|---|
|  |  |  | 
|---|
|  |  |  | 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); | 
|---|
|  |  |  | 
|---|
|  |  |  | public DetailProcurementVO detailProcurement(String clinicSupplierId, SysUser user, String id) { | 
|---|
|  |  |  | DetailProcurementVO detailProcurementVO = new DetailProcurementVO(); | 
|---|
|  |  |  | TErpProcurement tErpProcurement = this.getById(id); | 
|---|
|  |  |  | if (tErpProcurement.getWarehousingUserId()!=null && !tErpProcurement.getWarehousingUserId().isEmpty()) { | 
|---|
|  |  |  | SysUser sysUser = sysUserMapper.selectUserById(Long.valueOf(tErpProcurement.getWarehousingUserId())); | 
|---|
|  |  |  | detailProcurementVO.setWarehousingUserName(sysUser.getUserName()); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | detailProcurementVO.setWarehousingTime(tErpProcurement.getWarehousingTime()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | detailProcurementVO.setStatus(tErpProcurement.getStatus()); | 
|---|
|  |  |  | detailProcurementVO.setCreateTime(tErpProcurement.getCreateTime()); | 
|---|
|  |  |  | detailProcurementVO.setSendTime(tErpProcurement.getSendTime()); | 
|---|
|  |  |  | 
|---|
|  |  |  | 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); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public List<SupplierThirtyProcurementStatisticsVO> supplierThirtyProcurementStatistics(String supplierAndClinicId, String startTime, String endTime,Integer roleType) { | 
|---|
|  |  |  | return this.baseMapper.supplierThirtyProcurementStatistics(supplierAndClinicId, startTime, endTime, roleType); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public List<SupplierThirtyMoneyProcurementStatisticsVO> supplierThirtyMoneyProcurementStatistics(String supplierAndClinicId, String startTime, String endTime,Integer roleType) { | 
|---|
|  |  |  | 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 List<TErpProcurementGoods> branchAdminStatisticsThree(List<String> clinicIds) { | 
|---|
|  |  |  | return this.baseMapper.branchAdminStatisticsThree(clinicIds); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } | 
|---|