@momo-kits/native-kits 0.161.1-beta.15-debug → 0.161.2-beta.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (139) hide show
  1. package/ios/Application/ApplicationEnvironment.swift +2 -6
  2. package/ios/Input/Input.swift +50 -21
  3. package/ios/Input/InputPhoneNumber.swift +17 -17
  4. package/ios/StatusBarTap/StatusBarTap.h +13 -0
  5. package/ios/StatusBarTap/StatusBarTap.m +75 -0
  6. package/ios/Typography/Text.swift +19 -14
  7. package/ios/Typography/Typography.swift +22 -1
  8. package/ios/native-kits.podspec +2 -1
  9. package/package.json +1 -1
  10. package/build.gradle.kts +0 -11
  11. package/compose/build.gradle.kts +0 -180
  12. package/compose/build.gradle.kts.backup +0 -180
  13. package/compose/compose.podspec +0 -47
  14. package/compose/src/androidMain/kotlin/vn/momo/kits/platform/Platform.android.kt +0 -116
  15. package/compose/src/commonMain/composeResources/font/momosignature.otf +0 -0
  16. package/compose/src/commonMain/composeResources/font/momotrustdisplay.otf +0 -0
  17. package/compose/src/commonMain/composeResources/font/sfprotext_black.otf +0 -0
  18. package/compose/src/commonMain/composeResources/font/sfprotext_black.ttf +0 -0
  19. package/compose/src/commonMain/composeResources/font/sfprotext_bold.ttf +0 -0
  20. package/compose/src/commonMain/composeResources/font/sfprotext_heavy.ttf +0 -0
  21. package/compose/src/commonMain/composeResources/font/sfprotext_light.ttf +0 -0
  22. package/compose/src/commonMain/composeResources/font/sfprotext_medium.ttf +0 -0
  23. package/compose/src/commonMain/composeResources/font/sfprotext_regular.ttf +0 -0
  24. package/compose/src/commonMain/composeResources/font/sfprotext_semibold.ttf +0 -0
  25. package/compose/src/commonMain/composeResources/font/sfprotext_thin.otf +0 -0
  26. package/compose/src/commonMain/composeResources/font/sfprotext_thin.ttf +0 -0
  27. package/compose/src/commonMain/composeResources/font/sfprotext_ultralight.otf +0 -0
  28. package/compose/src/commonMain/composeResources/font/sfprotext_ultralight.ttf +0 -0
  29. package/compose/src/commonMain/kotlin/vn/momo/kits/application/AnimationSearchInput.kt +0 -57
  30. package/compose/src/commonMain/kotlin/vn/momo/kits/application/Context.kt +0 -115
  31. package/compose/src/commonMain/kotlin/vn/momo/kits/application/FloatingButton.kt +0 -201
  32. package/compose/src/commonMain/kotlin/vn/momo/kits/application/Header.kt +0 -222
  33. package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderAnimated.kt +0 -48
  34. package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderBackground.kt +0 -86
  35. package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderDefault.kt +0 -76
  36. package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderExtended.kt +0 -76
  37. package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderRight.kt +0 -305
  38. package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderTitle.kt +0 -33
  39. package/compose/src/commonMain/kotlin/vn/momo/kits/application/LiteScreen.kt +0 -720
  40. package/compose/src/commonMain/kotlin/vn/momo/kits/application/NavigationContainer.kt +0 -121
  41. package/compose/src/commonMain/kotlin/vn/momo/kits/application/Screen.kt +0 -402
  42. package/compose/src/commonMain/kotlin/vn/momo/kits/application/useHeaderSearchAnimation.kt +0 -69
  43. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Avatar.kt +0 -157
  44. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Badge.kt +0 -85
  45. package/compose/src/commonMain/kotlin/vn/momo/kits/components/BadgeDot.kt +0 -32
  46. package/compose/src/commonMain/kotlin/vn/momo/kits/components/BadgeRibbon.kt +0 -340
  47. package/compose/src/commonMain/kotlin/vn/momo/kits/components/BaselineView.kt +0 -194
  48. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Button.kt +0 -357
  49. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Carousel.kt +0 -123
  50. package/compose/src/commonMain/kotlin/vn/momo/kits/components/CheckBox.kt +0 -94
  51. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Chip.kt +0 -136
  52. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Collapse.kt +0 -224
  53. package/compose/src/commonMain/kotlin/vn/momo/kits/components/CupertinoOverscroll.kt +0 -543
  54. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Divider.kt +0 -23
  55. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Icon.kt +0 -76
  56. package/compose/src/commonMain/kotlin/vn/momo/kits/components/IconButton.kt +0 -148
  57. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Image.kt +0 -188
  58. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Information.kt +0 -116
  59. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Input.kt +0 -448
  60. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputDropDown.kt +0 -172
  61. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputMoney.kt +0 -255
  62. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputOTP.kt +0 -231
  63. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputPhoneNumber.kt +0 -233
  64. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputSearch.kt +0 -254
  65. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputTextArea.kt +0 -241
  66. package/compose/src/commonMain/kotlin/vn/momo/kits/components/LazyColumnWithBouncing.kt +0 -364
  67. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Loader.kt +0 -108
  68. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PaginationDot.kt +0 -56
  69. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PaginationNumber.kt +0 -41
  70. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PaginationScroll.kt +0 -92
  71. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PaginationWhiteDot.kt +0 -40
  72. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PopupNotify.kt +0 -352
  73. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PopupPromotion.kt +0 -103
  74. package/compose/src/commonMain/kotlin/vn/momo/kits/components/ProgressInfo.kt +0 -338
  75. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Radio.kt +0 -70
  76. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Rating.kt +0 -87
  77. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Skeleton.kt +0 -96
  78. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Slider.kt +0 -348
  79. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Stepper.kt +0 -256
  80. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Steps.kt +0 -494
  81. package/compose/src/commonMain/kotlin/vn/momo/kits/components/SuggestAction.kt +0 -131
  82. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Swipe.kt +0 -215
  83. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Switch.kt +0 -96
  84. package/compose/src/commonMain/kotlin/vn/momo/kits/components/TabView.kt +0 -531
  85. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Tag.kt +0 -92
  86. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Text.kt +0 -130
  87. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Title.kt +0 -214
  88. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Tooltip.kt +0 -590
  89. package/compose/src/commonMain/kotlin/vn/momo/kits/components/TrustBanner.kt +0 -177
  90. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Uploader.kt +0 -192
  91. package/compose/src/commonMain/kotlin/vn/momo/kits/components/datetimepicker/DateTimePicker.kt +0 -205
  92. package/compose/src/commonMain/kotlin/vn/momo/kits/components/datetimepicker/DateTimePickerTypes.kt +0 -29
  93. package/compose/src/commonMain/kotlin/vn/momo/kits/components/datetimepicker/DateTimePickerUtils.kt +0 -239
  94. package/compose/src/commonMain/kotlin/vn/momo/kits/components/datetimepicker/WheelPicker.kt +0 -191
  95. package/compose/src/commonMain/kotlin/vn/momo/kits/const/Colors.kt +0 -306
  96. package/compose/src/commonMain/kotlin/vn/momo/kits/const/Radius.kt +0 -12
  97. package/compose/src/commonMain/kotlin/vn/momo/kits/const/Spacing.kt +0 -16
  98. package/compose/src/commonMain/kotlin/vn/momo/kits/const/Theme.kt +0 -188
  99. package/compose/src/commonMain/kotlin/vn/momo/kits/const/Typography.kt +0 -270
  100. package/compose/src/commonMain/kotlin/vn/momo/kits/layout/Card.kt +0 -2
  101. package/compose/src/commonMain/kotlin/vn/momo/kits/layout/Item.kt +0 -35
  102. package/compose/src/commonMain/kotlin/vn/momo/kits/layout/Section.kt +0 -2
  103. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/AutomationId.kt +0 -57
  104. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/Clickable.kt +0 -68
  105. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/Conditional.kt +0 -11
  106. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/DeprecatedModifier.kt +0 -14
  107. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/Shadow.kt +0 -50
  108. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/Size.kt +0 -51
  109. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/BottomSheet.kt +0 -253
  110. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/ModalScreen.kt +0 -133
  111. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/Navigation.kt +0 -99
  112. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/NavigationContainer.kt +0 -168
  113. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/Navigator.kt +0 -333
  114. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/StackScreen.kt +0 -552
  115. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/bottomtab/BottomTab.kt +0 -161
  116. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/bottomtab/BottomTabBar.kt +0 -243
  117. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/bottomtab/CurvedContainer.kt +0 -86
  118. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/FloatingButton.kt +0 -187
  119. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/Header.kt +0 -279
  120. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/HeaderBackground.kt +0 -80
  121. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/HeaderRight.kt +0 -306
  122. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/HeaderTitle.kt +0 -32
  123. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/HeaderUser.kt +0 -370
  124. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/SnackBar.kt +0 -131
  125. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/tracking/ScreenTracker.kt +0 -167
  126. package/compose/src/commonMain/kotlin/vn/momo/kits/platform/Platform.kt +0 -45
  127. package/compose/src/commonMain/kotlin/vn/momo/kits/utils/Icons.kt +0 -1329
  128. package/compose/src/commonMain/kotlin/vn/momo/kits/utils/Resources.kt +0 -62
  129. package/compose/src/commonMain/kotlin/vn/momo/kits/utils/Tracking.kt +0 -15
  130. package/compose/src/commonMain/kotlin/vn/momo/kits/utils/Utils.kt +0 -105
  131. package/compose/src/iosMain/kotlin/vn/momo/kits/platform/Platform.ios.kt +0 -176
  132. package/gradle/libs.versions.toml +0 -58
  133. package/gradle/wrapper/gradle-wrapper.jar +0 -0
  134. package/gradle/wrapper/gradle-wrapper.properties +0 -8
  135. package/gradle.properties +0 -26
  136. package/gradlew +0 -252
  137. package/gradlew.bat +0 -94
  138. package/local.properties +0 -8
  139. package/settings.gradle.kts +0 -52
