I am trying to get list of years since epoch i.e 1970 , 1971, 1972, 1973 so on to 2017 , and list of months January - December after this according to month and year generate weeks (based on working days Monday-Friday).
If a month started on Thursday i.e. 2-2-2016
then it should return 2-2-2016, 3-2-2016
and a use case is suppose if a month end day is Tuesday and its date is 30-4-2016
then I should get 29-4-2016, 30-4-2016
so far I am only able to get last working day of same week from input date the code is below:
String Date = "06-04-2012";
DateTimeFormatter f = DateTimeFormatter.ofPattern("YYYY-MM-DD");
LocalDate ld = LocalDate.parse(Date, f);
LocalDate nextOrSameFriday = ld.with(TemporalAdjusters
.nextOrSame(DayOfWeek.FRIDAY));
String output = nextOrSameFriday.toString();
//String output = ld.format( f );
if (nextOrSameFriday.getMonthValue() != ld.getMonthValue()) {
nextOrSameFriday = ld.with(TemporalAdjusters
.nextOrSame(DayOfWeek.THURSDAY));
if (nextOrSameFriday.getMonthValue() == ld.getMonthValue())
return nextOrSameFriday.toString();
else if (nextOrSameFriday.getMonthValue() != ld.getMonthValue()) {
nextOrSameFriday = ld.with(TemporalAdjusters
.nextOrSame(DayOfWeek.WEDNESDAY));
if (nextOrSameFriday.getMonthValue() == ld.getMonthValue())
return nextOrSameFriday.toString();
else if (nextOrSameFriday.getMonthValue() != ld.getMonthValue()) {
nextOrSameFriday = ld.with(TemporalAdjusters
.nextOrSame(DayOfWeek.TUESDAY));
if (nextOrSameFriday.getMonthValue() == ld.getMonthValue())
return nextOrSameFriday.toString();
else
return Date;
}
}
}
After the month and year is selected I want following things to do:
Find first day of the Month
Find first Friday of MONTH
Check if its Saturday or Sunday , add 1 or 2 in DATE
Add 2 days in first Friday to get first day of 2nd WEEK.
Add 5 days to get 2nd week Friday
Similarly go on until the end of month