From dcdb0231034810232f2542f3865666ebf72daf11 Mon Sep 17 00:00:00 2001
From: jiangping <jp@doumee.com>
Date: 星期三, 30 四月 2025 16:45:34 +0800
Subject: [PATCH] sf

---
 server/service/src/main/java/com/doumee/service/business/impl/BrandServiceImpl.java |   84 ++++++++++++++++++++++++++++++-----------
 1 files changed, 61 insertions(+), 23 deletions(-)

diff --git a/server/service/src/main/java/com/doumee/service/business/impl/BrandServiceImpl.java b/server/service/src/main/java/com/doumee/service/business/impl/BrandServiceImpl.java
index d764fea..9db3591 100644
--- a/server/service/src/main/java/com/doumee/service/business/impl/BrandServiceImpl.java
+++ b/server/service/src/main/java/com/doumee/service/business/impl/BrandServiceImpl.java
@@ -42,17 +42,28 @@
     private SystemDictDataBiz systemDictDataBiz;
     @Override
     public Integer create(Brand brand) {
+        if(StringUtils.isBlank(brand.getName())){
+            throw new BusinessException(ResponseStatus.BAD_REQUEST);
+        }
         LoginUserInfo user = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal();
         if(brandMapper.selectCount(new QueryWrapper<Brand>()
                 .eq("ISDELETED",Constants.ZERO)
-                .eq(user.getType().equals(Constants.UserType.SYSTEM),"name",brand.getName())
-                .and(user.getType().equals(Constants.UserType.COMPANY),
+                 .and(user.getType().equals(Constants.UserType.SYSTEM.getKey()), wapper->wapper.lambda().eq(Brand::getType,Constants.ONE).eq(Brand::getName,brand.getName()))
+//               .eq(user.getType().equals(Constants.UserType.SYSTEM.getKey()),"name",brand.getName())
+                .and(user.getType().equals(Constants.UserType.COMPANY.getKey()),
                         i->i.apply(" name = '"+brand.getName()+"' and type = 1 ")
                                 .or().apply( "  name = '"+brand.getName()+"' and COMPANY_ID = '"+user.getCompanyId()+"' and type = 0 ")
                 )
         )>0){
             throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"銆�"+brand.getName()+"銆戝凡瀛樺湪");
-        };
+        }
+        if(Constants.equalsInteger(user.getType(), Constants.UserType.SYSTEM.getKey())){
+            //骞冲彴鍝佺墝
+            brand.setType(Constants.ONE);
+        }else{
+            brand.setType(Constants.ZERO);
+            brand.setCompanyId(user.getCompanyId());
+        }
         brand.setStatus(Constants.ZERO);
         brand.setCreateDate(new Date());
         brand.setCreator(user.getId());
