Index: chrome/android/java_staging/src/org/chromium/chrome/browser/webapps/WebappUrlBar.java |
diff --git a/chrome/android/java_staging/src/org/chromium/chrome/browser/webapps/WebappUrlBar.java b/chrome/android/java_staging/src/org/chromium/chrome/browser/webapps/WebappUrlBar.java |
deleted file mode 100644 |
index 78e11b60ec19e62744e9e197226515be21113f56..0000000000000000000000000000000000000000 |
--- a/chrome/android/java_staging/src/org/chromium/chrome/browser/webapps/WebappUrlBar.java |
+++ /dev/null |
@@ -1,172 +0,0 @@ |
-// Copyright 2015 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.chrome.browser.webapps; |
- |
-import android.content.Context; |
-import android.graphics.drawable.Drawable; |
-import android.text.Layout; |
-import android.text.TextUtils; |
-import android.text.method.ScrollingMovementMethod; |
-import android.util.AttributeSet; |
-import android.util.Log; |
-import android.util.SparseIntArray; |
-import android.view.Gravity; |
-import android.view.View; |
-import android.view.ViewGroup; |
-import android.widget.FrameLayout; |
-import android.widget.TextView; |
- |
-import org.chromium.base.ApiCompatibilityUtils; |
-import org.chromium.base.VisibleForTesting; |
-import org.chromium.chrome.R; |
-import org.chromium.chrome.browser.UrlUtilities; |
-import org.chromium.chrome.browser.omnibox.LocationBarLayout; |
- |
-import java.net.URI; |
- |
-/** |
- * Maintains a URL bar that is displayed above the webapp's content. |
- * For security reasons, this bar will appear when a user navigates to a website that is not |
- * considered the same as the one that was used to open a WebappActivity originally. |
- * The URL bar will disappear again once the user navigates back to the original website. |
- * |
- * Example scenario: |
- * 0) User opens a webapp for http://domain1.com. URL bar is hidden |
- * 1) User navigates to http://domain1.com/some.html URL bar is hidden |
- * 2) User navigates to http://domain2.com/ URL bar is shown |
- * 3) User navigates back to http://domain1.com/some.html URL bar is hidden |
- */ |
-public class WebappUrlBar extends FrameLayout implements View.OnLayoutChangeListener { |
- private static final String TAG = "WebappUrlBar"; |
- |
- private final TextView mUrlBar; |
- private final View mSeparator; |
- private final SparseIntArray mIconResourceWidths; |
- |
- private String mCurrentlyDisplayedUrl; |
- private int mCurrentIconResource; |
- |
- /** |
- * Creates a WebappUrlBar. |
- * @param context Context to grab resources from. |
- */ |
- public WebappUrlBar(Context context, AttributeSet attrSet) { |
- super(context, attrSet); |
- mIconResourceWidths = new SparseIntArray(); |
- |
- mUrlBar = new TextView(context); |
- mUrlBar.setSingleLine(true); |
- mUrlBar.setMovementMethod(ScrollingMovementMethod.getInstance()); |
- mUrlBar.setHorizontalFadingEdgeEnabled(true); |
- mSeparator = new View(context); |
- |
- addView(mUrlBar, |
- new FrameLayout.LayoutParams( |
- ViewGroup.LayoutParams.WRAP_CONTENT, ViewGroup.LayoutParams.WRAP_CONTENT, |
- Gravity.CENTER)); |
- addView(mSeparator, |
- new FrameLayout.LayoutParams( |
- ViewGroup.LayoutParams.MATCH_PARENT, 1, Gravity.BOTTOM)); |
- |
- // Set the colors. |
- mSeparator.setBackgroundColor( |
- context.getResources().getColor(R.color.webapp_url_bar_separator)); |
- setBackgroundColor(context.getResources().getColor(R.color.webapp_url_bar_bg)); |
- |
- // Listen for changes in the URL bar's size. |
- mUrlBar.addOnLayoutChangeListener(this); |
- } |
- |
- /** |
- * Updates the URL bar for the current URL. |
- * @param url URL to display. |
- * @param securityLevel Security level of the Tab. |
- */ |
- public void update(String url, int securityLevel) { |
- URI uri = createURI(url); |
- updateSecurityIcon(securityLevel); |
- updateDisplayedUrl(url, uri); |
- } |
- |
- /** |
- * @return the security icon being displayed for the current URL. |
- */ |
- @VisibleForTesting |
- protected int getCurrentIconResourceForTests() { |
- return mCurrentIconResource; |
- } |
- |
- /** |
- * @return the URL being displayed. |
- */ |
- @VisibleForTesting |
- protected CharSequence getDisplayedUrlForTests() { |
- return mUrlBar.getText(); |
- } |
- |
- /** |
- * Show the end of the URL rather than the beginning. |
- */ |
- @Override |
- public void onLayoutChange(View v, int left, int top, int right, int bottom, int oldLeft, |
- int oldTop, int oldRight, int oldBottom) { |
- Layout layout = mUrlBar.getLayout(); |
- if (layout == null) return; |
- |
- // Android doesn't account for the compound Drawable in its width calculations, leading to |
- // improper scrolling and even Android improperly placing the horizontal fade in its |
- // TextView calculation. Get around it by calculating that width manually: crbug.com/303908 |
- int urlBarWidth = mUrlBar.getWidth(); |
- int iconWidth = |
- mCurrentIconResource == 0 ? 0 : mIconResourceWidths.get(mCurrentIconResource); |
- int availableTextWidth = urlBarWidth - iconWidth; |
- int desiredWidth = (int) Layout.getDesiredWidth(layout.getText(), layout.getPaint()); |
- |
- if (desiredWidth > availableTextWidth) { |
- mUrlBar.scrollTo(desiredWidth - availableTextWidth, 0); |
- } else { |
- mUrlBar.scrollTo(0, 0); |
- } |
- } |
- |
- private static URI createURI(String url) { |
- // Get rid of spaces temporarily: crbug.com/298465 |
- // Get rid of the need for this hack eventually: crbug.com/296870 |
- url = url.replace(" ", "%20"); |
- |
- try { |
- return URI.create(url); |
- } catch (IllegalArgumentException exception) { |
- Log.e(TAG, "Failed to convert URI: ", exception); |
- return null; |
- } |
- } |
- |
- private void updateSecurityIcon(int securityLevel) { |
- mCurrentIconResource = LocationBarLayout.getSecurityIconResource(securityLevel, false); |
- |
- if (mCurrentIconResource != 0 && mIconResourceWidths.get(mCurrentIconResource, -1) == -1) { |
- Drawable icon = ApiCompatibilityUtils.getDrawable(getResources(), mCurrentIconResource); |
- mIconResourceWidths.put(mCurrentIconResource, icon.getIntrinsicWidth()); |
- } |
- |
- ApiCompatibilityUtils.setCompoundDrawablesRelativeWithIntrinsicBounds(mUrlBar, |
- mCurrentIconResource, 0, 0, 0); |
- } |
- |
- private void updateDisplayedUrl(String originalUrl, URI uri) { |
- boolean showScheme = mCurrentIconResource == 0; |
- String displayUrl = originalUrl; |
- if (uri != null) { |
- String shortenedUrl = UrlUtilities.getOriginForDisplay(uri, showScheme); |
- if (!TextUtils.isEmpty(shortenedUrl)) displayUrl = shortenedUrl; |
- } |
- |
- mUrlBar.setText(displayUrl); |
- if (!TextUtils.equals(mCurrentlyDisplayedUrl, displayUrl)) { |
- mCurrentlyDisplayedUrl = displayUrl; |
- } |
- } |
-} |