@momo-kits/native-kits 0.152.4-beta.6 → 0.152.4-maxapi

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 (155) hide show
  1. package/CODE_OF_CONDUCT.md +133 -0
  2. package/CONTRIBUTING.md +114 -0
  3. package/LICENSE +20 -0
  4. package/README.md +7 -0
  5. package/build.gradle.kts +32 -0
  6. package/compose/MoMoComposeKits.podspec +54 -0
  7. package/compose/build.gradle.kts +149 -0
  8. package/compose/src/androidMain/AndroidManifest.xml +2 -0
  9. package/compose/src/androidMain/kotlin/vn/momo/kits/platform/Platform.android.kt +105 -0
  10. package/compose/src/commonMain/composeResources/files/lottie_circle_loader.json +1 -0
  11. package/compose/src/commonMain/composeResources/font/momosignature.otf +0 -0
  12. package/compose/src/commonMain/composeResources/font/momotrustdisplay.otf +0 -0
  13. package/compose/src/commonMain/composeResources/font/sfprotext_black.otf +0 -0
  14. package/compose/src/commonMain/composeResources/font/sfprotext_black.ttf +0 -0
  15. package/compose/src/commonMain/composeResources/font/sfprotext_bold.ttf +0 -0
  16. package/compose/src/commonMain/composeResources/font/sfprotext_heavy.ttf +0 -0
  17. package/compose/src/commonMain/composeResources/font/sfprotext_light.ttf +0 -0
  18. package/compose/src/commonMain/composeResources/font/sfprotext_medium.ttf +0 -0
  19. package/compose/src/commonMain/composeResources/font/sfprotext_regular.ttf +0 -0
  20. package/compose/src/commonMain/composeResources/font/sfprotext_semibold.ttf +0 -0
  21. package/compose/src/commonMain/composeResources/font/sfprotext_thin.otf +0 -0
  22. package/compose/src/commonMain/composeResources/font/sfprotext_thin.ttf +0 -0
  23. package/compose/src/commonMain/composeResources/font/sfprotext_ultralight.otf +0 -0
  24. package/compose/src/commonMain/composeResources/font/sfprotext_ultralight.ttf +0 -0
  25. package/compose/src/commonMain/kotlin/vn/momo/kits/application/AnimationSearchInput.kt +57 -0
  26. package/compose/src/commonMain/kotlin/vn/momo/kits/application/FloatingButton.kt +201 -0
  27. package/compose/src/commonMain/kotlin/vn/momo/kits/application/Header.kt +222 -0
  28. package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderAnimated.kt +48 -0
  29. package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderBackground.kt +86 -0
  30. package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderDefault.kt +76 -0
  31. package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderExtended.kt +76 -0
  32. package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderRight.kt +306 -0
  33. package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderTitle.kt +33 -0
  34. package/compose/src/commonMain/kotlin/vn/momo/kits/application/LiteScreen.kt +715 -0
  35. package/compose/src/commonMain/kotlin/vn/momo/kits/application/NavigationContainer.kt +214 -0
  36. package/compose/src/commonMain/kotlin/vn/momo/kits/application/Screen.kt +236 -0
  37. package/compose/src/commonMain/kotlin/vn/momo/kits/application/useHeaderSearchAnimation.kt +69 -0
  38. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Badge.kt +77 -0
  39. package/compose/src/commonMain/kotlin/vn/momo/kits/components/BadgeDot.kt +27 -0
  40. package/compose/src/commonMain/kotlin/vn/momo/kits/components/BadgeRibbon.kt +334 -0
  41. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Button.kt +345 -0
  42. package/compose/src/commonMain/kotlin/vn/momo/kits/components/CheckBox.kt +90 -0
  43. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Chip.kt +131 -0
  44. package/compose/src/commonMain/kotlin/vn/momo/kits/components/CupertinoOverscroll.kt +543 -0
  45. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Divider.kt +23 -0
  46. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Icon.kt +58 -0
  47. package/compose/src/commonMain/kotlin/vn/momo/kits/components/IconButton.kt +143 -0
  48. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Image.kt +179 -0
  49. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Information.kt +111 -0
  50. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Input.kt +384 -0
  51. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputDropDown.kt +160 -0
  52. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputMoney.kt +234 -0
  53. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputOTP.kt +223 -0
  54. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputPhoneNumber.kt +232 -0
  55. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputSearch.kt +236 -0
  56. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputTextArea.kt +228 -0
  57. package/compose/src/commonMain/kotlin/vn/momo/kits/components/LazyColumnWithBouncing.kt +364 -0
  58. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PaginationDot.kt +50 -0
  59. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PaginationNumber.kt +34 -0
  60. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PaginationScroll.kt +85 -0
  61. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PaginationWhiteDot.kt +33 -0
  62. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PopupNotify.kt +338 -0
  63. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PopupPromotion.kt +95 -0
  64. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Radio.kt +64 -0
  65. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Skeleton.kt +89 -0
  66. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Switch.kt +91 -0
  67. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Tag.kt +86 -0
  68. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Text.kt +84 -0
  69. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Title.kt +208 -0
  70. package/compose/src/commonMain/kotlin/vn/momo/kits/components/TrustBanner.kt +172 -0
  71. package/compose/src/commonMain/kotlin/vn/momo/kits/components/datetimepicker/DateTimePicker.kt +199 -0
  72. package/compose/src/commonMain/kotlin/vn/momo/kits/components/datetimepicker/DateTimePickerTypes.kt +29 -0
  73. package/compose/src/commonMain/kotlin/vn/momo/kits/components/datetimepicker/DateTimePickerUtils.kt +237 -0
  74. package/compose/src/commonMain/kotlin/vn/momo/kits/components/datetimepicker/WheelPicker.kt +191 -0
  75. package/compose/src/commonMain/kotlin/vn/momo/kits/const/Colors.kt +306 -0
  76. package/compose/src/commonMain/kotlin/vn/momo/kits/const/Radius.kt +12 -0
  77. package/compose/src/commonMain/kotlin/vn/momo/kits/const/Spacing.kt +13 -0
  78. package/compose/src/commonMain/kotlin/vn/momo/kits/const/Theme.kt +191 -0
  79. package/compose/src/commonMain/kotlin/vn/momo/kits/const/Typography.kt +258 -0
  80. package/compose/src/commonMain/kotlin/vn/momo/kits/layout/Card.kt +2 -0
  81. package/compose/src/commonMain/kotlin/vn/momo/kits/layout/Item.kt +35 -0
  82. package/compose/src/commonMain/kotlin/vn/momo/kits/layout/Section.kt +2 -0
  83. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/AutomationId.kt +59 -0
  84. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/Clickable.kt +68 -0
  85. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/Conditional.kt +11 -0
  86. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/Shadow.kt +49 -0
  87. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/Size.kt +51 -0
  88. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/BottomSheet.kt +232 -0
  89. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/ModalScreen.kt +111 -0
  90. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/Navigation.kt +94 -0
  91. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/NavigationContainer.kt +159 -0
  92. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/Navigator.kt +232 -0
  93. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/ScaleSizeScope.kt +17 -0
  94. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/StackScreen.kt +459 -0
  95. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/bottomtab/BottomTab.kt +169 -0
  96. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/bottomtab/BottomTabBar.kt +216 -0
  97. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/bottomtab/CurvedContainer.kt +86 -0
  98. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/FloatingButton.kt +180 -0
  99. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/Header.kt +251 -0
  100. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/HeaderBackground.kt +80 -0
  101. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/HeaderRight.kt +306 -0
  102. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/HeaderTitle.kt +31 -0
  103. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/HeaderUser.kt +385 -0
  104. package/compose/src/commonMain/kotlin/vn/momo/kits/platform/Platform.kt +38 -0
  105. package/compose/src/commonMain/kotlin/vn/momo/kits/utils/Icons.kt +1329 -0
  106. package/compose/src/commonMain/kotlin/vn/momo/kits/utils/Resources.kt +62 -0
  107. package/compose/src/commonMain/kotlin/vn/momo/kits/utils/Utils.kt +88 -0
  108. package/compose/src/iosMain/kotlin/vn/momo/kits/platform/Platform.ios.kt +144 -0
  109. package/gradle.properties +19 -0
  110. package/gradlew +240 -0
  111. package/gradlew.bat +91 -0
  112. package/ios/Application/ApplicationEnvironment.swift +50 -0
  113. package/ios/Application/Components.swift +263 -0
  114. package/ios/Application/ComposeApi.swift +22 -0
  115. package/ios/Application/FloatingButton.swift +172 -0
  116. package/ios/Application/HeaderRight.swift +271 -0
  117. package/ios/Application/Screen.swift +249 -0
  118. package/ios/Badge/BadgeDot.swift +31 -0
  119. package/ios/Button/Button.swift +211 -0
  120. package/ios/CalculatorKeyboard/CalculatorKeyboard.swift +126 -0
  121. package/ios/Checkbox/Checkbox.swift +81 -0
  122. package/ios/Chip/Chip.swift +96 -0
  123. package/ios/Colors+Radius+Spacing/Colors.swift +172 -0
  124. package/ios/Colors+Radius+Spacing/Radius.swift +22 -0
  125. package/ios/Colors+Radius+Spacing/Spacing.swift +12 -0
  126. package/ios/Extensions/Color++.swift +25 -0
  127. package/ios/Icon/Icon.swift +51 -0
  128. package/ios/Image/Image.swift +70 -0
  129. package/ios/Input/Input.swift +207 -0
  130. package/ios/Input/InputPhoneNumber.swift +176 -0
  131. package/ios/Input/InputSearch.swift +238 -0
  132. package/ios/Input/InputTextArea.swift +242 -0
  133. package/ios/Lottie/LottieView.swift +86 -0
  134. package/ios/OTPKeyboard/KeyboardButton.swift +41 -0
  135. package/ios/OTPKeyboard/OTPKeyboard.swift +145 -0
  136. package/ios/Popup/PopupDisplay.swift +284 -0
  137. package/ios/Popup/PopupInput.swift +96 -0
  138. package/ios/Popup/PopupPromotion.swift +73 -0
  139. package/ios/PopupView/FullscreenPopup.swift +251 -0
  140. package/ios/PopupView/Modifiers.swift +158 -0
  141. package/ios/PopupView/PopupView.swift +289 -0
  142. package/ios/PopupView/Utils++.swift +281 -0
  143. package/ios/ScrollIndicator/ScrollIndicator.swift +110 -0
  144. package/ios/Swipeable/SwipeCell.swift +278 -0
  145. package/ios/Swipeable/SwipeCellModel.swift +86 -0
  146. package/ios/Switch/Switch.swift +44 -0
  147. package/ios/Template/Logo/Logo.swift +75 -0
  148. package/ios/Template/TrustBanner/TrustBanner.swift +120 -0
  149. package/ios/Theme.md +18 -0
  150. package/ios/Typography/Text.swift +140 -0
  151. package/ios/Typography/Typography.swift +95 -0
  152. package/ios/native-kits.podspec +18 -0
  153. package/package.json +6 -7
  154. package/settings.gradle.kts +25 -0
  155. package/shared/build.gradle.kts +0 -74
