refactor(android): remove TwoPaneLayoutPostActions

This commit is contained in:
Harsh Shandilya 2024-11-01 00:00:33 +05:30
parent 37d0614830
commit 4d260933c0
5 changed files with 13 additions and 62 deletions

View file

@ -15,7 +15,7 @@ import androidx.compose.ui.Modifier
import androidx.core.splashscreen.SplashScreen.Companion.installSplashScreen
import com.deliveryhero.whetstone.activity.ContributesActivityInjector
import dev.msfjarvis.claw.android.ui.screens.LobstersPostsScreen
import dev.msfjarvis.claw.android.ui.screens.TwoPaneLayout
import dev.msfjarvis.claw.android.ui.screens.TabletScreen
@ContributesActivityInjector
class MainActivity : BaseActivity() {
@ -36,7 +36,7 @@ class MainActivity : BaseActivity() {
}
else -> {
TwoPaneLayout(
TabletScreen(
urlLauncher = urlLauncher,
htmlConverter = htmlConverter,
modifier = Modifier.fillMaxSize(),

View file

@ -8,9 +8,7 @@ package dev.msfjarvis.claw.android.ui
import android.content.Context
import android.content.Intent
import androidx.navigation.NavController
import com.slack.eithernet.ApiResult
import dev.msfjarvis.claw.android.ui.navigation.Comments
import dev.msfjarvis.claw.android.viewmodel.ClawViewModel
import dev.msfjarvis.claw.common.posts.PostActions
import dev.msfjarvis.claw.common.urllauncher.UrlLauncher
@ -22,8 +20,8 @@ import java.net.HttpURLConnection
fun PostActions(
context: Context,
urlLauncher: UrlLauncher,
navController: NavController,
viewModel: ClawViewModel,
viewComments: (String) -> Unit,
): PostActions {
return object : PostActions {
override fun viewPost(postId: String, postUrl: String, commentsUrl: String) {
@ -33,7 +31,7 @@ fun PostActions(
override fun viewComments(postId: String) {
viewModel.markPostAsRead(postId)
navController.navigate(Comments(postId))
viewComments(postId)
}
override fun viewCommentsPage(post: UIPost) {
@ -70,57 +68,6 @@ fun PostActions(
}
}
fun TwoPaneLayoutPostActions(
context: Context,
urlLauncher: UrlLauncher,
viewModel: ClawViewModel,
setSelectedPost: (String) -> Unit,
): PostActions {
return object : PostActions {
override fun viewPost(postId: String, postUrl: String, commentsUrl: String) {
viewModel.markPostAsRead(postId)
urlLauncher.openUri(postUrl.ifEmpty { commentsUrl })
}
override fun viewComments(postId: String) {
viewModel.markPostAsRead(postId)
setSelectedPost(postId)
}
override fun viewCommentsPage(post: UIPost) {
urlLauncher.openUri(post.commentsUrl)
}
override fun toggleSave(post: UIPost) {
viewModel.toggleSave(post)
}
override fun share(post: UIPost) {
val sendIntent =
Intent().apply {
action = Intent.ACTION_SEND
putExtra(Intent.EXTRA_TEXT, post.url.ifEmpty { post.commentsUrl })
putExtra(Intent.EXTRA_TITLE, post.title)
type = "text/plain"
}
val shareIntent = Intent.createChooser(sendIntent, null)
context.startActivity(shareIntent)
}
override fun isPostRead(post: UIPost): Boolean = viewModel.isPostRead(post)
override fun isPostSaved(post: UIPost): Boolean = viewModel.isPostSaved(post)
override suspend fun getComments(postId: String): UIPost {
return viewModel.getPostComments(postId)
}
override suspend fun getLinkMetadata(url: String): LinkMetadata {
return viewModel.getLinkMetadata(url)
}
}
}
/**
* Convert an [ApiResult.Failure.HttpFailure] to a scoped down error with a more useful user-facing
* message.

View file

@ -109,7 +109,9 @@ fun LobstersPostsScreen(
val currentDestination = navBackStackEntry?.destination
val coroutineScope = rememberCoroutineScope()
val snackbarHostState = remember { SnackbarHostState() }
val postActions = remember { PostActions(context, urlLauncher, navController, viewModel) }
val postActions = remember {
PostActions(context, urlLauncher, viewModel) { navController.navigate(Comments(it)) }
}
val hazeState = remember { HazeState() }
val hottestPosts = viewModel.hottestPosts.collectAsLazyPagingItems()

View file

@ -39,7 +39,9 @@ fun SearchScreen(
) {
val context = LocalContext.current
val navController = rememberNavController()
val postActions = remember { PostActions(context, urlLauncher, navController, viewModel) }
val postActions = remember {
PostActions(context, urlLauncher, viewModel) { navController.navigate(Comments(it)) }
}
val listState = rememberLazyListState()
val searchResults = viewModel.searchResults.collectAsLazyPagingItems()

View file

@ -42,7 +42,7 @@ import androidx.navigation.compose.rememberNavController
import androidx.paging.compose.collectAsLazyPagingItems
import com.deliveryhero.whetstone.compose.injectedViewModel
import dev.msfjarvis.claw.android.R
import dev.msfjarvis.claw.android.ui.TwoPaneLayoutPostActions
import dev.msfjarvis.claw.android.ui.PostActions
import dev.msfjarvis.claw.android.ui.lists.NetworkPosts
import dev.msfjarvis.claw.android.ui.navigation.Comments
import dev.msfjarvis.claw.android.ui.navigation.User
@ -60,7 +60,7 @@ private fun ThreePaneScaffoldNavigator<*>.isDetailExpanded() =
@OptIn(ExperimentalMaterial3Api::class)
@Composable
fun TwoPaneLayout(
fun TabletScreen(
urlLauncher: UrlLauncher,
htmlConverter: HTMLConverter,
modifier: Modifier = Modifier,
@ -80,7 +80,7 @@ fun TwoPaneLayout(
}
val postActions = remember {
TwoPaneLayoutPostActions(context, urlLauncher, viewModel) {
PostActions(context, urlLauncher, viewModel) {
coroutineScope.launch {
navigator.navigateTo(pane = ListDetailPaneScaffoldRole.Detail, contentKey = Comments(it))
}