DO NOT MERGE. Do not access metadatadb from main thread.
Also fix Refresh button replicating itself on orientation change. Bug: 19786650 Change-Id: I19a964d69d9141ba6515bbe19a120d4685628fe3
This commit is contained in:
parent
60835872a1
commit
fd3e0175e5
1 changed files with 44 additions and 20 deletions
|
@ -28,6 +28,7 @@ import android.database.Cursor;
|
||||||
import android.net.ConnectivityManager;
|
import android.net.ConnectivityManager;
|
||||||
import android.net.NetworkInfo;
|
import android.net.NetworkInfo;
|
||||||
import android.net.Uri;
|
import android.net.Uri;
|
||||||
|
import android.os.AsyncTask;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.preference.Preference;
|
import android.preference.Preference;
|
||||||
import android.preference.PreferenceFragment;
|
import android.preference.PreferenceFragment;
|
||||||
|
@ -106,16 +107,27 @@ public final class DictionarySettingsFragment extends PreferenceFragment
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onCreateOptionsMenu(final Menu menu, final MenuInflater inflater) {
|
public void onCreateOptionsMenu(final Menu menu, final MenuInflater inflater) {
|
||||||
final String metadataUri =
|
new AsyncTask<Void, Void, String>() {
|
||||||
MetadataDbHelper.getMetadataUriAsString(getActivity(), mClientId);
|
@Override
|
||||||
// We only add the "Refresh" button if we have a non-empty URL to refresh from. If the
|
protected String doInBackground(Void... params) {
|
||||||
// URL is empty, of course we can't refresh so it makes no sense to display this.
|
return MetadataDbHelper.getMetadataUriAsString(getActivity(), mClientId);
|
||||||
if (!TextUtils.isEmpty(metadataUri)) {
|
}
|
||||||
mUpdateNowMenu =
|
|
||||||
menu.add(Menu.NONE, MENU_UPDATE_NOW, 0, R.string.check_for_updates_now);
|
@Override
|
||||||
mUpdateNowMenu.setShowAsAction(MenuItem.SHOW_AS_ACTION_IF_ROOM);
|
protected void onPostExecute(String metadataUri) {
|
||||||
refreshNetworkState();
|
// We only add the "Refresh" button if we have a non-empty URL to refresh from. If
|
||||||
}
|
// the URL is empty, of course we can't refresh so it makes no sense to display
|
||||||
|
// this.
|
||||||
|
if (!TextUtils.isEmpty(metadataUri)) {
|
||||||
|
if (mUpdateNowMenu == null) {
|
||||||
|
mUpdateNowMenu = menu.add(Menu.NONE, MENU_UPDATE_NOW, 0,
|
||||||
|
R.string.check_for_updates_now);
|
||||||
|
mUpdateNowMenu.setShowAsAction(MenuItem.SHOW_AS_ACTION_IF_ROOM);
|
||||||
|
}
|
||||||
|
refreshNetworkState();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}.execute();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -124,18 +136,25 @@ public final class DictionarySettingsFragment extends PreferenceFragment
|
||||||
mChangedSettings = false;
|
mChangedSettings = false;
|
||||||
UpdateHandler.registerUpdateEventListener(this);
|
UpdateHandler.registerUpdateEventListener(this);
|
||||||
final Activity activity = getActivity();
|
final Activity activity = getActivity();
|
||||||
if (!MetadataDbHelper.isClientKnown(activity, mClientId)) {
|
|
||||||
Log.i(TAG, "Unknown dictionary pack client: " + mClientId + ". Requesting info.");
|
|
||||||
final Intent unknownClientBroadcast =
|
|
||||||
new Intent(DictionaryPackConstants.UNKNOWN_DICTIONARY_PROVIDER_CLIENT);
|
|
||||||
unknownClientBroadcast.putExtra(
|
|
||||||
DictionaryPackConstants.DICTIONARY_PROVIDER_CLIENT_EXTRA, mClientId);
|
|
||||||
activity.sendBroadcast(unknownClientBroadcast);
|
|
||||||
}
|
|
||||||
final IntentFilter filter = new IntentFilter();
|
final IntentFilter filter = new IntentFilter();
|
||||||
filter.addAction(ConnectivityManager.CONNECTIVITY_ACTION);
|
filter.addAction(ConnectivityManager.CONNECTIVITY_ACTION);
|
||||||
getActivity().registerReceiver(mConnectivityChangedReceiver, filter);
|
getActivity().registerReceiver(mConnectivityChangedReceiver, filter);
|
||||||
refreshNetworkState();
|
refreshNetworkState();
|
||||||
|
|
||||||
|
new Thread("onResume") {
|
||||||
|
@Override
|
||||||
|
public void run() {
|
||||||
|
if (!MetadataDbHelper.isClientKnown(activity, mClientId)) {
|
||||||
|
Log.i(TAG, "Unknown dictionary pack client: " + mClientId
|
||||||
|
+ ". Requesting info.");
|
||||||
|
final Intent unknownClientBroadcast =
|
||||||
|
new Intent(DictionaryPackConstants.UNKNOWN_DICTIONARY_PROVIDER_CLIENT);
|
||||||
|
unknownClientBroadcast.putExtra(
|
||||||
|
DictionaryPackConstants.DICTIONARY_PROVIDER_CLIENT_EXTRA, mClientId);
|
||||||
|
activity.sendBroadcast(unknownClientBroadcast);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}.start();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -375,8 +394,13 @@ public final class DictionarySettingsFragment extends PreferenceFragment
|
||||||
private void cancelRefresh() {
|
private void cancelRefresh() {
|
||||||
UpdateHandler.unregisterUpdateEventListener(this);
|
UpdateHandler.unregisterUpdateEventListener(this);
|
||||||
final Context context = getActivity();
|
final Context context = getActivity();
|
||||||
UpdateHandler.cancelUpdate(context, mClientId);
|
new Thread("cancelByHand") {
|
||||||
stopLoadingAnimation();
|
@Override
|
||||||
|
public void run() {
|
||||||
|
UpdateHandler.cancelUpdate(context, mClientId);
|
||||||
|
stopLoadingAnimation();
|
||||||
|
}
|
||||||
|
}.start();
|
||||||
}
|
}
|
||||||
|
|
||||||
private void startLoadingAnimation() {
|
private void startLoadingAnimation() {
|
||||||
|
|
Loading…
Reference in a new issue