@momo-kits/native-kits 0.153.2-newsfeed.8 → 0.154.1-beta.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 (117) 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 +5 -175
  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 +308 -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 +404 -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 +78 -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 +133 -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 +69 -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 +393 -0
  51. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputDropDown.kt +164 -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 +226 -0
  54. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputPhoneNumber.kt +221 -0
  55. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputSearch.kt +246 -0
  56. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputTextArea.kt +233 -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/ScaleSizeScope.kt +19 -0
  66. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Skeleton.kt +89 -0
  67. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Switch.kt +91 -0
  68. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Tag.kt +86 -0
  69. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Text.kt +83 -0
  70. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Title.kt +208 -0
  71. package/compose/src/commonMain/kotlin/vn/momo/kits/components/TrustBanner.kt +172 -0
  72. package/compose/src/commonMain/kotlin/vn/momo/kits/components/datetimepicker/DateTimePicker.kt +199 -0
  73. package/compose/src/commonMain/kotlin/vn/momo/kits/components/datetimepicker/DateTimePickerTypes.kt +29 -0
  74. package/compose/src/commonMain/kotlin/vn/momo/kits/components/datetimepicker/DateTimePickerUtils.kt +237 -0
  75. package/compose/src/commonMain/kotlin/vn/momo/kits/components/datetimepicker/WheelPicker.kt +191 -0
  76. package/compose/src/commonMain/kotlin/vn/momo/kits/const/Colors.kt +306 -0
  77. package/compose/src/commonMain/kotlin/vn/momo/kits/const/Radius.kt +12 -0
  78. package/compose/src/commonMain/kotlin/vn/momo/kits/const/Spacing.kt +13 -0
  79. package/compose/src/commonMain/kotlin/vn/momo/kits/const/Theme.kt +189 -0
  80. package/compose/src/commonMain/kotlin/vn/momo/kits/const/Typography.kt +285 -0
  81. package/compose/src/commonMain/kotlin/vn/momo/kits/layout/Card.kt +2 -0
  82. package/compose/src/commonMain/kotlin/vn/momo/kits/layout/Item.kt +35 -0
  83. package/compose/src/commonMain/kotlin/vn/momo/kits/layout/Section.kt +2 -0
  84. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/AutomationId.kt +59 -0
  85. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/Clickable.kt +68 -0
  86. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/Conditional.kt +11 -0
  87. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/Shadow.kt +49 -0
  88. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/Size.kt +51 -0
  89. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/BottomSheet.kt +232 -0
  90. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/ModalScreen.kt +111 -0
  91. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/Navigation.kt +94 -0
  92. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/NavigationContainer.kt +159 -0
  93. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/Navigator.kt +302 -0
  94. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/StackScreen.kt +483 -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 +215 -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/navigation/component/SnackBar.kt +125 -0
  105. package/compose/src/commonMain/kotlin/vn/momo/kits/platform/Platform.kt +38 -0
  106. package/compose/src/commonMain/kotlin/vn/momo/kits/utils/Icons.kt +1329 -0
  107. package/compose/src/commonMain/kotlin/vn/momo/kits/utils/Resources.kt +62 -0
  108. package/compose/src/commonMain/kotlin/vn/momo/kits/utils/Utils.kt +88 -0
  109. package/compose/src/iosMain/kotlin/vn/momo/kits/platform/Platform.ios.kt +144 -0
  110. package/gradle.properties +19 -0
  111. package/gradlew +240 -0
  112. package/gradlew.bat +91 -0
  113. package/ios/Theme.md +18 -0
  114. package/ios/native-kits.podspec +16 -18
  115. package/local.properties +8 -0
  116. package/package.json +4 -2
  117. package/settings.gradle.kts +25 -0
