diff --git a/presentation/src/main/kotlin/ac/dnd/mour/android/presentation/common/view/chip/ChipItem.kt b/presentation/src/main/kotlin/ac/dnd/mour/android/presentation/common/view/chip/ChipItem.kt index 986f4f50..c95628a7 100644 --- a/presentation/src/main/kotlin/ac/dnd/mour/android/presentation/common/view/chip/ChipItem.kt +++ b/presentation/src/main/kotlin/ac/dnd/mour/android/presentation/common/view/chip/ChipItem.kt @@ -2,7 +2,6 @@ package ac.dnd.mour.android.presentation.common.view.chip import ac.dnd.mour.android.presentation.common.theme.Body1 import ac.dnd.mour.android.presentation.common.theme.Gray000 -import ac.dnd.mour.android.presentation.common.theme.Gray400 import ac.dnd.mour.android.presentation.common.theme.Gray500 import ac.dnd.mour.android.presentation.common.theme.Gray700 import ac.dnd.mour.android.presentation.common.theme.Gray800 @@ -84,18 +83,14 @@ fun ChipItem( ) { Text( text = chipText, - style = Body1.merge( - color = textColor.value, - fontWeight = if (isSelected) FontWeight.SemiBold else FontWeight.Normal - ) + style = Body1.merge(color = textColor.value), + fontWeight = if (isSelected) FontWeight.SemiBold else FontWeight.Normal, ) if (chipCount > 0) { Spacer(modifier = Modifier.width(4.dp)) Text( text = chipCount.toString(), - style = Body1.merge( - color = textColor.value - ) + style = Body1.merge(color = textColor.value) ) } } diff --git a/presentation/src/main/kotlin/ac/dnd/mour/android/presentation/common/view/textfield/TypingPriceField.kt b/presentation/src/main/kotlin/ac/dnd/mour/android/presentation/common/view/textfield/TypingPriceField.kt index 9ee3a025..18b56878 100644 --- a/presentation/src/main/kotlin/ac/dnd/mour/android/presentation/common/view/textfield/TypingPriceField.kt +++ b/presentation/src/main/kotlin/ac/dnd/mour/android/presentation/common/view/textfield/TypingPriceField.kt @@ -120,10 +120,8 @@ fun TypingPriceField( placeholder = { Text( text = hintText, - style = Headline3.merge( - color = Gray600, - fontWeight = FontWeight.SemiBold - ) + fontWeight = FontWeight.SemiBold, + style = Headline3.merge(color = Gray600) ) }, visualTransformation = textFormat, @@ -133,7 +131,6 @@ fun TypingPriceField( contentPadding = innerPadding ) } - Spacer(modifier = Modifier.height(8.dp)) Divider( modifier = Modifier .fillMaxWidth() diff --git a/presentation/src/main/kotlin/ac/dnd/mour/android/presentation/ui/main/home/common/group/get/type/DefaultGroupType.kt b/presentation/src/main/kotlin/ac/dnd/mour/android/presentation/model/relation/DefaultGroupType.kt similarity index 88% rename from presentation/src/main/kotlin/ac/dnd/mour/android/presentation/ui/main/home/common/group/get/type/DefaultGroupType.kt rename to presentation/src/main/kotlin/ac/dnd/mour/android/presentation/model/relation/DefaultGroupType.kt index 5c99b907..0729c3c8 100644 --- a/presentation/src/main/kotlin/ac/dnd/mour/android/presentation/ui/main/home/common/group/get/type/DefaultGroupType.kt +++ b/presentation/src/main/kotlin/ac/dnd/mour/android/presentation/model/relation/DefaultGroupType.kt @@ -1,4 +1,4 @@ -package ac.dnd.mour.android.presentation.ui.main.home.common.group.get.type +package ac.dnd.mour.android.presentation.model.relation import ac.dnd.mour.android.presentation.R @@ -11,6 +11,8 @@ enum class DefaultGroupType( ACQUAINTANCE("지인", R.drawable.ic_group_acquaintance), RECTAL("직장", R.drawable.ic_group_rectal); + fun getTypeName() = typeName + companion object { fun checkEditable(name: String): Boolean { return entries.find { it.typeName == name } == null diff --git a/presentation/src/main/kotlin/ac/dnd/mour/android/presentation/ui/main/home/HomeScreen.kt b/presentation/src/main/kotlin/ac/dnd/mour/android/presentation/ui/main/home/HomeScreen.kt index 58547313..8139e145 100644 --- a/presentation/src/main/kotlin/ac/dnd/mour/android/presentation/ui/main/home/HomeScreen.kt +++ b/presentation/src/main/kotlin/ac/dnd/mour/android/presentation/ui/main/home/HomeScreen.kt @@ -3,7 +3,6 @@ package ac.dnd.mour.android.presentation.ui.main.home import ac.dnd.mour.android.presentation.R import ac.dnd.mour.android.presentation.common.theme.Gray000 import ac.dnd.mour.android.presentation.common.theme.Icon24 -import ac.dnd.mour.android.presentation.common.theme.Primary3 import ac.dnd.mour.android.presentation.common.util.LaunchedEffectWithLifecycle import ac.dnd.mour.android.presentation.common.util.coroutine.event.EventFlow import ac.dnd.mour.android.presentation.common.util.coroutine.event.MutableEventFlow @@ -37,8 +36,6 @@ import androidx.compose.runtime.Composable import androidx.compose.runtime.LaunchedEffect import androidx.compose.runtime.getValue import androidx.compose.runtime.mutableIntStateOf -import androidx.compose.runtime.mutableStateOf -import androidx.compose.runtime.remember import androidx.compose.runtime.rememberCoroutineScope import androidx.compose.runtime.saveable.rememberSaveable import androidx.compose.runtime.setValue @@ -59,7 +56,6 @@ fun HomeScreen( handler: CoroutineExceptionHandler ) { val scope = rememberCoroutineScope() - var historyExpandedState by remember { mutableStateOf(false) } val bottomBarItemList: List = listOf( MainBottomBarItem( route = HistoryConstant.ROUTE, @@ -98,11 +94,9 @@ fun HomeScreen( pageCount = { bottomBarItemList.size } ) - LaunchedEffect(selectedItem, historyExpandedState) { - if (selectedItem != 0 || historyExpandedState) { + LaunchedEffect(selectedItem) { + if (selectedItem != 0) { appState.systemUiController.setStatusBarColor(Gray000) - } else { - appState.systemUiController.setStatusBarColor(Primary3) } pagerState.animateScrollToPage(selectedItem) } @@ -129,10 +123,8 @@ fun HomeScreen( when (bottomBarItemList[page].route) { HistoryConstant.ROUTE -> { HistoryScreen( - appState = appState, - changeState = { - historyExpandedState = it - } + selectedItem = selectedItem, + appState = appState ) } diff --git a/presentation/src/main/kotlin/ac/dnd/mour/android/presentation/ui/main/home/common/group/get/GetGroupScreen.kt b/presentation/src/main/kotlin/ac/dnd/mour/android/presentation/ui/main/home/common/group/get/GetGroupScreen.kt index e70913cf..0f66cf65 100644 --- a/presentation/src/main/kotlin/ac/dnd/mour/android/presentation/ui/main/home/common/group/get/GetGroupScreen.kt +++ b/presentation/src/main/kotlin/ac/dnd/mour/android/presentation/ui/main/home/common/group/get/GetGroupScreen.kt @@ -23,10 +23,10 @@ import ac.dnd.mour.android.presentation.common.util.coroutine.event.MutableEvent import ac.dnd.mour.android.presentation.common.util.coroutine.event.eventObserve import ac.dnd.mour.android.presentation.common.view.BottomSheetScreen import ac.dnd.mour.android.presentation.common.view.DialogScreen +import ac.dnd.mour.android.presentation.model.relation.DefaultGroupType import ac.dnd.mour.android.presentation.ui.main.ApplicationState import ac.dnd.mour.android.presentation.ui.main.home.common.group.add.AddGroupScreen import ac.dnd.mour.android.presentation.ui.main.home.common.group.edit.EditGroupScreen -import ac.dnd.mour.android.presentation.ui.main.home.common.group.get.type.DefaultGroupType import ac.dnd.mour.android.presentation.ui.main.rememberApplicationState import androidx.compose.foundation.Image import androidx.compose.foundation.background diff --git a/presentation/src/main/kotlin/ac/dnd/mour/android/presentation/ui/main/home/history/HistoryBackgroundComponent.kt b/presentation/src/main/kotlin/ac/dnd/mour/android/presentation/ui/main/home/history/HistoryBackgroundComponent.kt index 43f347be..3a74c2a6 100644 --- a/presentation/src/main/kotlin/ac/dnd/mour/android/presentation/ui/main/home/history/HistoryBackgroundComponent.kt +++ b/presentation/src/main/kotlin/ac/dnd/mour/android/presentation/ui/main/home/history/HistoryBackgroundComponent.kt @@ -7,7 +7,7 @@ import ac.dnd.mour.android.presentation.R import ac.dnd.mour.android.presentation.common.theme.Body1 import ac.dnd.mour.android.presentation.common.theme.Gray000 import ac.dnd.mour.android.presentation.common.theme.Gray600 -import ac.dnd.mour.android.presentation.common.theme.Gray700 +import ac.dnd.mour.android.presentation.common.theme.Gray800 import ac.dnd.mour.android.presentation.common.theme.Headline1 import ac.dnd.mour.android.presentation.common.theme.Primary2 import ac.dnd.mour.android.presentation.common.theme.Primary3 @@ -166,6 +166,8 @@ fun HistoryBackgroundComponent( .align(Alignment.TopEnd) .padding(top = 8.dp) .offset(x = 23.dp) + .width(236.dp) + .height(160.dp) ) { LottieAnimation( composition = composition, @@ -181,6 +183,7 @@ fun HistoryBackgroundComponent( ) { Spacer(modifier = Modifier.height(40.dp)) Text( + fontWeight = FontWeight.SemiBold, style = Headline1.merge(color = Gray000), text = "총 ${model.groups.size}번의 마음을 \n주고 받았어요", fontSize = 20.scaledSp(), @@ -226,18 +229,14 @@ fun HistoryBackgroundComponent( Column { Text( text = "지난 일정 ${model.unrecordedSchedule.size}개", - style = Body1.merge( - color = Gray700, - fontWeight = FontWeight.SemiBold - ) + fontWeight = FontWeight.SemiBold, + style = Body1.merge(color = Gray800) ) Row(verticalAlignment = Alignment.CenterVertically) { Text( text = "한번에 기록하기", - style = Body1.merge( - color = Gray600, - fontWeight = FontWeight.Medium - ) + fontWeight = FontWeight.Medium, + style = Body1.merge(color = Gray600) ) Image( painter = painterResource(R.drawable.ic_chevron_right_gray), diff --git a/presentation/src/main/kotlin/ac/dnd/mour/android/presentation/ui/main/home/history/HistoryPageScreen.kt b/presentation/src/main/kotlin/ac/dnd/mour/android/presentation/ui/main/home/history/HistoryPageScreen.kt index 11c40613..46adb159 100644 --- a/presentation/src/main/kotlin/ac/dnd/mour/android/presentation/ui/main/home/history/HistoryPageScreen.kt +++ b/presentation/src/main/kotlin/ac/dnd/mour/android/presentation/ui/main/home/history/HistoryPageScreen.kt @@ -21,6 +21,7 @@ import ac.dnd.mour.android.presentation.common.view.chip.ChipItem import ac.dnd.mour.android.presentation.common.view.chip.ChipType import ac.dnd.mour.android.presentation.model.history.HistorySortedType import ac.dnd.mour.android.presentation.model.history.HistoryViewType +import ac.dnd.mour.android.presentation.model.relation.DefaultGroupType import ac.dnd.mour.android.presentation.ui.main.ApplicationState import ac.dnd.mour.android.presentation.ui.main.home.history.detail.HistoryDetailConstant import android.annotation.SuppressLint @@ -66,7 +67,6 @@ import androidx.compose.ui.tooling.preview.Preview import androidx.compose.ui.unit.dp import androidx.compose.ui.unit.sp import kotlinx.coroutines.CoroutineExceptionHandler -import timber.log.Timber @SuppressLint("InvalidColorHexValue") @Composable @@ -95,34 +95,32 @@ fun HistoryPageScreen( } } ) + }.sortedByDescending { + it.relationList.size + }.filter { + if (searchText.isNotEmpty()) { + it.name.contains(searchText) + } else { + true + } } - val relations = - if (selectedGroupId == -1L) groups.flatMap { it.relationList } - else if (selectedGroupId < -1L) listOf() - else groups.find { it.id == selectedGroupId } - ?.relationList - ?: groups.flatMap { it.relationList } - .sortedByDescending { - if (viewSortType == HistorySortedType.LATEST) it.id else null - } - .sortedBy { - if (viewSortType == HistorySortedType.INTIMACY) { - when (viewType) { - HistoryViewType.TOTAL -> it.giveMoney + it.takeMoney - HistoryViewType.GIVE -> it.giveMoney - HistoryViewType.TAKE -> it.takeMoney - } - } else { - null - } - } - .filter { - if (searchText.isNotEmpty()) { - it.name.contains(searchText) - } else { - true - } + + val relations = groups.flatMap { it.relationList } + .sortedByDescending { + when (viewSortType) { + HistorySortedType.LATEST -> it.id + HistorySortedType.INTIMACY -> when (viewType) { + HistoryViewType.TOTAL -> it.giveMoney + it.takeMoney + HistoryViewType.GIVE -> it.giveMoney + HistoryViewType.TAKE -> it.takeMoney } + } + } + .filter { + if (selectedGroupId == -1L) true + else if (selectedGroupId < 0) false + else it.group.id == selectedGroupId + } fun navigateToHistoryDetail(id: Long) { val route = makeRoute( @@ -153,9 +151,9 @@ fun HistoryPageScreen( contentAlignment = Alignment.CenterStart ) { GroupChipListComponent( - chipType = ChipType.MAIN, currentSelectedId = selectedGroupId, groups = groups, + relationCount = model.groups.flatMap { it.relationList }.size, onSelectChip = { groupId -> selectedGroupId = groupId } @@ -166,12 +164,13 @@ fun HistoryPageScreen( .width(56.dp) .fillMaxHeight() .background( - Brush.horizontalGradient( + brush = Brush.horizontalGradient( listOf( Color(0x00F6F6F7), Color(0xFFF6F6F7), ) - ) + ), + alpha = 0.4f ) ) } @@ -240,6 +239,9 @@ fun HistoryPageScreen( }, ) } + item(1) { + Spacer(modifier = Modifier.height(80.dp)) + } } } } @@ -317,33 +319,33 @@ fun HistoryPageScreen( @Composable private fun GroupChipListComponent( - chipType: ChipType = ChipType.LESS_BORDER, currentSelectedId: Long, onSelectChip: (Long) -> Unit, + relationCount: Int, groups: List ) { - val defaultList = listOf("전체", "가족", "친구", "지인", "직장") + val defaultList = DefaultGroupType.entries + .map { it.getTypeName() } .filter { value -> value !in groups.map { it.name } } LazyRow(horizontalArrangement = Arrangement.spacedBy(6.dp)) { - items(defaultList.size) { index -> + item(1) { ChipItem( - chipType = chipType, + chipType = ChipType.MAIN, currentSelectedId = setOf(currentSelectedId), - chipId = (-index - 1).toLong(), - chipText = defaultList[index], - chipCount = if (index==0) groups.size else 0, + chipId = -1L, + chipText = "전체", + chipCount = relationCount, onSelectChip = { - onSelectChip((-index - 1).toLong()) + onSelectChip(-1L) } ) } - items(groups) { group -> ChipItem( - chipType = chipType, + chipType = ChipType.MAIN, currentSelectedId = setOf(currentSelectedId), chipId = group.id, chipText = group.name, @@ -353,6 +355,19 @@ private fun GroupChipListComponent( } ) } + + items(defaultList.size) { index -> + ChipItem( + chipType = ChipType.MAIN, + currentSelectedId = setOf(currentSelectedId), + chipId = (-index - 2).toLong(), + chipText = defaultList[index], + chipCount = 0, + onSelectChip = { + onSelectChip((-index - 2).toLong()) + } + ) + } } } @@ -430,9 +445,9 @@ private fun EmptyRelationViewPreview() { @Preview private fun GroupChipListComponent1Preview() { GroupChipListComponent( - chipType = ChipType.MAIN, currentSelectedId = -1, groups = listOf(), + relationCount = 10, onSelectChip = { } @@ -443,7 +458,6 @@ private fun GroupChipListComponent1Preview() { @Preview private fun GroupChipListComponent2Preview() { GroupChipListComponent( - chipType = ChipType.MAIN, currentSelectedId = -1, groups = listOf( GroupWithRelationDetail( @@ -543,6 +557,7 @@ private fun GroupChipListComponent2Preview() { ) ) ), + relationCount = 10, onSelectChip = { } diff --git a/presentation/src/main/kotlin/ac/dnd/mour/android/presentation/ui/main/home/history/HistoryRelationItem.kt b/presentation/src/main/kotlin/ac/dnd/mour/android/presentation/ui/main/home/history/HistoryRelationItem.kt index cdfa6517..202adfa4 100644 --- a/presentation/src/main/kotlin/ac/dnd/mour/android/presentation/ui/main/home/history/HistoryRelationItem.kt +++ b/presentation/src/main/kotlin/ac/dnd/mour/android/presentation/ui/main/home/history/HistoryRelationItem.kt @@ -4,17 +4,15 @@ import ac.dnd.mour.android.domain.model.feature.relation.RelationDetail import ac.dnd.mour.android.domain.model.feature.relation.RelationDetailGroup import ac.dnd.mour.android.presentation.common.theme.Body1 import ac.dnd.mour.android.presentation.common.theme.Body2 -import ac.dnd.mour.android.presentation.common.theme.Caption1 import ac.dnd.mour.android.presentation.common.theme.Gray000 -import ac.dnd.mour.android.presentation.common.theme.Gray500 import ac.dnd.mour.android.presentation.common.theme.Gray600 -import ac.dnd.mour.android.presentation.common.theme.Gray700 +import ac.dnd.mour.android.presentation.common.theme.Gray800 import ac.dnd.mour.android.presentation.common.theme.Headline3 import ac.dnd.mour.android.presentation.common.theme.Primary4 import ac.dnd.mour.android.presentation.common.theme.Primary5 import ac.dnd.mour.android.presentation.common.theme.Shapes import ac.dnd.mour.android.presentation.model.history.HistoryViewType -import ac.dnd.mour.android.presentation.ui.main.home.common.group.get.type.DefaultGroupType +import ac.dnd.mour.android.presentation.model.relation.DefaultGroupType import androidx.compose.foundation.Image import androidx.compose.foundation.clickable import androidx.compose.foundation.layout.Box @@ -31,6 +29,7 @@ import androidx.compose.material.Text import androidx.compose.runtime.Composable 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.res.painterResource import androidx.compose.ui.text.font.FontWeight @@ -50,9 +49,11 @@ fun HistoryRelationItem( Card( shape = Shapes.large, backgroundColor = Gray000, - modifier = Modifier.clickable { - onSelectCard(relation) - } + modifier = Modifier + .clip(Shapes.large) + .clickable { + onSelectCard(relation) + } ) { Column( modifier = Modifier.padding(horizontal = 12.dp) @@ -70,10 +71,8 @@ fun HistoryRelationItem( Column { Text( text = relation.name, - style = Headline3.merge( - color = Gray700, - fontWeight = FontWeight.SemiBold - ), + fontWeight = FontWeight.SemiBold, + style = Headline3.merge(color = Gray800), lineHeight = 24.sp, textAlign = TextAlign.Left, maxLines = 1, @@ -82,10 +81,8 @@ fun HistoryRelationItem( Spacer(modifier = Modifier.height(1.dp)) Text( text = relation.group.name, - style = Caption1.merge( - color = Gray600, - fontWeight = FontWeight.Normal - ), + fontWeight = FontWeight.Medium, + style = Body1.merge(color = Gray600), lineHeight = 21.sp, ) } @@ -95,10 +92,8 @@ fun HistoryRelationItem( Box(modifier = Modifier.fillMaxWidth()) { Text( text = "받음", - style = Body1.merge( - color = Gray500, - fontWeight = FontWeight.Medium - ), + fontWeight = FontWeight.Medium, + style = Body1.merge(color = Gray600), modifier = Modifier.align(Alignment.CenterStart) ) Row( @@ -128,10 +123,8 @@ fun HistoryRelationItem( Box(modifier = Modifier.fillMaxWidth()) { Text( text = "보냄", - style = Body1.merge( - color = Gray500, - fontWeight = FontWeight.Medium - ), + fontWeight = FontWeight.Medium, + style = Body1.merge(color = Gray600), modifier = Modifier.align(Alignment.CenterStart) ) Row( diff --git a/presentation/src/main/kotlin/ac/dnd/mour/android/presentation/ui/main/home/history/HistoryScreen.kt b/presentation/src/main/kotlin/ac/dnd/mour/android/presentation/ui/main/home/history/HistoryScreen.kt index 15f6c6fc..e4fc2d6d 100644 --- a/presentation/src/main/kotlin/ac/dnd/mour/android/presentation/ui/main/home/history/HistoryScreen.kt +++ b/presentation/src/main/kotlin/ac/dnd/mour/android/presentation/ui/main/home/history/HistoryScreen.kt @@ -16,7 +16,6 @@ import ac.dnd.mour.android.presentation.common.theme.Gray800 import ac.dnd.mour.android.presentation.common.theme.Headline3 import ac.dnd.mour.android.presentation.common.theme.Primary3 import ac.dnd.mour.android.presentation.common.theme.Primary4 -import ac.dnd.mour.android.presentation.common.theme.Secondary5 import ac.dnd.mour.android.presentation.common.theme.Secondary6 import ac.dnd.mour.android.presentation.common.util.ErrorObserver import ac.dnd.mour.android.presentation.common.util.LaunchedEffectWithLifecycle @@ -110,7 +109,7 @@ import kotlinx.datetime.LocalTime @Composable fun HistoryScreen( appState: ApplicationState, - changeState: (Boolean) -> Unit, + selectedItem: Int, viewModel: HistoryViewModel = hiltViewModel() ) { @@ -132,7 +131,7 @@ fun HistoryScreen( event = viewModel.event, intent = viewModel::onIntent, handler = viewModel.handler, - changeState = changeState + selectedItem = selectedItem ) } @@ -148,7 +147,7 @@ private fun HistoryScreen( event: EventFlow, intent: (HistoryIntent) -> Unit, handler: CoroutineExceptionHandler, - changeState: (Boolean) -> Unit + selectedItem: Int ) { LaunchedEffectWithLifecycle(context = handler) { @@ -169,10 +168,20 @@ private fun HistoryScreen( (if (model.unrecordedSchedule.isNotEmpty() && isViewUnrecordedState) 343.dp else 257.dp) val swipeState = rememberSwipeableState(initialValue = HistoryViewSwipingType.COLLAPSED) - LaunchedEffect(swipeState.progress.to){ - when (swipeState.progress.to) { - HistoryViewSwipingType.EXPANDED -> changeState(true) - HistoryViewSwipingType.COLLAPSED -> changeState(false) +// LaunchedEffect(isDropDownMenuExpanded){ +// appState.systemUiController.isStatusBarVisible = !isDropDownMenuExpanded +// } + LaunchedEffect(swipeState.progress.to, selectedItem, isDropDownMenuExpanded) { + if (selectedItem == 0) { + when (swipeState.progress.to) { + HistoryViewSwipingType.EXPANDED -> { + appState.systemUiController.setStatusBarColor(Gray000) + } + + HistoryViewSwipingType.COLLAPSED -> { + appState.systemUiController.setStatusBarColor(Primary3) + } + } } } @@ -218,7 +227,6 @@ private fun HistoryScreen( val searchBoxHeightState = animateDpAsState( targetValue = when (swipeState.progress.to) { HistoryViewSwipingType.COLLAPSED -> 0.dp - HistoryViewSwipingType.EXPANDED -> 65.dp }, label = "search in EXPANDED " @@ -292,7 +300,6 @@ private fun HistoryScreen( }, onDeleteUnrecorded = { isViewUnrecordedState = false - //TODO delete Unrecorded (api) } ) if (!isPlayingLoading) { @@ -495,7 +502,7 @@ private fun HistoryScreen( } if (isDropDownMenuExpanded) { - val isNotEmptyRelation = true //TODO edit to prevent + val isNotEmptyRelation = model.groups.isNotEmpty() Box( modifier = Modifier @@ -559,6 +566,7 @@ private fun HistoryScreen( x = (-14).dp, y = (-92).dp ) + .clip(RoundedCornerShape(100.dp)) .clickable { isDropDownMenuExpanded = false navigateToAddRelation() @@ -581,8 +589,7 @@ private fun HistoryScreen( horizontalArrangement = Arrangement.Center, ) { Image( - painter = painterResource(R.drawable.ic_person), - colorFilter = ColorFilter.tint(Secondary5), + painter = painterResource(R.drawable.ic_person_relation), modifier = Modifier.size(24.dp), contentDescription = null, ) @@ -762,6 +769,6 @@ private fun HistoryScreenPreview1() { event = MutableEventFlow(), intent = {}, handler = CoroutineExceptionHandler { _, _ -> }, - changeState = {} + selectedItem = 0 ) } diff --git a/presentation/src/main/kotlin/ac/dnd/mour/android/presentation/ui/main/home/history/unrecorded/HistoryUnrecordedPageScreen.kt b/presentation/src/main/kotlin/ac/dnd/mour/android/presentation/ui/main/home/history/unrecorded/HistoryUnrecordedPageScreen.kt index 4cd98ddb..cb0ff1f1 100644 --- a/presentation/src/main/kotlin/ac/dnd/mour/android/presentation/ui/main/home/history/unrecorded/HistoryUnrecordedPageScreen.kt +++ b/presentation/src/main/kotlin/ac/dnd/mour/android/presentation/ui/main/home/history/unrecorded/HistoryUnrecordedPageScreen.kt @@ -15,6 +15,7 @@ import ac.dnd.mour.android.presentation.common.theme.Gray900 import ac.dnd.mour.android.presentation.common.theme.Headline1 import ac.dnd.mour.android.presentation.common.theme.Headline2 import ac.dnd.mour.android.presentation.common.theme.Headline3 +import ac.dnd.mour.android.presentation.common.theme.Shapes import ac.dnd.mour.android.presentation.common.view.chip.ChipItem import ac.dnd.mour.android.presentation.common.view.chip.ChipType import ac.dnd.mour.android.presentation.common.view.component.FieldSubject @@ -37,6 +38,7 @@ import androidx.compose.foundation.layout.fillMaxHeight import androidx.compose.foundation.layout.fillMaxSize import androidx.compose.foundation.layout.fillMaxWidth import androidx.compose.foundation.layout.height +import androidx.compose.foundation.layout.offset import androidx.compose.foundation.layout.padding import androidx.compose.foundation.layout.width import androidx.compose.foundation.rememberScrollState @@ -57,6 +59,7 @@ import androidx.compose.ui.text.font.FontWeight import androidx.compose.ui.text.style.TextAlign import androidx.compose.ui.tooling.preview.Preview import androidx.compose.ui.unit.dp +import androidx.compose.ui.unit.sp import kotlinx.datetime.LocalDate import kotlinx.datetime.LocalTime @@ -69,7 +72,10 @@ fun HistoryUnrecordedPageScreen( var moneyText by remember { mutableStateOf("") } val tagIdList = remember { mutableStateListOf() } val scrollState = rememberScrollState() - Box(modifier = Modifier.fillMaxSize()) { + Box(modifier = Modifier + .fillMaxSize() + .background(Gray000) + ) { Column( modifier = Modifier .align(Alignment.TopCenter) @@ -78,27 +84,23 @@ fun HistoryUnrecordedPageScreen( Box( modifier = Modifier .fillMaxWidth() + .offset(x = 0.dp, y = (-7).dp) .padding(horizontal = 20.dp) ) { Column( - modifier = Modifier - .padding(top = 12.dp) - .align(Alignment.TopStart) + modifier = Modifier.align(Alignment.TopStart) ) { + Spacer(modifier = Modifier.height(12.dp)) Text( text = "지난 일정이 \n${unRecordSize}개 있습니다.", - style = Headline1.merge( - color = Gray900, - fontWeight = FontWeight.SemiBold - ), + fontWeight = FontWeight.SemiBold, + style = Headline1.merge(color = Gray900), ) Spacer(modifier = Modifier.height(12.dp)) Text( text = "얼마를 지출하셨나요?", - style = Body1.merge( - color = Gray700, - fontWeight = FontWeight.Medium - ) + fontWeight = FontWeight.Medium, + style = Body1.merge(color = Gray700) ) } Box( @@ -116,18 +118,15 @@ fun HistoryUnrecordedPageScreen( ) } } - Spacer(modifier = Modifier.height(31.dp)) + Spacer(modifier = Modifier.height(24.dp)) Row( modifier = Modifier .padding(horizontal = 20.dp) - .height(83.dp) .background( color = Color.White, - shape = RoundedCornerShape( - topStart = 8.dp, - bottomStart = 8.dp - ) - ), + shape = Shapes.medium + ) + .height(83.dp), verticalAlignment = Alignment.CenterVertically ) { Box( @@ -142,51 +141,50 @@ fun HistoryUnrecordedPageScreen( ) ) ) - Column( + Box( modifier = Modifier .padding( start = 20.dp, + end = 20.dp, top = 12.dp, - bottom = 14.dp, - end = 20.dp + bottom = 14.dp ) + .fillMaxHeight() ) { Text( text = "${unrecordedSchedule.day.year}년 " + "${unrecordedSchedule.day.monthNumber}월 " + "${unrecordedSchedule.day.dayOfMonth}일", - style = Body1.merge( - color = Gray600, - fontWeight = FontWeight.Normal - ) + fontWeight = FontWeight.Normal, + style = Body1.merge(color = Gray700), + letterSpacing = (-0.25).sp, + modifier = Modifier + .height(28.dp) + .align(Alignment.TopStart), ) - Spacer(modifier = Modifier.height(4.dp)) Row( - modifier = Modifier.fillMaxWidth(), + modifier = Modifier + .height(29.dp) + .align(Alignment.BottomStart) + .fillMaxWidth(), verticalAlignment = Alignment.CenterVertically ) { Text( text = unrecordedSchedule.relation.name, - style = Headline2.merge( - color = Gray800, - fontWeight = FontWeight.SemiBold - ) + fontWeight = FontWeight.SemiBold, + style = Headline2.merge(color = Gray900) ) Text( text = "•", - style = Body0.merge( - color = Gray600, - fontWeight = FontWeight.Normal - ), + fontWeight = FontWeight.Normal, + style = Body0.merge(color = Gray700), textAlign = TextAlign.Center, modifier = Modifier.width(16.dp) ) Text( - text = unrecordedSchedule.relation.name, - style = Body0.merge( - color = Gray600, - fontWeight = FontWeight.Normal - ) + text = unrecordedSchedule.relation.group.name, + fontWeight = FontWeight.Normal, + style = Body0.merge(color = Gray700) ) Spacer(modifier = Modifier.weight(1f)) Box( @@ -206,22 +204,18 @@ fun HistoryUnrecordedPageScreen( ) { Text( text = unrecordedSchedule.event, - style = Body1.merge( - color = Gray000, - fontWeight = FontWeight.SemiBold - ) + fontWeight = FontWeight.SemiBold, + style = Body1.merge(color = Gray000) ) } } } } Spacer(modifier = Modifier.height(28.dp)) - Spacer(modifier = Modifier.height(24.dp)) Column( modifier = Modifier .background(Gray000) .verticalScroll(scrollState) - .fillMaxSize() .padding(horizontal = 20.dp) ) { Spacer(modifier = Modifier.height(24.dp)) @@ -288,11 +282,9 @@ fun HistoryUnrecordedPageScreen( } ) { Text( - text = "다음", - style = Headline3.merge( - color = Gray000, - fontWeight = FontWeight.SemiBold - ) + text = if (unRecordSize==1) "완료" else "다음", + fontWeight = FontWeight.SemiBold, + style = Headline3.merge(color = Gray000) ) } Spacer(modifier = Modifier.height(12.dp)) diff --git a/presentation/src/main/kotlin/ac/dnd/mour/android/presentation/ui/main/home/schedule/ScheduleScreenItem.kt b/presentation/src/main/kotlin/ac/dnd/mour/android/presentation/ui/main/home/schedule/ScheduleScreenItem.kt index 295e8983..69b36c31 100644 --- a/presentation/src/main/kotlin/ac/dnd/mour/android/presentation/ui/main/home/schedule/ScheduleScreenItem.kt +++ b/presentation/src/main/kotlin/ac/dnd/mour/android/presentation/ui/main/home/schedule/ScheduleScreenItem.kt @@ -18,7 +18,7 @@ import ac.dnd.mour.android.presentation.common.view.confirm.ConfirmButtonPropert import ac.dnd.mour.android.presentation.common.view.confirm.ConfirmButtonSize import ac.dnd.mour.android.presentation.common.view.confirm.ConfirmButtonType import ac.dnd.mour.android.presentation.model.history.HistoryEventType -import ac.dnd.mour.android.presentation.ui.main.home.common.group.get.type.DefaultGroupType +import ac.dnd.mour.android.presentation.model.relation.DefaultGroupType import androidx.annotation.DrawableRes import androidx.compose.foundation.Image import androidx.compose.foundation.background @@ -28,7 +28,6 @@ import androidx.compose.foundation.layout.Box import androidx.compose.foundation.layout.Column import androidx.compose.foundation.layout.Row import androidx.compose.foundation.layout.Spacer -import androidx.compose.foundation.layout.fillMaxSize import androidx.compose.foundation.layout.fillMaxWidth import androidx.compose.foundation.layout.height import androidx.compose.foundation.layout.padding diff --git a/presentation/src/main/kotlin/ac/dnd/mour/android/presentation/ui/main/home/statistics/me/event/StatisticsMeEventScreen.kt b/presentation/src/main/kotlin/ac/dnd/mour/android/presentation/ui/main/home/statistics/me/event/StatisticsMeEventScreen.kt index 7c7056bc..3d24569a 100644 --- a/presentation/src/main/kotlin/ac/dnd/mour/android/presentation/ui/main/home/statistics/me/event/StatisticsMeEventScreen.kt +++ b/presentation/src/main/kotlin/ac/dnd/mour/android/presentation/ui/main/home/statistics/me/event/StatisticsMeEventScreen.kt @@ -25,7 +25,7 @@ import ac.dnd.mour.android.presentation.common.view.chip.ChipItem import ac.dnd.mour.android.presentation.common.view.chip.ChipType import ac.dnd.mour.android.presentation.model.history.HistoryEventType import ac.dnd.mour.android.presentation.ui.main.ApplicationState -import ac.dnd.mour.android.presentation.ui.main.home.common.group.get.type.DefaultGroupType +import ac.dnd.mour.android.presentation.model.relation.DefaultGroupType import ac.dnd.mour.android.presentation.ui.main.rememberApplicationState import androidx.compose.foundation.Image import androidx.compose.foundation.background diff --git a/presentation/src/main/res/drawable/ic_person_relation.xml b/presentation/src/main/res/drawable/ic_person_relation.xml new file mode 100644 index 00000000..b63a3f59 --- /dev/null +++ b/presentation/src/main/res/drawable/ic_person_relation.xml @@ -0,0 +1,12 @@ + + + + diff --git a/presentation/src/main/res/raw/history_main_flower.json b/presentation/src/main/res/raw/history_main_flower.json index 3c82a7ec..3f53f457 100644 --- a/presentation/src/main/res/raw/history_main_flower.json +++ b/presentation/src/main/res/raw/history_main_flower.json @@ -1 +1 @@ -{"v":"4.8.0","meta":{"g":"LottieFiles AE 3.5.4","a":"","k":"","d":"","tc":""},"fr":30,"ip":0,"op":191,"w":240,"h":163,"nm":"main flower","ddd":0,"assets":[{"id":"image_0","w":58,"h":71,"u":"","p":"","e":1},{"id":"image_1","w":103,"h":149,"u":"","p":"","e":1},{"id":"image_2","w":72,"h":152,"u":"","p":"","e":1}],"layers":[{"ddd":0,"ind":1,"ty":2,"nm":"p flower","refId":"image_0","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":1,"k":[{"i":{"x":[0.833],"y":[1]},"o":{"x":[0.167],"y":[0]},"t":0,"s":[0]},{"i":{"x":[0.41],"y":[1]},"o":{"x":[0.333],"y":[0]},"t":44,"s":[-2]},{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.167],"y":[0]},"t":85,"s":[2]},{"i":{"x":[0.833],"y":[1]},"o":{"x":[0.167],"y":[0]},"t":147,"s":[-2]},{"t":191,"s":[0]}],"ix":10,"x":"var $bm_rt;\n$bm_rt = loopOut('cycle', 0);"},"p":{"a":0,"k":[141.932,140.113,0],"ix":2},"a":{"a":0,"k":[12.998,66.958,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"ip":0,"op":191,"st":-1,"bm":0},{"ddd":0,"ind":2,"ty":2,"nm":"y flower","refId":"image_1","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":1,"k":[{"i":{"x":[0.318],"y":[1.501]},"o":{"x":[0.494],"y":[0]},"t":0,"s":[0]},{"i":{"x":[0.828],"y":[1]},"o":{"x":[0.223],"y":[0.115]},"t":44,"s":[3]},{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.167],"y":[0]},"t":85,"s":[-1]},{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.167],"y":[0]},"t":147,"s":[3]},{"t":191,"s":[0]}],"ix":10,"x":"var $bm_rt;\n$bm_rt = loopOut('cycle', 0);"},"p":{"a":0,"k":[107.727,150.467,0],"ix":2},"a":{"a":0,"k":[35.694,143.106,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"ip":0,"op":191,"st":0,"bm":0},{"ddd":0,"ind":3,"ty":2,"nm":"w flower","refId":"image_2","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":1,"k":[{"i":{"x":[0.955],"y":[1]},"o":{"x":[0.167],"y":[0]},"t":0,"s":[0]},{"i":{"x":[0.54],"y":[1]},"o":{"x":[0.333],"y":[0]},"t":44,"s":[-2]},{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.167],"y":[0]},"t":85,"s":[2]},{"i":{"x":[0.833],"y":[1]},"o":{"x":[0.167],"y":[0]},"t":147,"s":[-2]},{"t":191,"s":[0]}],"ix":10,"x":"var $bm_rt;\n$bm_rt = loopOut('cycle', 0);"},"p":{"a":0,"k":[111.922,156.455,0],"ix":2},"a":{"a":0,"k":[61.699,142.62,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"ip":0,"op":191,"st":0,"bm":0}],"markers":[]} \ No newline at end of file +{"v":"4.8.0","meta":{"g":"LottieFiles AE 3.5.4","a":"","k":"","d":"","tc":""},"fr":29.9700012207031,"ip":0,"op":180.00000733155,"w":475,"h":323,"nm":"main flower","ddd":0,"assets":[{"id":"image_0","w":123,"h":151,"u":"","p":"","e":1},{"id":"image_1","w":139,"h":280,"u":"","p":"","e":1},{"id":"image_2","w":154,"h":324,"u":"","p":"","e":1}],"layers":[{"ddd":0,"ind":1,"ty":2,"nm":"p flower","refId":"image_0","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":1,"k":[{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.333],"y":[0]},"t":0,"s":[0]},{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.333],"y":[0]},"t":90,"s":[-2.5]},{"t":180.00000733155,"s":[0]}],"ix":10},"p":{"a":0,"k":[290.087,277.198,0],"ix":2},"a":{"a":0,"k":[28.101,145.007,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"ip":0,"op":900.000036657751,"st":0,"bm":0},{"ddd":0,"ind":2,"ty":2,"nm":"y flower","refId":"image_1","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":1,"k":[{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.333],"y":[0]},"t":0,"s":[0]},{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.333],"y":[0]},"t":90,"s":[2.5]},{"t":180.00000733155,"s":[0]}],"ix":10},"p":{"a":0,"k":[223.977,294.972,0],"ix":2},"a":{"a":0,"k":[37.268,261.778,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"ip":0,"op":900.000036657751,"st":0,"bm":0},{"ddd":0,"ind":3,"ty":2,"nm":"w flower","refId":"image_2","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":1,"k":[{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.333],"y":[0]},"t":0,"s":[0]},{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.333],"y":[0]},"t":90,"s":[-2.5]},{"t":180.00000733155,"s":[0]}],"ix":10},"p":{"a":0,"k":[226.915,306.97,0],"ix":2},"a":{"a":0,"k":[127.939,305.131,0],"ix":1},"s":{"a":0,"k":[100,100,100],"ix":6}},"ao":0,"ip":0,"op":900.000036657751,"st":0,"bm":0}],"markers":[]} \ No newline at end of file