Remove ListView from preference_list_fragment.
As part of it, Use RecyclerView in PrintServiceSettingsFragment, which still depends on the old preference_list_frag layout. Also remove some unused pngs Test: manual Change-Id: I3189bd0dee5b6a74209eb1e707eb40427c96e312
Before Width: | Height: | Size: 22 KiB |
Before Width: | Height: | Size: 22 KiB |
Before Width: | Height: | Size: 26 KiB |
Before Width: | Height: | Size: 26 KiB |
Before Width: | Height: | Size: 26 KiB |
Before Width: | Height: | Size: 27 KiB |
Before Width: | Height: | Size: 26 KiB |
Before Width: | Height: | Size: 23 KiB |
Before Width: | Height: | Size: 23 KiB |
Before Width: | Height: | Size: 24 KiB |
Before Width: | Height: | Size: 25 KiB |
Before Width: | Height: | Size: 25 KiB |
Before Width: | Height: | Size: 24 KiB |
Before Width: | Height: | Size: 24 KiB |
Before Width: | Height: | Size: 26 KiB |
Before Width: | Height: | Size: 13 KiB |
Before Width: | Height: | Size: 14 KiB |
Before Width: | Height: | Size: 17 KiB |
Before Width: | Height: | Size: 17 KiB |
Before Width: | Height: | Size: 17 KiB |
Before Width: | Height: | Size: 17 KiB |
Before Width: | Height: | Size: 17 KiB |
Before Width: | Height: | Size: 14 KiB |
Before Width: | Height: | Size: 14 KiB |
Before Width: | Height: | Size: 15 KiB |
Before Width: | Height: | Size: 16 KiB |
Before Width: | Height: | Size: 16 KiB |
Before Width: | Height: | Size: 15 KiB |
Before Width: | Height: | Size: 15 KiB |
Before Width: | Height: | Size: 16 KiB |
Before Width: | Height: | Size: 27 KiB |
Before Width: | Height: | Size: 26 KiB |
Before Width: | Height: | Size: 50 KiB |
Before Width: | Height: | Size: 50 KiB |
Before Width: | Height: | Size: 51 KiB |
Before Width: | Height: | Size: 51 KiB |
Before Width: | Height: | Size: 49 KiB |
Before Width: | Height: | Size: 27 KiB |
Before Width: | Height: | Size: 28 KiB |
Before Width: | Height: | Size: 46 KiB |
Before Width: | Height: | Size: 47 KiB |
Before Width: | Height: | Size: 48 KiB |
Before Width: | Height: | Size: 46 KiB |
Before Width: | Height: | Size: 46 KiB |
Before Width: | Height: | Size: 50 KiB |
@@ -1,37 +0,0 @@
|
|||||||
<?xml version="1.0" encoding="utf-8"?>
|
|
||||||
<!--
|
|
||||||
/*
|
|
||||||
** Copyright 2008, The Android Open Source Project
|
|
||||||
**
|
|
||||||
** Licensed under the Apache License, Version 2.0 (the "License");
|
|
||||||
** you may not use this file except in compliance with the License.
|
|
||||||
** You may obtain a copy of the License at
|
|
||||||
**
|
|
||||||
** http://www.apache.org/licenses/LICENSE-2.0
|
|
||||||
**
|
|
||||||
** Unless required by applicable law or agreed to in writing, software
|
|
||||||
** distributed under the License is distributed on an "AS IS" BASIS,
|
|
||||||
** WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
||||||
** See the License for the specific language governing permissions and
|
|
||||||
** limitations under the License.
|
|
||||||
*/
|
|
||||||
-->
|
|
||||||
<animation-list
|
|
||||||
xmlns:android="http://schemas.android.com/apk/res/android"
|
|
||||||
android:oneshot="false">
|
|
||||||
<item android:drawable="@drawable/lock_anim_0" android:duration="200" />
|
|
||||||
<item android:drawable="@drawable/lock_anim_1" android:duration="200" />
|
|
||||||
<item android:drawable="@drawable/lock_anim_2" android:duration="200" />
|
|
||||||
<item android:drawable="@drawable/lock_anim_3" android:duration="200" />
|
|
||||||
<item android:drawable="@drawable/lock_anim_4" android:duration="200" />
|
|
||||||
<item android:drawable="@drawable/lock_anim_5" android:duration="200" />
|
|
||||||
<item android:drawable="@drawable/lock_anim_6" android:duration="200" />
|
|
||||||
<item android:drawable="@drawable/lock_anim_7" android:duration="200" />
|
|
||||||
<item android:drawable="@drawable/lock_anim_8" android:duration="200" />
|
|
||||||
<item android:drawable="@drawable/lock_anim_9" android:duration="200" />
|
|
||||||
<item android:drawable="@drawable/lock_anim_10" android:duration="200" />
|
|
||||||
<item android:drawable="@drawable/lock_anim_11" android:duration="200" />
|
|
||||||
<item android:drawable="@drawable/lock_anim_12" android:duration="200" />
|
|
||||||
<item android:drawable="@drawable/lock_anim_13" android:duration="200" />
|
|
||||||
<item android:drawable="@drawable/lock_anim_14" android:duration="200" />
|
|
||||||
</animation-list>
|
|
@@ -37,19 +37,6 @@
|
|||||||
android:paddingStart="@dimen/settings_side_margin"
|
android:paddingStart="@dimen/settings_side_margin"
|
||||||
android:paddingEnd="@dimen/settings_side_margin">
|
android:paddingEnd="@dimen/settings_side_margin">
|
||||||
|
|
||||||
<ListView android:id="@+id/backup_list"
|
|
||||||
style="@style/PreferenceFragmentListSinglePane"
|
|
||||||
android:layout_width="match_parent"
|
|
||||||
android:layout_height="match_parent"
|
|
||||||
android:paddingTop="@dimen/dashboard_padding_top"
|
|
||||||
android:paddingBottom="@dimen/dashboard_padding_bottom"
|
|
||||||
android:scrollbarStyle="@*android:integer/preference_fragment_scrollbarStyle"
|
|
||||||
android:clipToPadding="false"
|
|
||||||
android:drawSelectorOnTop="false"
|
|
||||||
android:elevation="@dimen/dashboard_category_elevation"
|
|
||||||
android:visibility="gone"
|
|
||||||
android:scrollbarAlwaysDrawVerticalTrack="true" />
|
|
||||||
|
|
||||||
<include layout="@layout/loading_container" />
|
<include layout="@layout/loading_container" />
|
||||||
|
|
||||||
</FrameLayout>
|
</FrameLayout>
|
||||||
@@ -74,8 +61,7 @@
|
|||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_margin="5dip"
|
android:layout_margin="5dip"
|
||||||
android:layout_alignParentStart="true"
|
android:layout_alignParentStart="true"
|
||||||
android:text="@*android:string/back_button_label"
|
android:text="@*android:string/back_button_label" />
|
||||||
/>
|
|
||||||
|
|
||||||
<LinearLayout
|
<LinearLayout
|
||||||
android:orientation="horizontal"
|
android:orientation="horizontal"
|
||||||
@@ -89,16 +75,14 @@
|
|||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_margin="5dip"
|
android:layout_margin="5dip"
|
||||||
android:text="@*android:string/skip_button_label"
|
android:text="@*android:string/skip_button_label"
|
||||||
android:visibility="gone"
|
android:visibility="gone" />
|
||||||
/>
|
|
||||||
|
|
||||||
<Button android:id="@+id/next_button"
|
<Button android:id="@+id/next_button"
|
||||||
style="?android:attr/buttonBarButtonStyle"
|
style="?android:attr/buttonBarButtonStyle"
|
||||||
android:layout_width="wrap_content"
|
android:layout_width="wrap_content"
|
||||||
android:layout_height="wrap_content"
|
android:layout_height="wrap_content"
|
||||||
android:layout_margin="5dip"
|
android:layout_margin="5dip"
|
||||||
android:text="@*android:string/next_button_label"
|
android:text="@*android:string/next_button_label" />
|
||||||
/>
|
|
||||||
|
|
||||||
</LinearLayout>
|
</LinearLayout>
|
||||||
|
|
||||||
|
@@ -97,9 +97,6 @@
|
|||||||
<dimen name="dashboard_category_padding_start">0dp</dimen>
|
<dimen name="dashboard_category_padding_start">0dp</dimen>
|
||||||
<dimen name="dashboard_category_padding_end">0dp</dimen>
|
<dimen name="dashboard_category_padding_end">0dp</dimen>
|
||||||
|
|
||||||
<!-- Dashboard category panel elevation -->
|
|
||||||
<dimen name="dashboard_category_elevation">2dp</dimen>
|
|
||||||
|
|
||||||
<!-- Dashboard tile minimum height -->
|
<!-- Dashboard tile minimum height -->
|
||||||
<dimen name="dashboard_tile_minimum_height">72dp</dimen>
|
<dimen name="dashboard_tile_minimum_height">72dp</dimen>
|
||||||
|
|
||||||
|
@@ -22,9 +22,6 @@ import android.content.Context;
|
|||||||
import android.content.Intent;
|
import android.content.Intent;
|
||||||
import android.content.IntentSender.SendIntentException;
|
import android.content.IntentSender.SendIntentException;
|
||||||
import android.content.pm.ResolveInfo;
|
import android.content.pm.ResolveInfo;
|
||||||
import android.database.DataSetObserver;
|
|
||||||
import android.graphics.Color;
|
|
||||||
import android.graphics.drawable.ColorDrawable;
|
|
||||||
import android.graphics.drawable.Drawable;
|
import android.graphics.drawable.Drawable;
|
||||||
import android.os.Bundle;
|
import android.os.Bundle;
|
||||||
import android.print.PrintManager;
|
import android.print.PrintManager;
|
||||||
@@ -44,13 +41,10 @@ import android.view.View;
|
|||||||
import android.view.View.OnClickListener;
|
import android.view.View.OnClickListener;
|
||||||
import android.view.ViewGroup;
|
import android.view.ViewGroup;
|
||||||
import android.view.accessibility.AccessibilityManager;
|
import android.view.accessibility.AccessibilityManager;
|
||||||
import android.widget.AdapterView;
|
|
||||||
import android.widget.BaseAdapter;
|
|
||||||
import android.widget.Filter;
|
import android.widget.Filter;
|
||||||
import android.widget.Filterable;
|
import android.widget.Filterable;
|
||||||
import android.widget.ImageView;
|
import android.widget.ImageView;
|
||||||
import android.widget.LinearLayout;
|
import android.widget.LinearLayout;
|
||||||
import android.widget.ListView;
|
|
||||||
import android.widget.SearchView;
|
import android.widget.SearchView;
|
||||||
import android.widget.Switch;
|
import android.widget.Switch;
|
||||||
import android.widget.TextView;
|
import android.widget.TextView;
|
||||||
@@ -67,8 +61,11 @@ import java.util.LinkedHashMap;
|
|||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
|
import androidx.annotation.NonNull;
|
||||||
import androidx.loader.app.LoaderManager;
|
import androidx.loader.app.LoaderManager;
|
||||||
import androidx.loader.content.Loader;
|
import androidx.loader.content.Loader;
|
||||||
|
import androidx.recyclerview.widget.RecyclerView;
|
||||||
|
import androidx.recyclerview.widget.RecyclerView.AdapterDataObserver;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Fragment with print service settings.
|
* Fragment with print service settings.
|
||||||
@@ -77,23 +74,18 @@ public class PrintServiceSettingsFragment extends SettingsPreferenceFragment
|
|||||||
implements SwitchBar.OnSwitchChangeListener,
|
implements SwitchBar.OnSwitchChangeListener,
|
||||||
LoaderManager.LoaderCallbacks<List<PrintServiceInfo>> {
|
LoaderManager.LoaderCallbacks<List<PrintServiceInfo>> {
|
||||||
|
|
||||||
private static final String LOG_TAG = "PrintServiceSettingsFragment";
|
private static final String LOG_TAG = "PrintServiceSettings";
|
||||||
|
|
||||||
private static final int LOADER_ID_PRINTERS_LOADER = 1;
|
private static final int LOADER_ID_PRINTERS_LOADER = 1;
|
||||||
private static final int LOADER_ID_PRINT_SERVICE_LOADER = 2;
|
private static final int LOADER_ID_PRINT_SERVICE_LOADER = 2;
|
||||||
|
|
||||||
private final DataSetObserver mDataObserver = new DataSetObserver() {
|
private final AdapterDataObserver mDataObserver = new AdapterDataObserver() {
|
||||||
@Override
|
@Override
|
||||||
public void onChanged() {
|
public void onChanged() {
|
||||||
invalidateOptionsMenuIfNeeded();
|
invalidateOptionsMenuIfNeeded();
|
||||||
updateEmptyView();
|
updateEmptyView();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
|
||||||
public void onInvalidated() {
|
|
||||||
invalidateOptionsMenuIfNeeded();
|
|
||||||
}
|
|
||||||
|
|
||||||
private void invalidateOptionsMenuIfNeeded() {
|
private void invalidateOptionsMenuIfNeeded() {
|
||||||
final int unfilteredItemCount = mPrintersAdapter.getUnfilteredCount();
|
final int unfilteredItemCount = mPrintersAdapter.getUnfilteredCount();
|
||||||
if ((mLastUnfilteredItemCount <= 0 && unfilteredItemCount > 0)
|
if ((mLastUnfilteredItemCount <= 0 && unfilteredItemCount > 0)
|
||||||
@@ -173,8 +165,6 @@ public class PrintServiceSettingsFragment extends SettingsPreferenceFragment
|
|||||||
super.onViewCreated(view, savedInstanceState);
|
super.onViewCreated(view, savedInstanceState);
|
||||||
initComponents();
|
initComponents();
|
||||||
updateUiForArguments();
|
updateUiForArguments();
|
||||||
getListView().setVisibility(View.GONE);
|
|
||||||
getBackupListView().setVisibility(View.VISIBLE);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -189,15 +179,11 @@ public class PrintServiceSettingsFragment extends SettingsPreferenceFragment
|
|||||||
.setPrintServiceEnabled(mComponentName, enabled);
|
.setPrintServiceEnabled(mComponentName, enabled);
|
||||||
}
|
}
|
||||||
|
|
||||||
private ListView getBackupListView() {
|
|
||||||
return (ListView) getView().findViewById(R.id.backup_list);
|
|
||||||
}
|
|
||||||
|
|
||||||
private void updateEmptyView() {
|
private void updateEmptyView() {
|
||||||
ViewGroup contentRoot = (ViewGroup) getListView().getParent();
|
ViewGroup contentRoot = (ViewGroup) getListView().getParent();
|
||||||
View emptyView = getBackupListView().getEmptyView();
|
View emptyView = getEmptyView();
|
||||||
if (!mToggleSwitch.isChecked()) {
|
if (!mToggleSwitch.isChecked()) {
|
||||||
if (emptyView != null && emptyView.getId() != R.id.empty_print_state) {
|
if (emptyView != null) {
|
||||||
contentRoot.removeView(emptyView);
|
contentRoot.removeView(emptyView);
|
||||||
emptyView = null;
|
emptyView = null;
|
||||||
}
|
}
|
||||||
@@ -209,11 +195,10 @@ public class PrintServiceSettingsFragment extends SettingsPreferenceFragment
|
|||||||
TextView textView = (TextView) emptyView.findViewById(R.id.message);
|
TextView textView = (TextView) emptyView.findViewById(R.id.message);
|
||||||
textView.setText(R.string.print_service_disabled);
|
textView.setText(R.string.print_service_disabled);
|
||||||
contentRoot.addView(emptyView);
|
contentRoot.addView(emptyView);
|
||||||
getBackupListView().setEmptyView(emptyView);
|
setEmptyView(emptyView);
|
||||||
}
|
}
|
||||||
} else if (mPrintersAdapter.getUnfilteredCount() <= 0) {
|
} else if (mPrintersAdapter.getUnfilteredCount() <= 0) {
|
||||||
if (emptyView != null
|
if (emptyView != null) {
|
||||||
&& emptyView.getId() != R.id.empty_printers_list_service_enabled) {
|
|
||||||
contentRoot.removeView(emptyView);
|
contentRoot.removeView(emptyView);
|
||||||
emptyView = null;
|
emptyView = null;
|
||||||
}
|
}
|
||||||
@@ -221,10 +206,10 @@ public class PrintServiceSettingsFragment extends SettingsPreferenceFragment
|
|||||||
emptyView = getActivity().getLayoutInflater().inflate(
|
emptyView = getActivity().getLayoutInflater().inflate(
|
||||||
R.layout.empty_printers_list_service_enabled, contentRoot, false);
|
R.layout.empty_printers_list_service_enabled, contentRoot, false);
|
||||||
contentRoot.addView(emptyView);
|
contentRoot.addView(emptyView);
|
||||||
getBackupListView().setEmptyView(emptyView);
|
setEmptyView(emptyView);
|
||||||
}
|
}
|
||||||
} else if (mPrintersAdapter.getCount() <= 0) {
|
} else if (mPrintersAdapter.getItemCount() <= 0) {
|
||||||
if (emptyView != null && emptyView.getId() != R.id.empty_print_state) {
|
if (emptyView != null) {
|
||||||
contentRoot.removeView(emptyView);
|
contentRoot.removeView(emptyView);
|
||||||
emptyView = null;
|
emptyView = null;
|
||||||
}
|
}
|
||||||
@@ -236,7 +221,11 @@ public class PrintServiceSettingsFragment extends SettingsPreferenceFragment
|
|||||||
TextView textView = (TextView) emptyView.findViewById(R.id.message);
|
TextView textView = (TextView) emptyView.findViewById(R.id.message);
|
||||||
textView.setText(R.string.print_no_printers_found);
|
textView.setText(R.string.print_no_printers_found);
|
||||||
contentRoot.addView(emptyView);
|
contentRoot.addView(emptyView);
|
||||||
getBackupListView().setEmptyView(emptyView);
|
setEmptyView(emptyView);
|
||||||
|
}
|
||||||
|
} else if (mPrintersAdapter.getItemCount() > 0) {
|
||||||
|
if (emptyView != null) {
|
||||||
|
contentRoot.removeView(emptyView);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -254,7 +243,7 @@ public class PrintServiceSettingsFragment extends SettingsPreferenceFragment
|
|||||||
|
|
||||||
private void initComponents() {
|
private void initComponents() {
|
||||||
mPrintersAdapter = new PrintersAdapter();
|
mPrintersAdapter = new PrintersAdapter();
|
||||||
mPrintersAdapter.registerDataSetObserver(mDataObserver);
|
mPrintersAdapter.registerAdapterDataObserver(mDataObserver);
|
||||||
|
|
||||||
final SettingsActivity activity = (SettingsActivity) getActivity();
|
final SettingsActivity activity = (SettingsActivity) getActivity();
|
||||||
|
|
||||||
@@ -263,31 +252,12 @@ public class PrintServiceSettingsFragment extends SettingsPreferenceFragment
|
|||||||
mSwitchBar.show();
|
mSwitchBar.show();
|
||||||
|
|
||||||
mToggleSwitch = mSwitchBar.getSwitch();
|
mToggleSwitch = mSwitchBar.getSwitch();
|
||||||
mToggleSwitch.setOnBeforeCheckedChangeListener(new ToggleSwitch.OnBeforeCheckedChangeListener() {
|
mToggleSwitch.setOnBeforeCheckedChangeListener((toggleSwitch, checked) -> {
|
||||||
@Override
|
onPreferenceToggled(mPreferenceKey, checked);
|
||||||
public boolean onBeforeCheckedChanged(ToggleSwitch toggleSwitch, boolean checked) {
|
return false;
|
||||||
onPreferenceToggled(mPreferenceKey, checked);
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
});
|
});
|
||||||
|
|
||||||
getBackupListView().setSelector(new ColorDrawable(Color.TRANSPARENT));
|
getListView().setAdapter(mPrintersAdapter);
|
||||||
getBackupListView().setAdapter(mPrintersAdapter);
|
|
||||||
getBackupListView().setOnItemClickListener(new AdapterView.OnItemClickListener() {
|
|
||||||
@Override
|
|
||||||
public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
|
|
||||||
PrinterInfo printer = (PrinterInfo) mPrintersAdapter.getItem(position);
|
|
||||||
|
|
||||||
if (printer.getInfoIntent() != null) {
|
|
||||||
try {
|
|
||||||
getActivity().startIntentSender(printer.getInfoIntent().getIntentSender(),
|
|
||||||
null, 0, 0, 0);
|
|
||||||
} catch (SendIntentException e) {
|
|
||||||
Log.e(LOG_TAG, "Could not execute info intent: %s", e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -446,8 +416,17 @@ public class PrintServiceSettingsFragment extends SettingsPreferenceFragment
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private final class PrintersAdapter extends BaseAdapter
|
public static class ViewHolder extends RecyclerView.ViewHolder {
|
||||||
|
|
||||||
|
public ViewHolder(@NonNull View itemView) {
|
||||||
|
super(itemView);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
private final class PrintersAdapter extends RecyclerView.Adapter<ViewHolder>
|
||||||
implements LoaderManager.LoaderCallbacks<List<PrinterInfo>>, Filterable {
|
implements LoaderManager.LoaderCallbacks<List<PrinterInfo>>, Filterable {
|
||||||
|
|
||||||
private final Object mLock = new Object();
|
private final Object mLock = new Object();
|
||||||
|
|
||||||
private final List<PrinterInfo> mPrinters = new ArrayList<PrinterInfo>();
|
private final List<PrinterInfo> mPrinters = new ArrayList<PrinterInfo>();
|
||||||
@@ -509,19 +488,19 @@ public class PrintServiceSettingsFragment extends SettingsPreferenceFragment
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
notifyDataSetChanged();
|
notifyDataSetChanged();
|
||||||
|
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int getCount() {
|
public int getItemCount() {
|
||||||
synchronized (mLock) {
|
synchronized (mLock) {
|
||||||
return mFilteredPrinters.size();
|
return mFilteredPrinters.size();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
private Object getItem(int position) {
|
||||||
public Object getItem(int position) {
|
|
||||||
synchronized (mLock) {
|
synchronized (mLock) {
|
||||||
return mFilteredPrinters.get(position);
|
return mFilteredPrinters.get(position);
|
||||||
}
|
}
|
||||||
@@ -543,24 +522,27 @@ public class PrintServiceSettingsFragment extends SettingsPreferenceFragment
|
|||||||
return printer.getStatus() != PrinterInfo.STATUS_UNAVAILABLE;
|
return printer.getStatus() != PrinterInfo.STATUS_UNAVAILABLE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@NonNull
|
||||||
@Override
|
@Override
|
||||||
public View getView(int position, View convertView, ViewGroup parent) {
|
public ViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
|
||||||
if (convertView == null) {
|
final View view = LayoutInflater.from(parent.getContext())
|
||||||
convertView = getActivity().getLayoutInflater().inflate(
|
.inflate(R.layout.printer_dropdown_item, parent, false);
|
||||||
R.layout.printer_dropdown_item, parent, false);
|
return new ViewHolder(view);
|
||||||
}
|
}
|
||||||
|
|
||||||
convertView.setEnabled(isActionable(position));
|
@Override
|
||||||
|
public void onBindViewHolder(@NonNull ViewHolder holder, int position) {
|
||||||
|
holder.itemView.setEnabled(isActionable(position));
|
||||||
|
|
||||||
final PrinterInfo printer = (PrinterInfo) getItem(position);
|
final PrinterInfo printer = (PrinterInfo) getItem(position);
|
||||||
CharSequence title = printer.getName();
|
CharSequence title = printer.getName();
|
||||||
CharSequence subtitle = printer.getDescription();
|
CharSequence subtitle = printer.getDescription();
|
||||||
Drawable icon = printer.loadIcon(getActivity());
|
Drawable icon = printer.loadIcon(getActivity());
|
||||||
|
|
||||||
TextView titleView = (TextView) convertView.findViewById(R.id.title);
|
TextView titleView = holder.itemView.findViewById(R.id.title);
|
||||||
titleView.setText(title);
|
titleView.setText(title);
|
||||||
|
|
||||||
TextView subtitleView = (TextView) convertView.findViewById(R.id.subtitle);
|
TextView subtitleView = holder.itemView.findViewById(R.id.subtitle);
|
||||||
if (!TextUtils.isEmpty(subtitle)) {
|
if (!TextUtils.isEmpty(subtitle)) {
|
||||||
subtitleView.setText(subtitle);
|
subtitleView.setText(subtitle);
|
||||||
subtitleView.setVisibility(View.VISIBLE);
|
subtitleView.setVisibility(View.VISIBLE);
|
||||||
@@ -569,7 +551,7 @@ public class PrintServiceSettingsFragment extends SettingsPreferenceFragment
|
|||||||
subtitleView.setVisibility(View.GONE);
|
subtitleView.setVisibility(View.GONE);
|
||||||
}
|
}
|
||||||
|
|
||||||
LinearLayout moreInfoView = (LinearLayout) convertView.findViewById(R.id.more_info);
|
LinearLayout moreInfoView = holder.itemView.findViewById(R.id.more_info);
|
||||||
if (printer.getInfoIntent() != null) {
|
if (printer.getInfoIntent() != null) {
|
||||||
moreInfoView.setVisibility(View.VISIBLE);
|
moreInfoView.setVisibility(View.VISIBLE);
|
||||||
moreInfoView.setOnClickListener(new OnClickListener() {
|
moreInfoView.setOnClickListener(new OnClickListener() {
|
||||||
@@ -587,7 +569,7 @@ public class PrintServiceSettingsFragment extends SettingsPreferenceFragment
|
|||||||
moreInfoView.setVisibility(View.GONE);
|
moreInfoView.setVisibility(View.GONE);
|
||||||
}
|
}
|
||||||
|
|
||||||
ImageView iconView = (ImageView) convertView.findViewById(R.id.icon);
|
ImageView iconView = holder.itemView.findViewById(R.id.icon);
|
||||||
if (icon != null) {
|
if (icon != null) {
|
||||||
iconView.setVisibility(View.VISIBLE);
|
iconView.setVisibility(View.VISIBLE);
|
||||||
if (!isActionable(position)) {
|
if (!isActionable(position)) {
|
||||||
@@ -603,7 +585,18 @@ public class PrintServiceSettingsFragment extends SettingsPreferenceFragment
|
|||||||
iconView.setVisibility(View.GONE);
|
iconView.setVisibility(View.GONE);
|
||||||
}
|
}
|
||||||
|
|
||||||
return convertView;
|
holder.itemView.setOnClickListener(v -> {
|
||||||
|
PrinterInfo pi = (PrinterInfo) getItem(position);
|
||||||
|
|
||||||
|
if (pi.getInfoIntent() != null) {
|
||||||
|
try {
|
||||||
|
getActivity().startIntentSender(pi.getInfoIntent().getIntentSender(),
|
||||||
|
null, 0, 0, 0);
|
||||||
|
} catch (SendIntentException e) {
|
||||||
|
Log.e(LOG_TAG, "Could not execute info intent: %s", e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@@ -642,7 +635,7 @@ public class PrintServiceSettingsFragment extends SettingsPreferenceFragment
|
|||||||
mFilteredPrinters.clear();
|
mFilteredPrinters.clear();
|
||||||
mLastSearchString = null;
|
mLastSearchString = null;
|
||||||
}
|
}
|
||||||
notifyDataSetInvalidated();
|
notifyDataSetChanged();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|