From a36fe1f1648176d39e5eb9590397175d4fa45a23 Mon Sep 17 00:00:00 2001 From: Dongmin Date: Thu, 21 Mar 2024 09:50:41 +0900 Subject: [PATCH 1/5] =?UTF-8?q?[FIX/#252]=20=EC=A0=90=EC=84=A0=20=EA=B0=84?= =?UTF-8?q?=EA=B2=A9=20=EC=88=98=EC=A0=95=20=EB=B0=8F=20=EA=B8=80=EC=9E=90?= =?UTF-8?q?=20=EC=88=98=EC=A0=95?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../shape_line_gray100_fill_dash_5_vertical.xml | 14 ++++++++++---- .../src/main/res/layout/view_chart_textview.xml | 16 ++++++++-------- 2 files changed, 18 insertions(+), 12 deletions(-) diff --git a/presentation/src/main/res/drawable/shape_line_gray100_fill_dash_5_vertical.xml b/presentation/src/main/res/drawable/shape_line_gray100_fill_dash_5_vertical.xml index c69c0986..1ae92cfb 100644 --- a/presentation/src/main/res/drawable/shape_line_gray100_fill_dash_5_vertical.xml +++ b/presentation/src/main/res/drawable/shape_line_gray100_fill_dash_5_vertical.xml @@ -1,5 +1,11 @@ - + + + + + \ No newline at end of file diff --git a/presentation/src/main/res/layout/view_chart_textview.xml b/presentation/src/main/res/layout/view_chart_textview.xml index 459a578f..a405dbaa 100644 --- a/presentation/src/main/res/layout/view_chart_textview.xml +++ b/presentation/src/main/res/layout/view_chart_textview.xml @@ -15,20 +15,21 @@ android:layout_height="wrap_content" android:gravity="center" app:layout_constraintBottom_toBottomOf="parent" - app:layout_constraintEnd_toStartOf="@id/linear_layout_chart_description" - app:layout_constraintHorizontal_weight="2" + app:layout_constraintEnd_toStartOf="@id/img_chart_dash_vertical" + app:layout_constraintHorizontal_weight="2.6" app:layout_constraintStart_toStartOf="parent" app:layout_constraintTop_toTopOf="parent" /> @@ -36,12 +37,11 @@ android:id="@+id/linear_layout_chart_description" android:layout_width="0dp" android:layout_height="match_parent" - android:layout_marginStart="26dp" android:orientation="vertical" app:layout_constraintBottom_toBottomOf="parent" app:layout_constraintEnd_toEndOf="parent" - app:layout_constraintHorizontal_weight="7" - app:layout_constraintStart_toEndOf="@id/tv_chart_title" + app:layout_constraintHorizontal_weight="6.8" + app:layout_constraintStart_toEndOf="@id/img_chart_dash_vertical" app:layout_constraintTop_toTopOf="parent"> Date: Thu, 21 Mar 2024 10:23:37 +0900 Subject: [PATCH 2/5] =?UTF-8?q?[FIX/#262]=20=EA=B8=80=EC=9E=90=20=EA=B2=B9?= =?UTF-8?q?=EC=B9=A8=20=ED=95=B4=EA=B2=B0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../profile/edit/ProfileEditViewModel.kt | 13 +++++++------ .../src/main/res/layout/activity_profile.xml | 5 +++-- 2 files changed, 10 insertions(+), 8 deletions(-) diff --git a/presentation/src/main/java/com/going/presentation/profile/edit/ProfileEditViewModel.kt b/presentation/src/main/java/com/going/presentation/profile/edit/ProfileEditViewModel.kt index 5735bff2..a7a9cb97 100644 --- a/presentation/src/main/java/com/going/presentation/profile/edit/ProfileEditViewModel.kt +++ b/presentation/src/main/java/com/going/presentation/profile/edit/ProfileEditViewModel.kt @@ -4,6 +4,7 @@ import androidx.lifecycle.ViewModel import androidx.lifecycle.viewModelScope import com.going.domain.entity.request.UserProfileRequestModel import com.going.domain.repository.ProfileRepository +import com.going.presentation.designsystem.edittext.EditTextState import com.going.presentation.onboarding.signup.SignUpViewModel import dagger.hilt.android.lifecycle.HiltViewModel import kotlinx.coroutines.flow.MutableSharedFlow @@ -40,23 +41,23 @@ class ProfileEditViewModel @Inject constructor( defaultInfo = info } - fun checkIsNameChanged(name: String) { + fun checkIsNameChanged(name: String, nameState: EditTextState, infoState: EditTextState) { nowName = name isNameChanged = name != defaultName - checkIsValueChanged() + checkIsValueChanged(nameState, infoState) } - fun checkIsInfoChanged(info: String) { + fun checkIsInfoChanged(info: String, nameState: EditTextState, infoState: EditTextState) { nowInfo = info isInfoChanged = info != defaultInfo - checkIsValueChanged() + checkIsValueChanged(nameState, infoState) } - private fun checkIsValueChanged() { + private fun checkIsValueChanged(nameState: EditTextState, infoState: EditTextState) { _isValueChanged.value = - nowName.isNotBlank() && nowName.length <= getMaxNameLen() && nowInfo.isNotBlank() && nowInfo.length <= getMaxInfoLen() && (isInfoChanged || isNameChanged) + nowName.isNotBlank() && nameState == EditTextState.SUCCESS && nowInfo.isNotBlank() && infoState == EditTextState.SUCCESS && (isInfoChanged || isNameChanged) } fun patchUserInfo() { diff --git a/presentation/src/main/res/layout/activity_profile.xml b/presentation/src/main/res/layout/activity_profile.xml index db7a617d..4ae1208d 100644 --- a/presentation/src/main/res/layout/activity_profile.xml +++ b/presentation/src/main/res/layout/activity_profile.xml @@ -106,11 +106,12 @@ From 6771b257f4890ba8627d4837c14f1dd8b97457ab Mon Sep 17 00:00:00 2001 From: Dongmin Date: Thu, 21 Mar 2024 10:23:48 +0900 Subject: [PATCH 3/5] =?UTF-8?q?[FIX/#262]=20=EC=9D=B4=EB=AA=A8=EC=A7=80=20?= =?UTF-8?q?=EA=B8=80=EC=9E=90=EC=88=98=20=ED=8C=90=EC=A0=95=20=EC=98=A4?= =?UTF-8?q?=EB=A5=98=20=ED=95=B4=EA=B2=B0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../going/presentation/profile/edit/ProfileEditActivity.kt | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/presentation/src/main/java/com/going/presentation/profile/edit/ProfileEditActivity.kt b/presentation/src/main/java/com/going/presentation/profile/edit/ProfileEditActivity.kt index d1422875..17336779 100644 --- a/presentation/src/main/java/com/going/presentation/profile/edit/ProfileEditActivity.kt +++ b/presentation/src/main/java/com/going/presentation/profile/edit/ProfileEditActivity.kt @@ -53,13 +53,13 @@ class ProfileEditActivity : private fun observeNameTextChanged() { binding.etProfileEditNickname.editText.doAfterTextChanged { name -> - viewModel.checkIsNameChanged(name.toString()) + viewModel.checkIsNameChanged(name.toString(), binding.etProfileEditNickname.state, binding.etProfileEditInfo.state) } } private fun observeInfoTextChanged() { binding.etProfileEditInfo.editText.doAfterTextChanged { info -> - viewModel.checkIsInfoChanged(info.toString()) + viewModel.checkIsInfoChanged(info.toString(), binding.etProfileEditNickname.state, binding.etProfileEditInfo.state) } } From a369d327ce6c1915de83c48bad10dc227fdada7d Mon Sep 17 00:00:00 2001 From: Dongmin Date: Thu, 21 Mar 2024 10:47:50 +0900 Subject: [PATCH 4/5] =?UTF-8?q?[FIX/#262]=20=EC=97=94=ED=84=B0=20=EB=B0=A9?= =?UTF-8?q?=EC=A7=80=EB=A5=BC=20=EC=9C=84=ED=95=9C=20=EC=83=88=20=EC=BB=B4?= =?UTF-8?q?=ED=8F=AC=EB=84=8C=ED=8A=B8=20=EC=83=9D=EC=84=B1=20=EB=B0=8F=20?= =?UTF-8?q?=EC=A0=81=EC=9A=A9?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../edittext/EmojiCounterEditText.kt | 1 + .../edittext/EmojiCounterEditTextMultiLine.kt | 152 ++++++++++++++++++ .../main/res/layout/activity_todo_change.xml | 2 +- .../main/res/layout/activity_todo_create.xml | 2 +- .../layout/view_emoji_counter_edittext.xml | 2 +- .../view_emoji_counter_edittext_multiline.xml | 71 ++++++++ 6 files changed, 227 insertions(+), 3 deletions(-) create mode 100644 presentation/src/main/java/com/going/presentation/designsystem/edittext/EmojiCounterEditTextMultiLine.kt create mode 100644 presentation/src/main/res/layout/view_emoji_counter_edittext_multiline.xml diff --git a/presentation/src/main/java/com/going/presentation/designsystem/edittext/EmojiCounterEditText.kt b/presentation/src/main/java/com/going/presentation/designsystem/edittext/EmojiCounterEditText.kt index 2ed5a129..4dd8d26a 100644 --- a/presentation/src/main/java/com/going/presentation/designsystem/edittext/EmojiCounterEditText.kt +++ b/presentation/src/main/java/com/going/presentation/designsystem/edittext/EmojiCounterEditText.kt @@ -2,6 +2,7 @@ package com.going.presentation.designsystem.edittext import android.content.Context import android.content.res.TypedArray +import android.text.InputType import android.text.method.ScrollingMovementMethod import android.util.AttributeSet import android.view.LayoutInflater diff --git a/presentation/src/main/java/com/going/presentation/designsystem/edittext/EmojiCounterEditTextMultiLine.kt b/presentation/src/main/java/com/going/presentation/designsystem/edittext/EmojiCounterEditTextMultiLine.kt new file mode 100644 index 00000000..25166983 --- /dev/null +++ b/presentation/src/main/java/com/going/presentation/designsystem/edittext/EmojiCounterEditTextMultiLine.kt @@ -0,0 +1,152 @@ +package com.going.presentation.designsystem.edittext + +import android.content.Context +import android.content.res.TypedArray +import android.text.method.ScrollingMovementMethod +import android.util.AttributeSet +import android.view.LayoutInflater +import android.view.View.OnFocusChangeListener +import androidx.constraintlayout.widget.ConstraintLayout +import androidx.core.content.res.ResourcesCompat +import androidx.core.view.isVisible +import androidx.core.widget.doAfterTextChanged +import com.going.presentation.R +import com.going.presentation.databinding.ViewEmojiCounterEdittextMultilineBinding +import com.going.ui.extension.colorOf +import com.going.ui.extension.getGraphemeLength +import com.going.ui.extension.setOnSingleClickListener + +class EmojiCounterEditTextMultiLine(context: Context, attrs: AttributeSet) : + ConstraintLayout(context, attrs) { + + private val binding: ViewEmojiCounterEdittextMultilineBinding + + private var maxLen: Int = 0 + private var canBlankError: Boolean = false + lateinit var overWarning: String + var blankWarning: String = "" + + private val editTextStateMap by lazy { + mapOf( + EditTextState.SUCCESS to Triple( + R.color.gray_700, + R.drawable.shape_rect_4_gray700_line, + "" + ), + EditTextState.EMPTY to Triple( + R.color.gray_200, + R.drawable.shape_rect_4_gray200_line, + "" + ), + EditTextState.BLANK to Triple( + R.color.red_500, + R.drawable.shape_rect_4_red500_line, + blankWarning + ), + EditTextState.OVER to Triple( + R.color.red_500, + R.drawable.shape_rect_4_red500_line, + overWarning + ), + ) + } + + val editText + get() = binding.etEmojiCounterEtContent + + var state: EditTextState = EditTextState.EMPTY + set(value) { + field = value + + binding.run { + btnDeleteText.isVisible = + (value != EditTextState.EMPTY) && etEmojiCounterEtContent.hasFocus() + } + + editTextStateMap[field]?.let { setEditTextState(it) } + } + + init { + val typedArray = context.obtainStyledAttributes(attrs, R.styleable.EmojiCounterEditText) + binding = ViewEmojiCounterEdittextMultilineBinding.inflate( + LayoutInflater.from(context), + this, + true, + ) + + initDeleteBtnClickListener() + setBindingContent(typedArray) + initEtFocusChangeListener() + + typedArray.recycle() + + checkTextAvailable() + } + + private fun initDeleteBtnClickListener() = with(binding) { + btnDeleteText.setOnSingleClickListener { + etEmojiCounterEtContent.text = null + } + } + + private fun setBindingContent(typedArray: TypedArray) { + with(binding) { + tvEmojiCounterEtTitle.text = + typedArray.getString(R.styleable.EmojiCounterEditText_title) + etEmojiCounterEtContent.hint = + typedArray.getString(R.styleable.EmojiCounterEditText_hint) + etEmojiCounterEtContent.minLines = + typedArray.getInt(R.styleable.EmojiCounterEditText_minLines, 1) + etEmojiCounterEtContent.maxLines = + typedArray.getInt(R.styleable.EmojiCounterEditText_minLines, 2) + etEmojiCounterEtContent.movementMethod = ScrollingMovementMethod() + tvEmojiCounterEtNameCounter.text = context.getString(R.string.counter, 0, maxLen) + } + canBlankError = typedArray.getBoolean(R.styleable.EmojiCounterEditText_canBlankError, false) + } + + private fun initEtFocusChangeListener() { + binding.etEmojiCounterEtContent.onFocusChangeListener = + OnFocusChangeListener { _, hasFocus -> + binding.btnDeleteText.isVisible = hasFocus && (state != EditTextState.EMPTY) + } + } + + private fun checkTextAvailable() { + binding.etEmojiCounterEtContent.doAfterTextChanged { text -> + val len = text.toString().getGraphemeLength() + + state = when { + text.toString().isBlank() && len != 0 && canBlankError -> EditTextState.BLANK + len > maxLen -> EditTextState.OVER + len > 0 -> EditTextState.SUCCESS + else -> EditTextState.EMPTY + } + + binding.tvEmojiCounterEtNameCounter.text = + context.getString(R.string.counter, len, maxLen) + } + } + + fun setMaxLen(len: Int) { + maxLen = len + binding.tvEmojiCounterEtNameCounter.text = context.getString(R.string.counter, 0, maxLen) + } + + private fun setEditTextState(info: Triple) { + val color = info.first + val background = info.second + val text = info.third + + with(binding) { + tvEmojiCounterEtWarningMessage.isVisible = color == R.color.red_500 + tvEmojiCounterEtNameCounter.setTextColor(context.colorOf(color)) + etEmojiCounterEtContent.background = ResourcesCompat.getDrawable( + this@EmojiCounterEditTextMultiLine.resources, + background, + context.theme, + ) + tvEmojiCounterEtWarningMessage.text = text + } + } +} diff --git a/presentation/src/main/res/layout/activity_todo_change.xml b/presentation/src/main/res/layout/activity_todo_change.xml index c671d460..1453cb20 100644 --- a/presentation/src/main/res/layout/activity_todo_change.xml +++ b/presentation/src/main/res/layout/activity_todo_change.xml @@ -229,7 +229,7 @@ - - + + + + + + + + + + + + + From 3ae7ad0943423df90d2f78982ba8b378fd66cca6 Mon Sep 17 00:00:00 2001 From: Dongmin Date: Thu, 21 Mar 2024 14:52:41 +0900 Subject: [PATCH 5/5] =?UTF-8?q?[FIX/#262]=20=EC=84=B1=ED=96=A5=20=EA=B2=80?= =?UTF-8?q?=EC=82=AC=20=EC=99=84=EB=A3=8C=EC=8B=9C=20=ED=9D=B0=EC=83=89=20?= =?UTF-8?q?=EC=97=AC=EB=B0=B1=20=EC=83=9D=EA=B8=B0=EB=8A=94=20=ED=98=84?= =?UTF-8?q?=EC=83=81=20=ED=95=B4=EA=B2=B0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../profile/participant/ParticipantProfileActivity.kt | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/presentation/src/main/java/com/going/presentation/profile/participant/ParticipantProfileActivity.kt b/presentation/src/main/java/com/going/presentation/profile/participant/ParticipantProfileActivity.kt index 9c10e4ba..ff889a19 100644 --- a/presentation/src/main/java/com/going/presentation/profile/participant/ParticipantProfileActivity.kt +++ b/presentation/src/main/java/com/going/presentation/profile/participant/ParticipantProfileActivity.kt @@ -88,6 +88,8 @@ class ParticipantProfileActivity : } } + setFragmentHeight(profile.result == -1) + tvProfileName.text = profile.name tvProfileOneLine.text = profile.intro @@ -149,7 +151,7 @@ class ParticipantProfileActivity : setFragmentHeight() } - private fun setFragmentHeight(temp: Boolean = true) { + private fun setFragmentHeight(isEmpty: Boolean = true) { val displayHeight = getWindowHeight() val toolbarHeight = binding.tbTripProfile.height val appBarHeight = binding.appbarTripProfile.totalScrollRange @@ -157,7 +159,7 @@ class ParticipantProfileActivity : binding.vpTripProfile.layoutParams = binding.vpTripProfile.layoutParams.also { it.height = - if (temp) displayHeight - toolbarHeight - appBarHeight - tabHeight else displayHeight - toolbarHeight - tabHeight + if (isEmpty) displayHeight - toolbarHeight - appBarHeight - tabHeight else displayHeight - toolbarHeight - tabHeight } }