@momo-kits/native-kits 0.157.8-debug → 0.157.8

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 (131) hide show
  1. package/package.json +1 -1
  2. package/build.gradle.kts +0 -11
  3. package/compose/build.gradle.kts +0 -180
  4. package/compose/build.gradle.kts.backup +0 -180
  5. package/compose/compose.podspec +0 -54
  6. package/compose/src/androidMain/kotlin/vn/momo/kits/platform/Platform.android.kt +0 -117
  7. package/compose/src/commonMain/composeResources/font/momosignature.otf +0 -0
  8. package/compose/src/commonMain/composeResources/font/momotrustdisplay.otf +0 -0
  9. package/compose/src/commonMain/composeResources/font/sfprotext_black.otf +0 -0
  10. package/compose/src/commonMain/composeResources/font/sfprotext_black.ttf +0 -0
  11. package/compose/src/commonMain/composeResources/font/sfprotext_bold.ttf +0 -0
  12. package/compose/src/commonMain/composeResources/font/sfprotext_heavy.ttf +0 -0
  13. package/compose/src/commonMain/composeResources/font/sfprotext_light.ttf +0 -0
  14. package/compose/src/commonMain/composeResources/font/sfprotext_medium.ttf +0 -0
  15. package/compose/src/commonMain/composeResources/font/sfprotext_regular.ttf +0 -0
  16. package/compose/src/commonMain/composeResources/font/sfprotext_semibold.ttf +0 -0
  17. package/compose/src/commonMain/composeResources/font/sfprotext_thin.otf +0 -0
  18. package/compose/src/commonMain/composeResources/font/sfprotext_thin.ttf +0 -0
  19. package/compose/src/commonMain/composeResources/font/sfprotext_ultralight.otf +0 -0
  20. package/compose/src/commonMain/composeResources/font/sfprotext_ultralight.ttf +0 -0
  21. package/compose/src/commonMain/kotlin/vn/momo/kits/application/AnimationSearchInput.kt +0 -57
  22. package/compose/src/commonMain/kotlin/vn/momo/kits/application/Context.kt +0 -107
  23. package/compose/src/commonMain/kotlin/vn/momo/kits/application/FloatingButton.kt +0 -201
  24. package/compose/src/commonMain/kotlin/vn/momo/kits/application/Header.kt +0 -222
  25. package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderAnimated.kt +0 -48
  26. package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderBackground.kt +0 -86
  27. package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderDefault.kt +0 -76
  28. package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderExtended.kt +0 -76
  29. package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderRight.kt +0 -305
  30. package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderTitle.kt +0 -33
  31. package/compose/src/commonMain/kotlin/vn/momo/kits/application/LiteScreen.kt +0 -720
  32. package/compose/src/commonMain/kotlin/vn/momo/kits/application/NavigationContainer.kt +0 -121
  33. package/compose/src/commonMain/kotlin/vn/momo/kits/application/Screen.kt +0 -405
  34. package/compose/src/commonMain/kotlin/vn/momo/kits/application/useHeaderSearchAnimation.kt +0 -69
  35. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Avatar.kt +0 -157
  36. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Badge.kt +0 -85
  37. package/compose/src/commonMain/kotlin/vn/momo/kits/components/BadgeDot.kt +0 -32
  38. package/compose/src/commonMain/kotlin/vn/momo/kits/components/BadgeRibbon.kt +0 -340
  39. package/compose/src/commonMain/kotlin/vn/momo/kits/components/BaselineView.kt +0 -198
  40. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Button.kt +0 -357
  41. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Carousel.kt +0 -123
  42. package/compose/src/commonMain/kotlin/vn/momo/kits/components/CheckBox.kt +0 -94
  43. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Chip.kt +0 -136
  44. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Collapse.kt +0 -224
  45. package/compose/src/commonMain/kotlin/vn/momo/kits/components/CupertinoOverscroll.kt +0 -543
  46. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Divider.kt +0 -23
  47. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Icon.kt +0 -76
  48. package/compose/src/commonMain/kotlin/vn/momo/kits/components/IconButton.kt +0 -148
  49. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Image.kt +0 -188
  50. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Information.kt +0 -116
  51. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Input.kt +0 -448
  52. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputDropDown.kt +0 -172
  53. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputMoney.kt +0 -255
  54. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputOTP.kt +0 -231
  55. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputPhoneNumber.kt +0 -233
  56. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputSearch.kt +0 -254
  57. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputTextArea.kt +0 -241
  58. package/compose/src/commonMain/kotlin/vn/momo/kits/components/LazyColumnWithBouncing.kt +0 -364
  59. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Loader.kt +0 -108
  60. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PaginationDot.kt +0 -56
  61. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PaginationNumber.kt +0 -41
  62. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PaginationScroll.kt +0 -92
  63. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PaginationWhiteDot.kt +0 -40
  64. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PopupNotify.kt +0 -352
  65. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PopupPromotion.kt +0 -103
  66. package/compose/src/commonMain/kotlin/vn/momo/kits/components/ProgressInfo.kt +0 -338
  67. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Radio.kt +0 -70
  68. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Rating.kt +0 -87
  69. package/compose/src/commonMain/kotlin/vn/momo/kits/components/ScaleSizeScope.kt +0 -17
  70. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Skeleton.kt +0 -96
  71. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Slider.kt +0 -348
  72. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Stepper.kt +0 -256
  73. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Steps.kt +0 -494
  74. package/compose/src/commonMain/kotlin/vn/momo/kits/components/SuggestAction.kt +0 -131
  75. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Swipe.kt +0 -215
  76. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Switch.kt +0 -96
  77. package/compose/src/commonMain/kotlin/vn/momo/kits/components/TabView.kt +0 -531
  78. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Tag.kt +0 -92
  79. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Text.kt +0 -130
  80. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Title.kt +0 -214
  81. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Tooltip.kt +0 -590
  82. package/compose/src/commonMain/kotlin/vn/momo/kits/components/TrustBanner.kt +0 -177
  83. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Uploader.kt +0 -192
  84. package/compose/src/commonMain/kotlin/vn/momo/kits/components/datetimepicker/DateTimePicker.kt +0 -205
  85. package/compose/src/commonMain/kotlin/vn/momo/kits/components/datetimepicker/DateTimePickerTypes.kt +0 -29
  86. package/compose/src/commonMain/kotlin/vn/momo/kits/components/datetimepicker/DateTimePickerUtils.kt +0 -239
  87. package/compose/src/commonMain/kotlin/vn/momo/kits/components/datetimepicker/WheelPicker.kt +0 -191
  88. package/compose/src/commonMain/kotlin/vn/momo/kits/const/Colors.kt +0 -306
  89. package/compose/src/commonMain/kotlin/vn/momo/kits/const/Radius.kt +0 -12
  90. package/compose/src/commonMain/kotlin/vn/momo/kits/const/Spacing.kt +0 -16
  91. package/compose/src/commonMain/kotlin/vn/momo/kits/const/Theme.kt +0 -188
  92. package/compose/src/commonMain/kotlin/vn/momo/kits/const/Typography.kt +0 -285
  93. package/compose/src/commonMain/kotlin/vn/momo/kits/layout/Card.kt +0 -2
  94. package/compose/src/commonMain/kotlin/vn/momo/kits/layout/Item.kt +0 -35
  95. package/compose/src/commonMain/kotlin/vn/momo/kits/layout/Section.kt +0 -2
  96. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/AutomationId.kt +0 -50
  97. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/Clickable.kt +0 -68
  98. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/Conditional.kt +0 -11
  99. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/DeprecatedModifier.kt +0 -14
  100. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/Shadow.kt +0 -50
  101. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/Size.kt +0 -51
  102. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/BottomSheet.kt +0 -253
  103. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/ModalScreen.kt +0 -133
  104. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/Navigation.kt +0 -99
  105. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/NavigationContainer.kt +0 -164
  106. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/Navigator.kt +0 -333
  107. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/StackScreen.kt +0 -552
  108. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/bottomtab/BottomTab.kt +0 -162
  109. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/bottomtab/BottomTabBar.kt +0 -243
  110. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/bottomtab/CurvedContainer.kt +0 -86
  111. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/FloatingButton.kt +0 -187
  112. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/Header.kt +0 -279
  113. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/HeaderBackground.kt +0 -80
  114. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/HeaderRight.kt +0 -306
  115. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/HeaderTitle.kt +0 -32
  116. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/HeaderUser.kt +0 -370
  117. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/SnackBar.kt +0 -132
  118. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/tracking/ScreenTracker.kt +0 -167
  119. package/compose/src/commonMain/kotlin/vn/momo/kits/platform/Platform.kt +0 -46
  120. package/compose/src/commonMain/kotlin/vn/momo/kits/utils/Icons.kt +0 -1329
  121. package/compose/src/commonMain/kotlin/vn/momo/kits/utils/Resources.kt +0 -62
  122. package/compose/src/commonMain/kotlin/vn/momo/kits/utils/Tracking.kt +0 -15
  123. package/compose/src/commonMain/kotlin/vn/momo/kits/utils/Utils.kt +0 -88
  124. package/compose/src/iosMain/kotlin/vn/momo/kits/platform/Platform.ios.kt +0 -161
  125. package/gradle/libs.versions.toml +0 -57
  126. package/gradle/wrapper/gradle-wrapper.jar +0 -0
  127. package/gradle/wrapper/gradle-wrapper.properties +0 -8
  128. package/gradle.properties +0 -26
  129. package/gradlew +0 -252
  130. package/gradlew.bat +0 -94
  131. package/settings.gradle.kts +0 -52
