@momo-kits/native-kits 0.157.1-debug → 0.157.1-sp.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 (118) hide show
  1. package/ios/Application/HeaderRight.swift +1 -1
  2. package/package.json +1 -1
  3. package/build.gradle.kts +0 -11
  4. package/compose/build.gradle.kts +0 -180
  5. package/compose/build.gradle.kts.backup +0 -180
  6. package/compose/compose.podspec +0 -54
  7. package/compose/src/androidMain/kotlin/vn/momo/kits/platform/Platform.android.kt +0 -110
  8. package/compose/src/commonMain/composeResources/font/momosignature.otf +0 -0
  9. package/compose/src/commonMain/composeResources/font/momotrustdisplay.otf +0 -0
  10. package/compose/src/commonMain/composeResources/font/sfprotext_black.otf +0 -0
  11. package/compose/src/commonMain/composeResources/font/sfprotext_black.ttf +0 -0
  12. package/compose/src/commonMain/composeResources/font/sfprotext_bold.ttf +0 -0
  13. package/compose/src/commonMain/composeResources/font/sfprotext_heavy.ttf +0 -0
  14. package/compose/src/commonMain/composeResources/font/sfprotext_light.ttf +0 -0
  15. package/compose/src/commonMain/composeResources/font/sfprotext_medium.ttf +0 -0
  16. package/compose/src/commonMain/composeResources/font/sfprotext_regular.ttf +0 -0
  17. package/compose/src/commonMain/composeResources/font/sfprotext_semibold.ttf +0 -0
  18. package/compose/src/commonMain/composeResources/font/sfprotext_thin.otf +0 -0
  19. package/compose/src/commonMain/composeResources/font/sfprotext_thin.ttf +0 -0
  20. package/compose/src/commonMain/composeResources/font/sfprotext_ultralight.otf +0 -0
  21. package/compose/src/commonMain/composeResources/font/sfprotext_ultralight.ttf +0 -0
  22. package/compose/src/commonMain/kotlin/vn/momo/kits/application/AnimationSearchInput.kt +0 -57
  23. package/compose/src/commonMain/kotlin/vn/momo/kits/application/Context.kt +0 -107
  24. package/compose/src/commonMain/kotlin/vn/momo/kits/application/FloatingButton.kt +0 -201
  25. package/compose/src/commonMain/kotlin/vn/momo/kits/application/Header.kt +0 -222
  26. package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderAnimated.kt +0 -48
  27. package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderBackground.kt +0 -86
  28. package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderDefault.kt +0 -76
  29. package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderExtended.kt +0 -76
  30. package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderRight.kt +0 -305
  31. package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderTitle.kt +0 -33
  32. package/compose/src/commonMain/kotlin/vn/momo/kits/application/LiteScreen.kt +0 -720
  33. package/compose/src/commonMain/kotlin/vn/momo/kits/application/NavigationContainer.kt +0 -121
  34. package/compose/src/commonMain/kotlin/vn/momo/kits/application/Screen.kt +0 -405
  35. package/compose/src/commonMain/kotlin/vn/momo/kits/application/useHeaderSearchAnimation.kt +0 -69
  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 -339
  41. package/compose/src/commonMain/kotlin/vn/momo/kits/components/CheckBox.kt +0 -94
  42. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Chip.kt +0 -136
  43. package/compose/src/commonMain/kotlin/vn/momo/kits/components/CupertinoOverscroll.kt +0 -543
  44. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Divider.kt +0 -23
  45. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Icon.kt +0 -76
  46. package/compose/src/commonMain/kotlin/vn/momo/kits/components/IconButton.kt +0 -148
  47. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Image.kt +0 -188
  48. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Information.kt +0 -116
  49. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Input.kt +0 -448
  50. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputDropDown.kt +0 -172
  51. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputMoney.kt +0 -255
  52. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputOTP.kt +0 -231
  53. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputPhoneNumber.kt +0 -233
  54. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputSearch.kt +0 -254
  55. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputTextArea.kt +0 -241
  56. package/compose/src/commonMain/kotlin/vn/momo/kits/components/LazyColumnWithBouncing.kt +0 -364
  57. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PaginationDot.kt +0 -56
  58. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PaginationNumber.kt +0 -41
  59. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PaginationScroll.kt +0 -92
  60. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PaginationWhiteDot.kt +0 -40
  61. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PopupNotify.kt +0 -352
  62. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PopupPromotion.kt +0 -103
  63. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Radio.kt +0 -70
  64. package/compose/src/commonMain/kotlin/vn/momo/kits/components/ScaleSizeScope.kt +0 -17
  65. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Skeleton.kt +0 -96
  66. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Switch.kt +0 -96
  67. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Tag.kt +0 -92
  68. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Text.kt +0 -130
  69. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Title.kt +0 -214
  70. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Tooltip.kt +0 -576
  71. package/compose/src/commonMain/kotlin/vn/momo/kits/components/TrustBanner.kt +0 -177
  72. package/compose/src/commonMain/kotlin/vn/momo/kits/components/datetimepicker/DateTimePicker.kt +0 -205
  73. package/compose/src/commonMain/kotlin/vn/momo/kits/components/datetimepicker/DateTimePickerTypes.kt +0 -29
  74. package/compose/src/commonMain/kotlin/vn/momo/kits/components/datetimepicker/DateTimePickerUtils.kt +0 -239
  75. package/compose/src/commonMain/kotlin/vn/momo/kits/components/datetimepicker/WheelPicker.kt +0 -191
  76. package/compose/src/commonMain/kotlin/vn/momo/kits/const/Colors.kt +0 -306
  77. package/compose/src/commonMain/kotlin/vn/momo/kits/const/Radius.kt +0 -12
  78. package/compose/src/commonMain/kotlin/vn/momo/kits/const/Spacing.kt +0 -13
  79. package/compose/src/commonMain/kotlin/vn/momo/kits/const/Theme.kt +0 -185
  80. package/compose/src/commonMain/kotlin/vn/momo/kits/const/Typography.kt +0 -285
  81. package/compose/src/commonMain/kotlin/vn/momo/kits/layout/Card.kt +0 -2
  82. package/compose/src/commonMain/kotlin/vn/momo/kits/layout/Item.kt +0 -35
  83. package/compose/src/commonMain/kotlin/vn/momo/kits/layout/Section.kt +0 -2
  84. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/AutomationId.kt +0 -59
  85. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/Clickable.kt +0 -68
  86. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/Conditional.kt +0 -11
  87. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/DeprecatedModifier.kt +0 -14
  88. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/Shadow.kt +0 -50
  89. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/Size.kt +0 -51
  90. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/BottomSheet.kt +0 -239
  91. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/ModalScreen.kt +0 -119
  92. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/Navigation.kt +0 -98
  93. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/NavigationContainer.kt +0 -161
  94. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/Navigator.kt +0 -331
  95. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/StackScreen.kt +0 -497
  96. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/bottomtab/BottomTab.kt +0 -162
  97. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/bottomtab/BottomTabBar.kt +0 -243
  98. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/bottomtab/CurvedContainer.kt +0 -86
  99. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/FloatingButton.kt +0 -187
  100. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/Header.kt +0 -279
  101. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/HeaderBackground.kt +0 -80
  102. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/HeaderRight.kt +0 -306
  103. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/HeaderTitle.kt +0 -32
  104. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/HeaderUser.kt +0 -370
  105. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/SnackBar.kt +0 -132
  106. package/compose/src/commonMain/kotlin/vn/momo/kits/platform/Platform.kt +0 -42
  107. package/compose/src/commonMain/kotlin/vn/momo/kits/utils/Icons.kt +0 -1329
  108. package/compose/src/commonMain/kotlin/vn/momo/kits/utils/Resources.kt +0 -62
  109. package/compose/src/commonMain/kotlin/vn/momo/kits/utils/Tracking.kt +0 -15
  110. package/compose/src/commonMain/kotlin/vn/momo/kits/utils/Utils.kt +0 -88
  111. package/compose/src/iosMain/kotlin/vn/momo/kits/platform/Platform.ios.kt +0 -149
  112. package/gradle/libs.versions.toml +0 -57
  113. package/gradle/wrapper/gradle-wrapper.jar +0 -0
  114. package/gradle/wrapper/gradle-wrapper.properties +0 -8
  115. package/gradle.properties +0 -26
  116. package/gradlew +0 -252
  117. package/gradlew.bat +0 -94
  118. package/settings.gradle.kts +0 -52
