From 6e709b3daad18b6f146d042812a98d924640e956 Mon Sep 17 00:00:00 2001
From: rentaiming <806181062@qq.com>
Date: 星期一, 01 七月 2024 18:15:10 +0800
Subject: [PATCH] 森林防火 供应商管理

---
 ruoyi-modules/ruoyi-management/src/main/java/com/ruoyi/management/service/impl/SlGoodsMaterialsServiceImpl.java |   90 +++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 90 insertions(+), 0 deletions(-)

diff --git a/ruoyi-modules/ruoyi-management/src/main/java/com/ruoyi/management/service/impl/SlGoodsMaterialsServiceImpl.java b/ruoyi-modules/ruoyi-management/src/main/java/com/ruoyi/management/service/impl/SlGoodsMaterialsServiceImpl.java
index 0b69191..144b8b6 100644
--- a/ruoyi-modules/ruoyi-management/src/main/java/com/ruoyi/management/service/impl/SlGoodsMaterialsServiceImpl.java
+++ b/ruoyi-modules/ruoyi-management/src/main/java/com/ruoyi/management/service/impl/SlGoodsMaterialsServiceImpl.java
@@ -1,10 +1,29 @@
 package com.ruoyi.management.service.impl;
 
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.core.toolkit.Wrappers;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.ruoyi.common.core.utils.page.PageDTO;
 import com.ruoyi.management.domain.SlGoodsMaterials;
+import com.ruoyi.management.domain.SlStoreManagement;
+import com.ruoyi.management.domain.SlVolumeProductionRk;
+import com.ruoyi.management.domain.dto.SlGoodsMaterialsDTO;
+import com.ruoyi.management.domain.dto.SlGoodsMaterialsQuery;
+import com.ruoyi.management.domain.dto.StoreManagementGoodSmaterialsQuery;
+import com.ruoyi.management.domain.vo.SlGoodsMaterialsVO;
+import com.ruoyi.management.domain.vo.SlGoodsShelfVO;
+import com.ruoyi.management.domain.vo.StoreManagementGoodSmaterialsVO;
 import com.ruoyi.management.mapper.SlGoodsMaterialsMapper;
+import com.ruoyi.management.mapper.SlVolumeProductionRkMapper;
 import com.ruoyi.management.service.SlGoodsMaterialsService;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.ruoyi.management.service.SlVolumeProductionRkService;
 import org.springframework.stereotype.Service;
