Do not expose AnnouncementState in the api module

This commit is contained in:
Benoit Marty 2025-10-03 11:57:06 +02:00
parent 26106365ef
commit 93c273468e
13 changed files with 16 additions and 30 deletions

View file

@ -174,8 +174,8 @@ class RootFlowNode(
state = state,
modifier = modifier,
onOpenBugReport = this::onOpenBugReport,
announcementRenderer = { state, announcementModifier ->
announcementService.Render(state, announcementModifier)
announcementRenderer = { announcementModifier ->
announcementService.Render(announcementModifier)
}
) {
val backstackSlider = rememberBackstackSlider<NavTarget>(

View file

@ -13,7 +13,6 @@ import androidx.compose.runtime.collectAsState
import androidx.compose.runtime.getValue
import dev.zacsweers.metro.Inject
import im.vector.app.features.analytics.plan.SuperProperties
import io.element.android.features.announcement.api.AnnouncementState
import io.element.android.features.rageshake.api.crash.CrashDetectionState
import io.element.android.features.rageshake.api.detection.RageshakeDetectionState
import io.element.android.libraries.architecture.Presenter
@ -25,7 +24,6 @@ import io.element.android.services.apperror.api.AppErrorStateService
class RootPresenter(
private val crashDetectionPresenter: Presenter<CrashDetectionState>,
private val rageshakeDetectionPresenter: Presenter<RageshakeDetectionState>,
private val announcementPresenter: Presenter<AnnouncementState>,
private val appErrorStateService: AppErrorStateService,
private val analyticsService: AnalyticsService,
private val sdkMetadata: SdkMetadata,
@ -34,7 +32,6 @@ class RootPresenter(
override fun present(): RootState {
val rageshakeDetectionState = rageshakeDetectionPresenter.present()
val crashDetectionState = crashDetectionPresenter.present()
val announcementState = announcementPresenter.present()
val appErrorState by appErrorStateService.appErrorStateFlow.collectAsState()
LaunchedEffect(Unit) {
@ -51,7 +48,6 @@ class RootPresenter(
rageshakeDetectionState = rageshakeDetectionState,
crashDetectionState = crashDetectionState,
errorState = appErrorState,
announcementState = announcementState,
)
}
}

View file

@ -8,7 +8,6 @@
package io.element.android.appnav.root
import androidx.compose.runtime.Immutable
import io.element.android.features.announcement.api.AnnouncementState
import io.element.android.features.rageshake.api.crash.CrashDetectionState
import io.element.android.features.rageshake.api.detection.RageshakeDetectionState
import io.element.android.services.apperror.api.AppErrorState
@ -18,5 +17,4 @@ data class RootState(
val rageshakeDetectionState: RageshakeDetectionState,
val crashDetectionState: CrashDetectionState,
val errorState: AppErrorState,
val announcementState: AnnouncementState,
)

View file

@ -8,7 +8,6 @@
package io.element.android.appnav.root
import androidx.compose.ui.tooling.preview.PreviewParameterProvider
import io.element.android.features.announcement.api.anAnnouncementState
import io.element.android.features.rageshake.api.crash.aCrashDetectionState
import io.element.android.features.rageshake.api.detection.aRageshakeDetectionState
import io.element.android.services.apperror.api.AppErrorState
@ -34,6 +33,5 @@ open class RootStateProvider : PreviewParameterProvider<RootState> {
fun aRootState() = RootState(
rageshakeDetectionState = aRageshakeDetectionState(),
crashDetectionState = aCrashDetectionState(),
announcementState = anAnnouncementState(),
errorState = AppErrorState.NoError,
)

View file

@ -14,7 +14,6 @@ import androidx.compose.runtime.Composable
import androidx.compose.ui.Alignment
import androidx.compose.ui.Modifier
import androidx.compose.ui.tooling.preview.PreviewParameter
import io.element.android.features.announcement.api.AnnouncementState
import io.element.android.features.rageshake.api.crash.CrashDetectionEvents
import io.element.android.features.rageshake.api.crash.CrashDetectionView
import io.element.android.features.rageshake.api.detection.RageshakeDetectionEvents
@ -28,7 +27,7 @@ import io.element.android.services.apperror.impl.AppErrorView
fun RootView(
state: RootState,
onOpenBugReport: () -> Unit,
announcementRenderer: @Composable (AnnouncementState, Modifier) -> Unit,
announcementRenderer: @Composable (Modifier) -> Unit,
modifier: Modifier = Modifier,
children: @Composable BoxScope.() -> Unit,
) {
@ -45,10 +44,7 @@ fun RootView(
onOpenBugReport.invoke()
}
announcementRenderer(
state.announcementState,
Modifier,
)
announcementRenderer(Modifier)
RageshakeDetectionView(
state = state.rageshakeDetectionState,
@ -70,7 +66,7 @@ internal fun RootViewPreview(@PreviewParameter(RootStateProvider::class) rootSta
RootView(
state = rootState,
onOpenBugReport = {},
announcementRenderer = { _, _ -> },
announcementRenderer = { },
) {
Text("Children")
}

View file

@ -12,7 +12,6 @@ import app.cash.molecule.moleculeFlow
import app.cash.turbine.test
import com.google.common.truth.Truth.assertThat
import io.element.android.appnav.root.RootPresenter
import io.element.android.features.announcement.api.anAnnouncementState
import io.element.android.features.rageshake.api.crash.aCrashDetectionState
import io.element.android.features.rageshake.api.detection.aRageshakeDetectionState
import io.element.android.libraries.matrix.test.FakeSdkMetadata
@ -72,7 +71,6 @@ class RootPresenterTest {
return RootPresenter(
crashDetectionPresenter = { aCrashDetectionState() },
rageshakeDetectionPresenter = { aRageshakeDetectionState() },
announcementPresenter = { anAnnouncementState() },
appErrorStateService = appErrorService,
analyticsService = FakeAnalyticsService(),
sdkMetadata = FakeSdkMetadata("sha")