From fc8b51f40e71aa09bb49f407c1e9f68ac94ceb58 Mon Sep 17 00:00:00 2001
From: mitao <2763622819@qq.com>
Date: 星期一, 29 七月 2024 18:51:32 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 ruoyi-modules/ruoyi-goods/src/main/java/com/ruoyi/goods/service/impl/GoodsSeriesServiceImpl.java |   78 +++++++++++++++++++++++++++++++++++++-
 1 files changed, 75 insertions(+), 3 deletions(-)

diff --git a/ruoyi-modules/ruoyi-goods/src/main/java/com/ruoyi/goods/service/impl/GoodsSeriesServiceImpl.java b/ruoyi-modules/ruoyi-goods/src/main/java/com/ruoyi/goods/service/impl/GoodsSeriesServiceImpl.java
index a516914..f52f23d 100644
--- a/ruoyi-modules/ruoyi-goods/src/main/java/com/ruoyi/goods/service/impl/GoodsSeriesServiceImpl.java
+++ b/ruoyi-modules/ruoyi-goods/src/main/java/com/ruoyi/goods/service/impl/GoodsSeriesServiceImpl.java
@@ -1,9 +1,22 @@
 package com.ruoyi.goods.service.impl;
 
-import com.ruoyi.goods.domain.pojo.GoodsSeries;
-import com.ruoyi.goods.mapper.GoodsSeriesMapper;
-import com.ruoyi.goods.service.IGoodsSeriesService;
+import com.baomidou.mybatisplus.core.toolkit.Wrappers;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.ruoyi.common.core.exception.ServiceException;
+import com.ruoyi.common.core.utils.StringUtils;
+import com.ruoyi.common.core.utils.page.BeanUtils;
+import com.ruoyi.common.core.utils.page.PageDTO;
+import com.ruoyi.goods.controller.management.dto.GoodsSeriesDTO;
+import com.ruoyi.goods.controller.management.dto.GoodsSeriesQuery;
+import com.ruoyi.goods.controller.management.vo.GoodsSeriesVO;
+import com.ruoyi.goods.mapper.GoodsSeriesMapper;
+import com.ruoyi.goods.mapper.GoodsSkuMapper;
+import com.ruoyi.goods.service.IGoodsSeriesService;
+import com.ruoyi.system.api.domain.GoodsSeries;
+import com.ruoyi.system.api.domain.GoodsSku;
+import java.util.List;
+import lombok.RequiredArgsConstructor;
 import org.springframework.stereotype.Service;
 
 /**
@@ -15,6 +28,65 @@
  * @since 2024-05-16
  */
 @Service
+@RequiredArgsConstructor
 public class GoodsSeriesServiceImpl extends ServiceImpl<GoodsSeriesMapper, GoodsSeries> implements IGoodsSeriesService {
 
+    private final GoodsSkuMapper goodsSkuMapper;
+    /**
+     * 获取商品系列列表的视图对象。
+     *
+     * <p>此方法不接受任何参数,它会调用 {@code list()} 方法获取原始列表,
+     * 然后使用 {@code BeanUtils.copyList} 将这些实体转换为视图对象。</p>
+     *
+     * @return 返回一个 {@link List} 类型的商品系列视图对象列表。每个视图对象代表一个商品系列的简要信息。
+     */
+    @Override
+    public List<GoodsSeriesVO> getGoodsSeriesList() {
+        // 使用BeanUtils工具类将实体列表转换为视图对象列表
+        return BeanUtils.copyList(this.list(), GoodsSeriesVO.class);
+    }
+
+    /**
+     * 获取商品系列的分页信息
+     *
+     * @param query 包含分页参数和查询条件的查询对象
+     * @return 返回商品系列的分页数据传输对象(DTO),包含分页信息和商品系列列表
+     */
+    @Override
+    public PageDTO<GoodsSeriesVO> getGoodsSeriesPage(GoodsSeriesQuery query) {
+        Page<GoodsSeries> page = this.lambdaQuery()
+                .like(StringUtils.isNotEmpty(query.getSeriesName()), GoodsSeries::getSeriesName,
+                        query.getSeriesName())
+                .orderByDesc(GoodsSeries::getCreateTime)
+                .page(new Page<>(query.getPageCurr(), query.getPageSize()));
+        if (StringUtils.isEmpty(page.getRecords())) {
+            return PageDTO.empty(page.getTotal(), page.getPages());
+        }
+        return PageDTO.of(page, GoodsSeriesVO.class);
+    }
+
+    /**
+     * 保存或更新商品系列信息。
+     *
+     * @param dto 商品系列数据传输对象,包含商品系列的详细信息。 如果商品系列ID为空,则视为新记录,进行保存; 如果商品系列ID不为空,则视为更新记录,进行更新。
+     */
+    @Override
+    public void saveGoodsSeries(GoodsSeriesDTO dto) {
+        GoodsSeries goodsSeries = BeanUtils.copyBean(dto, GoodsSeries.class);
+        if (StringUtils.isNull(goodsSeries.getId())) {
+            this.save(goodsSeries);
+        } else {
+            this.updateById(goodsSeries);
+        }
+    }
+
+    @Override
+    public void delete(Long id) {
+        Long count = goodsSkuMapper.selectCount(
+                Wrappers.lambdaQuery(GoodsSku.class).eq(GoodsSku::getSeriesId, id));
+        if (count > 0) {
+            throw new ServiceException("该分类已有商品关联,不能删除");
+        }
+        this.removeById(id);
+    }
 }

--
Gitblit v1.7.1