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

[init] 폰트, 색상 세팅 + 상단바 구현 #13

Merged
merged 12 commits into from
May 16, 2024
5 changes: 4 additions & 1 deletion .editorconfig
Original file line number Diff line number Diff line change
@@ -1,4 +1,7 @@
root = true

[*]
max_line_length = off
max_line_length = off

[*.{kt,kts}]
ktlint_function_naming_ignore_when_annotated_with=Composable
12 changes: 4 additions & 8 deletions app/build.gradle.kts
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,6 @@ plugins {
alias(libs.plugins.ktlint)
}


val properties =
Properties().apply {
load(project.rootProject.file("local.properties").inputStream())
Expand Down Expand Up @@ -53,7 +52,6 @@ android {
}
composeOptions {
kotlinCompilerExtensionVersion = "1.5.13"
kotlinCompilerVersion = "1.6.10"
}
}

Expand All @@ -62,6 +60,7 @@ dependencies {
implementation(libs.bundles.androidx)

implementation(libs.bundles.compose)
implementation(libs.androidx.foundation.android)

// Compose
debugImplementation(libs.compose.ui.tooling)
Expand All @@ -83,11 +82,8 @@ dependencies {
implementation(libs.bundles.okhttp)
implementation(libs.bundles.retrofit)
implementation(libs.kotlin.serialization.json)

implementation ("androidx.compose.ui:ui:1.6.7")
implementation ("androidx.compose.material:material:1.6.7")
implementation ("androidx.compose.ui:ui-tooling-preview:1.6.7")
androidTestImplementation ("androidx.compose.ui:ui-test-junit4:1.6.7")
}


ktlint {
disabledRules = listOf("standard:function-naming")
}
Copy link
Contributor

Choose a reason for hiding this comment

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

이거 지워줘도 됩니다 ~

Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ class DummyActivity : BindingActivity<ActivityDummyBinding>({ ActivityDummyBindi
super.onCreate(savedInstanceState)

setContent {
View1Screen(dummyViewModel)
View1Screen()
}
}
}
204 changes: 197 additions & 7 deletions app/src/main/java/org/sopt/kream/presentation/ui/dummy/View1Screen.kt
Original file line number Diff line number Diff line change
@@ -1,23 +1,213 @@
package org.sopt.kream.presentation.ui.dummy

import androidx.compose.foundation.ExperimentalFoundationApi
import androidx.compose.foundation.background
import androidx.compose.foundation.layout.Arrangement
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
import androidx.compose.foundation.layout.size
import androidx.compose.foundation.layout.width
import androidx.compose.foundation.pager.HorizontalPager
import androidx.compose.foundation.pager.PagerState
import androidx.compose.foundation.pager.rememberPagerState
import androidx.compose.foundation.shape.RoundedCornerShape
import androidx.compose.foundation.text.BasicTextField
import androidx.compose.material3.HorizontalDivider
import androidx.compose.material3.Icon
import androidx.compose.material3.Scaffold
import androidx.compose.material3.ScrollableTabRow
import androidx.compose.material3.Tab
import androidx.compose.material3.TabRowDefaults
import androidx.compose.material3.TabRowDefaults.tabIndicatorOffset
import androidx.compose.material3.Text
import androidx.compose.runtime.Composable
import androidx.compose.runtime.getValue
import androidx.compose.runtime.mutableStateOf
import androidx.compose.runtime.remember
import androidx.compose.runtime.rememberCoroutineScope
import androidx.compose.runtime.setValue
import androidx.compose.ui.Alignment
import androidx.compose.ui.Modifier
import androidx.compose.ui.graphics.Color
import androidx.compose.ui.res.painterResource
import androidx.compose.ui.res.stringResource
import androidx.compose.ui.tooling.preview.Preview
import androidx.compose.ui.unit.dp
import androidx.compose.ui.unit.times
import kotlinx.coroutines.launch
import org.sopt.kream.R
import org.sopt.kream.theme.Black01
import org.sopt.kream.theme.Black02
import org.sopt.kream.theme.Black09
import org.sopt.kream.theme.Gray06
import org.sopt.kream.theme.body3SemiBold
import org.sopt.kream.theme.body5Regular
import org.sopt.kream.theme.head1Bold

val pages = listOf("추천", "랭킹", "발매정보", "럭셔리", "남성", "여성", "발견")
Copy link
Contributor

Choose a reason for hiding this comment

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

스트링 추출 해주면 좋을 듯 우하하


@OptIn(ExperimentalFoundationApi::class)
@Preview
@Composable
fun View1Screen() {
var editText by remember {
mutableStateOf("")
}
val pagerState =
rememberPagerState {
pages.size
}
Scaffold(
topBar = {
Column(modifier = Modifier.fillMaxWidth()) {
Spacer(modifier = Modifier.height(33.dp))
Row(
modifier = Modifier.fillMaxWidth(),
verticalAlignment = Alignment.CenterVertically,
) {
Spacer(modifier = Modifier.width(14.dp))

BasicTextField(
value = editText,
onValueChange = { editText = it },
singleLine = true,
modifier =
Modifier
.weight(1f)
.size(width = 293.dp, height = 33.dp)
.background(color = Gray06, shape = RoundedCornerShape(9.dp)),
decorationBox = { innerTextField ->
Box(
contentAlignment = Alignment.CenterStart,
modifier = Modifier.padding(start = 7.dp),
) {
innerTextField()
if (editText.isEmpty()) {
Text(
style = body5Regular,
color = Black09,
text = stringResource(id = R.string.bar_search_label),
)
}
}
},
)

Spacer(modifier = Modifier.width(14.dp))
Icon(
painter = painterResource(R.drawable.ic_topappbar_bell_28),
contentDescription = null,
modifier = Modifier.size(28.dp),
)
Spacer(modifier = Modifier.width(11.dp))
}
CustomTabPager(pagerState, pages)
}
},
) { innerPadding ->
View1Content(Modifier.padding(innerPadding))
}
}

@OptIn(ExperimentalFoundationApi::class)
@Composable
fun CustomTabPager(
pagerState: PagerState,
tabs: List<String>,
) {
val coroutineScope = rememberCoroutineScope()
Column {
ScrollableTabRow(
selectedTabIndex = pagerState.currentPage,
indicator = { tabPositions ->
TabRowDefaults.PrimaryIndicator(
modifier =
Modifier
.tabIndicatorOffset(tabPositions[pagerState.currentPage]),
color = Black02,
width = pages[pagerState.currentPage].length * 12.dp,
)
},
containerColor = Color.White,
contentColor = Black02,
edgePadding = 0.dp,
modifier = Modifier.padding(0.dp),
divider = {
HorizontalDivider(
modifier =
Modifier
.fillMaxWidth(),
color = Color.LightGray,
thickness = 1.dp,
)
},
) {
tabs.forEachIndexed { index, title ->
Tab(
text = { Text(title, style = body3SemiBold) },
selected = pagerState.currentPage == index,
onClick = {
coroutineScope.launch {
pagerState.animateScrollToPage(index)
}
},
modifier = Modifier.width(0.dp),
)
}
}

HorizontalPager(
state = pagerState,
) { page ->
Column(
modifier =
Modifier
.fillMaxSize()
.background(Color.White),
verticalArrangement = Arrangement.Center,
horizontalAlignment = Alignment.CenterHorizontally,
) {
when (page) {
0 -> View1Content(modifier = Modifier)
2 -> View2Content(modifier = Modifier)
}
}
}
}
}

@Composable
fun View1Content(modifier: Modifier) {
Column(
modifier = modifier.fillMaxSize(),
horizontalAlignment = Alignment.CenterHorizontally,
verticalArrangement = Arrangement.Center,
) {
Text(
text = "추천",
style = head1Bold,
color = Black01,
)
}
}

@Composable
fun View1Screen(dummyViewModel: DummyViewModel) {
Column (modifier = Modifier.fillMaxSize(),
fun View2Content(modifier: Modifier) {
Column(
modifier = modifier.fillMaxSize(),
horizontalAlignment = Alignment.CenterHorizontally,
verticalArrangement = Arrangement.Center
){
Text(text = "View1 Screen",
verticalArrangement = Arrangement.Center,
) {
Text(
text = "발매정보",
style = head1Bold,
color = Gray06)
color = Black01,
)
}
}
}
8 changes: 0 additions & 8 deletions app/src/main/java/org/sopt/kream/theme/Color.kt
Copy link
Contributor

Choose a reason for hiding this comment

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

쏘굿도링

Original file line number Diff line number Diff line change
Expand Up @@ -2,14 +2,6 @@ package org.sopt.kream.theme

import androidx.compose.ui.graphics.Color

val Purple80 = Color(0xFFD0BCFF)
val PurpleGrey80 = Color(0xFFCCC2DC)
val Pink80 = Color(0xFFEFB8C8)

val Purple40 = Color(0xFF6650a4)
val PurpleGrey40 = Color(0xFF625b71)
val Pink40 = Color(0xFF7D5260)

val White = Color(0xFFFFFFFF)

val Green01 = Color(0xFF02E16A)
Expand Down
14 changes: 8 additions & 6 deletions app/src/main/java/org/sopt/kream/theme/Theme.kt
Original file line number Diff line number Diff line change
Expand Up @@ -17,16 +17,18 @@ import androidx.core.view.WindowCompat

private val DarkColorScheme =
darkColorScheme(
primary = Purple80,
secondary = PurpleGrey80,
tertiary = Pink80,
primary = White,
secondary = White,
tertiary = White,
background = White,
)

private val LightColorScheme =
lightColorScheme(
primary = Purple40,
secondary = PurpleGrey40,
tertiary = Pink40,
primary = White,
secondary = White,
tertiary = White,
background = White,
/* Other default colors to override
background = Color(0xFFFFFBFE),
surface = Color(0xFFFFFBFE),
Expand Down
Loading
Loading