X-Git-Url: https://git.ktnx.net/?p=mobile-ledger.git;a=blobdiff_plain;f=app%2Fsrc%2Fmain%2Fjava%2Fnet%2Fktnx%2Fmobileledger%2Fui%2FDatePickerFragment.java;h=ecaca2f2ddf04f1c1e89caf0cadb1d3bd51fe180;hp=abec8d6d8fb5915234c4981f74564b8be8766ed8;hb=9fc964d2191f987c6ba26274d9af005e944f2bfa;hpb=09e26d2279484b4dfe0de218b05f075362fff4b5 diff --git a/app/src/main/java/net/ktnx/mobileledger/ui/DatePickerFragment.java b/app/src/main/java/net/ktnx/mobileledger/ui/DatePickerFragment.java index abec8d6d..ecaca2f2 100644 --- a/app/src/main/java/net/ktnx/mobileledger/ui/DatePickerFragment.java +++ b/app/src/main/java/net/ktnx/mobileledger/ui/DatePickerFragment.java @@ -19,16 +19,17 @@ package net.ktnx.mobileledger.ui; import android.app.Dialog; import android.os.Bundle; -import androidx.annotation.NonNull; -import androidx.appcompat.app.AppCompatDialogFragment; import android.widget.CalendarView; import android.widget.TextView; +import androidx.annotation.NonNull; +import androidx.appcompat.app.AppCompatDialogFragment; + import net.ktnx.mobileledger.R; +import net.ktnx.mobileledger.model.MobileLedgerProfile; import java.util.Calendar; import java.util.GregorianCalendar; -import java.util.Locale; import java.util.Objects; import java.util.regex.Matcher; import java.util.regex.Pattern; @@ -38,6 +39,14 @@ public class DatePickerFragment extends AppCompatDialogFragment static final Pattern reYMD = Pattern.compile("^\\s*(\\d+)\\d*/\\s*(\\d+)\\s*/\\s*(\\d+)\\s*$"); static final Pattern reMD = Pattern.compile("^\\s*(\\d+)\\s*/\\s*(\\d+)\\s*$"); static final Pattern reD = Pattern.compile("\\s*(\\d+)\\s*$"); + private DatePickedListener onDatePickedListener; + private MobileLedgerProfile.FutureDates futureDates = MobileLedgerProfile.FutureDates.None; + public MobileLedgerProfile.FutureDates getFutureDates() { + return futureDates; + } + public void setFutureDates(MobileLedgerProfile.FutureDates futureDates) { + this.futureDates = futureDates; + } @NonNull @Override public Dialog onCreateDialog(Bundle savedInstanceState) { @@ -46,8 +55,8 @@ public class DatePickerFragment extends AppCompatDialogFragment int month = c.get(GregorianCalendar.MONTH); int day = c.get(GregorianCalendar.DAY_OF_MONTH); long todayStamp = c.getTimeInMillis(); - TextView date = - Objects.requireNonNull(getActivity()).findViewById(R.id.new_transaction_date); + TextView date = Objects.requireNonNull(getActivity()) + .findViewById(R.id.new_transaction_date); CharSequence present = date.getText(); @@ -77,33 +86,52 @@ public class DatePickerFragment extends AppCompatDialogFragment dpd.setContentView(R.layout.date_picker_view); dpd.setTitle(null); CalendarView cv = dpd.findViewById(R.id.calendarView); - cv.setDate(c.getTime().getTime()); - cv.setMaxDate(todayStamp); + cv.setDate(c.getTime() + .getTime()); + + if (futureDates == MobileLedgerProfile.FutureDates.All) { + cv.setMaxDate(Long.MAX_VALUE); + } + else { + switch (futureDates) { + case None: + // already there + break; + case OneMonth: + c.add(Calendar.MONTH, 1); + break; + case TwoMonths: + c.add(Calendar.MONTH, 2); + break; + case ThreeMonths: + c.add(Calendar.MONTH, 3); + break; + case SixMonths: + c.add(Calendar.MONTH, 6); + break; + case OneYear: + c.add(Calendar.YEAR, 1); + break; + } + cv.setMaxDate(c.getTime() + .getTime()); + } cv.setOnDateChangeListener(this); return dpd; } - private void updateDateInput(int year, int month, int day) { - TextView date = - Objects.requireNonNull(getActivity()).findViewById(R.id.new_transaction_date); - - final Calendar c = GregorianCalendar.getInstance(); - if (c.get(GregorianCalendar.YEAR) == year) { - if (c.get(GregorianCalendar.MONTH) == month) - date.setText(String.format(Locale.US, "%d", day)); - else date.setText(String.format(Locale.US, "%d/%d", month + 1, day)); - } - else date.setText(String.format(Locale.US, "%d/%d/%d", year, month + 1, day)); - - TextView description = Objects.requireNonNull(getActivity()) - .findViewById(R.id.new_transaction_description); - description.requestFocus(); - } @Override public void onSelectedDayChange(@NonNull CalendarView view, int year, int month, int dayOfMonth) { - updateDateInput(year, month, dayOfMonth); this.dismiss(); + if (onDatePickedListener != null) + onDatePickedListener.onDatePicked(year, month, dayOfMonth); + } + public void setOnDatePickedListener(DatePickedListener listener) { + onDatePickedListener = listener; + } + public interface DatePickedListener { + void onDatePicked(int year, int month, int day); } }