Browse Source

Room directory : start branching join event

pull/2620/head
ganfra 6 months ago
parent
commit
0c96769e8b
  1. 2
      appnav/src/main/kotlin/io/element/android/appnav/LoggedInFlowNode.kt
  2. 2
      features/roomdirectory/api/src/main/kotlin/io/element/android/features/roomdirectory/api/RoomDirectoryEntryPoint.kt
  3. 3
      features/roomdirectory/impl/src/main/kotlin/io/element/android/features/roomdirectory/impl/DefaultRoomDirectoryEntryPoint.kt
  4. 66
      features/roomdirectory/impl/src/main/kotlin/io/element/android/features/roomdirectory/impl/RoomDirectoryFlowNode.kt
  5. 3
      features/roomdirectory/impl/src/main/kotlin/io/element/android/features/roomdirectory/impl/root/RoomDirectoryEvents.kt
  6. 10
      features/roomdirectory/impl/src/main/kotlin/io/element/android/features/roomdirectory/impl/root/RoomDirectoryNode.kt
  7. 11
      features/roomdirectory/impl/src/main/kotlin/io/element/android/features/roomdirectory/impl/root/RoomDirectoryPresenter.kt
  8. 6
      features/roomdirectory/impl/src/main/kotlin/io/element/android/features/roomdirectory/impl/root/RoomDirectoryView.kt

2
appnav/src/main/kotlin/io/element/android/appnav/LoggedInFlowNode.kt

