Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Top Bar 구현 #19

Merged
merged 19 commits into from
Jan 19, 2025
Merged

Top Bar 구현 #19

merged 19 commits into from
Jan 19, 2025

Conversation

HI-JIN2
Copy link
Member

@HI-JIN2 HI-JIN2 commented Dec 9, 2024

구현

image

ToReviewer

왼쪽 아이콘은 box로 감싸서 터치영역을 넓혔는데, actions으로 받은 오른쪽 친구들의 터치영역을 넓힐 수 있는 방법이 있을까요? 단순하게 요소 간의 간격 띄우는거는 horizontalArrangement = Arrangement.spacedBy(topBarActionsInsidePadding), 로 하였는데, 다시 보니 여기도 왼쪽 아이콘 처럼 터치영역을 넓혀야할 것 같드라구요.. 좋은 아이디어가 있다면 코멘트 부탁드립니다. 감사합니다.

@HI-JIN2 HI-JIN2 changed the title ㅅop bar Top Bar 구현 Dec 9, 2024
@HI-JIN2 HI-JIN2 self-assigned this Dec 9, 2024
@HI-JIN2 HI-JIN2 marked this pull request as draft December 13, 2024 07:29
Copy link
Member

@kangyuri1114 kangyuri1114 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

아직 진행중인것 같지만 리뷰도 한번 확인부탁드려요!

Spacer(modifier = Modifier.weight(1f))