@@ -1,233 +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.fillMaxWidth
11
- import androidx.compose.foundation.layout.height
12
- import androidx.compose.foundation.layout.padding
13
- import androidx.compose.foundation.layout.size
14
- import androidx.compose.foundation.layout.width
15
- import androidx.compose.foundation.shape.RoundedCornerShape
16
- import androidx.compose.foundation.text.BasicTextField
17
- import androidx.compose.foundation.text.KeyboardOptions
18
- import androidx.compose.runtime.Composable
19
- import androidx.compose.runtime.MutableState
20
- import androidx.compose.runtime.getValue
21
- import androidx.compose.runtime.mutableStateOf
22
- import androidx.compose.runtime.remember
23
- import androidx.compose.runtime.setValue
24
- import androidx.compose.ui.Alignment
25
- import androidx.compose.ui.Modifier
26
- import androidx.compose.ui.focus.onFocusChanged
27
- import androidx.compose.ui.graphics.Color
28
- import androidx.compose.ui.graphics.SolidColor
29
- import androidx.compose.ui.layout.ContentScale
30
- import androidx.compose.ui.text.TextStyle
31
- import androidx.compose.ui.text.input.KeyboardType
32
- import androidx.compose.ui.unit.Dp
33
- import androidx.compose.ui.unit.dp
34
- import vn.momo.kits.application.IsShowBaseLineDebug
35
- import vn.momo.kits.const.AppTheme
36
- import vn.momo.kits.const.Colors
37
- import vn.momo.kits.const.Radius
38
- import vn.momo.kits.const.Spacing
39
- import vn.momo.kits.const.Typography
40
- import vn.momo.kits.const.scaleSize
41
- import vn.momo.kits.modifier.conditional
42
- import vn.momo.kits.modifier.setAutomationId
43
-
44
- data class InputPhoneNumberSizeDetail(
45
- val borderWidth: Dp,
46
- val borderRadius: Dp,
47
- val height: Dp,
48
- val textStyle: TextStyle,
49
- val dividerHeight: Dp,
50
- )
51
-
52
- enum class InputPhoneNumberSize(val values: InputPhoneNumberSizeDetail) {
53
- SMALL(
54
- InputPhoneNumberSizeDetail(
55
- borderWidth = 1.dp,
56
- borderRadius = Radius.S,
57
- height = 48.dp,
58
- textStyle = Typography.headerSSemibold,
59
- dividerHeight = 24.dp
60
- )
61
- ),
62
- LARGE(
63
- InputPhoneNumberSizeDetail(
64
- borderWidth = 1.dp,
65
- borderRadius = Radius.S,
66
- height = 56.dp,
67
- textStyle = Typography.headerMBold,
68
- dividerHeight = 32.dp
69
- )
70
- )
71
- }
72
-
73
- @Composable
74
- fun getBorderColor(isFocused: Boolean, error: String): Color {
75
- val theme = AppTheme.current
76
- return remember(isFocused, error, theme) {
77
- when {
78
- error.isNotEmpty() -> theme.colors.error.primary
79
- isFocused -> theme.colors.primary
80
- else -> theme.colors.border.default
81
- }
82
- }
83
- }
84
-
85
- @Composable
86
- fun InputPhoneNumber(
87
- text: MutableState<String> = remember { mutableStateOf("") },
88
- placeholder: String = "0123456789",
89
- size: InputPhoneNumberSize = InputPhoneNumberSize.SMALL,
90
- onChangeText: (String) -> Unit = {},
91
- hintText: String = "",
92
- error: String = "",
93
- errorSpacing: Boolean = false,
94
- icon: String = "",
95
- iconColor: Color = AppTheme.current.colors.text.default,
96
- onRightIconPressed: () -> Unit = {},
97
- onFocus: () -> Unit = {},
98
- onBlur: () -> Unit = {},
99
- loading: Boolean = false,
100
- modifier: Modifier = Modifier,
101
- inputModifier: Modifier = Modifier,
102
- ) {
103
- // Consolidated state management
104
- var inputState by remember { mutableStateOf(InputState()) }
105
-
106
- // Memoized color calculations
107
- val theme = AppTheme.current
108
- val colors = remember( theme) {
109
- Triple(
110
- theme.colors.text.default, // textColor
111
- theme.colors.text.hint, // placeholderColor
112
- iconColor // iconTintColor
113
- )
114
- }
115
-
116
- val (textColor, placeholderColor, iconTintColor) = colors
117
- val textStyle = scaleSize(size.values.textStyle.copy(color = textColor))
118
-
119
-
120
- Column(modifier = modifier
121
- .conditional(IsShowBaseLineDebug) {
122
- border(1.dp, Colors.blue_03)
123
- }) {
124
- BasicTextField(
125
- singleLine = true,
126
- value = text.value,
127
- textStyle = textStyle,
128
- keyboardOptions = KeyboardOptions.Default.copy(keyboardType = KeyboardType.Number),
129
- cursorBrush = SolidColor(AppTheme.current.colors.primary),
130
- modifier = inputModifier
131
- .height(scaleSize(size.values.height.value, 1.1f).dp)
132
- .onFocusChanged { focusState ->
133
- val wasFocused = inputState.isFocused
134
- inputState = inputState.copy(
135
- isFocused = focusState.isFocused,
136
- hasBeenBlurred = inputState.hasBeenBlurred || wasFocused
137
- )
138
-
139
- if (focusState.isFocused) {
140
- onFocus()
141
- } else if (inputState.hasBeenBlurred) {
142
- onBlur()
143
- }
144
- },
145
- onValueChange = onChangeText,
146
- decorationBox = { innerTextField ->
147
- // Input container
148
- Box(
149
- modifier = Modifier
150
- .fillMaxWidth()
151
- .background(
152
- color = AppTheme.current.colors.background.surface,
153
- shape = RoundedCornerShape(size.values.borderRadius)
154
- )
155
- .border(
156
- if(inputState.isFocused) 1.5.dp else 1.dp,
157
- getBorderColor(inputState.isFocused, error),
158
- RoundedCornerShape(size.values.borderRadius)
159
- ),
160
- contentAlignment = Alignment.CenterStart
161
- ) {
162
- Row(
163
- modifier = Modifier.padding(horizontal = Spacing.M),
164
- verticalAlignment = Alignment.CenterVertically
165
- ) {
166
- // Leading icon
167
- Image(
168
- source = "https://static.momocdn.net/app/img/icon/ic-qrcode-package/ic_vn_flag.png",
169
- modifier = Modifier.size(24.dp).padding(end = Spacing.XS),
170
- options = Options(
171
- contentScale = ContentScale.Fit,
172
- alignment = Alignment.Center
173
- )
174
- )
175
- Text(
176
- "+84",
177
- color = textColor,
178
- style = size.values.textStyle.copy(color = textColor),
179
- )
180
-
181
- // Divider
182
- Box(modifier = Modifier.padding(horizontal = Spacing.M)) {
183
- Box(
184
- modifier = Modifier.width(1.dp)
185
- .height(size.values.dividerHeight)
186
- .background(Colors.black_04)
187
- )
188
- }
189
-
190
-
191
- Box(Modifier.weight(1f)) {
192
- if (text.value.isEmpty()) {
193
- Text(
194
- text = placeholder,
195
- style = size.values.textStyle.copy(color = placeholderColor),
196
- color = placeholderColor,
197
- modifier = Modifier.align(Alignment.CenterStart)
198
- )
199
- }
200
- innerTextField()
201
- }
202
-
203
- // Clear button
204
- if (inputState.isFocused && text.value.isNotEmpty()) {
205
- Row {
206
- Icon(
207
- source = "24_navigation_close_circle_full",
208
- size = 16.dp,
209
- color = theme.colors.text.hint,
210
- modifier = Modifier.clickable(
211
- onClick = {
212
- text.value = ""
213
- onChangeText.invoke("")
214
- },
215
- interactionSource = remember { MutableInteractionSource() },
216
- indication = null
217
- )
218
- .padding(horizontal = Spacing.S)
219
- .setAutomationId("ic_clear")
220
- )
221
- }
222
- }
223
-
224
- // Right icon (password toggle or custom icon)
225
- RenderRightIcon(loading, icon, iconTintColor, onRightIconPressed)
226
- }
227
- }
228
- },
229
- )
230
- // Error/hint display
231
- ErrorView(error, errorSpacing, hintText)
232
- }
233
- }
@@ -1,254 +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.Arrangement
8
- import androidx.compose.foundation.layout.Box
9
- import androidx.compose.foundation.layout.Row
10
- import androidx.compose.foundation.layout.Spacer
11
- import androidx.compose.foundation.layout.fillMaxHeight
12
- import androidx.compose.foundation.layout.fillMaxWidth
13
- import androidx.compose.foundation.layout.height
14
- import androidx.compose.foundation.layout.padding
15
- import androidx.compose.foundation.layout.size
16
- import androidx.compose.foundation.layout.width
17
- import androidx.compose.foundation.shape.RoundedCornerShape
18
- import androidx.compose.foundation.text.BasicTextField
19
- import androidx.compose.foundation.text.KeyboardActions
20
- import androidx.compose.foundation.text.KeyboardOptions
21
- import androidx.compose.material3.CircularProgressIndicator
22
- import androidx.compose.runtime.Composable
23
- import androidx.compose.runtime.MutableState
24
- import androidx.compose.runtime.getValue
25
- import androidx.compose.runtime.mutableStateOf
26
- import androidx.compose.runtime.remember
27
- import androidx.compose.runtime.setValue
28
- import androidx.compose.ui.Alignment
29
- import androidx.compose.ui.Modifier
30
- import androidx.compose.ui.focus.onFocusChanged
31
- import androidx.compose.ui.graphics.Color
32
- import androidx.compose.ui.text.TextStyle
33
- import androidx.compose.ui.text.input.KeyboardType
34
- import androidx.compose.ui.text.style.TextOverflow
35
- import androidx.compose.ui.unit.Dp
36
- import androidx.compose.ui.unit.dp
37
- import androidx.compose.ui.unit.sp
38
- import vn.momo.kits.const.AppTheme
39
- import vn.momo.kits.const.Colors
40
- import vn.momo.kits.const.Radius
41
- import vn.momo.kits.const.Spacing
42
- import vn.momo.kits.application.IsShowBaseLineDebug
43
- import vn.momo.kits.const.Typography
44
- import vn.momo.kits.const.scaleSize
45
- import vn.momo.kits.modifier.conditional
46
- import vn.momo.kits.utils.ifTrue
47
-
48
- @Composable
49
- fun RenderRightIconSearch(
50
- loading: Boolean,
51
- icon: String,
52
- color: Color,
53
- onClick: () -> Unit,
54
- iconModifier: Modifier = Modifier
55
- ) {
56
- if (loading) {
57
- Box(Modifier.padding(horizontal = Spacing.S)) {
58
- CircularProgressIndicator(
59
- modifier = Modifier.size(16.dp),
60
- color = color,
61
- trackColor = Color.Transparent,
62
- strokeWidth = 2.dp
63
- )
64
- }
65
- }
66
- if (icon.isNotEmpty()) {
67
- Spacer(
68
- Modifier.padding(start = Spacing.S, top = Spacing.S, bottom = Spacing.S).width(1.dp).fillMaxHeight()
69
- .background(AppTheme.current.colors.primary)
70
- )
71
- Icon(
72
- source = icon,
73
- color = color,
74
- size = 24.dp,
75
- modifier = iconModifier.padding(start = Spacing.S, end = 0.dp).clickable(
76
- onClick = onClick,
77
- interactionSource = remember { MutableInteractionSource() },
78
- indication = null
79
- )
80
- )
81
- }
82
- }
83
-
84
- data class InputSearchProps(
85
- val text: MutableState<String>,
86
- val buttonText: String = "",
87
- val showButtonText: Boolean = false,
88
- val placeholder: String = "",
89
- val onChangeText: (String) -> Unit = {},
90
- val onPressButtonText: () -> Unit = {},
91
- val disabled: Boolean = false,
92
- val icon: String = "",
93
- val iconColor: Color = Color(0xff),
94
- val onRightIconPressed: () -> Unit = {},
95
- val onFocus: () -> Unit = {},
96
- val onBlur: () -> Unit = {},
97
- val loading: Boolean = false,
98
- val fontWeight: InputFontWeight = InputFontWeight.REGULAR,
99
- val keyboardType: KeyboardType = KeyboardType.Text,
100
- val backgroundColor: Color = Colors.black_01,
101
- val clearCondition: (() -> Boolean)? = null,
102
- val keyboardOptions: KeyboardOptions = KeyboardOptions.Default,
103
- val keyboardActions: KeyboardActions = KeyboardActions.Default,
104
- val modifier: Modifier = Modifier,
105
- val iconModifier: Modifier = Modifier,
106
- val onClearPress: () -> Unit = {},
107
- val leftPosition: Dp? = null,
108
- )
109
-
110
- @Composable
111
- fun InputSearch(
112
- inputSearchProps: InputSearchProps = InputSearchProps(
113
- text = remember { mutableStateOf("") },
114
- iconColor = AppTheme.current.colors.text.default
115
- ),
116
- ) {
117
- var isFocused by remember { mutableStateOf(false) }
118
- var isBlurred = false
119
- val disabledColor = AppTheme.current.colors.text.disable
120
- var textColor = AppTheme.current.colors.text.default
121
- var placeholderColor = AppTheme.current.colors.text.hint
122
- var iconTintColor = inputSearchProps.iconColor
123
-
124
- if (inputSearchProps.disabled) {
125
- textColor = disabledColor
126
- placeholderColor = disabledColor
127
- iconTintColor = disabledColor
128
- }
129
- val fontSize = 14.sp
130
- val scaleFontSize = scaleSize(fontSize)
131
-
132
- val textStyle = remember(textColor, inputSearchProps.fontWeight.value) {
133
- TextStyle(
134
- color = textColor,
135
- fontSize = scaleFontSize,
136
- fontWeight = inputSearchProps.fontWeight.value
137
- )
138
- }
139
-
140
- val placeHolderStyle = remember(textColor, inputSearchProps.fontWeight.value) {
141
- TextStyle(
142
- color = textColor,
143
- fontSize = fontSize,
144
- fontWeight = inputSearchProps.fontWeight.value
145
- )
146
- }
147
-
148
- Row(verticalAlignment = Alignment.CenterVertically, modifier = Modifier
149
- .fillMaxWidth()
150
- .height(36.dp)
151
- .conditional(IsShowBaseLineDebug) {
152
- border(1.dp, Colors.blue_03)
153
- }
154
- ) {
155
- BasicTextField(
156
- enabled = !inputSearchProps.disabled,
157
- singleLine = true,
158
- value = inputSearchProps.text.value,
159
- textStyle = textStyle,
160
- keyboardOptions = inputSearchProps.keyboardOptions.copy(keyboardType = inputSearchProps.keyboardType),
161
- keyboardActions = inputSearchProps.keyboardActions,
162
- modifier = inputSearchProps.modifier.weight(1f).fillMaxHeight().onFocusChanged {
163
- isFocused = it.isFocused
164
- if (it.isFocused) {
165
- inputSearchProps.onFocus()
166
- }
167
- if (!it.isFocused && isBlurred) inputSearchProps.onBlur()
168
- if (it.isFocused && !isBlurred) isBlurred = true
169
- },
170
- onValueChange = inputSearchProps.onChangeText,
171
- decorationBox = { innerTextField ->
172
- Row(verticalAlignment = Alignment.CenterVertically) {
173
- Row(
174
- modifier = Modifier.weight(
175
- inputSearchProps.showButtonText.ifTrue(
176
- 8f,
177
- 1f
178
- )
179
- ).fillMaxHeight()
180
- .background(
181
- inputSearchProps.backgroundColor,
182
- RoundedCornerShape(Radius.XL)
183
- ),
184
- horizontalArrangement = Arrangement.Start,
185
- verticalAlignment = Alignment.CenterVertically
186
- ) {
187
- Row(
188
- modifier = Modifier.padding(
189
- horizontal = Spacing.M
190
- ),
191
- verticalAlignment = Alignment.CenterVertically
192
- ) {
193
- Icon(
194
- source = "navigation_search",
195
- modifier = Modifier.padding(end = Spacing.XS),
196
- size = 24.dp,
197
- color = AppTheme.current.colors.text.hint
198
- )
199
- Box(Modifier.weight(1f)) {
200
- if (inputSearchProps.text.value.isEmpty()) {
201
- Text(
202
- text = inputSearchProps.placeholder,
203
- style = placeHolderStyle,
204
- maxLines = 1,
205
- color = placeholderColor,
206
- overflow = TextOverflow.Ellipsis
207
- )
208
- }
209
- innerTextField()
210
- }
211
- if (inputSearchProps.clearCondition?.invoke() == true || (isFocused && inputSearchProps.text.value.isNotEmpty())) {
212
- Row {
213
- Spacer(Modifier.width(Spacing.XS))
214
- Icon(
215
- source = "24_navigation_close_circle_full",
216
- size = 16.dp,
217
- color = AppTheme.current.colors.text.hint,
218
- modifier = Modifier.clickable(
219
- onClick = {
220
- inputSearchProps.text.value = ""
221
- inputSearchProps.onClearPress.invoke()
222
- },
223
- interactionSource = remember { MutableInteractionSource() },
224
- indication = null
225
- )
226
- )
227
- }
228
- }
229
- RenderRightIconSearch(
230
- inputSearchProps.loading,
231
- inputSearchProps.icon,
232
- iconTintColor,
233
- inputSearchProps.onRightIconPressed,
234
- iconModifier = inputSearchProps.iconModifier
235
- )
236
- }
237
- }
238
- }
239
- },
240
- )
241
- if (inputSearchProps.showButtonText) {
242
- Text(
243
- text = inputSearchProps.buttonText,
244
- style = Typography.actionDefaultBold,
245
- color = AppTheme.current.colors.text.default,
246
- modifier = Modifier.padding(start = Spacing.L).clickable(
247
- interactionSource = remember { MutableInteractionSource() },
248
- indication = null,
249
- onClick = inputSearchProps.onPressButtonText
250
- )
251
- )
252
- }
253
- }
254
- }