From b33e6f53dd537abaebad066de12474580fcc33b2 Mon Sep 17 00:00:00 2001 From: yaowanxin <3588231647@qq.com> Date: 星期四, 21 八月 2025 15:03:14 +0800 Subject: [PATCH] Merge branch 'pim_ywx' --- src/main/java/com/ruoyi/warehouse/service/impl/DocumentationBorrowManagementServiceImpl.java | 157 ++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 157 insertions(+), 0 deletions(-) diff --git a/src/main/java/com/ruoyi/warehouse/service/impl/DocumentationBorrowManagementServiceImpl.java b/src/main/java/com/ruoyi/warehouse/service/impl/DocumentationBorrowManagementServiceImpl.java new file mode 100644 index 0000000..38b8d5a --- /dev/null +++ b/src/main/java/com/ruoyi/warehouse/service/impl/DocumentationBorrowManagementServiceImpl.java @@ -0,0 +1,157 @@ +package com.ruoyi.warehouse.service.impl; + +import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; +import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; +import com.baomidou.mybatisplus.core.metadata.IPage; +import com.baomidou.mybatisplus.extension.plugins.pagination.Page; +import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; +import com.ruoyi.common.utils.poi.ExcelUtil; +import com.ruoyi.warehouse.dto.DocumentationBorrowManagementDto; +import com.ruoyi.warehouse.dto.ReturnExportDto; +import com.ruoyi.warehouse.mapper.DocumentationReturnManagementMapper; +import com.ruoyi.warehouse.pojo.Documentation; +import com.ruoyi.warehouse.pojo.DocumentationBorrowManagement; +import com.ruoyi.warehouse.pojo.DocumentationReturnManagement; +import com.ruoyi.warehouse.service.DocumentationBorrowManagementService; +import com.ruoyi.warehouse.mapper.DocumentationBorrowManagementMapper; +import com.ruoyi.warehouse.service.DocumentationService; +import org.springframework.beans.factory.annotation.Autowired; +import org.springframework.stereotype.Service; +import org.springframework.transaction.annotation.Transactional; + +import javax.servlet.http.HttpServletResponse; +import java.time.LocalDate; +import java.time.LocalDateTime; +import java.util.List; +import java.util.stream.Collectors; + +/** +* @author 86151 +* @description 閽堝琛ㄣ�恉ocumentation_borrow_management(鏂囨。鍊熼槄-褰掕繕琛�)銆戠殑鏁版嵁搴撴搷浣淪ervice瀹炵幇 +* @createDate 2025-08-14 15:55:45 +*/ +@Service +@Transactional(rollbackFor = Exception.class) +public class DocumentationBorrowManagementServiceImpl extends ServiceImpl<DocumentationBorrowManagementMapper, DocumentationBorrowManagement> + implements DocumentationBorrowManagementService{ + @Autowired + private DocumentationBorrowManagementMapper documentationBorrowManagementMapper; + @Autowired + private DocumentationReturnManagementMapper documentationReturnManagementMapper; + @Autowired + private DocumentationService documentationService; + @Override + public IPage<DocumentationBorrowManagement> listPage(Page page, DocumentationBorrowManagement documentationBorrowManagement) { + IPage<DocumentationBorrowManagement> listPage = documentationBorrowManagementMapper.listPage(page, documentationBorrowManagement); + return listPage; + } + + + @Override + public boolean add(DocumentationBorrowManagement documentationBorrowManagement) { + documentationBorrowManagement.setBorrowStatus("鍊熼槄"); + documentationBorrowManagementMapper.insert(documentationBorrowManagement); + Documentation documentation = documentationService.getById(documentationBorrowManagement.getDocumentationId()); + documentation.setDocStatus("鍊熷嚭"); + documentationService.updateById(documentation); + return true; + } + @Override + public boolean reventdbm(DocumentationReturnManagement documentationReturnManagement) { + // 鏇存柊鍊熼槄璁板綍鐘舵�佷负褰掕繕 + DocumentationBorrowManagement documentationBorrowManagement1 = documentationBorrowManagementMapper.selectById(documentationReturnManagement.getBorrowId()); + + DocumentationReturnManagement returnManagement = new DocumentationReturnManagement(); + returnManagement.setDocumentationId(documentationBorrowManagement1.getDocumentationId()); + returnManagement.setBorrower(documentationBorrowManagement1.getBorrower()); + returnManagement.setBorrowPurpose(documentationBorrowManagement1.getBorrowPurpose()); + returnManagement.setBorrowDate(documentationBorrowManagement1.getBorrowDate()); + returnManagement.setDueReturnDate(documentationBorrowManagement1.getDueReturnDate()); + returnManagement.setBorrowStatus("褰掕繕"); + returnManagement.setBorrowId(documentationReturnManagement.getBorrowId()); + returnManagement.setReturner(documentationReturnManagement.getReturner()); + returnManagement.setReturnDate(LocalDate.now()); + returnManagement.setRemark(documentationReturnManagement.getRemark()); + + documentationReturnManagementMapper.insert(returnManagement); + documentationBorrowManagement1.setBorrowStatus("褰掕繕"); + documentationBorrowManagement1.setReturner(documentationReturnManagement.getReturner()); + documentationBorrowManagement1.setReturnDate(LocalDate.now()); + documentationBorrowManagementMapper.updateById(documentationBorrowManagement1); + // 鏇存柊鏂囨。鐘舵�佷负姝e父 + Documentation documentation = documentationService.getById(documentationBorrowManagement1.getDocumentationId()); + documentation.setDocStatus("姝e父"); + documentationService.updateById(documentation); + return true; + } + + @Override + public boolean reventDeleteByIds(List<Long> ids) { + QueryWrapper<DocumentationReturnManagement> queryWrapper = new QueryWrapper<>(); + queryWrapper.in("id", ids); +// queryWrapper.eq("borrow_status", "褰掕繕"); + List<DocumentationReturnManagement> list = documentationReturnManagementMapper.selectList(queryWrapper); + + for (DocumentationReturnManagement documentationReturnManagement : list) { + + try { + documentationReturnManagementMapper.deleteById(documentationReturnManagement); + DocumentationBorrowManagement documentationBorrowManagement = documentationBorrowManagementMapper.selectById(documentationReturnManagement.getBorrowId()); + documentationBorrowManagement.setBorrowStatus("鍊熼槄"); + documentationBorrowManagement.setReturner(null); + documentationBorrowManagement.setReturnDate(null); + documentationBorrowManagementMapper.updateById(documentationBorrowManagement); + + Documentation documentation = documentationService.getById(documentationReturnManagement.getDocumentationId()); + documentation.setDocStatus("鍊熷嚭"); + documentationService.updateById(documentation); + } catch (Exception e) { + throw new RuntimeException("鍒犻櫎褰掕繕璁板綍鍜屾枃妗g姸鎬佹椂鍑洪敊", e); + } + } +// documentationReturnManagementMapper.deleteBatchIds(ids); + return true; + } + + @Override + public void export(HttpServletResponse response, DocumentationBorrowManagement documentationBorrowManagement) { + List<DocumentationBorrowManagementDto> documentationBorrowManagements = documentationBorrowManagementMapper.export(documentationBorrowManagement); + ExcelUtil<DocumentationBorrowManagementDto> util = new ExcelUtil<>(DocumentationBorrowManagementDto.class); + util.exportExcel(response, documentationBorrowManagements, "鏂囨。鍊熼槄-鍊熼槄璁板綍"); + } + + @Override + public void exportrevent(HttpServletResponse response, DocumentationReturnManagement documentationReturnManagement) { + List<ReturnExportDto> documentationReturnManagements = documentationReturnManagementMapper.exportrevent(documentationReturnManagement); + ExcelUtil<ReturnExportDto> util = new ExcelUtil<>(ReturnExportDto.class); + util.exportExcel(response, documentationReturnManagements, "鏂囨。鍊熼槄-褰掕繕璁板綍"); + } + + @Override + public List<DocumentationBorrowManagementDto> listAll() { + return documentationBorrowManagementMapper.list(new LambdaQueryWrapper<DocumentationBorrowManagementDto>().eq(DocumentationBorrowManagementDto::getBorrowStatus, "鍊熼槄")); + } + + @Override + public boolean deleteByIds(List<Long> ids) { + List<DocumentationBorrowManagement> list = documentationBorrowManagementMapper.selectList(new LambdaQueryWrapper<DocumentationBorrowManagement>().in(DocumentationBorrowManagement::getId, ids)); + for (DocumentationBorrowManagement documentationBorrowManagement : list) { + Documentation documentation = documentationService.getById(documentationBorrowManagement.getDocumentationId()); + documentation.setDocStatus("姝e父"); + boolean b = documentationService.updateById(documentation); + if (!b){ + throw new RuntimeException("鏇存柊鏂囨。鐘舵�佸け璐�"); + } + } + documentationBorrowManagementMapper.deleteBatchIds(ids); + return true; + } + + + + +} + + + + -- Gitblit v1.9.3