Fix bug where AutoCompleteTextView selected text but didn't delete it when typing
Also added in window focus change callback so that we can animate UI in correctly. Also other small changes
This commit is contained in:
parent
e11a718d3b
commit
b7f3defd19
@ -43,6 +43,7 @@ import android.support.v7.app.ActionBar;
|
|||||||
import android.support.v7.app.AlertDialog;
|
import android.support.v7.app.AlertDialog;
|
||||||
import android.support.v7.graphics.Palette;
|
import android.support.v7.graphics.Palette;
|
||||||
import android.support.v7.widget.Toolbar;
|
import android.support.v7.widget.Toolbar;
|
||||||
|
import android.text.Selection;
|
||||||
import android.util.Log;
|
import android.util.Log;
|
||||||
import android.view.KeyEvent;
|
import android.view.KeyEvent;
|
||||||
import android.view.Menu;
|
import android.view.Menu;
|
||||||
@ -125,6 +126,7 @@ import acr.browser.lightning.utils.Utils;
|
|||||||
import acr.browser.lightning.utils.WebUtils;
|
import acr.browser.lightning.utils.WebUtils;
|
||||||
import acr.browser.lightning.view.AnimatedProgressBar;
|
import acr.browser.lightning.view.AnimatedProgressBar;
|
||||||
import acr.browser.lightning.view.LightningView;
|
import acr.browser.lightning.view.LightningView;
|
||||||
|
import acr.browser.lightning.view.SearchView;
|
||||||
import butterknife.Bind;
|
import butterknife.Bind;
|
||||||
import butterknife.ButterKnife;
|
import butterknife.ButterKnife;
|
||||||
|
|
||||||
@ -152,7 +154,7 @@ public abstract class BrowserActivity extends ThemableBrowserActivity implements
|
|||||||
// Toolbar Views
|
// Toolbar Views
|
||||||
private View mSearchBackground;
|
private View mSearchBackground;
|
||||||
private Toolbar mToolbar;
|
private Toolbar mToolbar;
|
||||||
private AutoCompleteTextView mSearch;
|
private SearchView mSearch;
|
||||||
private ImageView mArrowImage;
|
private ImageView mArrowImage;
|
||||||
|
|
||||||
// Current tab view being displayed
|
// Current tab view being displayed
|
||||||
@ -372,7 +374,7 @@ public abstract class BrowserActivity extends ThemableBrowserActivity implements
|
|||||||
arrowButton.setOnClickListener(this);
|
arrowButton.setOnClickListener(this);
|
||||||
|
|
||||||
// create the search EditText in the ToolBar
|
// create the search EditText in the ToolBar
|
||||||
mSearch = (AutoCompleteTextView) customView.findViewById(R.id.search);
|
mSearch = (SearchView) customView.findViewById(R.id.search);
|
||||||
mSearchBackground = customView.findViewById(R.id.search_container);
|
mSearchBackground = customView.findViewById(R.id.search_container);
|
||||||
|
|
||||||
// initialize search background color
|
// initialize search background color
|
||||||
@ -397,6 +399,7 @@ public abstract class BrowserActivity extends ThemableBrowserActivity implements
|
|||||||
mSearch.setOnFocusChangeListener(search);
|
mSearch.setOnFocusChangeListener(search);
|
||||||
mSearch.setOnEditorActionListener(search);
|
mSearch.setOnEditorActionListener(search);
|
||||||
mSearch.setOnTouchListener(search);
|
mSearch.setOnTouchListener(search);
|
||||||
|
mSearch.setOnPreFocusListener(search);
|
||||||
|
|
||||||
initializeSearchSuggestions(mSearch);
|
initializeSearchSuggestions(mSearch);
|
||||||
|
|
||||||
@ -437,12 +440,13 @@ public abstract class BrowserActivity extends ThemableBrowserActivity implements
|
|||||||
System.exit(1);
|
System.exit(1);
|
||||||
}
|
}
|
||||||
|
|
||||||
private class SearchListenerClass implements OnKeyListener, OnEditorActionListener, OnFocusChangeListener, OnTouchListener {
|
private class SearchListenerClass implements OnKeyListener, OnEditorActionListener,
|
||||||
|
OnFocusChangeListener, OnTouchListener, SearchView.PreFocusListener {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean onKey(View arg0, int arg1, KeyEvent arg2) {
|
public boolean onKey(View searchView, int keyCode, KeyEvent keyEvent) {
|
||||||
|
|
||||||
switch (arg1) {
|
switch (keyCode) {
|
||||||
case KeyEvent.KEYCODE_ENTER:
|
case KeyEvent.KEYCODE_ENTER:
|
||||||
InputMethodManager imm = (InputMethodManager) getSystemService(Context.INPUT_METHOD_SERVICE);
|
InputMethodManager imm = (InputMethodManager) getSystemService(Context.INPUT_METHOD_SERVICE);
|
||||||
imm.hideSoftInputFromWindow(mSearch.getWindowToken(), 0);
|
imm.hideSoftInputFromWindow(mSearch.getWindowToken(), 0);
|
||||||
@ -480,20 +484,15 @@ public abstract class BrowserActivity extends ThemableBrowserActivity implements
|
|||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onFocusChange(View v, final boolean hasFocus) {
|
public void onFocusChange(final View v, final boolean hasFocus) {
|
||||||
final LightningView currentView = mTabsManager.getCurrentTab();
|
final LightningView currentView = mTabsManager.getCurrentTab();
|
||||||
if (!hasFocus && currentView != null) {
|
if (!hasFocus && currentView != null) {
|
||||||
setIsLoading(currentView.getProgress() < 100);
|
setIsLoading(currentView.getProgress() < 100);
|
||||||
updateUrl(currentView.getUrl(), true);
|
updateUrl(currentView.getUrl(), true);
|
||||||
} else if (hasFocus && currentView != null) {
|
} else if (hasFocus && currentView != null) {
|
||||||
String url = currentView.getUrl();
|
|
||||||
if (UrlUtils.isSpecialUrl(url)) {
|
|
||||||
mSearch.setText("");
|
|
||||||
} else {
|
|
||||||
mSearch.setText(url);
|
|
||||||
}
|
|
||||||
// Hack to make sure the text gets selected
|
// Hack to make sure the text gets selected
|
||||||
((AutoCompleteTextView) v).selectAll();
|
((SearchView) v).selectAll();
|
||||||
mIcon = mClearIcon;
|
mIcon = mClearIcon;
|
||||||
mSearch.setCompoundDrawables(null, null, mClearIcon, null);
|
mSearch.setCompoundDrawables(null, null, mClearIcon, null);
|
||||||
}
|
}
|
||||||
@ -522,6 +521,20 @@ public abstract class BrowserActivity extends ThemableBrowserActivity implements
|
|||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onPreFocus() {
|
||||||
|
final LightningView currentView = mTabsManager.getCurrentTab();
|
||||||
|
if (currentView == null) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
String url = currentView.getUrl();
|
||||||
|
if (UrlUtils.isSpecialUrl(url)) {
|
||||||
|
mSearch.setText("");
|
||||||
|
} else {
|
||||||
|
mSearch.setText(url);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private class DrawerLocker implements DrawerListener {
|
private class DrawerLocker implements DrawerListener {
|
||||||
@ -612,8 +625,6 @@ public abstract class BrowserActivity extends ThemableBrowserActivity implements
|
|||||||
// TODO layout transition causing memory leak
|
// TODO layout transition causing memory leak
|
||||||
// mBrowserFrame.setLayoutTransition(new LayoutTransition());
|
// mBrowserFrame.setLayoutTransition(new LayoutTransition());
|
||||||
|
|
||||||
mToolbarLayout.setTranslationY(0);
|
|
||||||
mBrowserFrame.setTranslationY(0);
|
|
||||||
setFullscreen(mPreferences.getHideStatusBarEnabled(), false);
|
setFullscreen(mPreferences.getHideStatusBarEnabled(), false);
|
||||||
|
|
||||||
initializeTabHeight();
|
initializeTabHeight();
|
||||||
@ -675,6 +686,13 @@ public abstract class BrowserActivity extends ThemableBrowserActivity implements
|
|||||||
mProxyUtils.updateProxySettings(this);
|
mProxyUtils.updateProxySettings(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onWindowVisibleToUserAfterResume() {
|
||||||
|
super.onWindowVisibleToUserAfterResume();
|
||||||
|
mToolbarLayout.setTranslationY(0);
|
||||||
|
mBrowserFrame.setTranslationY(0);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean onKeyDown(int keyCode, KeyEvent event) {
|
public boolean onKeyDown(int keyCode, KeyEvent event) {
|
||||||
if (keyCode == KeyEvent.KEYCODE_ENTER) {
|
if (keyCode == KeyEvent.KEYCODE_ENTER) {
|
||||||
@ -925,7 +943,7 @@ public abstract class BrowserActivity extends ThemableBrowserActivity implements
|
|||||||
// Use a delayed handler to make the transition smooth
|
// Use a delayed handler to make the transition smooth
|
||||||
// otherwise it will get caught up with the showTab code
|
// otherwise it will get caught up with the showTab code
|
||||||
// and cause a janky motion
|
// and cause a janky motion
|
||||||
mDrawerHandler.postDelayed(new Runnable() {
|
mDrawerHandler.postDelayed(new Runnable() {
|
||||||
@Override
|
@Override
|
||||||
public void run() {
|
public void run() {
|
||||||
mDrawerLayout.closeDrawers();
|
mDrawerLayout.closeDrawers();
|
||||||
@ -1230,9 +1248,8 @@ public abstract class BrowserActivity extends ThemableBrowserActivity implements
|
|||||||
mSuggestionsAdapter.refreshPreferences();
|
mSuggestionsAdapter.refreshPreferences();
|
||||||
mSuggestionsAdapter.refreshBookmarks();
|
mSuggestionsAdapter.refreshBookmarks();
|
||||||
}
|
}
|
||||||
mTabsManager.resumeAll();
|
mTabsManager.resumeAll(this);
|
||||||
initializePreferences();
|
initializePreferences();
|
||||||
mTabsManager.resume(this);
|
|
||||||
|
|
||||||
supportInvalidateOptionsMenu();
|
supportInvalidateOptionsMenu();
|
||||||
|
|
||||||
@ -1888,6 +1905,7 @@ public abstract class BrowserActivity extends ThemableBrowserActivity implements
|
|||||||
@Override
|
@Override
|
||||||
public void showActionBar() {
|
public void showActionBar() {
|
||||||
if (mFullScreen) {
|
if (mFullScreen) {
|
||||||
|
Log.d(TAG, "showActionBar");
|
||||||
if (mToolbarLayout == null)
|
if (mToolbarLayout == null)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
|
@ -196,8 +196,11 @@ public class TabsManager {
|
|||||||
* WebView when the app is open currently due to a
|
* WebView when the app is open currently due to a
|
||||||
* bug in the WebView, where calling onResume doesn't
|
* bug in the WebView, where calling onResume doesn't
|
||||||
* consistently resume it.
|
* consistently resume it.
|
||||||
|
*
|
||||||
|
* @param context the context needed to initialize
|
||||||
|
* the LightningView preferences.
|
||||||
*/
|
*/
|
||||||
public void resumeAll() {
|
public void resumeAll(@NonNull Context context) {
|
||||||
LightningView current = getCurrentTab();
|
LightningView current = getCurrentTab();
|
||||||
if (current != null) {
|
if (current != null) {
|
||||||
current.resumeTimers();
|
current.resumeTimers();
|
||||||
@ -205,6 +208,7 @@ public class TabsManager {
|
|||||||
for (LightningView tab : mTabList) {
|
for (LightningView tab : mTabList) {
|
||||||
if (tab != null) {
|
if (tab != null) {
|
||||||
tab.onResume();
|
tab.onResume();
|
||||||
|
tab.initializePreferences(context);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -274,19 +278,6 @@ public class TabsManager {
|
|||||||
mCurrentTab = null;
|
mCurrentTab = null;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Reinitializes the preferences for
|
|
||||||
* all the tabs in the list.
|
|
||||||
*
|
|
||||||
* @param context the context needed
|
|
||||||
* to initialize the preferences.
|
|
||||||
*/
|
|
||||||
public synchronized void resume(@NonNull final Context context) {
|
|
||||||
for (LightningView tab : mTabList) {
|
|
||||||
tab.initializePreferences(context);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Forwards network connection status to the WebViews.
|
* Forwards network connection status to the WebViews.
|
||||||
*
|
*
|
||||||
|
@ -3,8 +3,12 @@ package acr.browser.lightning.activity;
|
|||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.content.res.Configuration;
|
import android.content.res.Configuration;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
|
import android.support.annotation.NonNull;
|
||||||
import android.support.v7.app.AppCompatActivity;
|
import android.support.v7.app.AppCompatActivity;
|
||||||
|
|
||||||
|
import java.util.ArrayDeque;
|
||||||
|
import java.util.Queue;
|
||||||
|
|
||||||
import javax.inject.Inject;
|
import javax.inject.Inject;
|
||||||
|
|
||||||
import acr.browser.lightning.R;
|
import acr.browser.lightning.R;
|
||||||
@ -17,6 +21,7 @@ public abstract class ThemableBrowserActivity extends AppCompatActivity {
|
|||||||
|
|
||||||
private int mTheme;
|
private int mTheme;
|
||||||
private boolean mShowTabsInDrawer;
|
private boolean mShowTabsInDrawer;
|
||||||
|
private boolean mShouldRunOnResumeActions = false;
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void onCreate(Bundle savedInstanceState) {
|
protected void onCreate(Bundle savedInstanceState) {
|
||||||
@ -33,9 +38,29 @@ public abstract class ThemableBrowserActivity extends AppCompatActivity {
|
|||||||
super.onCreate(savedInstanceState);
|
super.onCreate(savedInstanceState);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onWindowFocusChanged(boolean hasFocus) {
|
||||||
|
super.onWindowFocusChanged(hasFocus);
|
||||||
|
if (hasFocus && mShouldRunOnResumeActions) {
|
||||||
|
mShouldRunOnResumeActions = false;
|
||||||
|
onWindowVisibleToUserAfterResume();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Called after the activity is resumed
|
||||||
|
* and the UI becomes visible to the user.
|
||||||
|
* Called by onWindowFocusChanged only if
|
||||||
|
* onResume has been called.
|
||||||
|
*/
|
||||||
|
public void onWindowVisibleToUserAfterResume() {
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void onResume() {
|
protected void onResume() {
|
||||||
super.onResume();
|
super.onResume();
|
||||||
|
mShouldRunOnResumeActions = true;
|
||||||
int theme = mPreferences.getUseTheme();
|
int theme = mPreferences.getUseTheme();
|
||||||
boolean drawerTabs = mPreferences.getShowTabsInDrawer(!isTablet());
|
boolean drawerTabs = mPreferences.getShowTabsInDrawer(!isTablet());
|
||||||
if (theme != mTheme || mShowTabsInDrawer != drawerTabs) {
|
if (theme != mTheme || mShowTabsInDrawer != drawerTabs) {
|
||||||
|
@ -1,7 +1,5 @@
|
|||||||
package acr.browser.lightning.app;
|
package acr.browser.lightning.app;
|
||||||
|
|
||||||
import android.preference.PreferenceFragment;
|
|
||||||
|
|
||||||
import javax.inject.Singleton;
|
import javax.inject.Singleton;
|
||||||
|
|
||||||
import acr.browser.lightning.activity.BrowserActivity;
|
import acr.browser.lightning.activity.BrowserActivity;
|
||||||
|
@ -233,7 +233,7 @@ public class LightningView {
|
|||||||
* to get the default UserAgent for the WebView.
|
* to get the default UserAgent for the WebView.
|
||||||
*/
|
*/
|
||||||
@SuppressLint({"NewApi", "SetJavaScriptEnabled"})
|
@SuppressLint({"NewApi", "SetJavaScriptEnabled"})
|
||||||
public synchronized void initializePreferences(Context context) {
|
public synchronized void initializePreferences(@NonNull Context context) {
|
||||||
if (mWebView == null) {
|
if (mWebView == null) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
62
app/src/main/java/acr/browser/lightning/view/SearchView.java
Normal file
62
app/src/main/java/acr/browser/lightning/view/SearchView.java
Normal file
@ -0,0 +1,62 @@
|
|||||||
|
package acr.browser.lightning.view;
|
||||||
|
|
||||||
|
import android.content.Context;
|
||||||
|
import android.support.annotation.Nullable;
|
||||||
|
import android.util.AttributeSet;
|
||||||
|
import android.view.MotionEvent;
|
||||||
|
import android.view.ViewConfiguration;
|
||||||
|
import android.widget.AutoCompleteTextView;
|
||||||
|
|
||||||
|
public class SearchView extends AutoCompleteTextView {
|
||||||
|
|
||||||
|
public interface PreFocusListener {
|
||||||
|
void onPreFocus();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Nullable private PreFocusListener mListener;
|
||||||
|
private boolean mIsBeingClicked;
|
||||||
|
private long mTimePressed;
|
||||||
|
|
||||||
|
public SearchView(Context context) {
|
||||||
|
super(context);
|
||||||
|
}
|
||||||
|
|
||||||
|
public SearchView(Context context, AttributeSet attrs) {
|
||||||
|
super(context, attrs);
|
||||||
|
}
|
||||||
|
|
||||||
|
public SearchView(Context context, AttributeSet attrs, int defStyleAttr) {
|
||||||
|
super(context, attrs, defStyleAttr);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setOnPreFocusListener(@Nullable PreFocusListener listener) {
|
||||||
|
mListener = listener;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean onTouchEvent(MotionEvent event) {
|
||||||
|
switch (event.getAction()) {
|
||||||
|
case MotionEvent.ACTION_DOWN:
|
||||||
|
mTimePressed = System.currentTimeMillis();
|
||||||
|
mIsBeingClicked = true;
|
||||||
|
break;
|
||||||
|
case MotionEvent.ACTION_CANCEL:
|
||||||
|
mIsBeingClicked = false;
|
||||||
|
break;
|
||||||
|
case MotionEvent.ACTION_UP:
|
||||||
|
if (mIsBeingClicked && !isLongPress()) {
|
||||||
|
if (mListener != null) {
|
||||||
|
mListener.onPreFocus();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
return super.onTouchEvent(event);
|
||||||
|
}
|
||||||
|
|
||||||
|
private boolean isLongPress() {
|
||||||
|
return (System.currentTimeMillis() - mTimePressed) >= ViewConfiguration.getLongPressTimeout();
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
}
|
@ -16,7 +16,7 @@
|
|||||||
android:focusableInTouchMode="true"
|
android:focusableInTouchMode="true"
|
||||||
android:gravity="center">
|
android:gravity="center">
|
||||||
|
|
||||||
<AutoCompleteTextView
|
<acr.browser.lightning.view.SearchView
|
||||||
android:id="@+id/search"
|
android:id="@+id/search"
|
||||||
android:layout_width="match_parent"
|
android:layout_width="match_parent"
|
||||||
android:layout_height="match_parent"
|
android:layout_height="match_parent"
|
||||||
@ -29,7 +29,6 @@
|
|||||||
android:paddingLeft="8dp"
|
android:paddingLeft="8dp"
|
||||||
android:paddingRight="5dp"
|
android:paddingRight="5dp"
|
||||||
android:paddingTop="1dp"
|
android:paddingTop="1dp"
|
||||||
android:selectAllOnFocus="true"
|
|
||||||
android:singleLine="true"
|
android:singleLine="true"
|
||||||
android:textColor="@color/gray_dark"
|
android:textColor="@color/gray_dark"
|
||||||
android:textColorHint="@color/hint_text"
|
android:textColorHint="@color/hint_text"
|
||||||
|
Loading…
x
Reference in New Issue
Block a user