+
+import javax.annotation.Resource;
+import java.util.List;
+import java.util.Set;
+import java.util.stream.Collectors;
 
 /**
  * <p>
@@ -17,4 +36,75 @@
 @Service
 public class SlGoodsMaterialsServiceImpl extends ServiceImpl<SlGoodsMaterialsMapper, SlGoodsMaterials> implements SlGoodsMaterialsService {
 
+    @Resource
+    private SlVolumeProductionRkMapper  slVolumeProductionRkMapper;
+
+
+    @Override
+    public void addSlGoodsShelf(SlGoodsMaterialsDTO slGoodsMaterialsDTO) {
+        if(slGoodsMaterialsDTO.getId()==null){
+            SlGoodsMaterials slGoodsMaterials=new  SlGoodsMaterials();
+            slGoodsMaterials.setGoodsMaterialsName(slGoodsMaterialsDTO.getGoodsMaterialsName());
+            slGoodsMaterials.setIsConsume(slGoodsMaterialsDTO.getIsConsume());
+            slGoodsMaterials.setRepertory(slGoodsMaterialsDTO.getRepertory());
+        }else{
+            SlGoodsMaterials byId = this.getById(slGoodsMaterialsDTO.getId());
+            if (slGoodsMaterialsDTO.getGoodsMaterialsName()!=null){
+                byId.setGoodsMaterialsName(slGoodsMaterialsDTO.getGoodsMaterialsName());
+            }
+            if (slGoodsMaterialsDTO.getRepertory()!=null){
+                byId.setRepertory(slGoodsMaterialsDTO.getRepertory());
+            }
+            if (slGoodsMaterialsDTO.getIsConsume()!=null){
+                byId.setIsConsume(slGoodsMaterialsDTO.getIsConsume());
+            }
+            this.updateById(byId);
+        }
+    }
+
+    @Override
+    public PageDTO<SlGoodsMaterialsVO> getGoodSmaterialsList(SlGoodsMaterialsQuery slGoodsMaterialsQuery) {
+        Page<SlGoodsMaterials> page = new Page<>(slGoodsMaterialsQuery.getPageCurr(), slGoodsMaterialsQuery.getPageSize());
+        LambdaQueryWrapper< SlGoodsMaterials> wrapper= Wrappers.lambdaQuery();
+        wrapper.eq(SlGoodsMaterials::getGoodsMaterialsName,slGoodsMaterialsQuery.getGoodsMaterialsName());
+        if (slGoodsMaterialsQuery.getIsConsume()!=0){
+            wrapper.eq(SlGoodsMaterials::getIsConsume,slGoodsMaterialsQuery.getIsConsume());
+        }
+        wrapper.eq( SlGoodsMaterials::getDelFlag,0);
+        wrapper.orderByDesc(SlGoodsMaterials::getCreateTime);
+        Page<SlGoodsMaterials> page1 = this.page(page, wrapper);
+        return PageDTO.of(page1,SlGoodsMaterialsVO.class);
+    }
+
+    @Override
+    public PageDTO<StoreManagementGoodSmaterialsVO> getStoreManagementGoodSmaterialsOne(StoreManagementGoodSmaterialsQuery storeManagementGoodSmaterialsQuery) {
+        LambdaQueryWrapper<SlVolumeProductionRk> wrappers= Wrappers.lambdaQuery();
+        wrappers.eq(SlVolumeProductionRk::getManagementId,storeManagementGoodSmaterialsQuery.getStoreManagementId());
+        List<SlVolumeProductionRk> slVolumeProductionRks = slVolumeProductionRkMapper.selectList(wrappers);
+        Set<Long> slVolumeProductionIdList = null;
+        slVolumeProductionIdList = slVolumeProductionRks.stream().map(SlVolumeProductionRk::getMaterialsId)
+                .collect(Collectors.toSet());
+
+        Page<SlGoodsMaterials> page = new Page<>(storeManagementGoodSmaterialsQuery.getPageCurr(), storeManagementGoodSmaterialsQuery.getPageSize());
+        LambdaQueryWrapper< SlGoodsMaterials> wrapper= Wrappers.lambdaQuery();
+        wrapper.eq(SlGoodsMaterials::getGoodsMaterialsName,storeManagementGoodSmaterialsQuery.getGoodsMaterialsName());
+        if (storeManagementGoodSmaterialsQuery.getIsConsume()!=0){
+            wrapper.eq(SlGoodsMaterials::getIsConsume,storeManagementGoodSmaterialsQuery.getIsConsume());
+        }
+        if (slVolumeProductionIdList.size()>0){
+            wrapper.in(SlGoodsMaterials::getId,slVolumeProductionIdList);
+        }
+        wrapper.eq( SlGoodsMaterials::getDelFlag,0);
+        wrapper.orderByDesc(SlGoodsMaterials::getCreateTime);
+        Page<SlGoodsMaterials> page1 = this.page(page, wrapper);
+        PageDTO<StoreManagementGoodSmaterialsVO> storeManagementGoodSmaterialsVOPageDTO = PageDTO.of(page1, StoreManagementGoodSmaterialsVO.class);
+        List<StoreManagementGoodSmaterialsVO> list = storeManagementGoodSmaterialsVOPageDTO.getList();
+        for (StoreManagementGoodSmaterialsVO li:list){
+            Double storeManagementGoodSmaterialsOne = slVolumeProductionRkMapper.getStoreManagementGoodSmaterialsOne(li.getId());
+            li.setAveragePrice(storeManagementGoodSmaterialsOne);
+        }
+
+
+        return storeManagementGoodSmaterialsVOPageDTO;
+    }
 }

--
Gitblit v1.7.1