Commit 98443fcb authored by Leonardo Aramaki's avatar Leonardo Aramaki

Replace username by real name if 'UI_Use_Real_Name' is set. Make

MessageParser as non-singleton since the server settings changes when
swapping between multiple servers.
parent 7eaa9971
...@@ -304,7 +304,7 @@ class ViewModelMapper @Inject constructor( ...@@ -304,7 +304,7 @@ class ViewModelMapper @Inject constructor(
private fun getContent(message: Message): CharSequence { private fun getContent(message: Message): CharSequence {
return when (message.isSystemMessage()) { return when (message.isSystemMessage()) {
true -> getSystemMessage(message) true -> getSystemMessage(message)
false -> parser.renderMarkdown(message, currentUsername) false -> parser.render(message, currentUsername)
} }
} }
......
...@@ -269,7 +269,6 @@ class AppModule { ...@@ -269,7 +269,6 @@ class AppModule {
} }
@Provides @Provides
@Singleton
fun provideMessageParser(context: Application, configuration: SpannableConfiguration, serverInteractor: GetCurrentServerInteractor, settingsInteractor: GetSettingsInteractor): MessageParser { fun provideMessageParser(context: Application, configuration: SpannableConfiguration, serverInteractor: GetCurrentServerInteractor, settingsInteractor: GetSettingsInteractor): MessageParser {
val url = serverInteractor.get()!! val url = serverInteractor.get()!!
return MessageParser(context, configuration, settingsInteractor.get(url)) return MessageParser(context, configuration, settingsInteractor.get(url))
......
...@@ -39,15 +39,23 @@ class MessageParser @Inject constructor( ...@@ -39,15 +39,23 @@ class MessageParser @Inject constructor(
private val parser = Markwon.createParser() private val parser = Markwon.createParser()
/** /**
* Render a markdown text message to Spannable. * Render markdown and other rules on message to rich text with spans.
* *
* @param message The [Message] object we're interested on rendering. * @param message The [Message] object we're interested on rendering.
* @param selfUsername This user username. * @param selfUsername This user username.
* *
* @return A Spannable with the parsed markdown. * @return A Spannable with the parsed markdown.
*/ */
fun renderMarkdown(message: Message, selfUsername: String? = null): CharSequence { fun render(message: Message, selfUsername: String? = null): CharSequence {
val text = message.message var text: String = message.message
val mentions = mutableListOf<String>()
message.mentions?.forEach {
val mention = getMention(it)
mentions.add(mention)
if (it.username != null) {
text = text.replace("@${it.username}", mention)
}
}
val builder = SpannableBuilder() val builder = SpannableBuilder()
val content = EmojiRepository.shortnameToUnicode(text, true) val content = EmojiRepository.shortnameToUnicode(text, true)
val parentNode = parser.parse(toLenientMarkdown(content)) val parentNode = parser.parse(toLenientMarkdown(content))
...@@ -55,7 +63,7 @@ class MessageParser @Inject constructor( ...@@ -55,7 +63,7 @@ class MessageParser @Inject constructor(
parentNode.accept(LinkVisitor(builder)) parentNode.accept(LinkVisitor(builder))
parentNode.accept(EmojiVisitor(configuration, builder)) parentNode.accept(EmojiVisitor(configuration, builder))
message.mentions?.let { message.mentions?.let {
parentNode.accept(MentionVisitor(context, builder, it, selfUsername, settings)) parentNode.accept(MentionVisitor(context, builder, mentions, selfUsername))
} }
return builder.text() return builder.text()
...@@ -68,12 +76,19 @@ class MessageParser @Inject constructor( ...@@ -68,12 +76,19 @@ class MessageParser @Inject constructor(
.replace("\\_(.+)\\_".toRegex()) { "_${it.groupValues[1].trim()}_" } .replace("\\_(.+)\\_".toRegex()) { "_${it.groupValues[1].trim()}_" }
} }
private fun getMention(user: SimpleUser): String {
return if (settings.useRealName()) {
user.name ?: "@${user.username}"
} else {
"@${user.username}"
}
}
class MentionVisitor( class MentionVisitor(
context: Context, context: Context,
private val builder: SpannableBuilder, private val builder: SpannableBuilder,
private val mentions: List<SimpleUser>, private val mentions: List<String>,
private val currentUser: String?, private val currentUser: String?
private val settings: PublicSettings
) : AbstractVisitor() { ) : AbstractVisitor() {
private val othersTextColor = ResourcesCompat.getColor(context.resources, R.color.colorAccent, context.theme) private val othersTextColor = ResourcesCompat.getColor(context.resources, R.color.colorAccent, context.theme)
...@@ -85,27 +100,23 @@ class MessageParser @Inject constructor( ...@@ -85,27 +100,23 @@ class MessageParser @Inject constructor(
override fun visit(t: Text) { override fun visit(t: Text) {
val text = t.literal val text = t.literal
val mentionsList = mentions.map { val mentionsList = mentions.toMutableList().also {
if (settings.useRealName()) it.name else it.username ?: "" it.add("@all")
}.toMutableList() it.add("@here")
}.toList()
mentionsList.add("all")
mentionsList.add("here") mentionsList.forEach {
val mentionMe = it == currentUser || it == "@all" || it == "@here"
mentionsList.toList().forEach { var offset = text.indexOf(it, 0, true)
if (it != null) { while (offset > -1) {
val mentionMe = it == currentUser || it == "all" || it == "here" val textColor = if (mentionMe) myselfTextColor else othersTextColor
var offset = text.indexOf("@$it", 0, true) val backgroundColor = if (mentionMe) myselfBackgroundColor else othersBackgroundColor
while (offset > -1) { val usernameSpan = MentionSpan(backgroundColor, textColor, mentionRadius, mentionPadding,
val textColor = if (mentionMe) myselfTextColor else othersTextColor mentionMe)
val backgroundColor = if (mentionMe) myselfBackgroundColor else othersBackgroundColor // Add 1 to end offset to include the @.
val usernameSpan = MentionSpan(backgroundColor, textColor, mentionRadius, mentionPadding, val end = offset + it.length + 1
mentionMe) builder.setSpan(usernameSpan, offset, end, 0)
// Add 1 to end offset to include the @. offset = text.indexOf("@$it", end, true)
val end = offset + it.length + 1
builder.setSpan(usernameSpan, offset, end, 0)
offset = text.indexOf("@$it", end, true)
}
} }
} }
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment