PlayerAndroid/app/src/main/java/code/name/monkey/retromusic/adapter/album/AlbumAdapter.kt

204 lines
6.8 KiB
Kotlin
Raw Normal View History

2020-10-06 08:46:04 +00:00
/*
* Copyright (c) 2020 Hemanth Savarla.
*
* Licensed under the GNU General Public License v3
*
* This is free software: you can redistribute it and/or modify it
* under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
*
* This software is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
* without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
* See the GNU General Public License for more details.
*
*/
2019-04-20 05:29:45 +00:00
package code.name.monkey.retromusic.adapter.album
2018-11-30 01:06:16 +00:00
import android.content.res.ColorStateList
import android.content.res.Resources
2019-12-10 17:36:20 +00:00
import android.view.LayoutInflater
import android.view.MenuItem
import android.view.View
import android.view.ViewGroup
import androidx.core.view.ViewCompat
2020-08-11 18:29:44 +00:00
import androidx.fragment.app.FragmentActivity
2019-09-18 15:44:14 +00:00
import code.name.monkey.retromusic.R
2019-12-10 17:36:20 +00:00
import code.name.monkey.retromusic.adapter.base.AbsMultiSelectAdapter
import code.name.monkey.retromusic.adapter.base.MediaEntryViewHolder
2020-02-25 13:15:23 +00:00
import code.name.monkey.retromusic.glide.AlbumGlideRequest
2019-12-10 17:36:20 +00:00
import code.name.monkey.retromusic.glide.RetroMusicColoredTarget
import code.name.monkey.retromusic.helper.MusicPlayerRemote
import code.name.monkey.retromusic.helper.SortOrder
2018-11-30 01:06:16 +00:00
import code.name.monkey.retromusic.helper.menu.SongsMenuHelper
import code.name.monkey.retromusic.interfaces.IAlbumClickListener
import code.name.monkey.retromusic.interfaces.ICabHolder
2019-12-10 17:36:20 +00:00
import code.name.monkey.retromusic.model.Album
import code.name.monkey.retromusic.model.Song
import code.name.monkey.retromusic.util.MusicUtil
2020-06-06 18:57:28 +00:00
import code.name.monkey.retromusic.util.PreferenceUtil
import code.name.monkey.retromusic.util.color.MediaNotificationProcessor
import com.bumptech.glide.Glide
2020-01-17 17:19:06 +00:00
import me.zhanghai.android.fastscroll.PopupTextProvider
2018-11-30 01:06:16 +00:00
2019-11-15 17:44:42 +00:00
open class AlbumAdapter(
2020-08-11 18:29:44 +00:00
protected val activity: FragmentActivity,
2020-02-17 11:20:08 +00:00
var dataSet: List<Album>,
2020-01-02 03:53:43 +00:00
protected var itemLayoutRes: Int,
ICabHolder: ICabHolder?,
private val albumClickListener: IAlbumClickListener?
2019-11-15 17:44:42 +00:00
) : AbsMultiSelectAdapter<AlbumAdapter.ViewHolder, Album>(
2020-01-02 03:53:43 +00:00
activity,
ICabHolder,
2020-01-02 03:53:43 +00:00
R.menu.menu_media_selection
2020-01-17 17:19:06 +00:00
), PopupTextProvider {
2020-01-02 03:53:43 +00:00
2019-12-10 17:36:20 +00:00
init {
this.setHasStableIds(true)
}
2020-02-17 11:20:08 +00:00
fun swapDataSet(dataSet: List<Album>) {
2019-12-10 17:36:20 +00:00
this.dataSet = dataSet
notifyDataSetChanged()
}
override fun onCreateViewHolder(parent: ViewGroup, viewType: Int): ViewHolder {
val view =
try {
LayoutInflater.from(activity).inflate(itemLayoutRes, parent, false)
} catch (e: Resources.NotFoundException) {
LayoutInflater.from(activity).inflate(R.layout.item_grid, parent, false)
}
2019-12-10 17:36:20 +00:00
return createViewHolder(view, viewType)
}
protected open fun createViewHolder(view: View, viewType: Int): ViewHolder {
return ViewHolder(view)
}
private fun getAlbumTitle(album: Album): String? {
return album.title
}
protected open fun getAlbumText(album: Album): String? {
return album.artistName
}
override fun onBindViewHolder(holder: ViewHolder, position: Int) {
val album = dataSet[position]
val isChecked = isChecked(album)
holder.itemView.isActivated = isChecked
holder.title?.text = getAlbumTitle(album)
holder.text?.text = getAlbumText(album)
2020-01-02 03:53:43 +00:00
holder.playSongs?.setOnClickListener {
album.songs.let { songs ->
2020-01-02 03:53:43 +00:00
MusicPlayerRemote.openQueue(
songs,
0,
true
)
}
}
2019-12-10 17:36:20 +00:00
loadAlbumCover(album, holder)
}
2020-05-09 13:41:20 +00:00
protected open fun setColors(color: MediaNotificationProcessor, holder: ViewHolder) {
2019-12-10 17:36:20 +00:00
if (holder.paletteColorContainer != null) {
2020-05-09 13:41:20 +00:00
holder.title?.setTextColor(color.primaryTextColor)
holder.text?.setTextColor(color.secondaryTextColor)
holder.paletteColorContainer?.setBackgroundColor(color.backgroundColor)
2019-12-10 17:36:20 +00:00
}
2020-05-09 13:41:20 +00:00
holder.mask?.backgroundTintList = ColorStateList.valueOf(color.primaryTextColor)
2019-12-10 17:36:20 +00:00
}
protected open fun loadAlbumCover(album: Album, holder: ViewHolder) {
if (holder.image == null) {
return
}
2020-02-25 13:15:23 +00:00
AlbumGlideRequest.Builder.from(Glide.with(activity), album.safeGetFirstSong())
2020-09-05 15:52:10 +00:00
.checkIgnoreMediaStore()
2020-02-25 13:15:23 +00:00
.generatePalette(activity)
.build()
2020-01-02 03:53:43 +00:00
.into(object : RetroMusicColoredTarget(holder.image!!) {
override fun onColorReady(colors: MediaNotificationProcessor) {
2020-05-09 13:41:20 +00:00
setColors(colors, holder)
2020-01-02 03:53:43 +00:00
}
})
2019-12-10 17:36:20 +00:00
}
override fun getItemCount(): Int {
return dataSet.size
}
override fun getItemId(position: Int): Long {
return dataSet[position].id
2019-12-10 17:36:20 +00:00
}
override fun getIdentifier(position: Int): Album? {
return dataSet[position]
}
override fun getName(album: Album): String {
return album.title!!
}
override fun onMultipleItemAction(
2020-10-06 08:46:04 +00:00
menuItem: MenuItem,
selection: List<Album>
2019-12-10 17:36:20 +00:00
) {
SongsMenuHelper.handleMenuClick(activity, getSongList(selection), menuItem.itemId)
}
private fun getSongList(albums: List<Album>): List<Song> {
2019-12-10 17:36:20 +00:00
val songs = ArrayList<Song>()
for (album in albums) {
2020-09-18 11:01:55 +00:00
songs.addAll(album.songs)
2019-12-10 17:36:20 +00:00
}
return songs
}
2020-01-17 17:19:06 +00:00
override fun getPopupText(position: Int): String {
return getSectionName(position)
}
private fun getSectionName(position: Int): String {
2019-12-10 17:36:20 +00:00
var sectionName: String? = null
2020-06-06 18:57:28 +00:00
when (PreferenceUtil.albumSortOrder) {
2020-01-02 03:53:43 +00:00
SortOrder.AlbumSortOrder.ALBUM_A_Z, SortOrder.AlbumSortOrder.ALBUM_Z_A -> sectionName =
dataSet[position].title
2019-12-10 17:36:20 +00:00
SortOrder.AlbumSortOrder.ALBUM_ARTIST -> sectionName = dataSet[position].artistName
SortOrder.AlbumSortOrder.ALBUM_YEAR -> return MusicUtil.getYearString(
2020-01-02 03:53:43 +00:00
dataSet[position].year
2019-12-10 17:36:20 +00:00
)
}
return MusicUtil.getSectionName(sectionName)
}
inner class ViewHolder(itemView: View) : MediaEntryViewHolder(itemView) {
init {
setImageTransitionName("Album")
2019-12-10 17:36:20 +00:00
menu?.visibility = View.GONE
}
override fun onClick(v: View?) {
super.onClick(v)
if (isInQuickSelectMode) {
2020-04-15 13:08:42 +00:00
toggleChecked(layoutPosition)
2019-12-10 17:36:20 +00:00
} else {
ViewCompat.setTransitionName(itemView, "album")
2020-09-18 11:01:55 +00:00
albumClickListener?.onAlbumClick(dataSet[layoutPosition].id, itemView)
2019-12-10 17:36:20 +00:00
}
}
override fun onLongClick(v: View?): Boolean {
2020-04-15 13:08:42 +00:00
toggleChecked(layoutPosition)
2019-12-10 17:36:20 +00:00
return super.onLongClick(v)
}
}
companion object {
val TAG: String = AlbumAdapter::class.java.simpleName
}
2018-11-30 01:06:16 +00:00
}