Check user dictionary is enabled before showing touch-to-save
Bug: 5024127 Change-Id: If4d691a4a59c43579d1f977e9a0545495f30bafbmain
parent
68ff3a0a8b
commit
ada26bb383
|
@ -151,6 +151,7 @@ public class LatinIME extends InputMethodServiceCompatWrapper implements Keyboar
|
|||
private UserDictionary mUserDictionary;
|
||||
private UserBigramDictionary mUserBigramDictionary;
|
||||
private UserUnigramDictionary mUserUnigramDictionary;
|
||||
private boolean mIsUserDictionaryAvaliable;
|
||||
|
||||
// TODO: Create an inner class to group options and pseudo-options to improve readability.
|
||||
// These variables are initialized according to the {@link EditorInfo#inputType}.
|
||||
|
@ -436,6 +437,7 @@ public class LatinIME extends InputMethodServiceCompatWrapper implements Keyboar
|
|||
|
||||
mUserDictionary = new UserDictionary(this, localeStr);
|
||||
mSuggest.setUserDictionary(mUserDictionary);
|
||||
mIsUserDictionaryAvaliable = mUserDictionary.isEnabled();
|
||||
|
||||
resetContactsDictionary();
|
||||
|
||||
|
@ -1691,7 +1693,11 @@ public class LatinIME extends InputMethodServiceCompatWrapper implements Keyboar
|
|||
// take a noticeable delay to update them which may feel uneasy.
|
||||
}
|
||||
if (showingAddToDictionaryHint) {
|
||||
mCandidateView.showAddToDictionaryHint(suggestion);
|
||||
if (mIsUserDictionaryAvaliable) {
|
||||
mCandidateView.showAddToDictionaryHint(suggestion);
|
||||
} else {
|
||||
mHandler.postUpdateSuggestions();
|
||||
}
|
||||
}
|
||||
if (ic != null) {
|
||||
ic.endBatchEdit();
|
||||
|
|
|
@ -38,23 +38,24 @@ public class UserDictionary extends ExpandableDictionary {
|
|||
Words.FREQUENCY,
|
||||
Words.LOCALE,
|
||||
};
|
||||
|
||||
|
||||
private ContentObserver mObserver;
|
||||
private String mLocale;
|
||||
|
||||
public UserDictionary(Context context, String locale) {
|
||||
super(context, Suggest.DIC_USER);
|
||||
mLocale = locale;
|
||||
// Perform a managed query. The Activity will handle closing and requerying the cursor
|
||||
// Perform a managed query. The Activity will handle closing and re-querying the cursor
|
||||
// when needed.
|
||||
ContentResolver cres = context.getContentResolver();
|
||||
|
||||
cres.registerContentObserver(Words.CONTENT_URI, true, mObserver = new ContentObserver(null) {
|
||||
|
||||
mObserver = new ContentObserver(null) {
|
||||
@Override
|
||||
public void onChange(boolean self) {
|
||||
setRequiresReload(true);
|
||||
}
|
||||
});
|
||||
};
|
||||
cres.registerContentObserver(Words.CONTENT_URI, true, mObserver);
|
||||
|
||||
loadDictionary();
|
||||
}
|
||||
|
@ -76,6 +77,17 @@ public class UserDictionary extends ExpandableDictionary {
|
|||
addWords(cursor);
|
||||
}
|
||||
|
||||
public boolean isEnabled() {
|
||||
final ContentResolver cr = getContext().getContentResolver();
|
||||
final ContentProviderClient client = cr.acquireContentProviderClient(Words.CONTENT_URI);
|
||||
if (client != null) {
|
||||
client.release();
|
||||
return true;
|
||||
} else {
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Adds a word to the dictionary and makes it persistent.
|
||||
* @param word the word to add. If the word is capitalized, then the dictionary will
|
||||
|
|
Loading…
Reference in New Issue