|
@@ -94,8 +94,7 @@ class OutcomingVoiceMessageViewHolder(outcomingView: View) : MessageHolders
|
|
|
binding.seekbar.max = message.voiceMessageDuration
|
|
|
|
|
|
if (message.isPlayingVoiceMessage) {
|
|
|
- binding.progressBar.visibility = View.GONE
|
|
|
- binding.playPauseBtn.visibility = View.VISIBLE
|
|
|
+ showPlayButton()
|
|
|
binding.playPauseBtn.icon = ContextCompat.getDrawable(
|
|
|
context!!,
|
|
|
R.drawable.ic_baseline_pause_voice_message_24
|
|
@@ -110,8 +109,7 @@ class OutcomingVoiceMessageViewHolder(outcomingView: View) : MessageHolders
|
|
|
}
|
|
|
|
|
|
if (message.isDownloadingVoiceMessage) {
|
|
|
- binding.playPauseBtn.visibility = View.GONE
|
|
|
- binding.progressBar.visibility = View.VISIBLE
|
|
|
+ showVoiceMessageLoading()
|
|
|
} else {
|
|
|
binding.progressBar.visibility = View.GONE
|
|
|
}
|
|
@@ -172,8 +170,7 @@ class OutcomingVoiceMessageViewHolder(outcomingView: View) : MessageHolders
|
|
|
try {
|
|
|
for (workInfo in workers.get()) {
|
|
|
if (workInfo.state == WorkInfo.State.RUNNING || workInfo.state == WorkInfo.State.ENQUEUED) {
|
|
|
- binding.progressBar.visibility = View.VISIBLE
|
|
|
- binding.playPauseBtn.visibility = View.GONE
|
|
|
+ showVoiceMessageLoading()
|
|
|
WorkManager.getInstance(context!!).getWorkInfoByIdLiveData(workInfo.id)
|
|
|
.observeForever { info: WorkInfo? ->
|
|
|
if (info != null) {
|
|
@@ -181,18 +178,15 @@ class OutcomingVoiceMessageViewHolder(outcomingView: View) : MessageHolders
|
|
|
when (info.state) {
|
|
|
WorkInfo.State.RUNNING -> {
|
|
|
Log.d(TAG, "WorkInfo.State.RUNNING in ViewHolder")
|
|
|
- binding.playPauseBtn.visibility = View.GONE
|
|
|
- binding.progressBar.visibility = View.VISIBLE
|
|
|
+ showVoiceMessageLoading()
|
|
|
}
|
|
|
WorkInfo.State.SUCCEEDED -> {
|
|
|
Log.d(TAG, "WorkInfo.State.SUCCEEDED in ViewHolder")
|
|
|
- binding.playPauseBtn.visibility = View.VISIBLE
|
|
|
- binding.progressBar.visibility = View.GONE
|
|
|
+ showPlayButton()
|
|
|
}
|
|
|
WorkInfo.State.FAILED -> {
|
|
|
Log.d(TAG, "WorkInfo.State.FAILED in ViewHolder")
|
|
|
- binding.playPauseBtn.visibility = View.VISIBLE
|
|
|
- binding.progressBar.visibility = View.GONE
|
|
|
+ showPlayButton()
|
|
|
}
|
|
|
else -> {
|
|
|
}
|
|
@@ -208,6 +202,16 @@ class OutcomingVoiceMessageViewHolder(outcomingView: View) : MessageHolders
|
|
|
}
|
|
|
}
|
|
|
|
|
|
+ private fun showPlayButton() {
|
|
|
+ binding.playPauseBtn.visibility = View.VISIBLE
|
|
|
+ binding.progressBar.visibility = View.GONE
|
|
|
+ }
|
|
|
+
|
|
|
+ private fun showVoiceMessageLoading() {
|
|
|
+ binding.playPauseBtn.visibility = View.GONE
|
|
|
+ binding.progressBar.visibility = View.VISIBLE
|
|
|
+ }
|
|
|
+
|
|
|
private fun setParentMessageDataOnMessageItem(message: ChatMessage) {
|
|
|
if (!message.isDeleted && message.parentMessage != null) {
|
|
|
val parentChatMessage = message.parentMessage
|