mirror of
https://github.com/moparisthebest/k-9
synced 2025-01-12 06:08:25 -05:00
Extract MessageWebView specific code into a new class
This commit is contained in:
parent
e6a4ef2e8b
commit
5f9eae1580
@ -247,7 +247,7 @@
|
|||||||
|
|
||||||
</LinearLayout>
|
</LinearLayout>
|
||||||
<!-- Content area -->
|
<!-- Content area -->
|
||||||
<WebView
|
<com.fsck.k9.view.MessageWebView
|
||||||
android:id="@+id/message_content"
|
android:id="@+id/message_content"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_width="fill_parent" />
|
android:layout_width="fill_parent" />
|
||||||
|
@ -6,7 +6,6 @@ import java.io.IOException;
|
|||||||
import java.io.InputStream;
|
import java.io.InputStream;
|
||||||
import java.io.OutputStream;
|
import java.io.OutputStream;
|
||||||
import java.io.Serializable;
|
import java.io.Serializable;
|
||||||
import java.lang.reflect.Method;
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.Collection;
|
import java.util.Collection;
|
||||||
import java.util.HashSet;
|
import java.util.HashSet;
|
||||||
@ -16,6 +15,7 @@ import java.util.Set;
|
|||||||
import java.util.regex.Matcher;
|
import java.util.regex.Matcher;
|
||||||
import java.util.regex.Pattern;
|
import java.util.regex.Pattern;
|
||||||
|
|
||||||
|
|
||||||
import org.apache.commons.io.IOUtils;
|
import org.apache.commons.io.IOUtils;
|
||||||
|
|
||||||
import android.app.AlertDialog;
|
import android.app.AlertDialog;
|
||||||
@ -34,7 +34,6 @@ import android.graphics.drawable.Drawable;
|
|||||||
import android.media.MediaScannerConnection;
|
import android.media.MediaScannerConnection;
|
||||||
import android.media.MediaScannerConnection.MediaScannerConnectionClient;
|
import android.media.MediaScannerConnection.MediaScannerConnectionClient;
|
||||||
import android.net.Uri;
|
import android.net.Uri;
|
||||||
import android.os.Build;
|
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.os.Environment;
|
import android.os.Environment;
|
||||||
import android.os.Handler;
|
import android.os.Handler;
|
||||||
@ -56,7 +55,6 @@ import android.view.Window;
|
|||||||
import android.view.animation.AccelerateInterpolator;
|
import android.view.animation.AccelerateInterpolator;
|
||||||
import android.view.animation.Animation;
|
import android.view.animation.Animation;
|
||||||
import android.view.animation.TranslateAnimation;
|
import android.view.animation.TranslateAnimation;
|
||||||
import android.webkit.WebSettings;
|
|
||||||
import android.webkit.WebView;
|
import android.webkit.WebView;
|
||||||
import android.widget.Button;
|
import android.widget.Button;
|
||||||
import android.widget.CheckBox;
|
import android.widget.CheckBox;
|
||||||
@ -90,6 +88,7 @@ import com.fsck.k9.mail.store.LocalStore.LocalMessage;
|
|||||||
import com.fsck.k9.mail.store.LocalStore.LocalTextBody;
|
import com.fsck.k9.mail.store.LocalStore.LocalTextBody;
|
||||||
import com.fsck.k9.provider.AttachmentProvider;
|
import com.fsck.k9.provider.AttachmentProvider;
|
||||||
import com.fsck.k9.view.AccessibleWebView;
|
import com.fsck.k9.view.AccessibleWebView;
|
||||||
|
import com.fsck.k9.view.MessageWebView;
|
||||||
import com.fsck.k9.view.ToggleScrollView;
|
import com.fsck.k9.view.ToggleScrollView;
|
||||||
|
|
||||||
public class MessageView extends K9Activity implements OnClickListener
|
public class MessageView extends K9Activity implements OnClickListener
|
||||||
@ -101,14 +100,6 @@ public class MessageView extends K9Activity implements OnClickListener
|
|||||||
private static final String SHOW_PICTURES = "showPictures";
|
private static final String SHOW_PICTURES = "showPictures";
|
||||||
private static final String STATE_PGP_DATA = "pgpData";
|
private static final String STATE_PGP_DATA = "pgpData";
|
||||||
|
|
||||||
/**
|
|
||||||
* We use WebSettings.getBlockNetworkLoads() to prevent the WebView that displays email
|
|
||||||
* bodies from loading external resources over the network. Unfortunately this method
|
|
||||||
* isn't exposed via the official Android API. That's why we use reflection to be able
|
|
||||||
* to call the method.
|
|
||||||
*/
|
|
||||||
private static final Method mGetBlockNetworkLoads = K9.getMethod(WebSettings.class, "setBlockNetworkLoads");
|
|
||||||
|
|
||||||
private static final int ACTIVITY_CHOOSE_FOLDER_MOVE = 1;
|
private static final int ACTIVITY_CHOOSE_FOLDER_MOVE = 1;
|
||||||
private static final int ACTIVITY_CHOOSE_FOLDER_COPY = 2;
|
private static final int ACTIVITY_CHOOSE_FOLDER_COPY = 2;
|
||||||
|
|
||||||
@ -127,7 +118,7 @@ public class MessageView extends K9Activity implements OnClickListener
|
|||||||
private ImageView mCryptoSignatureStatusImage = null;
|
private ImageView mCryptoSignatureStatusImage = null;
|
||||||
private TextView mCryptoSignatureUserId = null;
|
private TextView mCryptoSignatureUserId = null;
|
||||||
private TextView mCryptoSignatureUserIdRest = null;
|
private TextView mCryptoSignatureUserIdRest = null;
|
||||||
private WebView mMessageContentView;
|
private MessageWebView mMessageContentView;
|
||||||
|
|
||||||
private boolean mScreenReaderEnabled;
|
private boolean mScreenReaderEnabled;
|
||||||
|
|
||||||
@ -845,7 +836,7 @@ public class MessageView extends K9Activity implements OnClickListener
|
|||||||
mDateView = (TextView)findViewById(R.id.date);
|
mDateView = (TextView)findViewById(R.id.date);
|
||||||
mTimeView = (TextView)findViewById(R.id.time);
|
mTimeView = (TextView)findViewById(R.id.time);
|
||||||
mTopView = mToggleScrollView = (ToggleScrollView)findViewById(R.id.top_view);
|
mTopView = mToggleScrollView = (ToggleScrollView)findViewById(R.id.top_view);
|
||||||
mMessageContentView = (WebView)findViewById(R.id.message_content);
|
mMessageContentView = (MessageWebView)findViewById(R.id.message_content);
|
||||||
mAccessibleMessageContentView = (AccessibleWebView) findViewById(R.id.accessible_message_content);
|
mAccessibleMessageContentView = (AccessibleWebView) findViewById(R.id.accessible_message_content);
|
||||||
|
|
||||||
mScreenReaderEnabled = isScreenReaderActive();
|
mScreenReaderEnabled = isScreenReaderActive();
|
||||||
@ -914,7 +905,7 @@ public class MessageView extends K9Activity implements OnClickListener
|
|||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
MessageView.configureMessageWebView(mMessageContentView);
|
mMessageContentView.configure();
|
||||||
|
|
||||||
|
|
||||||
mFromView.setTextSize(TypedValue.COMPLEX_UNIT_DIP, mFontSizes.getMessageViewSender());
|
mFromView.setTextSize(TypedValue.COMPLEX_UNIT_DIP, mFontSizes.getMessageViewSender());
|
||||||
@ -1861,7 +1852,7 @@ public class MessageView extends K9Activity implements OnClickListener
|
|||||||
*/
|
*/
|
||||||
private void setLoadPictures(boolean enable)
|
private void setLoadPictures(boolean enable)
|
||||||
{
|
{
|
||||||
blockNetworkDataInWebView(mMessageContentView, !enable);
|
mMessageContentView.blockNetworkData(!enable);
|
||||||
mShowPictures = enable;
|
mShowPictures = enable;
|
||||||
mHandler.showShowPictures(false);
|
mHandler.showShowPictures(false);
|
||||||
}
|
}
|
||||||
@ -2759,80 +2750,4 @@ public class MessageView extends K9Activity implements OnClickListener
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Configure a {@link android.webkit.WebView} to display a Message. This method takes into account a user's
|
|
||||||
* preferences when configuring the view. This message is used to view a message and to display a message being
|
|
||||||
* replied to.
|
|
||||||
* @param view WebView to configure.
|
|
||||||
*/
|
|
||||||
public static void configureMessageWebView(final WebView view)
|
|
||||||
{
|
|
||||||
view.setVerticalScrollBarEnabled(true);
|
|
||||||
view.setVerticalScrollbarOverlay(true);
|
|
||||||
view.setScrollBarStyle(View.SCROLLBARS_INSIDE_OVERLAY);
|
|
||||||
|
|
||||||
|
|
||||||
final WebSettings webSettings = view.getSettings();
|
|
||||||
|
|
||||||
webSettings.setCacheMode(WebSettings.LOAD_NO_CACHE);
|
|
||||||
webSettings.setSupportZoom(true);
|
|
||||||
webSettings.setJavaScriptEnabled(false);
|
|
||||||
webSettings.setLoadsImagesAutomatically(true);
|
|
||||||
webSettings.setRenderPriority(WebSettings.RenderPriority.HIGH);
|
|
||||||
|
|
||||||
if (K9.zoomControlsEnabled())
|
|
||||||
{
|
|
||||||
webSettings.setBuiltInZoomControls(true);
|
|
||||||
}
|
|
||||||
|
|
||||||
// SINGLE_COLUMN layout was broken on Android < 2.2, so we
|
|
||||||
// administratively disable it
|
|
||||||
if (
|
|
||||||
( Integer.parseInt(Build.VERSION.SDK) > 7)
|
|
||||||
&& K9.mobileOptimizedLayout())
|
|
||||||
{
|
|
||||||
webSettings.setLayoutAlgorithm(WebSettings.LayoutAlgorithm.SINGLE_COLUMN);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
webSettings.setLayoutAlgorithm(WebSettings.LayoutAlgorithm.NARROW_COLUMNS);
|
|
||||||
}
|
|
||||||
|
|
||||||
webSettings.setTextSize(K9.getFontSizes().getMessageViewContent());
|
|
||||||
|
|
||||||
// Disable network images by default. This is overriden by preferences.
|
|
||||||
blockNetworkDataInWebView(view, true);
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Configure a web view to load or not load network data. A <b>true</b> setting here means that
|
|
||||||
* network data will be blocked.
|
|
||||||
* @param view {@link android.webkit.WebView} to adjust network data settings on.
|
|
||||||
* @param shouldBlockNetworkData True if network data should be blocked, false to allow network data.
|
|
||||||
*/
|
|
||||||
public static void blockNetworkDataInWebView(final WebView view, final boolean shouldBlockNetworkData)
|
|
||||||
{
|
|
||||||
// Sanity check to make sure we don't blow up.
|
|
||||||
if (view == null || view.getSettings() == null)
|
|
||||||
{
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Block network loads.
|
|
||||||
if (mGetBlockNetworkLoads != null)
|
|
||||||
{
|
|
||||||
try
|
|
||||||
{
|
|
||||||
mGetBlockNetworkLoads.invoke(view.getSettings(), shouldBlockNetworkData);
|
|
||||||
}
|
|
||||||
catch (Exception e)
|
|
||||||
{
|
|
||||||
Log.e(K9.LOG_TAG, "Error on invoking WebSettings.setBlockNetworkLoads()", e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Block network images.
|
|
||||||
view.getSettings().setBlockNetworkImage(shouldBlockNetworkData);
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
120
src/com/fsck/k9/view/MessageWebView.java
Normal file
120
src/com/fsck/k9/view/MessageWebView.java
Normal file
@ -0,0 +1,120 @@
|
|||||||
|
package com.fsck.k9.view;
|
||||||
|
|
||||||
|
import android.content.Context;
|
||||||
|
import android.os.Build;
|
||||||
|
import android.util.AttributeSet;
|
||||||
|
import android.util.Log;
|
||||||
|
import android.webkit.WebSettings;
|
||||||
|
import android.webkit.WebView;
|
||||||
|
import com.fsck.k9.K9;
|
||||||
|
|
||||||
|
import java.lang.reflect.Method;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Created by IntelliJ IDEA.
|
||||||
|
* User: jesse
|
||||||
|
* Date: 12/25/10
|
||||||
|
* Time: 3:57 PM
|
||||||
|
* To change this template use File | Settings | File Templates.
|
||||||
|
*/
|
||||||
|
public class MessageWebView extends WebView {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* We use WebSettings.getBlockNetworkLoads() to prevent the WebView that displays email
|
||||||
|
* bodies from loading external resources over the network. Unfortunately this method
|
||||||
|
* isn't exposed via the official Android API. That's why we use reflection to be able
|
||||||
|
* to call the method.
|
||||||
|
*/
|
||||||
|
public static final Method mGetBlockNetworkLoads = K9.getMethod(WebSettings.class, "setBlockNetworkLoads");
|
||||||
|
|
||||||
|
public MessageWebView(Context context)
|
||||||
|
{
|
||||||
|
super(context);
|
||||||
|
}
|
||||||
|
|
||||||
|
public MessageWebView(Context context, AttributeSet attrs)
|
||||||
|
{
|
||||||
|
super(context, attrs);
|
||||||
|
}
|
||||||
|
|
||||||
|
public MessageWebView(Context context, AttributeSet attrs, int defStyle)
|
||||||
|
{
|
||||||
|
super(context, attrs, defStyle);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Configure a web view to load or not load network data. A <b>true</b> setting here means that
|
||||||
|
* network data will be blocked.
|
||||||
|
* @param view {@link android.webkit.WebView} to adjust network data settings on.
|
||||||
|
* @param shouldBlockNetworkData True if network data should be blocked, false to allow network data.
|
||||||
|
*/
|
||||||
|
public void blockNetworkData(final boolean shouldBlockNetworkData)
|
||||||
|
{
|
||||||
|
// Sanity check to make sure we don't blow up.
|
||||||
|
if (getSettings() == null)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Block network loads.
|
||||||
|
if (mGetBlockNetworkLoads != null)
|
||||||
|
{
|
||||||
|
try
|
||||||
|
{
|
||||||
|
mGetBlockNetworkLoads.invoke(getSettings(), shouldBlockNetworkData);
|
||||||
|
}
|
||||||
|
catch (Exception e)
|
||||||
|
{
|
||||||
|
Log.e(K9.LOG_TAG, "Error on invoking WebSettings.setBlockNetworkLoads()", e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Block network images.
|
||||||
|
getSettings().setBlockNetworkImage(shouldBlockNetworkData);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Configure a {@link android.webkit.WebView} to display a Message. This method takes into account a user's
|
||||||
|
* preferences when configuring the view. This message is used to view a message and to display a message being
|
||||||
|
* replied to.
|
||||||
|
*/
|
||||||
|
public void configure()
|
||||||
|
{
|
||||||
|
this.setVerticalScrollBarEnabled(true);
|
||||||
|
this.setVerticalScrollbarOverlay(true);
|
||||||
|
this.setScrollBarStyle(SCROLLBARS_INSIDE_OVERLAY);
|
||||||
|
|
||||||
|
|
||||||
|
final WebSettings webSettings = this.getSettings();
|
||||||
|
|
||||||
|
webSettings.setCacheMode(WebSettings.LOAD_NO_CACHE);
|
||||||
|
webSettings.setSupportZoom(true);
|
||||||
|
webSettings.setJavaScriptEnabled(false);
|
||||||
|
webSettings.setLoadsImagesAutomatically(true);
|
||||||
|
webSettings.setRenderPriority(WebSettings.RenderPriority.HIGH);
|
||||||
|
|
||||||
|
if (K9.zoomControlsEnabled())
|
||||||
|
{
|
||||||
|
webSettings.setBuiltInZoomControls(true);
|
||||||
|
}
|
||||||
|
|
||||||
|
// SINGLE_COLUMN layout was broken on Android < 2.2, so we
|
||||||
|
// administratively disable it
|
||||||
|
if (
|
||||||
|
( Integer.parseInt(Build.VERSION.SDK) > 7)
|
||||||
|
&& K9.mobileOptimizedLayout())
|
||||||
|
{
|
||||||
|
webSettings.setLayoutAlgorithm(WebSettings.LayoutAlgorithm.SINGLE_COLUMN);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
webSettings.setLayoutAlgorithm(WebSettings.LayoutAlgorithm.NARROW_COLUMNS);
|
||||||
|
}
|
||||||
|
|
||||||
|
webSettings.setTextSize(K9.getFontSizes().getMessageViewContent());
|
||||||
|
|
||||||
|
// Disable network images by default. This is overriden by preferences.
|
||||||
|
blockNetworkData(true);
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user