Index: content/shell/android/java/org/chromium/content_shell/ShellView.java |
diff --git a/content/shell/android/java/org/chromium/content_shell/ShellView.java b/content/shell/android/java/org/chromium/content_shell/ShellView.java |
new file mode 100644 |
index 0000000000000000000000000000000000000000..0e090868b801e3f80b26864091bfd825a0ce480c |
--- /dev/null |
+++ b/content/shell/android/java/org/chromium/content_shell/ShellView.java |
@@ -0,0 +1,167 @@ |
+// Copyright (c) 2012 The Chromium Authors. All rights reserved. |
+// Use of this source code is governed by a BSD-style license that can be |
+// found in the LICENSE file. |
+ |
+package org.chromium.content_shell; |
+ |
+import android.content.Context; |
+import android.graphics.drawable.ClipDrawable; |
+import android.text.TextUtils; |
+import android.util.AttributeSet; |
+import android.view.KeyEvent; |
+import android.view.View; |
+import android.view.inputmethod.EditorInfo; |
+import android.view.inputmethod.InputMethodManager; |
+import android.widget.EditText; |
+import android.widget.FrameLayout; |
+import android.widget.ImageButton; |
+import android.widget.LinearLayout; |
+import android.widget.TextView; |
+import android.widget.TextView.OnEditorActionListener; |
+ |
+import org.chromium.base.CalledByNative; |
+import org.chromium.content.browser.ContentView; |
+ |
+/** |
+ * Container for the various UI components that make up a shell window. |
+ */ |
+public class ShellView extends LinearLayout { |
+ |
+ private static final long COMPLETED_PROGRESS_TIMEOUT_MS = 200; |
+ |
+ private int mNativeShellView; |
+ private ContentView mContentView; |
+ private EditText mUrlTextView; |
+ private ImageButton mPrevButton; |
+ private ImageButton mNextButton; |
+ |
+ private ClipDrawable mProgressDrawable; |
+ |
+ /** |
+ * Constructor for inflating via XML. |
+ */ |
+ public ShellView(Context context, AttributeSet attrs) { |
+ super(context, attrs); |
+ |
+ mNativeShellView = nativeInit(); |
+ } |
+ |
+ @Override |
+ protected void onFinishInflate() { |
+ super.onFinishInflate(); |
+ |
+ mProgressDrawable = (ClipDrawable) findViewById(R.id.toolbar).getBackground(); |
+ |
+ initilizeUrlField(); |
+ initializeNavigationButtons(); |
+ } |
+ |
+ /** |
+ * @return the native shell view pointer. |
+ */ |
+ protected int getNativeShellView() { |
+ return mNativeShellView; |
+ } |
+ |
+ private void initilizeUrlField() { |
+ mUrlTextView = (EditText) findViewById(R.id.url); |
+ mUrlTextView.setOnEditorActionListener(new OnEditorActionListener() { |
+ @Override |
+ public boolean onEditorAction(TextView v, int actionId, KeyEvent event) { |
+ if (actionId != EditorInfo.IME_ACTION_GO) return false; |
+ loadUrl(mUrlTextView.getText().toString()); |
+ setKeyboardVisibilityForUrl(false); |
+ mUrlTextView.clearFocus(); |
+ return true; |
+ } |
+ }); |
+ mUrlTextView.setOnFocusChangeListener(new OnFocusChangeListener() { |
+ @Override |
+ public void onFocusChange(View v, boolean hasFocus) { |
+ setKeyboardVisibilityForUrl(hasFocus); |
+ mNextButton.setVisibility(hasFocus ? GONE : VISIBLE); |
+ mPrevButton.setVisibility(hasFocus ? GONE : VISIBLE); |
+ } |
+ }); |
+ } |
+ |
+ /** |
+ * Loads an URL. This will perform minimal amounts of sanitizing of the URL to attempt to |
+ * make it valid. |
+ * |
+ * @param url The URL to be loaded by the shell. |
+ */ |
+ public void loadUrl(String url) { |
+ if (url == null) return; |
+ |
+ if (TextUtils.equals(url, mContentView.getUrl())) { |
+ mContentView.reload(); |
+ } else { |
+ mContentView.loadUrlWithoutUrlSanitization(sanitizeUrl(url)); |
+ } |
+ mUrlTextView.clearFocus(); |
+ } |
+ |
+ /** |
+ * Given an URL, this performs minimal sanitizing to ensure it will be valid. |
+ * @param url The url to be sanitized. |
+ * @return The sanitized URL. |
+ */ |
+ public static String sanitizeUrl(String url) { |
+ if (url == null) return url; |
+ if (url.startsWith("www.") || url.indexOf(":") == -1) url = "http://" + url; |
+ return url; |
+ } |
+ |
+ private void initializeNavigationButtons() { |
+ mPrevButton = (ImageButton) findViewById(R.id.prev); |
+ mPrevButton.setOnClickListener(new OnClickListener() { |
+ @Override |
+ public void onClick(View v) { |
+ if (mContentView.canGoBack()) mContentView.goBack(); |
+ } |
+ }); |
+ |
+ mNextButton = (ImageButton) findViewById(R.id.next); |
+ mNextButton.setOnClickListener(new OnClickListener() { |
+ @Override |
+ public void onClick(View v) { |
+ if (mContentView.canGoForward()) mContentView.goForward(); |
+ } |
+ }); |
+ } |
+ |
+ /** |
+ * Initializes the ContentView based on the native tab contents pointer passed in. |
+ * @param nativeTabContents The pointer to the native tab contents object. |
+ */ |
+ @SuppressWarnings("unused") |
+ @CalledByNative |
+ private void initFromNativeTabContents(int nativeTabContents) { |
+ // TODO(tedchoc): Pass along native tab contents. |
+ mContentView = new ContentView(getContext()); |
+ ((FrameLayout) findViewById(R.id.contentview_holder)).addView(mContentView, |
+ new FrameLayout.LayoutParams( |
+ FrameLayout.LayoutParams.MATCH_PARENT, |
+ FrameLayout.LayoutParams.MATCH_PARENT)); |
+ } |
+ |
+ /** |
+ * @return The {@link ContentView} currently shown by this Shell. |
+ */ |
+ public ContentView getContentView() { |
+ return mContentView; |
+ } |
+ |
+ private void setKeyboardVisibilityForUrl(boolean visible) { |
+ InputMethodManager imm = (InputMethodManager) getContext().getSystemService( |
+ Context.INPUT_METHOD_SERVICE); |
+ if (visible) { |
+ imm.showSoftInput(mUrlTextView, InputMethodManager.SHOW_IMPLICIT); |
+ } else { |
+ imm.hideSoftInputFromWindow(mUrlTextView.getWindowToken(), 0); |
+ } |
+ } |
+ |
+ private native int nativeInit(); |
+} |