From d2807bf6fa32403ece70ea0fa8f224bdff149392 Mon Sep 17 00:00:00 2001
From: mitao <2763622819@qq.com>
Date: 星期一, 03 三月 2025 11:42:10 +0800
Subject: [PATCH] 党员端:党员证所在党组织bug修改
---
springcloud_k8s_panzhihuazhihuishequ/service_sangeshenbian/src/main/java/com/panzhihua/sangeshenbian/controller/HomeController.java | 53 ++++++++++++++++++++++++++++++++++++++++++++---------
1 files changed, 44 insertions(+), 9 deletions(-)
diff --git a/springcloud_k8s_panzhihuazhihuishequ/service_sangeshenbian/src/main/java/com/panzhihua/sangeshenbian/controller/HomeController.java b/springcloud_k8s_panzhihuazhihuishequ/service_sangeshenbian/src/main/java/com/panzhihua/sangeshenbian/controller/HomeController.java
index 45bca34..ee4f1e5 100644
--- a/springcloud_k8s_panzhihuazhihuishequ/service_sangeshenbian/src/main/java/com/panzhihua/sangeshenbian/controller/HomeController.java
+++ b/springcloud_k8s_panzhihuazhihuishequ/service_sangeshenbian/src/main/java/com/panzhihua/sangeshenbian/controller/HomeController.java
@@ -5,10 +5,9 @@
import com.panzhihua.common.controller.BaseController;
import com.panzhihua.common.model.vos.LoginUserInfoVO;
import com.panzhihua.common.model.vos.R;
-import com.panzhihua.common.model.vos.sangeshenbian.SystemUserVo;
-import com.panzhihua.common.service.sangeshenbian.SystemUserService;
import com.panzhihua.common.service.user.UserService;
import com.panzhihua.sangeshenbian.model.entity.Banner;
+import com.panzhihua.sangeshenbian.model.entity.Department;
import com.panzhihua.sangeshenbian.model.entity.SystemUser;
import com.panzhihua.sangeshenbian.model.query.BasePage;
import com.panzhihua.sangeshenbian.model.vo.ComplaintTodoVO;
@@ -16,6 +15,7 @@
import com.panzhihua.sangeshenbian.model.vo.PartyCardInfoVO;
import com.panzhihua.sangeshenbian.service.IBannerService;
import com.panzhihua.sangeshenbian.service.IComplaintService;
+import com.panzhihua.sangeshenbian.service.IDepartmentService;
import com.panzhihua.sangeshenbian.service.IMessageNotificationService;
import com.panzhihua.sangeshenbian.service.ISystemUserService;
import com.panzhihua.sangeshenbian.utils.BaiduMapUtil;
@@ -29,7 +29,11 @@
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RestController;
+import java.util.HashMap;
import java.util.List;
+import java.util.Map;
+import java.util.Objects;
+import java.util.Optional;
/**
* @author mitao
@@ -37,7 +41,7 @@
*/
@RestController
@RequestMapping("/applet/home")
-@RequiredArgsConstructor(onConstructor_=@Lazy)
+@RequiredArgsConstructor(onConstructor_ = @Lazy)
@Api(tags = "首页相关接口")
public class HomeController extends BaseController {
private final IBannerService bannerService;
@@ -45,11 +49,14 @@
private final IComplaintService complaintService;
private final ISystemUserService systemUserService;
private final UserService userService;
+ private final IDepartmentService departmentService;
+
@ApiOperation("获取banner列表")
@GetMapping("/banner-list")
public R<List<Banner>> getBannerList() {
return R.ok(bannerService.list());
}
+
@GetMapping("/party-card-info")
@ApiOperation("获取党员证信息")
public R<PartyCardInfoVO> getPartyCardInfo() {
@@ -57,43 +64,71 @@
PartyCardInfoVO partyCardInfoVO = new PartyCardInfoVO();
partyCardInfoVO.setName(loginUserInfo.getName());
partyCardInfoVO.setIdCard(loginUserInfo.getIdCard());
+ Optional<SystemUser> systemUserOpt = systemUserService.getSystemUserByPhone(loginUserInfo.getPhone());
+ systemUserOpt.ifPresent(systemUser -> {
+ // 使用Optional链式调用简化部门ID获取逻辑
+ Integer lastDepartmentId = Optional.ofNullable(systemUser.getFourDepartmentId())
+ .orElseGet(() -> Optional.ofNullable(systemUser.getThreeDepartmentId())
+ .orElseGet(systemUser::getTwoDepartmentId));
+
+ // 缓存部门查询结果避免重复查询
+ Map<Integer, Department> departmentCache = new HashMap<>();
+ Department first = departmentCache.computeIfAbsent(systemUser.getOneDepartmentId(),
+ departmentService::getById);
+ Department last = null;
+ if (Objects.nonNull(lastDepartmentId)) {
+ last = departmentCache.computeIfAbsent(lastDepartmentId,
+ departmentService::getById);
+ }
+
+ // 使用Objects.toString简化字符串拼接
+ partyCardInfoVO.setPartyOrganization(
+ Objects.isNull(last) ? Objects.toString(first.getName(), "") :
+ Objects.toString(first.getName(), "") + "-" + Objects.toString(last.getName(), ""));
+ });
+
partyCardInfoVO.setPartyOrganization(loginUserInfo.getCommunityName());
return R.ok(partyCardInfoVO);
}
+
@PostMapping("/message")
@ApiOperation("获取消息列表")
public R<Page<MessageNotificationVO>> getMessageList(@RequestBody BasePage page) {
- return R.ok(messageNotificationService.getMessageList(page,getUserId()));
+ return R.ok(messageNotificationService.getMessageList(page, getUserId()));
}
+
@PostMapping("/todo-list")
@ApiOperation("获取待办诉求")
public R<Page<ComplaintTodoVO>> getTodoList(@RequestBody BasePage page) {
- return R.ok(complaintService.getTodoList(page,getLoginUserInfo()));
+ return R.ok(complaintService.getTodoList(page, getLoginUserInfo()));
}
+
@GetMapping("/current-user-info")
@ApiOperation("获取三个身边当前用户信息 用于判断用户是否是上级")
public R<SystemUser> getCurrentUserInfo() {
- return R.ok(systemUserService.getSystemUserByPhone(getLoginUserInfo().getPhone()).orElse(null));
+ return R.ok(systemUserService.getSystemUserAdminByPhone(getLoginUserInfo().getPhone()).orElse(null));
}
+
/**
* 标记已读
*/
@PostMapping("/read")
@ApiOperation("标记已读")
- public R<?> read(){
+ public R<?> read() {
messageNotificationService.read(getLoginUserInfo());
return R.ok();
}
/**
* 百度地图圆形区域检索
+ *
* @param query
* @param location
* @return
*/
@GetMapping("/search-location")
@ApiOperation("百度地图圆形区域检索")
- public R<JSONArray> searchLocation(String query,String location){
- return R.ok(BaiduMapUtil.searchLocation(query,location));
+ public R<JSONArray> searchLocation(String query, String location) {
+ return R.ok(BaiduMapUtil.searchLocation(query, location));
}
}
--
Gitblit v1.7.1