fix(Markdown): Do not crash the app if the link you've clicked could not be handled
This commit is contained in:
parent
974889279d
commit
7cd468542e
|
@ -2,14 +2,22 @@ package com.artemchep.keyguard.ui.markdown
|
|||
|
||||
import androidx.compose.material3.MaterialTheme
|
||||
import androidx.compose.runtime.Composable
|
||||
import androidx.compose.runtime.getValue
|
||||
import androidx.compose.runtime.remember
|
||||
import androidx.compose.runtime.rememberUpdatedState
|
||||
import androidx.compose.ui.Modifier
|
||||
import androidx.compose.ui.platform.LocalUriHandler
|
||||
import com.artemchep.keyguard.common.model.ToastMessage
|
||||
import com.artemchep.keyguard.common.usecase.ShowMessage
|
||||
import com.halilibo.richtext.commonmark.Markdown
|
||||
import com.halilibo.richtext.markdown.BasicMarkdown
|
||||
import com.halilibo.richtext.markdown.node.AstNode
|
||||
import com.halilibo.richtext.ui.LinkClickHandler
|
||||
import com.halilibo.richtext.ui.RichTextStyle
|
||||
import com.halilibo.richtext.ui.material3.RichText
|
||||
import com.halilibo.richtext.ui.resolveDefaults
|
||||
import com.halilibo.richtext.ui.string.RichTextStringStyle
|
||||
import org.kodein.di.compose.rememberInstance
|
||||
|
||||
@Composable
|
||||
fun MarkdownText(
|
||||
|
@ -20,6 +28,7 @@ fun MarkdownText(
|
|||
RichText(
|
||||
modifier = modifier,
|
||||
style = richTextStyle,
|
||||
linkClickHandler = rememberGracefulLinkClickHandler(),
|
||||
) {
|
||||
Markdown(markdown)
|
||||
}
|
||||
|
@ -34,11 +43,33 @@ fun MarkdownText(
|
|||
RichText(
|
||||
modifier = modifier,
|
||||
style = richTextStyle,
|
||||
linkClickHandler = rememberGracefulLinkClickHandler(),
|
||||
) {
|
||||
BasicMarkdown(markdown)
|
||||
}
|
||||
}
|
||||
|
||||
@Composable
|
||||
private fun rememberGracefulLinkClickHandler(): LinkClickHandler {
|
||||
val showMessage by rememberInstance<ShowMessage>()
|
||||
val updatedUriHandler by rememberUpdatedState(LocalUriHandler.current)
|
||||
return remember {
|
||||
LinkClickHandler { uri ->
|
||||
try {
|
||||
updatedUriHandler.openUri(uri)
|
||||
} catch (e: Exception) {
|
||||
val title = e.message
|
||||
?: "Could not open a URI"
|
||||
val msg = ToastMessage(
|
||||
title = title,
|
||||
type = ToastMessage.Type.ERROR,
|
||||
)
|
||||
showMessage.copy(msg)
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@Composable
|
||||
private fun getRichTextStyle(): RichTextStyle {
|
||||
return RichTextStyle().resolveDefaults().copy(
|
||||
|
|
Loading…
Reference in New Issue