Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
51 changes: 40 additions & 11 deletions app/src/main/java/com/getcode/navigation/screens/ChatScreens.kt
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,10 @@ import androidx.compose.foundation.layout.Row
import androidx.compose.foundation.layout.padding
import androidx.compose.foundation.layout.size
import androidx.compose.foundation.shape.CircleShape
import androidx.compose.material.Icon
import androidx.compose.material.Text
import androidx.compose.material.icons.Icons
import androidx.compose.material.icons.rounded.BubbleChart
import androidx.compose.runtime.Composable
import androidx.compose.runtime.LaunchedEffect
import androidx.compose.runtime.collectAsState
Expand All @@ -16,6 +19,7 @@ import androidx.compose.runtime.remember
import androidx.compose.ui.Alignment
import androidx.compose.ui.Modifier
import androidx.compose.ui.draw.clip
import androidx.compose.ui.graphics.Color
import androidx.compose.ui.platform.LocalLifecycleOwner
import androidx.compose.ui.res.stringResource
import androidx.compose.ui.unit.dp
Expand All @@ -35,17 +39,17 @@ import com.getcode.model.ID
import com.getcode.navigation.core.LocalCodeNavigator
import com.getcode.theme.BrandLight
import com.getcode.theme.CodeTheme
import com.getcode.ui.components.SheetTitleDefaults
import com.getcode.ui.components.SheetTitleText
import com.getcode.ui.utils.getActivityScopedViewModel
import com.getcode.ui.components.chat.localized
import com.getcode.ui.utils.getActivityScopedViewModel
import com.getcode.util.formatDateRelatively
import com.getcode.view.main.balance.BalanceScreeen
import com.getcode.view.main.balance.BalanceSheetViewModel
import com.getcode.view.main.chat.ChatScreen
import com.getcode.view.main.chat.ChatViewModel
import com.getcode.view.main.chat.conversation.ChatConversationScreen
import com.getcode.view.main.chat.conversation.ConversationViewModel
import com.getcode.view.main.giveKin.GiveKinScreen
import com.getcode.view.main.home.HomeViewModel
import kotlinx.coroutines.flow.filterIsInstance
import kotlinx.coroutines.flow.launchIn
Expand Down Expand Up @@ -73,18 +77,43 @@ data object BalanceModal : ChatGraph, ModalRoot {
derivedStateOf { state.isBucketDebuggerVisible }
}

val backButton = @Composable {
when {
isViewingBuckets -> SheetTitleDefaults.BackButton()
!isViewingBuckets && state.isBucketDebuggerEnabled -> {
Icon(
imageVector = Icons.Rounded.BubbleChart,
contentDescription = "",
tint = Color.White,
)
}
else -> Unit
}
}

