|  |  |  | 
|---|
|  |  |  | import com.ruoyi.system.dto.InventoryGoodsDto; | 
|---|
|  |  |  | import com.ruoyi.system.mapper.*; | 
|---|
|  |  |  | import com.ruoyi.system.model.*; | 
|---|
|  |  |  | import com.ruoyi.system.query.TClinicGoodsWarehouseQuery; | 
|---|
|  |  |  | import com.ruoyi.system.query.TErpGoodsInventoryQuery; | 
|---|
|  |  |  | import com.ruoyi.system.query.TErpGoodsQuery; | 
|---|
|  |  |  | import com.ruoyi.system.query.*; | 
|---|
|  |  |  | import com.ruoyi.system.service.TErpGoodsService; | 
|---|
|  |  |  | import com.ruoyi.system.service.TErpSupplierInventoryGoodsService; | 
|---|
|  |  |  | import com.ruoyi.system.vo.*; | 
|---|
|  |  |  | import org.springframework.stereotype.Service; | 
|---|
|  |  |  | import org.springframework.transaction.annotation.Propagation; | 
|---|
|  |  |  | import org.springframework.transaction.annotation.Transactional; | 
|---|
|  |  |  |  | 
|---|
|  |  |  | import javax.annotation.Resource; | 
|---|
|  |  |  | import java.math.BigDecimal; | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public PageInfo<TErpGoodsVO> pageAdminList(TErpGoodsAdminQuery query) { | 
|---|
|  |  |  | PageInfo<TErpGoodsVO> pageInfo = new PageInfo<>(query.getPageNum(), query.getPageSize()); | 
|---|
|  |  |  | List<TErpGoodsVO> list = this.baseMapper.pageAdminList(query, pageInfo); | 
|---|
|  |  |  | if (list.isEmpty()) { | 
|---|
|  |  |  | return pageInfo; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<String> typeIds = list.stream().map(TErpGoods::getTypeId).collect(Collectors.toList()); | 
|---|
|  |  |  | if (!typeIds.isEmpty()) { | 
|---|
|  |  |  | List<TErpGoodsType> typeList = erpGoodsTypeMapper.selectBatchIds(typeIds); | 
|---|
|  |  |  | for (TErpGoodsVO tErpGoodsVO : list) { | 
|---|
|  |  |  | typeList.stream().filter(t -> t.getId().equals(tErpGoodsVO.getTypeId())).findFirst().ifPresent(t -> tErpGoodsVO.setTypeName(t.getTypeName())); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | pageInfo.setRecords( list); | 
|---|
|  |  |  | return pageInfo; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public List<TErpGoods> pageAddList(Page<TErpGoods> tErpGoodsPage, String clinicSupplierId, PageAddListQuery query) { | 
|---|
|  |  |  | return this.baseMapper.pageAddList(tErpGoodsPage, clinicSupplierId, query); | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public List<TErpGoodsVO> listExport(TErpGoodsQuery query, SysUser user) { | 
|---|
|  |  |  | List<TErpGoodsVO> list = this.baseMapper.listExport(query, user); | 
|---|
|  |  |  | if (list.isEmpty()) { | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | public boolean isExit(String goodsIdCode, String quasiNumber,String id) { | 
|---|
|  |  |  | Long size = this.baseMapper.selectCount(new LambdaQueryWrapper<>(TErpGoods.class).ne(id!=null,TErpGoods::getId, id).eq(TErpGoods::getGoodsIdCode, goodsIdCode).or().eq(TErpGoods::getQuasiNumber, quasiNumber)); | 
|---|
|  |  |  | Long size = this.baseMapper.selectCount(new LambdaQueryWrapper<>(TErpGoods.class).eq(TErpGoods::getGoodsSource,1).ne(id!=null,TErpGoods::getId, id).and(q -> q.eq(TErpGoods::getGoodsIdCode, goodsIdCode).or().eq(TErpGoods::getQuasiNumber, quasiNumber))); | 
|---|
|  |  |  | if (size > 0) { | 
|---|
|  |  |  | return true; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  | wrapper.orderByDesc(BaseModel::getCreateTime); | 
|---|
|  |  |  | Page<TErpGoods> page = this.page(new Page<>(query.getPageNum(), query.getPageSize()), wrapper); | 
|---|
|  |  |  | List<TErpGoods> records = page.getRecords(); | 
|---|
|  |  |  | if(records.isEmpty()){ | 
|---|
|  |  |  | return page; | 
|---|
|  |  |  | } | 
|---|
|  |  |  | List<String> packingUnitId = records.stream().map(TErpGoods::getPackingUnitId).collect(Collectors.toList()); | 
|---|
|  |  |  | if(!packingUnitId.isEmpty()){ | 
|---|
|  |  |  | List<TErpGoodsUnit> tErpGoodsUnits = erpGoodsUnitMapper.selectBatchIds(packingUnitId); | 
|---|
|  |  |  | for (TErpGoods tErpGoods : records) { | 
|---|
|  |  |  | tErpGoodsUnits.stream().filter(t -> t.getId().equals(tErpGoods.getPackingUnitId())).findFirst().ifPresent(t -> tErpGoods.setPackingUnitName(t.getUnitName())); | 
|---|
|  |  |  | } | 
|---|
|  |  |  | } | 
|---|
|  |  |  | page.setRecords( records); | 
|---|
|  |  |  | return page; | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | outboundGoodsDetailVo.setCreateBy(tErpClinicOutbound.getCreateBy()); | 
|---|
|  |  |  | outboundGoodsDetailVo.setOutboundType(tErpClinicOutbound.getOutboundType()); | 
|---|
|  |  |  | outboundGoodsDetailVo.setOrderNumber(tErpClinicOutbound.getOrderNumber()); | 
|---|
|  |  |  | outboundGoodsDetailVo.setOutboundReason(tErpClinicOutbound.getOutboundReason()); | 
|---|
|  |  |  | if(tErpClinicOutbound.getOutboundType()==6){ | 
|---|
|  |  |  | TErpClinicInventory tErpClinicInventory = erpClinicInventoryMapper.selectById(tErpClinicOutbound.getInventoryId()); | 
|---|
|  |  |  | outboundGoodsDetailVo.setInventoryNumber(tErpClinicInventory.getInventoryNumber()); | 
|---|
|  |  |  | 
|---|
|  |  |  | outboundGoodsDetailNextVo.setWarehouseNo(tErpClinicWarehousing.getWarehouseNo()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | outboundGoodsDetailNextVo.setGoodsId(outboundGoods.getGoodsId()); | 
|---|
|  |  |  | TErpGoods goods = erpGoodsMapper.selectById(outboundGoods.getGoodsId()); | 
|---|
|  |  |  | TErpGoods goods = erpGoodsMapper.getGoodsById(outboundGoods.getGoodsId()); | 
|---|
|  |  |  | outboundGoodsDetailNextVo.setGoodsName(goods.getGoodsName()); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | outboundGoodsDetailNextVo.setTypeId(goods.getTypeId()); | 
|---|
|  |  |  | 
|---|
|  |  |  | } | 
|---|
|  |  |  |  | 
|---|
|  |  |  | @Override | 
|---|
|  |  |  | @Transactional(rollbackFor = Exception.class, propagation = Propagation.REQUIRED) | 
|---|
|  |  |  | public void inventoryGoods(InventoryDto dto, SysUser user) { | 
|---|
|  |  |  | Integer roleType = user.getRoleType(); | 
|---|
|  |  |  | String supplierClinicId = null; | 
|---|
|  |  |  | 
|---|
|  |  |  | tErpSupplierWarehousing.setGoodsId(tErpSupplierWarehousing1.getGoodsId()); | 
|---|
|  |  |  | tErpSupplierWarehousing.setGoodsName(erpGoods.getGoodsName()); | 
|---|
|  |  |  | tErpSupplierWarehousing.setGoodsCount(inventoryGoodsDto.getInventoryCount() - inventoryGoodsDto.getNum()); | 
|---|
|  |  |  | tErpSupplierWarehousing.setUnitAmount(erpGoods.getSalesAmount()); | 
|---|
|  |  |  | tErpSupplierWarehousing.setTotalPrice(erpGoods.getSalesAmount().multiply(new BigDecimal(tErpSupplierWarehousing.getGoodsCount()))); | 
|---|
|  |  |  | tErpSupplierWarehousing.setUnitAmount(tErpSupplierWarehousing1.getUnitAmount()); | 
|---|
|  |  |  | tErpSupplierWarehousing.setTotalPrice(tErpSupplierWarehousing1.getUnitAmount().multiply(new BigDecimal(tErpSupplierWarehousing.getGoodsCount()))); | 
|---|
|  |  |  | // 当前年月日时分秒 | 
|---|
|  |  |  | String time = DateUtils.dateTimeNow(); | 
|---|
|  |  |  | tErpSupplierWarehousing.setWarehouseNo("G" + time); | 
|---|
|  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | } else { | 
|---|
|  |  |  |  | 
|---|
|  |  |  | TErpSupplierWarehousingBatch tErpSupplierWarehousingBatch1 = erpSupplierWarehousingBatchMapper.selectById(inventoryGoodsDto.getId()); | 
|---|
|  |  |  | String warehousingId1 = tErpSupplierWarehousingBatch1.getWarehousingId(); | 
|---|
|  |  |  | TErpSupplierWarehousing tErpSupplierWarehousing2 = erpSupplierWarehousingMapper.selectById(warehousingId1); | 
|---|
|  |  |  |  | 
|---|
|  |  |  | TErpSupplierOutbound tErpSupplierOutbound = new TErpSupplierOutbound(); | 
|---|
|  |  |  | tErpSupplierOutbound.setWarehouseId(dto.getWarehouseId()); | 
|---|
|  |  |  | 
|---|
|  |  |  | tErpSupplierOutbound.setOutboundType(6); | 
|---|
|  |  |  | tErpSupplierOutbound.setOutboundNumber("G" + s); | 
|---|
|  |  |  | int count = inventoryGoodsDto.getNum() - inventoryGoodsDto.getInventoryCount(); | 
|---|
|  |  |  | tErpSupplierOutbound.setTotalMoney(erpGoods.getSalesAmount().multiply(new BigDecimal(count))); | 
|---|
|  |  |  | tErpSupplierOutbound.setTotalMoney(tErpSupplierWarehousing1.getUnitAmount().multiply(new BigDecimal(count))); | 
|---|
|  |  |  | tErpSupplierOutbound.setGoodsId(tErpSupplierWarehousing2.getGoodsId()); | 
|---|
|  |  |  | erpSupplierOutboundMapper.insert(tErpSupplierOutbound); | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|
|  |  |  | 
|---|
|  |  |  | tErpSupplierOutboundGoods.setWarehousingId(tErpSupplierWarehousing1.getId()); | 
|---|
|  |  |  | tErpSupplierOutboundGoods.setWarehousingBatchId(tErpSupplierWarehousingBatch.getId()); | 
|---|
|  |  |  | tErpSupplierOutboundGoods.setOutboundCount(count); | 
|---|
|  |  |  | tErpSupplierOutboundGoods.setTotalPrice(erpGoods.getSalesAmount().multiply(new BigDecimal(count))); | 
|---|
|  |  |  | tErpSupplierOutboundGoods.setTotalPrice(tErpSupplierWarehousing1.getUnitAmount().multiply(new BigDecimal(count))); | 
|---|
|  |  |  | erpSupplierOutboundGoodsMapper.insert(tErpSupplierOutboundGoods); | 
|---|
|  |  |  |  | 
|---|
|  |  |  |  | 
|---|