@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,255 +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.width
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.runtime.Composable
21
- import androidx.compose.runtime.MutableState
22
- import androidx.compose.runtime.getValue
23
- import androidx.compose.runtime.mutableStateOf
24
- import androidx.compose.runtime.remember
25
- import androidx.compose.runtime.setValue
26
- import androidx.compose.ui.Alignment
27
- import androidx.compose.ui.Modifier
28
- import androidx.compose.ui.focus.onFocusChanged
29
- import androidx.compose.ui.graphics.Color
30
- import androidx.compose.ui.semantics.contentDescription
31
- import androidx.compose.ui.semantics.semantics
32
- import androidx.compose.ui.semantics.testTag
33
- import androidx.compose.ui.text.AnnotatedString
34
- import androidx.compose.ui.text.TextStyle
35
- import androidx.compose.ui.text.input.KeyboardType
36
- import androidx.compose.ui.text.input.OffsetMapping
37
- import androidx.compose.ui.text.input.TransformedText
38
- import androidx.compose.ui.text.input.VisualTransformation
39
- import androidx.compose.ui.unit.dp
40
- import androidx.compose.ui.unit.sp
41
- import androidx.compose.ui.zIndex
42
- import vn.momo.kits.const.AppTheme
43
- import vn.momo.kits.const.Spacing
44
- import vn.momo.kits.application.IsShowBaseLineDebug
45
- import vn.momo.kits.const.Colors
46
- import vn.momo.kits.const.Typography
47
- import vn.momo.kits.modifier.conditional
48
- import vn.momo.kits.utils.formatNumberToMoney
49
-
50
- class CustomConverter : VisualTransformation {
51
- override fun filter(text: AnnotatedString): TransformedText {
52
- if (text.text.isEmpty()) {
53
- return TransformedText(
54
- AnnotatedString("0"),
55
- object : OffsetMapping {
56
- override fun originalToTransformed(offset: Int): Int = 0
57
- override fun transformedToOriginal(offset: Int): Int = 0
58
- }
59
- )
60
- }
61
-
62
- if (text.text == "0") {
63
- return TransformedText(AnnotatedString("0"), OffsetMapping.Identity)
64
- }
65
-
66
- val formattedText = formatNumberToMoney(text.text.toLong())
67
-
68
- return TransformedText(
69
- AnnotatedString(formattedText),
70
- object : OffsetMapping {
71
- override fun originalToTransformed(offset: Int): Int = formattedText.length
72
- override fun transformedToOriginal(offset: Int): Int = text.length
73
- }
74
- )
75
- }
76
- }
77
-
78
- @Composable
79
- fun InputMoney(
80
- text: MutableState<String> = remember { mutableStateOf("0") },
81
- floatingValue: String = "",
82
- floatingValueColor: Color = AppTheme.current.colors.text.hint,
83
- floatingIcon: String = "",
84
- floatingIconColor: Color = AppTheme.current.colors.text.default,
85
- placeholder: String = "0đ",
86
- size: InputSize = InputSize.SMALL,
87
- onChangeText: (String) -> Unit = {},
88
- error: String = "",
89
- errorSpacing: Boolean = false,
90
- disabled: Boolean = false,
91
- icon: String = "",
92
- iconColor: Color = AppTheme.current.colors.text.default,
93
- onPressIcon: () -> Unit = {},
94
- leadingIcon: String = "",
95
- leadingIconColor: Color = AppTheme.current.colors.text.hint,
96
- onFocus: () -> Unit = {},
97
- onBlur: () -> Unit = {},
98
- loading: Boolean = false,
99
- required: Boolean = false,
100
- fontWeight: InputFontWeight = InputFontWeight.BOLD,
101
- keyboardType: KeyboardType = KeyboardType.Number,
102
- ) {
103
- var isFocused by remember { mutableStateOf(false) }
104
- var isBlurred = false
105
- val disabledColor = AppTheme.current.colors.text.disable
106
- var textColor = AppTheme.current.colors.text.default
107
- var placeholderColor = AppTheme.current.colors.text.hint
108
- var iconTintColor = iconColor
109
- val floatingTitleColor = when {
110
- disabled -> AppTheme.current.colors.text.disable
111
- else -> floatingValueColor
112
- }
113
- val floatingIconTintColor = when {
114
- disabled -> AppTheme.current.colors.text.disable
115
- else -> floatingIconColor
116
- }
117
-
118
- if (disabled) {
119
- textColor = disabledColor
120
- placeholderColor = disabledColor
121
- iconTintColor = disabledColor
122
- }
123
-
124
- val testId = if (disabled) "input_${floatingValue}_disabled" else "input_$floatingValue"
125
-
126
- Column(modifier = Modifier
127
- .conditional(IsShowBaseLineDebug) {
128
- border(1.dp, Colors.blue_03)
129
- }
130
- .semantics {
131
- contentDescription = floatingValue; testTag = testId
132
- }) {
133
- BasicTextField(
134
- enabled = !disabled,
135
- singleLine = true,
136
- value = text.value,
137
- textStyle = TextStyle(
138
- color = textColor,
139
- fontSize = 20.sp,
140
- lineHeight = 24.sp,
141
- fontWeight = fontWeight.value
142
- ),
143
- visualTransformation = CustomConverter(),
144
- keyboardOptions = KeyboardOptions.Default.copy(keyboardType = keyboardType),
145
- modifier = Modifier.height(size.values.height).onFocusChanged {
146
- isFocused = it.isFocused
147
- if (it.isFocused) {
148
- onFocus()
149
- }
150
- if (!it.isFocused && isBlurred) onBlur()
151
- if (it.isFocused && !isBlurred) isBlurred = true
152
- },
153
- onValueChange = {
154
- val numericValue = it.filter { char -> char.isDigit() }
155
- onChangeText(numericValue)
156
- },
157
- decorationBox = { innerTextField ->
158
- // Floating Icon
159
- if (floatingValue.isNotEmpty() || floatingIcon.isNotEmpty()) {
160
- Box(
161
- modifier = Modifier.wrapContentSize()
162
- .offset(y = (-size.values.height / 2), x = (Spacing.S))
163
- .background(AppTheme.current.colors.background.surface)
164
- .zIndex(10f),
165
- ) {
166
- Row(
167
- modifier = Modifier.padding(horizontal = Spacing.S),
168
- ) {
169
- Text(
170
- floatingValue,
171
- style = Typography.labelSMedium,
172
- color = floatingTitleColor
173
- )
174
- if (required) {
175
- Text(
176
- "*",
177
- style = Typography.labelSMedium,
178
- color = AppTheme.current.colors.error.primary,
179
- )
180
- }
181
- if (floatingIcon.isNotEmpty()) {
182
- Icon(
183
- source = floatingIcon,
184
- modifier = Modifier.padding(start = Spacing.XS),
185
- size = 16.dp,
186
- color = floatingIconTintColor
187
- )
188
- }
189
- }
190
- }
191
- }
192
- //input box wrapper
193
- Box(
194
- modifier = Modifier.fillMaxWidth()
195
- .border(
196
- 1.dp,
197
- getBorderColor(isFocused, error, disabled),
198
- RoundedCornerShape(size.values.borderRadius)
199
- ),
200
- contentAlignment = Alignment.CenterStart
201
- ) {
202
- Row(
203
- modifier = Modifier.padding(horizontal = Spacing.M),
204
- verticalAlignment = Alignment.CenterVertically
205
- ) {
206
- //leading icon
207
- if (leadingIcon.isNotEmpty()) {
208
- Icon(
209
- source = leadingIcon,
210
- modifier = Modifier.padding(end = Spacing.XS),
211
- size = if (size.name == InputSize.SMALL.name) 24.dp else 32.dp,
212
- color = leadingIconColor
213
- )
214
- }
215
- Box(Modifier.weight(9f).padding(start = 0.dp)) {
216
- if (text.value.isEmpty()) {
217
- Text(
218
- text = placeholder,
219
- style = TextStyle(
220
- fontSize = 20.sp,
221
- lineHeight = 24.sp,
222
- fontWeight = fontWeight.value
223
- ),
224
- color = placeholderColor
225
- )
226
- } else {
227
- innerTextField()
228
- }
229
- }
230
- if (isFocused && text.value.isNotEmpty()) {
231
- Row {
232
- Spacer(Modifier.width(Spacing.XS))
233
- Icon(
234
- source = "24_navigation_close_circle_full",
235
- size = 16.dp,
236
- color = AppTheme.current.colors.text.hint,
237
- modifier = Modifier.clickable(
238
- onClick = {
239
- text.value = ""
240
- onChangeText.invoke("")
241
- },
242
- interactionSource = remember { MutableInteractionSource() },
243
- indication = null
244
- )
245
- )
246
- }
247
- }
248
- RenderRightIcon(loading, icon, iconTintColor, onPressIcon)
249
- }
250
- }
251
- },
252
- )
253
- ErrorView(error, errorSpacing, "")
254
- }
255
- }
@@ -1,231 +0,0 @@
1
- package vn.momo.kits.components
2
-
3
- import androidx.compose.animation.core.LinearEasing
4
- import androidx.compose.animation.core.RepeatMode
5
- import androidx.compose.animation.core.animateFloat
6
- import androidx.compose.animation.core.infiniteRepeatable
7
- import androidx.compose.animation.core.rememberInfiniteTransition
8
- import androidx.compose.animation.core.tween
9
- import androidx.compose.foundation.background
10
- import androidx.compose.foundation.border
11
- import androidx.compose.foundation.clickable
12
- import androidx.compose.foundation.layout.Arrangement
13
- import androidx.compose.foundation.layout.Box
14
- import androidx.compose.foundation.layout.Column
15
- import androidx.compose.foundation.layout.Row
16
- import androidx.compose.foundation.layout.Spacer
17
- import androidx.compose.foundation.layout.fillMaxWidth
18
- import androidx.compose.foundation.layout.height
19
- import androidx.compose.foundation.layout.offset
20
- import androidx.compose.foundation.layout.padding
21
- import androidx.compose.foundation.layout.size
22
- import androidx.compose.foundation.layout.width
23
- import androidx.compose.foundation.layout.wrapContentSize
24
- import androidx.compose.foundation.shape.RoundedCornerShape
25
- import androidx.compose.foundation.text.BasicTextField
26
- import androidx.compose.foundation.text.KeyboardOptions
27
- import androidx.compose.runtime.Composable
28
- import androidx.compose.runtime.getValue
29
- import androidx.compose.runtime.mutableStateOf
30
- import androidx.compose.runtime.remember
31
- import androidx.compose.runtime.setValue
32
- import androidx.compose.ui.Alignment
33
- import androidx.compose.ui.Modifier
34
- import androidx.compose.ui.focus.onFocusChanged
35
- import androidx.compose.ui.text.TextStyle
36
- import androidx.compose.ui.text.input.KeyboardType
37
- import androidx.compose.ui.unit.dp
38
- import androidx.compose.ui.unit.sp
39
- import androidx.compose.ui.zIndex
40
- import vn.momo.kits.const.AppTheme
41
- import vn.momo.kits.const.Radius
42
- import vn.momo.kits.const.Spacing
43
- import vn.momo.kits.application.IsShowBaseLineDebug
44
- import vn.momo.kits.const.Colors
45
- import vn.momo.kits.const.Typography
46
- import vn.momo.kits.const.scaleSize
47
- import vn.momo.kits.modifier.conditional
48
-
49
- @Composable
50
- fun OTPCaret() {
51
- val duration = 500
52
- val backgroundColor = AppTheme.current.colors.primary
53
-
54
- val infiniteTransition = rememberInfiniteTransition()
55
- val alpha by infiniteTransition.animateFloat(
56
- initialValue = 1f,
57
- targetValue = 0f,
58
- animationSpec = infiniteRepeatable(
59
- animation = tween(
60
- durationMillis = duration,
61
- delayMillis = duration,
62
- easing = LinearEasing
63
- ),
64
- repeatMode = RepeatMode.Reverse
65
- )
66
- )
67
-
68
- Row(verticalAlignment = Alignment.CenterVertically) {
69
- Box(
70
- modifier = Modifier
71
- .size(1.dp, scaleSize(12f).dp)
72
- .background(backgroundColor.copy(alpha = alpha))
73
- )
74
- Text(
75
- text = "-",
76
- color = AppTheme.current.colors.text.hint,
77
- style = Typography.descriptionDefaultRegular
78
- )
79
- }
80
- }
81
-
82
- @Composable
83
- fun InputOTP(
84
- value: String = "",
85
- length: Int? = null,
86
- errorMessage: String = "",
87
- errorSpacing: Boolean = false,
88
- floatingValue: String = "Label",
89
- placeholder: String = "",
90
- onChangeText: (String) -> Unit,
91
- onFocus: () -> Unit = {},
92
- onBlur: () -> Unit = {},
93
- dataType: String = "number",
94
- modifier: Modifier = Modifier
95
- ) {
96
- val maxLength = length ?: 10
97
- var isFocused by remember { mutableStateOf(false) }
98
- var isBlurred = false
99
-
100
- val handleChangeText: (String) -> Unit = { text ->
101
- if (text.length <= maxLength &&
102
- (dataType != "number" || !text.any { !it.isDigit() }) &&
103
- (text.length < value.length || value.length < text.length)
104
- ) {
105
- onChangeText(text)
106
- }
107
- }
108
-
109
- fun onClearText(){
110
- handleChangeText("")
111
- }
112
-
113
- val fontSize = scaleSize(20.sp)
114
-
115
- Column(modifier = modifier.conditional(IsShowBaseLineDebug) {
116
- border(1.dp, Colors.blue_03)
117
- }) {
118
- BasicTextField(
119
- value = value,
120
- textStyle = TextStyle(fontSize = fontSize),
121
- onValueChange = handleChangeText,
122
- singleLine = true,
123
- keyboardOptions = KeyboardOptions.Default.copy(keyboardType = if (dataType == "number") KeyboardType.Number else KeyboardType.Ascii),
124
- modifier = modifier.height(56.dp).onFocusChanged {
125
- isFocused = it.isFocused
126
- if (it.isFocused) {
127
- onFocus()
128
- }
129
- if (!it.isFocused && isBlurred) onBlur()
130
- if (it.isFocused && !isBlurred) isBlurred = true
131
- },
132
- decorationBox = { _ ->
133
- Box {
134
- if (floatingValue.isNotEmpty()) {
135
- Box(
136
- modifier = Modifier.wrapContentSize()
137
- .offset(y = ((-56).dp / 2))
138
- .align(Alignment.Center)
139
- .background(AppTheme.current.colors.background.surface)
140
- .zIndex(10f),
141
- ) {
142
- Row(
143
- modifier = Modifier
144
- .padding(horizontal = Spacing.S),
145
- verticalAlignment = Alignment.Bottom
146
- ) {
147
- Text(
148
- floatingValue,
149
- style = Typography.labelSMedium,
150
- color = AppTheme.current.colors.text.hint
151
- )
152
- }
153
- }
154
- }
155
- Box(
156
- modifier = Modifier
157
- .fillMaxWidth()
158
- .height(56.dp)
159
- .border(
160
- 1.dp,
161
- getBorderColor(isFocused, errorMessage, false),
162
- RoundedCornerShape(
163
- Radius.S
164
- )
165
- ), contentAlignment = Alignment.Center
166
- ) {
167
- Row(
168
- modifier = Modifier.padding(vertical = 8.dp),
169
- horizontalArrangement = Arrangement.SpaceBetween,
170
- verticalAlignment = Alignment.CenterVertically
171
- ) {
172
- if (length != null) {
173
- for (i in 0 until length) {
174
- if (isFocused && value.length == i) {
175
- OTPCaret()
176
- } else {
177
- val textColor =
178
- if (value.getOrNull(i) != null) AppTheme.current.colors.text.default else AppTheme.current.colors.text.hint
179
- val typo =
180
- if (value.getOrNull(i) != null) Typography.headerDefaultBold else Typography.descriptionDefaultRegular
181
- Text(
182
- text = value.getOrNull(i)?.toString() ?: "-",
183
- color = textColor,
184
- style = typo
185
- )
186
- }
187
- if (i != length - 1) Spacer(Modifier.width(Spacing.L))
188
- }
189
- } else {
190
- if (value.isEmpty() && !isFocused && placeholder.isNotEmpty()) {
191
- return@BasicTextField Text(
192
- text = placeholder,
193
- color = AppTheme.current.colors.text.hint
194
- )
195
- } else {
196
- for (i in value.indices) {
197
- Text(
198
- style = Typography.headerDefaultBold,
199
- text = value[i].toString()
200
- )
201
- if (i != value.length - 1 || (isFocused && value.length != MAX_LENGTH)) {
202
- Spacer(Modifier.width(Spacing.L))
203
- }
204
- }
205
- if (isFocused && value.length != MAX_LENGTH) OTPCaret()
206
- }
207
- }
208
- }
209
- }
210
- Box(
211
- modifier = Modifier.align(Alignment.Center).zIndex(10f)
212
- ) {
213
- Row(
214
- horizontalArrangement = Arrangement.End,
215
- modifier = Modifier.fillMaxWidth()
216
- ) {
217
- Icon(
218
- "24_navigation_close_circle_full",
219
- size = 12.dp,
220
- modifier = Modifier.padding(end = 12.dp).clickable {
221
- onClearText()
222
- }
223
- )
224
- }
225
- }
226
- }
227
- }
228
- )
229
- ErrorView(errorMessage, errorSpacing, "")
230
- }
231
- }