// Actions
if (actions != null) {
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

별건 아니지만 전 이런식의 표현이 좀 더 kotlin스러워서 선호합니다

actions?.let{
    ... // anctions가 null이 아닌경우
}

Comment on lines 150 to 158
if (actions != null) {
Row(
verticalAlignment = Alignment.CenterVertically,
modifier = Modifier
.padding(10.dp)
) {
actions()
}
}
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

오른쪽 아이콘이 여러개 들어간 경우 figma상 각각 아이콘 사이의 패딩과 현재 프리뷰 상 패딩이 다른 것 같아요
이것도 사용 시에 패딩을 주는 것 말고 패딩이 지정되어있으면 어떨까요
[프리뷰]
image

[피그마]
image
image

…p-bar

# Conflicts:
#	compose/src/main/kotlin/com/yourssu/handy/compose/TopAppBar.kt
@HI-JIN2 HI-JIN2 marked this pull request as ready for review January 13, 2025 10:38
@cometj03
Copy link
Member

질문하신 내용에 대해서 머티리얼은 어떻게 구현되어 있나요?

Copy link
Member

@kangyuri1114 kangyuri1114 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

수고하셨습니다!!

@kangyuri1114
Copy link
Member

왼쪽 아이콘은 box로 감싸서 터치영역을 넓혔는데, actions으로 받은 오른쪽 친구들의 터치영역을 넓힐 수 있는 방법이 있을까요? 단순하게 요소 간의 간격 띄우는거는 horizontalArrangement = Arrangement.spacedBy(topBarActionsInsidePadding), 로 하였는데, 다시 보니 여기도 왼쪽 아이콘 처럼 터치영역을 넓혀야할 것 같드라구요.. 좋은 아이디어가 있다면 코멘트 부탁드립니다. 감사합니다.

-> 내부 패딩을 넣는 방법은 어떨까요??

@HI-JIN2
Copy link
Member Author

HI-JIN2 commented Jan 14, 2025

왼쪽 아이콘은 box로 감싸서 터치영역을 넓혔는데, actions으로 받은 오른쪽 친구들의 터치영역을 넓힐 수 있는 방법이 있을까요? 단순하게 요소 간의 간격 띄우는거는 horizontalArrangement = Arrangement.spacedBy(topBarActionsInsidePadding), 로 하였는데, 다시 보니 여기도 왼쪽 아이콘 처럼 터치영역을 넓혀야할 것 같드라구요.. 좋은 아이디어가 있다면 코멘트 부탁드립니다. 감사합니다.

-> 내부 패딩을 넣는 방법은 어떨까요??

https://www.notion.so/yourssu/top-bar-6840c966d0a24e47a3120ff7ebfba193?pvs=4
요걸 봐주시면 좋을 것 같은데..

  actions?.let {
            Row(
                verticalAlignment = Alignment.CenterVertically,
                horizontalArrangement = Arrangement.spacedBy(topBarActionsInsidePadding), // 요소 사이에 24dp 간격 추가
                modifier = Modifier.fillMaxHeight()
            ) {
                Spacer(modifier = Modifier.weight(1f))
                actions()
            }
        }
        

actions: @Composable (RowScope.() -> Unit)? = null 이렇게 받아버리면 action의 각 요소에 접근을 못해서 내부 패딩을 줄 수가 없어요. (제가 모르는걸수도 있지만)
그래서 머테리얼이나 스카이스캐너 구현을 봤는데, IconAction, TextAction 이런식으로 별도의 이너 함수를 만들어서 그 형식대로 받더라구요. 이렇게 하면 내부 패딩을 줄 수는 있긴 한데, 호출시 IconAction, TextAction의 존재를 알아야한다는게 저한테는 별로 좋지 않게 느껴져서 ㅠㅠ

@kangyuri1114
Copy link
Member

kangyuri1114 commented Jan 14, 2025

actions: @composable (RowScope.() -> Unit)? = null 이렇게 받아버리면 action의 각 요소에 접근을 못해서 내부 패딩을 줄 수가 없다 -> 그런 것 같네요

다른 디자인시스템처럼 IconAction, TextAction 이런식으로 별도의 이너 함수를 만들어서 그 형식대로 받거나 왼쪽 아이콘처럼 Box로 감싸거나 해야할것같아요
Box로 감싸면 이런식으로..?

actions?.let {
    Row(
        verticalAlignment = Alignment.CenterVertically,
        horizontalArrangement = Arrangement.spacedBy(topBarActionsInsidePadding), // 요소 간 간격
        modifier = Modifier.fillMaxHeight()
    ) {
        Spacer(modifier = Modifier.weight(1f))
        it.forEach { action ->
            Box(
                contentAlignment = Alignment.Center,
                modifier = Modifier
                    .size(48.dp) // 터치 영역 48dp 보장
                    .clickable { action.onClick() } // 각각의 action 클릭 핸들러
            ) {
                action.icon()
            }
        }
    }
}

@HI-JIN2
Copy link
Member Author

HI-JIN2 commented Jan 14, 2025

actions: @composable (RowScope.() -> Unit)? = null 이렇게 받아버리면 action의 각 요소에 접근을 못해서 내부 패딩을 줄 수가 없다 -> 그런 것 같네요

다른 디자인시스템처럼 IconAction, TextAction 이런식으로 별도의 이너 함수를 만들어서 그 형식대로 받거나 왼쪽 아이콘처럼 Box로 감싸거나 해야할것같아요 Box로 감싸면 이런식으로..?

actions?.let {
    Row(
        verticalAlignment = Alignment.CenterVertically,
        horizontalArrangement = Arrangement.spacedBy(topBarActionsInsidePadding), // 요소 간 간격
        modifier = Modifier.fillMaxHeight()
    ) {
        Spacer(modifier = Modifier.weight(1f))
        it.forEach { action ->
            Box(
                contentAlignment = Alignment.Center,
                modifier = Modifier
                    .size(48.dp) // 터치 영역 48dp 보장
                    .clickable { action.onClick() } // 각각의 action 클릭 핸들러
            ) {
                action.icon()
            }
        }
    }
}

it.forEach가 안먹..혀서 ㅜㅜ @Composable (RowScope.() -> Unit)? = null 이렇게 통짜로 받는거 자체가 그 자체로 실행 가능한 컴포저블 코드 블록이라서 안 먹히는 것 같아요. 이너함수 만드는 방법은 피하고 싶었는데... 이렇게 되면 왼쪽 아이콘 버튼도 동일하게 받도록 수정하는게 좋을 것 같군여..

@kangyuri1114 kangyuri1114 merged commit 9ab1a76 into main Jan 19, 2025
@kangyuri1114 kangyuri1114 deleted the feat/hi/top-bar branch January 19, 2025 10:58
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants