Search in sources :

Example 1 with Area

use of de.symeda.sormas.backend.infrastructure.area.Area in project SORMAS-Project by hzi-braunschweig.

the class RegionFacadeEjb method getIndexList.

@Override
public List<RegionIndexDto> getIndexList(RegionCriteria criteria, Integer first, Integer max, List<SortProperty> sortProperties) {
    CriteriaBuilder cb = em.getCriteriaBuilder();
    CriteriaQuery<Region> cq = cb.createQuery(Region.class);
    Root<Region> region = cq.from(Region.class);
    Join<Region, Area> area = region.join(Region.AREA, JoinType.LEFT);
    Join<Region, Country> country = region.join(Region.COUNTRY, JoinType.LEFT);
    Predicate filter = null;
    if (criteria != null) {
        filter = service.buildCriteriaFilter(criteria, cb, region);
    }
    if (filter != null) {
        cq.where(filter);
    }
    if (CollectionUtils.isNotEmpty(sortProperties)) {
        List<Order> order = new ArrayList<>(sortProperties.size());
        for (SortProperty sortProperty : sortProperties) {
            Expression<?> expression;
            switch(sortProperty.propertyName) {
                case Region.NAME:
                case Region.EPID_CODE:
                case Region.GROWTH_RATE:
                case Region.EXTERNAL_ID:
                    expression = region.get(sortProperty.propertyName);
                    break;
                case Region.AREA:
                    expression = area.get(Area.NAME);
                    break;
                case RegionIndexDto.COUNTRY:
                    expression = country.get(Country.DEFAULT_NAME);
                    break;
                default:
                    throw new IllegalArgumentException(sortProperty.propertyName);
            }
            order.add(sortProperty.ascending ? cb.asc(expression) : cb.desc(expression));
        }
        cq.orderBy(order);
    } else {
        cq.orderBy(cb.asc(region.get(Region.NAME)));
    }
    cq.select(region);
    return QueryHelper.getResultList(em, cq, first, max, this::toIndexDto);
}
Also used : CriteriaBuilder(javax.persistence.criteria.CriteriaBuilder) Order(javax.persistence.criteria.Order) ArrayList(java.util.ArrayList) Predicate(javax.persistence.criteria.Predicate) Area(de.symeda.sormas.backend.infrastructure.area.Area) SortProperty(de.symeda.sormas.api.utils.SortProperty) Country(de.symeda.sormas.backend.infrastructure.country.Country)

Example 2 with Area

use of de.symeda.sormas.backend.infrastructure.area.Area in project SORMAS-Project by hzi-braunschweig.

the class PopulationDataFacadeEjb method getAreaPopulation.

public Integer getAreaPopulation(String areaUuid, AgeGroup ageGroup) {
    CriteriaBuilder cb = em.getCriteriaBuilder();
    CriteriaQuery<Integer> cq = cb.createQuery(Integer.class);
    Root<PopulationData> root = cq.from(PopulationData.class);
    Join<PopulationData, Region> regionJoin = root.join(PopulationData.REGION);
    Join<Region, Area> areaJoin = regionJoin.join(Region.AREA);
    Predicate areaFilter = cb.equal(areaJoin.get(Area.UUID), areaUuid);
    Predicate ageFilter = cb.and(cb.equal(root.get(PopulationData.AGE_GROUP), ageGroup));
    cq.where(areaFilter, ageFilter);
    cq.select(root.get(PopulationData.POPULATION));
    TypedQuery query = em.createQuery(cq);
    try {
        Integer totalPopulation = 0;
        for (Object i : query.getResultList()) {
            if (Objects.nonNull(i)) {
                totalPopulation = totalPopulation + (Integer) i;
            }
        }
        return totalPopulation;
    } catch (NoResultException e) {
        return null;
    }
}
Also used : CriteriaBuilder(javax.persistence.criteria.CriteriaBuilder) TypedQuery(javax.persistence.TypedQuery) NoResultException(javax.persistence.NoResultException) Predicate(javax.persistence.criteria.Predicate) Area(de.symeda.sormas.backend.infrastructure.area.Area) Region(de.symeda.sormas.backend.infrastructure.region.Region)

Example 3 with Area

use of de.symeda.sormas.backend.infrastructure.area.Area in project SORMAS-Project by hzi-braunschweig.

the class CampaignFormDataFacadeEjb method getDiagramDataByAgeGroup.