@@ -0,0 +1,385 @@
1
+ package vn.momo.kits.navigation.component
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.Box
7
+ import androidx.compose.foundation.layout.Column
8
+ import androidx.compose.foundation.layout.Row
9
+ import androidx.compose.foundation.layout.Spacer
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.layout.widthIn
16
+ import androidx.compose.foundation.shape.CircleShape
17
+ import androidx.compose.foundation.shape.RoundedCornerShape
18
+ import androidx.compose.runtime.Composable
19
+ import androidx.compose.runtime.Immutable
20
+ import androidx.compose.runtime.remember
21
+ import androidx.compose.ui.Alignment
22
+ import androidx.compose.ui.Modifier
23
+ import androidx.compose.ui.draw.clip
24
+ import androidx.compose.ui.draw.clipToBounds
25
+ import androidx.compose.ui.layout.ContentScale
26
+ import androidx.compose.ui.text.style.TextOverflow
27
+ import androidx.compose.ui.unit.Dp
28
+ import androidx.compose.ui.unit.dp
29
+ import androidx.compose.ui.unit.sp
30
+ import vn.momo.kits.components.Image
31
+ import vn.momo.kits.components.Options
32
+ import vn.momo.kits.components.Skeleton
33
+ import vn.momo.kits.components.Text
34
+ import vn.momo.kits.const.AppTheme
35
+ import vn.momo.kits.const.Colors
36
+ import vn.momo.kits.const.Spacing
37
+ import vn.momo.kits.const.Typography
38
+ import vn.momo.kits.const.scaleSize
39
+ import vn.momo.kits.modifier.activeOpacityClickable
40
+ import vn.momo.kits.navigation.component.HeaderTitle.User
41
+ import vn.momo.kits.platform.getScreenDimensions
42
+
43
+ @Composable
44
+ fun HeaderUser(
45
+ data: HeaderTitle
46
+ ) {
47
+ if (data !is User) return
48
+
49
+ if (data.isLoading) {
50
+ return TitleUserShimmer()
51
+ }
52
+
53
+ val maxWidth = getScreenDimensions().width.dp - scaleSize(172.dp)- (data.icons.size * 16).dp
54
+
55
+ Row(
56
+ modifier = Modifier
57
+ .fillMaxWidth()
58
+ .padding(vertical = Spacing.XS)
59
+ .activeOpacityClickable(enabled = data.onPress != null, onClick = { data.onPress?.invoke() }),
60
+ horizontalArrangement = Arrangement.SpaceBetween,
61
+ verticalAlignment = Alignment.CenterVertically
62
+ ) {
63
+ Row(
64
+ modifier = Modifier.widthIn(max = maxWidth),
65
+ verticalAlignment = Alignment.CenterVertically
66
+ ) {
67
+ Box(modifier = Modifier.size(Spacing.XXL)) {
68
+ AvatarGroup(urls = AvatarUrls(data.image ?: listOf()), title = data.title)
69
+ if (data.dotColor != null) {
70
+ Box(
71
+ modifier = Modifier
72
+ .align(Alignment.BottomEnd)
73
+ .size(10.dp)
74
+ .clip(CircleShape)
75
+ .background(data.dotColor)
76
+ )
77
+ }
78
+ }
79
+
80
+ Spacer(Modifier.width(6.dp))
81
+
82
+ Column(modifier = Modifier.weight(1f, fill = false)) {
83
+ Row(verticalAlignment = Alignment.CenterVertically) {
84
+ Text(
85
+ text = data.title,
86
+ color = data.tintColor,
87
+ style = Typography.actionXsBold,
88
+ maxLines = 1,
89
+ overflow = TextOverflow.Ellipsis
90
+ )
91
+ if (data.icons.isNotEmpty()) {
92
+ Spacer(Modifier.width(6.dp))
93
+ Row(verticalAlignment = Alignment.CenterVertically) {
94
+ data.icons.forEach { icon ->
95
+ RemoteIcon16(url = icon)
96
+ }
97
+ }
98
+ }
99
+ }
100
+
101
+ if (!data.subTitle.isNullOrEmpty()) {
102
+ Spacer(Modifier.height(2.dp))
103
+ Text(
104
+ text = data.subTitle,
105
+ color = data.tintColor,
106
+ style = Typography.descriptionXsRegular,
107
+ maxLines = 1,
108
+ overflow = TextOverflow.Ellipsis
109
+ )
110
+ }
111
+ }
112
+ }
113
+ }
114
+ }
115
+
116
+ @Composable
117
+ private fun TitleUserShimmer() {
118
+ val theme = AppTheme.current
119
+ Row(
120
+ modifier = Modifier
121
+ .fillMaxWidth()
122
+ .padding(vertical = Spacing.XS),
123
+ verticalAlignment = Alignment.CenterVertically
124
+ ) {
125
+ Box(
126
+ modifier = Modifier
127
+ .size(Spacing.XXL)
128
+ .clip(CircleShape)
129
+ .background(theme.colors.border.default)
130
+ ) {
131
+ Skeleton()
132
+ }
133
+ Spacer(Modifier.width(Spacing.M / 2))
134
+ Column(modifier = Modifier.fillMaxWidth()) {
135
+ Box(
136
+ modifier = Modifier
137
+ .height(18.dp)
138
+ .width(120.dp)
139
+ .clip(RoundedCornerShape(8.dp))
140
+ ) { Skeleton() }
141
+ Spacer(Modifier.height(Spacing.XXS))
142
+ Box(
143
+ modifier = Modifier
144
+ .height(12.dp)
145
+ .width(120.dp)
146
+ .clip(RoundedCornerShape(8.dp))
147
+ ) { Skeleton() }
148
+ }
149
+ }
150
+ }
151
+
152
+ @Composable
153
+ private fun AvatarGroup(
154
+ urls: AvatarUrls?,
155
+ title: String? = null,
156
+ size: Dp = Spacing.XXL
157
+ ) {
158
+ val theme = AppTheme.current
159
+ val modifierBorder = remember {
160
+ Modifier.clip(CircleShape).border(width = (0.5).dp, color = theme.colors.border.default, shape = CircleShape)
161
+ }
162
+
163
+ when (urls?.items?.size) {
164
+ 0 -> InitialsAvatar(
165
+ modifier = modifierBorder,
166
+ name = title ?: "",
167
+ fallbackInitials = null,
168
+ size = size
169
+ )
170
+ 1 -> SingleAvatar(modifier = modifierBorder, urls.items[0], size)
171
+ 2 -> TwoAvatar(modifier = modifierBorder, urls, size)
172
+ 3 -> ThreeAvatar(modifier = modifierBorder, urls, size)
173
+ 4 -> FourAvatar(modifier = modifierBorder, urls, size)
174
+ else -> ManyAvatar(modifier = modifierBorder, urls!!, size)
175
+ }
176
+ }
177
+
178
+ @Composable
179
+ private fun SingleAvatar(modifier: Modifier = Modifier, url: String, size: Dp) {
180
+ Image(
181
+ source = url,
182
+ options = Options(
183
+ contentScale = ContentScale.Crop
184
+ ),
185
+ modifier = modifier
186
+ .size(size)
187
+ )
188
+ }
189
+
190
+ @Composable
191
+ private fun TwoAvatar(modifier: Modifier = Modifier, urls: AvatarUrls, size: Dp) {
192
+ val child = 24.dp
193
+ Box(modifier = Modifier.size(size)) {
194
+ Image(
195
+ source = urls.items[0],
196
+ options = Options(
197
+ contentScale = ContentScale.Crop
198
+ ),
199
+ modifier = modifier
200
+ .size(child)
201
+ .align(Alignment.TopEnd)
202
+ )
203
+ Image(
204
+ source = urls.items[1],
205
+ options = Options(
206
+ contentScale = ContentScale.Crop
207
+ ),
208
+ modifier = modifier
209
+ .size(child)
210
+ .align(Alignment.BottomStart)
211
+ )
212
+ }
213
+ }
214
+
215
+ @Composable
216
+ private fun ThreeAvatar(modifier: Modifier = Modifier, urls: AvatarUrls, size: Dp) {
217
+ val child = 16.dp
218
+ Box(modifier = Modifier.size(size).padding(2.dp)) {
219
+ Image(
220
+ source = urls.items[0],
221
+ options = Options(
222
+ contentScale = ContentScale.Crop
223
+ ),
224
+ modifier = modifier
225
+ .size(child)
226
+ .align(Alignment.BottomEnd)
227
+ )
228
+ Image(
229
+ source = urls.items[1],
230
+ options = Options(
231
+ contentScale = ContentScale.Crop
232
+ ),
233
+ modifier = modifier
234
+ .size(child)
235
+ .align(Alignment.TopCenter)
236
+ )
237
+ Image(
238
+ source = urls.items[2],
239
+ options = Options(
240
+ contentScale = ContentScale.Crop
241
+ ),
242
+ modifier = modifier
243
+ .size(child)
244
+ .align(Alignment.BottomStart)
245
+ )
246
+ }
247
+ }
248
+
249
+ @Composable
250
+ private fun FourAvatar(modifier: Modifier = Modifier, urls: AvatarUrls, size: Dp) {
251
+ val child = 16.dp
252
+ Box(modifier = Modifier.size(size).padding(1.dp)) {
253
+ Image(
254
+ source = urls.items[0],
255
+ options = Options(
256
+ contentScale = ContentScale.Crop
257
+ ),
258
+ modifier = modifier
259
+ .size(child)
260
+ .align(Alignment.BottomStart)
261
+ )
262
+ Image(
263
+ source = urls.items[1],
264
+ options = Options(
265
+ contentScale = ContentScale.Crop
266
+ ),
267
+ modifier = modifier
268
+ .size(child)
269
+ .align(Alignment.BottomEnd)
270
+ )
271
+ Image(
272
+ source = urls.items[2],
273
+ options = Options(
274
+ contentScale = ContentScale.Crop
275
+ ),
276
+ modifier = modifier
277
+ .size(child)
278
+ .align(Alignment.TopEnd)
279
+ )
280
+ Image(
281
+ source = urls.items[3],
282
+ options = Options(
283
+ contentScale = ContentScale.Crop
284
+ ),
285
+ modifier = modifier
286
+ .size(child)
287
+ .align(Alignment.TopStart)
288
+ )
289
+ }
290
+ }
291
+
292
+ @Composable
293
+ private fun ManyAvatar(modifier: Modifier = Modifier, urls: AvatarUrls, size: Dp) {
294
+ val child = 16.dp
295
+ val more = urls.items.size - 3
296
+ Box(modifier = Modifier.size(size).padding(1.dp)) {
297
+ Image(
298
+ source = urls.items[0],
299
+ options = Options(
300
+ contentScale = ContentScale.Crop
301
+ ),
302
+ modifier = modifier
303
+ .size(child)
304
+ .align(Alignment.BottomStart)
305
+ )
306
+ Image(
307
+ source = urls.items[1],
308
+ options = Options(
309
+ contentScale = ContentScale.Crop
310
+ ),
311
+ modifier = modifier
312
+ .size(child)
313
+ .align(Alignment.TopEnd)
314
+ )
315
+ Image(
316
+ source = urls.items[2],
317
+ options = Options(
318
+ contentScale = ContentScale.Crop
319
+ ),
320
+ modifier = modifier
321
+ .size(child)
322
+ .align(Alignment.TopStart)
323
+ )
324
+ Box(
325
+ modifier = modifier
326
+ .size(child)
327
+ .align(Alignment.BottomEnd)
328
+ .background(Colors.pink_09)
329
+ .padding(1.dp)
330
+ .clipToBounds(),
331
+ contentAlignment = Alignment.Center
332
+ ) {
333
+ Text(
334
+ text = "+$more",
335
+ color = Colors.pink_03,
336
+ style = Typography.descriptionXsRegular.copy(fontSize = 8.sp),
337
+ maxLines = 1,
338
+ overflow = TextOverflow.Visible
339
+ )
340
+ }
341
+ }
342
+ }
343
+
344
+ @Composable
345
+ private fun InitialsAvatar(
346
+ modifier: Modifier = Modifier,
347
+ name: String,
348
+ fallbackInitials: String? = null,
349
+ size: Dp = Spacing.XXL
350
+ ) {
351
+ val initials = remember(name, fallbackInitials) {
352
+ fallbackInitials ?: run {
353
+ val words = name.trim().split(Regex("\\s+")).takeLast(2)
354
+ words.joinToString("") { it.firstOrNull()?.uppercase() ?: "" }
355
+ }
356
+ }
357
+ Box(
358
+ modifier = modifier
359
+ .size(size)
360
+ .background(Colors.pink_09),
361
+ contentAlignment = Alignment.Center
362
+ ) {
363
+ Text(
364
+ text = initials,
365
+ color = Colors.pink_03,
366
+ style = Typography.descriptionXsRegular
367
+ )
368
+ }
369
+ }
370
+
371
+ @Composable
372
+ private fun RemoteIcon16(url: String) {
373
+ Image(
374
+ source = url,
375
+ options = Options(
376
+ contentScale = ContentScale.Crop
377
+ ),
378
+ modifier = Modifier
379
+ .size(16.dp)
380
+ .clip(RoundedCornerShape(4.dp)),
381
+ )
382
+ }
383
+
384
+ @Immutable
385
+ data class AvatarUrls(val items: List<String>)
@@ -0,0 +1,38 @@
1
+ package vn.momo.kits.platform
2
+
3
+ import androidx.compose.runtime.Composable
4
+ import androidx.compose.ui.Modifier
5
+ import androidx.compose.ui.graphics.Color
6
+ import androidx.compose.ui.graphics.NativePaint
7
+ import androidx.compose.ui.unit.Dp
8
+
9
+ data class ScreenDimension(
10
+ val width: Int,
11
+ val height: Int,
12
+ )
13
+
14
+ expect fun getPlatformName(): String
15
+
16
+ @Composable
17
+ expect fun getScreenDimensions(): ScreenDimension
18
+
19
+ expect fun NativePaint.setMaskFilter(blurRadius: Float)
20
+
21
+ @Composable
22
+ expect fun getStatusBarHeight(): Dp
23
+
24
+ @Composable
25
+ expect fun BackHandler(enabled: Boolean, onBack: () -> Unit)
26
+
27
+ @Composable
28
+ expect fun getScreenHeight(): Dp
29
+
30
+ expect fun getAndroidBuildVersion(): Int
31
+
32
+ @Composable
33
+ expect fun LottieAnimation(
34
+ path: String,
35
+ tintColor: Color? = null,
36
+ bgColor: Color? = null,
37
+ modifier: Modifier = Modifier
38
+ )