package org.jeecg.modules.dnc.service.impl; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.toolkit.Wrappers; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import org.jeecg.modules.dnc.entity.ProductDepartment; import org.jeecg.modules.dnc.mapper.ProductDepartmentMapper; import org.jeecg.modules.dnc.utils.ValidateUtil; import org.jeecg.modules.dnc.service.IProductDepartmentService; import org.jeecg.modules.system.entity.MdcProduction; import org.springframework.stereotype.Service; import org.springframework.transaction.annotation.Transactional; import java.util.ArrayList; import java.util.List; @Service public class ProductDepartmentServiceImpl extends ServiceImpl implements IProductDepartmentService { @Override @Transactional(rollbackFor = {Exception.class}) public boolean deleteByProductId(String productId) { if(!ValidateUtil.validateString(productId)) return false; LambdaQueryWrapper lambdaQueryWrapper = Wrappers.lambdaQuery(); lambdaQueryWrapper.eq(ProductDepartment::getProductId, productId); return super.remove(lambdaQueryWrapper); } @Override public List getDepartPermsByProductId(String productId) { return super.getBaseMapper().getDepartPermsByProductId(productId); } @Override public List getDepartNonPermsByProductId(String productId) { return super.getBaseMapper().getDepartNonPermsByProductId(productId); } @Override @Transactional(rollbackFor = {Exception.class}) public boolean removeByCollection(List productDepartmentList) { if(productDepartmentList == null || productDepartmentList.isEmpty()) return false; if(productDepartmentList.size() == 1) return super.removeById(productDepartmentList.get(0).getProductDepartId()); List ids = new ArrayList<>(); productDepartmentList.forEach(item -> { ids.add(item.getProductDepartId()); }); return super.removeByIds(ids); } @Override public ProductDepartment getByProductIdAndDepartId(String productId, String departId) { if(!ValidateUtil.validateString(productId) || !ValidateUtil.validateString(departId)) return null; List list = super.lambdaQuery().eq(ProductDepartment::getProductId, productId).eq(ProductDepartment::getDepartId, departId).list(); if(list == null || list.isEmpty()) return null; return list.get(0); } }