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:
Trogel 2017-08-30 10:57:55 +02:00 committed by cketti
parent affc41c853
commit c505083d6b
2 changed files with 56 additions and 79 deletions

View file

@ -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();
} }

View file

@ -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);
}
}
} }