public List<CampaignDiagramDataDto> getDiagramDataByAgeGroup(CampaignDiagramSeries diagramSeriesTotal, CampaignDiagramSeries diagramSeries, CampaignDiagramCriteria campaignDiagramCriteria) {
    List<CampaignDiagramDataDto> resultData = new ArrayList<>();
    final AreaReferenceDto area = campaignDiagramCriteria.getArea();
    final RegionReferenceDto region = campaignDiagramCriteria.getRegion();
    final DistrictReferenceDto district = campaignDiagramCriteria.getDistrict();
    final CampaignJurisdictionLevel grouping = campaignDiagramCriteria.getCampaignJurisdictionLevelGroupBy();
    if (grouping == CampaignJurisdictionLevel.AREA) {
        List<Area> areas = areaService.getAll();
        areas.forEach(areaItem -> {
            Integer population = populationDataFacadeEjb.getAreaPopulation(areaItem.getUuid(), diagramSeriesTotal.getPopulationGroup());
            if (population == 0) {
                resultData.add(new CampaignDiagramDataDto(areaItem.getName(), 0, areaItem.getUuid(), areaItem.getName(), diagramSeries.getFieldId(), diagramSeries.getFormId(), false));
            } else {
                resultData.add(new CampaignDiagramDataDto(areaItem.getName(), population, areaItem.getUuid(), areaItem.getName(), diagramSeries.getFieldId(), diagramSeries.getFormId(), true));
            }
        });
    } else if (grouping == CampaignJurisdictionLevel.REGION) {
        List<RegionReferenceDto> regions;
        if (area != null)
            regions = regionFacadeEjb.getAllActiveByArea(area.getUuid());
        else
            regions = regionFacadeEjb.getAllActiveAsReference();
        // this should not be needed
        // if (regions.isEmpty()) {
        // resultData.add(
        // new CampaignDiagramDataDto(
        // area.getCaption(),
        // 0,
        // area.getUuid(),
        // area.getCaption(),
        // diagramSeries.getFieldId(),
        // diagramSeries.getFormId(),
        // false));
        // } else {
        regions.stream().forEach(regionReferenceDto -> {
            PopulationDataCriteria criteria = new PopulationDataCriteria();
            criteria.sexIsNull(true);
            criteria.region(regionReferenceDto);
            criteria.ageGroup(diagramSeriesTotal.getPopulationGroup());
            List<PopulationDataDto> populationDataDto = populationDataFacadeEjb.getPopulationData(criteria);
            Integer populationSum = 0;
            if (!populationDataDto.isEmpty()) {
                populationSum = populationDataDto.stream().mapToInt(e -> e.getPopulation()).sum();
                resultData.add(new CampaignDiagramDataDto(regionReferenceDto.getCaption(), populationSum, regionReferenceDto.getUuid(), regionReferenceDto.getCaption(), diagramSeries.getFieldId(), diagramSeries.getFormId(), true));
            } else {
                resultData.add(new CampaignDiagramDataDto(regionReferenceDto.getCaption(), 0, regionReferenceDto.getUuid(), regionReferenceDto.getCaption(), diagramSeries.getFieldId(), diagramSeries.getFormId(), false));
            }
        });
    // }
    } else if (grouping == CampaignJurisdictionLevel.DISTRICT || Objects.isNull(district)) {
        List<DistrictReferenceDto> districts;
        if (region != null) {
            districts = districtFacadeEjb.getAllActiveByRegion(region.getUuid());
        } else if (area != null) {
            districts = districtFacadeEjb.getAllActiveByArea(area.getUuid());
        } else {
            districts = districtFacadeEjb.getAllActiveAsReference();
        }
        // this should not be needed
        // if (districts.isEmpty()) {
        // resultData.add(
        // new CampaignDiagramDataDto(
        // region.getCaption(),
        // 0,
        // region.getUuid(),
        // region.getCaption(),
        // diagramSeries.getFieldId(),
        // diagramSeries.getFormId(),
        // false));
        // } else {
        districts.stream().forEach(districtReferenceDto -> {
            PopulationDataCriteria criteria = new PopulationDataCriteria();
            criteria.sexIsNull(true);
            criteria.district(districtReferenceDto);
            criteria.region(region);
            criteria.ageGroup(diagramSeriesTotal.getPopulationGroup());
            List<PopulationDataDto> populationDataDtoList = populationDataFacadeEjb.getPopulationData(criteria);
            Integer populationSum = 0;
            if (!populationDataDtoList.isEmpty()) {
                populationSum = populationDataDtoList.stream().mapToInt(e -> e.getPopulation()).sum();
                resultData.add(new CampaignDiagramDataDto(districtReferenceDto.getCaption(), populationSum, districtReferenceDto.getUuid(), districtReferenceDto.getCaption(), diagramSeries.getFieldId(), diagramSeries.getFormId(), true));
            } else {
                resultData.add(new CampaignDiagramDataDto(districtReferenceDto.getCaption(), populationSum, districtReferenceDto.getUuid(), districtReferenceDto.getCaption(), diagramSeries.getFieldId(), diagramSeries.getFormId(), false));
            }
        });
    // }
    } else if (district != null) {
        resultData.add(new CampaignDiagramDataDto(district.getCaption(), 0, district.getUuid(), district.getCaption(), diagramSeries.getFieldId(), diagramSeries.getFormId(), true));
    }
    return resultData;
}
Also used : PopulationDataCriteria(de.symeda.sormas.api.infrastructure.PopulationDataCriteria) DtoHelper(de.symeda.sormas.backend.util.DtoHelper) Join(javax.persistence.criteria.Join) CampaignFormDataReferenceDto(de.symeda.sormas.api.campaign.data.CampaignFormDataReferenceDto) AbstractDomainObject(de.symeda.sormas.backend.common.AbstractDomainObject) Date(java.util.Date) I18nProperties(de.symeda.sormas.api.i18n.I18nProperties) CampaignDiagramCriteria(de.symeda.sormas.api.campaign.diagram.CampaignDiagramCriteria) CampaignFormMetaFacadeEjb(de.symeda.sormas.backend.campaign.form.CampaignFormMetaFacadeEjb) CommunityFacadeEjb(de.symeda.sormas.backend.infrastructure.community.CommunityFacadeEjb) DistrictService(de.symeda.sormas.backend.infrastructure.district.DistrictService) Valid(javax.validation.Valid) CampaignService(de.symeda.sormas.backend.campaign.CampaignService) Predicate(javax.persistence.criteria.Predicate) UserFacadeEjb(de.symeda.sormas.backend.user.UserFacadeEjb) CampaignDiagramSeries(de.symeda.sormas.api.campaign.diagram.CampaignDiagramSeries) Area(de.symeda.sormas.backend.infrastructure.area.Area) CriteriaBuilder(javax.persistence.criteria.CriteriaBuilder) JoinType(javax.persistence.criteria.JoinType) CampaignFormDataFacade(de.symeda.sormas.api.campaign.data.CampaignFormDataFacade) Stateless(javax.ejb.Stateless) CampaignFormElementType(de.symeda.sormas.api.campaign.form.CampaignFormElementType) CriteriaQuery(javax.persistence.criteria.CriteriaQuery) CommunityService(de.symeda.sormas.backend.infrastructure.community.CommunityService) Region(de.symeda.sormas.backend.infrastructure.region.Region) District(de.symeda.sormas.backend.infrastructure.district.District) NotNull(javax.validation.constraints.NotNull) CampaignJurisdictionLevel(de.symeda.sormas.api.campaign.CampaignJurisdictionLevel) Collectors(java.util.stream.Collectors) Objects(java.util.Objects) List(java.util.List) Query(javax.persistence.Query) UserService(de.symeda.sormas.backend.user.UserService) CampaignFormDataCriteria(de.symeda.sormas.api.campaign.data.CampaignFormDataCriteria) DistrictFacadeEjb(de.symeda.sormas.backend.infrastructure.district.DistrictFacadeEjb) Campaign(de.symeda.sormas.backend.campaign.Campaign) Order(javax.persistence.criteria.Order) RegionReferenceDto(de.symeda.sormas.api.infrastructure.region.RegionReferenceDto) ValidationRuntimeException(de.symeda.sormas.api.utils.ValidationRuntimeException) CampaignFormMeta(de.symeda.sormas.backend.campaign.form.CampaignFormMeta) Community(de.symeda.sormas.backend.infrastructure.community.Community) QueryHelper(de.symeda.sormas.backend.util.QueryHelper) CampaignFormElement(de.symeda.sormas.api.campaign.form.CampaignFormElement) PopulationDataFacadeEjb(de.symeda.sormas.backend.infrastructure.PopulationDataFacadeEjb) ArrayList(java.util.ArrayList) CampaignFormDataDto(de.symeda.sormas.api.campaign.data.CampaignFormDataDto) CampaignDiagramDataDto(de.symeda.sormas.api.campaign.diagram.CampaignDiagramDataDto) LocalBean(javax.ejb.LocalBean) Expression(javax.persistence.criteria.Expression) CampaignFormDataEntry(de.symeda.sormas.api.campaign.data.CampaignFormDataEntry) CriteriaBuilderHelper(de.symeda.sormas.backend.common.CriteriaBuilderHelper) AreaService(de.symeda.sormas.backend.infrastructure.area.AreaService) EJB(javax.ejb.EJB) Root(javax.persistence.criteria.Root) ModelConstants(de.symeda.sormas.backend.util.ModelConstants) CampaignFormMetaService(de.symeda.sormas.backend.campaign.form.CampaignFormMetaService) CampaignFormDataIndexDto(de.symeda.sormas.api.campaign.data.CampaignFormDataIndexDto) Validations(de.symeda.sormas.api.i18n.Validations) DistrictReferenceDto(de.symeda.sormas.api.infrastructure.district.DistrictReferenceDto) CampaignReferenceDto(de.symeda.sormas.api.campaign.CampaignReferenceDto) EntityManager(javax.persistence.EntityManager) PersistenceContext(javax.persistence.PersistenceContext) SortProperty(de.symeda.sormas.api.utils.SortProperty) RegionFacadeEjb(de.symeda.sormas.backend.infrastructure.region.RegionFacadeEjb) RegionService(de.symeda.sormas.backend.infrastructure.region.RegionService) UserRight(de.symeda.sormas.api.user.UserRight) PopulationDataDto(de.symeda.sormas.api.infrastructure.PopulationDataDto) CampaignFacadeEjb(de.symeda.sormas.backend.campaign.CampaignFacadeEjb) AreaReferenceDto(de.symeda.sormas.api.infrastructure.area.AreaReferenceDto) Collections(java.util.Collections) ArrayList(java.util.ArrayList) CampaignJurisdictionLevel(de.symeda.sormas.api.campaign.CampaignJurisdictionLevel) DistrictReferenceDto(de.symeda.sormas.api.infrastructure.district.DistrictReferenceDto) Area(de.symeda.sormas.backend.infrastructure.area.Area) RegionReferenceDto(de.symeda.sormas.api.infrastructure.region.RegionReferenceDto) PopulationDataCriteria(de.symeda.sormas.api.infrastructure.PopulationDataCriteria) AreaReferenceDto(de.symeda.sormas.api.infrastructure.area.AreaReferenceDto) List(java.util.List) ArrayList(java.util.ArrayList) PopulationDataDto(de.symeda.sormas.api.infrastructure.PopulationDataDto) CampaignDiagramDataDto(de.symeda.sormas.api.campaign.diagram.CampaignDiagramDataDto)

