Skip to content

Commit d7f39c3

Browse files
committed
Introduce Announcement enum.
1 parent 93c2734 commit d7f39c3

File tree

7 files changed

+38
-13
lines changed

7 files changed

+38
-13
lines changed
Lines changed: 12 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,12 @@
1+
/*
2+
* Copyright 2025 New Vector Ltd.
3+
*
4+
* SPDX-License-Identifier: AGPL-3.0-only OR LicenseRef-Element-Commercial
5+
* Please see LICENSE files in the repository root for full details.
6+
*/
7+
8+
package io.element.android.features.announcement.api
9+
10+
enum class Announcement {
11+
Space,
12+
}

features/announcement/api/src/main/kotlin/io/element/android/features/announcement/api/AnnouncementService.kt

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -11,7 +11,7 @@ import androidx.compose.runtime.Composable
1111
import androidx.compose.ui.Modifier
1212

1313
interface AnnouncementService {
14-
suspend fun onEnteringSpaceTab()
14+
suspend fun showAnnouncement(announcement: Announcement)
1515

1616
@Composable
1717
fun Render(

features/announcement/impl/src/main/kotlin/io/element/android/features/announcement/impl/DefaultAnnouncementService.kt

Lines changed: 8 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -17,6 +17,7 @@ import androidx.compose.ui.Modifier
1717
import dev.zacsweers.metro.AppScope
1818
import dev.zacsweers.metro.ContributesBinding
1919
import dev.zacsweers.metro.Inject
20+
import io.element.android.features.announcement.api.Announcement
2021
import io.element.android.features.announcement.api.AnnouncementService
2122
import io.element.android.features.announcement.impl.spaces.SpaceAnnouncementState
2223
import io.element.android.features.announcement.impl.spaces.SpaceAnnouncementView
@@ -31,7 +32,13 @@ class DefaultAnnouncementService(
3132
private val announcementPresenter: Presenter<AnnouncementState>,
3233
private val spaceAnnouncementPresenter: Presenter<SpaceAnnouncementState>,
3334
) : AnnouncementService {
34-
override suspend fun onEnteringSpaceTab() {
35+
override suspend fun showAnnouncement(announcement: Announcement) {
36+
when (announcement) {
37+
Announcement.Space -> showSpaceAnnouncement()
38+
}
39+
}
40+
41+
private suspend fun showSpaceAnnouncement() {
3542
val currentValue = announcementStore.spaceAnnouncementFlow().first()
3643
if (currentValue == AnnouncementStore.SpaceAnnouncement.NeverShown) {
3744
announcementStore.setSpaceAnnouncementValue(AnnouncementStore.SpaceAnnouncement.Show)

features/announcement/impl/src/test/kotlin/io/element/android/features/announcement/impl/DefaultAnnouncementServiceTest.kt

Lines changed: 4 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -8,6 +8,7 @@
88
package io.element.android.features.announcement.impl
99

1010
import com.google.common.truth.Truth.assertThat
11+
import io.element.android.features.announcement.api.Announcement
1112
import io.element.android.features.announcement.impl.spaces.SpaceAnnouncementState
1213
import io.element.android.features.announcement.impl.spaces.aSpaceAnnouncementState
1314
import io.element.android.features.announcement.impl.store.AnnouncementStore
@@ -19,18 +20,18 @@ import org.junit.Test
1920

2021
class DefaultAnnouncementServiceTest {
2122
@Test
22-
fun `when entering space tab, space announcement is set to show only if it was never shown`() = runTest {
23+
fun `when showing Space announcement, space announcement is set to show only if it was never shown`() = runTest {
2324
val announcementStore = InMemoryAnnouncementStore()
2425
val sut = createDefaultAnnouncementService(
2526
announcementStore = announcementStore,
2627
)
2728
assertThat(announcementStore.spaceAnnouncementFlow().first()).isEqualTo(AnnouncementStore.SpaceAnnouncement.NeverShown)
28-
sut.onEnteringSpaceTab()
29+
sut.showAnnouncement(Announcement.Space)
2930
assertThat(announcementStore.spaceAnnouncementFlow().first()).isEqualTo(AnnouncementStore.SpaceAnnouncement.Show)
3031
// Simulate user close the announcement
3132
announcementStore.setSpaceAnnouncementValue(AnnouncementStore.SpaceAnnouncement.Shown)
3233
// Entering again the space tab should not change the value
33-
sut.onEnteringSpaceTab()
34+
sut.showAnnouncement(Announcement.Space)
3435
assertThat(announcementStore.spaceAnnouncementFlow().first()).isEqualTo(AnnouncementStore.SpaceAnnouncement.Shown)
3536
}
3637

features/announcement/test/src/main/kotlin/io/element/android/features/rageshake/test/logs/FakeAnnouncementService.kt

Lines changed: 4 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -9,15 +9,16 @@ package io.element.android.features.rageshake.test.logs
99

1010
import androidx.compose.runtime.Composable
1111
import androidx.compose.ui.Modifier
12+
import io.element.android.features.announcement.api.Announcement
1213
import io.element.android.features.announcement.api.AnnouncementService
1314
import io.element.android.tests.testutils.lambda.lambdaError
1415

1516
class FakeAnnouncementService(
16-
val onEnteringSpaceTabResult: () -> Unit = { lambdaError() },
17+
val showAnnouncementResult: (Announcement) -> Unit = { lambdaError() },
1718
val renderResult: (Modifier) -> Unit = { lambdaError() },
1819
) : AnnouncementService {
19-
override suspend fun onEnteringSpaceTab() {
20-
onEnteringSpaceTabResult()
20+
override suspend fun showAnnouncement(announcement: Announcement) {
21+
showAnnouncementResult(announcement)
2122
}
2223

2324
@Composable

features/home/impl/src/main/kotlin/io/element/android/features/home/impl/HomePresenter.kt

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -18,6 +18,7 @@ import androidx.compose.runtime.rememberCoroutineScope
1818
import androidx.compose.runtime.saveable.rememberSaveable
1919
import androidx.compose.runtime.setValue
2020
import dev.zacsweers.metro.Inject
21+
import io.element.android.features.announcement.api.Announcement
2122
import io.element.android.features.announcement.api.AnnouncementService
2223
import io.element.android.features.home.impl.roomlist.RoomListState
2324
import io.element.android.features.home.impl.spaces.HomeSpacesState
@@ -88,7 +89,7 @@ class HomePresenter(
8889
when (event) {
8990
is HomeEvents.SelectHomeNavigationBarItem -> coroutineState.launch {
9091
if (event.item == HomeNavigationBarItem.Spaces) {
91-
announcementService.onEnteringSpaceTab()
92+
announcementService.showAnnouncement(Announcement.Space)
9293
}
9394
currentHomeNavigationBarItemOrdinal = event.item.ordinal
9495
}

features/home/impl/src/test/kotlin/io/element/android/features/home/impl/HomePresenterTest.kt

Lines changed: 7 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -11,6 +11,7 @@ import app.cash.molecule.RecompositionMode
1111
import app.cash.molecule.moleculeFlow
1212
import app.cash.turbine.test
1313
import com.google.common.truth.Truth.assertThat
14+
import io.element.android.features.announcement.api.Announcement
1415
import io.element.android.features.announcement.api.AnnouncementService
1516
import io.element.android.features.home.impl.roomlist.aRoomListState
1617
import io.element.android.features.home.impl.spaces.HomeSpacesState
@@ -40,6 +41,7 @@ import io.element.android.libraries.sessionstorage.test.aSessionData
4041
import io.element.android.tests.testutils.MutablePresenter
4142
import io.element.android.tests.testutils.WarmUpRule
4243
import io.element.android.tests.testutils.lambda.lambdaRecorder
44+
import io.element.android.tests.testutils.lambda.value
4345
import io.element.android.tests.testutils.test
4446
import kotlinx.coroutines.flow.flowOf
4547
import kotlinx.coroutines.test.runTest
@@ -168,13 +170,13 @@ class HomePresenterTest {
168170

169171
@Test
170172
fun `present - NavigationBar change`() = runTest {
171-
val onEnteringSpaceTabResult = lambdaRecorder<Unit> { }
173+
val showAnnouncementResult = lambdaRecorder<Announcement, Unit> { }
172174
val presenter = createHomePresenter(
173175
sessionStore = InMemorySessionStore(
174176
updateUserProfileResult = { _, _, _ -> },
175177
),
176178
announcementService = FakeAnnouncementService(
177-
onEnteringSpaceTabResult = onEnteringSpaceTabResult,
179+
showAnnouncementResult = showAnnouncementResult,
178180
)
179181
)
180182
moleculeFlow(RecompositionMode.Immediate) {
@@ -185,7 +187,8 @@ class HomePresenterTest {
185187
initialState.eventSink(HomeEvents.SelectHomeNavigationBarItem(HomeNavigationBarItem.Spaces))
186188
val finalState = awaitItem()
187189
assertThat(finalState.currentHomeNavigationBarItem).isEqualTo(HomeNavigationBarItem.Spaces)
188-
onEnteringSpaceTabResult.assertions().isCalledOnce()
190+
showAnnouncementResult.assertions().isCalledOnce()
191+
.with(value(Announcement.Space))
189192
}
190193
}
191194

@@ -201,7 +204,7 @@ class HomePresenterTest {
201204
),
202205
homeSpacesPresenter = homeSpacesPresenter,
203206
announcementService = FakeAnnouncementService(
204-
onEnteringSpaceTabResult = {},
207+
showAnnouncementResult = {},
205208
)
206209
)
207210
presenter.test {

0 commit comments

Comments
 (0)