use of org.hisp.dhis.period.DailyPeriodType in project dhis2-core by dhis2.
the class FacilityReportingServiceImpl method getMobileDataSetsForUnit.
// -------------------------------------------------------------------------
// Service methods
// -------------------------------------------------------------------------
@Override
public List<DataSet> getMobileDataSetsForUnit(OrganisationUnit unit, String localeString) {
List<DataSet> datasets = new ArrayList<>();
Locale locale = LocaleUtil.getLocale(localeString);
if (DEBUG)
log.debug("Getting data sets for unit " + unit.getName());
for (org.hisp.dhis.dataset.DataSet dataSet : dataSetService.getDataSetsForMobile(unit)) {
PeriodType periodType = dataSet.getPeriodType();
if (periodType instanceof DailyPeriodType || periodType instanceof WeeklyPeriodType || periodType instanceof MonthlyPeriodType || periodType instanceof YearlyPeriodType || periodType instanceof QuarterlyPeriodType) {
if (DEBUG)
log.debug("Found data set " + dataSet.getName());
datasets.add(getDataSetForLocale(dataSet.getId(), locale));
} else {
log.warn("Dataset '" + dataSet.getName() + "' set to be reported from mobile, but not of a supported period type: " + periodType.getName());
}
}
return datasets;
}
use of org.hisp.dhis.period.DailyPeriodType in project dhis2-core by dhis2.
the class EthiopianCalendarTest method testGenerateDailyPeriods.
@Test
void testGenerateDailyPeriods() {
Date startDate = new Cal(1975, 1, 1, true).time();
Date endDate = new Cal(2025, 1, 2, true).time();
List<Period> days = new DailyPeriodType().generatePeriods(calendar, startDate, endDate);
assertEquals(18001, days.size());
}
use of org.hisp.dhis.period.DailyPeriodType in project dhis2-core by dhis2.
the class DatePeriodResourceTable method getPopulateTempTableContent.
@Override
public Optional<List<Object[]>> getPopulateTempTableContent() {
List<PeriodType> periodTypes = PeriodType.getAvailablePeriodTypes();
List<Object[]> batchArgs = new ArrayList<>();
// TODO Create a dynamic solution instead of having fixed dates
Date startDate = new Cal(1975, 1, 1, true).time();
Date endDate = new Cal(2025, 1, 1, true).time();
List<Period> dailyPeriods = new DailyPeriodType().generatePeriods(startDate, endDate);
List<Date> days = new UniqueArrayList<>(dailyPeriods.stream().map(Period::getStartDate).collect(Collectors.toList()));
Calendar calendar = PeriodType.getCalendar();
for (Date day : days) {
List<Object> values = new ArrayList<>();
final int year = PeriodType.getCalendar().fromIso(day).getYear();
values.add(day);
values.add(year);
for (PeriodType periodType : periodTypes) {
values.add(periodType.createPeriod(day, calendar).getIsoDate());
}
batchArgs.add(values.toArray());
}
return Optional.of(batchArgs);
}
use of org.hisp.dhis.period.DailyPeriodType in project dhis2-core by dhis2.
the class DataApprovalWorkflowTest method testGetWorkflowSqlCoEnddateExtension.
/**
* Note that as part of the following test, we are checking to be sure that
* the longest extension to the category option end date is returned from
* data sets that are successively added to the workflow. The total
* extension length (period length times number of periods) is always
* increasing as we add data sets to the workflow. The most recently-added
* data set always has the longest total extension so far.
*/
@Test
void testGetWorkflowSqlCoEnddateExtension() {
DataSet noPeriodsAfterCoEndDate = createDataSet("noPeriodsAfterCoEndDate", new MonthlyPeriodType(), 0);
DataSet dailyDs = createDataSet("dailyDs", new DailyPeriodType(), 3);
DataSet weeklyDs = createDataSet("weeklyDs", new WeeklyPeriodType(), 3);
DataSet weeklyWedDs = createDataSet("weeklyWedDs", new WeeklyWednesdayPeriodType(), 4);
DataSet weeklyThuDs = createDataSet("weeklyThuDs", new WeeklyThursdayPeriodType(), 5);
DataSet weeklySatDs = createDataSet("weeklySatDs", new WeeklySaturdayPeriodType(), 6);
DataSet weeklySunDs = createDataSet("weeklySunDs", new WeeklySundayPeriodType(), 7);
DataSet biWeeklyDs = createDataSet("biWeeklyDs", new BiWeeklyPeriodType(), 4);
DataSet monthlyDs = createDataSet("monthlyDs", new MonthlyPeriodType(), 3);
DataSet biMonthlyDs = createDataSet("biMonthlyDs", new BiMonthlyPeriodType(), 3);
DataSet querterlyDs = createDataSet("querterlyDs", new QuarterlyPeriodType(), 3);
DataSet sixMonthlyDs = createDataSet("sixMonthlyDs", new SixMonthlyPeriodType(), 3);
DataSet sixMonthlyAprDs = createDataSet("sixMonthlyAprDs", new SixMonthlyAprilPeriodType(), 4);
DataSet sixMonthlyNovDs = createDataSet("sixMonthlyNovDs", new SixMonthlyNovemberPeriodType(), 5);
DataSet yearlyDs = createDataSet("yearlyDs", new YearlyPeriodType(), 3);
DataSet financialAprDs = createDataSet("financialAprDs", new FinancialAprilPeriodType(), 4);
DataSet financialJulDs = createDataSet("financialJulDs", new FinancialJulyPeriodType(), 5);
DataSet financialOctDs = createDataSet("financialOctDs", new FinancialOctoberPeriodType(), 6);
DataSet financialNovDs = createDataSet("financialNovDs", new FinancialNovemberPeriodType(), 7);
DataSet twoYearlyDs = createDataSet("twoYearlyDs", new TwoYearlyPeriodType(), 4);
DataApprovalWorkflow workflow = new DataApprovalWorkflow("test workflow", new DailyPeriodType(), newHashSet());
assertEquals("", workflow.getSqlCoEndDateExtension());
workflow.getDataSets().add(noPeriodsAfterCoEndDate);
assertEquals("", workflow.getSqlCoEndDateExtension());
workflow.getDataSets().add(dailyDs);
assertEquals(" + 3 * INTERVAL '+ 1 day'", workflow.getSqlCoEndDateExtension());
workflow.getDataSets().add(weeklyDs);
assertEquals(" + 3 * INTERVAL '+ 1 week'", workflow.getSqlCoEndDateExtension());
workflow.getDataSets().add(weeklyWedDs);
assertEquals(" + 4 * INTERVAL '+ 1 week'", workflow.getSqlCoEndDateExtension());
workflow.getDataSets().add(weeklyThuDs);
assertEquals(" + 5 * INTERVAL '+ 1 week'", workflow.getSqlCoEndDateExtension());
workflow.getDataSets().add(weeklySatDs);
assertEquals(" + 6 * INTERVAL '+ 1 week'", workflow.getSqlCoEndDateExtension());
workflow.getDataSets().add(weeklySunDs);
assertEquals(" + 7 * INTERVAL '+ 1 week'", workflow.getSqlCoEndDateExtension());
workflow.getDataSets().add(biWeeklyDs);
assertEquals(" + 4 * INTERVAL '+ 2 weeks'", workflow.getSqlCoEndDateExtension());
workflow.getDataSets().add(monthlyDs);
assertEquals(" + 3 * INTERVAL '+ 1 month'", workflow.getSqlCoEndDateExtension());
workflow.getDataSets().add(biMonthlyDs);
assertEquals(" + 3 * INTERVAL '+ 2 months'", workflow.getSqlCoEndDateExtension());
workflow.getDataSets().add(querterlyDs);
assertEquals(" + 3 * INTERVAL '+ 3 months'", workflow.getSqlCoEndDateExtension());
workflow.getDataSets().add(sixMonthlyDs);
assertEquals(" + 3 * INTERVAL '+ 6 months'", workflow.getSqlCoEndDateExtension());
workflow.getDataSets().add(sixMonthlyAprDs);
assertEquals(" + 4 * INTERVAL '+ 6 months'", workflow.getSqlCoEndDateExtension());
workflow.getDataSets().add(sixMonthlyNovDs);
assertEquals(" + 5 * INTERVAL '+ 6 months'", workflow.getSqlCoEndDateExtension());
workflow.getDataSets().add(yearlyDs);
assertEquals(" + 3 * INTERVAL '+ 1 year'", workflow.getSqlCoEndDateExtension());
workflow.getDataSets().add(financialAprDs);
assertEquals(" + 4 * INTERVAL '+ 1 year'", workflow.getSqlCoEndDateExtension());
workflow.getDataSets().add(financialJulDs);
assertEquals(" + 5 * INTERVAL '+ 1 year'", workflow.getSqlCoEndDateExtension());
workflow.getDataSets().add(financialOctDs);
assertEquals(" + 6 * INTERVAL '+ 1 year'", workflow.getSqlCoEndDateExtension());
workflow.getDataSets().add(financialNovDs);
assertEquals(" + 7 * INTERVAL '+ 1 year'", workflow.getSqlCoEndDateExtension());
workflow.getDataSets().add(twoYearlyDs);
assertEquals(" + 4 * INTERVAL '+ 2 years'", workflow.getSqlCoEndDateExtension());
}
use of org.hisp.dhis.period.DailyPeriodType in project dhis2-core by dhis2.
the class DataApprovalWorkflowTest method testGetSortedLevels.
@Test
void testGetSortedLevels() {
DataApprovalLevel level1 = new DataApprovalLevel("level1", 1, null);
level1.setLevel(1);
DataApprovalLevel level2 = new DataApprovalLevel("level2", 2, null);
level2.setLevel(2);
DataApprovalLevel level3 = new DataApprovalLevel("level3", 3, null);
level3.setLevel(3);
DataApprovalWorkflow workflow = new DataApprovalWorkflow("test workflow", new DailyPeriodType(), newHashSet(level3, level2, level1));
List<DataApprovalLevel> levels = workflow.getSortedLevels();
assertEquals(1, levels.get(0).getLevel());
assertEquals(2, levels.get(1).getLevel());
assertEquals(3, levels.get(2).getLevel());
}
Aggregations