From d7e5728e207bf0ac67d3a9f6684e60dff31e21a5 Mon Sep 17 00:00:00 2001
From: Administrator <15274802129@163.com>
Date: Fri, 05 Sep 2025 17:43:24 +0800
Subject: [PATCH] refactor(ai): 优化产品要点页面布局和代码结构
---
src/main/java/cc/mrbird/febs/ai/controller/product/ViewController.java | 149 ++++++++++++++++++++++++++++++++++++++++++++++++-
1 files changed, 145 insertions(+), 4 deletions(-)
diff --git a/src/main/java/cc/mrbird/febs/ai/controller/product/ViewController.java b/src/main/java/cc/mrbird/febs/ai/controller/product/ViewController.java
index 65e03e8..7f874d9 100644
--- a/src/main/java/cc/mrbird/febs/ai/controller/product/ViewController.java
+++ b/src/main/java/cc/mrbird/febs/ai/controller/product/ViewController.java
@@ -1,9 +1,15 @@
package cc.mrbird.febs.ai.controller.product;
-import cc.mrbird.febs.ai.entity.AiProduct;
-import cc.mrbird.febs.ai.service.AiProductService;
+import cc.mrbird.febs.ai.entity.*;
+import cc.mrbird.febs.ai.res.AdminMoveChooseInfoVo;
+import cc.mrbird.febs.ai.service.*;
import cc.mrbird.febs.common.entity.FebsConstant;
import cc.mrbird.febs.common.utils.FebsUtil;
+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.toolkit.Wrappers;
import lombok.RequiredArgsConstructor;
import org.apache.shiro.authz.annotation.RequiresPermissions;
import org.springframework.stereotype.Controller;
@@ -11,6 +17,12 @@
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.PathVariable;
import org.springframework.web.bind.annotation.RequestMapping;
+
+import java.util.ArrayList;
+import java.util.HashSet;
+import java.util.List;
+import java.util.Set;
+import java.util.stream.Collectors;
/**
* @author Administrator
@@ -21,7 +33,13 @@
public class ViewController {
- private final AiProductService service;
+ private final AiProductService aiProductService;
+ private final AiProductPointLinkService aiProductPointLinkService;
+ private final AiProductPointService aiProductPointService;
+ private final AiProductRoleLinkService aiProductRoleLinkService;
+ private final AiProductQuestionLinkService aiProductQuestionLinkService;
+ private final AiProductQuestionService aiProductQuestionService;
+ private final AiProductRoleService aiProductRoleService;
@GetMapping("list")
@RequiresPermissions("productList:view")
@@ -40,8 +58,131 @@
@GetMapping("info/{id}")
@RequiresPermissions("productList:info")
public String artInfo(@PathVariable String id, Model model) {
- AiProduct entity = service.getById(id);
+ AiProduct entity = aiProductService.getById(id);
model.addAttribute("aiProduct", entity);
return FebsUtil.view("modules/ai/product/info");
}
+
+
+
+ @GetMapping("pointSet/{id}")
+ @RequiresPermissions("productList:pointSet")
+ public String pointSet(@PathVariable String id, Model model) {
+ List<AdminMoveChooseInfoVo> vos = new ArrayList<>();
+ Set<String> productIds = new HashSet<>();
+
+ AiProduct entity = aiProductService.getById(id);
+ if(ObjectUtil.isNotNull(entity)){
+ //右侧数据
+ LambdaQueryWrapper<AiProductPointLink> query = Wrappers.lambdaQuery(AiProductPointLink.class);
+ if(StrUtil.isNotEmpty(id)){
+ query.eq(AiProductPointLink::getProductId, id);
+ }
+ List<AiProductPointLink> selectedList = aiProductPointLinkService.selectListByQuery(query);
+ if(CollUtil.isNotEmpty(selectedList)){
+ //stream流操作happyMemberLabelRecords,获取memberId的set集合
+ productIds = selectedList.stream().map(AiProductPointLink::getProductPointId).collect(Collectors.toSet());
+ }
+
+ //左侧数据
+ List<AiProductPoint> allList = aiProductPointService.pointTree();
+ if(CollUtil.isNotEmpty(allList)){
+ //stream流操作mallMembers,生成一个新的List<MallMemberVo>
+ vos = allList.stream().map(AiProductPoint -> {
+ AdminMoveChooseInfoVo vo = new AdminMoveChooseInfoVo();
+ vo.setId(AiProductPoint.getId());
+ vo.setName(AiProductPoint.getTitle());
+ return vo;
+ }).collect(Collectors.toList());
+ }
+ }
+
+ model.addAttribute("pointAll", vos);
+ model.addAttribute("pointSelected", productIds);
+ model.addAttribute("chooseId", id);
+ return FebsUtil.view("modules/ai/product/pointSet");
+ }
+
+
+
+ @GetMapping("productRoleSet/{id}")
+ @RequiresPermissions("productList:productRoleSet")
+ public String productRoleSet(@PathVariable String id, Model model) {
+ List<AdminMoveChooseInfoVo> vos = new ArrayList<>();
+ Set<String> productIds = new HashSet<>();
+
+ AiProduct entity = aiProductService.getById(id);
+ if(ObjectUtil.isNotNull(entity)){
+ //右侧数据
+ LambdaQueryWrapper<AiProductRoleLink> query = Wrappers.lambdaQuery(AiProductRoleLink.class);
+ if(StrUtil.isNotEmpty(id)){
+ query.eq(AiProductRoleLink::getProductId, id);
+ }
+ List<AiProductRoleLink> selectedList = aiProductRoleLinkService.selectListByQuery(query);
+ if(CollUtil.isNotEmpty(selectedList)){
+ //stream流操作happyMemberLabelRecords,获取memberId的set集合
+ productIds = selectedList.stream().map(AiProductRoleLink::getProductRoleId).collect(Collectors.toSet());
+ }
+
+ //左侧数据
+ List<AiProductRole> allList = aiProductRoleService.productRoleTree();
+ if(CollUtil.isNotEmpty(allList)){
+ //stream流操作mallMembers,生成一个新的List<MallMemberVo>
+ vos = allList.stream().map(AiProductRole -> {
+ AdminMoveChooseInfoVo vo = new AdminMoveChooseInfoVo();
+ vo.setId(AiProductRole.getId());
+ vo.setName(AiProductRole.getName());
+ return vo;
+ }).collect(Collectors.toList());
+ }
+ }
+
+ model.addAttribute("productRoleAll", vos);
+ model.addAttribute("productRoleSelected", productIds);
+ model.addAttribute("chooseId", id);
+ return FebsUtil.view("modules/ai/product/productRoleSet");
+ }
+
+
+
+ @GetMapping("productQuestionSet/{id}")
+ @RequiresPermissions("productList:productQuestionSet")
+ public String productQuestionSet(@PathVariable String id, Model model) {
+ List<AdminMoveChooseInfoVo> vos = new ArrayList<>();
+ Set<String> productIds = new HashSet<>();
+
+ AiProduct entity = aiProductService.getById(id);
+ if(ObjectUtil.isNotNull(entity)){
+ //右侧数据
+ LambdaQueryWrapper<AiProductQuestionLink> query = Wrappers.lambdaQuery(AiProductQuestionLink.class);
+ if(StrUtil.isNotEmpty(id)){
+ query.eq(AiProductQuestionLink::getProductId, id);
+ }
+ List<AiProductQuestionLink> selectedList = aiProductQuestionLinkService.selectListByQuery(query);
+ if(CollUtil.isNotEmpty(selectedList)){
+ //stream流操作happyMemberLabelRecords,获取memberId的set集合
+ productIds = selectedList.stream().map(AiProductQuestionLink::getProductQuestionId).collect(Collectors.toSet());
+ }
+
+ //左侧数据
+ LambdaQueryWrapper<AiProductQuestion> aiProductQuestionLambdaQueryWrapper = Wrappers.lambdaQuery(AiProductQuestion.class);
+ aiProductQuestionLambdaQueryWrapper.eq(AiProductQuestion::getProductCategoryId, entity.getProductCategoryId());
+ aiProductQuestionLambdaQueryWrapper.eq(AiProductQuestion::getState, 1);
+ List<AiProductQuestion> allList = aiProductQuestionService.productQuestionTree(aiProductQuestionLambdaQueryWrapper);
+ if(CollUtil.isNotEmpty(allList)){
+ //stream流操作mallMembers,生成一个新的List<MallMemberVo>
+ vos = allList.stream().map(AiProductQuestion -> {
+ AdminMoveChooseInfoVo vo = new AdminMoveChooseInfoVo();
+ vo.setId(AiProductQuestion.getId());
+ vo.setName(AiProductQuestion.getTitle());
+ return vo;
+ }).collect(Collectors.toList());
+ }
+ }
+
+ model.addAttribute("productQuestionAll", vos);
+ model.addAttribute("productQuestionSelected", productIds);
+ model.addAttribute("chooseId", id);
+ return FebsUtil.view("modules/ai/product/productQuestionSet");
+ }
}
--
Gitblit v1.9.1