@@ -1,339 +0,0 @@
1
- package vn.momo.kits.components
2
-
3
- import androidx.compose.animation.core.animateDpAsState
4
- import androidx.compose.animation.core.animateFloatAsState
5
- import androidx.compose.animation.core.tween
6
- import androidx.compose.foundation.background
7
- import androidx.compose.foundation.border
8
- import androidx.compose.foundation.clickable
9
- import androidx.compose.foundation.interaction.MutableInteractionSource
10
- import androidx.compose.foundation.interaction.collectIsPressedAsState
11
- import androidx.compose.foundation.layout.Arrangement
12
- import androidx.compose.foundation.layout.Box
13
- import androidx.compose.foundation.layout.Row
14
- import androidx.compose.foundation.layout.fillMaxWidth
15
- import androidx.compose.foundation.layout.height
16
- import androidx.compose.foundation.layout.padding
17
- import androidx.compose.foundation.layout.size
18
- import androidx.compose.foundation.shape.RoundedCornerShape
19
- import androidx.compose.runtime.Composable
20
- import androidx.compose.runtime.getValue
21
- import androidx.compose.runtime.remember
22
- import androidx.compose.ui.Alignment
23
- import androidx.compose.ui.Modifier
24
- import androidx.compose.ui.draw.alpha
25
- import androidx.compose.ui.draw.clip
26
- import androidx.compose.ui.graphics.Color
27
- import androidx.compose.ui.text.TextStyle
28
- import androidx.compose.ui.text.style.TextOverflow
29
- import androidx.compose.ui.unit.Dp
30
- import androidx.compose.ui.unit.dp
31
- import vn.momo.kits.application.IsShowBaseLineDebug
32
- import vn.momo.kits.const.AppTheme
33
- import vn.momo.kits.const.Colors
34
- import vn.momo.kits.const.Radius
35
- import vn.momo.kits.const.Spacing
36
- import vn.momo.kits.const.Typography
37
- import vn.momo.kits.modifier.conditional
38
- import vn.momo.kits.platform.LottieAnimation
39
-
40
- enum class ButtonType {
41
- PRIMARY,
42
- SECONDARY,
43
- TONAL,
44
- OUTLINE,
45
- DANGER,
46
- TEXT,
47
- DISABLED
48
- }
49
-
50
- data class ButtonSpecs(
51
- val height: Dp,
52
- val radius: Dp,
53
- val padding: Dp,
54
- val width: Dp,
55
- )
56
-
57
- enum class Size(val value: ButtonSpecs) {
58
- LARGE(
59
- ButtonSpecs(
60
- height = 48.dp,
61
- radius = Radius.S,
62
- padding = Spacing.L,
63
- width = 128.dp
64
- )
65
- ),
66
- MEDIUM(
67
- ButtonSpecs(
68
- height = 36.dp,
69
- radius = Radius.S,
70
- padding = Spacing.M,
71
- width = 80.dp
72
- )
73
- ),
74
- SMALL(
75
- ButtonSpecs(
76
- height = 28.dp,
77
- radius = Radius.S,
78
- padding = Spacing.S,
79
- width = 60.dp
80
- )
81
- )
82
- }
83
-
84
- private val styleCache = mapOf(
85
- Size.LARGE to Typography.actionDefaultBold,
86
- Size.MEDIUM to Typography.actionSBold,
87
- Size.SMALL to Typography.actionXsBold
88
- )
89
-
90
- private val iconSizeCache = mapOf(
91
- Size.LARGE to 24.dp,
92
- Size.MEDIUM to 16.dp,
93
- Size.SMALL to 16.dp
94
- )
95
-
96
- private val iconSpaceCache = mapOf(
97
- Size.SMALL to Spacing.XS,
98
- Size.MEDIUM to Spacing.S,
99
- Size.LARGE to Spacing.S
100
- )
101
-
102
- fun getStyle(size: Size): TextStyle {
103
- return styleCache[size] ?: Typography.actionDefaultBold
104
- }
105
-
106
- fun getIconSize(size: Size): Dp = iconSizeCache[size] ?: 24.dp
107
- fun getIconSpace(size: Size): Dp = iconSpaceCache[size] ?: Spacing.S
108
-
109
- @Composable
110
- fun getTextColor(loading: Boolean, type: ButtonType): Color {
111
- val theme = AppTheme.current
112
-
113
- return remember(type, theme, loading) {
114
- when (type) {
115
- ButtonType.DISABLED -> theme.colors.text.disable
116
- ButtonType.PRIMARY -> Colors.black_01
117
- ButtonType.SECONDARY -> theme.colors.text.default
118
- ButtonType.OUTLINE -> theme.colors.primary
119
- ButtonType.TONAL -> theme.colors.primary
120
- ButtonType.DANGER -> Colors.black_01
121
- ButtonType.TEXT -> theme.colors.primary
122
- }.withLoading(loading)
123
- }
124
- }
125
-
126
- @Composable
127
- fun RenderTitle(size: Size, title: String = "", textColor: Color) {
128
- val style = remember(size) { getStyle(size) }
129
- Text(
130
- style = style,
131
- text = title,
132
- color = textColor,
133
- overflow = TextOverflow.Ellipsis,
134
- maxLines = 1
135
- )
136
- }
137
-
138
- @Composable
139
- fun RenderIcon(
140
- size: Size,
141
- isIconLeft: Boolean,
142
- useTintColor: Boolean = true,
143
- icon: String = "",
144
- forceLoading: Boolean = false,
145
- bgColor: Color? = null,
146
- textColor: Color? = null,
147
- ) {
148
- val iconSize = remember(size) { getIconSize(size) }
149
- val margin = remember(size) { getIconSpace(size) }
150
- val color = if (useTintColor) textColor else Color.Unspecified
151
-
152
- val modifier = Modifier.padding(
153
- start = if (isIconLeft) 0.dp else margin,
154
- end = if (isIconLeft) margin else 0.dp
155
- )
156
-
157
- if (forceLoading) {
158
- Box(modifier) {
159
- LottieAnimation(
160
- modifier = Modifier.size(iconSize),
161
- bgColor = bgColor,
162
- tintColor = color,
163
- path = "files/lottie_circle_loader"
164
- )
165
- }
166
- } else if (icon.isNotEmpty()) {
167
- Icon(
168
- source = icon,
169
- color = color,
170
- size = iconSize,
171
- modifier = modifier
172
- )
173
- }
174
- }
175
-
176
- private fun shouldLoadingOnLeft(iconLeft: String, iconRight: String): Boolean {
177
- val hasLeft = iconLeft.isNotEmpty()
178
- val hasRight = iconRight.isNotEmpty()
179
- return when {
180
- !hasLeft && !hasRight -> true
181
- hasLeft && !hasRight -> true
182
- !hasLeft && hasRight -> false
183
- hasLeft && hasRight -> false
184
- else -> true
185
- }
186
- }
187
-
188
- @Composable
189
- fun getTypeStyle(
190
- type: ButtonType,
191
- color: Color? = AppTheme.current.colors.primary,
192
- size: Size,
193
- bgColor: Color,
194
- ): Modifier {
195
- val theme = AppTheme.current
196
- val radius = remember(size) { size.value.radius }
197
- val modifier = Modifier.background(bgColor)
198
-
199
- return remember(type, color, theme, radius, bgColor) {
200
- when (type) {
201
- ButtonType.DISABLED -> modifier
202
- .border(0.dp, Color.Unspecified, RoundedCornerShape(radius))
203
-
204
- ButtonType.PRIMARY -> modifier
205
- .border(0.dp, Color.Unspecified, RoundedCornerShape(radius))
206
-
207
- ButtonType.SECONDARY -> modifier
208
- .border(1.dp, theme.colors.border.default, RoundedCornerShape(radius))
209
-
210
- ButtonType.OUTLINE -> modifier
211
- .border(1.dp, color ?: theme.colors.primary, RoundedCornerShape(radius))
212
-
213
- ButtonType.TONAL -> modifier
214
- .border(0.dp, Color.Unspecified, RoundedCornerShape(radius))
215
-
216
- ButtonType.DANGER -> modifier
217
- .border(0.dp, Color.Unspecified, RoundedCornerShape(radius))
218
-
219
- ButtonType.TEXT -> modifier
220
- }
221
- }
222
- }
223
-
224
- @Composable
225
- fun getButtonBackgroundColor(
226
- loading: Boolean,
227
- type: ButtonType
228
- ): Color {
229
- val theme = AppTheme.current
230
-
231
- return remember(loading, type, theme) {
232
- when (type) {
233
- ButtonType.DISABLED -> theme.colors.background.disable.withLoading(loading)
234
- ButtonType.PRIMARY -> theme.colors.primary.withLoading(loading)
235
- ButtonType.SECONDARY -> theme.colors.background.surface.withLoading(loading)
236
- ButtonType.OUTLINE -> theme.colors.background.surface.withLoading(loading)
237
- ButtonType.TONAL -> theme.colors.background.tonal.withLoading(loading)
238
- ButtonType.DANGER -> theme.colors.error.primary.withLoading(loading)
239
- ButtonType.TEXT -> Color.Unspecified
240
- }
241
- }
242
- }
243
-
244
- fun Color.withLoading(loading: Boolean): Color =
245
- this.copy(alpha = if (loading) 0.75f else 1f)
246
-
247
- @Composable
248
- fun Button(
249
- onClick: () -> Unit,
250
- type: ButtonType = ButtonType.PRIMARY,
251
- size: Size = Size.LARGE,
252
- iconRight: String = "",
253
- iconLeft: String = "",
254
- title: String = "Button",
255
- loading: Boolean = false,
256
- useTintColor: Boolean = true,
257
- isFull: Boolean = true,
258
- modifier: Modifier = Modifier,
259
- ) {
260
- val radius = remember(size) { size.value.radius }
261
- val isEnabled = remember(type) { type != ButtonType.DISABLED }
262
- val loadingOnLeft = remember(iconLeft, iconRight) {
263
- shouldLoadingOnLeft(iconLeft, iconRight)
264
- }
265
-
266
- val sizeSpecs = remember(size) { size.value }
267
-
268
- val interactionSource = remember { MutableInteractionSource() }
269
- val isPressed by interactionSource.collectIsPressedAsState()
270
-
271
- val animatedPadding by animateDpAsState(
272
- targetValue = if (isPressed && isEnabled && !loading) 2.dp else 0.dp,
273
- animationSpec = tween(100),
274
- label = "pressPadding"
275
- )
276
-
277
- val targetAlpha = if (isPressed && isEnabled && !loading) 0.5f else 1f
278
- val alpha by animateFloatAsState(
279
- targetValue = targetAlpha,
280
- animationSpec = tween(100),
281
- label = "buttonPressAlpha"
282
- )
283
-
284
- val clickableModifier =
285
- if (isEnabled && !loading) {
286
- modifier
287
- .then(if (isFull) Modifier.fillMaxWidth() else Modifier)
288
- .clip(RoundedCornerShape(radius))
289
- .clickable(
290
- enabled = isEnabled && !loading,
291
- interactionSource = interactionSource,
292
- indication = null,
293
- onClick = onClick
294
- )
295
- .alpha(alpha)
296
- } else {
297
- modifier
298
- .then(if (isFull) Modifier.fillMaxWidth() else Modifier)
299
- .clip(RoundedCornerShape(radius))
300
- }
301
-
302
- val bgColor = getButtonBackgroundColor(loading, type)
303
- val textColor = getTextColor(loading, type)
304
-
305
- Row(
306
- modifier = clickableModifier
307
- .padding(horizontal = animatedPadding)
308
- .clip(RoundedCornerShape(radius))
309
- .then(getTypeStyle(type, size = size, bgColor = bgColor))
310
- .conditional(IsShowBaseLineDebug) {
311
- border(1.dp, Colors.blue_03)
312
- }
313
- .padding(horizontal = sizeSpecs.padding)
314
- .height(sizeSpecs.height),
315
- horizontalArrangement = Arrangement.Center,
316
- verticalAlignment = Alignment.CenterVertically,
317
- ) {
318
- RenderIcon(
319
- size = size,
320
- isIconLeft = true,
321
- useTintColor = useTintColor,
322
- icon = iconLeft,
323
- forceLoading = loading && loadingOnLeft,
324
- bgColor = bgColor,
325
- textColor = textColor
326
- )
327
- RenderTitle(size, title, textColor = textColor)
328
- RenderIcon(
329
- size = size,
330
- isIconLeft = false,
331
- useTintColor = useTintColor,
332
- icon = iconRight,
333
- forceLoading = loading && !loadingOnLeft,
334
- bgColor = bgColor,
335
- textColor = textColor
336
- )
337
- }
338
- }
339
-
@@ -1,94 +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.layout.Box
6
- import androidx.compose.foundation.layout.Row
7
- import androidx.compose.foundation.layout.Spacer
8
- import androidx.compose.foundation.layout.size
9
- import androidx.compose.foundation.shape.RoundedCornerShape
10
- import androidx.compose.runtime.Composable
11
- import androidx.compose.runtime.remember
12
- import androidx.compose.ui.Alignment
13
- import androidx.compose.ui.Modifier
14
- import androidx.compose.ui.graphics.Color
15
- import androidx.compose.ui.unit.dp
16
- import vn.momo.kits.application.IsShowBaseLineDebug
17
- import vn.momo.kits.const.AppTheme
18
- import vn.momo.kits.const.Colors
19
- import vn.momo.kits.const.Radius
20
- import vn.momo.kits.const.Spacing
21
- import vn.momo.kits.const.Typography
22
- import vn.momo.kits.modifier.activeOpacityClickable
23
- import vn.momo.kits.modifier.conditional
24
-
25
- // Pre-computed shape for performance
26
- private val checkboxShape = RoundedCornerShape(Radius.XS)
27
-
28
- @Composable
29
- fun CheckBox(
30
- disabled: Boolean = false,
31
- checked: Boolean = false,
32
- onCheckedChange: (Boolean) -> Unit,
33
- indeterminate: Boolean = false,
34
- title: String = "",
35
- ) {
36
- // Cache theme access
37
- val theme = AppTheme.current
38
-
39
- // Memoize color calculations to avoid repeated conditional logic
40
- val colors = remember(checked, disabled, theme) {
41
- when {
42
- disabled && checked -> Pair(theme.colors.background.tonal, theme.colors.background.tonal)
43
- disabled -> Pair(theme.colors.border.disable, Color.Transparent)
44
- checked -> Pair(theme.colors.primary, theme.colors.primary)
45
- else -> Pair(theme.colors.text.default, Color.Transparent)
46
- }
47
- }
48
-
49
- val (borderColor, backgroundColor) = colors
50
-
51
- // Memoize icon source to avoid repeated conditional check
52
- val iconSource = remember(indeterminate) {
53
- if (indeterminate) "navigation_minus" else "ic_checked"
54
- }
55
-
56
- // Memoize click handler to avoid lambda recreation
57
- val onClickHandler = remember(onCheckedChange, checked) {
58
- { onCheckedChange(!checked) }
59
- }
60
-
61
- Row(verticalAlignment = Alignment.CenterVertically) {
62
- Box(
63
- modifier = Modifier
64
- .size(20.dp)
65
- .background(backgroundColor, checkboxShape)
66
- .border(Spacing.XXS, borderColor, checkboxShape)
67
- .conditional(IsShowBaseLineDebug) {
68
- border(1.dp, Colors.blue_03)
69
- }
70
- .activeOpacityClickable(
71
- activeOpacity = 0.8f,
72
- onClick = onClickHandler,
73
- enabled = !disabled,
74
- ),
75
- ) {
76
- if (checked) {
77
- Icon(
78
- source = iconSource,
79
- size = 20.dp,
80
- color = Colors.black_01
81
- )
82
- }
83
- }
84
-
85
- if (title.isNotEmpty()) {
86
- Spacer(Modifier.size(Spacing.S))
87
- Text(
88
- style = Typography.descriptionDefaultRegular,
89
- text = title,
90
- )
91
- }
92
- }
93
-
94
- }
@@ -1,136 +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.layout.Arrangement
6
- import androidx.compose.foundation.layout.Row
7
- import androidx.compose.foundation.layout.height
8
- import androidx.compose.foundation.layout.padding
9
- import androidx.compose.foundation.layout.wrapContentWidth
10
- import androidx.compose.foundation.shape.RoundedCornerShape
11
- import androidx.compose.runtime.Composable
12
- import androidx.compose.runtime.Immutable
13
- import androidx.compose.ui.Alignment
14
- import androidx.compose.ui.Modifier
15
- import androidx.compose.ui.draw.clip
16
- import androidx.compose.ui.graphics.Color
17
- import androidx.compose.ui.text.style.TextAlign
18
- import androidx.compose.ui.text.style.TextOverflow
19
- import androidx.compose.ui.unit.dp
20
- import vn.momo.kits.const.AppTheme
21
- import vn.momo.kits.const.Colors
22
- import vn.momo.kits.const.Radius
23
- import vn.momo.kits.const.Typography
24
- import vn.momo.kits.application.IsShowBaseLineDebug
25
- import vn.momo.kits.const.scaleSize
26
- import vn.momo.kits.modifier.activeOpacityClickable
27
- import vn.momo.kits.modifier.conditional
28
- import vn.momo.kits.modifier.setAutomationId
29
-
30
- @Composable
31
- fun Chip(
32
- modifier: Modifier = Modifier,
33
- label: String? = "Label",
34
- iconLeft: String? = null,
35
- iconRight: String? = null,
36
- selected: Boolean = false,
37
- onClick: () -> Unit = {},
38
- size: ChipSize = ChipSize.LARGE,
39
- iconLeftTint: Color? = null,
40
- iconRightTint: Color? = null,
41
- backgroundColor: Color? = null,
42
- accessibilityLabel: String? = null,
43
- ) {
44
- val theme = AppTheme.current
45
- val bg = when {
46
- selected -> theme.colors.background.selected
47
- backgroundColor != null -> backgroundColor
48
- else -> Colors.black_03
49
- }
50
-
51
- val textColor = if (selected) theme.colors.primary else theme.colors.text.default
52
- val leftTint = if (selected) theme.colors.primary else iconLeftTint ?: theme.colors.text.default
53
- val rightTint = if (selected) theme.colors.primary else iconRightTint ?: theme.colors.text.default
54
-
55
- val dims = when (size) {
56
- ChipSize.SMALL -> ChipDefaults.Small
57
- ChipSize.LARGE -> ChipDefaults.Large
58
- }
59
-
60
- val (height, horizontal, iconSize, iconSpacing) =
61
- listOf(scaleSize(dims.height), scaleSize(dims.horizontal), scaleSize(dims.iconSize), scaleSize(dims.iconSpacing))
62
-
63
- val radius = scaleSize(Radius.L)
64
-
65
- Row(
66
- modifier
67
- .wrapContentWidth()
68
- .height(height.dp)
69
- .clip(RoundedCornerShape(radius))
70
- .background(bg)
71
- .conditional(selected) {
72
- Modifier.border(width = 2.dp, color = theme.colors.secondary, shape = RoundedCornerShape(radius))
73
- }
74
- .conditional(IsShowBaseLineDebug) {
75
- border(1.dp, Colors.blue_03)
76
- }
77
- .activeOpacityClickable {
78
- onClick()
79
- }
80
- .padding(horizontal = horizontal.dp)
81
- .conditional(accessibilityLabel != null) {
82
- setAutomationId(accessibilityLabel.toString())
83
- },
84
- verticalAlignment = Alignment.CenterVertically,
85
- horizontalArrangement = Arrangement.spacedBy(iconSpacing.dp)
86
- ) {
87
- if (iconLeft != null) {
88
- Icon(source = iconLeft, size = dims.iconSize.dp, color = leftTint)
89
- }
90
-
91
- if (!label.isNullOrEmpty()) {
92
- Text(
93
- text = label,
94
- textAlign = TextAlign.Center,
95
- color = textColor,
96
- style = when (size) {
97
- ChipSize.SMALL -> Typography.labelSMedium
98
- ChipSize.LARGE -> Typography.labelDefaultMedium
99
- },
100
- maxLines = 1,
101
- overflow = TextOverflow.Ellipsis,
102
- modifier = Modifier.weight(1f, fill = false),
103
- )
104
- }
105
-
106
- if (iconRight != null) {
107
- Icon(source = iconRight, size = iconSize.dp, color = rightTint)
108
- }
109
- }
110
- }
111
-
112
- enum class ChipSize { SMALL, LARGE }
113
-
114
- object ChipDefaults {
115
- @Immutable
116
- data class Dimensions(
117
- val height: Float,
118
- val horizontal: Float,
119
- val iconSize: Float,
120
- val iconSpacing: Float,
121
- )
122
-
123
- val Large = Dimensions(
124
- height = 32f,
125
- horizontal = 12f,
126
- iconSize = 20f,
127
- iconSpacing = 4f,
128
- )
129
-
130
- val Small = Dimensions(
131
- height = 24f,
132
- horizontal = 10f,
133
- iconSize = 16f,
134
- iconSpacing = 4f,
135
- )
136
- }