ModalContainer(
navigator = navigator,
onLogoClicked = {},
backButton = { isViewingBuckets },
onBackClicked = isViewingBuckets.takeIf { it }?.let {
{
viewModel.dispatchEvent(
BalanceSheetViewModel.Event.OnDebugBucketsVisible(false)
)
backButton = backButton,
backButtonEnabled = { isViewingBuckets || state.isBucketDebuggerEnabled },
onBackClicked = when {
isViewingBuckets -> {
{
viewModel.dispatchEvent(
BalanceSheetViewModel.Event.OnDebugBucketsVisible(false)
)
}
}
state.isBucketDebuggerEnabled -> {
{
viewModel.dispatchEvent(
BalanceSheetViewModel.Event.OnDebugBucketsVisible(true)
)
}
}
else -> null
},
closeButton = close@{
closeButtonEnabled = close@{
if (viewModel.stateFlow.value.isBucketDebuggerVisible) return@close false
if (navigator.isVisible) {
it is BalanceModal
Expand Down Expand Up @@ -127,7 +156,7 @@ data class ChatScreen(val chatId: ID) : ChatGraph, ModalContent {

ModalContainer(
titleString = { state.title.localized },
backButton = { it is ChatScreen },
backButtonEnabled = { it is ChatScreen },
) {
val messages = vm.chatMessages.collectAsLazyPagingItems()
ChatScreen(state = state, messages = messages, dispatch = vm::dispatchEvent)
Expand Down Expand Up @@ -197,7 +226,7 @@ data class ChatMessageConversationScreen(val messageId: ID) : AppScreen(), ChatG
}
}
},
backButton = { it is ChatMessageConversationScreen },
backButtonEnabled = { it is ChatMessageConversationScreen },
) {
val messages = vm.messages.collectAsLazyPagingItems()
ChatConversationScreen(state, messages, vm::dispatchEvent)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -86,7 +86,7 @@ data object GiveKinModal : AppScreen(), MainGraph, ModalRoot {
override fun Content() {
val navigator = LocalCodeNavigator.current
ModalContainer(
closeButton = {
closeButtonEnabled = {
if (navigator.isVisible) {
it is GiveKinModal
} else {
Expand Down Expand Up @@ -125,7 +125,7 @@ data class RequestKinModal(

if (showClose) {
ModalContainer(
closeButton = {
closeButtonEnabled = {
if (navigator.isVisible) {
it is RequestKinModal
} else {
Expand All @@ -137,7 +137,7 @@ data class RequestKinModal(
}
} else {
ModalContainer(
backButton = {
backButtonEnabled = {
if (navigator.isVisible) {
it is RequestKinModal
} else {
Expand Down Expand Up @@ -168,7 +168,7 @@ data object AccountModal : MainGraph, ModalRoot {
ModalContainer(
displayLogo = true,
onLogoClicked = { viewModel.dispatchEvent(AccountSheetViewModel.Event.LogoClicked) },
closeButton = {
closeButtonEnabled = {
if (navigator.isVisible) {
it is AccountModal
} else {
Expand Down
48 changes: 20 additions & 28 deletions app/src/main/java/com/getcode/navigation/screens/ModalScreens.kt
Original file line number Diff line number Diff line change
@@ -1,7 +1,6 @@
package com.getcode.navigation.screens

import androidx.compose.runtime.Composable
import androidx.compose.runtime.LaunchedEffect
import androidx.compose.ui.platform.LocalLifecycleOwner
import androidx.compose.ui.res.stringResource
import cafe.adriel.voyager.core.screen.ScreenKey
Expand Down Expand Up @@ -32,15 +31,8 @@ import com.getcode.view.main.getKin.GetKinSheetViewModel
import com.getcode.view.main.getKin.ReferFriend
import com.getcode.view.main.tip.EnterTipScreen
import com.getcode.view.main.tip.RequestTipScreen
import kotlinx.coroutines.delay
import kotlinx.coroutines.flow.delayFlow
import kotlinx.coroutines.flow.filterIsInstance
import kotlinx.coroutines.flow.launchIn
import kotlinx.coroutines.flow.onEach
import kotlinx.coroutines.flow.onStart
import kotlinx.parcelize.IgnoredOnParcel
import kotlinx.parcelize.Parcelize
import timber.log.Timber


@Parcelize
Expand All @@ -53,7 +45,7 @@ data object DepositKinScreen : MainGraph, ModalContent {

@Composable
override fun Content() {
ModalContainer(backButton = { it is DepositKinScreen }) {
ModalContainer(backButtonEnabled = { it is DepositKinScreen }) {
AccountDeposit()
}

Expand All @@ -74,7 +66,7 @@ data object FaqScreen : MainGraph, ModalContent {

@Composable
override fun Content() {
ModalContainer(backButton = { it is FaqScreen }) {
ModalContainer(backButtonEnabled = { it is FaqScreen }) {
AccountFaq(getViewModel())
}

Expand All @@ -95,7 +87,7 @@ data object AccountDebugOptionsScreen : MainGraph, ModalContent {

@Composable
override fun Content() {
ModalContainer(backButton = { it is AccountDebugOptionsScreen }) {
ModalContainer(backButtonEnabled = { it is AccountDebugOptionsScreen }) {
BetaFlagsScreen(getViewModel())
}

Expand All @@ -116,7 +108,7 @@ data object AccountDetailsScreen : MainGraph, ModalContent {

@Composable
override fun Content() {
ModalContainer(backButton = { it is AccountDetailsScreen }) {
ModalContainer(backButtonEnabled = { it is AccountDetailsScreen }) {
AccountDetails(getActivityScopedViewModel())
}
}
Expand All @@ -132,7 +124,7 @@ data object BackupScreen : MainGraph, ModalContent {

@Composable
override fun Content() {
ModalContainer(backButton = { it is BackupScreen }) {
ModalContainer(backButtonEnabled = { it is BackupScreen }) {
BackupKey(getViewModel())
}

Expand All @@ -154,7 +146,7 @@ data object PhoneNumberScreen : MainGraph, ModalContent {

@Composable
override fun Content() {
ModalContainer(backButton = { it is PhoneNumberScreen }) {
ModalContainer(backButtonEnabled = { it is PhoneNumberScreen }) {
AccountPhone(getViewModel())
}
}
Expand All @@ -181,7 +173,7 @@ data class PhoneVerificationScreen(
override fun Content() {
val navigator = LocalCodeNavigator.current
val viewModel = getStackScopedViewModel<PhoneVerifyViewModel>(key)
ModalContainer(backButton = { it is PhoneVerificationScreen }) {
ModalContainer(backButtonEnabled = { it is PhoneVerificationScreen }) {
PhoneVerify(viewModel, arguments) {
navigator.show(PhoneAreaSelectionModal(key))
}
Expand All @@ -202,7 +194,7 @@ data class PhoneAreaSelectionModal(val providedKey: String) : MainGraph, ModalCo
val navigator = LocalCodeNavigator.current
val vm = getStackScopedViewModel<PhoneVerifyViewModel>(providedKey)

ModalContainer(closeButton = { it is PhoneAreaSelectionModal }) {
ModalContainer(closeButtonEnabled = { it is PhoneAreaSelectionModal }) {
PhoneCountrySelection(viewModel = vm) {
navigator.hide()
}
Expand All @@ -229,7 +221,7 @@ data class PhoneConfirmationScreen(

@Composable
override fun Content() {
ModalContainer(backButton = { it is PhoneConfirmationScreen }) {
ModalContainer(backButtonEnabled = { it is PhoneConfirmationScreen }) {
PhoneConfirm(
getViewModel(),
arguments = arguments,
Expand All @@ -249,7 +241,7 @@ data object DeleteCodeScreen : MainGraph, ModalContent {

@Composable
override fun Content() {
ModalContainer(backButton = { it is DeleteCodeScreen }) {
ModalContainer(backButtonEnabled = { it is DeleteCodeScreen }) {
DeleteCodeAccount()
}
}
Expand All @@ -265,7 +257,7 @@ data object DeleteConfirmationScreen : MainGraph, ModalContent {

@Composable
override fun Content() {
ModalContainer(backButton = { it is DeleteConfirmationScreen }) {
ModalContainer(backButtonEnabled = { it is DeleteConfirmationScreen }) {
ConfirmDeleteAccount(getViewModel())
}
}
Expand All @@ -278,7 +270,7 @@ data object ReferFriendScreen : MainGraph, ModalContent {

@Composable
override fun Content() {
ModalContainer(backButton = { it is DeleteConfirmationScreen }) {
ModalContainer(backButtonEnabled = { it is DeleteConfirmationScreen }) {
ReferFriend()
}
}
Expand All @@ -297,7 +289,7 @@ data object CurrencySelectionModal : MainGraph, ModalContent {
override fun Content() {
val navigator = LocalCodeNavigator.current
ModalContainer(
backButton = {
backButtonEnabled = {
if (navigator.isVisible) {
it is CurrencySelectionModal
} else {
Expand Down Expand Up @@ -339,7 +331,7 @@ data class BuyMoreKinModal(

if (showClose) {
ModalContainer(
closeButton = {
closeButtonEnabled = {
if (navigator.isVisible) {
it is BuyMoreKinModal
} else {
Expand All @@ -351,7 +343,7 @@ data class BuyMoreKinModal(
}
} else {
ModalContainer(
backButton = {
backButtonEnabled = {
if (navigator.isVisible) {
it is BuyMoreKinModal
} else {
Expand Down Expand Up @@ -387,7 +379,7 @@ data class EnterTipModal(val isInChat: Boolean = false) : MainGraph, ModalRoot {
val navigator = LocalCodeNavigator.current
if (isInChat) {
ModalContainer(
backButton = {
backButtonEnabled = {
if (navigator.isVisible) {
it is EnterTipModal
} else {
Expand All @@ -401,7 +393,7 @@ data class EnterTipModal(val isInChat: Boolean = false) : MainGraph, ModalRoot {
}
} else {
ModalContainer(
closeButton = {
closeButtonEnabled = {
if (navigator.isVisible) {
it is EnterTipModal
} else {
Expand All @@ -427,7 +419,7 @@ data object RequestTip : MainGraph, ModalContent {
override fun Content() {
val navigator = LocalCodeNavigator.current
ModalContainer(
backButton = {
backButtonEnabled = {
if (navigator.isVisible) {
it is RequestTip
} else {
Expand All @@ -451,7 +443,7 @@ data object GetKinModal : MainGraph, ModalRoot {

val viewModel = getViewModel<GetKinSheetViewModel>()
ModalContainer(
closeButton = {
closeButtonEnabled = {
if (navigator.isVisible) {
it is GetKinModal
} else {
Expand All @@ -476,7 +468,7 @@ data object BuySellScreen : MainGraph, ModalContent {

@Composable
override fun Content() {
ModalContainer(backButton = { it is BuySellScreen }) {
ModalContainer(backButtonEnabled = { it is BuySellScreen }) {
BuyAndSellKin(getViewModel())
}

Expand Down
Loading