ntfy-android/app/src/main/java/io/heckel/ntfy/MainActivity.kt

118 lines
4.4 KiB
Kotlin
Raw Normal View History

2021-10-27 07:35:51 +13:00
package io.heckel.ntfy
import android.app.Activity
2021-10-26 13:25:54 +13:00
import android.app.NotificationChannel
import android.app.NotificationManager
import android.content.Context
import android.content.Intent
2021-10-26 13:25:54 +13:00
import android.os.Build
import android.os.Bundle
import android.view.View
import androidx.activity.viewModels
2021-10-26 07:24:44 +13:00
import androidx.appcompat.app.AppCompatActivity
2021-10-26 13:25:54 +13:00
import androidx.core.app.NotificationCompat
import androidx.core.app.NotificationManagerCompat
import androidx.recyclerview.widget.RecyclerView
2021-10-26 07:24:44 +13:00
import io.heckel.ntfy.add.AddTopicActivity
2021-10-27 15:41:19 +13:00
import io.heckel.ntfy.data.Status
import io.heckel.ntfy.data.Topic
2021-10-27 15:41:19 +13:00
import io.heckel.ntfy.data.topicShortUrl
import io.heckel.ntfy.data.topicUrl
2021-10-27 07:40:52 +13:00
import io.heckel.ntfy.detail.DetailActivity
2021-10-26 13:25:54 +13:00
import kotlin.random.Random
2021-10-27 14:44:12 +13:00
const val TOPIC_ID = "topic_id"
const val TOPIC_NAME = "topic_name"
const val TOPIC_BASE_URL = "base_url"
2021-10-27 07:35:51 +13:00
class MainActivity : AppCompatActivity() {
private val newTopicActivityRequestCode = 1
private val topicsViewModel by viewModels<TopicsViewModel> {
2021-10-27 13:34:09 +13:00
TopicsViewModelFactory()
}
override fun onCreate(savedInstanceState: Bundle?) {
super.onCreate(savedInstanceState)
setContentView(R.layout.activity_main)
// Floating action button ("+")
val fab: View = findViewById(R.id.fab)
fab.setOnClickListener {
fabOnClick()
}
// Update main list based on topicsViewModel (& its datasource/livedata)
val adapter = TopicsAdapter { topic -> topicOnClick(topic) }
val recyclerView: RecyclerView = findViewById(R.id.recycler_view)
2021-10-26 06:45:56 +13:00
recyclerView.adapter = adapter
topicsViewModel.list().observe(this) {
it?.let {
2021-10-26 06:45:56 +13:00
adapter.submitList(it as MutableList<Topic>)
}
2021-10-26 06:45:56 +13:00
}
// Set up notification channel
2021-10-26 13:25:54 +13:00
createNotificationChannel()
topicsViewModel.setNotificationListener { n -> displayNotification(n) }
2021-10-26 14:14:09 +13:00
}
2021-10-26 13:25:54 +13:00
2021-10-26 06:45:56 +13:00
/* Opens TopicDetailActivity when RecyclerView item is clicked. */
private fun topicOnClick(topic: Topic) {
2021-10-27 07:40:52 +13:00
val intent = Intent(this, DetailActivity()::class.java)
2021-10-26 06:45:56 +13:00
intent.putExtra(TOPIC_ID, topic.id)
startActivity(intent)
}
2021-10-26 06:45:56 +13:00
/* Adds topic to topicList when FAB is clicked. */
private fun fabOnClick() {
val intent = Intent(this, AddTopicActivity::class.java)
startActivityForResult(intent, newTopicActivityRequestCode)
}
override fun onActivityResult(requestCode: Int, resultCode: Int, intentData: Intent?) {
super.onActivityResult(requestCode, resultCode, intentData)
if (requestCode == newTopicActivityRequestCode && resultCode == Activity.RESULT_OK) {
intentData?.let { data ->
2021-10-27 14:44:12 +13:00
val name = data.getStringExtra(TOPIC_NAME) ?: return
val baseUrl = data.getStringExtra(TOPIC_BASE_URL) ?: return
2021-10-27 15:41:19 +13:00
val topic = Topic(Random.nextLong(), name, baseUrl, Status.CONNECTING, 0)
2021-10-27 05:23:41 +13:00
topicsViewModel.add(topic)
}
}
}
2021-10-26 13:25:54 +13:00
private fun displayNotification(n: Notification) {
2021-10-27 05:23:41 +13:00
val channelId = getString(R.string.notification_channel_id)
val notification = NotificationCompat.Builder(this, channelId)
.setSmallIcon(R.drawable.ntfy)
2021-10-27 15:41:19 +13:00
.setContentTitle(topicShortUrl(n.topic))
.setContentText(n.message)
2021-10-27 05:23:41 +13:00
.setPriority(NotificationCompat.PRIORITY_DEFAULT)
.build()
with(NotificationManagerCompat.from(this)) {
notify(Random.nextInt(), notification)
}
}
2021-10-27 06:46:49 +13:00
private fun createNotificationChannel() {
// Create the NotificationChannel, but only on API 26+ because
// the NotificationChannel class is new and not in the support library
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.O) {
val channelId = getString(R.string.notification_channel_id)
val name = getString(R.string.notification_channel_name)
val descriptionText = getString(R.string.notification_channel_name)
val importance = NotificationManager.IMPORTANCE_DEFAULT
val channel = NotificationChannel(channelId, name, importance).apply {
description = descriptionText
}
// Register the channel with the system
val notificationManager: NotificationManager =
getSystemService(Context.NOTIFICATION_SERVICE) as NotificationManager
notificationManager.createNotificationChannel(channel)
}
}
}