package com.example.melodify
import android.content.Intent
import android.icu.text.CaseMap.Title
import android.os.Bundle
import android.view.View
import android.widget.RelativeLayout
import android.widget.TextView
import androidx.appcompat.app.AppCompatActivity
import androidx.core.content.ContextCompat.startActivity
import androidx.recyclerview.widget.LinearLayoutManager
import androidx.recyclerview.widget.RecyclerView
import com.bumptech.glide.Glide
import com.bumptech.glide.load.resource.bitmap.RoundedCorners
import com.bumptech.glide.request.RequestOptions
import com.example.melodify.adapter.CategoryAdapter
import com.example.melodify.adapter.SectionSongListAdapter
import com.example.melodify.databinding.ActivityMainBinding
import com.example.melodify.models.CategoryModel
import com.example.melodify.models.SongModel
import com.google.firebase.Firebase
import com.google.firebase.firestore.FirebaseFirestore
import com.google.firebase.firestore.Query
import com.google.firebase.firestore.firestore
import com.google.firebase.firestore.toObjects
class MainActivity : AppCompatActivity() {
val db = Firebase.firestore
lateinit var binding: ActivityMainBinding
lateinit var categoryAdapter: CategoryAdapter
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
binding = ActivityMainBinding.inflate(layoutInflater)
setContentView(binding.root)
getCategories()
setupSection("section_1",binding.section1MainLayout,binding.section1Title,binding.section1RecyclerView)
setupSection("section_2",binding.section2MainLayout,binding.section2Title,binding.section2RecyclerView)
setupSection("section_3", binding.section3MainLayout, binding.section3Title, binding.section3RecyclerView)
setupMostlyPlayed("mostly_played", binding.mostlyPlayedMainLayout, binding.mostlyPlayedTitle, binding.mostlyPlayedRecyclerView)
}
override fun onResume() {
super.onResume()
showPlayerView()
}
fun showPlayerView() {
binding.playerView.setOnClickListener {
startActivity(Intent(this, PlayerActivity::class.java))
}
MyExoplayer.getCurrentSong()?.let {
binding.playerView.visibility = View.VISIBLE
binding.songTitleTextView.text = "Now Playing : " + it.title
Glide.with(binding.songCoverImageView).load(it.coverUrl)
.apply(
RequestOptions().transform(RoundedCorners(32))
).into(binding.songCoverImageView)
} ?: run {
binding.playerView.visibility = View.GONE
}
}
//Categories
fun getCategories() {
FirebaseFirestore.getInstance().collection("category")
.get().addOnSuccessListener {
val categoryList = it.toObjects(CategoryModel::class.java)
setupCategoryRecyclerView(categoryList)
}
}
fun setupCategoryRecyclerView(categoryList: List<CategoryModel>) {
categoryAdapter = CategoryAdapter(categoryList)
binding.categoriesRecyclerView.layoutManager =
LinearLayoutManager(this, LinearLayoutManager.HORIZONTAL, false)
binding.categoriesRecyclerView.adapter = categoryAdapter
}
//Sections
fun setupSection(
id: String,
mainLayout: RelativeLayout,
titleView: TextView,
recyclerView: RecyclerView
) {
FirebaseFirestore.getInstance().collection("sections")
.document(id)
.get().addOnSuccessListener {
val section = it.toObject(CategoryModel::class.java)
section?.apply {
mainLayout.visibility = View.VISIBLE
titleView.text = name
recyclerView.layoutManager = LinearLayoutManager(
this@MainActivity,
LinearLayoutManager.HORIZONTAL,
false
)
recyclerView.adapter = SectionSongListAdapter(songs)
mainLayout.setOnClickListener {
SongsListActivity.category = section
startActivity(Intent(this@MainActivity, SongsListActivity::class.java))
}
}
}
}
fun setupMostlyPlayed(
id: String,
mainLayout: RelativeLayout,
titleView: TextView,
recyclerView: RecyclerView
) {
FirebaseFirestore.getInstance().collection("sections")
.document(id)
.get().addOnSuccessListener {
//get most played songs
FirebaseFirestore.getInstance().collection("songs")
.orderBy("count",Query.Direction.DESCENDING)
.limit(5)
.get().addOnSuccessListener {songListSnapshot->
val songsModelList = songListSnapshot.toObjects<SongModel>()
val songsIdList = songsModelList.map{
it.id
}.toList()
val section = it.toObject(CategoryModel::class.java)
section?.apply {
section.songs = songsIdList
mainLayout.visibility = View.VISIBLE
titleView.text = name
recyclerView.layoutManager = LinearLayoutManager(this@MainActivity, LinearLayoutManager.HORIZONTAL, false)
recyclerView.adapter = SectionSongListAdapter(songs)
mainLayout.setOnClickListener {
SongsListActivity.category = section
startActivity(Intent(this@MainActivity, SongsListActivity::class.java))
}
}
}
}
}
}
Write, Run & Share Kotlin code online using OneCompiler’s Kotlin online compiler for free. It’s a modern and fast online playground for Kotlin, supporting the latest version and ideal for learning, experimenting, and sharing code instantly.
Kotlin is a statically typed, modern programming language developed by JetBrains. It runs on the JVM and is fully interoperable with Java. Kotlin is concise, expressive, and safe, and it’s officially supported by Google for Android app development.
The following is a simple Kotlin program that prints a greeting:
fun main() {
println("Hello, OneCompiler!")
}
OneCompiler’s Kotlin editor supports stdin. You can provide input using the I/O tab. Here's a sample program that reads a line of input and prints a greeting:
fun main() {
print("Enter your name: ")
val name = readLine()
println("Hello, $name")
}
val name: String = "OneCompiler" // Immutable
var age: Int = 25 // Mutable
Kotlin supports type inference, so explicit types are optional:
val city = "Hyderabad"
var count = 10
val score = 85
if (score >= 50) {
println("Pass")
} else {
println("Fail")
}
for (i in 1..5) {
println(i)
}
var i = 1
while (i <= 5) {
println(i)
i++
}
var j = 1
do {
println(j)
j++
} while (j <= 5)
fun add(a: Int, b: Int): Int {
return a + b
}
fun greet(name: String) = "Hello, $name"
val items = listOf("apple", "banana", "cherry")
for (item in items) {
println(item)
}
This guide provides a quick reference to Kotlin programming syntax and features. Start coding in Kotlin using OneCompiler’s Kotlin online compiler today!