reset contact selection after batch invite

fixes #4452
Closes #4498
// FREEBIE
This commit is contained in:
Jake McGinty 2015-11-12 10:47:42 -08:00 committed by Moxie Marlinspike
parent fb9ba8cb8d
commit 5b1e5b18f9
2 changed files with 37 additions and 14 deletions

View File

@ -34,6 +34,9 @@ import org.thoughtcrime.securesms.sms.MessageSender;
import org.thoughtcrime.securesms.sms.OutgoingTextMessage; import org.thoughtcrime.securesms.sms.OutgoingTextMessage;
import org.thoughtcrime.securesms.util.ProgressDialogAsyncTask; import org.thoughtcrime.securesms.util.ProgressDialogAsyncTask;
import org.thoughtcrime.securesms.util.ViewUtil; import org.thoughtcrime.securesms.util.ViewUtil;
import org.thoughtcrime.securesms.util.concurrent.ListenableFuture.Listener;
import java.util.concurrent.ExecutionException;
public class InviteActivity extends PassphraseRequiredActionBarActivity implements ContactSelectionListFragment.OnContactSelectedListener { public class InviteActivity extends PassphraseRequiredActionBarActivity implements ContactSelectionListFragment.OnContactSelectedListener {
@ -241,7 +244,15 @@ public class InviteActivity extends PassphraseRequiredActionBarActivity implemen
final Context context = getContext(); final Context context = getContext();
if (context == null) return; if (context == null) return;
ViewUtil.animateOut(smsSendFrame, slideOutAnimation); ViewUtil.animateOut(smsSendFrame, slideOutAnimation).addListener(new Listener<Boolean>() {
@Override
public void onSuccess(Boolean result) {
contactsFragment.reset();
}
@Override
public void onFailure(ExecutionException e) {}
});
Toast.makeText(context, R.string.InviteActivity_invitations_sent, Toast.LENGTH_LONG).show(); Toast.makeText(context, R.string.InviteActivity_invitations_sent, Toast.LENGTH_LONG).show();
} }
} }

View File

@ -37,6 +37,9 @@ import android.view.animation.Animation;
import android.widget.LinearLayout.LayoutParams; import android.widget.LinearLayout.LayoutParams;
import android.widget.TextView; import android.widget.TextView;
import org.thoughtcrime.securesms.util.concurrent.ListenableFuture;
import org.thoughtcrime.securesms.util.concurrent.SettableFuture;
public class ViewUtil { public class ViewUtil {
@SuppressWarnings("deprecation") @SuppressWarnings("deprecation")
public static void setBackground(final @NonNull View v, final @Nullable Drawable drawable) { public static void setBackground(final @NonNull View v, final @Nullable Drawable drawable) {
@ -130,21 +133,30 @@ public class ViewUtil {
animateOut(view, getAlphaAnimation(1f, 0f, duration)); animateOut(view, getAlphaAnimation(1f, 0f, duration));
} }
public static void animateOut(final @NonNull View view, final @NonNull Animation animation) { public static ListenableFuture<Boolean> animateOut(final @NonNull View view, final @NonNull Animation animation) {
if (view.getVisibility() == View.GONE) return; final SettableFuture future = new SettableFuture();
if (view.getVisibility() == View.GONE) {
future.set(true);
} else {
view.clearAnimation();
animation.reset();
animation.setStartTime(0);
animation.setAnimationListener(new Animation.AnimationListener() {
@Override
public void onAnimationStart(Animation animation) {}
view.clearAnimation(); @Override
animation.reset(); public void onAnimationRepeat(Animation animation) {}
animation.setStartTime(0);
animation.setAnimationListener(new Animation.AnimationListener() {
@Override public void onAnimationStart(Animation animation) {}
@Override public void onAnimationRepeat(Animation animation) {}
@Override public void onAnimationEnd(Animation animation) {
view.setVisibility(View.GONE);
}
});
view.startAnimation(animation); @Override
public void onAnimationEnd(Animation animation) {
view.setVisibility(View.GONE);
future.set(true);
}
});
view.startAnimation(animation);
}
return future;
} }
public static void animateIn(final @NonNull View view, final @NonNull Animation animation) { public static void animateIn(final @NonNull View view, final @NonNull Animation animation) {