From d4d5205a7d954117a9e70426534b7b1d95f0edd5 Mon Sep 17 00:00:00 2001 From: jinpengyong <jpy123456> Date: Thu, 17 Feb 2022 14:03:21 +0800 Subject: [PATCH] 督办单查询根据地区显示 --- screen-api/src/main/java/com/moral/api/service/impl/SupervisionServiceImpl.java | 76 +++++++++++++++++++++++--------------- 1 files changed, 46 insertions(+), 30 deletions(-) diff --git a/screen-api/src/main/java/com/moral/api/service/impl/SupervisionServiceImpl.java b/screen-api/src/main/java/com/moral/api/service/impl/SupervisionServiceImpl.java index 9f5cd2a..92d2d94 100644 --- a/screen-api/src/main/java/com/moral/api/service/impl/SupervisionServiceImpl.java +++ b/screen-api/src/main/java/com/moral/api/service/impl/SupervisionServiceImpl.java @@ -1,18 +1,18 @@ package com.moral.api.service.impl; -import com.alibaba.fastjson.JSONObject; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.extension.plugins.pagination.Page; +import com.moral.api.entity.MonitorPoint; +import com.moral.api.entity.Organization; import com.moral.api.entity.Supervision; -import com.moral.api.entity.SysArea; import com.moral.api.mapper.SupervisionMapper; +import com.moral.api.service.MonitorPointService; +import com.moral.api.service.OrganizationService; import com.moral.api.service.SupervisionService; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; -import com.moral.api.service.SysAreaService; import com.moral.constant.Constants; import com.moral.constant.ResponseCodeEnum; -import com.moral.util.DateUtils; import com.moral.util.FileUtils; import lombok.extern.slf4j.Slf4j; @@ -49,7 +49,10 @@ private SupervisionMapper supervisionMapper; @Autowired - private SysAreaService sysAreaService; + private OrganizationService organizationService; + + @Autowired + private MonitorPointService monitorPointService; @Override @Transactional @@ -97,52 +100,65 @@ @Override public Map<String, Object> selectSupervisions(Map<String, Object> params) { //������������������ - int cityCode = Integer.parseInt(params.get("cityCode").toString()); int page = Integer.parseInt(params.get("page").toString()); int size = Integer.parseInt(params.get("size").toString()); Object start = params.get("start"); Object end = params.get("end"); - QueryWrapper<Supervision> queryWrapper = new QueryWrapper<>(); - queryWrapper.eq("city_code", cityCode) - .eq("is_delete", Constants.NOT_DELETE); + + QueryWrapper<Supervision> supervisionQueryWrapper = new QueryWrapper<>(); + supervisionQueryWrapper.eq("is_delete", Constants.NOT_DELETE); + if (params.get("organizationId") != null) { + Integer orgId = Integer.parseInt(params.get("organizationId").toString()); + //������������������������������ + List<Organization> organizations = organizationService.getChildrenOrganizationsById(orgId); + List<Integer> orgIds = organizations.stream().map(Organization::getId).collect(Collectors.toList()); + orgIds.add(orgId); + QueryWrapper<MonitorPoint> queryWrapper = new QueryWrapper<>(); + queryWrapper.select("city_code") + .eq("is_delete", Constants.NOT_DELETE) + .in("organization_id", orgIds); + + //������������id������������������������code + List<Object> cityCodes = monitorPointService.listObjs(queryWrapper); + + cityCodes = cityCodes.stream() + .distinct() + .collect(Collectors.toList()); + + supervisionQueryWrapper.in("CONCAT(LEFT(city_code,4),'00')", cityCodes); + } else { + String cityCode = params.get("cityCode").toString(); + //��������������������������������������������������������������������������������������� + if (cityCode.endsWith("00")) { + supervisionQueryWrapper.eq("CONCAT(LEFT(city_code,4),'00')", cityCode); + } else { + supervisionQueryWrapper.eq("city_code", cityCode); + } + } + + if (start != null) { - queryWrapper.ge("time", start); + supervisionQueryWrapper.ge("time", start); } if (start != null) { - queryWrapper.le("time", end); + supervisionQueryWrapper.le("time", end); } //���time������ - queryWrapper.orderByDesc("time"); + supervisionQueryWrapper.orderByDesc("time"); //������ Page<Supervision> supervisionPage = new Page<>(page, size); - supervisionMapper.selectPage(supervisionPage, queryWrapper); + supervisionMapper.selectPage(supervisionPage, supervisionQueryWrapper); List<Supervision> supervisions = supervisionPage.getRecords(); - - //������������������ - List<Map<String, Object>> item = new ArrayList<>(); - QueryWrapper<SysArea> sysAreaQueryWrapper = new QueryWrapper<>(); - sysAreaQueryWrapper.eq("area_code", cityCode); - SysArea one = sysAreaService.getOne(sysAreaQueryWrapper); - String cityName = one.getAreaName(); - for (Supervision supervision : supervisions) { - Map<String, Object> map = JSONObject.parseObject(JSONObject.toJSONString(supervision), Map.class); - map.remove("isDelete"); - map.remove("createTime"); - map.remove("updateTime"); - map.put("cityName", cityName); - map.put("time", DateUtils.getLongToStr((Long) map.remove("time"), DateUtils.yyyy_MM_dd_EN)); - item.add(map); - } Map<String, Object> result = new LinkedHashMap<>(); result.put("total", supervisionPage.getTotal()); result.put("totalPage", supervisionPage.getPages()); result.put("current", supervisionPage.getCurrent()); result.put("pageSize", supervisionPage.getSize()); - result.put("item", item); + result.put("item", supervisions); return result; } -- Gitblit v1.8.0