summaryrefslogtreecommitdiffstats
path: root/src/com/android/settings/print
diff options
context:
space:
mode:
authorMakoto Onuki <omakoto@google.com>2015-06-04 17:45:03 -0700
committerMakoto Onuki <omakoto@google.com>2015-06-11 14:26:29 -0700
commit0ec96fe64cea4d27e866fc2dc17b799cf9c265a4 (patch)
tree727f64cc65e78fb2a3af2fb797f29e043e6801e4 /src/com/android/settings/print
parent0f6b243d4b0d2224b26852a4801d444afc9289d8 (diff)
downloadpackages_apps_Settings-0ec96fe64cea4d27e866fc2dc17b799cf9c265a4.zip
packages_apps_Settings-0ec96fe64cea4d27e866fc2dc17b799cf9c265a4.tar.gz
packages_apps_Settings-0ec96fe64cea4d27e866fc2dc17b799cf9c265a4.tar.bz2
Promote "add service" from menu to list item
Also show the app icon for each service. Bug 19914125 Change-Id: I592c526746a3ec9f67e8e8a6c6f1530e7724e310
Diffstat (limited to 'src/com/android/settings/print')
-rw-r--r--src/com/android/settings/print/PrintSettingsFragment.java86
1 files changed, 68 insertions, 18 deletions
diff --git a/src/com/android/settings/print/PrintSettingsFragment.java b/src/com/android/settings/print/PrintSettingsFragment.java
index ebd51d5..d737282 100644
--- a/src/com/android/settings/print/PrintSettingsFragment.java
+++ b/src/com/android/settings/print/PrintSettingsFragment.java
@@ -17,6 +17,7 @@
package com.android.settings.print;
import android.app.LoaderManager.LoaderCallbacks;
+import android.content.ActivityNotFoundException;
import android.content.AsyncTaskLoader;
import android.content.ComponentName;
import android.content.ContentResolver;
@@ -26,6 +27,7 @@ import android.content.Loader;
import android.content.pm.PackageManager;
import android.content.pm.ResolveInfo;
import android.database.ContentObserver;
+import android.graphics.drawable.Drawable;
import android.net.Uri;
import android.os.Bundle;
import android.os.Handler;
@@ -46,13 +48,12 @@ import android.provider.Settings;
import android.text.TextUtils;
import android.text.format.DateUtils;
import android.util.Log;
-import android.view.Menu;
-import android.view.MenuInflater;
-import android.view.MenuItem;
import android.view.View;
+import android.view.View.OnClickListener;
import android.view.ViewGroup;
import android.widget.AdapterView;
import android.widget.AdapterView.OnItemSelectedListener;
+import android.widget.Button;
import android.widget.Spinner;
import android.widget.TextView;
@@ -75,8 +76,8 @@ import java.util.List;
* Fragment with the top level print settings.
*/
public class PrintSettingsFragment extends SettingsPreferenceFragment
- implements DialogCreatable, Indexable, OnItemSelectedListener {
-
+ implements DialogCreatable, Indexable, OnItemSelectedListener, OnClickListener {
+ public static final String TAG = "PrintSettingsFragment";
private static final int LOADER_ID_PRINT_JOBS_LOADER = 1;
private static final String PRINT_JOBS_CATEGORY = "print_jobs_category";
@@ -99,6 +100,8 @@ public class PrintSettingsFragment extends SettingsPreferenceFragment
private static final String EXTRA_PRINT_SERVICE_COMPONENT_NAME =
"EXTRA_PRINT_SERVICE_COMPONENT_NAME";
+ private static final int ORDER_LAST = 1000;
+
private final PackageMonitor mSettingsPackageMonitor = new SettingsPackageMonitor();
private final Handler mHandler = new Handler() {
@@ -122,6 +125,7 @@ public class PrintSettingsFragment extends SettingsPreferenceFragment
private PrintJobsController mPrintJobsController;
private UserAdapter mProfileSpinnerAdapter;
private Spinner mSpinner;
+ private Button mAddNewServiceButton;
@Override
protected int getMetricsCategory() {
@@ -167,18 +171,6 @@ public class PrintSettingsFragment extends SettingsPreferenceFragment
}
@Override
- public void onCreateOptionsMenu(Menu menu, MenuInflater inflater) {
- super.onCreateOptionsMenu(menu, inflater);
- String searchUri = Settings.Secure.getString(getContentResolver(),
- Settings.Secure.PRINT_SERVICE_SEARCH_URI);
- if (!TextUtils.isEmpty(searchUri)) {
- MenuItem menuItem = menu.add(R.string.print_menu_item_add_service);
- menuItem.setShowAsActionFlags(MenuItem.SHOW_AS_ACTION_NEVER);
- menuItem.setIntent(new Intent(Intent.ACTION_VIEW, Uri.parse(searchUri)));
- }
- }
-
- @Override
public void onViewCreated(View view, Bundle savedInstanceState) {
super.onViewCreated(view, savedInstanceState);
ViewGroup contentRoot = (ViewGroup) getListView().getParent();
@@ -186,6 +178,15 @@ public class PrintSettingsFragment extends SettingsPreferenceFragment
R.layout.empty_print_state, contentRoot, false);
TextView textView = (TextView) emptyView.findViewById(R.id.message);
textView.setText(R.string.print_no_services_installed);
+
+ final Intent addNewServiceIntent = createAddNewServiceIntentOrNull();
+ if (addNewServiceIntent != null) {
+ mAddNewServiceButton = (Button) emptyView.findViewById(R.id.add_new_service);
+ mAddNewServiceButton.setOnClickListener(this);
+ // The empty is used elsewhere too so it's hidden by default.
+ mAddNewServiceButton.setVisibility(View.VISIBLE);
+ }
+
contentRoot.addView(emptyView);
getListView().setEmptyView(emptyView);
@@ -210,7 +211,9 @@ public class PrintSettingsFragment extends SettingsPreferenceFragment
List<ComponentName> enabledServices = PrintSettingsUtils
.readEnabledPrintServices(getActivity());
- List<ResolveInfo> installedServices = getActivity().getPackageManager()
+ final PackageManager pm = getActivity().getPackageManager();
+
+ List<ResolveInfo> installedServices = pm
.queryIntentServices(
new Intent(android.printservice.PrintService.SERVICE_INTERFACE),
PackageManager.GET_SERVICES | PackageManager.GET_META_DATA);
@@ -241,6 +244,11 @@ public class PrintSettingsFragment extends SettingsPreferenceFragment
preference.setSummary(getString(R.string.print_feature_state_off));
}
+ final Drawable drawable = installedService.loadIcon(pm);
+ if (drawable != null) {
+ preference.setIcon(drawable);
+ }
+
Bundle extras = preference.getExtras();
extras.putString(EXTRA_PREFERENCE_KEY, preference.getKey());
extras.putBoolean(EXTRA_CHECKED, serviceEnabled);
@@ -281,9 +289,37 @@ public class PrintSettingsFragment extends SettingsPreferenceFragment
if (mPrintServicesCategory.getPreferenceCount() == 0) {
getPreferenceScreen().removePreference(mPrintServicesCategory);
+ } else {
+ final Preference addNewServicePreference = newAddServicePreferenceOrNull();
+ if (addNewServicePreference != null) {
+ mPrintServicesCategory.addPreference(addNewServicePreference);
+ }
}
}
+ private Preference newAddServicePreferenceOrNull() {
+ final Intent addNewServiceIntent = createAddNewServiceIntentOrNull();
+ if (addNewServiceIntent == null) {
+ return null;
+ }
+ Preference preference = new Preference(getContext());
+ preference.setTitle(R.string.print_menu_item_add_service);
+ preference.setIcon(R.drawable.ic_menu_add);
+ preference.setOrder(ORDER_LAST);
+ preference.setIntent(addNewServiceIntent);
+ preference.setPersistent(false);
+ return preference;
+ }
+
+ private Intent createAddNewServiceIntentOrNull() {
+ final String searchUri = Settings.Secure.getString(getContentResolver(),
+ Settings.Secure.PRINT_SERVICE_SEARCH_URI);
+ if (TextUtils.isEmpty(searchUri)) {
+ return null;
+ }
+ return new Intent(Intent.ACTION_VIEW, Uri.parse(searchUri));
+ }
+
private void startSubSettingsIfNeeded() {
if (getArguments() == null) {
return;
@@ -316,6 +352,20 @@ public class PrintSettingsFragment extends SettingsPreferenceFragment
// Nothing to do
}
+ @Override
+ public void onClick(View v) {
+ if (mAddNewServiceButton == v) {
+ final Intent addNewServiceIntent = createAddNewServiceIntentOrNull();
+ if (addNewServiceIntent != null) { // check again just in case.
+ try {
+ startActivity(addNewServiceIntent);
+ } catch (ActivityNotFoundException e) {
+ Log.w(TAG, "Unable to start activity", e);
+ }
+ }
+ }
+ }
+
private class SettingsPackageMonitor extends PackageMonitor {
@Override
public void onPackageAdded(String packageName, int uid) {