From 43c5aa63efb2e11857cd90cffe1d126e24091336 Mon Sep 17 00:00:00 2001
From: Administrator <15274802129@163.com>
Date: Mon, 20 Oct 2025 15:54:07 +0800
Subject: [PATCH] fix(ai): 调整公司成员申请状态处理逻辑
---
src/main/java/cc/mrbird/febs/ai/service/impl/AiMemberRoleServiceImpl.java | 214 +++++++++++++++++++++++++++++++++--------------------
1 files changed, 134 insertions(+), 80 deletions(-)
diff --git a/src/main/java/cc/mrbird/febs/ai/service/impl/AiMemberRoleServiceImpl.java b/src/main/java/cc/mrbird/febs/ai/service/impl/AiMemberRoleServiceImpl.java
index c0e8f0a..488e56b 100644
--- a/src/main/java/cc/mrbird/febs/ai/service/impl/AiMemberRoleServiceImpl.java
+++ b/src/main/java/cc/mrbird/febs/ai/service/impl/AiMemberRoleServiceImpl.java
@@ -1,15 +1,31 @@
package cc.mrbird.febs.ai.service.impl;
import cc.mrbird.febs.ai.entity.AiMemberRole;
+import cc.mrbird.febs.ai.entity.AiMemberRolePoint;
+import cc.mrbird.febs.ai.entity.AiMemberRoleProduct;
import cc.mrbird.febs.ai.mapper.AiMemberRoleMapper;
+import cc.mrbird.febs.ai.req.AdminMoveChooseInfoDto;
+import cc.mrbird.febs.ai.service.AiMemberRolePointService;
+import cc.mrbird.febs.ai.service.AiMemberRoleProductService;
import cc.mrbird.febs.ai.service.AiMemberRoleService;
+import cc.mrbird.febs.ai.service.AiProductService;
+import cc.mrbird.febs.ai.util.UUID;
+import cc.mrbird.febs.common.entity.FebsResponse;
+import cc.mrbird.febs.common.entity.QueryRequest;
+import cc.mrbird.febs.system.service.IUserService;
+import cn.hutool.core.collection.CollUtil;
+import cn.hutool.core.util.ObjectUtil;
+import cn.hutool.core.util.StrUtil;
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.core.metadata.IPage;
+import com.baomidou.mybatisplus.core.toolkit.Wrappers;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import lombok.RequiredArgsConstructor;
import lombok.extern.slf4j.Slf4j;
import org.springframework.stereotype.Service;
-import org.springframework.transaction.annotation.Transactional;
+import java.util.Date;
import java.util.List;
/**
@@ -24,106 +40,144 @@
public class AiMemberRoleServiceImpl extends ServiceImpl<AiMemberRoleMapper, AiMemberRole> implements AiMemberRoleService {
private final AiMemberRoleMapper aiMemberRoleMapper;
+ private final AiProductService aiProductService;
+ private final AiMemberRoleProductService aiMemberRoleProductService;
+ private final AiMemberRolePointService aiMemberRolePointService;
+ private final IUserService iUserService;
@Override
public AiMemberRole getById(String id) {
- return this.getById(id);
+ return aiMemberRoleMapper.selectById(id);
}
@Override
- public List<AiMemberRole> getByCompanyId(String companyId) {
- LambdaQueryWrapper<AiMemberRole> queryWrapper = new LambdaQueryWrapper<>();
- queryWrapper.eq(AiMemberRole::getCompanyId, companyId);
- queryWrapper.orderByDesc(AiMemberRole::getCreatedTime);
- return this.list(queryWrapper);
- }
-
- @Override
- public AiMemberRole getByCode(String code) {
- LambdaQueryWrapper<AiMemberRole> queryWrapper = new LambdaQueryWrapper<>();
- queryWrapper.eq(AiMemberRole::getCode, code);
- return this.getOne(queryWrapper);
- }
-
- @Override
- public List<AiMemberRole> getByName(String name) {
- LambdaQueryWrapper<AiMemberRole> queryWrapper = new LambdaQueryWrapper<>();
- queryWrapper.eq(AiMemberRole::getName, name);
- queryWrapper.orderByDesc(AiMemberRole::getCreatedTime);
- return this.list(queryWrapper);
- }
-
- @Override
- public List<AiMemberRole> getByState(Integer state) {
- LambdaQueryWrapper<AiMemberRole> queryWrapper = new LambdaQueryWrapper<>();
- queryWrapper.eq(AiMemberRole::getState, state);
- queryWrapper.orderByDesc(AiMemberRole::getCreatedTime);
- return this.list(queryWrapper);
- }
-
- @Override
- public List<AiMemberRole> getByCompanyIdAndState(String companyId, Integer state) {
- LambdaQueryWrapper<AiMemberRole> queryWrapper = new LambdaQueryWrapper<>();
- queryWrapper.eq(AiMemberRole::getCompanyId, companyId);
- queryWrapper.eq(AiMemberRole::getState, state);
- queryWrapper.orderByDesc(AiMemberRole::getCreatedTime);
- return this.list(queryWrapper);
- }
-
- @Override
- @Transactional(rollbackFor = Exception.class)
- public boolean saveRole(AiMemberRole aiMemberRole) {
- try {
- return this.save(aiMemberRole);
- } catch (Exception e) {
- log.error("保存角色失败: ", e);
- return false;
+ public IPage<AiMemberRole> listInPage(AiMemberRole dto, QueryRequest request) {
+ Page<AiMemberRole> page = new Page<>(request.getPageNum(), request.getPageSize());
+ LambdaQueryWrapper<AiMemberRole> query = Wrappers.lambdaQuery(AiMemberRole.class);
+ if (StrUtil.isNotEmpty(dto.getCompanyId())){
+ query.eq(AiMemberRole::getCompanyId, dto.getCompanyId());
}
+ query.ne(AiMemberRole::getState, 2);
+ query.orderByAsc(AiMemberRole::getSort);
+ Page<AiMemberRole> pages = aiMemberRoleMapper.selectPage(page, query);
+ return pages;
}
@Override
- @Transactional(rollbackFor = Exception.class)
- public boolean saveBatchRoles(List<AiMemberRole> roles) {
- try {
- return this.saveBatch(roles);
- } catch (Exception e) {
- log.error("批量保存角色失败: ", e);
- return false;
+ public FebsResponse changeState(String id, Integer state) {
+ AiMemberRole entity = this.getById(id);
+ if(ObjectUtil.isNotEmpty(entity)){
+ this.update(null,
+ Wrappers.lambdaUpdate(AiMemberRole.class)
+ .set(AiMemberRole::getState, state)
+ .set(AiMemberRole::getUpdatedTime, new Date())
+ .eq(AiMemberRole::getId, id));
}
+ return new FebsResponse().success().message("操作成功");
}
@Override
- @Transactional(rollbackFor = Exception.class)
- public boolean updateRole(AiMemberRole aiMemberRole) {
- try {
- return this.updateById(aiMemberRole);
- } catch (Exception e) {
- log.error("更新角色失败: ", e);
- return false;
- }
+ public FebsResponse memberRoleAdd(AiMemberRole dto) {
+ AiMemberRole entity = new AiMemberRole();
+ entity.setId(UUID.getSimpleUUIDString());
+ entity.setName(dto.getName());
+ entity.setCode(dto.getCode());
+ entity.setIconImg(dto.getIconImg());
+ entity.setSort(dto.getSort());
+ entity.setState(dto.getState());
+ entity.setCompanyId(dto.getCompanyId());
+ entity.setCreatedTime(new Date());
+ this.save( entity);
+ return new FebsResponse().success().message("操作成功");
}
@Override
- @Transactional(rollbackFor = Exception.class)
- public boolean deleteById(String id) {
- try {
- return this.removeById(id);
- } catch (Exception e) {
- log.error("删除角色失败: ", e);
- return false;
+ public FebsResponse updateMemberRole(AiMemberRole dto) {
+
+ String id = dto.getId();
+ AiMemberRole entity = this.getById(id);
+ if(ObjectUtil.isNotNull( entity)){
+ this.update(null,
+ Wrappers.lambdaUpdate(AiMemberRole.class)
+ .set(AiMemberRole::getCode, dto.getCode())
+ .set(AiMemberRole::getName, dto.getName())
+ .set(AiMemberRole::getIconImg, dto.getIconImg())
+ .set(AiMemberRole::getSort, dto.getSort())
+ .set(AiMemberRole::getUpdatedTime, new Date())
+ .eq(AiMemberRole::getId, id));
+
}
+ return new FebsResponse().success().message("操作成功");
}
@Override
- @Transactional(rollbackFor = Exception.class)
- public boolean deleteByCompanyId(String companyId) {
- try {
- LambdaQueryWrapper<AiMemberRole> queryWrapper = new LambdaQueryWrapper<>();
- queryWrapper.eq(AiMemberRole::getCompanyId, companyId);
- return this.remove(queryWrapper);
- } catch (Exception e) {
- log.error("根据公司ID删除角色失败: ", e);
- return false;
+ public FebsResponse delete(String id) {
+ AiMemberRole entity = this.getById(id);
+ if(ObjectUtil.isNotNull( entity)){
+ this.update(null,
+ Wrappers.lambdaUpdate(AiMemberRole.class)
+ .set(AiMemberRole::getState, 2)
+ .set(AiMemberRole::getUpdatedTime, new Date())
+ .eq(AiMemberRole::getId, id));
+
}
+ return new FebsResponse().success().message("操作成功");
+ }
+
+ @Override
+ public FebsResponse productSet(AdminMoveChooseInfoDto dto) {
+ String chooseId = dto.getChooseId();
+ List<String> chooseIds = dto.getChooseIds();
+ AiMemberRole aiMemberRole = this.getById(chooseId);
+ if (ObjectUtil.isNotNull(aiMemberRole)) {
+ String companyId = aiMemberRole.getCompanyId();
+ aiMemberRoleProductService.deleteByQuery(
+ Wrappers.lambdaQuery(AiMemberRoleProduct.class)
+ .eq(AiMemberRoleProduct::getRoleId,chooseId)
+ .eq(AiMemberRoleProduct::getCompanyId,companyId)
+ );
+ if(CollUtil.isNotEmpty(chooseIds)){
+ Date createdTime = new Date();
+ for (String item : chooseIds){
+ AiMemberRoleProduct entity = new AiMemberRoleProduct();
+ entity.setId(UUID.getSimpleUUIDString());
+ entity.setRoleId(chooseId);
+ entity.setProductId(item);
+ entity.setCompanyId(companyId);
+ entity.setCreatedTime(createdTime);
+ aiMemberRoleProductService.getBaseMapper().insert(entity);
+ }
+ }
+ }
+ return new FebsResponse().success().message("操作成功");
+ }
+
+ @Override
+ public FebsResponse productPointSet(AdminMoveChooseInfoDto dto) {
+
+ String chooseId = dto.getChooseId();
+ List<String> chooseIds = dto.getChooseIds();
+ AiMemberRole aiMemberRole = this.getById(chooseId);
+ if (ObjectUtil.isNotNull(aiMemberRole)) {
+ String companyId = aiMemberRole.getCompanyId();
+ aiMemberRolePointService.deleteByQuery(
+ Wrappers.lambdaQuery(AiMemberRolePoint.class)
+ .eq(AiMemberRolePoint::getRoleId,chooseId)
+ .eq(AiMemberRolePoint::getCompanyId,companyId)
+ );
+ if(CollUtil.isNotEmpty(chooseIds)){
+ Date createdTime = new Date();
+ for (String item : chooseIds){
+ AiMemberRolePoint entity = new AiMemberRolePoint();
+ entity.setId(UUID.getSimpleUUIDString());
+ entity.setRoleId(chooseId);
+ entity.setProductPointId(item);
+ entity.setCompanyId(companyId);
+ entity.setCreatedTime(createdTime);
+ aiMemberRolePointService.getBaseMapper().insert(entity);
+ }
+ }
+ }
+ return new FebsResponse().success().message("操作成功");
}
}
--
Gitblit v1.9.1