@@ -1,448 +0,0 @@
1
- package vn.momo.kits.components
2
-
3
- import androidx.compose.foundation.background
4
- import androidx.compose.foundation.border
5
- import androidx.compose.foundation.clickable
6
- import androidx.compose.foundation.interaction.MutableInteractionSource
7
- import androidx.compose.foundation.layout.Box
8
- import androidx.compose.foundation.layout.Column
9
- import androidx.compose.foundation.layout.Row
10
- import androidx.compose.foundation.layout.Spacer
11
- import androidx.compose.foundation.layout.fillMaxWidth
12
- import androidx.compose.foundation.layout.height
13
- import androidx.compose.foundation.layout.offset
14
- import androidx.compose.foundation.layout.padding
15
- import androidx.compose.foundation.layout.size
16
- import androidx.compose.foundation.layout.wrapContentSize
17
- import androidx.compose.foundation.shape.RoundedCornerShape
18
- import androidx.compose.foundation.text.BasicTextField
19
- import androidx.compose.foundation.text.KeyboardOptions
20
- import androidx.compose.material3.CircularProgressIndicator
21
- import androidx.compose.runtime.Composable
22
- import androidx.compose.runtime.MutableState
23
- import androidx.compose.runtime.getValue
24
- import androidx.compose.runtime.mutableStateOf
25
- import androidx.compose.runtime.remember
26
- import androidx.compose.runtime.setValue
27
- import androidx.compose.ui.Alignment
28
- import androidx.compose.ui.Modifier
29
- import androidx.compose.ui.focus.onFocusChanged
30
- import androidx.compose.ui.graphics.Color
31
- import androidx.compose.ui.text.AnnotatedString
32
- import androidx.compose.ui.text.SpanStyle
33
- import androidx.compose.ui.text.TextStyle
34
- import androidx.compose.ui.text.font.FontFamily
35
- import androidx.compose.ui.text.font.FontWeight
36
- import androidx.compose.ui.text.input.KeyboardType
37
- import androidx.compose.ui.text.input.OffsetMapping
38
- import androidx.compose.ui.text.input.TransformedText
39
- import androidx.compose.ui.text.input.VisualTransformation
40
- import androidx.compose.ui.text.style.TextAlign
41
- import androidx.compose.ui.unit.Dp
42
- import androidx.compose.ui.unit.TextUnit
43
- import androidx.compose.ui.unit.dp
44
- import androidx.compose.ui.unit.sp
45
- import androidx.compose.ui.zIndex
46
- import vn.momo.kits.application.IsShowBaseLineDebug
47
- import vn.momo.kits.const.AppTheme
48
- import vn.momo.kits.const.Colors
49
- import vn.momo.kits.const.Radius
50
- import vn.momo.kits.const.Spacing
51
- import vn.momo.kits.const.Typography
52
- import vn.momo.kits.const.getFont
53
- import vn.momo.kits.const.scaleSize
54
- import vn.momo.kits.modifier.conditional
55
- import vn.momo.kits.modifier.setAutomationId
56
- import vn.momo.uikits.resources.Res
57
- import vn.momo.uikits.resources.sfprotext_regular
58
-
59
- data class InputSizeDetail(
60
- val borderWidth: Dp,
61
- val borderRadius: Dp,
62
- val height: Dp,
63
- )
64
-
65
- enum class InputSize(val values: InputSizeDetail) {
66
- SMALL(
67
- InputSizeDetail(
68
- borderWidth = 1.dp,
69
- borderRadius = Radius.S,
70
- height = 48.dp
71
- )
72
- ),
73
- LARGE(
74
- InputSizeDetail(
75
- borderWidth = 1.dp,
76
- borderRadius = Radius.S,
77
- height = 56.dp
78
- )
79
- )
80
- }
81
-
82
- enum class InputFontWeight(val value: FontWeight) {
83
- REGULAR(
84
- FontWeight(400)
85
- ),
86
- BOLD(
87
- FontWeight(700)
88
- )
89
- }
90
-
91
- // Consolidated input state for better performance
92
- data class InputState(
93
- val isFocused: Boolean = false,
94
- val passHidden: Boolean = false,
95
- val hasBeenBlurred: Boolean = false
96
- )
97
-
98
- private class PasswordVisualTransformation(
99
- private val fontFamily: FontFamily,
100
- private val fontSize: TextUnit
101
- ) : VisualTransformation {
102
- private val mask: Char = '\u2022'
103
-
104
- override fun filter(text: AnnotatedString): TransformedText {
105
-
106
- val maskedText = AnnotatedString(
107
- text = mask.toString().repeat(text.length),
108
- spanStyles = listOf(
109
- AnnotatedString.Range(
110
- SpanStyle(fontSize = fontSize, letterSpacing = 0.sp, fontFamily = fontFamily),
111
- 0,
112
- text.length
113
- )
114
- )
115
- )
116
- return TransformedText(maskedText, OffsetMapping.Identity)
117
- }
118
-
119
- override fun equals(other: Any?): Boolean {
120
- if (this === other) return true
121
- if (other !is PasswordVisualTransformation) return false
122
- return mask == other.mask && fontSize == other.fontSize
123
- }
124
-
125
- override fun hashCode(): Int {
126
- return 31 * mask.hashCode() + fontSize.hashCode()
127
- }
128
- }
129
-
130
- @Composable
131
- fun getBorderColor(isFocused: Boolean, error: String, disabled: Boolean): Color {
132
- val theme = AppTheme.current
133
- return remember(isFocused, error, disabled, theme) {
134
- when {
135
- disabled -> theme.colors.border.disable
136
- error.isNotEmpty() -> theme.colors.error.primary
137
- isFocused -> theme.colors.primary
138
- else -> theme.colors.border.default
139
- }
140
- }
141
- }
142
-
143
- @Composable
144
- fun RenderRightIcon(loading: Boolean, icon: String, color: Color, onClick: () -> Unit, modifier: Modifier = Modifier) {
145
- if (loading) {
146
- Box {
147
- CircularProgressIndicator(
148
- modifier = Modifier.size(16.dp),
149
- color = color,
150
- trackColor = Color.Transparent,
151
- strokeWidth = 2.dp
152
- )
153
- }
154
- }
155
- if (icon.isNotEmpty()) {
156
- Icon(
157
- source = icon,
158
- color = color,
159
- size = 24.dp,
160
- modifier = modifier.clickable(
161
- onClick = onClick,
162
- interactionSource = remember { MutableInteractionSource() },
163
- indication = null
164
- )
165
- )
166
- }
167
- }
168
-
169
- @Composable
170
- fun ErrorView(errorMessage: String, errorSpacing: Boolean, hintText: String) {
171
- val theme = AppTheme.current
172
- val errorColor = remember(theme) { theme.colors.error.primary }
173
- val hintColor = remember(theme) { theme.colors.text.hint }
174
- val hintTextDefault = remember(hintText) { hintText.ifEmpty { "Không thể chỉnh sửa" } }
175
-
176
- if (errorMessage.isNotEmpty() || hintText.isNotEmpty()) {
177
- val color = if (errorMessage.isNotEmpty()) errorColor else hintColor
178
- Row(
179
- Modifier.padding(top = Spacing.XS),
180
- verticalAlignment = Alignment.Top
181
- ) {
182
- Icon(
183
- size = 16.dp,
184
- color = color,
185
- source = "ic_error"
186
- )
187
- Text(
188
- errorMessage.ifEmpty { hintTextDefault },
189
- style = Typography.descriptionDefaultRegular,
190
- modifier = Modifier.padding(start = Spacing.XS),
191
- color = color,
192
- )
193
- }
194
- } else if (errorSpacing) {
195
- Spacer(Modifier.padding(top = Spacing.XS).height(18.dp))
196
- }
197
- }
198
-
199
- @Composable
200
- fun Input(
201
- text: MutableState<String> = remember { mutableStateOf("") },
202
- floatingValue: String = "",
203
- floatingValueColor: Color = AppTheme.current.colors.text.hint,
204
- floatingIcon: String = "",
205
- floatingIconColor: Color = AppTheme.current.colors.text.default,
206
- placeholder: String = "",
207
- size: InputSize = InputSize.SMALL,
208
- onChangeText: (String) -> Unit = {},
209
- hintText: String = "",
210
- error: String = "",
211
- errorSpacing: Boolean = false,
212
- disabled: Boolean = false,
213
- readOnly: Boolean = false,
214
- secureTextEntry: Boolean = false,
215
- icon: String = "",
216
- iconColor: Color = AppTheme.current.colors.text.default,
217
- onRightIconPressed: () -> Unit = {},
218
- leadingIcon: String = "",
219
- leadingIconColor: Color = AppTheme.current.colors.text.hint,
220
- onFocus: () -> Unit = {},
221
- onBlur: () -> Unit = {},
222
- loading: Boolean = false,
223
- required: Boolean = false,
224
- fontWeight: InputFontWeight = InputFontWeight.REGULAR,
225
- keyboardType: KeyboardType = KeyboardType.Text,
226
- modifier: Modifier = Modifier,
227
- inputModifier: Modifier = Modifier,
228
- ) {
229
- // Consolidated state management
230
- var inputState by remember { mutableStateOf(InputState()) }
231
-
232
- // Memoized color calculations
233
- val theme = AppTheme.current
234
- val colors = remember(disabled, theme) {
235
- if (disabled) {
236
- val disabledColor = theme.colors.text.disable
237
- Triple(disabledColor, disabledColor, disabledColor)
238
- } else {
239
- Triple(
240
- theme.colors.text.default, // textColor
241
- theme.colors.text.hint, // placeholderColor
242
- iconColor // iconTintColor
243
- )
244
- }
245
- }
246
-
247
- val (textColor, placeholderColor, iconTintColor) = colors
248
-
249
- val floatingTitleColor = remember(disabled, floatingValueColor, theme) {
250
- if (disabled) theme.colors.text.disable else floatingValueColor
251
- }
252
-
253
- val floatingIconTintColor = remember(disabled, floatingIconColor, theme) {
254
- if (disabled) theme.colors.text.disable else floatingIconColor
255
- }
256
-
257
- val fontSize = 14.sp
258
- val lineHeight = 24.sp
259
- val scaleFontSize = scaleSize(fontSize)
260
- val scaleLineHeight = scaleSize(lineHeight)
261
-
262
- val textStyle = remember(textColor, fontWeight) {
263
- TextStyle(
264
- color = textColor,
265
- fontSize = scaleFontSize,
266
- lineHeight = scaleLineHeight,
267
- fontWeight = fontWeight.value
268
- )
269
- }
270
-
271
- val placeholderStyle = remember(placeholderColor, fontWeight) {
272
- TextStyle(
273
- fontSize = fontSize,
274
- lineHeight = lineHeight,
275
- fontWeight = fontWeight.value,
276
- textAlign = TextAlign.Center
277
- )
278
- }
279
-
280
- val keyboardOptionsConfig = remember(secureTextEntry, keyboardType) {
281
- KeyboardOptions.Default.copy(
282
- keyboardType = keyboardType
283
- )
284
- }
285
-
286
- val passwordFontFamily = getFont(Res.font.sfprotext_regular)
287
- val passwordFontSize = scaleSize(24.sp)
288
- val visualTransformation = remember(secureTextEntry, inputState.passHidden, passwordFontFamily) {
289
- if (secureTextEntry && !inputState.passHidden)
290
- PasswordVisualTransformation(fontFamily = passwordFontFamily, fontSize = passwordFontSize)
291
- else
292
- VisualTransformation.None
293
- }
294
-
295
- Column(modifier = modifier
296
- .conditional(IsShowBaseLineDebug) {
297
- border(1.dp, Colors.blue_03)
298
- }) {
299
- BasicTextField(
300
- enabled = !disabled,
301
- readOnly = readOnly,
302
- singleLine = true,
303
- value = text.value,
304
- textStyle = textStyle,
305
- visualTransformation = visualTransformation,
306
- keyboardOptions = keyboardOptionsConfig,
307
- modifier = inputModifier
308
- .height(scaleSize(size.values.height.value).dp)
309
- .onFocusChanged { focusState ->
310
- val wasFocused = inputState.isFocused
311
- inputState = inputState.copy(
312
- isFocused = focusState.isFocused,
313
- hasBeenBlurred = inputState.hasBeenBlurred || wasFocused
314
- )
315
-
316
- if (focusState.isFocused) {
317
- onFocus()
318
- } else if (inputState.hasBeenBlurred) {
319
- onBlur()
320
- }
321
- },
322
- onValueChange = onChangeText,
323
- decorationBox = { innerTextField ->
324
- // Floating label
325
- if (floatingValue.isNotEmpty() || floatingIcon.isNotEmpty()) {
326
- Box(
327
- modifier = Modifier
328
- .wrapContentSize()
329
- .offset(y = (-size.values.height / 2), x = Spacing.S)
330
- .background(theme.colors.background.surface)
331
- .zIndex(10f),
332
- ) {
333
- Row(
334
- modifier = Modifier.padding(horizontal = Spacing.S),
335
- verticalAlignment = Alignment.CenterVertically
336
- ) {
337
- Text(
338
- floatingValue,
339
- style = Typography.labelSMedium,
340
- color = floatingTitleColor
341
- )
342
- if (required) {
343
- Text(
344
- "*",
345
- style = Typography.labelSMedium,
346
- color = theme.colors.error.primary,
347
- )
348
- }
349
- if (floatingIcon.isNotEmpty()) {
350
- Icon(
351
- source = floatingIcon,
352
- modifier = Modifier.padding(start = Spacing.XS),
353
- size = 16.dp,
354
- color = floatingIconTintColor
355
- )
356
- }
357
- }
358
- }
359
- }
360
-
361
- // Input container
362
- Box(
363
- modifier = Modifier
364
- .fillMaxWidth()
365
- .background(
366
- color = AppTheme.current.colors.background.surface,
367
- shape = RoundedCornerShape(size.values.borderRadius)
368
- )
369
- .border(
370
- 1.dp,
371
- getBorderColor(inputState.isFocused, error, disabled),
372
- RoundedCornerShape(size.values.borderRadius)
373
- ),
374
- contentAlignment = Alignment.CenterStart
375
- ) {
376
- Row(
377
- modifier = Modifier.padding(horizontal = Spacing.M),
378
- verticalAlignment = Alignment.CenterVertically
379
- ) {
380
- // Leading icon
381
- if (leadingIcon.isNotEmpty()) {
382
- Icon(
383
- source = leadingIcon,
384
- modifier = Modifier.padding(end = Spacing.M),
385
- size = if (size == InputSize.SMALL) 24.dp else 32.dp,
386
- color = leadingIconColor
387
- )
388
- }
389
-
390
- Box(Modifier.weight(1f), contentAlignment = Alignment.CenterStart) {
391
- if (text.value.isEmpty()) {
392
- Text(
393
- text = placeholder,
394
- style = placeholderStyle,
395
- color = placeholderColor
396
- )
397
-
398
- }
399
- innerTextField()
400
- }
401
-
402
- // Clear button
403
- if (inputState.isFocused && text.value.isNotEmpty()) {
404
- Row(Modifier.padding(horizontal = Spacing.XS)) {
405
- Icon(
406
- source = "24_navigation_close_circle_full",
407
- size = 16.dp,
408
- color = theme.colors.text.hint,
409
- modifier = Modifier.clickable(
410
- onClick = {
411
- text.value = ""
412
- onChangeText.invoke("")
413
- },
414
- interactionSource = remember { MutableInteractionSource() },
415
- indication = null
416
- ).setAutomationId("ic_clear")
417
- )
418
- }
419
- }
420
-
421
- // Right icon (password toggle or custom icon)
422
- when {
423
- secureTextEntry && text.value.isNotEmpty() -> {
424
- val iconName = if (inputState.passHidden) "24_security_eye_open" else "24_security_eye_off"
425
- val togglePassword = {
426
- onRightIconPressed()
427
- inputState = inputState.copy(passHidden = !inputState.passHidden)
428
- }
429
- RenderRightIcon(
430
- loading = loading,
431
- icon = iconName,
432
- color = iconTintColor,
433
- onClick = togglePassword,
434
- modifier = Modifier.setAutomationId("ic_show_hide"))
435
- }
436
- else -> {
437
- RenderRightIcon(loading, icon, iconTintColor, onRightIconPressed)
438
- }
439
- }
440
- }
441
- }
442
- },
443
- )
444
-
445
- // Error/hint display
446
- ErrorView(error, errorSpacing, hintText)
447
- }
448
- }
@@ -1,172 +0,0 @@
1
- package vn.momo.kits.components
2
-
3
- import androidx.compose.foundation.background
4
- import androidx.compose.foundation.border
5
- import androidx.compose.foundation.clickable
6
- import androidx.compose.foundation.layout.Box
7
- import androidx.compose.foundation.layout.Column
8
- import androidx.compose.foundation.layout.Row
9
- import androidx.compose.foundation.layout.fillMaxWidth
10
- import androidx.compose.foundation.layout.height
11
- import androidx.compose.foundation.layout.offset
12
- import androidx.compose.foundation.layout.padding
13
- import androidx.compose.foundation.layout.wrapContentSize
14
- import androidx.compose.foundation.shape.RoundedCornerShape
15
- import androidx.compose.runtime.Composable
16
- import androidx.compose.runtime.MutableState
17
- import androidx.compose.runtime.getValue
18
- import androidx.compose.runtime.mutableStateOf
19
- import androidx.compose.runtime.remember
20
- import androidx.compose.ui.Alignment
21
- import androidx.compose.ui.Modifier
22
- import androidx.compose.ui.graphics.Color
23
- import androidx.compose.ui.semantics.contentDescription
24
- import androidx.compose.ui.semantics.semantics
25
- import androidx.compose.ui.semantics.testTag
26
- import androidx.compose.ui.text.TextStyle
27
- import androidx.compose.ui.unit.dp
28
- import androidx.compose.ui.unit.sp
29
- import androidx.compose.ui.zIndex
30
- import vn.momo.kits.const.AppTheme
31
- import vn.momo.kits.const.Spacing
32
- import vn.momo.kits.application.IsShowBaseLineDebug
33
- import vn.momo.kits.const.Colors
34
- import vn.momo.kits.const.Typography
35
- import vn.momo.kits.const.scaleSize
36
- import vn.momo.kits.modifier.conditional
37
-
38
- @Composable
39
- fun InputDropDown(
40
- value: MutableState<String> = remember { mutableStateOf("") },
41
- floatingValue: String = "",
42
- floatingValueColor: Color = AppTheme.current.colors.text.hint,
43
- floatingIcon: String = "",
44
- floatingIconColor: Color = AppTheme.current.colors.text.default,
45
- placeholder: String = "",
46
- size: InputSize = InputSize.SMALL,
47
- onPress: () -> Unit = {},
48
- hintText: String = "",
49
- error: String = "",
50
- errorSpacing: Boolean = false,
51
- disabled: Boolean = false,
52
- icon: String = "arrow_chevron_down_small",
53
- iconColor: Color = AppTheme.current.colors.text.default,
54
- onRightIconPressed: () -> Unit = {},
55
- leadingIcon: String = "",
56
- leadingIconColor: Color = AppTheme.current.colors.text.hint,
57
- loading: Boolean = false,
58
- required: Boolean = false,
59
- ) {
60
- val isFocused by remember { mutableStateOf(false) }
61
-
62
- val disabledColor = AppTheme.current.colors.text.disable
63
- var textColor = AppTheme.current.colors.text.default
64
- var placeholderColor = AppTheme.current.colors.text.hint
65
- var iconTintColor = iconColor
66
- val floatingTitleColor = when {
67
- disabled -> AppTheme.current.colors.text.disable
68
- else -> floatingValueColor
69
- }
70
- val floatingIconTintColor = when {
71
- disabled -> AppTheme.current.colors.text.disable
72
- else -> floatingIconColor
73
- }
74
-
75
- if (disabled) {
76
- textColor = disabledColor
77
- placeholderColor = disabledColor
78
- iconTintColor = disabledColor
79
- }
80
-
81
- val testId = if (disabled) "input_${floatingValue}_disabled" else "input_$floatingValue"
82
-
83
- val fontSize = scaleSize(16.sp)
84
- val lineHeight = scaleSize(24.sp)
85
-
86
- Column(modifier = Modifier
87
- .conditional(IsShowBaseLineDebug) {
88
- border(1.dp, Colors.blue_03)
89
- }
90
- .clickable(enabled = !disabled, onClick = onPress)
91
- .semantics {
92
- contentDescription = floatingValue; testTag = testId
93
- }) {
94
- Box {
95
- if (floatingValue.isNotEmpty() || floatingIcon.isNotEmpty()) {
96
- Box(
97
- modifier = Modifier.wrapContentSize()
98
- .offset(y = -Spacing.S, x = Spacing.S)
99
- .background(AppTheme.current.colors.background.surface)
100
- .zIndex(10f),
101
- ) {
102
- Row(
103
- modifier = Modifier
104
- .padding(horizontal = Spacing.S),
105
- verticalAlignment = Alignment.CenterVertically
106
- ) {
107
- Text(
108
- floatingValue,
109
- style = Typography.labelSMedium,
110
- color = floatingTitleColor
111
- )
112
- if (required) {
113
- Text(
114
- "*",
115
- style = Typography.labelSMedium,
116
- color = AppTheme.current.colors.error.primary,
117
- )
118
- }
119
- if (floatingIcon.isNotEmpty()) {
120
- Icon(
121
- source = floatingIcon,
122
- modifier = Modifier.padding(start = Spacing.XS),
123
- size = 16.dp,
124
- color = floatingIconTintColor
125
- )
126
- }
127
- }
128
- }
129
- }
130
- Box(
131
- modifier = Modifier.fillMaxWidth()
132
- .height(if (size == InputSize.SMALL) 48.dp else 56.dp)
133
- .border(
134
- 1.dp,
135
- getBorderColor(isFocused, error, disabled),
136
- RoundedCornerShape(size.values.borderRadius)
137
- ),
138
- contentAlignment = Alignment.CenterStart
139
- ) {
140
- Row(
141
- modifier = Modifier.padding(horizontal = Spacing.M),
142
- verticalAlignment = Alignment.CenterVertically
143
- ) {
144
- //leading icon
145
- if (leadingIcon.isNotEmpty()) {
146
- Icon(
147
- source = leadingIcon,
148
- modifier = Modifier.padding(end = Spacing.M),
149
- size = if (size.name == InputSize.SMALL.name) 24.dp else 32.dp,
150
- color = leadingIconColor
151
- )
152
- }
153
- Box(Modifier.weight(1f)) {
154
- Text(
155
- text = value.value.ifEmpty { placeholder },
156
- style = TextStyle(
157
- fontSize = fontSize,
158
- lineHeight = lineHeight
159
- ),
160
- color = if (value.value.isEmpty()) placeholderColor else textColor
161
- )
162
- }
163
- RenderRightIcon(
164
- loading, icon, iconTintColor,
165
- onRightIconPressed
166
- )
167
- }
168
- }
169
- }
170
- ErrorView(error, errorSpacing, hintText)
171
- }
172
- }