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!