@momo-kits/native-kits 0.152.4-beta.9 → 0.152.4-klib.10

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/README.md +175 -5
  2. package/ios/Badge/Badge.swift +0 -6
  3. package/ios/Badge/BadgeRibbon.swift +77 -9
  4. package/ios/Button/Button.swift +7 -7
  5. package/ios/native-kits.podspec +18 -16
  6. package/package.json +2 -4
  7. package/CODE_OF_CONDUCT.md +0 -133
  8. package/CONTRIBUTING.md +0 -114
  9. package/LICENSE +0 -20
  10. package/build.gradle.kts +0 -32
  11. package/compose/MoMoComposeKits.podspec +0 -54
  12. package/compose/build.gradle.kts +0 -149
  13. package/compose/src/androidMain/AndroidManifest.xml +0 -2
  14. package/compose/src/androidMain/kotlin/vn/momo/kits/platform/Platform.android.kt +0 -105
  15. package/compose/src/commonMain/composeResources/files/lottie_circle_loader.json +0 -1
  16. package/compose/src/commonMain/composeResources/font/momosignature.otf +0 -0
  17. package/compose/src/commonMain/composeResources/font/momotrustdisplay.otf +0 -0
  18. package/compose/src/commonMain/composeResources/font/sfprotext_black.otf +0 -0
  19. package/compose/src/commonMain/composeResources/font/sfprotext_black.ttf +0 -0
  20. package/compose/src/commonMain/composeResources/font/sfprotext_bold.ttf +0 -0
  21. package/compose/src/commonMain/composeResources/font/sfprotext_heavy.ttf +0 -0
  22. package/compose/src/commonMain/composeResources/font/sfprotext_light.ttf +0 -0
  23. package/compose/src/commonMain/composeResources/font/sfprotext_medium.ttf +0 -0
  24. package/compose/src/commonMain/composeResources/font/sfprotext_regular.ttf +0 -0
  25. package/compose/src/commonMain/composeResources/font/sfprotext_semibold.ttf +0 -0
  26. package/compose/src/commonMain/composeResources/font/sfprotext_thin.otf +0 -0
  27. package/compose/src/commonMain/composeResources/font/sfprotext_thin.ttf +0 -0
  28. package/compose/src/commonMain/composeResources/font/sfprotext_ultralight.otf +0 -0
  29. package/compose/src/commonMain/composeResources/font/sfprotext_ultralight.ttf +0 -0
  30. package/compose/src/commonMain/kotlin/vn/momo/kits/application/AnimationSearchInput.kt +0 -57
  31. package/compose/src/commonMain/kotlin/vn/momo/kits/application/FloatingButton.kt +0 -201
  32. package/compose/src/commonMain/kotlin/vn/momo/kits/application/Header.kt +0 -222
  33. package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderAnimated.kt +0 -48
  34. package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderBackground.kt +0 -86
  35. package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderDefault.kt +0 -76
  36. package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderExtended.kt +0 -76
  37. package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderRight.kt +0 -306
  38. package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderTitle.kt +0 -33
  39. package/compose/src/commonMain/kotlin/vn/momo/kits/application/LiteScreen.kt +0 -715
  40. package/compose/src/commonMain/kotlin/vn/momo/kits/application/NavigationContainer.kt +0 -214
  41. package/compose/src/commonMain/kotlin/vn/momo/kits/application/Screen.kt +0 -236
  42. package/compose/src/commonMain/kotlin/vn/momo/kits/application/useHeaderSearchAnimation.kt +0 -69
  43. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Badge.kt +0 -77
  44. package/compose/src/commonMain/kotlin/vn/momo/kits/components/BadgeDot.kt +0 -27
  45. package/compose/src/commonMain/kotlin/vn/momo/kits/components/BadgeRibbon.kt +0 -334
  46. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Button.kt +0 -345
  47. package/compose/src/commonMain/kotlin/vn/momo/kits/components/CheckBox.kt +0 -90
  48. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Chip.kt +0 -131
  49. package/compose/src/commonMain/kotlin/vn/momo/kits/components/CupertinoOverscroll.kt +0 -543
  50. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Divider.kt +0 -23
  51. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Icon.kt +0 -58
  52. package/compose/src/commonMain/kotlin/vn/momo/kits/components/IconButton.kt +0 -143
  53. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Image.kt +0 -179
  54. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Information.kt +0 -111
  55. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Input.kt +0 -384
  56. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputDropDown.kt +0 -160
  57. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputMoney.kt +0 -234
  58. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputOTP.kt +0 -223
  59. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputPhoneNumber.kt +0 -232
  60. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputSearch.kt +0 -236
  61. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputTextArea.kt +0 -228
  62. package/compose/src/commonMain/kotlin/vn/momo/kits/components/LazyColumnWithBouncing.kt +0 -364
  63. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PaginationDot.kt +0 -50
  64. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PaginationNumber.kt +0 -34
  65. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PaginationScroll.kt +0 -85
  66. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PaginationWhiteDot.kt +0 -33
  67. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PopupNotify.kt +0 -338
  68. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PopupPromotion.kt +0 -95
  69. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Radio.kt +0 -64
  70. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Skeleton.kt +0 -89
  71. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Switch.kt +0 -91
  72. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Tag.kt +0 -86
  73. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Text.kt +0 -84
  74. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Title.kt +0 -208
  75. package/compose/src/commonMain/kotlin/vn/momo/kits/components/TrustBanner.kt +0 -172
  76. package/compose/src/commonMain/kotlin/vn/momo/kits/components/datetimepicker/DateTimePicker.kt +0 -199
  77. package/compose/src/commonMain/kotlin/vn/momo/kits/components/datetimepicker/DateTimePickerTypes.kt +0 -29
  78. package/compose/src/commonMain/kotlin/vn/momo/kits/components/datetimepicker/DateTimePickerUtils.kt +0 -237
  79. package/compose/src/commonMain/kotlin/vn/momo/kits/components/datetimepicker/WheelPicker.kt +0 -191
  80. package/compose/src/commonMain/kotlin/vn/momo/kits/const/Colors.kt +0 -306
  81. package/compose/src/commonMain/kotlin/vn/momo/kits/const/Radius.kt +0 -12
  82. package/compose/src/commonMain/kotlin/vn/momo/kits/const/Spacing.kt +0 -13
  83. package/compose/src/commonMain/kotlin/vn/momo/kits/const/Theme.kt +0 -191
  84. package/compose/src/commonMain/kotlin/vn/momo/kits/const/Typography.kt +0 -258
  85. package/compose/src/commonMain/kotlin/vn/momo/kits/layout/Card.kt +0 -2
  86. package/compose/src/commonMain/kotlin/vn/momo/kits/layout/Item.kt +0 -35
  87. package/compose/src/commonMain/kotlin/vn/momo/kits/layout/Section.kt +0 -2
  88. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/AutomationId.kt +0 -59
  89. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/Clickable.kt +0 -68
  90. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/Conditional.kt +0 -11
  91. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/Shadow.kt +0 -49
  92. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/Size.kt +0 -51
  93. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/BottomSheet.kt +0 -232
  94. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/ModalScreen.kt +0 -111
  95. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/Navigation.kt +0 -94
  96. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/NavigationContainer.kt +0 -159
  97. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/Navigator.kt +0 -232
  98. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/ScaleSizeScope.kt +0 -17
  99. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/StackScreen.kt +0 -459
  100. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/bottomtab/BottomTab.kt +0 -169
  101. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/bottomtab/BottomTabBar.kt +0 -216
  102. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/bottomtab/CurvedContainer.kt +0 -86
  103. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/FloatingButton.kt +0 -180
  104. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/Header.kt +0 -251
  105. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/HeaderBackground.kt +0 -80
  106. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/HeaderRight.kt +0 -306
  107. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/HeaderTitle.kt +0 -31
  108. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/HeaderUser.kt +0 -385
  109. package/compose/src/commonMain/kotlin/vn/momo/kits/platform/Platform.kt +0 -38
  110. package/compose/src/commonMain/kotlin/vn/momo/kits/utils/Icons.kt +0 -1329
  111. package/compose/src/commonMain/kotlin/vn/momo/kits/utils/Resources.kt +0 -62
  112. package/compose/src/commonMain/kotlin/vn/momo/kits/utils/Utils.kt +0 -88
  113. package/compose/src/iosMain/kotlin/vn/momo/kits/platform/Platform.ios.kt +0 -144
  114. package/gradle.properties +0 -19
  115. package/gradlew +0 -240
  116. package/gradlew.bat +0 -91
  117. package/ios/Theme.md +0 -18
  118. package/settings.gradle.kts +0 -25
@@ -1,385 +0,0 @@
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>)
@@ -1,38 +0,0 @@
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
- )