@ -389,7 +389,7 @@ class LoggedInFlowNode @AssistedInject constructor( @@ -389,7 +389,7 @@ class LoggedInFlowNode @AssistedInject constructor(
NavTarget.RoomDirectorySearch -> {
roomDirectoryEntryPoint.nodeBuilder(this, buildContext)
.callback(object : RoomDirectoryEntryPoint.Callback {
override fun onRoomJoined(roomId: RoomId) {
override fun onJoinRoom(roomId: RoomId) {
coroutineScope.launch { attachRoom(roomId) }
}
})

2
features/roomdirectory/api/src/main/kotlin/io/element/android/features/roomdirectory/api/RoomDirectoryEntryPoint.kt

@ -32,7 +32,7 @@ interface RoomDirectoryEntryPoint : FeatureEntryPoint { @@ -32,7 +32,7 @@ interface RoomDirectoryEntryPoint : FeatureEntryPoint {
}
interface Callback : Plugin {
fun onRoomJoined(roomId: RoomId)
fun onJoinRoom(roomId: RoomId)
}
}

3
features/roomdirectory/impl/src/main/kotlin/io/element/android/features/roomdirectory/impl/DefaultRoomDirectoryEntryPoint.kt

@ -21,6 +21,7 @@ import com.bumble.appyx.core.node.Node @@ -21,6 +21,7 @@ import com.bumble.appyx.core.node.Node
import com.bumble.appyx.core.plugin.Plugin
import com.squareup.anvil.annotations.ContributesBinding
import io.element.android.features.roomdirectory.api.RoomDirectoryEntryPoint
import io.element.android.features.roomdirectory.impl.root.RoomDirectoryNode
import io.element.android.libraries.architecture.createNode
import io.element.android.libraries.di.AppScope
import javax.inject.Inject
@ -39,7 +40,7 @@ class DefaultRoomDirectoryEntryPoint @Inject constructor() : RoomDirectoryEntryP @@ -39,7 +40,7 @@ class DefaultRoomDirectoryEntryPoint @Inject constructor() : RoomDirectoryEntryP
}
override fun build(): Node {
return parentNode.createNode<RoomDirectoryFlowNode>(buildContext, plugins)
return parentNode.createNode<RoomDirectoryNode>(buildContext, plugins)
}
}
}

66
features/roomdirectory/impl/src/main/kotlin/io/element/android/features/roomdirectory/impl/RoomDirectoryFlowNode.kt

@ -1,66 +0,0 @@ @@ -1,66 +0,0 @@
/*
* Copyright (c) 2024 New Vector Ltd
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package io.element.android.features.roomdirectory.impl
import android.os.Parcelable
import androidx.compose.runtime.Composable
import androidx.compose.ui.Modifier
import com.bumble.appyx.core.modality.BuildContext
import com.bumble.appyx.core.node.Node
import com.bumble.appyx.core.plugin.Plugin
import com.bumble.appyx.navmodel.backstack.BackStack
import dagger.assisted.Assisted
import dagger.assisted.AssistedInject
import io.element.android.anvilannotations.ContributesNode
import io.element.android.features.roomdirectory.impl.root.RoomDirectoryNode
import io.element.android.libraries.architecture.BackstackView
import io.element.android.libraries.architecture.BaseFlowNode
import io.element.android.libraries.architecture.createNode
import io.element.android.libraries.di.SessionScope
import kotlinx.parcelize.Parcelize
@ContributesNode(SessionScope::class)
class RoomDirectoryFlowNode @AssistedInject constructor(
@Assisted buildContext: BuildContext,
@Assisted plugins: List<Plugin>,
) : BaseFlowNode<RoomDirectoryFlowNode.NavTarget>(
backstack = BackStack(
initialElement = NavTarget.Root,
savedStateMap = buildContext.savedStateMap,
),
buildContext = buildContext,
plugins = plugins,
) {
sealed interface NavTarget : Parcelable {
@Parcelize
data object Root : NavTarget
}
override fun resolve(navTarget: NavTarget, buildContext: BuildContext): Node {
return when (navTarget) {
NavTarget.Root -> {
createNode<RoomDirectoryNode>(buildContext)
}
}
}
@Composable
override fun View(modifier: Modifier) {
BackstackView()
}
}

3
features/roomdirectory/impl/src/main/kotlin/io/element/android/features/roomdirectory/impl/root/RoomDirectoryEvents.kt

@ -16,10 +16,7 @@ @@ -16,10 +16,7 @@
package io.element.android.features.roomdirectory.impl.root
import io.element.android.libraries.matrix.api.core.RoomId
sealed interface RoomDirectoryEvents {
data class Search(val query: String) : RoomDirectoryEvents
data object LoadMore : RoomDirectoryEvents
data class JoinRoom(val roomId: RoomId) : RoomDirectoryEvents
}

10
features/roomdirectory/impl/src/main/kotlin/io/element/android/features/roomdirectory/impl/root/RoomDirectoryNode.kt

@ -21,10 +21,13 @@ import androidx.compose.ui.Modifier @@ -21,10 +21,13 @@ import androidx.compose.ui.Modifier
import com.bumble.appyx.core.modality.BuildContext
import com.bumble.appyx.core.node.Node
import com.bumble.appyx.core.plugin.Plugin
import com.bumble.appyx.core.plugin.plugins
import dagger.assisted.Assisted
import dagger.assisted.AssistedInject
import io.element.android.anvilannotations.ContributesNode
import io.element.android.features.roomdirectory.api.RoomDirectoryEntryPoint
import io.element.android.libraries.di.SessionScope
import io.element.android.libraries.matrix.api.core.RoomId
@ContributesNode(SessionScope::class)
class RoomDirectoryNode @AssistedInject constructor(
@ -33,11 +36,18 @@ class RoomDirectoryNode @AssistedInject constructor( @@ -33,11 +36,18 @@ class RoomDirectoryNode @AssistedInject constructor(
private val presenter: RoomDirectoryPresenter,
) : Node(buildContext, plugins = plugins) {
private fun onJoinRoom(roomId: RoomId) {
plugins<RoomDirectoryEntryPoint.Callback>().forEach {
it.onJoinRoom(roomId)
}
}
@Composable
override fun View(modifier: Modifier) {
val state = presenter.present()
RoomDirectoryView(
state = state,
onJoinRoom = ::onJoinRoom,
onBackPressed = ::navigateUp,
modifier = modifier
)

11
features/roomdirectory/impl/src/main/kotlin/io/element/android/features/roomdirectory/impl/root/RoomDirectoryPresenter.kt

@ -28,20 +28,20 @@ import androidx.compose.runtime.saveable.rememberSaveable @@ -28,20 +28,20 @@ import androidx.compose.runtime.saveable.rememberSaveable
import androidx.compose.runtime.setValue
import io.element.android.features.roomdirectory.impl.root.model.toUiModel
import io.element.android.libraries.architecture.Presenter
import io.element.android.libraries.core.coroutine.CoroutineDispatchers
import io.element.android.libraries.matrix.api.MatrixClient
import io.element.android.libraries.matrix.api.roomdirectory.RoomDirectoryList
import io.element.android.libraries.matrix.api.roomdirectory.RoomDirectoryService
import kotlinx.collections.immutable.persistentListOf
import kotlinx.collections.immutable.toImmutableList
import kotlinx.coroutines.Dispatchers
import kotlinx.coroutines.flow.flowOn
import kotlinx.coroutines.flow.map
import kotlinx.coroutines.launch
import javax.inject.Inject
class RoomDirectoryPresenter @Inject constructor(
private val client: MatrixClient,
private val roomDirectoryService: RoomDirectoryService,
private val dispatchers: CoroutineDispatchers,
roomDirectoryService: RoomDirectoryService,
) : Presenter<RoomDirectoryState> {
private val roomDirectoryList = roomDirectoryService.createRoomDirectoryList()
@ -62,9 +62,6 @@ class RoomDirectoryPresenter @Inject constructor( @@ -62,9 +62,6 @@ class RoomDirectoryPresenter @Inject constructor(
}
fun handleEvents(event: RoomDirectoryEvents) {
when (event) {
is RoomDirectoryEvents.JoinRoom -> {
//coroutineScope.joinRoom(event.roomId)
}
RoomDirectoryEvents.LoadMore -> {
coroutineScope.launch {
roomDirectoryList.loadMore()
@ -90,6 +87,6 @@ class RoomDirectoryPresenter @Inject constructor( @@ -90,6 +87,6 @@ class RoomDirectoryPresenter @Inject constructor(
list
.map { roomDescription -> roomDescription.toUiModel() }
.toImmutableList()
}.flowOn(Dispatchers.Default)
}.flowOn(dispatchers.computation)
}.collectAsState(persistentListOf())
}

6
features/roomdirectory/impl/src/main/kotlin/io/element/android/features/roomdirectory/impl/root/RoomDirectoryView.kt

@ -67,6 +67,7 @@ import kotlinx.collections.immutable.ImmutableList @@ -67,6 +67,7 @@ import kotlinx.collections.immutable.ImmutableList
fun RoomDirectoryView(
state: RoomDirectoryState,
onBackPressed: () -> Unit,
onJoinRoom: (RoomId) -> Unit,
modifier: Modifier = Modifier,
) {
Scaffold(
@ -77,9 +78,7 @@ fun RoomDirectoryView( @@ -77,9 +78,7 @@ fun RoomDirectoryView(
content = { padding ->
RoomDirectoryContent(
state = state,
onResultClicked = { roomId ->
state.eventSink(RoomDirectoryEvents.JoinRoom(roomId))
},
onResultClicked = onJoinRoom,
modifier = Modifier
.padding(padding)
.consumeWindowInsets(padding)
@ -296,6 +295,7 @@ private fun RoomDirectoryRoomRow( @@ -296,6 +295,7 @@ private fun RoomDirectoryRoomRow(
fun RoomDirectorySearchViewLightPreview(@PreviewParameter(RoomDirectorySearchStateProvider::class) state: RoomDirectoryState) = ElementPreview {
RoomDirectoryView(
state = state,
onJoinRoom = {},
onBackPressed = {},
)
}

Loading…
Cancel
Save