Skip to content

Commit

Permalink
Fix repeating hashtag not highlighting in note content
Browse files Browse the repository at this point in the history
  • Loading branch information
mehmedalijaK committed Dec 16, 2024
1 parent cb84fcc commit 12df242
Show file tree
Hide file tree
Showing 3 changed files with 34 additions and 8 deletions.
20 changes: 13 additions & 7 deletions app/src/main/kotlin/net/primal/android/core/utils/TextMatcher.kt
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@ package net.primal.android.core.utils
class TextMatcher(
content: String,
texts: List<String>,
repeatingOccurrences: Boolean = false,
) {

private val matches: MutableList<TextMatch> = mutableListOf()
Expand All @@ -26,16 +27,21 @@ class TextMatcher(
}

init {
texts.forEach {
val startIndex = content.indexOfNotMatchedBefore(text = it)
if (startIndex != null) {
texts.forEach { text ->
var currentIndex = content.indexOfNotMatchedBefore(text = text)

while (currentIndex != null) {
matches.add(
TextMatch(
value = it,
startIndex = startIndex,
endIndex = startIndex + it.length,
),
value = text,
startIndex = currentIndex,
endIndex = currentIndex + text.length,
)
)

if (!repeatingOccurrences) break

currentIndex = content.indexOfNotMatchedBefore(text = text)
}
}
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -393,7 +393,11 @@ fun renderContentAsAnnotatedString(
)
}

TextMatcher(content = refinedContent, texts = data.hashtags)
TextMatcher(
content = refinedContent,
texts = data.hashtags,
repeatingOccurrences = true,
)
.matches()
.forEach {
addHashtagAnnotation(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,9 @@ package net.primal.android.core.utils

import io.kotest.matchers.collections.shouldContain
import io.kotest.matchers.collections.shouldContainAll
import io.kotest.matchers.collections.shouldContainExactlyInAnyOrder
import io.kotest.matchers.collections.shouldNotContain
import io.kotest.matchers.shouldBe
import org.junit.Test

class TextMatcherTest {
Expand Down Expand Up @@ -31,6 +33,20 @@ class TextMatcherTest {
actual.shouldContainAll(hashtags)
}

@Test
fun `matches should match hashtags and return hashtags with duplicates`() {
val hashtags = listOf("#nostr", "#bitcoin", "#sats", "#freedom")
val expected = listOf("#nostr", "#nostr", "#nostr", "#bitcoin", "#freedom", "#freedom", "#sats")
val matcher = TextMatcher(
content = "Hello I love #nostr #nostr somemore #nostr #bitcoin #freedom #sats #freedom",
texts = hashtags,
repeatingOccurrences = true,
)

val actual = matcher.matches().map { it.value }
actual.shouldContainExactlyInAnyOrder(expected)
}

@Test
fun `matches should not match unknown hashtags`() {
val hashtags = listOf("#Hiking", "#Trails")
Expand Down

0 comments on commit 12df242

Please sign in to comment.