From 039abee6b27058ca46b1e1e82aa0b5407a5dad44 Mon Sep 17 00:00:00 2001
From: liujie <1793218484@qq.com>
Date: 星期一, 28 七月 2025 15:25:26 +0800
Subject: [PATCH] 优化 和修改bug

---
 springcloud_k8s_panzhihuazhihuishequ/service_westcommittee/src/main/java/com/panzhihua/westcommittee/service/impl/ComplaintServiceImpl.java |  920 +++++++++++++++++++++++++++++++++++++++++++++------------
 1 files changed, 726 insertions(+), 194 deletions(-)

diff --git a/springcloud_k8s_panzhihuazhihuishequ/service_westcommittee/src/main/java/com/panzhihua/westcommittee/service/impl/ComplaintServiceImpl.java b/springcloud_k8s_panzhihuazhihuishequ/service_westcommittee/src/main/java/com/panzhihua/westcommittee/service/impl/ComplaintServiceImpl.java
index 93d7a21..33eaa84 100644
--- a/springcloud_k8s_panzhihuazhihuishequ/service_westcommittee/src/main/java/com/panzhihua/westcommittee/service/impl/ComplaintServiceImpl.java
+++ b/springcloud_k8s_panzhihuazhihuishequ/service_westcommittee/src/main/java/com/panzhihua/westcommittee/service/impl/ComplaintServiceImpl.java
@@ -11,7 +11,7 @@
 import com.deepoove.poi.XWPFTemplate;
 import com.panzhihua.common.exceptions.ServiceException;
 import com.panzhihua.common.model.vos.LoginUserInfoVO;
-import com.panzhihua.common.model.vos.sangeshenbian.SystemUserVo;
+import com.panzhihua.common.model.vos.west.SystemUserVo;
 import com.panzhihua.common.redis.RedisUtils;
 import com.panzhihua.common.utlis.DateUtils;
 import com.panzhihua.common.utlis.StringUtils;
@@ -27,9 +27,8 @@
 import com.panzhihua.westcommittee.model.query.ComplaintQuery;
 import com.panzhihua.westcommittee.model.vo.*;
 import com.panzhihua.westcommittee.service.*;
-import com.panzhihua.westcommittee.warpper.IdentityInformation;
-import com.panzhihua.westcommittee.warpper.MgtComplaintQuery;
-import com.panzhihua.westcommittee.warpper.PermissionsVO;
+import com.panzhihua.westcommittee.utils.AliSmsUtil;
+import com.panzhihua.westcommittee.warpper.*;
 import jodd.util.StringUtil;
 import lombok.RequiredArgsConstructor;
 import lombok.extern.slf4j.Slf4j;
@@ -39,6 +38,7 @@
 import org.springframework.transaction.annotation.Transactional;
 
 import javax.servlet.http.HttpServletResponse;
+
 import java.io.IOException;
 import java.io.InputStream;
 import java.math.BigDecimal;
@@ -79,10 +79,14 @@
     private final IPartyMemberService partyMemberService;
     private final IdentityInformationService identityInformationService;
     private final IDepartmentService departmentService;
+    private final WestPopUpService westPopUpService;
+
     private final RedisUtils redisUtils;
 
     @Override
-    public void saveComplaint(Complaint complaint, LoginUserInfoVO loginUserInfoVO) {
+    public  HashMap<String, String> saveComplaint(Complaint complaint, LoginUserInfoVO loginUserInfoVO) {
+        HashMap<String, String> map = new HashMap<>();
+        String timeStr = null;
         // 获取当前日期(年月日)
         String datePrefix = new SimpleDateFormat("yyyyMMdd").format(new Date());
 
@@ -105,29 +109,22 @@
 
         // 设置流水号
         complaint.setSerialNumber(serialNumber);
-        Integer accountLevel = 5;
+        Integer accountLevel = 4;
         //获取当前身份
         IdentityInformation identityInformationVO = identityInformationService.getCurrentIdentityInformation(loginUserInfoVO);
         //1=党员,2=管理员
         SystemUser systemUser = identityInformationVO.getSystemUser();
         Integer identity = identityInformationVO.getIdentity();
         if (identity == 2) {
+            loginUserInfoVO.setUserId(Long.valueOf(systemUser.getId()));
             accountLevel = systemUser.getAccountLevel();
             switch (accountLevel) {
-                case 1:
-                    //市级
-                    complaint.setCityCode(510400);
-                    complaint.setReportUserName(systemUser.getName());
-                    complaint.setReportUserPhone(systemUser.getPhone());
-                    break;
                 case 2:
                     //区县级
                     complaint.setCityCode(510400);
                     complaint.setDistrictsCode(Integer.valueOf(systemUser.getDistrictsCode()));
                     complaint.setReportUserName(systemUser.getName());
                     complaint.setReportUserPhone(systemUser.getPhone());
-
-
                     complaint.setSuperiorId(Long.valueOf(systemUser.getDistrictsCode()));
                     break;
                 case 3:
@@ -162,7 +159,7 @@
                     complaint.setReportUserName(partyMember.getName());
                     complaint.setReportUserPhone(partyMember.getPhone());
 
-                    accountLevel=4;
+                    accountLevel = 4;
                     complaint.setSuperiorId(systemUser.getCommunityId());
                     break;
             }
@@ -176,14 +173,37 @@
 //            }
         } else {
             PartyMember partyMember = partyMemberService.getPartyMemberByPhone(loginUserInfoVO.getPhone());
-            //党员
             complaint.setCityCode(510400);
-            complaint.setDistrictsCode(Integer.valueOf(partyMember.getDistrictsCode()));
-            complaint.setStreetId(Long.valueOf(partyMember.getStreetId()));
-            complaint.setCommunityId(partyMember.getCommunityId());
-            complaint.setPartyMemberId(partyMember.getId());
-            complaint.setReportUserName(partyMember.getName());
-            complaint.setReportUserPhone(partyMember.getPhone());
+            if (partyMember != null) {
+                //党员
+                complaint.setDistrictsCode(Integer.valueOf(partyMember.getDistrictsCode()));
+                complaint.setStreetId(Long.valueOf(partyMember.getStreetId()));
+                complaint.setCommunityId(partyMember.getCommunityId());
+                complaint.setPartyMemberId(partyMember.getId());
+                complaint.setReportUserName(partyMember.getName());
+                complaint.setReportUserPhone(partyMember.getPhone());
+                complaint.setSuperiorId(partyMember.getCommunityId());
+            } else {
+                complaint.setDistrictsCode(Integer.valueOf(loginUserInfoVO.getAreaCode()));
+                complaint.setStreetId(loginUserInfoVO.getStreetId());
+                complaint.setCommunityId(loginUserInfoVO.getCommunityId());
+                complaint.setReportUserName(loginUserInfoVO.getName());
+                complaint.setReportUserPhone(loginUserInfoVO.getPhone());
+                complaint.setSuperiorId(loginUserInfoVO.getCommunityId());
+
+
+                ComAct byId = comActService.getById(loginUserInfoVO.getCommunityId());
+                String name = byId.getName();
+                WestPopUp one = westPopUpService.getOne(new LambdaQueryWrapper<WestPopUp>().eq(WestPopUp::getName, name));
+
+                if(one!=null){
+                    map.put("name", one.getDeptName());
+                    map.put("phone", one.getPhone());
+                }
+
+
+            }
+
 
             // 添加处理人
 //            SystemUser one = systemUserService.getOne(new LambdaQueryWrapper<SystemUser>().eq(SystemUser::getAccountLevel, 4).eq(SystemUser::getIsDeptAdmin, 1).eq(SystemUser::getCommunityId, partyMember.getCommunityId()).ne(SystemUser::getStatus, 3));
@@ -196,6 +216,8 @@
         }
         complaint.setReportType(accountLevel);
         complaint.setNowLevel(accountLevel);
+        complaint.setLastLevel(accountLevel);
+        complaint.setLastSuperiorId(complaint.getSuperiorId());
 
         // 设置其他字段
         complaint.setStatus(ProcessStatusEnum.PROCESSING.getCode());
@@ -208,9 +230,15 @@
         if (Objects.isNull(config)) {
             throw new ServiceException("工单事项未配置,请联系管理员");
         }
-        complaint.setClosingTime(new Date(System.currentTimeMillis() + config.getDemandProcessingTime() * 24 * 60 * 60 * 1000));
+        complaint.setNowLevelTime(new Date());
+        complaint.setNowLevelSms(0);
         // 保存诉求记录
         save(complaint);
+
+
+
+
+        return map;
     }
 
     @Override
@@ -238,6 +266,7 @@
         saveResult(complaintCompletionDTO, loginUserInfo);
     }
 
