PlayerAndroid/app/src/main/java/code/name/monkey/retromusic/adapter/playlist/PlaylistAdapter.kt

255 lines
9.1 KiB
Kotlin
Raw Normal View History

2019-04-20 05:29:45 +00:00
package code.name.monkey.retromusic.adapter.playlist
2018-11-30 01:06:16 +00:00
2020-04-16 14:52:04 +00:00
import android.graphics.Bitmap
2020-01-17 17:19:06 +00:00
import android.graphics.Color
import android.graphics.drawable.Drawable
2020-04-16 14:52:04 +00:00
import android.os.AsyncTask
2020-02-01 18:14:04 +00:00
import android.text.TextUtils
2019-12-01 15:27:01 +00:00
import android.view.LayoutInflater
import android.view.MenuItem
import android.view.View
import android.view.ViewGroup
2018-11-30 01:06:16 +00:00
import androidx.appcompat.app.AppCompatActivity
import androidx.appcompat.widget.PopupMenu
import code.name.monkey.appthemehelper.ThemeStore
2019-12-01 15:27:01 +00:00
import code.name.monkey.appthemehelper.util.ATHUtil
import code.name.monkey.appthemehelper.util.TintHelper
2018-11-30 01:06:16 +00:00
import code.name.monkey.retromusic.R
2019-12-01 15:27:01 +00:00
import code.name.monkey.retromusic.adapter.base.AbsMultiSelectAdapter
import code.name.monkey.retromusic.adapter.base.MediaEntryViewHolder
import code.name.monkey.retromusic.dialogs.ClearSmartPlaylistDialog
import code.name.monkey.retromusic.dialogs.DeletePlaylistDialog
2020-01-17 17:19:06 +00:00
import code.name.monkey.retromusic.extensions.hide
import code.name.monkey.retromusic.extensions.show
2019-12-01 15:27:01 +00:00
import code.name.monkey.retromusic.helper.menu.PlaylistMenuHelper
import code.name.monkey.retromusic.helper.menu.SongsMenuHelper
2018-11-30 01:06:16 +00:00
import code.name.monkey.retromusic.interfaces.CabHolder
import code.name.monkey.retromusic.loaders.PlaylistSongsLoader
2019-12-01 15:27:01 +00:00
import code.name.monkey.retromusic.model.AbsCustomPlaylist
import code.name.monkey.retromusic.model.Playlist
import code.name.monkey.retromusic.model.Song
import code.name.monkey.retromusic.model.smartplaylist.AbsSmartPlaylist
import code.name.monkey.retromusic.model.smartplaylist.LastAddedPlaylist
2020-04-16 14:52:04 +00:00
import code.name.monkey.retromusic.util.AutoGeneratedPlaylistBitmap
2019-12-01 15:27:01 +00:00
import code.name.monkey.retromusic.util.MusicUtil
import code.name.monkey.retromusic.util.NavigationUtil
import java.util.*
2018-11-30 01:06:16 +00:00
2019-11-15 17:44:42 +00:00
class PlaylistAdapter(
2020-01-17 17:19:06 +00:00
private val activity: AppCompatActivity,
2020-02-17 11:20:08 +00:00
var dataSet: List<Playlist>,
2020-01-17 17:19:06 +00:00
private var itemLayoutRes: Int,
cabHolder: CabHolder?
2019-11-15 17:44:42 +00:00
) : AbsMultiSelectAdapter<PlaylistAdapter.ViewHolder, Playlist>(
2020-01-17 17:19:06 +00:00
activity,
cabHolder,
R.menu.menu_playlists_selection
2019-11-15 17:44:42 +00:00
) {
2019-12-01 15:27:01 +00:00
init {
setHasStableIds(true)
}
2020-02-17 11:20:08 +00:00
fun swapDataSet(dataSet: List<Playlist>) {
2019-12-01 15:27:01 +00:00
this.dataSet = dataSet
notifyDataSetChanged()
}
override fun getItemId(position: Int): Long {
return dataSet[position].id.toLong()
}
override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): ViewHolder {
val view = LayoutInflater.from(activity).inflate(itemLayoutRes, parent, false)
return createViewHolder(view)
}
2020-02-01 18:14:04 +00:00
fun createViewHolder(view: View): ViewHolder {
2019-12-01 15:27:01 +00:00
return ViewHolder(view)
}
2020-02-01 18:14:04 +00:00
private fun getPlaylistTitle(playlist: Playlist): String {
return if (TextUtils.isEmpty(playlist.name)) "-" else playlist.name
2019-12-01 15:27:01 +00:00
}
2020-02-01 18:14:04 +00:00
private fun getPlaylistText(playlist: Playlist): String {
2019-12-01 15:27:01 +00:00
return MusicUtil.getPlaylistInfoString(activity, getSongs(playlist))
}
override fun onBindViewHolder(holder: ViewHolder, position: Int) {
val playlist = dataSet[position]
holder.itemView.isActivated = isChecked(playlist)
holder.title?.text = getPlaylistTitle(playlist)
holder.text?.text = getPlaylistText(playlist)
holder.image?.setImageDrawable(getIconRes(playlist))
2020-01-17 17:19:06 +00:00
val isChecked = isChecked(playlist)
if (isChecked) {
holder.menu?.hide()
} else {
holder.menu?.show()
}
2020-04-16 14:52:04 +00:00
PlaylistBitmapLoader(this, holder, playlist).execute()
2019-12-01 15:27:01 +00:00
}
private fun getIconRes(playlist: Playlist): Drawable {
return if (MusicUtil.isFavoritePlaylist(activity, playlist))
2020-01-17 17:19:06 +00:00
TintHelper.createTintedDrawable(
activity,
R.drawable.ic_favorite_white_24dp,
ThemeStore.accentColor(activity)
)
else TintHelper.createTintedDrawable(
activity,
R.drawable.ic_playlist_play_white_24dp,
ATHUtil.resolveColor(activity, R.attr.colorControlNormal)
)
2019-12-01 15:27:01 +00:00
}
override fun getItemViewType(position: Int): Int {
return if (dataSet[position] is AbsSmartPlaylist) SMART_PLAYLIST else DEFAULT_PLAYLIST
}
override fun getItemCount(): Int {
return dataSet.size
}
override fun getIdentifier(position: Int): Playlist? {
return dataSet[position]
}
override fun getName(playlist: Playlist): String {
return playlist.name
}
override fun onMultipleItemAction(menuItem: MenuItem, selection: ArrayList<Playlist>) {
when (menuItem.itemId) {
R.id.action_delete_playlist -> {
var i = 0
while (i < selection.size) {
val playlist = selection[i]
if (playlist is AbsSmartPlaylist) {
ClearSmartPlaylistDialog.create(playlist).show(
2020-01-17 17:19:06 +00:00
activity.supportFragmentManager, "CLEAR_PLAYLIST_" + playlist.name
2019-12-01 15:27:01 +00:00
)
selection.remove(playlist)
i--
}
i++
}
if (selection.size > 0) {
DeletePlaylistDialog.create(selection)
2020-01-17 17:19:06 +00:00
.show(activity.supportFragmentManager, "DELETE_PLAYLIST")
2019-12-01 15:27:01 +00:00
}
}
else -> SongsMenuHelper.handleMenuClick(
2020-01-17 17:19:06 +00:00
activity,
getSongList(selection),
menuItem.itemId
2019-12-01 15:27:01 +00:00
)
}
}
private fun getSongList(playlists: List<Playlist>): ArrayList<Song> {
val songs = ArrayList<Song>()
for (playlist in playlists) {
if (playlist is AbsCustomPlaylist) {
songs.addAll(playlist.getSongs(activity))
} else {
songs.addAll(PlaylistSongsLoader.getPlaylistSongList(activity, playlist.id))
}
}
return songs
}
private fun getSongs(playlist: Playlist): ArrayList<Song> {
val songs = ArrayList<Song>()
if (playlist is AbsSmartPlaylist) {
songs.addAll(playlist.getSongs(activity))
} else {
songs.addAll(PlaylistSongsLoader.getPlaylistSongList(activity, playlist.id))
}
return songs
}
inner class ViewHolder(itemView: View) : MediaEntryViewHolder(itemView) {
init {
image?.apply {
val iconPadding =
activity.resources.getDimensionPixelSize(R.dimen.list_item_image_icon_padding)
2019-12-01 15:27:01 +00:00
setPadding(iconPadding, iconPadding, iconPadding, iconPadding)
}
menu?.setOnClickListener { view ->
val playlist = dataSet[adapterPosition]
val popupMenu = PopupMenu(activity, view)
popupMenu.inflate(
2020-01-17 17:19:06 +00:00
if (itemViewType == SMART_PLAYLIST) R.menu.menu_item_smart_playlist
else R.menu.menu_item_playlist
2019-12-01 15:27:01 +00:00
)
if (playlist is LastAddedPlaylist) {
popupMenu.menu.findItem(R.id.action_clear_playlist).isVisible = false
}
popupMenu.setOnMenuItemClickListener { item ->
if (item.itemId == R.id.action_clear_playlist) {
if (playlist is AbsSmartPlaylist) {
ClearSmartPlaylistDialog.create(playlist).show(
2020-01-17 17:19:06 +00:00
activity.supportFragmentManager,
"CLEAR_SMART_PLAYLIST_" + playlist.name
2019-12-01 15:27:01 +00:00
)
return@setOnMenuItemClickListener true
}
}
PlaylistMenuHelper.handleMenuClick(
2020-01-17 17:19:06 +00:00
activity, dataSet[adapterPosition], item
2019-12-01 15:27:01 +00:00
)
}
popupMenu.show()
}
imageTextContainer?.apply {
cardElevation = 0f
2020-01-17 17:19:06 +00:00
setCardBackgroundColor(Color.TRANSPARENT)
2019-12-01 15:27:01 +00:00
}
}
override fun onClick(v: View?) {
if (isInQuickSelectMode) {
toggleChecked(adapterPosition)
} else {
val playlist = dataSet[adapterPosition]
NavigationUtil.goToPlaylistNew(activity, playlist)
}
}
override fun onLongClick(v: View?): Boolean {
toggleChecked(adapterPosition)
return true
}
}
2020-04-16 14:52:04 +00:00
class PlaylistBitmapLoader(
private var adapter: PlaylistAdapter,
private var viewHolder: ViewHolder,
private var playlist: Playlist
) : AsyncTask<Void, Void, Bitmap>() {
override fun doInBackground(vararg params: Void?): Bitmap {
val songs = PlaylistSongsLoader.getPlaylistSongList(adapter.activity, playlist)
return AutoGeneratedPlaylistBitmap.getBitmap(adapter.activity, songs, false, false)
}
override fun onPostExecute(result: Bitmap?) {
super.onPostExecute(result)
viewHolder.image?.setImageBitmap(result)
}
}
2019-12-01 15:27:01 +00:00
companion object {
val TAG: String = PlaylistAdapter::class.java.simpleName
private const val SMART_PLAYLIST = 0
private const val DEFAULT_PLAYLIST = 1
}
2018-11-30 01:06:16 +00:00
}