mirror of
https://github.com/oxen-io/session-android.git
synced 2025-01-12 21:33:40 +00:00
reset contact selection after batch invite
fixes #4452 Closes #4498 // FREEBIE
This commit is contained in:
parent
fb9ba8cb8d
commit
5b1e5b18f9
@ -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();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user