+
     @Override
     public Page<ComplaintVO> complaintList(ComplaintQuery query, LoginUserInfoVO loginUserInfoVO) {
 
@@ -252,11 +281,12 @@
         Integer identity = identityInformation.getIdentity();
         query.setUserId(loginUserInfoVO.getUserId());
 
-        SystemUser systemUser = null;
+        SystemUser systemUser;
         //上级
         if (systemUserByPhone.isPresent() && null != identity && identity == 2) {
-          systemUserByPhone.get();
+            systemUser = systemUserByPhone.get();
             accountLevel = systemUser.getAccountLevel();
+            query.setUserId(Long.valueOf(systemUser.getId()));
             switch (accountLevel) {
                 case 2:
                     //区县级
@@ -277,53 +307,129 @@
                     break;
             }
         } else {
+            systemUser = null;
             //党员
             PartyMember partyMember = partyMemberService.getPartyMemberByPhone(loginUserInfoVO.getPhone());
-            targetId = partyMember.getCommunityId();
+            if (partyMember != null) {
+                targetId = partyMember.getCommunityId();
+            } else {
+                targetId = loginUserInfoVO.getCommunityId();
+            }
         }
         //查询对应诉求
         //page = baseMapper.selectComplaintPage(page, query, targetId, isSuperior);
         // 党员只看自己上报的
-        if(accountLevel==5){
-            page =  baseMapper.selectComplaintPage2(page, query, accountLevel, targetId);
-        }else if(accountLevel==2){
+        if (accountLevel == 5) {
+            page = baseMapper.selectComplaintPage2(page, query, accountLevel, targetId);
+        } else if (accountLevel == 2) {
             // 西区单位  如果是西区单位,则只看自己上报的
-            if(systemUser.getSystemRoleId()==1){
+            if (systemUser.getSystemRoleId() == 1 || systemUser.getSystemRoleId() == 2) {
                 // 是管理员 看所有的
-                page =  baseMapper.selectComplaintPage3(page, query, accountLevel, targetId);
-            }else {
+                page = baseMapper.selectComplaintPage3(page, query, accountLevel, targetId, systemUser.getSystemRoleId());
+            } else {
                 // 不是管理员 看到指派给我的单位的诉求
-                page =  baseMapper.selectComplaintPage4(page, query, systemUser.getOneDepartmentId());
+                page = baseMapper.selectComplaintPage4(page, query, systemUser.getOneDepartmentId());
             }
-        }else if(accountLevel==3){
+        } else if (accountLevel == 3) {
             // 街道 1
-            if(systemUser.getSystemRoleId()==1){
-                // 获取街道的所有单位
-                List<Department> list = departmentService.list(new LambdaQueryWrapper<Department>().eq(Department::getTier, 3).eq(Department::getStreetId, systemUser.getStreetId()));
-                if(list.isEmpty()){
-                    return page;
-                }
+            if (systemUser.getSystemRoleId() == 1 || systemUser.getSystemRoleId() == 2) {
+                // 获取这个街道所管的社区id
+                List<Long> communityIds = comActService.list(new LambdaQueryWrapper<ComAct>().eq(ComAct::getStreetId, systemUser.getStreetId())).stream().map(ComAct::getCommunityId).collect(Collectors.toList());
                 // 是管理员 可以看到下派来的  也可以看到上派待审核的
-                page =  baseMapper.selectComplaintPage5(page, query,systemUser.getStreetId(),list.stream().map(Department::getId).collect(Collectors.toList()));
-            }else {
+                page = baseMapper.selectComplaintPage5(page, query, systemUser.getStreetId(), communityIds, systemUser.getSystemRoleId());
+            } else {
                 // 不是管理员 看指派给我的
-                page =  baseMapper.selectComplaintPage4(page, query, systemUser.getOneDepartmentId());
+                page = baseMapper.selectComplaintPage4(page, query, systemUser.getOneDepartmentId());
             }
-        }else if(accountLevel==4){
+        } else if (accountLevel == 4) {
             // 社区
-            if(systemUser.getSystemRoleId()==1){
-                List<Department> list = departmentService.list(new LambdaQueryWrapper<Department>().eq(Department::getTier, 4).eq(Department::getCommunityId, systemUser.getCommunityId()));
-                if(list.isEmpty()){
-                    return page;
-                }
+            if (systemUser.getSystemRoleId() == 1 || systemUser.getSystemRoleId() == 2) {
                 // 是管理员
-                page =  baseMapper.selectComplaintPage6(page, query,systemUser.getCommunityId(),list.stream().map(Department::getId).collect(Collectors.toList()));
-            }else {
+                page = baseMapper.selectComplaintPage6(page, query, systemUser.getCommunityId(), null, systemUser.getSystemRoleId());
+            } else {
                 // 不是管理员 看到负责社区的所有诉求  和 上级下派来的诉求
-                page =  baseMapper.selectComplaintPage4(page, query, systemUser.getOneDepartmentId());
+                page = baseMapper.selectComplaintPage4(page, query, systemUser.getOneDepartmentId());
 
             }
         }
+
+
+        Date date = new Date();
+        WorkOrderItemConfig config = workOrderItemConfigService.getById(1);
+        for (ComplaintVO record : page.getRecords()) {
+
+            // 处理页面颜色展示和倒计时
+            Date nowLevelTime = record.getNowLevelTime();
+            if (record.getNowLevel() == 2) {
+                Long HandlingTime = config.getDistrictHandlingTime().longValue();
+                Long DeadlineReminder = config.getDistrictDeadlineReminder().longValue();
+                // 判断是超时 还是  临期
+                if (nowLevelTime.getTime() + HandlingTime * 24 * 60 * 60 * 1000 < date.getTime()) {
+                    record.setRemindStatus(2);
+                } else if (nowLevelTime.getTime() + DeadlineReminder * 24 * 60 * 60 * 1000 < date.getTime()) {
+                    record.setRemindStatus(1);
+                }
+                long l = nowLevelTime.getTime() + HandlingTime * 24 * 60 * 60 * 1000 - date.getTime();
+                double days = (double) l / (24 * 60 * 60 * 1000); // 毫秒转天数
+                BigDecimal result = new BigDecimal(days).setScale(1, RoundingMode.HALF_UP); // 保留1位小数
+                record.setRemindTime(result.doubleValue());
+            } else if (record.getNowLevel() == 3) {
+                Long HandlingTime = config.getStreetHandlingTime().longValue();
+                Long DeadlineReminder = config.getStreetDeadlineReminder().longValue();
+                // 判断是超时 还是  临期
+                if (nowLevelTime.getTime() + HandlingTime * 24 * 60 * 60 * 1000 < date.getTime()) {
+                    record.setRemindStatus(2);
+                } else if (nowLevelTime.getTime() + DeadlineReminder * 24 * 60 * 60 * 1000 < date.getTime()) {
+                    record.setRemindStatus(1);
+                }
+                long l = nowLevelTime.getTime() + HandlingTime * 24 * 60 * 60 * 1000 - date.getTime();
+                double days = (double) l / (24 * 60 * 60 * 1000); // 毫秒转天数
+                BigDecimal result = new BigDecimal(days).setScale(1, RoundingMode.HALF_UP); // 保留1位小数
+                record.setRemindTime(result.doubleValue());
+            } else if (record.getNowLevel() == 4) {
+                Long HandlingTime = config.getCommunityHandlingTime().longValue();
+                Long DeadlineReminder = config.getCommunityDeadlineReminder().longValue();
+                // 判断是超时 还是  临期
+                if (nowLevelTime.getTime() + HandlingTime * 24 * 60 * 60 * 1000 < date.getTime()) {
+                    record.setRemindStatus(2);
+                } else if (nowLevelTime.getTime() + DeadlineReminder * 24 * 60 * 60 * 1000 < date.getTime()) {
+                    record.setRemindStatus(1);
+                }
+                long l = nowLevelTime.getTime() + HandlingTime * 24 * 60 * 60 * 1000 - date.getTime();
+                double days = (double) l / (24 * 60 * 60 * 1000); // 毫秒转天数
+                BigDecimal result = new BigDecimal(days).setScale(1, RoundingMode.HALF_UP); // 保留1位小数
+                record.setRemindTime(result.doubleValue());
+            }
+
+
+            int count = complaintCommentService.count(new LambdaQueryWrapper<ComplaintComment>().eq(ComplaintComment::getComplaintId, record.getId()));
+            if (count > 0) {
+                record.setEvaluateButtonStatus(1);
+            } else {
+                if(record.getStatus()==3){
+                    record.setEvaluateButtonStatus(0);
+                }else {
+                    record.setEvaluateButtonStatus(1);
+                }
+//                if (systemUser != null) {
+//                    if (record.getStatus() == 3 && systemUser.getAccountLevel() == record.getNowLevel()) {
+//                        record.setEvaluateButtonStatus(0);
+//                    } else if (record.getCreateBy().equals(loginUserInfoVO.getUserId()) && record.getStatus() == 3) {
+//                        record.setEvaluateButtonStatus(0);
+//                    } else {
+//                        record.setEvaluateButtonStatus(1);
+//                    }
+//                } else {
+//                    if (record.getStatus() == 3 && loginUserInfoVO.getUserId().equals(record.getCreateBy())) {
+//                        record.setEvaluateButtonStatus(0);
+//                    } else {
+//                        record.setEvaluateButtonStatus(1);
+//                    }
+//                }
+            }
+
+        }
+
         return page;
     }
 
@@ -338,7 +444,6 @@
         // 获取身份
         IdentityInformation currentIdentityInformation = identityInformationService.getCurrentIdentityInformation(loginUserInfo);
         Integer identity = currentIdentityInformation.getIdentity();
-        SystemUserLevel systemUserLevel = currentIdentityInformation.getSystemUserLevel();
         SystemUser systemUser1 = currentIdentityInformation.getSystemUser();
         ComplaintAuditRecord one = complaintAuditRecordService.getOne(new LambdaQueryWrapper<ComplaintAuditRecord>()
                 .eq(ComplaintAuditRecord::getComplaintId, vo.getId())
@@ -364,7 +469,7 @@
                 }
             }*/
             //当前身份是管理员
-            if (2 == identity && systemUserLevel.getLevel().compareTo(vo.getReportType()) == 0 && (systemUserLevel.getLevel() != 5)) {
+            if (2 == identity && systemUser1.getAccountLevel().compareTo(vo.getReportType()) == 0 && (systemUser1.getAccountLevel() != 5)) {
                 vo.setListControlsButtonStatus(0);
             }
             //如果当前身份是党员
@@ -389,7 +494,7 @@
                     }*/
                     if (identity == 2) {
                         //非党员用户,必须是管理员有权限
-                        if (systemUserLevel.getLevel().compareTo(one.getReportType()) == 0) {
+                        if (systemUser1.getAccountLevel().compareTo(one.getReportType()) == 0) {
                             vo.setListControlsButtonStatus(0);
                         }
                     }
@@ -403,7 +508,7 @@
                             .last(" limit 0, 1"));
                     if (null != one1) {
                         //非党员用户,必须是管理员有权限
-                        if (identity == 2 && systemUserLevel.getLevel().compareTo(one1.getReportType()) == 0 && systemUserLevel.getLevel() != 5) {
+                        if (identity == 2 && systemUser1.getAccountLevel().compareTo(one1.getReportType()) == 0 && systemUser1.getAccountLevel() != 5) {
                             vo.setListControlsButtonStatus(0);
                         }
                         /*if (systemUserByPhone.isPresent()) {
@@ -435,7 +540,7 @@
                             }
                         }*/
                         //当前身份是管理员
-                        if (2 == identity && systemUserLevel.getLevel().compareTo(vo.getReportType()) == 0 && (systemUserLevel.getLevel() != 5)) {
+                        if (2 == identity && systemUser1.getAccountLevel().compareTo(vo.getReportType()) == 0 && (systemUser1.getAccountLevel() != 5)) {
                             vo.setListControlsButtonStatus(0);
                         }
                         //如果当前身份是党员
@@ -460,7 +565,7 @@
                             vo.setListControlsButtonStatus(0);
                         }
                     }*/
-                    if (2 == identity && systemUserLevel.getLevel().compareTo(one.getReportType()) == 0) {
+                    if (2 == identity && systemUser1.getAccountLevel().compareTo(one.getReportType()) == 0) {
                         vo.setListControlsButtonStatus(0);
                     }
                 }
@@ -474,7 +579,7 @@
             String targetId = "";
             Integer accountLevel = 5;
             //获取当前身份,1=党员,2=管理员
-            accountLevel = systemUserLevel.getLevel();
+            accountLevel = systemUser1.getAccountLevel();
             switch (accountLevel) {
                 case 1:
                     //市级
@@ -482,15 +587,15 @@
                     break;
                 case 2:
                     //区县级
-                    targetId = systemUserLevel.getDistrictsCode();
+                    targetId = systemUser1.getDistrictsCode();
                     break;
                 case 3:
                     //街道
-                    targetId = systemUserLevel.getStreetId().toString();
+                    targetId = systemUser1.getStreetId().toString();
                     break;
                 case 4:
                     //社区
-                    targetId = systemUserLevel.getCommunityId().toString();
+                    targetId = systemUser1.getCommunityId().toString();
                     break;
                 case 5:
                     //党员
@@ -529,7 +634,7 @@
                 }
             }*/
             //当前不是党员身份,需要是管理员才有权限
-            if (2 == identity && systemUserLevel.getLevel().compareTo(vo.getReportType()) == 0 && systemUserLevel.getLevel() != 5) {
+            if (2 == identity && systemUser1.getAccountLevel().compareTo(vo.getReportType()) == 0 && systemUser1.getAccountLevel() != 5) {
                 vo.setEvaluateButtonStatus(0);
             }
             //当前是党员身份,只有是以党员身份提交的数据才有权限
@@ -564,10 +669,11 @@
         //获取当前身份,1=党员,2=管理员
         IdentityInformation identityInformation = identityInformationService.getCurrentIdentityInformation(loginUserInfoVO);
         Integer identity = identityInformation.getIdentity();
+        ComplaintVO detail = baseMapper.getDetail(id);
+        SystemUser systemUser = identityInformation.getSystemUser();
         //上级
         if (identity == 2) {
-            SystemUserLevel systemUserLevel = identityInformation.getSystemUserLevel();
-            accountLevel = systemUserLevel.getLevel();
+            accountLevel = systemUser.getAccountLevel();
             switch (accountLevel) {
                 case 1:
                     //市级
@@ -575,15 +681,15 @@
                     break;
                 case 2:
                     //区县级
-                    targetId = systemUserLevel.getDistrictsCode();
+                    targetId = systemUser.getDistrictsCode();
                     break;
                 case 3:
                     //街道
-                    targetId = systemUserLevel.getStreetId().toString();
+                    targetId = systemUser.getStreetId().toString();
                     break;
                 case 4:
                     //社区
-                    targetId = systemUserLevel.getCommunityId().toString();
+                    targetId = systemUser.getCommunityId().toString();
                     break;
                 case 5:
                     //党员
@@ -594,11 +700,87 @@
         } else {
             //党员
             PartyMember partyMember = partyMemberService.getPartyMemberByPhone(loginUserInfoVO.getPhone());
-            targetId = partyMember.getId().toString();
+            if (partyMember != null) {
+                targetId = partyMember.getId().toString();
+            } else {
+                targetId = loginUserInfoVO.getUserId().toString();
+            }
+
         }
-        ComplaintVO detail = baseMapper.getDetail(id);
-        if (detail.getStatus().equals(0)) {
-            List<ComplaintFlow> list = complaintFlowService.lambdaQuery().eq(ComplaintFlow::getComplaintId, id).orderByAsc(ComplaintFlow::getSort).list();
+        // 更新状态 此时status是表中的状态 未做变动
+        // 如果是区级
+        if (systemUser != null) {
+            ComplaintAuditRecord one = complaintAuditRecordService.getOne(new LambdaQueryWrapper<ComplaintAuditRecord>().eq(ComplaintAuditRecord::getComplaintId, id).eq(ComplaintAuditRecord::getLatestFlag, 1).last("limit 1"));
+            if (systemUser.getAccountLevel() == 2) {
+                if(detail.getStatus()!=5) {
+                    if (detail.getStatus() != 3 && detail.getStatus() != 8 && detail.getNowLevel() == 2 && detail.getAssignStatus() == 0 && ((one != null && one.getAuditStatus() == 1) || (one != null && one.getAuditStatus() == 3) || one == null)) {
+                        detail.setStatus(-1);
+                    } else if (systemUser.getSystemRoleId() == 0) {
+                        // 查是否是当前层级处理  不是则都是正在办理
+                        if (detail.getNowLevel() != 4 && detail.getStatus() != 3 && detail.getStatus() != 8) {
+                            detail.setStatus(0);
+                        }
+                    } else if (detail.getStatus() != 3 && detail.getStatus() != 8 && detail.getFirstStatus() == 0 && detail.getNowLevel() == 2) {
+                        detail.setStatus(5);
+                    } else if (detail.getStatus() == 3 || detail.getStatus() == 8) {
+                        detail.setStatus(detail.getStatus());
+                    } else {
+                        detail.setStatus(0);
+                    }
+
+                }
+
+            }
+            if (systemUser.getAccountLevel() == 3) {
+                if(detail.getStatus()!=5) {
+                    if (detail.getStatus() != 3 && detail.getStatus() != 8 && detail.getNowLevel() == 3 && detail.getAssignStatus() == 0 && ((one != null && one.getAuditStatus() == 1) || (one != null && one.getAuditStatus() == 3) || one == null)) {
+                        detail.setStatus(-1);
+                    } else if (systemUser.getSystemRoleId() == 0) {
+                        // 查是否是当前层级处理  不是则都是正在办理
+                        if (detail.getNowLevel() != 3 && detail.getStatus() != 3 && detail.getStatus() != 8) {
+                            detail.setStatus(0);
+                        }
+                    } else if (detail.getStatus() != 3 && detail.getStatus() != 8 && detail.getFirstStatus() == 0 && detail.getNowLevel() == 3) {
+                        detail.setStatus(5);
+                    } else if (detail.getStatus() == 3 || detail.getStatus() == 8) {
+                        detail.setStatus(detail.getStatus());
+                    } else {
+                        detail.setStatus(0);
+                    }
+
+                }
+
+            }
+            if (systemUser.getAccountLevel() == 4) {
+                if(detail.getStatus()!=5){
+                    if (detail.getStatus() != 3 && detail.getStatus() != 8 &&  detail.getNowLevel() == 4 && detail.getAssignStatus() == 0 &&  ((one != null && one.getAuditStatus() == 1)||(one != null && one.getAuditStatus() == 3)  || one==null )) {
+                        detail.setStatus(-1);
+                     }else if (detail.getStatus() != 3 && detail.getStatus() != 8 && detail.getFirstStatus() == 0 && detail.getNowLevel()==4) {
+                        detail.setStatus(5);
+                    }else if(detail.getStatus()==3 || detail.getStatus()==8){
+                        detail.setStatus(detail.getStatus());
+                    }else {
+                        detail.setStatus(0);
+                    }
+                }
+
+
+            }
+        } else {
+            if (detail.getFirstStatus() == 1 && detail.getStatus() != 3 && detail.getStatus() != 8) {
+                detail.setStatus(0);
+            } else if (detail.getFirstStatus() == 0 && detail.getCreateBy().equals(loginUserInfoVO.getUserId())) {
+                detail.setStatus(5);
+            } else if (detail.getFirstStatus() == 1 && detail.getStatus() == 3) {
+                detail.setStatus(3);
+            } else if (detail.getFirstStatus() == 1 && detail.getStatus() == 8) {
+                detail.setStatus(8);
+            }
+        }
+
+
+        if (true) {
+            List<ComplaintFlow> list = complaintFlowService.lambdaQuery().eq(ComplaintFlow::getComplaintId, id).orderByDesc(ComplaintFlow::getCreateTime).orderByAsc(ComplaintFlow::getType).list();
             detail.setComplaintFlows(list);
         }
         //查询办理进度
@@ -610,9 +792,9 @@
         buttonPermission(detail, systemUserByPhone, loginUserInfoVO);
         Long reporterId = detail.getReporterId();
         Long superiorId = detail.getSuperiorId2();
-        if (!String.valueOf(reporterId).equals(targetId) && !String.valueOf(superiorId).equals(targetId) && detail.getStatus() == 5) {
-            detail.setStatus(0);
-        }
+//        if (!String.valueOf(reporterId).equals(targetId) && !String.valueOf(superiorId).equals(targetId) && detail.getStatus() == 5 && systemUser==null) {
+//            detail.setStatus(0);
+//        }
 
 
 //        if (auditButtonStatus == 1 && detail.getStatus() == 5 && !Objects.equals(detail.getAuditCreateBy(), loginUserInfoVO.getUserId())){
@@ -620,23 +802,47 @@
 //        }
 
 
-//        //已办结,显示评价按钮
-//        int count = complaintCommentService.count(new LambdaQueryWrapper<ComplaintComment>().eq(ComplaintComment::getComplaintId, detail.getId()).eq(ComplaintComment::getDelFlag, 0));
-//        if(detail.getStatus() == 3 && 0 == count){
-//            if(systemUserByPhone.isPresent()){
-//                SystemUser systemUser = systemUserByPhone.get();
-//                Integer isAdmin = systemUser.getIsAdmin();
-//                if(accountLevel.compareTo(detail.getReportType()) == 0 && ((accountLevel != 5 && 1 == isAdmin) || accountLevel == 5)){
-//                    detail.setEvaluateButtonStatus(0);
-//                }
-//            }else{
-//                if(detail.getReportType() == 5){
-//                    detail.setEvaluateButtonStatus(0);
-//                }
-//            }
-//        }
+        //已办结,显示评价按钮
+        int count = complaintCommentService.count(new LambdaQueryWrapper<ComplaintComment>().eq(ComplaintComment::getComplaintId, detail.getId()).eq(ComplaintComment::getDelFlag, 0));
+        //查询评价
+        ComplaintComment comment = complaintCommentService.lambdaQuery().eq(ComplaintComment::getComplaintId, id).last("LIMIT 1").one();
+        detail.setComplaintComment(comment);
+        if (detail.getStatus() == 3 && 0 == count) {
+                detail.setEvaluateButtonStatus(0);
+        }else {
+            detail.setEvaluateButtonStatus(1);
+        }
+
+
         return detail;
     }
+
+
+    @Override
+    public ComplaintVO detailScreen(Long id) {
+        //获取当前身份,1=党员,2=管理员
+        ComplaintVO detail = baseMapper.getDetail(id);
+        // 更新状态 此时status是表中的状态 未做变动
+        if (detail.getFirstStatus() == 1 && detail.getStatus() != 3 && detail.getStatus() != 8) {
+            detail.setStatus(0);
+        } else if (detail.getFirstStatus() == 0) {
+            detail.setStatus(5);
+        } else if (detail.getFirstStatus() == 1 && detail.getStatus() == 3) {
+            detail.setStatus(3);
+        } else if (detail.getFirstStatus() == 1 && detail.getStatus() == 8) {
+            detail.setStatus(8);
+        }
+
+        List<ComplaintFlow> list = complaintFlowService.lambdaQuery().eq(ComplaintFlow::getComplaintId, id).orderByDesc(ComplaintFlow::getCreateTime).orderByAsc(ComplaintFlow::getType).list();
+        detail.setComplaintFlows(list);
+        //查询办理进度
+        List<ComplaintProgress> list1 = complaintProgressService.lambdaQuery().eq(ComplaintProgress::getComplaintId, id)
+                .orderByAsc(ComplaintProgress::getCreateTime).list();
+        detail.setComplaintProgresses(list1);
+
+        return detail;
+    }
+
 
     /**
      * 办理进度录入
@@ -691,8 +897,7 @@
         if (identityInformationVO.getIdentity() == 2) {
             //1=党员,2=管理员
             SystemUser systemUser = identityInformationVO.getSystemUser();
-            SystemUserLevel systemUserLevel = identityInformationVO.getSystemUserLevel();
-            accountLevel = systemUserLevel.getLevel();
+            accountLevel = systemUser.getAccountLevel();
             name = systemUser.getName();
         } else if (identityInformationVO.getIdentity() == 1) {
             accountLevel = 5;
@@ -716,6 +921,16 @@
         double handlingDay = new BigDecimal(l).divide(new BigDecimal("24"), 2, RoundingMode.HALF_UP).doubleValue();
         complaint.setHandlingDay(handlingDay);
         this.updateById(complaint);
+
+        if (dto.getStatus() == 3) {
+            // 发送短信
+            Long createBy = complaint.getCreateBy();
+
+            String phone = systemUserService.getCreateByIdPhone(createBy);
+            if (StringUtils.isNotEmpty(phone)) {
+                AliSmsUtil.sendSuccessMessage(phone);
+            }
+        }
     }
 
     /**
@@ -740,15 +955,18 @@
         SystemUser adminUser = identityInformationVO.getSystemUser();
 
         Long superiorId;
+        Long lastSuperiorId;
         int reportType;
         int reporterLevel;
         Long reporterId = null;
         String departmentName = "";
         String reporter = "";
-        int nowLevel=0;
+        int nowLevel = 0;
         if (identityInformationVO.getIdentity() == 1) {
             PartyMember partyMember = partyMemberService.getPartyMemberByPhone(phone);
-            superiorId = partyMember.getCommunityId();
+            superiorId = Long.valueOf(partyMember.getStreetId());
+            lastSuperiorId = partyMember.getCommunityId();
+
             reporterId = partyMember.getId();
             reportType = 4;
             reporterLevel = 5;
@@ -769,11 +987,16 @@
             // 使用基本类型比较并补充默认分支
             if (accountLevel == ReportTypeEnum.COMMUNITY.getCode()) {
                 superiorId = Long.parseLong(adminUser.getStreetId());
+
+                lastSuperiorId = adminUser.getCommunityId();
+
                 reporterId = adminUser.getCommunityId();
                 nowLevel = 3;
 
             } else if (accountLevel == ReportTypeEnum.STREET.getCode()) {
                 superiorId = Long.parseLong(adminUser.getDistrictsCode());
+                lastSuperiorId = Long.valueOf(adminUser.getStreetId());
+
                 reporterId = Long.parseLong(adminUser.getStreetId());
                 nowLevel = 2;
             } else {
@@ -814,8 +1037,12 @@
             complaint.setStatus(0);
         }
         complaint.setSuperiorId(superiorId);
+        complaint.setLastSuperiorId(lastSuperiorId);
         complaint.setNowLevel(nowLevel);
+        complaint.setLastLevel(nowLevel + 1);
         complaint.setAssignStatus(0);
+        complaint.setNowLevelTime(new Date());
+        complaint.setNowLevelSms(0);
         updateById(complaint);
 
         // 标记最新
@@ -840,7 +1067,7 @@
         complaintAuditRecord.setComment(dto.getComment());
         complaintAuditRecord.setSort(count + 1);
         complaintAuditRecord.setDepartmentName(departmentName);
-        complaintAuditRecord.setReporterLevel(reporterLevel);
+        complaintAuditRecord.setReporterLevel(nowLevel);
         complaintAuditRecord.setReporterId(reporterId);
         complaintAuditRecord.setApplyName(reporter);
         complaintAuditRecord.setApplyPhone(phone);
@@ -868,7 +1095,7 @@
                 .eq(ComplaintAuditRecord::getComplaintId, dto.getComplaintId())
                 .eq(ComplaintAuditRecord::getAuditType, 2)
                 .eq(ComplaintAuditRecord::getLatestFlag, false)
-                .orderByDesc(ComplaintAuditRecord::getSort)
+                .orderByDesc(ComplaintAuditRecord::getSort).last("limit 1")
         );
         if (Objects.nonNull(lastRecord)) {
             // 复制上一条记录
@@ -880,6 +1107,12 @@
             newRecord.setUpdateTime(new Date());
             complaintAuditRecordService.save(newRecord);
         }
+        // 返回原来的层级
+        Complaint complaint = this.getById(dto.getComplaintId());
+        complaint.setNowLevel(complaint.getLastLevel());
+        complaint.setSuperiorId(complaint.getLastSuperiorId());
+        this.updateById(complaint);
+
     }
 
     @Override
@@ -930,7 +1163,7 @@
         complaintAuditRecord.setComplaintId(complaint.getId());
         complaintAuditRecord.setReportType(systemUser.getAccountLevel());
         Long superiorId = null;
-        int nowLevel=0;
+        int nowLevel = 0;
 
         switch (systemUser.getAccountLevel()) {
             case 1:
@@ -938,19 +1171,24 @@
                 break;
             case 2:
                 superiorId = Long.parseLong(systemUser.getStreetId());
-                nowLevel=3;
+                nowLevel = 3;
                 break;
             case 3:
                 superiorId = systemUser.getCommunityId();
-                nowLevel=4;
+                nowLevel = 4;
                 break;
             case 4:
                 superiorId = systemUser.getCommunityId();
+                nowLevel = 4;
                 break;
         }
         complaint.setSuperiorId(superiorId);
+        complaint.setLastSuperiorId(superiorId);
         complaint.setAssignStatus(0);
         complaint.setNowLevel(nowLevel);
+        complaint.setLastLevel(nowLevel);
+        complaint.setNowLevelTime(new Date());
+        complaint.setNowLevelSms(0);
         this.updateById(complaint);
 
         complaintAuditRecord.setSuperiorId(superiorId);
@@ -964,35 +1202,32 @@
         IdentityInformation identityInformation = identityInformationService.getCurrentIdentityInformation(loginUserInfoVO);
 
         SystemUser systemUser = identityInformation.getSystemUser();
-        SystemUserLevel systemUserLevel = identityInformation.getSystemUserLevel();
         if (identityInformation.getIdentity() != 2) {
             throw new ServiceException("无权审核");
         }
 
         Long superiorId = 0L;
-        switch (systemUserLevel.getLevel()) {
+        switch (systemUser.getAccountLevel()) {
             case 1:
                 superiorId = 510400L;//默认市级
                 break;
             case 2:
-                superiorId = Long.parseLong(systemUserLevel.getDistrictsCode());
+                superiorId = Long.parseLong(systemUser.getDistrictsCode());
                 break;
             case 3:
-                superiorId = Long.parseLong(systemUserLevel.getStreetId());
+                superiorId = Long.parseLong(systemUser.getStreetId());
                 break;
             case 4:
-                superiorId = systemUserLevel.getCommunityId();
+                superiorId = systemUser.getCommunityId();
                 break;
         }
-
-
 
         //查询上报审核记录
         ComplaintAuditRecord complaintAuditRecord = complaintAuditRecordService.lambdaQuery()
                 .eq(ComplaintAuditRecord::getComplaintId, complaintReporAuditDTO.getId())
                 .eq(ComplaintAuditRecord::getAuditType, 2)
                 .eq(ComplaintAuditRecord::getLatestFlag, true)
-                .eq(ComplaintAuditRecord::getReportType, systemUserLevel.getLevel())
+                .eq(ComplaintAuditRecord::getReportType, systemUser.getAccountLevel())
                 .eq(ComplaintAuditRecord::getSuperiorId, superiorId)
                 .last("LIMIT 1").one();
         if (Objects.isNull(complaintAuditRecord)) {
@@ -1001,6 +1236,12 @@
         complaintAuditRecord.setAuditorName(systemUser.getName());
         complaintAuditRecord.setAuditorPhone(systemUser.getPhone());
         complaintAuditRecord.setAuditTime(new Date());
+
+
+        if (systemUser.getSystemRoleId() > 2 || systemUser.getAccountLevel() != complaintAuditRecord.getReporterLevel()) {
+            throw new ServiceException("无权审核");
+        }
+
 
         if (complaintReporAuditDTO.getAuditResult().equals(1)) {
             complaintAuditRecord.setAuditStatus(1);
@@ -1013,18 +1254,55 @@
             complaintAuditRecord2.setReportType(complaintAuditRecord.getReporterLevel());
             complaintFlowService.createFlow(complaintAuditRecord2, 0, loginUserInfoVO.getUserId());
 
-            // 通过修改状态
+
+            // 通过修改状态  已经修改superiorId  和层级  不需要修改 superiorId
             Complaint complaint = this.getById(complaintReporAuditDTO.getId());
             complaint.setAssignPersonId(complaintReporAuditDTO.getDeptId());
             complaint.setAssignStatus(1);
-            this.updateById(complaint);
+            complaint.setFirstStatus(1);
+            complaint.setLastSuperiorId(complaint.getSuperiorId());
+            complaint.setLastLevel(complaint.getNowLevel());
+            complaint.setRemark(complaintReporAuditDTO.getRemark());
+            complaint.setNowLevelTime(new Date());
+            complaint.setNowLevelSms(0);
+            if (StringUtils.isEmpty(complaint.getProblemType())) {
+                complaint.setProblemType(complaintReporAuditDTO.getProblemType());
+            }
 
+            // 分配流转
+            ComplaintFlow complaintFlow = new ComplaintFlow();
+            complaintFlow.setComplaintId(complaintReporAuditDTO.getId());
+            complaintFlow.setLevel(complaintAuditRecord.getReporterLevel());
+            Department byId = departmentService.getById(complaintReporAuditDTO.getDeptId());
+            complaintFlow.setName(byId.getName());
+            complaintFlow.setType(1);
+            complaintFlow.setCreateTime(new Date(System.currentTimeMillis() + 1000));
+            complaintFlowService.save(complaintFlow);
+
+
+            this.updateById(complaint);
+            List<SystemUser> list = systemUserService.list(new LambdaQueryWrapper<SystemUser>().eq(SystemUser::getOneDepartmentId, complaintReporAuditDTO.getDeptId()).eq(SystemUser::getSystemRoleId, 1).eq(SystemUser::getStatus, 1));
+            if (!list.isEmpty()) {
+                List<String> phoneList = list.stream().map(SystemUser::getPhone).collect(Collectors.toList());
+                AliSmsUtil.sendAssignMessageAdmin(phoneList, complaint.getSerialNumber());
+            }
 
         } else {
             complaintAuditRecord.setRejectReason(complaintReporAuditDTO.getRejectReason());
             complaintAuditRecord.setAuditStatus(2);
             complaintAuditRecord.setAuditorId(loginUserInfoVO.getUserId());
             complaintAuditRecordService.updateById(complaintAuditRecord);
+
+            // 还原上次的状态
+            Complaint complaint = this.getById(complaintReporAuditDTO.getId());
+            complaint.setAssignPersonId(complaintReporAuditDTO.getDeptId());
+            complaint.setAssignStatus(1);
+            complaint.setSuperiorId(complaint.getLastSuperiorId());
+            complaint.setNowLevel(complaint.getLastLevel());
+            complaint.setNowLevelTime(new Date());
+            complaint.setNowLevelSms(0);
+            this.updateById(complaint);
+
         }
     }
 
@@ -1035,11 +1313,11 @@
         IdentityInformation identityInformation = identityInformationService.getCurrentIdentityInformation(loginUserInfoVO);
 
         SystemUser systemUser = identityInformation.getSystemUser();
-        SystemUserLevel systemUserLevel = identityInformation.getSystemUserLevel();
         Long superiorId;
         int reportType;
         String departmentName = "";
         String reporter = "";
+        int nowLevel = 4;
         if (identityInformation.getIdentity() == 1) {
             PartyMember partyMember = partyMemberService.getPartyMemberByPhone(loginUserInfoVO.getPhone());
             superiorId = partyMember.getCommunityId();
@@ -1050,7 +1328,7 @@
             departmentName = partyMember.getDistricts() + "-" + partyMember.getStreet() + "-" + partyMember.getCommunity();
             reporter = partyMember.getName();
         } else if (identityInformation.getIdentity() == 2) {
-            int accountLevel = systemUserLevel.getLevel(); // 改为基本类型
+            int accountLevel = systemUser.getAccountLevel(); // 改为基本类型
             if (accountLevel == 2) {
                 throw new ServiceException("区级账号,无法延期申请!");
             }
@@ -1059,13 +1337,13 @@
 
             // 使用基本类型比较并补充默认分支
             if (accountLevel == ReportTypeEnum.COMMUNITY.getCode()) {
-                superiorId = Long.parseLong(systemUserLevel.getStreetId());
+                superiorId = Long.parseLong(systemUser.getStreetId());
             } else if (accountLevel == ReportTypeEnum.STREET.getCode()) {
-                superiorId = Long.parseLong(systemUserLevel.getDistrictsCode());
+                superiorId = Long.parseLong(systemUser.getDistrictsCode());
+                nowLevel = 4;
             } else if (accountLevel == ReportTypeEnum.DISTRICT.getCode()) {
-                superiorId = 510400L; // 攀枝花市
-            } else if (accountLevel == ReportTypeEnum.PARTY.getCode()) {
-                superiorId = systemUserLevel.getCommunityId();
+                superiorId = Long.valueOf(systemUser.getDistrictsCode());
+                nowLevel = 3;// 攀枝花市
             } else {
                 // 处理未预期的账号等级
                 throw new ServiceException("未知的账号等级");
@@ -1073,22 +1351,22 @@
             //查询社区信息
             switch (accountLevel) {
                 case 2:
-                    BcRegion region = bcRegionService.getDistrictByCode(systemUserLevel.getDistrictsCode().toString());
+                    BcRegion region = bcRegionService.getDistrictByCode(systemUser.getDistrictsCode().toString());
                     if (Objects.nonNull(region)) {
                         departmentName = region.getRegionName();
                     }
                     break;
                 case 3:
-                    ComStreet street = comStreetService.getById(systemUserLevel.getStreetId().toString());
+                    ComStreet street = comStreetService.getById(systemUser.getStreetId().toString());
                     if (Objects.nonNull(street)) {
                         BcRegion district = bcRegionService.getDistrictByCode(street.getAreaCode().toString());
                         departmentName = Objects.nonNull(district) ? district.getRegionName() + "-" + street.getName() : street.getName();
                     }
                     break;
                 case 4:
-                    ComAct act = comActService.getById(systemUserLevel.getCommunityId());
+                    ComAct act = comActService.getById(systemUser.getCommunityId());
                     if (Objects.nonNull(act)) {
-                        ComStreet street2 = comStreetService.getById(systemUserLevel.getStreetId().toString());
+                        ComStreet street2 = comStreetService.getById(systemUser.getStreetId().toString());
                         BcRegion district = bcRegionService.getDistrictByCode(act.getAreaCode());
                         departmentName = Objects.nonNull(district) && Objects.nonNull(street2) ?
                                 district.getRegionName() + "-" + street2.getName() + "-" + act.getName() : act.getName();
@@ -1123,6 +1401,13 @@
         record1.setApplyName(reporter);
         record1.setApplyPhone(loginUserInfoVO.getPhone());
         complaintAuditRecordService.save(record1);
+
+        Complaint byId = this.getById(dto.getComplaintId());
+        byId.setSuperiorId(superiorId);
+        byId.setNowLevel(nowLevel);
+        this.updateById(byId);
+
+
     }
 
 
@@ -1130,20 +1415,19 @@
     public void delayAudit(ComplaintDelayAuditDTO dto, LoginUserInfoVO loginUserInfoVO) {
         IdentityInformation identityInformation = identityInformationService.getCurrentIdentityInformation(loginUserInfoVO);
         SystemUser systemUser = identityInformation.getSystemUser();
-        SystemUserLevel systemUserLevel = identityInformation.getSystemUserLevel();
         if (identityInformation.getIdentity() != 2) {
             throw new ServiceException("无权审核");
         }
 
-        int accountLevel = systemUserLevel.getLevel(); // 改为基本类型
+        int accountLevel = systemUser.getAccountLevel(); // 改为基本类型
         Long superiorId;
         // 使用基本类型比较并补充默认分支
         if (accountLevel == ReportTypeEnum.COMMUNITY.getCode()) {
-            superiorId = systemUserLevel.getCommunityId();
+            superiorId = systemUser.getCommunityId();
         } else if (accountLevel == ReportTypeEnum.STREET.getCode()) {
-            superiorId = Long.parseLong(systemUserLevel.getStreetId());
+            superiorId = Long.parseLong(systemUser.getStreetId());
         } else if (accountLevel == ReportTypeEnum.DISTRICT.getCode()) {
-            superiorId = Long.parseLong(systemUserLevel.getDistrictsCode());
+            superiorId = Long.parseLong(systemUser.getDistrictsCode());
         } else if (accountLevel == ReportTypeEnum.CITY.getCode()) {
             superiorId = 510400L;
         } else {
@@ -1233,6 +1517,36 @@
         return dispatchVOList;
     }
 
+    @Override
+    public List<DispatchVO> getAllocationList(LoginUserInfoVO loginUserInfo) {
+        IdentityInformation identityInformation = identityInformationService.getCurrentIdentityInformation(loginUserInfo);
+        List<DispatchVO> dispatchVOList = new ArrayList<>();
+        SystemUser adminUser = identityInformation.getSystemUser();
+        if (adminUser.getSystemRoleId() >2) {
+            throw new ServiceException("无权查看");
+        }
+        Integer oneDepartmentId = adminUser.getOneDepartmentId();
+        Department byId = departmentService.getById(oneDepartmentId);
+        LambdaQueryWrapper<Department> eq = new LambdaQueryWrapper<Department>().eq(Department::getTier, byId.getTier());
+        if(byId.getTier()==2){
+            eq.eq(Department::getDistrictsCode, byId.getDistrictsCode());
+        }
+        if(byId.getTier()==3){
+            eq.eq(Department::getStreetId, byId.getStreetId());
+        }
+        if(byId.getTier()==4){
+            eq.eq(Department::getCommunityId, byId.getCommunityId());
+        }
+        List<Department> list1 = departmentService.list(eq);
+        for (Department department : list1) {
+            DispatchVO dispatchVO = new DispatchVO();
+            dispatchVO.setId(department.getId().toString());
+            dispatchVO.setName(department.getName());
+            dispatchVOList.add(dispatchVO);
+        }
+        return dispatchVOList;
+    }
+
     /**
      * 获取待办诉求
      *
@@ -1298,7 +1612,44 @@
      */
     @Override
     public Page<ComplaintVO> pageList(MgtComplaintQuery query, SystemUserVo loginUserInfo) {
-        return baseMapper.pageList(new Page<>(query.getPageNum(), query.getPageSize()), query, loginUserInfo);
+        Page<ComplaintVO> complaintVOPage = new Page<>();
+        if (loginUserInfo.getAccountLevel() == 2) {
+            if (loginUserInfo.getSystemRoleId() == 1 || loginUserInfo.getSystemRoleId() == 2) {
+                complaintVOPage = baseMapper.pageList(new Page<>(query.getPageNum(), query.getPageSize()), query, loginUserInfo);
+            } else {
+                complaintVOPage = baseMapper.pageList1(new Page<>(query.getPageNum(), query.getPageSize()), query, loginUserInfo);
+            }
+        }
+        if (loginUserInfo.getAccountLevel() == 3) {
+            if (loginUserInfo.getSystemRoleId() == 1 || loginUserInfo.getSystemRoleId() == 2) {
+                // 获取这个街道所管的社区id
+                List<Long> communityIds = comActService.list(new LambdaQueryWrapper<ComAct>().eq(ComAct::getStreetId, loginUserInfo.getStreetId())).stream().map(ComAct::getCommunityId).collect(Collectors.toList());
+                complaintVOPage = baseMapper.pageList2(new Page<>(query.getPageNum(), query.getPageSize()), query, loginUserInfo, communityIds);
+            } else {
+                complaintVOPage = baseMapper.pageList1(new Page<>(query.getPageNum(), query.getPageSize()), query, loginUserInfo);
+            }
+        }
+        if (loginUserInfo.getAccountLevel() == 4) {
+            if (loginUserInfo.getSystemRoleId() == 1 || loginUserInfo.getSystemRoleId() == 2) {
+                complaintVOPage = baseMapper.pageList3(new Page<>(query.getPageNum(), query.getPageSize()), query, loginUserInfo);
+            } else {
+                complaintVOPage = baseMapper.pageList1(new Page<>(query.getPageNum(), query.getPageSize()), query, loginUserInfo);
+            }
+        }
+
+        for (ComplaintVO record : complaintVOPage.getRecords()) {
+            int count = complaintCommentService.count(new LambdaQueryWrapper<ComplaintComment>().eq(ComplaintComment::getComplaintId, record.getId()));
+            if (count > 0) {
+                record.setEvaluateButtonStatus(1);
+            } else {
+                if (record.getStatus() == 3 ) {
+                    record.setEvaluateButtonStatus(0);
+                } else {
+                    record.setEvaluateButtonStatus(1);
+                }
+            }
+        }
+        return complaintVOPage;
     }
 
     @Override
@@ -1338,7 +1689,32 @@
      */
     @Override
     public void export(MgtComplaintQuery query, SystemUserVo loginUserInfo) throws IOException {
-        List<ComplaintVO> list = baseMapper.getList(query, loginUserInfo);
+        List<ComplaintVO> list = null;
+
+        if (loginUserInfo.getAccountLevel() == 2) {
+            if (loginUserInfo.getSystemRoleId() == 1 || loginUserInfo.getSystemRoleId() == 2) {
+                list = baseMapper.pageListExport(query, loginUserInfo);
+            } else {
+                list = baseMapper.pageList1Export(query, loginUserInfo);
+            }
+        }
+        if (loginUserInfo.getAccountLevel() == 3) {
+            if (loginUserInfo.getSystemRoleId() == 1 || loginUserInfo.getSystemRoleId() == 2) {
+                // 获取这个街道所管的社区id
+                List<Long> communityIds = comActService.list(new LambdaQueryWrapper<ComAct>().eq(ComAct::getStreetId, loginUserInfo.getStreetId())).stream().map(ComAct::getCommunityId).collect(Collectors.toList());
+                list = baseMapper.pageList2Export(query, loginUserInfo, communityIds);
+            } else {
+                list = baseMapper.pageList1Export(query, loginUserInfo);
+            }
+        }
+        if (loginUserInfo.getAccountLevel() == 4) {
+            if (loginUserInfo.getSystemRoleId() == 1 || loginUserInfo.getSystemRoleId() == 2) {
+                list = baseMapper.pageList3Export(query, loginUserInfo);
+            } else {
+                list = baseMapper.pageList1Export(query, loginUserInfo);
+            }
+        }
+
         List<ComplaintExcel> complaintExcels = BeanUtil.copyToList(list, ComplaintExcel.class);
         response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");
         response.setCharacterEncoding("utf-8");
@@ -1350,6 +1726,10 @@
                 .doWrite(complaintExcels);
     }
 
+    //    ComplaintVO(reporter=何健豪, reporterId=1676144498628919300, superiorId2=510403, auditCreateBy=1892421828085837826, reporterLevel=2, reporterPhone=null, departmentName=西区-金江镇, reportTime=Tue Jun 03 15:06:01 CST 2025, comment=1111, nickname=null, phone=null, auditorName=null, auditorPhone=null, rejectReason=null, auditTime=null, complaintFlows=null, complaintProgresses=null, auditButtonStatus=null, withdrawButtonStatus=null, rate=null, complaintComment=null, listControlsButtonStatus=null, evaluateButtonStatus=0, voiceFileList=null, progressCount=null, assignmentCount=null, reportCount=null, remindStatus=0, remindTime=null, reportStr=自办, deptName=aa)
+//    ComplaintVO(reporter=null, reporterId=null, superiorId2=null, auditCreateBy=null, reporterLevel=null, reporterPhone=null, departmentName=null, reportTime=null, comment=null, nickname=null, phone=null, auditorName=null, auditorPhone=null, rejectReason=null, auditTime=null, complaintFlows=null, complaintProgresses=null, auditButtonStatus=null, withdrawButtonStatus=null, rate=null, complaintComment=null, listControlsButtonStatus=null, evaluateButtonStatus=0, voiceFileList=null, progressCount=null, assignmentCount=null, reportCount=null, remindStatus=0, remindTime=null, reportStr=自办, deptName=aa)
+//    ComplaintVO(reporter=刘, reporterId=1552661132500668416, superiorId2=510403, auditCreateBy=1892403820151992322, reporterLevel=2, reporterPhone=null, departmentName=西区-格里坪镇, reportTime=Fri Jun 27 10:04:18 CST 2025, comment=null, nickname=null, phone=null, auditorName=null, auditorPhone=null, rejectReason=null, auditTime=null, complaintFlows=null, complaintProgresses=null, auditButtonStatus=null, withdrawButtonStatus=null, rate=null, complaintComment=null, listControlsButtonStatus=null, evaluateButtonStatus=0, voiceFileList=null, progressCount=null, assignmentCount=null, reportCount=null, remindStatus=0, remindTime=null, reportStr=自办, deptName=null)
+//    ComplaintVO(reporter=null, reporterId=null, superiorId2=null, auditCreateBy=null, reporterLevel=null, reporterPhone=null, departmentName=null, reportTime=null, comment=null, nickname=null, phone=null, auditorName=null, auditorPhone=null, rejectReason=null, auditTime=null, complaintFlows=null, complaintProgresses=null, auditButtonStatus=null, withdrawButtonStatus=null, rate=null, complaintComment=null, listControlsButtonStatus=null, evaluateButtonStatus=0, voiceFileList=null, progressCount=null, assignmentCount=null, reportCount=null, remindStatus=0, remindTime=null, reportStr=自办, deptName=aa)
     @Override
     public String downloadFile(Long id, Integer type, SystemUserVo loginUserInfo) throws IOException {
         Complaint complaint = baseMapper.getDetailBg(id);
@@ -1521,7 +1901,7 @@
     }
 
     @Override
-    public AnalyticStatisticsOneVo analyticStatisticsOne(AnalyticStatisticsQuery query, List<Complaint> complaints, SimpleDateFormat simpleDateFormat) {
+    public AnalyticStatisticsOneVo analyticStatisticsOne(AnalyticStatisticsQuery query, List<Complaint> complaints, SimpleDateFormat simpleDateFormat, Integer level) {
         String nowYearMonth;
         String lastYearMonth;
         int value = LocalDate.now().getMonth().getValue();
@@ -1543,18 +1923,18 @@
         if (CollUtil.isEmpty(ids)) {
             ids.add(0, -1L);
         }
-        complaints = this.baseMapper.getStatusForList(ids);
+        complaints = this.baseMapper.getStatusForList(ids, level);
 
         AnalyticStatisticsOneVo vo = new AnalyticStatisticsOneVo();
 
         // 诉求单量总计
         vo.setAllTotal(complaints.size());
         // 诉求单量本月
-        int thisMonthTotal = (int) complaints.stream().filter(e -> simpleDateFormat.format(e.getCreateTime()).contains(nowYearMonth)).count();
+        int thisMonthTotal = (int) complaints.stream().filter(e -> simpleDateFormat.format(e.getTime()).contains(nowYearMonth)).count();
         vo.setThisMonthTotal(thisMonthTotal);
 
         // 诉求单量同比上月
-        int lastMonthTotal = (int) complaints.stream().filter(e -> simpleDateFormat.format(e.getCreateTime()).contains(lastYearMonth)).count();
+        int lastMonthTotal = (int) complaints.stream().filter(e -> simpleDateFormat.format(e.getTime()).contains(lastYearMonth)).count();
         vo.setLastMonthCompareTotal(thisMonthTotal - lastMonthTotal);
 
         // 正在办理
@@ -1578,11 +1958,11 @@
         vo.setOvertimeTransactTotal(overtimeComplaints.size());
 
         // 超时办理本月
-        int thisMonthOvertimeTransactTotal = (int) overtimeComplaints.stream().filter(e -> simpleDateFormat.format(e.getCreateTime()).contains(nowYearMonth)).count();
+        int thisMonthOvertimeTransactTotal = (int) overtimeComplaints.stream().filter(e -> simpleDateFormat.format(e.getTime()).contains(nowYearMonth)).count();
         vo.setThisMonthOvertimeTransactTotal(thisMonthOvertimeTransactTotal);
 
         // 超时办理同比上月
-        int lastMonthOvertimeTransactTotal = (int) overtimeComplaints.stream().filter(e -> simpleDateFormat.format(e.getCreateTime()).contains(lastYearMonth)).count();
+        int lastMonthOvertimeTransactTotal = (int) overtimeComplaints.stream().filter(e -> simpleDateFormat.format(e.getTime()).contains(lastYearMonth)).count();
         vo.setLastMonthOvertimeTransactCompareTotal(thisMonthOvertimeTransactTotal - lastMonthOvertimeTransactTotal);
 
         // 平均处理时长
@@ -1591,20 +1971,20 @@
             averageDay = BigDecimal.valueOf(averageDay).setScale(2, RoundingMode.HALF_UP).doubleValue();
             vo.setAverageTime(averageDay);
 
-            List<Complaint> thisMonthAverageTimeComplaints = complaints.stream().filter(e -> simpleDateFormat.format(e.getCreateTime()).contains(nowYearMonth)).collect(Collectors.toList());
+            List<Complaint> thisMonthAverageTimeComplaints = complaints.stream().filter(e -> simpleDateFormat.format(e.getTime()).contains(nowYearMonth)).collect(Collectors.toList());
             if (thisMonthAverageTimeComplaints.size() > 0) {
                 double thisMonthAverageTime = thisMonthAverageTimeComplaints.stream().mapToDouble(v -> v.getHandlingDay() == null ? 0 : v.getHandlingDay()).average().getAsDouble();
                 thisMonthAverageTime = BigDecimal.valueOf(thisMonthAverageTime).setScale(2, RoundingMode.HALF_UP).doubleValue();
                 vo.setThisMonthAverageTime(thisMonthAverageTime);
             }
-            List<Complaint> lastMonthAverageTimeComplaints = complaints.stream().filter(e -> simpleDateFormat.format(e.getCreateTime()).contains(lastYearMonth)).collect(Collectors.toList());
+            List<Complaint> lastMonthAverageTimeComplaints = complaints.stream().filter(e -> simpleDateFormat.format(e.getTime()).contains(lastYearMonth)).collect(Collectors.toList());
             if (lastMonthAverageTimeComplaints.size() > 0) {
                 double lastMonthAverageTime = lastMonthAverageTimeComplaints.stream().mapToDouble(v -> v.getHandlingDay() == null ? 0 : v.getHandlingDay()).average().getAsDouble();
                 BigDecimal lastMonthAverageTime1 = BigDecimal.valueOf(lastMonthAverageTime).setScale(2, RoundingMode.HALF_UP);
 
-                vo.setLastMonthCompareAverageTime( new BigDecimal(vo.getThisMonthAverageTime()).subtract(lastMonthAverageTime1).setScale(2,RoundingMode.HALF_UP).doubleValue());
-            }else {
-                vo.setLastMonthCompareAverageTime( new BigDecimal(vo.getThisMonthAverageTime()).setScale(2,RoundingMode.HALF_UP).doubleValue());
+                vo.setLastMonthCompareAverageTime(new BigDecimal(vo.getThisMonthAverageTime()).subtract(lastMonthAverageTime1).setScale(2, RoundingMode.HALF_UP).doubleValue());
+            } else {
+                vo.setLastMonthCompareAverageTime(new BigDecimal(vo.getThisMonthAverageTime()).setScale(2, RoundingMode.HALF_UP).doubleValue());
 
             }
 
@@ -1617,7 +1997,7 @@
             BigDecimal multiply = BigDecimal.valueOf(count).divide(new BigDecimal(size), 2, BigDecimal.ROUND_HALF_UP).multiply(new BigDecimal("100"));
             vo.setSatisfactionRate(multiply.doubleValue());
 
-            List<Complaint> nowMonth = commentRateComplaints.stream().filter(e -> simpleDateFormat.format(e.getCreateTime()).contains(nowYearMonth)).collect(Collectors.toList());
+            List<Complaint> nowMonth = commentRateComplaints.stream().filter(e -> simpleDateFormat.format(e.getTime()).contains(nowYearMonth)).collect(Collectors.toList());
             // 当月满意
             long count1 = nowMonth.stream().filter(e -> e.getCommentRate() > 1).count();
             // 当月的评价数
@@ -1627,7 +2007,7 @@
                 vo.setThisMonthSatisfactionRate(multiply1.doubleValue());
             }
 
-            List<Complaint> lastMonth = commentRateComplaints.stream().filter(e -> simpleDateFormat.format(e.getCreateTime()).contains(lastYearMonth)).collect(Collectors.toList());
+            List<Complaint> lastMonth = commentRateComplaints.stream().filter(e -> simpleDateFormat.format(e.getTime()).contains(lastYearMonth)).collect(Collectors.toList());
             // 当月满意
             long count2 = lastMonth.stream().filter(e -> e.getCommentRate() > 1).count();
             // 当月的评价数
@@ -1635,7 +2015,7 @@
             if (lastMonthSize > 0) {
                 BigDecimal multiply2 = BigDecimal.valueOf(count2).divide(new BigDecimal(lastMonthSize), 2, BigDecimal.ROUND_HALF_UP).multiply(new BigDecimal("100"));
                 vo.setLastMonthCompareSatisfactionRate(vo.getThisMonthSatisfactionRate() - multiply2.doubleValue());
-            }else {
+            } else {
                 vo.setLastMonthCompareSatisfactionRate(vo.getThisMonthSatisfactionRate());
             }
         }
@@ -1644,9 +2024,11 @@
 
 
     public static void main(String[] args) {
+        LocalDate localDate = LocalDate.now().plusDays(2);
+
         String time = "2022-02-02 - 2023-02-02";
         String[] split = time.split(" - ");
-        System.out.println(split[0]);
+        System.out.println(localDate.toString());
     }
 
     @Override
@@ -1657,7 +2039,7 @@
                 String[] split = time.split(" - ");
                 Date parse = simpleDateFormat.parse(split[0] + " 00:00:00");
                 Date parse1 = simpleDateFormat.parse(split[1] + " 23:59:59");
-                complaints = complaints.stream().filter(e -> e.getCreateTime().getTime() <= parse1.getTime() && e.getCreateTime().getTime() >= parse.getTime()).collect(Collectors.toList());
+                complaints = complaints.stream().filter(e -> e.getTime().getTime() <= parse1.getTime() && e.getTime().getTime() >= parse.getTime()).collect(Collectors.toList());
                 int day = DateUtils.getDay(parse, parse1);
 
                 if (day > 30) {
@@ -1667,7 +2049,7 @@
                 for (int i = 0; i <= day; i++) {
                     AnalyticStatisticsTwoVo analyticStatisticsTwoVo = new AnalyticStatisticsTwoVo();
                     if (i == 0) {
-                        List<Complaint> collect = complaints.stream().filter(e -> simpleDateFormat.format(e.getCreateTime()).contains(split[0])).collect(Collectors.toList());
+                        List<Complaint> collect = complaints.stream().filter(e -> simpleDateFormat.format(e.getTime()).contains(split[0])).collect(Collectors.toList());
                         analyticStatisticsTwoVo.setTime(split[0]);
                         analyticStatisticsTwoVo.setAllTotal(collect.size());
                         int count = (int) collect.stream().filter(e -> e.getStatus() == 3).count();
@@ -1675,7 +2057,7 @@
                         list.add(analyticStatisticsTwoVo);
                     } else {
                         String nextDay = DateUtils.getNextDay(parse, i);
-                        List<Complaint> collect = complaints.stream().filter(e -> simpleDateFormat.format(e.getCreateTime()).contains(nextDay)).collect(Collectors.toList());
+                        List<Complaint> collect = complaints.stream().filter(e -> simpleDateFormat.format(e.getTime()).contains(nextDay)).collect(Collectors.toList());
                         analyticStatisticsTwoVo.setTime(nextDay);
                         analyticStatisticsTwoVo.setAllTotal(collect.size());
                         int count = (int) collect.stream().filter(e -> e.getStatus() == 3).count();
@@ -1688,12 +2070,12 @@
                 time = DateUtils.getBeforeDay(6) + " 00:00:00";
                 Date parse = simpleDateFormat.parse(time);
                 // 近7天数据
-                complaints = complaints.stream().filter(e -> e.getCreateTime().getTime() <= new Date().getTime() && e.getCreateTime().getTime() >= parse.getTime()).collect(Collectors.toList());
+                complaints = complaints.stream().filter(e -> e.getTime().getTime() <= new Date().getTime() && e.getTime().getTime() >= parse.getTime()).collect(Collectors.toList());
 
                 for (int i = 6; i >= 0; i--) {
                     // 获取前7天的时间
                     String day = DateUtils.getBeforeDay(i);
-                    List<Complaint> complaintList = complaints.stream().filter(e -> simpleDateFormat.format(e.getCreateTime()).contains(day)).collect(Collectors.toList());
+                    List<Complaint> complaintList = complaints.stream().filter(e -> simpleDateFormat.format(e.getTime()).contains(day)).collect(Collectors.toList());
                     AnalyticStatisticsTwoVo analyticStatisticsTwoVo = new AnalyticStatisticsTwoVo();
                     analyticStatisticsTwoVo.setTime(day);
                     analyticStatisticsTwoVo.setAllTotal(complaintList.size());
@@ -1711,7 +2093,7 @@
 
     @Override
     public List<AnalyticStatisticsThreeVo> analyticStatisticsThree(Integer rank, List<Complaint> complaints) {
-        Map<String, List<Complaint>> groupedByProblemType = complaints.stream()
+        Map<String, List<Complaint>> groupedByProblemType = complaints.stream().filter(e->e.getProblemType()!=null)
                 .collect(Collectors.groupingBy(Complaint::getProblemType));
         List<AnalyticStatisticsThreeVo> analyticStatisticsThreeVos = groupedByProblemType.entrySet().stream()
                 .map(entry -> {
@@ -1747,10 +2129,10 @@
         long count3 = complaints.stream().filter(e -> e.getCommentRate() != null && e.getCommentRate() == 3).count();
         vo.setGreatSatisfactionNum((int) count3);
         if (complaints.size() > 0) {
-            vo.setDissatisfactionRate(BigDecimal.valueOf(count).divide(BigDecimal.valueOf(complaints.size()),4,RoundingMode.HALF_UP).multiply(new BigDecimal("100")).setScale(2,RoundingMode.HALF_UP).doubleValue());
-            vo.setGeneralSatisfactionRate(BigDecimal.valueOf(count1).divide(BigDecimal.valueOf(complaints.size()),4,RoundingMode.HALF_UP).multiply(new BigDecimal("100")).setScale(2,RoundingMode.HALF_UP).doubleValue());
-            vo.setSatisfactionRate(BigDecimal.valueOf(count2).divide(BigDecimal.valueOf(complaints.size()),4,RoundingMode.HALF_UP).multiply(new BigDecimal("100")).setScale(2,RoundingMode.HALF_UP).doubleValue());
-            vo.setGreatSatisfactionRate(BigDecimal.valueOf(count3).divide(BigDecimal.valueOf(complaints.size()),4,RoundingMode.HALF_UP).multiply(new BigDecimal("100")).setScale(2,RoundingMode.HALF_UP).doubleValue());
+            vo.setDissatisfactionRate(BigDecimal.valueOf(count).divide(BigDecimal.valueOf(complaints.size()), 4, RoundingMode.HALF_UP).multiply(new BigDecimal("100")).setScale(2, RoundingMode.HALF_UP).doubleValue());
+            vo.setGeneralSatisfactionRate(BigDecimal.valueOf(count1).divide(BigDecimal.valueOf(complaints.size()), 4, RoundingMode.HALF_UP).multiply(new BigDecimal("100")).setScale(2, RoundingMode.HALF_UP).doubleValue());
+            vo.setSatisfactionRate(BigDecimal.valueOf(count2).divide(BigDecimal.valueOf(complaints.size()), 4, RoundingMode.HALF_UP).multiply(new BigDecimal("100")).setScale(2, RoundingMode.HALF_UP).doubleValue());
+            vo.setGreatSatisfactionRate(BigDecimal.valueOf(count3).divide(BigDecimal.valueOf(complaints.size()), 4, RoundingMode.HALF_UP).multiply(new BigDecimal("100")).setScale(2, RoundingMode.HALF_UP).doubleValue());
         }
         return vo;
     }
@@ -1758,58 +2140,27 @@
     @Override
     public List<Complaint> queryCompliantList(AppStaticsQuery query, LoginUserInfoVO loginUserInfo) {
         IdentityInformation identityInformation = identityInformationService.getIdentityInformation(loginUserInfo);
-        Integer identity = identityInformation.getIdentity();
-        PartyMember partyMember = identityInformation.getPartyMember();
-        SystemUserLevel systemUserLevel = identityInformation.getSystemUserLevel();
-        Long targetId = null;
-        Integer accountLevel = 5;
-        //党员,查询该党员
-        if (identity.equals(1)) {
-            targetId = partyMember.getId();
-        } else if (identity.equals(2)) {
-            //上级
-            if (Objects.nonNull(query.getTier()) && query.getTier().equals(-1)) {
-                accountLevel = systemUserLevel.getLevel();
-                switch (systemUserLevel.getLevel()) {
-                    case 1:
-                        //市级
-                        targetId = 510400L;
-                        break;
-                    case 2:
-                        //区县级
-                        targetId = Long.valueOf(systemUserLevel.getDistrictsCode());
-                        break;
-                    case 3:
-                        //街道
-                        targetId = Long.valueOf(systemUserLevel.getStreetId());
-                        break;
-                    case 4:
-                        //社区
-                        targetId = systemUserLevel.getCommunityId();
-                        break;
-                }
-            } else {
-                targetId = Long.valueOf(query.getAreaId());
-                accountLevel = query.getTier();
-            }
+        SystemUser systemUserLevel = identityInformation.getSystemUser();
+        if (systemUserLevel.getSystemRoleId() == 1 || systemUserLevel.getSystemRoleId() == 2) {
+            return baseMapper.queryCompliantList(systemUserLevel.getAccountLevel(), systemUserLevel.getSystemRoleId(), query);
         }
-        return baseMapper.queryCompliantList(targetId, accountLevel, loginUserInfo, query);
+        return null;
     }
 
 
     @Override
-    public Page<SysUserVO> getDeptUserList(LoginUserInfoVO loginUserInfo,BasePage page) {
+    public Page<SysUserVO> getDeptUserList(LoginUserInfoVO loginUserInfo, BasePage page) {
         IdentityInformation currentIdentityInformation = identityInformationService.getCurrentIdentityInformation(loginUserInfo);
         if (currentIdentityInformation.getIdentity().equals(2)) {
             SystemUser systemUser = currentIdentityInformation.getSystemUser();
-            if(systemUser.getIsDeptAdmin()==0){
+            if (systemUser.getSystemRoleId() != 1) {
                 throw new ServiceException("你没有分配权限");
             }
 
             Page<SysUserVO> sysUserVOPage = new Page<>();
             ArrayList<SysUserVO> sysUserVOS = new ArrayList<>();
 
-            Page<SystemUser> page1 = systemUserService.page(new Page<>(page.getPageNum(), page.getPageSize()), new LambdaQueryWrapper<SystemUser>().eq(SystemUser::getOneDepartmentId, systemUser.getOneDepartmentId()).ne(SystemUser::getId,systemUser.getId()).ne(SystemUser::getStatus, 3));
+            Page<SystemUser> page1 = systemUserService.page(new Page<>(page.getPageNum(), page.getPageSize()), new LambdaQueryWrapper<SystemUser>().eq(SystemUser::getOneDepartmentId, systemUser.getOneDepartmentId()).ne(SystemUser::getId, systemUser.getId()).ne(SystemUser::getStatus, 3));
             for (SystemUser record : page1.getRecords()) {
                 SysUserVO sysUserVO = new SysUserVO();
                 sysUserVO.setId(record.getId());
@@ -1817,29 +2168,210 @@
                 sysUserVOS.add(sysUserVO);
             }
             sysUserVOPage.setRecords(sysUserVOS);
-            BeanUtils.copyProperties(page1,sysUserVOPage);
+            BeanUtils.copyProperties(page1, sysUserVOPage);
             return sysUserVOPage;
-        }else {
+        } else {
             throw new ServiceException("你没有分配权限");
         }
     }
 
 
     @Override
-    public void assignComplain(LoginUserInfoVO loginUserInfo, Long complainId, Integer userId) {
+    public void assignComplain(LoginUserInfoVO loginUserInfo, Long complainId, Integer userId, String remark, String problemType) {
         IdentityInformation currentIdentityInformation = identityInformationService.getCurrentIdentityInformation(loginUserInfo);
         if (currentIdentityInformation.getIdentity().equals(2)) {
             SystemUser systemUser = currentIdentityInformation.getSystemUser();
             Complaint complaint = baseMapper.selectById(complainId);
+            if (StringUtils.isEmpty(complaint.getProblemType())) {
+                complaint.setProblemType(problemType);
+            }
+            if (systemUser.getSystemRoleId() != 1 || !complaint.getNowLevel().equals(systemUser.getAccountLevel())) {
+                throw new ServiceException("你没有分配权限");
+            }
+
             // 已分配状态
             complaint.setAssignPersonId(userId);
             complaint.setFirstStatus(1);
             complaint.setAssignStatus(1);
-        }else {
+            complaint.setRemark(remark);
+            complaint.setNowLevelTime(new Date());
+            complaint.setNowLevelSms(0);
+            baseMapper.updateById(complaint);
+
+            Department department = departmentService.getById(userId);
+            ComplaintFlow complaintFlow = new ComplaintFlow();
+            complaintFlow.setComplaintId(complainId);
+            complaintFlow.setLevel(complaint.getNowLevel());
+            complaintFlow.setName(department.getName());
+            complaintFlow.setCreateTime(new Date());
+            complaintFlow.setType(1);
+            complaintFlowService.save(complaintFlow);
+
+
+            List<SystemUser> list = systemUserService.list(new LambdaQueryWrapper<SystemUser>().eq(SystemUser::getOneDepartmentId, userId).eq(SystemUser::getSystemRoleId, 1).eq(SystemUser::getStatus, 1));
+            if (!list.isEmpty()) {
+                List<String> phoneList = list.stream().map(SystemUser::getPhone).collect(Collectors.toList());
+                AliSmsUtil.sendAssignMessageAdmin(phoneList, complaint.getSerialNumber());
+            }
+
+        } else {
             throw new ServiceException("你没有分配权限");
         }
 
     }
 
+
+    @Override
+    public Page<ComplaintVO> pageScreenList(ScreenComplaintQuery query) {
+
+        // 已分派了的
+        Page<ComplaintVO> page = new Page<>(query.getPageNum(), query.getPageSize());
+
+        page = baseMapper.pageScreenList(page, query);
+
+        page.getRecords().forEach(detail -> {
+            if (detail.getFirstStatus() == 1 && detail.getStatus() != 3 && detail.getStatus() != 8) {
+                detail.setStatus(0);
+            } else if (detail.getFirstStatus() == 0) {
+                detail.setStatus(5);
+            } else if (detail.getFirstStatus() == 1 && detail.getStatus() == 3) {
+                detail.setStatus(3);
+            } else if (detail.getFirstStatus() == 1 && detail.getStatus() == 8) {
+                detail.setStatus(8);
+            }
+        });
+        return page;
+    }
+
+    @Override
+    public Page<String> getHouseAddress(GetHouseAddressQuery query) {
+        Page<String> page = new Page<>(query.getPageNum(), query.getPageSize());
+        return this.baseMapper.getHouseAddress(page, query.getAddress());
+    }
+
+
+    @Override
+    public void saveComplaintAdmin(Complaint complaint, SystemUserVo systemUser) {
+        // 获取当前日期(年月日)
+        String datePrefix = new SimpleDateFormat("yyyyMMdd").format(new Date());
+
+        // 查询当前日期的最大流水号
+        Complaint lastComplaint = getOne(new LambdaQueryWrapper<Complaint>()
+                .likeRight(Complaint::getSerialNumber, datePrefix) // 查询以当前日期开头的流水号
+                .orderByDesc(Complaint::getSerialNumber)
+                .last("limit 1"));
+
+        String serialNumber;
+        if (isNull(lastComplaint)) {
+            // 如果当天没有记录,从 0001 开始
+            serialNumber = datePrefix + "0001";
+        } else {
+            // 获取当前日期的最大流水号,并递增
+            String lastSerialNumber = lastComplaint.getSerialNumber();
+            int num = Integer.parseInt(lastSerialNumber.substring(lastSerialNumber.length() - 4)); // 提取后4位数字
+            serialNumber = datePrefix + String.format("%04d", num + 1); // 递增并格式化为4位
+        }
+
+        // 设置流水号
+        complaint.setSerialNumber(serialNumber);
+        Integer accountLevel = 4;
+        //获取当前身份
+        //1=党员,2=管理员
+        accountLevel = systemUser.getAccountLevel();
+        switch (accountLevel) {
+            case 2:
+                //区县级
+                complaint.setCityCode(510400);
+                complaint.setDistrictsCode(Integer.valueOf(systemUser.getDistrictsCode()));
+                complaint.setReportUserName(systemUser.getName());
+                complaint.setReportUserPhone(systemUser.getPhone());
+
+
+                complaint.setSuperiorId(Long.valueOf(systemUser.getDistrictsCode()));
+                break;
+            case 3:
+                //街道
+                complaint.setCityCode(510400);
+                complaint.setDistrictsCode(Integer.valueOf(systemUser.getDistrictsCode()));
+                complaint.setStreetId(Long.valueOf(systemUser.getStreetId()));
+                complaint.setReportUserName(systemUser.getName());
+                complaint.setReportUserPhone(systemUser.getPhone());
+
+                complaint.setSuperiorId(Long.valueOf(systemUser.getStreetId()));
+                break;
+            case 4:
+                //社区
+                complaint.setCityCode(510400);
+                complaint.setDistrictsCode(Integer.valueOf(systemUser.getDistrictsCode()));
+                complaint.setStreetId(Long.valueOf(systemUser.getStreetId()));
+                complaint.setCommunityId(systemUser.getCommunityId());
+                complaint.setReportUserName(systemUser.getName());
+                complaint.setReportUserPhone(systemUser.getPhone());
+
+                complaint.setSuperiorId(systemUser.getCommunityId());
+                break;
+        }
+        complaint.setCreateBy(Long.valueOf(systemUser.getId()));
+        complaint.setReportType(accountLevel);
+        complaint.setNowLevel(accountLevel);
+        complaint.setLastLevel(accountLevel);
+        complaint.setLastSuperiorId(complaint.getSuperiorId());
+
+        // 设置其他字段
+        complaint.setStatus(ProcessStatusEnum.PROCESSING.getCode());
+        complaint.setCreateTime(new Date(System.currentTimeMillis()));
+        complaint.setUpdateTime(new Date(System.currentTimeMillis()));
+        //查询系统配置诉求处理期限,设置截止日期
+        WorkOrderItemConfig config = workOrderItemConfigService.lambdaQuery().orderByDesc(WorkOrderItemConfig::getId).last("LIMIT 1").one();
+        if (Objects.isNull(config)) {
+            throw new ServiceException("工单事项未配置,请联系管理员");
+        }
+        complaint.setNowLevelTime(new Date());
+        complaint.setNowLevelSms(0);
+        // 保存诉求记录
+        save(complaint);
+    }
+
+    @Override
+    public void setProblemType(LoginUserInfoVO loginUserInfo, SetProblemTypeDto dto) {
+        IdentityInformation currentIdentityInformation = identityInformationService.getCurrentIdentityInformation(loginUserInfo);
+        if (currentIdentityInformation.getSystemUser().getSystemRoleId() != 1) {
+            throw new ServiceException("无权限");
+        }
+        Complaint complaint = getById(dto.getComplaintId());
+        complaint.setProblemType(dto.getProblemType());
+        updateById(complaint);
+    }
+
+    @Override
+    public Map<String, Integer> getComplaintTip(LoginUserInfoVO loginUserInfo) {
+        HashMap<String, Integer> map = new HashMap<>();
+        IdentityInformation currentIdentityInformation = identityInformationService.getCurrentIdentityInformation(loginUserInfo);
+        SystemUser systemUser = currentIdentityInformation.getSystemUser();
+        if (systemUser.getSystemRoleId() == 1) {
+            Integer accountLevel =systemUser.getAccountLevel();
+            String code = null;
+            switch (accountLevel) {
+                case 2:
+                    code ="510403";
+                    break;
+                case 3:
+                    code =systemUser.getStreetId();
+                    break;
+                case 4:
+                    code =systemUser.getCommunityId().toString();
+                    break;
+                default:
+                    throw new ServiceException("无此权限");
+            }
+            // 待分配
+            map.put("waitAssign", this.baseMapper.getWaitAssign(accountLevel,code));
+            // 待处理
+            int count = this.count(new LambdaQueryWrapper<Complaint>().eq(Complaint::getAssignPersonId, systemUser.getOneDepartmentId()).notIn(Complaint::getStatus, 3, 8));
+            map.put("waitProcess", count);
+        }
+        return map;
+    }
+
 }
 

--
Gitblit v1.7.1