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

๐Ÿ”— :: (#24) ๋น„๋ฐ€๋ฒˆํ˜ธ ์„ค์ • ์Šคํฌ๋ฆฐ ํผ๋ธ”๋ฆฌ์‹ฑ #27

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
Original file line number Diff line number Diff line change
Expand Up @@ -8,10 +8,11 @@ import team.retum.landing.landing
import team.retum.signin.navigateToSignIn
import team.retum.signin.signIn
import team.retum.signup.navigation.navigateToInputEmail
import team.retum.signup.navigation.navigateToInputPersonalInfo
import team.retum.signup.navigation.navigateToSettingPassword
import team.retum.signup.navigation.navigateToSignUp
import team.retum.signup.navigation.signUp


Tmdhoon2 marked this conversation as resolved.
Show resolved Hide resolved
const val NAVIGATION_AUTH = "auth"

internal fun NavGraphBuilder.authNavigation(navController: NavController) {
Expand All @@ -26,7 +27,8 @@ internal fun NavGraphBuilder.authNavigation(navController: NavController) {
signIn(onBackClick = navController::popBackStack)
signUp(
onBackClick = navController::popBackStack,
onNextClick = navController::navigateToInputEmail,
onInputEmailClick = navController::navigateToInputEmail,
onInputPasswordClick = navController::navigateToSettingPassword,
)
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -9,9 +9,13 @@ const val NAVIGATION_SIGN_UP_INPUT_EMAIL = "signUp/inputEmail"

fun NavGraphBuilder.inputEmail(
onBackClick: () -> Unit,
onNextClick: () -> Unit,
) {
composable(route = NAVIGATION_SIGN_UP_INPUT_EMAIL) {
InputEmailScreen(onBackClick = onBackClick)
InputEmailScreen(
onNextClick = onNextClick,
onBackClick = onBackClick,
)
}
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -21,4 +21,4 @@ fun NavGraphBuilder.inputPersonalInformation(

fun NavController.navigateToInputPersonalInfo() {
navigate(NAVIGATION_SIGN_UP_INPUT_PERSONAL_INFO)
}
}
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
package team.retum.signup.navigation

import androidx.navigation.NavController
import androidx.navigation.NavGraphBuilder
import androidx.navigation.compose.composable
import team.retum.signup.ui.SettingPasswordScreen

const val NAVIGATION_SIGN_UP_SETTING_PASSWORD = "signUp/settingPassword"

fun NavGraphBuilder.settingPassword(
onBackClick: () -> Unit,
) {
composable(route = NAVIGATION_SIGN_UP_SETTING_PASSWORD) {
SettingPasswordScreen(
onBackClick = onBackClick,
)
}
}

fun NavController.navigateToSettingPassword(){
navigate(NAVIGATION_SIGN_UP_SETTING_PASSWORD)
}
Original file line number Diff line number Diff line change
Expand Up @@ -8,17 +8,24 @@ const val NAVIGATION_SIGN_UP = "signUp"

fun NavGraphBuilder.signUp(
onBackClick: () -> Unit,
onNextClick: () -> Unit,
onInputEmailClick: () -> Unit,
onInputPasswordClick: () -> Unit,
) {
navigation(
route = NAVIGATION_SIGN_UP,
startDestination = NAVIGATION_SIGN_UP_INPUT_PERSONAL_INFO,
) {
inputPersonalInformation(
onBackClick = onBackClick,
onNextClick = onNextClick,
onNextClick = onInputEmailClick,
)
inputEmail(
onNextClick = onInputPasswordClick,
onBackClick = onBackClick,
)
settingPassword(
onBackClick = onBackClick,
)
inputEmail(onBackClick = onBackClick)
}
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,9 @@ import androidx.compose.ui.Alignment
import androidx.compose.ui.Modifier
import androidx.compose.ui.res.stringResource
import androidx.compose.ui.unit.dp
import androidx.navigation.NavController
import team.retum.signup.R
import team.retum.signup.navigation.NAVIGATION_SIGN_UP_SETTING_PASSWORD
import team.returm.jobisdesignsystemv2.appbar.JobisLargeTopAppBar
import team.returm.jobisdesignsystemv2.button.ButtonColor
import team.returm.jobisdesignsystemv2.button.JobisButton
Expand All @@ -27,6 +29,7 @@ import team.returm.jobisdesignsystemv2.textfield.JobisTextField
@Composable
internal fun InputEmailScreen(
onBackClick: () -> Unit,
onNextClick: () -> Unit,
) {
// TODO: viewModel๋กœ ์˜ฎ๊ธฐ๊ธฐ
var email by remember { mutableStateOf("") }
Expand All @@ -53,7 +56,7 @@ internal fun InputEmailScreen(
modifier = Modifier.padding(bottom = 24.dp),
text = stringResource(id = R.string.next),
color = ButtonColor.Primary,
onClick = {},
onClick = onNextClick,
)
}
}
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,81 @@
package team.retum.signup.ui

import androidx.compose.foundation.background
import androidx.compose.foundation.layout.Column
import androidx.compose.foundation.layout.Spacer
import androidx.compose.foundation.layout.fillMaxSize
import androidx.compose.foundation.layout.padding
import androidx.compose.runtime.Composable
import androidx.compose.runtime.getValue
import androidx.compose.runtime.mutableStateOf
import androidx.compose.runtime.remember
import androidx.compose.runtime.setValue
import androidx.compose.ui.Alignment
import androidx.compose.ui.Modifier
import androidx.compose.ui.res.stringResource
import androidx.compose.ui.unit.dp
import team.retum.signup.R
import team.returm.jobisdesignsystemv2.appbar.JobisLargeTopAppBar
import team.returm.jobisdesignsystemv2.button.ButtonColor
import team.returm.jobisdesignsystemv2.button.JobisButton
import team.returm.jobisdesignsystemv2.foundation.JobisTheme
import team.returm.jobisdesignsystemv2.textfield.DescriptionType
import team.returm.jobisdesignsystemv2.textfield.JobisTextField

@Composable
fun SettingPasswordScreen(
onBackClick: () -> Unit,
) {
// TODO: viewModel๋กœ ์˜ฎ๊ธฐ๊ธฐ
var password by remember { mutableStateOf("") }
var checkPassword by remember { mutableStateOf("") }
Tmdhoon2 marked this conversation as resolved.
Show resolved Hide resolved
Column(
modifier = Modifier
.fillMaxSize()
.background(JobisTheme.colors.background)
.padding(horizontal = 24.dp),
horizontalAlignment = Alignment.CenterHorizontally,
) {
JobisLargeTopAppBar(
title = stringResource(id = R.string.setting_password),
onBackPressed = onBackClick,
)
PasswordInputs(
password = { password },
checkPassword = { checkPassword },
onPasswordChange = { password = it },
onCheckPassword = { checkPassword = it },
)
Spacer(modifier = Modifier.weight(1f))
JobisButton(
modifier = Modifier.padding(vertical = 12.dp),
text = stringResource(id = R.string.next),
color = ButtonColor.Primary,
onClick = { },
)
}
}

@Composable
fun PasswordInputs(
password: () -> String,
checkPassword: () -> String,
onPasswordChange: (String) -> Unit,
onCheckPassword: (String) -> Unit,
) {
JobisTextField(
title = stringResource(id = R.string.password),
value = password,
onValueChange = onPasswordChange,
hint = stringResource(id = R.string.hint_password),
showDescription = {true},
informationDescription = "8 ~ 16์ž, ์˜๋ฌธ์ž, ์ˆซ์ž, ํŠน์ˆ˜๋ฌธ์ž ํฌํ•จ",
descriptionType = DescriptionType.Information
Tmdhoon2 marked this conversation as resolved.
Show resolved Hide resolved
)
JobisTextField(
title = stringResource(id = R.string.check_password),
value = checkPassword,
onValueChange = onCheckPassword,
hint = stringResource(id = R.string.hint_check_password),
)
}
5 changes: 5 additions & 0 deletions feature/signup/src/main/res/values/strings.xml
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@

<string name="input_personal_information">๊ฐœ์ธ์ •๋ณด๋ฅผ ์ž…๋ ฅํ•ด์ฃผ์„ธ์š”</string>
<string name="input_email">์ด๋ฉ”์ผ์„ ์ž…๋ ฅํ•ด์ฃผ์„ธ์š”</string>
<string name="setting_password">๋น„๋ฐ€๋ฒˆํ˜ธ๋ฅผ ์„ค์ •ํ•ด์ฃผ์„ธ์š”</string>
<string name="name">์ด๋ฆ„</string>
<string name="hint_name">ํ™๊ธธ๋™</string>
<string name="student_number">ํ•™๋ฒˆ</string>
Expand All @@ -12,4 +13,8 @@
<string name="hint_email">example</string>
<string name="authentication_code">์ธ์ฆ์ฝ”๋“œ</string>
<string name="hint_authentication_code">์ด๋ฉ”์ผ๋กœ ์˜จ ์ฝ”๋“œ๋ฅผ ์ž…๋ ฅํ•ด์ฃผ์„ธ์š”</string>
<string name="password">๋น„๋ฐ€๋ฒˆํ˜ธ</string>
<string name="hint_password">๊ณ„์ •์˜ ๋น„๋ฐ€๋ฒˆํ˜ธ๋ฅผ ์„ค์ •ํ•ด์ฃผ์„ธ์š”.</string>
<string name="check_password">๋น„๋ฐ€๋ฒˆํ˜ธ ํ™•์ธ</string>
<string name="hint_check_password">์œ„ ๋น„๋ฐ€๋ฒˆํ˜ธ๋ฅผ ํ•œ ๋ฒˆ ๋” ์ž…๋ ฅํ•ด์ฃผ์„ธ์š”.</string>
</resources>
Loading