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

200 lines
6.9 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
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
import code.name.monkey.retromusic.glide.GlideApp
import code.name.monkey.retromusic.glide.RetroGlideExtension
2019-12-10 17:36:20 +00:00
import code.name.monkey.retromusic.glide.RetroMusicColoredTarget
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
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(
override val activity: FragmentActivity,
2020-02-17 11:20:08 +00:00
var dataSet: List<Album>,
2020-12-03 20:57:44 +00:00
var itemLayoutRes: Int,
iCabHolder: ICabHolder?,
val listener: IAlbumClickListener?
2019-11-15 17:44:42 +00:00
) : AbsMultiSelectAdapter<AlbumAdapter.ViewHolder, Album>(
2020-01-02 03:53:43 +00:00
activity,
2020-12-03 20:57:44 +00:00
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 {
2020-12-03 20:57:44 +00:00
val view = LayoutInflater.from(activity).inflate(itemLayoutRes, 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 {
2019-12-10 17:36:20 +00:00
return album.title
}
protected open fun getAlbumText(album: Album): String? {
return album.albumArtist.let {
if (it.isNullOrEmpty()) {
album.artistName
} else {
it
}
}
2019-12-10 17:36:20 +00:00
}
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)
// Check if imageContainer exists so we can have a smooth transition without
// CardView clipping, if it doesn't exist in current layout set transition name to image instead.
if (holder.imageContainer != null) {
ViewCompat.setTransitionName(holder.imageContainer!!, album.id.toString())
} else {
ViewCompat.setTransitionName(holder.image!!, album.id.toString())
}
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)
holder.imageContainerCard?.setCardBackgroundColor(color.backgroundColor)
}
2019-12-10 17:36:20 +00:00
protected open fun loadAlbumCover(album: Album, holder: ViewHolder) {
if (holder.image == null) {
return
}
val song = album.safeGetFirstSong()
GlideApp.with(activity).asBitmapPalette().albumCoverOptions(song)
//.checkIgnoreMediaStore()
.load(RetroGlideExtension.getSongModel(song))
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 {
2021-10-11 06:17:55 +00:00
return album.title
2019-12-10 17:36:20 +00:00
}
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
SortOrder.AlbumSortOrder.ALBUM_ARTIST -> sectionName = dataSet[position].albumArtist
2019-12-10 17:36:20 +00:00
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 {
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 {
2020-12-03 20:57:44 +00:00
image?.let {
listener?.onAlbumClick(dataSet[layoutPosition].id, imageContainer ?: it)
2020-12-03 20:57:44 +00:00
}
2019-12-10 17:36:20 +00:00
}
}
override fun onLongClick(v: View?): Boolean {
return toggleChecked(layoutPosition)
2019-12-10 17:36:20 +00:00
}
}
companion object {
val TAG: String = AlbumAdapter::class.java.simpleName
}
2018-11-30 01:06:16 +00:00
}