Skip to content
This repository has been archived by the owner on Mar 28, 2024. It is now read-only.

Commit

Permalink
Merge pull request #202 from Z-Jais/master
Browse files Browse the repository at this point in the history
Add image field and refine notification messages
  • Loading branch information
Ziedelth authored Nov 12, 2023
2 parents ee815f7 + 5288caf commit 6fbed44
Show file tree
Hide file tree
Showing 2 changed files with 12 additions and 36 deletions.
42 changes: 8 additions & 34 deletions src/main/kotlin/fr/ziedelth/listeners/EpisodesRelease.kt
Original file line number Diff line number Diff line change
@@ -1,60 +1,34 @@
package fr.ziedelth.listeners

import fr.ziedelth.entities.EpisodeType
import fr.ziedelth.entities.LangType
import fr.ziedelth.entities.Episode
import fr.ziedelth.events.EpisodesReleaseEvent
import fr.ziedelth.utils.Logger
import fr.ziedelth.utils.Notifications
import fr.ziedelth.utils.plugins.events.EventHandler
import fr.ziedelth.utils.plugins.events.Listener
import java.util.*

class EpisodesRelease : Listener {
private var lastDaySend = 0
private var lastSend = mutableListOf<UUID>()

fun toString(triple: Triple<EpisodeType, Int, LangType>): String {
val etName = when (triple.first.name) {
private fun toString(episode: Episode): String {
val etName = when (episode.episodeType!!.name) {
"EPISODE" -> "Épisode"
"SPECIAL" -> "Spécial"
"FILM" -> "Film"
else -> "Épisode"
}

val ltName = when (triple.third.name) {
val ltName = when (episode.langType!!.name) {
"SUBTITLES" -> "VOSTFR"
"VOICE" -> "VF"
else -> "VOSTFR"
}

return "$etName ${triple.second} $ltName"
return "Saison ${episode.season}$etName ${episode.number} $ltName"
}

@EventHandler
fun onEpisodesRelease(event: EpisodesReleaseEvent) {
val currentDay = Calendar.getInstance()[Calendar.DAY_OF_YEAR]

if (currentDay != lastDaySend) {
lastDaySend = currentDay
lastSend.clear()
}

val animes = event.episodes.map { it.anime to toString(Triple(it.episodeType!!, it.number!!, it.langType!!)) }
.distinctBy { it.first?.uuid }.filter { !lastSend.contains(it.first?.uuid) }
if (animes.isEmpty()) return
lastSend.addAll(animes.map { it.first!!.uuid })

val animeNames = animes.sortedBy { it.first!!.name!!.lowercase() }
val joinToString = animeNames.joinToString(", ") { "${it.first!!.name} - ${it.second}" }
Logger.info("Sending notification for ${animes.size} animes: $joinToString")

Notifications.send(body = joinToString)
animes.forEach {
Notifications.send(
title = it.first!!.name,
body = "${it.second} est disponible !",
topic = it.first!!.uuid.toString()
)
event.episodes.forEach {
Notifications.send(it.anime!!.name!!, toString(it), it.image!!)
Notifications.send(it.anime!!.name!!, toString(it), it.image, it.anime!!.uuid.toString())
}
}
}
6 changes: 4 additions & 2 deletions src/main/kotlin/fr/ziedelth/utils/Notifications.kt
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@ object Notifications {
Logger.info("Firebase initialized")
}

fun send(title: String? = null, body: String? = null, topic: String = "all") {
fun send(title: String, body: String, image: String, topic: String = "all") {
with(System.getenv("SEND_NOTIFICATIONS")) {
if (this.isNullOrBlank() || this == "false") return
}
Expand All @@ -39,7 +39,9 @@ object Notifications {
AndroidConfig.builder().setNotification(
AndroidNotification.builder()
.setTitle(title)
.setBody(body).build()
.setBody(body)
.setImage(image)
.build()
).build()
).setTopic(topic).build()
)
Expand Down

0 comments on commit 6fbed44

Please sign in to comment.