@@ -0,0 +1,285 @@
1
+ package vn.momo.kits.const
2
+
3
+ import androidx.compose.runtime.Composable
4
+ import androidx.compose.runtime.Immutable
5
+ import androidx.compose.ui.platform.LocalDensity
6
+ import androidx.compose.ui.text.TextStyle
7
+ import androidx.compose.ui.text.font.FontFamily
8
+ import androidx.compose.ui.text.font.FontWeight
9
+ import androidx.compose.ui.text.style.TextDecoration
10
+ import androidx.compose.ui.unit.Dp
11
+ import androidx.compose.ui.unit.TextUnit
12
+ import androidx.compose.ui.unit.TextUnitType
13
+ import androidx.compose.ui.unit.dp
14
+ import androidx.compose.ui.unit.sp
15
+ import org.jetbrains.compose.resources.Font
16
+ import org.jetbrains.compose.resources.FontResource
17
+ import org.jetbrains.compose.resources.InternalResourceApi
18
+ import vn.momo.kits.components.ScaleSizeMaxRate
19
+ import vn.momo.kits.platform.getScreenDimensions
20
+ import kotlin.math.max
21
+ import kotlin.math.min
22
+ import vn.momo.uikits.resources.Res
23
+ import vn.momo.uikits.resources.momosignature
24
+ import vn.momo.uikits.resources.momotrustdisplay
25
+ import vn.momo.uikits.resources.sfprotext_black
26
+ import vn.momo.uikits.resources.sfprotext_bold
27
+ import vn.momo.uikits.resources.sfprotext_heavy
28
+ import vn.momo.uikits.resources.sfprotext_light
29
+ import vn.momo.uikits.resources.sfprotext_medium
30
+ import vn.momo.uikits.resources.sfprotext_regular
31
+ import vn.momo.uikits.resources.sfprotext_semibold
32
+ import vn.momo.uikits.resources.sfprotext_thin
33
+ import vn.momo.uikits.resources.sfprotext_ultralight
34
+
35
+ const val DEFAULT_SCREEN_SIZE = 375f
36
+ const val MAX_FONT_SCALE = 1.5f
37
+ const val MAX_DEVICE_SCALE = 5
38
+
39
+ @Composable
40
+ fun scaleSize(size: Float): Float {
41
+ val scaleSizeMaxRate: Float = ScaleSizeMaxRate.current ?: MAX_FONT_SCALE
42
+ val deviceWidth = getScreenDimensions().width
43
+ val deviceScale = deviceWidth / DEFAULT_SCREEN_SIZE
44
+
45
+ val density = LocalDensity.current
46
+ val fontScale = density.fontScale
47
+
48
+ var fontSizeScaleDevice = size
49
+ var fontSizeScaleOS = size
50
+
51
+ if (deviceScale > 1) {
52
+ fontSizeScaleDevice =
53
+ min(deviceScale * fontSizeScaleDevice, fontSizeScaleDevice + MAX_DEVICE_SCALE)
54
+ }
55
+
56
+ if (fontScale > 1) {
57
+ fontSizeScaleOS = min(fontScale * fontSizeScaleOS, fontSizeScaleOS * scaleSizeMaxRate)
58
+ }
59
+
60
+ return max(
61
+ fontSizeScaleDevice,
62
+ fontSizeScaleOS
63
+ )
64
+ }
65
+
66
+ @Composable
67
+ fun scaleSize(size: TextUnit): TextUnit {
68
+ if (!size.isSp) return size
69
+
70
+ val density = LocalDensity.current
71
+
72
+ val scaled = scaleSize(size.value)
73
+ val spValue = scaled / density.fontScale
74
+
75
+ return TextUnit(value = spValue, type = TextUnitType.Sp)
76
+ }
77
+
78
+ @Composable
79
+ fun scaleSize(size: Dp): Dp {
80
+ return scaleSize(size.value).toInt().dp
81
+ }
82
+
83
+ @Composable
84
+ fun scaleSize(textStyle: TextStyle): TextStyle {
85
+ return textStyle.copy(
86
+ fontSize = if (textStyle.fontSize != TextUnit.Unspecified)
87
+ scaleSize(textStyle.fontSize)
88
+ else
89
+ TextUnit.Unspecified,
90
+
91
+ lineHeight = if (textStyle.lineHeight != TextUnit.Unspecified)
92
+ scaleSize(textStyle.lineHeight)
93
+ else
94
+ TextUnit.Unspecified,
95
+ )
96
+ }
97
+
98
+
99
+ @OptIn(InternalResourceApi::class)
100
+ @Composable
101
+ fun getFont(font: FontResource): FontFamily {
102
+ return FontFamily(Font(font))
103
+ }
104
+
105
+ @Composable
106
+ fun getFontFamily(fontFamily: String, fontWeight: FontWeight? = FontWeight.Normal): FontFamily {
107
+ val key = "$fontFamily-${fontWeight?.weight}"
108
+ val fontMap = mapOf(
109
+ "SFProText-100" to Res.font.sfprotext_thin,
110
+ "SFProText-200" to Res.font.sfprotext_ultralight,
111
+ "SFProText-300" to Res.font.sfprotext_light,
112
+ "SFProText-400" to Res.font.sfprotext_regular,
113
+ "SFProText-500" to Res.font.sfprotext_medium,
114
+ "SFProText-600" to Res.font.sfprotext_semibold,
115
+ "SFProText-700" to Res.font.sfprotext_bold,
116
+ "SFProText-800" to Res.font.sfprotext_heavy,
117
+ "SFProText-900" to Res.font.sfprotext_black,
118
+
119
+ "MoMoSignature-100" to Res.font.momosignature,
120
+ "MoMoSignature-200" to Res.font.momosignature,
121
+ "MoMoSignature-300" to Res.font.momosignature,
122
+ "MoMoSignature-400" to Res.font.momosignature,
123
+ "MoMoSignature-500" to Res.font.momosignature,
124
+ "MoMoSignature-600" to Res.font.momosignature,
125
+ "MoMoSignature-700" to Res.font.momosignature,
126
+ "MoMoSignature-800" to Res.font.momosignature,
127
+ "MoMoSignature-900" to Res.font.momosignature,
128
+
129
+ "MoMoTrustDisplay-100" to Res.font.momotrustdisplay,
130
+ "MoMoTrustDisplay-200" to Res.font.momotrustdisplay,
131
+ "MoMoTrustDisplay-300" to Res.font.momotrustdisplay,
132
+ "MoMoTrustDisplay-400" to Res.font.momotrustdisplay,
133
+ "MoMoTrustDisplay-500" to Res.font.momotrustdisplay,
134
+ "MoMoTrustDisplay-600" to Res.font.momotrustdisplay,
135
+ "MoMoTrustDisplay-700" to Res.font.momotrustdisplay,
136
+ "MoMoTrustDisplay-800" to Res.font.momotrustdisplay,
137
+ "MoMoTrustDisplay-900" to Res.font.momotrustdisplay,
138
+ )
139
+ val font = fontMap[key] ?: Res.font.sfprotext_regular
140
+ return getFont(font)
141
+ }
142
+
143
+ @Immutable
144
+ class AppTypography internal constructor(
145
+ val headlineDefaultBold: TextStyle,
146
+ val headerMBold: TextStyle,
147
+ val headerDefaultBold: TextStyle,
148
+ val headerSSemibold: TextStyle,
149
+ val headerXsSemibold: TextStyle,
150
+ val bodyDefaultRegular: TextStyle,
151
+ val bodyDefaultRegularStrikethrough: TextStyle,
152
+ val descriptionDefaultRegular: TextStyle,
153
+ val descriptionDefaultRegularStrikethrough: TextStyle,
154
+ val descriptionXsRegular: TextStyle,
155
+ val descriptionXsRegularStrikethrough: TextStyle,
156
+ val labelDefaultMedium: TextStyle,
157
+ val labelSMedium: TextStyle,
158
+ val labelXsMedium: TextStyle,
159
+ val actionDefaultBold: TextStyle,
160
+ val actionSBold: TextStyle,
161
+ val actionXsBold: TextStyle,
162
+ val actionXxsBold: TextStyle,
163
+ ) {
164
+ constructor(
165
+ default: TextStyle = TextStyle(
166
+ fontSize = 14.sp,
167
+ lineHeight = 20.sp,
168
+ fontWeight = FontWeight.Normal
169
+ ),
170
+ headlineDefaultBold: TextStyle = TextStyle(
171
+ fontSize = 24.sp,
172
+ lineHeight = 34.sp,
173
+ fontWeight = FontWeight.Bold
174
+ ),
175
+ headerMBold: TextStyle = TextStyle(
176
+ fontSize = 18.sp,
177
+ lineHeight = 26.sp,
178
+ fontWeight = FontWeight.Bold
179
+ ),
180
+ headerDefaultBold: TextStyle = TextStyle(
181
+ fontSize = 16.sp,
182
+ lineHeight = 22.sp,
183
+ fontWeight = FontWeight.Bold
184
+ ),
185
+ headerSSemibold: TextStyle = TextStyle(
186
+ fontSize = 14.sp,
187
+ lineHeight = 20.sp,
188
+ fontWeight = FontWeight.SemiBold
189
+ ),
190
+ headerXsSemibold: TextStyle = TextStyle(
191
+ fontSize = 12.sp,
192
+ lineHeight = 18.sp,
193
+ fontWeight = FontWeight.SemiBold
194
+ ),
195
+ bodyDefaultRegular: TextStyle = TextStyle(
196
+ fontSize = 14.sp,
197
+ lineHeight = 20.sp,
198
+ fontWeight = FontWeight.Normal
199
+ ),
200
+ bodyDefaultRegularStrikethrough: TextStyle = TextStyle(
201
+ fontSize = 14.sp,
202
+ lineHeight = 20.sp,
203
+ fontWeight = FontWeight.Normal,
204
+ textDecoration = TextDecoration.LineThrough
205
+ ),
206
+ descriptionDefaultRegular: TextStyle = TextStyle(
207
+ fontSize = 12.sp,
208
+ lineHeight = 18.sp,
209
+ fontWeight = FontWeight.Normal
210
+ ),
211
+ descriptionDefaultRegularStrikethrough: TextStyle = TextStyle(
212
+ fontSize = 12.sp,
213
+ lineHeight = 18.sp,
214
+ fontWeight = FontWeight.Normal,
215
+ textDecoration = TextDecoration.LineThrough
216
+ ),
217
+ descriptionXsRegular: TextStyle = TextStyle(
218
+ fontSize = 10.sp,
219
+ lineHeight = 14.sp,
220
+ fontWeight = FontWeight.Normal
221
+ ),
222
+ descriptionXsRegularStrikethrough: TextStyle = TextStyle(
223
+ fontSize = 10.sp,
224
+ lineHeight = 14.sp,
225
+ fontWeight = FontWeight.Normal,
226
+ textDecoration = TextDecoration.LineThrough
227
+ ),
228
+ labelDefaultMedium: TextStyle = TextStyle(
229
+ fontSize = 14.sp,
230
+ lineHeight = 20.sp,
231
+ fontWeight = FontWeight.Medium
232
+ ),
233
+ labelSMedium: TextStyle = TextStyle(
234
+ fontSize = 12.sp,
235
+ lineHeight = 18.sp,
236
+ fontWeight = FontWeight.Medium
237
+ ),
238
+ labelXsMedium: TextStyle = TextStyle(
239
+ fontSize = 10.sp,
240
+ lineHeight = 14.sp,
241
+ fontWeight = FontWeight.Medium
242
+ ),
243
+ actionDefaultBold: TextStyle = TextStyle(
244
+ fontSize = 16.sp,
245
+ lineHeight = 22.sp,
246
+ fontWeight = FontWeight.Bold
247
+ ),
248
+ actionSBold: TextStyle = TextStyle(
249
+ fontSize = 14.sp,
250
+ lineHeight = 20.sp,
251
+ fontWeight = FontWeight.Bold
252
+ ),
253
+ actionXsBold: TextStyle = TextStyle(
254
+ fontSize = 12.sp,
255
+ lineHeight = 18.sp,
256
+ fontWeight = FontWeight.Bold
257
+ ),
258
+ actionXxsBold: TextStyle = TextStyle(
259
+ fontSize = 10.sp,
260
+ lineHeight = 14.sp,
261
+ fontWeight = FontWeight.Bold
262
+ ),
263
+ ) : this(
264
+ headlineDefaultBold = headlineDefaultBold,
265
+ headerMBold = headerMBold,
266
+ headerDefaultBold = headerDefaultBold,
267
+ headerSSemibold = headerSSemibold,
268
+ headerXsSemibold = headerXsSemibold,
269
+ bodyDefaultRegular = bodyDefaultRegular,
270
+ bodyDefaultRegularStrikethrough = bodyDefaultRegularStrikethrough,
271
+ descriptionDefaultRegular = descriptionDefaultRegular,
272
+ descriptionDefaultRegularStrikethrough = descriptionDefaultRegularStrikethrough,
273
+ descriptionXsRegular = descriptionXsRegular,
274
+ descriptionXsRegularStrikethrough = descriptionXsRegularStrikethrough,
275
+ labelDefaultMedium = labelDefaultMedium,
276
+ labelSMedium = labelSMedium,
277
+ labelXsMedium = labelXsMedium,
278
+ actionDefaultBold = actionDefaultBold,
279
+ actionSBold = actionSBold,
280
+ actionXsBold = actionXsBold,
281
+ actionXxsBold = actionXxsBold
282
+ )
283
+ }
284
+
285
+ val Typography = AppTypography()
@@ -0,0 +1,2 @@
1
+ package vn.momo.kits.layout
2
+
@@ -0,0 +1,35 @@
1
+ package vn.momo.kits.layout
2
+
3
+ import androidx.compose.foundation.layout.Box
4
+ import androidx.compose.foundation.layout.height
5
+ import androidx.compose.foundation.layout.width
6
+ import androidx.compose.runtime.Composable
7
+ import androidx.compose.ui.Modifier
8
+ import androidx.compose.ui.unit.Dp
9
+
10
+ data class GridContext(
11
+ val numberOfColumns: Number,
12
+ val gutterSize: Number,
13
+ val sizePerSpan: Number,
14
+ val getSizeSpan: (Number) -> Number
15
+ )
16
+
17
+ @Composable
18
+ fun Item(
19
+ heightSpan: Number = 1,
20
+ widthSpan: Number = 1,
21
+ content: @Composable() () -> Unit,
22
+ modifier: Modifier = Modifier,
23
+ grid: GridContext
24
+ ) {
25
+
26
+ val widthItem = grid.getSizeSpan(widthSpan)
27
+ val heightItem = grid.getSizeSpan(heightSpan)
28
+
29
+ Box(
30
+ modifier = modifier.width(width = Dp(widthItem.toFloat()))
31
+ .height(height = Dp(heightItem.toFloat()))
32
+ ) {
33
+ content()
34
+ }
35
+ }
@@ -0,0 +1,2 @@
1
+ package vn.momo.kits.layout
2
+
@@ -0,0 +1,59 @@
1
+ package vn.momo.kits.modifier
2
+
3
+ import androidx.compose.ui.Modifier
4
+ import androidx.compose.ui.node.ModifierNodeElement
5
+ import androidx.compose.ui.node.SemanticsModifierNode
6
+ import androidx.compose.ui.semantics.SemanticsPropertyReceiver
7
+ import androidx.compose.ui.semantics.contentDescription
8
+ import androidx.compose.ui.semantics.semantics
9
+ import androidx.compose.ui.semantics.testTag
10
+ import vn.momo.kits.platform.getPlatformName
11
+
12
+ fun Modifier.setAutomationId(accessibilityId: String, label: String? = null): Modifier {
13
+ return if (getPlatformName() == "Android") {
14
+ semantics {
15
+ contentDescription = accessibilityId
16
+ }
17
+ } else {
18
+ semantics {
19
+ testTag = accessibilityId
20
+ contentDescription = label ?: accessibilityId
21
+ }
22
+ }
23
+ }
24
+
25
+ /**
26
+ * Alternative for [setAutomationId]
27
+ *
28
+ * reason: [link](https://developer.android.com/develop/ui/compose/custom-modifiers#composable_function_modifiers_are_never_skipped)
29
+ * */
30
+ fun Modifier.kitsAutomationId(accessibilityId: String, label: String? = null) =
31
+ this then KitsAutomationIdElement(accessibilityId, label)
32
+
33
+ private data class KitsAutomationIdElement(
34
+ private val accessibilityId: String,
35
+ private val label: String? = null,
36
+ ) : ModifierNodeElement<KitsAutomationIdNode>() {
37
+ override fun create(): KitsAutomationIdNode {
38
+ return KitsAutomationIdNode(accessibilityId, label)
39
+ }
40
+
41
+ override fun update(node: KitsAutomationIdNode) {
42
+ node.accessibilityId = accessibilityId
43
+ node.label = label
44
+ }
45
+ }
46
+
47
+ private class KitsAutomationIdNode(
48
+ var accessibilityId: String,
49
+ var label: String?,
50
+ ) : Modifier.Node(), SemanticsModifierNode {
51
+ override fun SemanticsPropertyReceiver.applySemantics() {
52
+ if (getPlatformName() == "Android") {
53
+ contentDescription = accessibilityId
54
+ } else {
55
+ testTag = accessibilityId
56
+ contentDescription = label ?: accessibilityId
57
+ }
58
+ }
59
+ }
@@ -0,0 +1,68 @@
1
+ package vn.momo.kits.modifier
2
+
3
+ import androidx.compose.animation.core.animateFloatAsState
4
+ import androidx.compose.foundation.clickable
5
+ import androidx.compose.foundation.gestures.detectTapGestures
6
+ import androidx.compose.foundation.interaction.MutableInteractionSource
7
+ import androidx.compose.foundation.interaction.collectIsPressedAsState
8
+ import androidx.compose.runtime.getValue
9
+ import androidx.compose.runtime.remember
10
+ import androidx.compose.ui.Modifier
11
+ import androidx.compose.ui.composed
12
+ import androidx.compose.ui.graphics.graphicsLayer
13
+ import androidx.compose.ui.input.pointer.pointerInput
14
+ import androidx.compose.ui.platform.LocalFocusManager
15
+ import androidx.compose.ui.platform.LocalSoftwareKeyboardController
16
+ import androidx.compose.ui.semantics.Role
17
+
18
+ fun Modifier.noFeedbackClickable(
19
+ enabled: Boolean = true, onClickLabel: String? = null, role: Role? = null, onClick: () -> Unit
20
+ ): Modifier = composed {
21
+ clickable(
22
+ interactionSource = remember { MutableInteractionSource() },
23
+ indication = null,
24
+ enabled,
25
+ onClickLabel,
26
+ role,
27
+ onClick
28
+ )
29
+ }
30
+
31
+ fun Modifier.activeOpacityClickable(
32
+ activeOpacity: Float = 0.2f,
33
+ enabled: Boolean = true,
34
+ onClickLabel: String? = null,
35
+ role: Role? = null,
36
+ onClick: () -> Unit
37
+ ): Modifier = composed {
38
+ val interactionSource = remember { MutableInteractionSource() }
39
+ val isPressed by interactionSource.collectIsPressedAsState()
40
+ val animatedAlpha by animateFloatAsState(
41
+ targetValue = if (isPressed) activeOpacity else 1f,
42
+ label = "ActiveOpacity"
43
+ )
44
+
45
+ this
46
+ .graphicsLayer { alpha = animatedAlpha }
47
+ .clickable(
48
+ interactionSource = interactionSource,
49
+ indication = null,
50
+ enabled,
51
+ onClickLabel,
52
+ role,
53
+ onClick
54
+ )
55
+ }
56
+
57
+
58
+ fun Modifier.hideKeyboardOnTap() = composed {
59
+ val focusManager = LocalFocusManager.current
60
+ val keyboardManager = LocalSoftwareKeyboardController.current
61
+
62
+ pointerInput(Unit) {
63
+ detectTapGestures {
64
+ keyboardManager?.hide()
65
+ focusManager.clearFocus()
66
+ }
67
+ }
68
+ }
@@ -0,0 +1,11 @@
1
+ package vn.momo.kits.modifier
2
+
3
+ import androidx.compose.ui.Modifier
4
+
5
+ fun Modifier.conditional(condition: Boolean, modifier: Modifier.() -> Modifier): Modifier {
6
+ return if (condition) {
7
+ then(modifier(Modifier))
8
+ } else {
9
+ this
10
+ }
11
+ }
@@ -0,0 +1,49 @@
1
+ package vn.momo.kits.modifier
2
+
3
+ import androidx.compose.ui.Modifier
4
+ import androidx.compose.ui.draw.drawBehind
5
+ import androidx.compose.ui.graphics.Color
6
+ import androidx.compose.ui.graphics.Paint
7
+ import androidx.compose.ui.graphics.drawscope.drawIntoCanvas
8
+ import androidx.compose.ui.graphics.toArgb
9
+ import androidx.compose.ui.unit.Dp
10
+ import androidx.compose.ui.unit.dp
11
+ import vn.momo.kits.platform.setMaskFilter
12
+
13
+
14
+ fun Modifier.shadow(
15
+ color: Color = Color.Black,
16
+ borderRadius: Dp = 0.dp,
17
+ blurRadius: Float = 0f,
18
+ offsetY: Dp = 0.dp,
19
+ offsetX: Dp = 0.dp,
20
+ spread: Dp = 0f.dp,
21
+ modifier: Modifier = Modifier
22
+ ) = this.then(
23
+ modifier.drawBehind {
24
+ this.drawIntoCanvas {
25
+ val paint = Paint()
26
+ val frameworkPaint = paint.asFrameworkPaint()
27
+ val spreadPixel = spread.toPx()
28
+ val leftPixel = (0f - spreadPixel) + offsetX.toPx()
29
+ val topPixel = (0f - spreadPixel) + offsetY.toPx()
30
+ val rightPixel = (this.size.width + spreadPixel)
31
+ val bottomPixel = (0f + spreadPixel) - offsetY.toPx()
32
+
33
+ if (blurRadius != 0f) {
34
+ frameworkPaint.setMaskFilter(blurRadius)
35
+ }
36
+
37
+ frameworkPaint.color = color.toArgb()
38
+ it.drawRoundRect(
39
+ left = leftPixel,
40
+ top = topPixel,
41
+ right = rightPixel,
42
+ bottom = bottomPixel,
43
+ radiusX = borderRadius.toPx(),
44
+ radiusY = borderRadius.toPx(),
45
+ paint
46
+ )
47
+ }
48
+ }
49
+ )
@@ -0,0 +1,51 @@
1
+ package vn.momo.kits.modifier
2
+
3
+ import androidx.compose.runtime.Composable
4
+ import androidx.compose.runtime.State
5
+ import androidx.compose.ui.Modifier
6
+ import androidx.compose.ui.layout.Measurable
7
+ import androidx.compose.ui.layout.MeasureResult
8
+ import androidx.compose.ui.layout.MeasureScope
9
+ import androidx.compose.ui.node.LayoutModifierNode
10
+ import androidx.compose.ui.node.ModifierNodeElement
11
+ import androidx.compose.ui.unit.Constraints
12
+ import androidx.compose.ui.unit.IntOffset
13
+
14
+ @Composable
15
+ fun Modifier.dynamicSize(
16
+ widthState: State<Int>? = null,
17
+ heightState: State<Int>? = null,
18
+ ) = this then DynamicSizeElement(widthState, heightState)
19
+
20
+ private data class DynamicSizeElement(
21
+ val widthState: State<Int>?,
22
+ val heightState: State<Int>?,
23
+ ) : ModifierNodeElement<DynamicSizeNode>() {
24
+ override fun create(): DynamicSizeNode {
25
+ return DynamicSizeNode(widthState, heightState)
26
+ }
27
+
28
+ override fun update(node: DynamicSizeNode) {
29
+ node.widthState = widthState
30
+ node.heightState = heightState
31
+ }
32
+
33
+ }
34
+
35
+ private class DynamicSizeNode(
36
+ var widthState: State<Int>?,
37
+ var heightState: State<Int>?,
38
+ ) : Modifier.Node(), LayoutModifierNode {
39
+ override fun MeasureScope.measure(
40
+ measurable: Measurable,
41
+ constraints: Constraints
42
+ ): MeasureResult {
43
+ val p = measurable.measure(constraints)
44
+ return layout(
45
+ width = widthState?.value ?: p.width,
46
+ height = heightState?.value ?: p.height,
47
+ ) {
48
+ p.place(IntOffset.Zero)
49
+ }
50
+ }
51
+ }