mirror of
				https://github.com/TeamNewPipe/NewPipe
				synced 2025-10-24 20:07:39 +00:00 
			
		
		
		
	Return ViewBinding instead of View in BaseLocalListFragment's getListHeader() and getListFooter() methods.
This commit is contained in:
		| @@ -4,6 +4,8 @@ import android.content.SharedPreferences; | ||||
| import android.content.res.Configuration; | ||||
| import android.content.res.Resources; | ||||
| import android.os.Bundle; | ||||
|  | ||||
| import androidx.annotation.Nullable; | ||||
| import androidx.preference.PreferenceManager; | ||||
| import android.util.Log; | ||||
| import android.view.Menu; | ||||
| @@ -15,8 +17,10 @@ import androidx.fragment.app.Fragment; | ||||
| import androidx.recyclerview.widget.GridLayoutManager; | ||||
| import androidx.recyclerview.widget.LinearLayoutManager; | ||||
| import androidx.recyclerview.widget.RecyclerView; | ||||
| import androidx.viewbinding.ViewBinding; | ||||
|  | ||||
| import org.schabi.newpipe.R; | ||||
| import org.schabi.newpipe.databinding.PignateFooterBinding; | ||||
| import org.schabi.newpipe.fragments.BaseStateFragment; | ||||
| import org.schabi.newpipe.fragments.list.ListViewContract; | ||||
|  | ||||
| @@ -42,8 +46,8 @@ public abstract class BaseLocalListFragment<I, N> extends BaseStateFragment<I> | ||||
|     //////////////////////////////////////////////////////////////////////////*/ | ||||
|  | ||||
|     private static final int LIST_MODE_UPDATE_FLAG = 0x32; | ||||
|     private View headerRootView; | ||||
|     private View footerRootView; | ||||
|     private ViewBinding headerRootBinding; | ||||
|     private ViewBinding footerRootBinding; | ||||
|     protected LocalItemListAdapter itemListAdapter; | ||||
|     protected RecyclerView itemsList; | ||||
|     private int updateFlags = 0; | ||||
| @@ -86,12 +90,13 @@ public abstract class BaseLocalListFragment<I, N> extends BaseStateFragment<I> | ||||
|     // Lifecycle - View | ||||
|     //////////////////////////////////////////////////////////////////////////*/ | ||||
|  | ||||
|     protected View getListHeader() { | ||||
|     @Nullable | ||||
|     protected ViewBinding getListHeader() { | ||||
|         return null; | ||||
|     } | ||||
|  | ||||
|     protected View getListFooter() { | ||||
|         return activity.getLayoutInflater().inflate(R.layout.pignate_footer, itemsList, false); | ||||
|     protected ViewBinding getListFooter() { | ||||
|         return PignateFooterBinding.inflate(activity.getLayoutInflater(), itemsList, false); | ||||
|     } | ||||
|  | ||||
|     protected RecyclerView.LayoutManager getGridLayoutManager() { | ||||
| @@ -120,10 +125,12 @@ public abstract class BaseLocalListFragment<I, N> extends BaseStateFragment<I> | ||||
|         itemsList.setLayoutManager(useGrid ? getGridLayoutManager() : getListLayoutManager()); | ||||
|  | ||||
|         itemListAdapter.setUseGridVariant(useGrid); | ||||
|         headerRootView = getListHeader(); | ||||
|         itemListAdapter.setHeader(headerRootView); | ||||
|         footerRootView = getListFooter(); | ||||
|         itemListAdapter.setFooter(footerRootView); | ||||
|         headerRootBinding = getListHeader(); | ||||
|         if (headerRootBinding != null) { | ||||
|             itemListAdapter.setHeader(headerRootBinding.getRoot()); | ||||
|         } | ||||
|         footerRootBinding = getListFooter(); | ||||
|         itemListAdapter.setFooter(footerRootBinding.getRoot()); | ||||
|  | ||||
|         itemsList.setAdapter(itemListAdapter); | ||||
|     } | ||||
| @@ -180,8 +187,8 @@ public abstract class BaseLocalListFragment<I, N> extends BaseStateFragment<I> | ||||
|         if (itemsList != null) { | ||||
|             animateView(itemsList, false, 200); | ||||
|         } | ||||
|         if (headerRootView != null) { | ||||
|             animateView(headerRootView, false, 200); | ||||
|         if (headerRootBinding != null) { | ||||
|             animateView(headerRootBinding.getRoot(), false, 200); | ||||
|         } | ||||
|     } | ||||
|  | ||||
| @@ -191,8 +198,8 @@ public abstract class BaseLocalListFragment<I, N> extends BaseStateFragment<I> | ||||
|         if (itemsList != null) { | ||||
|             animateView(itemsList, true, 200); | ||||
|         } | ||||
|         if (headerRootView != null) { | ||||
|             animateView(headerRootView, true, 200); | ||||
|         if (headerRootBinding != null) { | ||||
|             animateView(headerRootBinding.getRoot(), true, 200); | ||||
|         } | ||||
|     } | ||||
|  | ||||
| @@ -204,8 +211,8 @@ public abstract class BaseLocalListFragment<I, N> extends BaseStateFragment<I> | ||||
|         if (itemsList != null) { | ||||
|             animateView(itemsList, false, 200); | ||||
|         } | ||||
|         if (headerRootView != null) { | ||||
|             animateView(headerRootView, false, 200); | ||||
|         if (headerRootBinding != null) { | ||||
|             animateView(headerRootBinding.getRoot(), false, 200); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -10,13 +10,12 @@ import android.view.MenuInflater; | ||||
| import android.view.MenuItem; | ||||
| import android.view.View; | ||||
| import android.view.ViewGroup; | ||||
| import android.widget.ImageView; | ||||
| import android.widget.TextView; | ||||
| import android.widget.Toast; | ||||
|  | ||||
| import androidx.annotation.NonNull; | ||||
| import androidx.annotation.Nullable; | ||||
| import androidx.appcompat.app.AlertDialog; | ||||
| import androidx.viewbinding.ViewBinding; | ||||
|  | ||||
| import com.google.android.material.snackbar.Snackbar; | ||||
|  | ||||
| @@ -26,6 +25,8 @@ import org.schabi.newpipe.R; | ||||
| import org.schabi.newpipe.database.LocalItem; | ||||
| import org.schabi.newpipe.database.stream.StreamStatisticsEntry; | ||||
| import org.schabi.newpipe.database.stream.model.StreamEntity; | ||||
| import org.schabi.newpipe.databinding.PlaylistControlBinding; | ||||
| import org.schabi.newpipe.databinding.StatisticPlaylistControlBinding; | ||||
| import org.schabi.newpipe.extractor.stream.StreamInfoItem; | ||||
| import org.schabi.newpipe.extractor.stream.StreamType; | ||||
| import org.schabi.newpipe.info_list.InfoItemDialog; | ||||
| @@ -60,13 +61,10 @@ public class StatisticsPlaylistFragment | ||||
|     @State | ||||
|     Parcelable itemsListState; | ||||
|     private StatisticSortMode sortMode = StatisticSortMode.LAST_PLAYED; | ||||
|     private View headerPlayAllButton; | ||||
|     private View headerPopupButton; | ||||
|     private View headerBackgroundButton; | ||||
|     private View playlistCtrl; | ||||
|     private View sortButton; | ||||
|     private ImageView sortButtonIcon; | ||||
|     private TextView sortButtonText; | ||||
|  | ||||
|     private StatisticPlaylistControlBinding headerBinding; | ||||
|     private PlaylistControlBinding playlistControlBinding; | ||||
|  | ||||
|     /* Used for independent events */ | ||||
|     private Subscription databaseSubscription; | ||||
|     private HistoryRecordManager recordManager; | ||||
| @@ -131,17 +129,12 @@ public class StatisticsPlaylistFragment | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     protected View getListHeader() { | ||||
|         final View headerRootLayout = activity.getLayoutInflater() | ||||
|                 .inflate(R.layout.statistic_playlist_control, itemsList, false); | ||||
|         playlistCtrl = headerRootLayout.findViewById(R.id.playlist_control); | ||||
|         headerPlayAllButton = headerRootLayout.findViewById(R.id.playlist_ctrl_play_all_button); | ||||
|         headerPopupButton = headerRootLayout.findViewById(R.id.playlist_ctrl_play_popup_button); | ||||
|         headerBackgroundButton = headerRootLayout.findViewById(R.id.playlist_ctrl_play_bg_button); | ||||
|         sortButton = headerRootLayout.findViewById(R.id.sortButton); | ||||
|         sortButtonIcon = headerRootLayout.findViewById(R.id.sortButtonIcon); | ||||
|         sortButtonText = headerRootLayout.findViewById(R.id.sortButtonText); | ||||
|         return headerRootLayout; | ||||
|     protected ViewBinding getListHeader() { | ||||
|         headerBinding = StatisticPlaylistControlBinding.inflate(activity.getLayoutInflater(), | ||||
|                 itemsList, false); | ||||
|         playlistControlBinding = headerBinding.playlistControl; | ||||
|  | ||||
|         return headerBinding; | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
| @@ -245,14 +238,13 @@ public class StatisticsPlaylistFragment | ||||
|         if (itemListAdapter != null) { | ||||
|             itemListAdapter.unsetSelectedListener(); | ||||
|         } | ||||
|         if (headerBackgroundButton != null) { | ||||
|             headerBackgroundButton.setOnClickListener(null); | ||||
|         } | ||||
|         if (headerPlayAllButton != null) { | ||||
|             headerPlayAllButton.setOnClickListener(null); | ||||
|         } | ||||
|         if (headerPopupButton != null) { | ||||
|             headerPopupButton.setOnClickListener(null); | ||||
|         if (playlistControlBinding != null) { | ||||
|             playlistControlBinding.playlistCtrlPlayBgButton.setOnClickListener(null); | ||||
|             playlistControlBinding.playlistCtrlPlayAllButton.setOnClickListener(null); | ||||
|             playlistControlBinding.playlistCtrlPlayPopupButton.setOnClickListener(null); | ||||
|  | ||||
|             headerBinding = null; | ||||
|             playlistControlBinding = null; | ||||
|         } | ||||
|  | ||||
|         if (databaseSubscription != null) { | ||||
| @@ -311,7 +303,7 @@ public class StatisticsPlaylistFragment | ||||
|             return; | ||||
|         } | ||||
|  | ||||
|         playlistCtrl.setVisibility(View.VISIBLE); | ||||
|         playlistControlBinding.getRoot().setVisibility(View.VISIBLE); | ||||
|  | ||||
|         itemListAdapter.clearStreamItemList(); | ||||
|  | ||||
| @@ -326,13 +318,13 @@ public class StatisticsPlaylistFragment | ||||
|             itemsListState = null; | ||||
|         } | ||||
|  | ||||
|         headerPlayAllButton.setOnClickListener(view -> | ||||
|         playlistControlBinding.playlistCtrlPlayAllButton.setOnClickListener(view -> | ||||
|                 NavigationHelper.playOnMainPlayer(activity, getPlayQueue())); | ||||
|         headerPopupButton.setOnClickListener(view -> | ||||
|         playlistControlBinding.playlistCtrlPlayPopupButton.setOnClickListener(view -> | ||||
|                 NavigationHelper.playOnPopupPlayer(activity, getPlayQueue(), false)); | ||||
|         headerBackgroundButton.setOnClickListener(view -> | ||||
|         playlistControlBinding.playlistCtrlPlayBgButton.setOnClickListener(view -> | ||||
|                 NavigationHelper.playOnBackgroundPlayer(activity, getPlayQueue(), false)); | ||||
|         sortButton.setOnClickListener(view -> toggleSortMode()); | ||||
|         headerBinding.sortButton.setOnClickListener(view -> toggleSortMode()); | ||||
|  | ||||
|         hideLoading(); | ||||
|     } | ||||
| @@ -368,15 +360,15 @@ public class StatisticsPlaylistFragment | ||||
|         if (sortMode == StatisticSortMode.LAST_PLAYED) { | ||||
|             sortMode = StatisticSortMode.MOST_PLAYED; | ||||
|             setTitle(getString(R.string.title_most_played)); | ||||
|             sortButtonIcon.setImageResource( | ||||
|             headerBinding.sortButtonIcon.setImageResource( | ||||
|                 ThemeHelper.resolveResourceIdFromAttr(requireContext(), R.attr.ic_history)); | ||||
|             sortButtonText.setText(R.string.title_last_played); | ||||
|             headerBinding.sortButtonText.setText(R.string.title_last_played); | ||||
|         } else { | ||||
|             sortMode = StatisticSortMode.LAST_PLAYED; | ||||
|             setTitle(getString(R.string.title_last_played)); | ||||
|             sortButtonIcon.setImageResource( | ||||
|             headerBinding.sortButtonIcon.setImageResource( | ||||
|                 ThemeHelper.resolveResourceIdFromAttr(requireContext(), R.attr.ic_filter_list)); | ||||
|             sortButtonText.setText(R.string.title_most_played); | ||||
|             headerBinding.sortButtonText.setText(R.string.title_most_played); | ||||
|         } | ||||
|         startLoading(true); | ||||
|     } | ||||
|   | ||||
| @@ -14,7 +14,6 @@ import android.view.MenuItem; | ||||
| import android.view.View; | ||||
| import android.view.ViewGroup; | ||||
| import android.widget.EditText; | ||||
| import android.widget.TextView; | ||||
| import android.widget.Toast; | ||||
|  | ||||
| import androidx.annotation.NonNull; | ||||
| @@ -22,6 +21,7 @@ import androidx.annotation.Nullable; | ||||
| import androidx.appcompat.app.AlertDialog; | ||||
| import androidx.recyclerview.widget.ItemTouchHelper; | ||||
| import androidx.recyclerview.widget.RecyclerView; | ||||
| import androidx.viewbinding.ViewBinding; | ||||
|  | ||||
| import org.reactivestreams.Subscriber; | ||||
| import org.reactivestreams.Subscription; | ||||
| @@ -32,6 +32,8 @@ import org.schabi.newpipe.database.history.model.StreamHistoryEntry; | ||||
| import org.schabi.newpipe.database.playlist.PlaylistStreamEntry; | ||||
| import org.schabi.newpipe.database.stream.model.StreamEntity; | ||||
| import org.schabi.newpipe.database.stream.model.StreamStateEntity; | ||||
| import org.schabi.newpipe.databinding.LocalPlaylistHeaderBinding; | ||||
| import org.schabi.newpipe.databinding.PlaylistControlBinding; | ||||
| import org.schabi.newpipe.extractor.stream.StreamInfoItem; | ||||
| import org.schabi.newpipe.extractor.stream.StreamType; | ||||
| import org.schabi.newpipe.info_list.InfoItemDialog; | ||||
| @@ -77,13 +79,8 @@ public class LocalPlaylistFragment extends BaseLocalListFragment<List<PlaylistSt | ||||
|     @State | ||||
|     Parcelable itemsListState; | ||||
|  | ||||
|     private View headerRootLayout; | ||||
|     private TextView headerTitleView; | ||||
|     private TextView headerStreamCount; | ||||
|     private View playlistControl; | ||||
|     private View headerPlayAllButton; | ||||
|     private View headerPopupButton; | ||||
|     private View headerBackgroundButton; | ||||
|     private LocalPlaylistHeaderBinding headerBinding; | ||||
|     private PlaylistControlBinding playlistControlBinding; | ||||
|  | ||||
|     private ItemTouchHelper itemTouchHelper; | ||||
|  | ||||
| @@ -137,8 +134,8 @@ public class LocalPlaylistFragment extends BaseLocalListFragment<List<PlaylistSt | ||||
|     public void setTitle(final String title) { | ||||
|         super.setTitle(title); | ||||
|  | ||||
|         if (headerTitleView != null) { | ||||
|             headerTitleView.setText(title); | ||||
|         if (headerBinding != null) { | ||||
|             headerBinding.playlistTitleView.setText(title); | ||||
|         } | ||||
|     } | ||||
|  | ||||
| @@ -149,28 +146,21 @@ public class LocalPlaylistFragment extends BaseLocalListFragment<List<PlaylistSt | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     protected View getListHeader() { | ||||
|         headerRootLayout = activity.getLayoutInflater() | ||||
|                 .inflate(R.layout.local_playlist_header, itemsList, false); | ||||
|     protected ViewBinding getListHeader() { | ||||
|         headerBinding = LocalPlaylistHeaderBinding.inflate(activity.getLayoutInflater(), itemsList, | ||||
|                 false); | ||||
|         playlistControlBinding = headerBinding.playlistControl; | ||||
|  | ||||
|         headerTitleView = headerRootLayout.findViewById(R.id.playlist_title_view); | ||||
|         headerTitleView.setSelected(true); | ||||
|         headerBinding.playlistTitleView.setSelected(true); | ||||
|  | ||||
|         headerStreamCount = headerRootLayout.findViewById(R.id.playlist_stream_count); | ||||
|  | ||||
|         playlistControl = headerRootLayout.findViewById(R.id.playlist_control); | ||||
|         headerPlayAllButton = headerRootLayout.findViewById(R.id.playlist_ctrl_play_all_button); | ||||
|         headerPopupButton = headerRootLayout.findViewById(R.id.playlist_ctrl_play_popup_button); | ||||
|         headerBackgroundButton = headerRootLayout.findViewById(R.id.playlist_ctrl_play_bg_button); | ||||
|  | ||||
|         return headerRootLayout; | ||||
|         return headerBinding; | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     protected void initListeners() { | ||||
|         super.initListeners(); | ||||
|  | ||||
|         headerTitleView.setOnClickListener(view -> createRenameDialog()); | ||||
|         headerBinding.playlistTitleView.setOnClickListener(view -> createRenameDialog()); | ||||
|  | ||||
|         itemTouchHelper = new ItemTouchHelper(getItemTouchCallback()); | ||||
|         itemTouchHelper.attachToRecyclerView(itemsList); | ||||
| @@ -210,22 +200,18 @@ public class LocalPlaylistFragment extends BaseLocalListFragment<List<PlaylistSt | ||||
|     @Override | ||||
|     public void showLoading() { | ||||
|         super.showLoading(); | ||||
|         if (headerRootLayout != null) { | ||||
|             animateView(headerRootLayout, false, 200); | ||||
|         } | ||||
|         if (playlistControl != null) { | ||||
|             animateView(playlistControl, false, 200); | ||||
|         if (headerBinding != null) { | ||||
|             animateView(headerBinding.getRoot(), false, 200); | ||||
|             animateView(playlistControlBinding.getRoot(), false, 200); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     @Override | ||||
|     public void hideLoading() { | ||||
|         super.hideLoading(); | ||||
|         if (headerRootLayout != null) { | ||||
|             animateView(headerRootLayout, true, 200); | ||||
|         } | ||||
|         if (playlistControl != null) { | ||||
|             animateView(playlistControl, true, 200); | ||||
|         if (headerBinding != null) { | ||||
|             animateView(headerBinding.getRoot(), true, 200); | ||||
|             animateView(playlistControlBinding.getRoot(), true, 200); | ||||
|         } | ||||
|     } | ||||
|  | ||||
| @@ -277,14 +263,13 @@ public class LocalPlaylistFragment extends BaseLocalListFragment<List<PlaylistSt | ||||
|         if (itemListAdapter != null) { | ||||
|             itemListAdapter.unsetSelectedListener(); | ||||
|         } | ||||
|         if (headerBackgroundButton != null) { | ||||
|             headerBackgroundButton.setOnClickListener(null); | ||||
|         } | ||||
|         if (headerPlayAllButton != null) { | ||||
|             headerPlayAllButton.setOnClickListener(null); | ||||
|         } | ||||
|         if (headerPopupButton != null) { | ||||
|             headerPopupButton.setOnClickListener(null); | ||||
|         if (playlistControlBinding != null) { | ||||
|             playlistControlBinding.playlistCtrlPlayBgButton.setOnClickListener(null); | ||||
|             playlistControlBinding.playlistCtrlPlayAllButton.setOnClickListener(null); | ||||
|             playlistControlBinding.playlistCtrlPlayPopupButton.setOnClickListener(null); | ||||
|  | ||||
|             headerBinding = null; | ||||
|             playlistControlBinding = null; | ||||
|         } | ||||
|  | ||||
|         if (databaseSubscription != null) { | ||||
| @@ -494,19 +479,19 @@ public class LocalPlaylistFragment extends BaseLocalListFragment<List<PlaylistSt | ||||
|         } | ||||
|         setVideoCount(itemListAdapter.getItemsList().size()); | ||||
|  | ||||
|         headerPlayAllButton.setOnClickListener(view -> | ||||
|         playlistControlBinding.playlistCtrlPlayAllButton.setOnClickListener(view -> | ||||
|                 NavigationHelper.playOnMainPlayer(activity, getPlayQueue())); | ||||
|         headerPopupButton.setOnClickListener(view -> | ||||
|         playlistControlBinding.playlistCtrlPlayPopupButton.setOnClickListener(view -> | ||||
|                 NavigationHelper.playOnPopupPlayer(activity, getPlayQueue(), false)); | ||||
|         headerBackgroundButton.setOnClickListener(view -> | ||||
|         playlistControlBinding.playlistCtrlPlayBgButton.setOnClickListener(view -> | ||||
|                 NavigationHelper.playOnBackgroundPlayer(activity, getPlayQueue(), false)); | ||||
|  | ||||
|         headerPopupButton.setOnLongClickListener(view -> { | ||||
|         playlistControlBinding.playlistCtrlPlayPopupButton.setOnLongClickListener(view -> { | ||||
|             NavigationHelper.enqueueOnPopupPlayer(activity, getPlayQueue(), true); | ||||
|             return true; | ||||
|         }); | ||||
|  | ||||
|         headerBackgroundButton.setOnLongClickListener(view -> { | ||||
|         playlistControlBinding.playlistCtrlPlayBgButton.setOnLongClickListener(view -> { | ||||
|             NavigationHelper.enqueueOnBackgroundPlayer(activity, getPlayQueue(), true); | ||||
|             return true; | ||||
|         }); | ||||
| @@ -806,8 +791,9 @@ public class LocalPlaylistFragment extends BaseLocalListFragment<List<PlaylistSt | ||||
|     } | ||||
|  | ||||
|     private void setVideoCount(final long count) { | ||||
|         if (activity != null && headerStreamCount != null) { | ||||
|             headerStreamCount.setText(Localization.localizeStreamCount(activity, count)); | ||||
|         if (activity != null && headerBinding != null) { | ||||
|             headerBinding.playlistStreamCount.setText(Localization | ||||
|                     .localizeStreamCount(activity, count)); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|   | ||||
| @@ -40,7 +40,10 @@ | ||||
|         android:layout_height="wrap_content" | ||||
|         android:layout_below="@id/playlist_stream_count"> | ||||
|  | ||||
|         <include layout="@layout/playlist_control" /> | ||||
|         <include | ||||
|             android:id="@+id/playlist_control" | ||||
|             layout="@layout/playlist_control" /> | ||||
|  | ||||
|     </LinearLayout> | ||||
|  | ||||
| </RelativeLayout> | ||||
|   | ||||
| @@ -38,6 +38,8 @@ | ||||
|             tools:ignore="RtlHardcoded" /> | ||||
|     </RelativeLayout> | ||||
|  | ||||
|     <include layout="@layout/playlist_control" /> | ||||
|     <include | ||||
|         android:id="@+id/playlist_control" | ||||
|         layout="@layout/playlist_control" /> | ||||
|  | ||||
| </LinearLayout> | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Isira Seneviratne
					Isira Seneviratne