teapod/app/src/main/java/org/mosad/teapod/ui/fragments/MediaFragment.kt

125 lines
4.6 KiB
Kotlin
Raw Normal View History

package org.mosad.teapod.ui.fragments
2020-10-11 10:02:00 +02:00
import android.graphics.Color
import android.graphics.drawable.ColorDrawable
2020-10-11 10:02:00 +02:00
import android.os.Bundle
import android.util.Log
2020-10-11 10:02:00 +02:00
import androidx.fragment.app.Fragment
import android.view.LayoutInflater
import android.view.View
import android.view.ViewGroup
import androidx.recyclerview.widget.LinearLayoutManager
import androidx.recyclerview.widget.RecyclerView
2020-10-11 10:02:00 +02:00
import com.bumptech.glide.Glide
import com.bumptech.glide.request.RequestOptions
import jp.wasabeef.glide.transformations.BlurTransformation
2020-10-11 10:02:00 +02:00
import kotlinx.android.synthetic.main.fragment_media.*
2020-10-11 13:18:20 +02:00
import org.mosad.teapod.MainActivity
2020-10-11 10:02:00 +02:00
import org.mosad.teapod.R
2020-10-13 23:47:48 +02:00
import org.mosad.teapod.parser.AoDParser
2020-10-15 21:00:31 +02:00
import org.mosad.teapod.util.CacheHelper
import org.mosad.teapod.util.DataTypes.MediaType
import org.mosad.teapod.util.adapter.EpisodeItemAdapter
import org.mosad.teapod.util.Media
import org.mosad.teapod.util.TMDBResponse
2020-10-11 10:02:00 +02:00
class MediaFragment(private val media: Media, private val tmdb: TMDBResponse) : Fragment() {
private lateinit var adapterRecEpisodes: EpisodeItemAdapter
private lateinit var viewManager: RecyclerView.LayoutManager
2020-10-11 10:02:00 +02:00
override fun onCreateView(inflater: LayoutInflater, container: ViewGroup?, savedInstanceState: Bundle?): View? {
return inflater.inflate(R.layout.fragment_media, container, false)
}
override fun onViewCreated(view: View, savedInstanceState: Bundle?) {
super.onViewCreated(view, savedInstanceState)
initGUI()
initActions()
}
/**
* if tmdb data is present, use it, else use the aod data
*/
private fun initGUI() {
// generic gui
2020-10-13 16:30:23 +02:00
val backdropUrl = if (tmdb.backdropUrl.isNotEmpty()) tmdb.backdropUrl else media.info.posterLink
val posterUrl = if (tmdb.posterUrl.isNotEmpty()) tmdb.posterUrl else media.info.posterLink
Glide.with(requireContext()).load(backdropUrl)
.apply(RequestOptions.placeholderOf(ColorDrawable(Color.DKGRAY)))
2020-10-16 10:05:11 +02:00
.apply(RequestOptions.bitmapTransform(BlurTransformation(20, 3)))
.into(image_backdrop)
Glide.with(requireContext()).load(posterUrl)
.into(image_poster)
text_title.text = media.title
text_year.text = media.info.year.toString()
text_age.text = media.info.age.toString()
text_overview.text = media.info.shortDesc
2020-10-15 21:00:31 +02:00
check_my_list.isChecked = CacheHelper.myList.contains(media.link)
// specific gui
if (media.type == MediaType.TVSHOW) {
adapterRecEpisodes = EpisodeItemAdapter(media.episodes, requireContext())
viewManager = LinearLayoutManager(context)
recycler_episodes.layoutManager = viewManager
recycler_episodes.adapter = adapterRecEpisodes
text_episodes_or_runtime.text = getString(R.string.text_episodes_count, media.info.episodesCount)
} else if (media.type == MediaType.MOVIE) {
recycler_episodes.visibility = View.GONE
if (tmdb.runtime > 0) {
text_episodes_or_runtime.text = getString(R.string.text_runtime, tmdb.runtime)
} else {
text_episodes_or_runtime.visibility = View.GONE
}
}
2020-10-11 10:02:00 +02:00
}
private fun initActions() {
button_play.setOnClickListener {
when (media.type) {
MediaType.MOVIE -> playStream(media.episodes.first().streamUrl)
MediaType.TVSHOW -> playStream(media.episodes.first().streamUrl)
else -> Log.e(javaClass.name, "Wrong Type: $media.type")
}
}
2020-10-15 21:00:31 +02:00
// add or remove media from myList
check_my_list.setOnCheckedChangeListener { buttonView, isChecked ->
if (isChecked) {
CacheHelper.myList.add(media.link)
} else {
CacheHelper.myList.remove(media.link)
}
CacheHelper.saveMyList(requireContext())
// TODO notify home fragment on change
}
// set onItemClick only in adapter is initialized
if (this::adapterRecEpisodes.isInitialized) {
2020-10-16 10:05:11 +02:00
adapterRecEpisodes.onImageClick = { _, position ->
playStream(media.episodes[position].streamUrl)
2020-10-13 23:47:48 +02:00
// update watched state
AoDParser().sendCallback(media.episodes[position].watchedCallback)
adapterRecEpisodes.updateWatchedState(true, position)
adapterRecEpisodes.notifyDataSetChanged()
}
}
2020-10-11 10:02:00 +02:00
}
private fun playStream(url: String) {
2020-10-11 13:18:20 +02:00
val mainActivity = activity as MainActivity
println("url is: $url")
mainActivity.startPlayer(url)
2020-10-11 10:02:00 +02:00
}
}