Save whether "show pictures" has been clicked
Save/restore whether "show pictures" has been clicked. On restore this allows us to correctly instruct MessageContainerView whether to load pictures.
This commit is contained in:
parent
affc41c853
commit
c505083d6b
2 changed files with 56 additions and 79 deletions
|
@ -8,8 +8,6 @@ import android.content.ActivityNotFoundException;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.net.Uri;
|
import android.net.Uri;
|
||||||
import android.os.Parcel;
|
|
||||||
import android.os.Parcelable;
|
|
||||||
import android.text.TextUtils;
|
import android.text.TextUtils;
|
||||||
import android.util.AttributeSet;
|
import android.util.AttributeSet;
|
||||||
import android.view.ContextMenu;
|
import android.view.ContextMenu;
|
||||||
|
@ -68,7 +66,6 @@ public class MessageContainerView extends LinearLayout implements OnLayoutChange
|
||||||
private boolean showingPictures;
|
private boolean showingPictures;
|
||||||
private LayoutInflater mInflater;
|
private LayoutInflater mInflater;
|
||||||
private AttachmentViewCallback attachmentCallback;
|
private AttachmentViewCallback attachmentCallback;
|
||||||
private SavedState mSavedState;
|
|
||||||
private ClipboardManager mClipboardManager;
|
private ClipboardManager mClipboardManager;
|
||||||
private Map<AttachmentViewInfo, AttachmentView> attachmentViewMap = new HashMap<>();
|
private Map<AttachmentViewInfo, AttachmentView> attachmentViewMap = new HashMap<>();
|
||||||
private Map<Uri, AttachmentViewInfo> attachments = new HashMap<>();
|
private Map<Uri, AttachmentViewInfo> attachments = new HashMap<>();
|
||||||
|
@ -371,7 +368,7 @@ public class MessageContainerView extends LinearLayout implements OnLayoutChange
|
||||||
}
|
}
|
||||||
|
|
||||||
public void displayMessageViewContainer(MessageViewInfo messageViewInfo,
|
public void displayMessageViewContainer(MessageViewInfo messageViewInfo,
|
||||||
final OnRenderingFinishedListener onRenderingFinishedListener, boolean automaticallyLoadPictures,
|
final OnRenderingFinishedListener onRenderingFinishedListener, boolean loadPictures,
|
||||||
boolean hideUnsignedTextDivider, AttachmentViewCallback attachmentCallback) {
|
boolean hideUnsignedTextDivider, AttachmentViewCallback attachmentCallback) {
|
||||||
|
|
||||||
this.attachmentCallback = attachmentCallback;
|
this.attachmentCallback = attachmentCallback;
|
||||||
|
@ -380,18 +377,10 @@ public class MessageContainerView extends LinearLayout implements OnLayoutChange
|
||||||
|
|
||||||
renderAttachments(messageViewInfo);
|
renderAttachments(messageViewInfo);
|
||||||
|
|
||||||
if (mSavedState != null) {
|
|
||||||
if (mSavedState.showingPictures) {
|
|
||||||
setLoadPictures(true);
|
|
||||||
}
|
|
||||||
|
|
||||||
mSavedState = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
String textToDisplay = messageViewInfo.text;
|
String textToDisplay = messageViewInfo.text;
|
||||||
if (textToDisplay != null && !isShowingPictures()) {
|
if (textToDisplay != null && !isShowingPictures()) {
|
||||||
if (Utility.hasExternalImages(textToDisplay)) {
|
if (Utility.hasExternalImages(textToDisplay)) {
|
||||||
if (automaticallyLoadPictures) {
|
if (loadPictures) {
|
||||||
setLoadPictures(true);
|
setLoadPictures(true);
|
||||||
} else {
|
} else {
|
||||||
hasHiddenExternalImages = true;
|
hasHiddenExternalImages = true;
|
||||||
|
@ -506,32 +495,6 @@ public class MessageContainerView extends LinearLayout implements OnLayoutChange
|
||||||
clearDisplayedContent();
|
clearDisplayedContent();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public Parcelable onSaveInstanceState() {
|
|
||||||
Parcelable superState = super.onSaveInstanceState();
|
|
||||||
|
|
||||||
SavedState savedState = new SavedState(superState);
|
|
||||||
|
|
||||||
savedState.attachmentViewVisible = (mAttachmentsContainer != null &&
|
|
||||||
mAttachmentsContainer.getVisibility() == View.VISIBLE);
|
|
||||||
savedState.showingPictures = showingPictures;
|
|
||||||
|
|
||||||
return savedState;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onRestoreInstanceState(Parcelable state) {
|
|
||||||
if(!(state instanceof SavedState)) {
|
|
||||||
super.onRestoreInstanceState(state);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
SavedState savedState = (SavedState)state;
|
|
||||||
super.onRestoreInstanceState(savedState.getSuperState());
|
|
||||||
|
|
||||||
mSavedState = savedState;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onLayoutChanged() {
|
public void onLayoutChanged() {
|
||||||
if (mMessageContentView != null) {
|
if (mMessageContentView != null) {
|
||||||
|
@ -555,42 +518,6 @@ public class MessageContainerView extends LinearLayout implements OnLayoutChange
|
||||||
return attachmentViewMap.get(attachment);
|
return attachmentViewMap.get(attachment);
|
||||||
}
|
}
|
||||||
|
|
||||||
static class SavedState extends BaseSavedState {
|
|
||||||
boolean attachmentViewVisible;
|
|
||||||
boolean showingPictures;
|
|
||||||
|
|
||||||
public static final Parcelable.Creator<SavedState> CREATOR =
|
|
||||||
new Parcelable.Creator<SavedState>() {
|
|
||||||
@Override
|
|
||||||
public SavedState createFromParcel(Parcel in) {
|
|
||||||
return new SavedState(in);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public SavedState[] newArray(int size) {
|
|
||||||
return new SavedState[size];
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
SavedState(Parcelable superState) {
|
|
||||||
super(superState);
|
|
||||||
}
|
|
||||||
|
|
||||||
private SavedState(Parcel in) {
|
|
||||||
super(in);
|
|
||||||
this.attachmentViewVisible = (in.readInt() != 0);
|
|
||||||
this.showingPictures = (in.readInt() != 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public void writeToParcel(Parcel out, int flags) {
|
|
||||||
super.writeToParcel(out, flags);
|
|
||||||
out.writeInt((this.attachmentViewVisible) ? 1 : 0);
|
|
||||||
out.writeInt((this.showingPictures) ? 1 : 0);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
interface OnRenderingFinishedListener {
|
interface OnRenderingFinishedListener {
|
||||||
void onLoadFinished();
|
void onLoadFinished();
|
||||||
}
|
}
|
||||||
|
|
|
@ -6,6 +6,8 @@ import android.animation.AnimatorListenerAdapter;
|
||||||
import android.animation.ObjectAnimator;
|
import android.animation.ObjectAnimator;
|
||||||
import android.content.Context;
|
import android.content.Context;
|
||||||
import android.graphics.drawable.Drawable;
|
import android.graphics.drawable.Drawable;
|
||||||
|
import android.os.Parcel;
|
||||||
|
import android.os.Parcelable;
|
||||||
import android.util.AttributeSet;
|
import android.util.AttributeSet;
|
||||||
import android.view.LayoutInflater;
|
import android.view.LayoutInflater;
|
||||||
import android.view.View;
|
import android.view.View;
|
||||||
|
@ -49,6 +51,7 @@ public class MessageTopView extends LinearLayout {
|
||||||
private AttachmentViewCallback attachmentCallback;
|
private AttachmentViewCallback attachmentCallback;
|
||||||
private Button showPicturesButton;
|
private Button showPicturesButton;
|
||||||
private boolean isShowingProgress;
|
private boolean isShowingProgress;
|
||||||
|
private boolean showPicturesButtonClicked;
|
||||||
|
|
||||||
private MessageCryptoPresenter messageCryptoPresenter;
|
private MessageCryptoPresenter messageCryptoPresenter;
|
||||||
|
|
||||||
|
@ -85,6 +88,7 @@ public class MessageTopView extends LinearLayout {
|
||||||
@Override
|
@Override
|
||||||
public void onClick(View v) {
|
public void onClick(View v) {
|
||||||
showPicturesInAllContainerViews();
|
showPicturesInAllContainerViews();
|
||||||
|
showPicturesButtonClicked = true;
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
@ -107,8 +111,8 @@ public class MessageTopView extends LinearLayout {
|
||||||
resetAndPrepareMessageView(messageViewInfo);
|
resetAndPrepareMessageView(messageViewInfo);
|
||||||
|
|
||||||
ShowPictures showPicturesSetting = account.getShowPictures();
|
ShowPictures showPicturesSetting = account.getShowPictures();
|
||||||
boolean automaticallyLoadPictures =
|
boolean loadPictures = shouldAutomaticallyLoadPictures(showPicturesSetting, messageViewInfo.message) ||
|
||||||
shouldAutomaticallyLoadPictures(showPicturesSetting, messageViewInfo.message);
|
showPicturesButtonClicked;
|
||||||
|
|
||||||
MessageContainerView view = (MessageContainerView) mInflater.inflate(R.layout.message_container,
|
MessageContainerView view = (MessageContainerView) mInflater.inflate(R.layout.message_container,
|
||||||
containerView, false);
|
containerView, false);
|
||||||
|
@ -120,9 +124,9 @@ public class MessageTopView extends LinearLayout {
|
||||||
public void onLoadFinished() {
|
public void onLoadFinished() {
|
||||||
displayViewOnLoadFinished(true);
|
displayViewOnLoadFinished(true);
|
||||||
}
|
}
|
||||||
}, automaticallyLoadPictures, hideUnsignedTextDivider, attachmentCallback);
|
}, loadPictures, hideUnsignedTextDivider, attachmentCallback);
|
||||||
|
|
||||||
if (view.hasHiddenExternalImages()) {
|
if (view.hasHiddenExternalImages() && !showPicturesButtonClicked) {
|
||||||
showShowPicturesButton();
|
showShowPicturesButton();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -328,4 +332,50 @@ public class MessageTopView extends LinearLayout {
|
||||||
progressBar.setProgress(newPosition);
|
progressBar.setProgress(newPosition);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Parcelable onSaveInstanceState() {
|
||||||
|
Parcelable superState = super.onSaveInstanceState();
|
||||||
|
SavedState savedState = new SavedState(superState);
|
||||||
|
savedState.showPicturesButtonClicked = showPicturesButtonClicked;
|
||||||
|
return savedState;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onRestoreInstanceState(Parcelable state) {
|
||||||
|
SavedState savedState = (SavedState) state;
|
||||||
|
super.onRestoreInstanceState(savedState.getSuperState());
|
||||||
|
showPicturesButtonClicked = savedState.showPicturesButtonClicked;
|
||||||
|
}
|
||||||
|
|
||||||
|
private static class SavedState extends BaseSavedState {
|
||||||
|
boolean showPicturesButtonClicked;
|
||||||
|
|
||||||
|
public static final Parcelable.Creator<SavedState> CREATOR = new Parcelable.Creator<SavedState>() {
|
||||||
|
@Override
|
||||||
|
public SavedState createFromParcel(Parcel in) {
|
||||||
|
return new SavedState(in);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public SavedState[] newArray(int size) {
|
||||||
|
return new SavedState[size];
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
SavedState(Parcelable superState) {
|
||||||
|
super(superState);
|
||||||
|
}
|
||||||
|
|
||||||
|
private SavedState(Parcel in) {
|
||||||
|
super(in);
|
||||||
|
this.showPicturesButtonClicked = (in.readInt() != 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void writeToParcel(Parcel out, int flags) {
|
||||||
|
super.writeToParcel(out, flags);
|
||||||
|
out.writeInt((this.showPicturesButtonClicked) ? 1 : 0);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue