From 31cb68240b247d6b971ec47dabc53d7e21ce83b8 Mon Sep 17 00:00:00 2001 From: TebbeUbben Date: Mon, 11 Jun 2018 15:45:28 +0200 Subject: [PATCH] Automatically scroll to currently active objective --- .../ObjectivesFragment.java | 37 +++++++++++++++++-- .../objectives/Objective.java | 15 ++++---- 2 files changed, 41 insertions(+), 11 deletions(-) diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/ConstraintsObjectives/ObjectivesFragment.java b/app/src/main/java/info/nightscout/androidaps/plugins/ConstraintsObjectives/ObjectivesFragment.java index 75aa6b6922..df70409769 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/ConstraintsObjectives/ObjectivesFragment.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/ConstraintsObjectives/ObjectivesFragment.java @@ -1,13 +1,16 @@ package info.nightscout.androidaps.plugins.ConstraintsObjectives; +import android.animation.LayoutTransition; import android.app.Activity; import android.os.Bundle; import android.support.annotation.NonNull; import android.support.v4.content.ContextCompat; import android.support.v7.widget.CardView; import android.support.v7.widget.LinearLayoutManager; +import android.support.v7.widget.LinearSmoothScroller; import android.support.v7.widget.RecyclerView; import android.text.Html; +import android.util.DisplayMetrics; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; @@ -51,8 +54,10 @@ public class ObjectivesFragment extends SubscriberFragment { reset.setOnClickListener(v -> { ObjectivesPlugin.getPlugin().reset(); ObjectivesPlugin.saveProgress(); - updateGUI(); + recyclerView.getAdapter().notifyDataSetChanged(); + scrollToCurrentObjective(); }); + scrollToCurrentObjective(); return view; } catch (Exception e) { @@ -62,6 +67,28 @@ public class ObjectivesFragment extends SubscriberFragment { return null; } + private void scrollToCurrentObjective() { + for (int i = 0; i < ObjectivesPlugin.getObjectives().size(); i++) { + Objective objective = ObjectivesPlugin.getObjectives().get(i); + if (!objective.isStarted() || !objective.isAccomplished()) { + RecyclerView.SmoothScroller smoothScroller = new LinearSmoothScroller(getContext()) { + @Override + protected int getVerticalSnapPreference() { + return LinearSmoothScroller.SNAP_TO_START; + } + + @Override + protected int calculateTimeForScrolling(int dx) { + return super.calculateTimeForScrolling(dx) * 4; + } + }; + smoothScroller.setTargetPosition(i); + recyclerView.getLayoutManager().startSmoothScroll(smoothScroller); + break; + } + } + } + private class ObjectivesAdapter extends RecyclerView.Adapter { @NonNull @@ -97,7 +124,7 @@ public class ObjectivesFragment extends SubscriberFragment { } else if (objective.isStarted()) { holder.gate.setTextColor(0xFFFFFFFF); holder.verify.setVisibility(View.VISIBLE); - holder.verify.setEnabled(objective.isAccomplished() || enableFake.isChecked()); + holder.verify.setEnabled(objective.isCompleted() || enableFake.isChecked()); holder.start.setVisibility(View.GONE); holder.progress.setVisibility(View.VISIBLE); holder.progress.removeAllViews(); @@ -113,11 +140,13 @@ public class ObjectivesFragment extends SubscriberFragment { } holder.verify.setOnClickListener((view) -> { objective.setAccomplishedOn(new Date()); - updateGUI(); + notifyDataSetChanged(); + scrollToCurrentObjective(); }); holder.start.setOnClickListener((view) -> { objective.setStartedOn(new Date()); - updateGUI(); + notifyDataSetChanged(); + scrollToCurrentObjective(); }); } diff --git a/app/src/main/java/info/nightscout/androidaps/plugins/ConstraintsObjectives/objectives/Objective.java b/app/src/main/java/info/nightscout/androidaps/plugins/ConstraintsObjectives/objectives/Objective.java index 30306da4f3..d5a6b27dbc 100644 --- a/app/src/main/java/info/nightscout/androidaps/plugins/ConstraintsObjectives/objectives/Objective.java +++ b/app/src/main/java/info/nightscout/androidaps/plugins/ConstraintsObjectives/objectives/Objective.java @@ -33,15 +33,16 @@ public abstract class Objective { for (Task task : tasks) task.objective = this; } - public boolean isAccomplished() { - boolean completed = true; + public boolean isCompleted() { for (Task task : tasks) { - if (!task.shouldBeIgnored() && !task.isCompleted()) { - completed = false; - break; - } + if (!task.shouldBeIgnored() && !task.isCompleted()) + return false; } - return startedOn != null && (accomplishedOn != null || completed); + return true; + } + + public boolean isAccomplished() { + return accomplishedOn != null; } public boolean isStarted() {