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