@@ -88,16 +99,22 @@
     @Override
     public void updateById(Brand brand) {
         LoginUserInfo user = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal();
-        if(brandMapper.selectCount(new QueryWrapper<Brand>()
-                .eq("ISDELETED",Constants.ZERO)
-                .eq(user.getType().equals(Constants.UserType.SYSTEM),"name",brand.getName())
-                .and(user.getType().equals(Constants.UserType.COMPANY),
-                        i->i.apply(" name = '"+brand.getName()+"' and type = 1 ")
-                                .or().apply( "  name = '"+brand.getName()+"' and COMPANY_ID = '"+user.getCompanyId()+"' and type = 0 ")
-                )
-        )>0){
+
+        Brand brand1 = brandMapper.selectOne(new QueryWrapper<Brand>()
+                .eq("ISDELETED", Constants.ZERO)
+                  .and(user.getType().equals(Constants.UserType.SYSTEM.getKey()), wapper->wapper.lambda().eq(Brand::getType,Constants.ONE).eq(Brand::getName,brand.getName()))
+//              .eq(user.getType().equals(Constants.UserType.SYSTEM.getKey()), "name", brand.getName())
+                .and(user.getType().equals(Constants.UserType.COMPANY.getKey()),
+                        i -> i.apply(" name = '" + brand.getName() + "' and type = 1 ")
+                                .or().apply("  name = '" + brand.getName() + "' and COMPANY_ID = '" + user.getCompanyId() + "' and type = 0 ")
+                ).last("limit 1")
+        );
+
+        if(Objects.nonNull(brand1) && (!brand.getId().equals(brand.getId()))){
             throw new BusinessException(ResponseStatus.NOT_ALLOWED.getCode(),"銆�"+brand.getName()+"銆戝凡瀛樺湪");
-        };
+        }
+        brand.setType(null);
+        brand.setCompanyId(null);
         brand.setStatus(Constants.ZERO);
         brand.setEditDate(new Date());
         brand.setEditor(user.getId());
@@ -117,10 +134,12 @@
 
     @Override
     public Brand findById(Integer id) {
-        String prefixUrl = systemDictDataBiz.queryByCode(Constants.SYSTEM, Constants.FILE_DIR).getCode()
-                + systemDictDataBiz.queryByCode(Constants.SYSTEM, Constants.PROJECTS).getCode();
         Brand brand = brandMapper.selectById(id);
-        brand.setImgfullurl(prefixUrl+brand.getImgurl());
+        if(StringUtils.isNotBlank(brand.getImgurl())){
+            String prefixUrl = systemDictDataBiz.queryByCode(Constants.OSS, Constants.RESOURCE_PATH).getCode()
+                    + systemDictDataBiz.queryByCode(Constants.OSS, Constants.BRAND_IMG).getCode();
+            brand.setImgfullurl(prefixUrl+brand.getImgurl());
+        }
         return brand;
     }
 
@@ -135,17 +154,26 @@
         LoginUserInfo user = (LoginUserInfo) SecurityUtils.getSubject().getPrincipal();
         QueryWrapper<Brand> wrapper = new QueryWrapper<>(brand);
         wrapper.lambda().eq(Brand::getIsdeleted,Constants.ZERO);
-        wrapper.lambda().eq(Brand::getStatus,Constants.ZERO);
+//        wrapper.lambda().eq(Brand::getStatus,Constants.ZERO);
+        wrapper.lambda().orderByAsc(Brand::getType);
         wrapper.lambda().orderByAsc(Brand::getSortnum);
         // 绫诲瀷 0浼佷笟 1骞冲彴
-        if (Objects.isNull(user.getCompanyId())) {
+        if (Constants.equalsInteger(user.getType(), Constants.UserType.SYSTEM.getKey())) {
             wrapper.lambda().eq(Brand::getType,Constants.ONE);
+        }else {
+            wrapper.lambda().exists(!Objects.isNull(brand.getCategoryId())," select 1 from goods g where g.brand_id = brand.id and g.category_id = "+brand.getCategoryId()+" and  g.COMPANY_ID = "+user.getCompanyId()+" " +
+                    " and g.STATUS = 0 and g.ISDELETED = 0  ");
+            wrapper.lambda().and(i->i.eq(Brand::getCompanyId,user.getCompanyId())
+                            .or().eq(Brand::getType,Constants.ONE)
+            );
         }
         List<Brand> list = brandMapper.selectList(wrapper);
-        String prefixUrl = systemDictDataBiz.queryByCode(Constants.SYSTEM, Constants.FILE_DIR).getCode()
-                + systemDictDataBiz.queryByCode(Constants.SYSTEM, Constants.PROJECTS).getCode();
+        String prefixUrl = systemDictDataBiz.queryByCode(Constants.OSS, Constants.RESOURCE_PATH).getCode()
+                + systemDictDataBiz.queryByCode(Constants.OSS, Constants.BRAND_IMG).getCode();
         for (Brand b:list) {
-            b.setImgfullurl(prefixUrl+b.getImgurl());
+            if(StringUtils.isNotBlank(b.getImgurl())){
+                b.setImgfullurl(prefixUrl+b.getImgurl());
+            }
         }
         return list;
     }
@@ -163,16 +191,26 @@
         if (pageWrap.getModel().getStatus() != null) {
             queryWrapper.lambda().eq(Brand::getStatus, pageWrap.getModel().getStatus());
         }
+        if (pageWrap.getModel().getType() != null) {
+            queryWrapper.lambda().eq(Brand::getType, pageWrap.getModel().getType());
+        }
         // 绫诲瀷 0浼佷笟 1骞冲彴
         if (Objects.isNull(user.getCompanyId())) {
             queryWrapper.lambda().eq(Brand::getType,Constants.ONE);
+        }else {
+            queryWrapper.lambda().and(i->i.eq(Brand::getCompanyId,user.getCompanyId())
+                    .or().eq(Brand::getType,Constants.ONE)
+            );
         }
+        queryWrapper.lambda().orderByAsc(Brand::getType);
         queryWrapper.lambda().orderByAsc(Brand::getSortnum);
         IPage<Brand> brandIPage = brandMapper.selectPage(page, queryWrapper);
-        String prefixUrl = systemDictDataBiz.queryByCode(Constants.SYSTEM, Constants.FILE_DIR).getCode()
-                + systemDictDataBiz.queryByCode(Constants.SYSTEM, Constants.PROJECTS).getCode();
+        String prefixUrl = systemDictDataBiz.queryByCode(Constants.OSS, Constants.RESOURCE_PATH).getCode()
+                + systemDictDataBiz.queryByCode(Constants.OSS, Constants.BRAND_IMG).getCode();
         brandIPage.getRecords().forEach(i->{
-            i.setImgfullurl(prefixUrl+i.getImgurl());
+            if(StringUtils.isNotBlank(i.getImgurl())){
+                i.setImgfullurl(prefixUrl+i.getImgurl());
+            }
         });
         return PageData.from(brandIPage);
     }

--
Gitblit v1.9.3