Example 4 with Area

use of de.symeda.sormas.backend.infrastructure.area.Area in project SORMAS-Project by hzi-braunschweig.

the class DistrictService method getAllActiveByArea.

public List<District> getAllActiveByArea(Area area) {
    CriteriaBuilder cb = em.getCriteriaBuilder();
    CriteriaQuery<District> cq = cb.createQuery(getElementClass());
    Root<District> from = cq.from(getElementClass());
    Path<Area> regionJoin = from.join(District.REGION, JoinType.LEFT);
    cq.where(cb.and(createBasicFilter(cb, from), cb.equal(regionJoin.get(Region.AREA), area)));
    cq.orderBy(cb.asc(from.get(District.NAME)));
    return em.createQuery(cq).getResultList();
}
Also used : CriteriaBuilder(javax.persistence.criteria.CriteriaBuilder) Area(de.symeda.sormas.backend.infrastructure.area.Area)

Aggregations

Area (de.symeda.sormas.backend.infrastructure.area.Area)4 CriteriaBuilder (javax.persistence.criteria.CriteriaBuilder)4 SortProperty (de.symeda.sormas.api.utils.SortProperty)2 Predicate (javax.persistence.criteria.Predicate)2 CampaignJurisdictionLevel (de.symeda.sormas.api.campaign.CampaignJurisdictionLevel)1 CampaignReferenceDto (de.symeda.sormas.api.campaign.CampaignReferenceDto)1 CampaignFormDataCriteria (de.symeda.sormas.api.campaign.data.CampaignFormDataCriteria)1 CampaignFormDataDto (de.symeda.sormas.api.campaign.data.CampaignFormDataDto)1 CampaignFormDataEntry (de.symeda.sormas.api.campaign.data.CampaignFormDataEntry)1 CampaignFormDataFacade (de.symeda.sormas.api.campaign.data.CampaignFormDataFacade)1 CampaignFormDataIndexDto (de.symeda.sormas.api.campaign.data.CampaignFormDataIndexDto)1 CampaignFormDataReferenceDto (de.symeda.sormas.api.campaign.data.CampaignFormDataReferenceDto)1 CampaignDiagramCriteria (de.symeda.sormas.api.campaign.diagram.CampaignDiagramCriteria)1 CampaignDiagramDataDto (de.symeda.sormas.api.campaign.diagram.CampaignDiagramDataDto)1 CampaignDiagramSeries (de.symeda.sormas.api.campaign.diagram.CampaignDiagramSeries)1 CampaignFormElement (de.symeda.sormas.api.campaign.form.CampaignFormElement)1 CampaignFormElementType (de.symeda.sormas.api.campaign.form.CampaignFormElementType)1 I18nProperties (de.symeda.sormas.api.i18n.I18nProperties)1 Validations (de.symeda.sormas.api.i18n.Validations)1 PopulationDataCriteria (de.symeda.sormas.api.infrastructure.PopulationDataCriteria)1