Removed extra actions
This commit is contained in:
parent
05b3c18848
commit
d2284f410d
12 changed files with 29 additions and 218 deletions
|
@ -1,16 +1,12 @@
|
|||
package code.name.monkey.retromusic.adapter.song
|
||||
|
||||
import android.view.View
|
||||
import android.widget.PopupMenu
|
||||
import androidx.appcompat.app.AppCompatActivity
|
||||
import androidx.appcompat.widget.AppCompatImageView
|
||||
import code.name.monkey.retromusic.R
|
||||
import code.name.monkey.retromusic.helper.MusicPlayerRemote
|
||||
import code.name.monkey.retromusic.helper.SortOrder.SongSortOrder
|
||||
import code.name.monkey.retromusic.interfaces.CabHolder
|
||||
import code.name.monkey.retromusic.model.Song
|
||||
import code.name.monkey.retromusic.util.PreferenceUtil
|
||||
import com.google.android.material.textview.MaterialTextView
|
||||
import com.google.android.material.button.MaterialButton
|
||||
|
||||
class ShuffleButtonSongAdapter(
|
||||
activity: AppCompatActivity,
|
||||
|
@ -32,77 +28,14 @@ class ShuffleButtonSongAdapter(
|
|||
viewHolder.shuffleAction?.setOnClickListener {
|
||||
MusicPlayerRemote.openAndShuffleQueue(dataSet, true)
|
||||
}
|
||||
val songCount = activity.resources.getQuantityString(R.plurals.songCount, dataSet.size, dataSet.size)
|
||||
viewHolder.songCount?.text = songCount
|
||||
viewHolder.sortAction?.setOnClickListener {
|
||||
showSortPopupMenu(it)
|
||||
}
|
||||
} else {
|
||||
super.onBindViewHolder(holder, position - 1)
|
||||
}
|
||||
}
|
||||
|
||||
private fun showGridPopupMenu(view: View) {
|
||||
val popupMenu = PopupMenu(activity, view)
|
||||
popupMenu.menuInflater.inflate(R.menu.menu_grid_options, popupMenu.menu)
|
||||
popupMenu.setOnMenuItemClickListener {
|
||||
when (it.itemId) {
|
||||
R.id.action_grid_size_1 -> {
|
||||
PreferenceUtil.getInstance(activity).setSongGridSize(1)
|
||||
}
|
||||
R.id.action_grid_size_2 -> {
|
||||
PreferenceUtil.getInstance(activity).setSongGridSize(2)
|
||||
}
|
||||
R.id.action_grid_size_3 -> {
|
||||
PreferenceUtil.getInstance(activity).setSongGridSize(3)
|
||||
}
|
||||
R.id.action_grid_size_4 -> {
|
||||
PreferenceUtil.getInstance(activity).setSongGridSize(4)
|
||||
}
|
||||
|
||||
}
|
||||
return@setOnMenuItemClickListener true
|
||||
}
|
||||
popupMenu.show()
|
||||
}
|
||||
|
||||
private fun showSortPopupMenu(view: View) {
|
||||
val popupMenu = PopupMenu(activity, view)
|
||||
popupMenu.menuInflater.inflate(R.menu.menu_song_sort, popupMenu.menu)
|
||||
popupMenu.setOnMenuItemClickListener {
|
||||
when (it.itemId) {
|
||||
R.id.action_song_sort_order_asc -> {
|
||||
PreferenceUtil.getInstance(activity).songSortOrder = SongSortOrder.SONG_A_Z
|
||||
}
|
||||
R.id.action_song_sort_order_desc -> {
|
||||
PreferenceUtil.getInstance(activity).songSortOrder = SongSortOrder.SONG_Z_A
|
||||
}
|
||||
R.id.action_song_sort_order_artist -> {
|
||||
PreferenceUtil.getInstance(activity).songSortOrder = SongSortOrder.SONG_ARTIST
|
||||
}
|
||||
R.id.action_song_sort_order_album -> {
|
||||
PreferenceUtil.getInstance(activity).songSortOrder = SongSortOrder.SONG_ALBUM
|
||||
}
|
||||
R.id.action_song_sort_order_date -> {
|
||||
PreferenceUtil.getInstance(activity).songSortOrder = SongSortOrder.SONG_DATE
|
||||
}
|
||||
R.id.action_song_sort_order_composer -> {
|
||||
PreferenceUtil.getInstance(activity).songSortOrder = SongSortOrder.COMPOSER
|
||||
}
|
||||
R.id.action_song_sort_order_year -> {
|
||||
PreferenceUtil.getInstance(activity).songSortOrder = SongSortOrder.SONG_YEAR
|
||||
}
|
||||
}
|
||||
return@setOnMenuItemClickListener true
|
||||
}
|
||||
popupMenu.show()
|
||||
}
|
||||
|
||||
inner class ViewHolder(itemView: View) : AbsOffsetSongAdapter.ViewHolder(itemView) {
|
||||
val playAction: AppCompatImageView? = itemView.findViewById(R.id.playAction)
|
||||
val shuffleAction: AppCompatImageView? = itemView.findViewById(R.id.shuffleAction)
|
||||
val sortAction: AppCompatImageView? = itemView.findViewById(R.id.sortAction)
|
||||
val songCount: MaterialTextView? = itemView.findViewById(R.id.songCount)
|
||||
val playAction: MaterialButton? = itemView.findViewById(R.id.playAction)
|
||||
val shuffleAction: MaterialButton? = itemView.findViewById(R.id.shuffleAction)
|
||||
|
||||
override fun onClick(v: View?) {
|
||||
if (itemViewType == OFFSET_ITEM) {
|
||||
|
|
|
@ -1,7 +1,5 @@
|
|||
package code.name.monkey.retromusic.fragments.mainactivity
|
||||
|
||||
import android.content.SharedPreferences
|
||||
import android.content.SharedPreferences.OnSharedPreferenceChangeListener
|
||||
import android.os.Bundle
|
||||
import android.view.View
|
||||
import androidx.annotation.LayoutRes
|
||||
|
@ -20,7 +18,7 @@ import java.util.ArrayList
|
|||
import javax.inject.Inject
|
||||
|
||||
class SongsFragment : AbsLibraryPagerRecyclerViewCustomGridSizeFragment<SongAdapter, LinearLayoutManager>(),
|
||||
SongView, MainActivityFragmentCallbacks, OnSharedPreferenceChangeListener {
|
||||
SongView, MainActivityFragmentCallbacks {
|
||||
|
||||
@Inject
|
||||
lateinit var songPresenter: SongPresenter
|
||||
|
@ -84,13 +82,11 @@ class SongsFragment : AbsLibraryPagerRecyclerViewCustomGridSizeFragment<SongAdap
|
|||
super.onResume()
|
||||
if (adapter?.dataSet.isNullOrEmpty())
|
||||
songPresenter.loadSongs()
|
||||
PreferenceUtil.getInstance(requireContext()).registerOnSharedPreferenceChangedListener(this)
|
||||
}
|
||||
|
||||
override fun onDestroyView() {
|
||||
super.onDestroyView()
|
||||
songPresenter.detachView()
|
||||
PreferenceUtil.getInstance(requireContext()).unregisterOnSharedPreferenceChangedListener(this)
|
||||
}
|
||||
|
||||
override fun showEmptyView() {
|
||||
|
@ -137,10 +133,4 @@ class SongsFragment : AbsLibraryPagerRecyclerViewCustomGridSizeFragment<SongAdap
|
|||
override fun handleBackPress(): Boolean {
|
||||
return false
|
||||
}
|
||||
|
||||
override fun onSharedPreferenceChanged(sharedPreferences: SharedPreferences?, key: String?) {
|
||||
if (key == PreferenceUtil.SONG_SORT_ORDER || key == PreferenceUtil.SONG_GRID_SIZE) {
|
||||
songPresenter.loadSongs()
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue