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

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 (117) 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 -110
  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/Badge.kt +0 -85
  36. package/compose/src/commonMain/kotlin/vn/momo/kits/components/BadgeDot.kt +0 -32
  37. package/compose/src/commonMain/kotlin/vn/momo/kits/components/BadgeRibbon.kt +0 -340
  38. package/compose/src/commonMain/kotlin/vn/momo/kits/components/BaselineView.kt +0 -198
  39. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Button.kt +0 -357
  40. package/compose/src/commonMain/kotlin/vn/momo/kits/components/CheckBox.kt +0 -94
  41. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Chip.kt +0 -136
  42. package/compose/src/commonMain/kotlin/vn/momo/kits/components/CupertinoOverscroll.kt +0 -543
  43. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Divider.kt +0 -23
  44. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Icon.kt +0 -76
  45. package/compose/src/commonMain/kotlin/vn/momo/kits/components/IconButton.kt +0 -148
  46. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Image.kt +0 -188
  47. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Information.kt +0 -116
  48. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Input.kt +0 -448
  49. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputDropDown.kt +0 -172
  50. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputMoney.kt +0 -255
  51. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputOTP.kt +0 -231
  52. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputPhoneNumber.kt +0 -233
  53. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputSearch.kt +0 -254
  54. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputTextArea.kt +0 -241
  55. package/compose/src/commonMain/kotlin/vn/momo/kits/components/LazyColumnWithBouncing.kt +0 -364
  56. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PaginationDot.kt +0 -56
  57. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PaginationNumber.kt +0 -41
  58. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PaginationScroll.kt +0 -92
  59. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PaginationWhiteDot.kt +0 -40
  60. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PopupNotify.kt +0 -352
  61. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PopupPromotion.kt +0 -103
  62. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Radio.kt +0 -70
  63. package/compose/src/commonMain/kotlin/vn/momo/kits/components/ScaleSizeScope.kt +0 -17
  64. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Skeleton.kt +0 -96
  65. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Switch.kt +0 -96
  66. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Tag.kt +0 -92
  67. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Text.kt +0 -130
  68. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Title.kt +0 -214
  69. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Tooltip.kt +0 -576
  70. package/compose/src/commonMain/kotlin/vn/momo/kits/components/TrustBanner.kt +0 -177
  71. package/compose/src/commonMain/kotlin/vn/momo/kits/components/datetimepicker/DateTimePicker.kt +0 -205
  72. package/compose/src/commonMain/kotlin/vn/momo/kits/components/datetimepicker/DateTimePickerTypes.kt +0 -29
  73. package/compose/src/commonMain/kotlin/vn/momo/kits/components/datetimepicker/DateTimePickerUtils.kt +0 -239
  74. package/compose/src/commonMain/kotlin/vn/momo/kits/components/datetimepicker/WheelPicker.kt +0 -191
  75. package/compose/src/commonMain/kotlin/vn/momo/kits/const/Colors.kt +0 -306
  76. package/compose/src/commonMain/kotlin/vn/momo/kits/const/Radius.kt +0 -12
  77. package/compose/src/commonMain/kotlin/vn/momo/kits/const/Spacing.kt +0 -13
  78. package/compose/src/commonMain/kotlin/vn/momo/kits/const/Theme.kt +0 -185
  79. package/compose/src/commonMain/kotlin/vn/momo/kits/const/Typography.kt +0 -285
  80. package/compose/src/commonMain/kotlin/vn/momo/kits/layout/Card.kt +0 -2
  81. package/compose/src/commonMain/kotlin/vn/momo/kits/layout/Item.kt +0 -35
  82. package/compose/src/commonMain/kotlin/vn/momo/kits/layout/Section.kt +0 -2
  83. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/AutomationId.kt +0 -59
  84. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/Clickable.kt +0 -68
  85. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/Conditional.kt +0 -11
  86. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/DeprecatedModifier.kt +0 -14
  87. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/Shadow.kt +0 -50
  88. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/Size.kt +0 -51
  89. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/BottomSheet.kt +0 -239
  90. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/ModalScreen.kt +0 -119
  91. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/Navigation.kt +0 -98
  92. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/NavigationContainer.kt +0 -161
  93. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/Navigator.kt +0 -331
  94. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/StackScreen.kt +0 -497
  95. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/bottomtab/BottomTab.kt +0 -162
  96. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/bottomtab/BottomTabBar.kt +0 -243
  97. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/bottomtab/CurvedContainer.kt +0 -86
  98. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/FloatingButton.kt +0 -187
  99. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/Header.kt +0 -279
  100. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/HeaderBackground.kt +0 -80
  101. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/HeaderRight.kt +0 -306
  102. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/HeaderTitle.kt +0 -32
  103. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/HeaderUser.kt +0 -370
  104. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/SnackBar.kt +0 -132
  105. package/compose/src/commonMain/kotlin/vn/momo/kits/platform/Platform.kt +0 -42
  106. package/compose/src/commonMain/kotlin/vn/momo/kits/utils/Icons.kt +0 -1329
  107. package/compose/src/commonMain/kotlin/vn/momo/kits/utils/Resources.kt +0 -62
  108. package/compose/src/commonMain/kotlin/vn/momo/kits/utils/Tracking.kt +0 -15
  109. package/compose/src/commonMain/kotlin/vn/momo/kits/utils/Utils.kt +0 -88
  110. package/compose/src/iosMain/kotlin/vn/momo/kits/platform/Platform.ios.kt +0 -149
  111. package/gradle/libs.versions.toml +0 -57
  112. package/gradle/wrapper/gradle-wrapper.jar +0 -0
  113. package/gradle/wrapper/gradle-wrapper.properties +0 -8
  114. package/gradle.properties +0 -26
  115. package/gradlew +0 -252
  116. package/gradlew.bat +0 -94
  117. 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
- }