@momo-kits/native-kits 0.152.4-beta.3 → 0.152.5

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/package.json +7 -6
  2. package/shared/build.gradle.kts +74 -0
  3. package/CODE_OF_CONDUCT.md +0 -133
  4. package/CONTRIBUTING.md +0 -114
  5. package/LICENSE +0 -20
  6. package/README.md +0 -7
  7. package/build.gradle.kts +0 -32
  8. package/compose/MoMoComposeKits.podspec +0 -54
  9. package/compose/build.gradle.kts +0 -149
  10. package/compose/src/androidMain/AndroidManifest.xml +0 -2
  11. package/compose/src/androidMain/kotlin/vn/momo/kits/platform/Platform.android.kt +0 -105
  12. package/compose/src/commonMain/composeResources/files/lottie_circle_loader.json +0 -1
  13. package/compose/src/commonMain/composeResources/font/momosignature.otf +0 -0
  14. package/compose/src/commonMain/composeResources/font/momotrustdisplay.otf +0 -0
  15. package/compose/src/commonMain/composeResources/font/sfprotext_black.otf +0 -0
  16. package/compose/src/commonMain/composeResources/font/sfprotext_black.ttf +0 -0
  17. package/compose/src/commonMain/composeResources/font/sfprotext_bold.ttf +0 -0
  18. package/compose/src/commonMain/composeResources/font/sfprotext_heavy.ttf +0 -0
  19. package/compose/src/commonMain/composeResources/font/sfprotext_light.ttf +0 -0
  20. package/compose/src/commonMain/composeResources/font/sfprotext_medium.ttf +0 -0
  21. package/compose/src/commonMain/composeResources/font/sfprotext_regular.ttf +0 -0
  22. package/compose/src/commonMain/composeResources/font/sfprotext_semibold.ttf +0 -0
  23. package/compose/src/commonMain/composeResources/font/sfprotext_thin.otf +0 -0
  24. package/compose/src/commonMain/composeResources/font/sfprotext_thin.ttf +0 -0
  25. package/compose/src/commonMain/composeResources/font/sfprotext_ultralight.otf +0 -0
  26. package/compose/src/commonMain/composeResources/font/sfprotext_ultralight.ttf +0 -0
  27. package/compose/src/commonMain/kotlin/vn/momo/kits/application/AnimationSearchInput.kt +0 -57
  28. package/compose/src/commonMain/kotlin/vn/momo/kits/application/FloatingButton.kt +0 -201
  29. package/compose/src/commonMain/kotlin/vn/momo/kits/application/Header.kt +0 -222
  30. package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderAnimated.kt +0 -48
  31. package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderBackground.kt +0 -86
  32. package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderDefault.kt +0 -76
  33. package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderExtended.kt +0 -76
  34. package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderRight.kt +0 -306
  35. package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderTitle.kt +0 -33
  36. package/compose/src/commonMain/kotlin/vn/momo/kits/application/LiteScreen.kt +0 -715
  37. package/compose/src/commonMain/kotlin/vn/momo/kits/application/NavigationContainer.kt +0 -214
  38. package/compose/src/commonMain/kotlin/vn/momo/kits/application/Screen.kt +0 -236
  39. package/compose/src/commonMain/kotlin/vn/momo/kits/application/useHeaderSearchAnimation.kt +0 -69
  40. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Badge.kt +0 -77
  41. package/compose/src/commonMain/kotlin/vn/momo/kits/components/BadgeDot.kt +0 -27
  42. package/compose/src/commonMain/kotlin/vn/momo/kits/components/BadgeRibbon.kt +0 -334
  43. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Button.kt +0 -345
  44. package/compose/src/commonMain/kotlin/vn/momo/kits/components/CheckBox.kt +0 -90
  45. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Chip.kt +0 -131
  46. package/compose/src/commonMain/kotlin/vn/momo/kits/components/CupertinoOverscroll.kt +0 -543
  47. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Divider.kt +0 -23
  48. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Icon.kt +0 -69
  49. package/compose/src/commonMain/kotlin/vn/momo/kits/components/IconButton.kt +0 -143
  50. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Image.kt +0 -179
  51. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Information.kt +0 -111
  52. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Input.kt +0 -384
  53. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputDropDown.kt +0 -160
  54. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputMoney.kt +0 -234
  55. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputOTP.kt +0 -223
  56. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputPhoneNumber.kt +0 -232
  57. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputSearch.kt +0 -236
  58. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputTextArea.kt +0 -228
  59. package/compose/src/commonMain/kotlin/vn/momo/kits/components/LazyColumnWithBouncing.kt +0 -364
  60. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PaginationDot.kt +0 -50
  61. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PaginationNumber.kt +0 -34
  62. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PaginationScroll.kt +0 -85
  63. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PaginationWhiteDot.kt +0 -33
  64. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PopupNotify.kt +0 -338
  65. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PopupPromotion.kt +0 -95
  66. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Radio.kt +0 -64
  67. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Skeleton.kt +0 -89
  68. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Switch.kt +0 -91
  69. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Tag.kt +0 -86
  70. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Text.kt +0 -84
  71. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Title.kt +0 -208
  72. package/compose/src/commonMain/kotlin/vn/momo/kits/components/TrustBanner.kt +0 -172
  73. package/compose/src/commonMain/kotlin/vn/momo/kits/components/datetimepicker/DateTimePicker.kt +0 -199
  74. package/compose/src/commonMain/kotlin/vn/momo/kits/components/datetimepicker/DateTimePickerTypes.kt +0 -29
  75. package/compose/src/commonMain/kotlin/vn/momo/kits/components/datetimepicker/DateTimePickerUtils.kt +0 -237
  76. package/compose/src/commonMain/kotlin/vn/momo/kits/components/datetimepicker/WheelPicker.kt +0 -191
  77. package/compose/src/commonMain/kotlin/vn/momo/kits/const/Colors.kt +0 -306
  78. package/compose/src/commonMain/kotlin/vn/momo/kits/const/Radius.kt +0 -12
  79. package/compose/src/commonMain/kotlin/vn/momo/kits/const/Spacing.kt +0 -13
  80. package/compose/src/commonMain/kotlin/vn/momo/kits/const/Theme.kt +0 -191
  81. package/compose/src/commonMain/kotlin/vn/momo/kits/const/Typography.kt +0 -258
  82. package/compose/src/commonMain/kotlin/vn/momo/kits/layout/Card.kt +0 -2
  83. package/compose/src/commonMain/kotlin/vn/momo/kits/layout/Item.kt +0 -35
  84. package/compose/src/commonMain/kotlin/vn/momo/kits/layout/Section.kt +0 -2
  85. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/AutomationId.kt +0 -59
  86. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/Clickable.kt +0 -68
  87. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/Conditional.kt +0 -11
  88. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/Shadow.kt +0 -49
  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 -232
  91. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/ModalScreen.kt +0 -111
  92. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/Navigation.kt +0 -94
  93. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/NavigationContainer.kt +0 -159
  94. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/Navigator.kt +0 -232
  95. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/ScaleSizeScope.kt +0 -17
  96. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/StackScreen.kt +0 -459
  97. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/bottomtab/BottomTab.kt +0 -169
  98. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/bottomtab/BottomTabBar.kt +0 -216
  99. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/bottomtab/CurvedContainer.kt +0 -86
  100. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/FloatingButton.kt +0 -180
  101. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/Header.kt +0 -251
  102. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/HeaderBackground.kt +0 -80
  103. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/HeaderRight.kt +0 -306
  104. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/HeaderTitle.kt +0 -31
  105. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/HeaderUser.kt +0 -385
  106. package/compose/src/commonMain/kotlin/vn/momo/kits/platform/Platform.kt +0 -38
  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/Utils.kt +0 -88
  110. package/compose/src/iosMain/kotlin/vn/momo/kits/platform/Platform.ios.kt +0 -144
  111. package/gradle.properties +0 -19
  112. package/gradlew +0 -240
  113. package/gradlew.bat +0 -91
  114. package/ios/Application/ApplicationEnvironment.swift +0 -50
  115. package/ios/Application/Components.swift +0 -263
  116. package/ios/Application/ComposeApi.swift +0 -22
  117. package/ios/Application/FloatingButton.swift +0 -172
  118. package/ios/Application/HeaderRight.swift +0 -271
  119. package/ios/Application/Screen.swift +0 -249
  120. package/ios/Badge/BadgeDot.swift +0 -31
  121. package/ios/Button/Button.swift +0 -211
  122. package/ios/CalculatorKeyboard/CalculatorKeyboard.swift +0 -126
  123. package/ios/Checkbox/Checkbox.swift +0 -81
  124. package/ios/Chip/Chip.swift +0 -96
  125. package/ios/Colors+Radius+Spacing/Colors.swift +0 -172
  126. package/ios/Colors+Radius+Spacing/Radius.swift +0 -22
  127. package/ios/Colors+Radius+Spacing/Spacing.swift +0 -12
  128. package/ios/Extensions/Color++.swift +0 -25
  129. package/ios/Icon/Icon.swift +0 -51
  130. package/ios/Image/Image.swift +0 -70
  131. package/ios/Input/Input.swift +0 -207
  132. package/ios/Input/InputPhoneNumber.swift +0 -176
  133. package/ios/Input/InputSearch.swift +0 -238
  134. package/ios/Input/InputTextArea.swift +0 -242
  135. package/ios/Lottie/LottieView.swift +0 -86
  136. package/ios/OTPKeyboard/KeyboardButton.swift +0 -41
  137. package/ios/OTPKeyboard/OTPKeyboard.swift +0 -145
  138. package/ios/Popup/PopupDisplay.swift +0 -284
  139. package/ios/Popup/PopupInput.swift +0 -96
  140. package/ios/Popup/PopupPromotion.swift +0 -73
  141. package/ios/PopupView/FullscreenPopup.swift +0 -251
  142. package/ios/PopupView/Modifiers.swift +0 -158
  143. package/ios/PopupView/PopupView.swift +0 -289
  144. package/ios/PopupView/Utils++.swift +0 -281
  145. package/ios/ScrollIndicator/ScrollIndicator.swift +0 -110
  146. package/ios/Swipeable/SwipeCell.swift +0 -278
  147. package/ios/Swipeable/SwipeCellModel.swift +0 -86
  148. package/ios/Switch/Switch.swift +0 -44
  149. package/ios/Template/Logo/Logo.swift +0 -75
  150. package/ios/Template/TrustBanner/TrustBanner.swift +0 -120
  151. package/ios/Theme.md +0 -18
  152. package/ios/Typography/Text.swift +0 -140
  153. package/ios/Typography/Typography.swift +0 -95
  154. package/ios/native-kits.podspec +0 -18
  155. package/settings.gradle.kts +0 -25
@@ -1,105 +0,0 @@
1
- package vn.momo.kits.platform
2
-
3
- import android.annotation.SuppressLint
4
- import android.content.res.Resources
5
- import android.graphics.BlurMaskFilter
6
- import android.graphics.PorterDuff
7
- import android.graphics.PorterDuffColorFilter
8
- import android.os.Build
9
- import androidx.compose.foundation.layout.Box
10
- import androidx.compose.runtime.Composable
11
- import androidx.compose.runtime.getValue
12
- import androidx.compose.ui.Modifier
13
- import androidx.compose.ui.graphics.Color
14
- import androidx.compose.ui.graphics.NativePaint
15
- import androidx.compose.ui.graphics.toArgb
16
- import androidx.compose.ui.platform.LocalConfiguration
17
- import androidx.compose.ui.unit.Dp
18
- import androidx.compose.ui.unit.dp
19
- import com.airbnb.lottie.LottieProperty
20
- import com.airbnb.lottie.compose.LottieAnimation
21
- import com.airbnb.lottie.compose.LottieCompositionSpec
22
- import com.airbnb.lottie.compose.LottieConstants
23
- import com.airbnb.lottie.compose.rememberLottieComposition
24
- import com.airbnb.lottie.compose.rememberLottieDynamicProperties
25
- import com.airbnb.lottie.compose.rememberLottieDynamicProperty
26
- import vn.momo.kits.const.AppNavigationBar
27
- import vn.momo.kits.const.AppStatusBar
28
- import vn.momo.kits.utils.readJson
29
- import androidx.activity.compose.BackHandler as AndroidBackHandler
30
-
31
- actual fun getPlatformName(): String = "Android"
32
-
33
- @Composable
34
- actual fun getScreenDimensions(): ScreenDimension {
35
- val config = LocalConfiguration.current
36
- return ScreenDimension(
37
- config.screenWidthDp, config.screenHeightDp
38
- )
39
- }
40
-
41
- actual fun NativePaint.setMaskFilter(blurRadius: Float) {
42
- this.maskFilter = BlurMaskFilter(blurRadius, BlurMaskFilter.Blur.NORMAL)
43
- }
44
-
45
- @SuppressLint("InternalInsetResource")
46
- @Composable
47
- actual fun getStatusBarHeight(): Dp {
48
- val resourceId = Resources.getSystem().getIdentifier(
49
- "status_bar_height",
50
- "dimen",
51
- "android"
52
- )
53
- return if(resourceId > 0) Resources.getSystem().getDimensionPixelSize(resourceId).dp else 0.dp
54
- }
55
-
56
- @Composable
57
- actual fun BackHandler(enabled: Boolean, onBack: () -> Unit) {
58
- AndroidBackHandler(enabled = enabled, onBack = onBack)
59
- }
60
-
61
- @Composable
62
- actual fun getScreenHeight(): Dp {
63
- return getScreenDimensions().height.dp + if (getAndroidBuildVersion() >= 35) 0.dp else AppStatusBar.current + AppNavigationBar.current
64
- }
65
-
66
- actual fun getAndroidBuildVersion(): Int = Build.VERSION.SDK_INT
67
-
68
- @Composable
69
- actual fun LottieAnimation(
70
- path: String,
71
- tintColor: Color?,
72
- bgColor: Color?,
73
- modifier: Modifier
74
- ) {
75
- val json = readJson(path)
76
-
77
- if (json.isEmpty()) {
78
- Box(modifier)
79
- return
80
- }
81
-
82
- val composition by rememberLottieComposition(
83
- LottieCompositionSpec.JsonString(json)
84
- )
85
-
86
- val colorFilter = PorterDuffColorFilter(
87
- tintColor?.toArgb() ?: Color.White.toArgb(),
88
- PorterDuff.Mode.SRC_ATOP
89
- )
90
-
91
- val dynamicProperties = rememberLottieDynamicProperties(
92
- rememberLottieDynamicProperty(
93
- property = LottieProperty.COLOR_FILTER,
94
- value = colorFilter,
95
- keyPath = arrayOf("**")
96
- )
97
- )
98
-
99
- LottieAnimation(
100
- composition = composition,
101
- iterations = LottieConstants.IterateForever,
102
- dynamicProperties = if (tintColor != null) dynamicProperties else null,
103
- modifier = modifier
104
- )
105
- }
@@ -1 +0,0 @@
1
- {"v":"5.10.2","fr":30,"ip":0,"op":20,"w":100,"h":100,"nm":"Spinner3.1_Refine","ddd":0,"assets":[],"layers":[{"ddd":0,"ind":12,"ty":4,"nm":"loading 2","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":0,"s":[0],"e":[360]},{"t":20}],"ix":10},"p":{"a":0,"k":[50,50,0],"ix":2,"l":2},"a":{"a":0,"k":[44.124,44.124,0],"ix":1,"l":2},"s":{"a":0,"k":[100,100,100],"ix":6,"l":2}},"ao":0,"shapes":[{"ty":"gr","it":[{"d":1,"ty":"el","s":{"a":0,"k":[90,90],"ix":2},"p":{"a":0,"k":[0,0],"ix":3},"nm":"Ellipse Path 1","mn":"ADBE Vector Shape - Ellipse","hd":false},{"ty":"st","c":{"a":0,"k":[0.996078431373,0.956862745098,0.980392156863,1],"ix":3},"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":9,"ix":5},"lc":2,"lj":1,"ml":4,"bm":0,"nm":"Stroke 1","mn":"ADBE Vector Graphic - Stroke","hd":false},{"ty":"tr","p":{"a":0,"k":[44.124,44.124],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Ellipse 1","np":3,"cix":2,"bm":0,"ix":1,"mn":"ADBE Vector Group","hd":false},{"ty":"tm","s":{"a":1,"k":[{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.167],"y":[0.167]},"t":0,"s":[0],"e":[20]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.333],"y":[0]},"t":10,"s":[20],"e":[0]},{"t":20}],"ix":1},"e":{"a":1,"k":[{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.167],"y":[0.167]},"t":0,"s":[35],"e":[50]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.333],"y":[0]},"t":10,"s":[50],"e":[35]},{"t":20}],"ix":2},"o":{"a":0,"k":0,"ix":3},"m":1,"ix":2,"nm":"Trim Paths 1","mn":"ADBE Vector Filter - Trim","hd":false}],"ip":0,"op":20,"st":0,"ct":1,"bm":0},{"ddd":0,"ind":13,"ty":4,"nm":"loading 3","sr":1,"ks":{"o":{"a":0,"k":100,"ix":11},"r":{"a":1,"k":[{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.167],"y":[0.167]},"t":2,"s":[0],"e":[360]},{"t":20}],"ix":10},"p":{"a":0,"k":[50,50,0],"ix":2,"l":2},"a":{"a":0,"k":[44.124,44.124,0],"ix":1,"l":2},"s":{"a":0,"k":[100,100,100],"ix":6,"l":2}},"ao":0,"shapes":[{"ty":"gr","it":[{"d":1,"ty":"el","s":{"a":0,"k":[90,90],"ix":2},"p":{"a":0,"k":[0,0],"ix":3},"nm":"Ellipse Path 1","mn":"ADBE Vector Shape - Ellipse","hd":false},{"ty":"st","c":{"a":0,"k":[0.98431372549,0.835294117647,0.917647058824,1],"ix":3},"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":9,"ix":5},"lc":2,"lj":1,"ml":4,"bm":0,"nm":"Stroke 1","mn":"ADBE Vector Graphic - Stroke","hd":false},{"ty":"tr","p":{"a":0,"k":[44.124,44.124],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Ellipse 1","np":3,"cix":2,"bm":0,"ix":1,"mn":"ADBE Vector Group","hd":false},{"ty":"tm","s":{"a":1,"k":[{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.167],"y":[0.167]},"t":2,"s":[0],"e":[20]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.333],"y":[0]},"t":12,"s":[20],"e":[0]},{"t":20}],"ix":1},"e":{"a":1,"k":[{"i":{"x":[0.667],"y":[1]},"o":{"x":[0.167],"y":[0.167]},"t":2,"s":[35],"e":[50]},{"i":{"x":[0.833],"y":[0.833]},"o":{"x":[0.333],"y":[0]},"t":12,"s":[50],"e":[35]},{"t":20}],"ix":2},"o":{"a":0,"k":0,"ix":3},"m":1,"ix":2,"nm":"Trim Paths 1","mn":"ADBE Vector Filter - Trim","hd":false}],"ip":0,"op":20,"st":0,"ct":1,"bm":0},{"ddd":0,"ind":14,"ty":4,"nm":"base pink 2","sr":1,"ks":{"o":{"a":0,"k":40,"ix":11},"r":{"a":0,"k":0,"ix":10},"p":{"a":0,"k":[50,50,0],"ix":2,"l":2},"a":{"a":0,"k":[44.124,44.124,0],"ix":1,"l":2},"s":{"a":0,"k":[100,100,100],"ix":6,"l":2}},"ao":0,"shapes":[{"ty":"gr","it":[{"d":1,"ty":"el","s":{"a":0,"k":[90,90],"ix":2},"p":{"a":0,"k":[0,0],"ix":3},"nm":"Ellipse Path 1","mn":"ADBE Vector Shape - Ellipse","hd":false},{"ty":"st","c":{"a":0,"k":[0.996078431373,0.972549019608,0.988235294118,1],"ix":3},"o":{"a":0,"k":100,"ix":4},"w":{"a":0,"k":9,"ix":5},"lc":1,"lj":1,"ml":4,"bm":0,"nm":"Stroke 1","mn":"ADBE Vector Graphic - Stroke","hd":false},{"ty":"tr","p":{"a":0,"k":[44.124,44.124],"ix":2},"a":{"a":0,"k":[0,0],"ix":1},"s":{"a":0,"k":[100,100],"ix":3},"r":{"a":0,"k":0,"ix":6},"o":{"a":0,"k":100,"ix":7},"sk":{"a":0,"k":0,"ix":4},"sa":{"a":0,"k":0,"ix":5},"nm":"Transform"}],"nm":"Ellipse 1","np":3,"cix":2,"bm":0,"ix":1,"mn":"ADBE Vector Group","hd":false}],"ip":0,"op":20,"st":0,"ct":1,"bm":0}],"markers":[]}
@@ -1,57 +0,0 @@
1
- package vn.momo.kits.application
2
-
3
- import androidx.compose.foundation.background
4
- import androidx.compose.foundation.layout.Box
5
- import androidx.compose.foundation.layout.fillMaxWidth
6
- import androidx.compose.foundation.layout.height
7
- import androidx.compose.foundation.layout.offset
8
- import androidx.compose.foundation.layout.padding
9
- import androidx.compose.foundation.layout.width
10
- import androidx.compose.foundation.shape.RoundedCornerShape
11
- import androidx.compose.runtime.Composable
12
- import androidx.compose.ui.Modifier
13
- import androidx.compose.ui.graphics.Color
14
- import androidx.compose.ui.unit.dp
15
- import androidx.compose.ui.zIndex
16
- import vn.momo.kits.components.InputSearch
17
- import vn.momo.kits.components.InputSearchProps
18
- import vn.momo.kits.const.Radius
19
- import vn.momo.kits.const.Spacing
20
-
21
- @Composable
22
- fun AnimationSearchInput(
23
- animations: HeaderAnimations,
24
- inputSearchProps: InputSearchProps
25
- ) {
26
- Box(
27
- modifier = Modifier
28
- .fillMaxWidth()
29
- .offset(
30
- x = animations.translateX.dp,
31
- y = animations.translateY.dp
32
- )
33
- ) {
34
- Box(
35
- modifier = Modifier
36
- .height(HEADER_HEIGHT.dp)
37
- .padding(vertical = Spacing.S)
38
- .zIndex(1f)
39
- ) {
40
- Box(
41
- modifier = Modifier
42
- .width(animations.width.dp)
43
- .background(
44
- color = animations.backgroundSearch,
45
- shape = RoundedCornerShape(Radius.XL)
46
- )
47
- ) {
48
- InputSearch(
49
- inputSearchProps = inputSearchProps.copy(
50
- showButtonText = false,
51
- backgroundColor = Color.Transparent
52
- )
53
- )
54
- }
55
- }
56
- }
57
- }
@@ -1,201 +0,0 @@
1
- package vn.momo.kits.application
2
-
3
- import androidx.compose.animation.AnimatedVisibility
4
- import androidx.compose.animation.core.CubicBezierEasing
5
- import androidx.compose.animation.core.animateDpAsState
6
- import androidx.compose.animation.core.tween
7
- import androidx.compose.animation.expandHorizontally
8
- import androidx.compose.animation.fadeIn
9
- import androidx.compose.animation.fadeOut
10
- import androidx.compose.animation.shrinkHorizontally
11
- import androidx.compose.foundation.ScrollState
12
- import androidx.compose.foundation.background
13
- import androidx.compose.foundation.interaction.MutableInteractionSource
14
- import androidx.compose.foundation.layout.Arrangement
15
- import androidx.compose.foundation.layout.Box
16
- import androidx.compose.foundation.layout.Row
17
- import androidx.compose.foundation.layout.Spacer
18
- import androidx.compose.foundation.layout.fillMaxSize
19
- import androidx.compose.foundation.layout.height
20
- import androidx.compose.foundation.layout.offset
21
- import androidx.compose.foundation.layout.padding
22
- import androidx.compose.foundation.layout.sizeIn
23
- import androidx.compose.foundation.layout.width
24
- import androidx.compose.material3.AlertDialogDefaults.shape
25
- import androidx.compose.material3.FloatingActionButton
26
- import androidx.compose.material3.FloatingActionButtonDefaults
27
- import androidx.compose.runtime.Composable
28
- import androidx.compose.runtime.LaunchedEffect
29
- import androidx.compose.runtime.getValue
30
- import androidx.compose.runtime.mutableStateOf
31
- import androidx.compose.runtime.remember
32
- import androidx.compose.runtime.rememberCoroutineScope
33
- import androidx.compose.runtime.saveable.rememberSaveable
34
- import androidx.compose.runtime.setValue
35
- import androidx.compose.ui.Alignment
36
- import androidx.compose.ui.Modifier
37
- import androidx.compose.ui.graphics.Color
38
- import androidx.compose.ui.unit.Dp
39
- import androidx.compose.ui.unit.dp
40
- import androidx.compose.ui.zIndex
41
- import kotlinx.coroutines.delay
42
- import kotlinx.coroutines.flow.MutableStateFlow
43
- import kotlinx.coroutines.flow.collectLatest
44
- import kotlinx.coroutines.launch
45
- import vn.momo.kits.components.Icon
46
- import vn.momo.kits.components.Text
47
- import vn.momo.kits.const.Typography
48
-
49
- enum class FABSize {
50
- SMALL,
51
- DEFAULT,
52
- }
53
-
54
- enum class FABPosition {
55
- END,
56
- CENTER,
57
- }
58
-
59
- data class FabProps(
60
- val icon: String,
61
- val iconColor: Color? = null,
62
- val label: String? = null,
63
- val onClick: () -> Unit,
64
- val size: FABSize = FABSize.DEFAULT,
65
- val bottom: Dp? = null,
66
- val scrollState: ScrollState? = null,
67
- val position: FABPosition? = FABPosition.END,
68
- )
69
-
70
- @Deprecated("Use vn.momo.kits.navigation.FloatingButton instead", ReplaceWith("vn.momo.kits.navigation.FloatingButton"))
71
- @Composable
72
- fun FloatingButton(
73
- scrollPosition: Int,
74
- bottom: Dp,
75
- onClick: () -> Unit,
76
- containerColor: Color,
77
- contentColor: Color = containerColor,
78
- icon: String,
79
- iconColor: Color? = null,
80
- text: String? = null,
81
- elevation: androidx.compose.material3.FloatingActionButtonElevation = FloatingActionButtonDefaults.elevation(
82
- 4.dp,
83
- 4.dp,
84
- 4.dp,
85
- 4.dp
86
- ),
87
- size: FABSize = FABSize.DEFAULT,
88
- position: FABPosition = FABPosition.END,
89
- keyboardSize: Dp = 0.dp,
90
- ) {
91
- val scrollPositionStateFlow = remember { MutableStateFlow(scrollPosition) }
92
- var lastScrollPosition by rememberSaveable { mutableStateOf(0) }
93
- val coroutineScope = rememberCoroutineScope()
94
- var isExpanded by rememberSaveable { mutableStateOf(false) }
95
-
96
- val startPadding = if (isExpanded) 12.dp else 0.dp
97
- val endPadding = if (isExpanded) 12.dp else 0.dp
98
- val widthIn = if ((size === FABSize.SMALL)) 36.dp else 48.dp
99
-
100
-
101
- val width = animateDpAsState(
102
- targetValue = if (isExpanded && text != null) 80.dp else widthIn,
103
- animationSpec = tween(
104
- durationMillis = 200,
105
- easing = CubicBezierEasing(0.2f, 0.2f, 0.2f, 0.2f),
106
- )
107
- )
108
-
109
- LaunchedEffect(text) {
110
- if (text != null) {
111
- coroutineScope.launch {
112
- scrollPositionStateFlow
113
- .collectLatest { debouncedScrollPosition ->
114
- isExpanded = debouncedScrollPosition > lastScrollPosition
115
- delay(300)
116
- lastScrollPosition = debouncedScrollPosition
117
-
118
- }
119
- }
120
- }
121
- }
122
-
123
- LaunchedEffect(scrollPosition) {
124
- scrollPositionStateFlow.value = scrollPosition
125
- }
126
-
127
- Box(
128
- Modifier
129
- .fillMaxSize()
130
- .padding(end = 12.dp, bottom = bottom)
131
- .offset(y = -keyboardSize)
132
- .background(Color.Transparent)
133
- .zIndex(10f),
134
- contentAlignment = if (position == FABPosition.END) Alignment.BottomEnd else Alignment.BottomCenter,
135
- ) {
136
- FloatingActionButton(
137
- onClick = onClick,
138
- shape = shape,
139
- containerColor = containerColor,
140
- contentColor = contentColor,
141
- elevation = elevation,
142
- interactionSource = remember { MutableInteractionSource() },
143
- modifier = Modifier
144
- .sizeIn(minWidth = width.value)
145
- .height(widthIn)
146
- ) {
147
- Row(
148
- modifier = Modifier.padding(start = startPadding, end = endPadding),
149
- verticalAlignment = Alignment.CenterVertically,
150
- horizontalArrangement = if (isExpanded) Arrangement.Start else Arrangement.Center
151
- ) {
152
- Icon(
153
- icon,
154
- size = if (size === FABSize.SMALL) 12.dp else 24.dp,
155
- color = iconColor ?: Color.White
156
- )
157
- AnimatedVisibility(
158
- visible = isExpanded,
159
- enter = ExtendedFabExpandAnimation,
160
- exit = ExtendedFabCollapseAnimation,
161
- ) {
162
- Row {
163
- Spacer(Modifier.width(12.dp))
164
- Text(
165
- text ?: "",
166
- color = Color.White,
167
- style = Typography.actionDefaultBold
168
- )
169
- }
170
- }
171
- }
172
- }
173
- }
174
- }
175
-
176
- private val ExtendedFabCollapseAnimation = fadeOut(
177
- animationSpec = tween(
178
- durationMillis = 800,
179
- easing = CubicBezierEasing(0.0f, 0.0f, 1.0f, 1.0f),
180
- )
181
- ) + shrinkHorizontally(
182
- animationSpec = tween(
183
- durationMillis = 500,
184
- easing = CubicBezierEasing(0.2f, 0.0f, 0.0f, 1.0f),
185
- ),
186
- shrinkTowards = Alignment.Start,
187
- )
188
-
189
- private val ExtendedFabExpandAnimation = fadeIn(
190
- animationSpec = tween(
191
- durationMillis = 200,
192
- delayMillis = 100,
193
- easing = CubicBezierEasing(0.0f, 0.0f, 1.0f, 1.0f),
194
- ),
195
- ) + expandHorizontally(
196
- animationSpec = tween(
197
- durationMillis = 500,
198
- easing = CubicBezierEasing(0.2f, 0.0f, 0.0f, 1.0f),
199
- ),
200
- expandFrom = Alignment.Start,
201
- )
@@ -1,222 +0,0 @@
1
- package vn.momo.kits.application
2
-
3
- import androidx.compose.animation.core.animateFloatAsState
4
- import androidx.compose.foundation.background
5
- import androidx.compose.foundation.border
6
- import androidx.compose.foundation.clickable
7
- import androidx.compose.foundation.layout.Arrangement
8
- import androidx.compose.foundation.layout.Box
9
- import androidx.compose.foundation.layout.BoxWithConstraints
10
- import androidx.compose.foundation.layout.Row
11
- import androidx.compose.foundation.layout.Spacer
12
- import androidx.compose.foundation.layout.fillMaxWidth
13
- import androidx.compose.foundation.layout.height
14
- import androidx.compose.foundation.layout.padding
15
- import androidx.compose.foundation.layout.size
16
- import androidx.compose.foundation.layout.width
17
- import androidx.compose.foundation.shape.RoundedCornerShape
18
- import androidx.compose.runtime.Composable
19
- import androidx.compose.runtime.LaunchedEffect
20
- import androidx.compose.runtime.getValue
21
- import androidx.compose.runtime.mutableStateOf
22
- import androidx.compose.runtime.remember
23
- import androidx.compose.runtime.setValue
24
- import androidx.compose.runtime.snapshotFlow
25
- import androidx.compose.ui.Alignment
26
- import androidx.compose.ui.Modifier
27
- import androidx.compose.ui.graphics.Color
28
- import androidx.compose.ui.graphics.graphicsLayer
29
- import androidx.compose.ui.text.style.TextAlign
30
- import androidx.compose.ui.unit.Dp
31
- import androidx.compose.ui.unit.dp
32
- import androidx.compose.ui.zIndex
33
- import kotlinx.coroutines.flow.distinctUntilChanged
34
- import kotlinx.coroutines.flow.map
35
- import vn.momo.kits.components.Icon
36
- import vn.momo.kits.components.InputSearch
37
- import vn.momo.kits.components.InputSearchProps
38
- import vn.momo.kits.const.AppTheme
39
- import vn.momo.kits.const.Colors
40
- import vn.momo.kits.const.Spacing
41
- import vn.momo.kits.modifier.conditional
42
- import vn.momo.kits.modifier.setAutomationId
43
- import vn.momo.kits.utils.getAppStatusBarHeight
44
-
45
- data class HeaderColor(val tintIconColor: Color, val backgroundButton: Color, val borderColor: Color)
46
- fun getHeaderColor(animatedHeader: AnimatedHeader?, opacity: Float, tintColor: Color?, defaultColor: Color): HeaderColor{
47
- return if(animatedHeader !== null)
48
- if (opacity == 1f || !animatedHeader.isSurface)
49
- HeaderColor(
50
- tintIconColor = Colors.black_17,
51
- backgroundButton = Colors.black_01.copy(alpha = 0.6f),
52
- borderColor = Colors.black_20.copy(alpha = 0.2f)
53
- )
54
- else
55
- HeaderColor(
56
- tintIconColor = Colors.black_01,
57
- backgroundButton = Colors.black_20.copy(alpha = 0.6f),
58
- borderColor = Color.Transparent
59
- )
60
- else
61
- if (tintColor == Colors.black_01)
62
- HeaderColor(
63
- tintIconColor = tintColor,
64
- backgroundButton = Colors.black_20.copy(alpha = 0.6f),
65
- borderColor = Colors.black_01.copy(alpha = 0.2f)
66
- )
67
- else
68
- HeaderColor(
69
- tintIconColor = tintColor ?: defaultColor,
70
- backgroundButton = Colors.black_01.copy(alpha = 0.6f),
71
- borderColor = Colors.black_20.copy(alpha = 0.2f)
72
- )
73
- }
74
-
75
- @Deprecated("Use vn.momo.kits.navigation.component.Header instead", ReplaceWith("vn.momo.kits.navigation.component.Header"))
76
- @Composable
77
- fun Header(
78
- headerType: HeaderType = HeaderType.DEFAULT,
79
- titlePosition: TitlePosition,
80
- title: String,
81
- headerRight: @Composable (() -> Unit)? = null,
82
- goBack: (() -> Unit)? = null,
83
- opacity: Float = 1f,
84
- animatedHeader: AnimatedHeader? = null,
85
- scrollState: Int = 0,
86
- inputSearchProps: InputSearchProps? = null,
87
- headerRightWidth: Dp = 0.dp,
88
- useAnimationSearch: Boolean = false,
89
- tintColor: Color? = null
90
- ) {
91
- val statusBarHeight = getAppStatusBarHeight()
92
- val color = getHeaderColor(animatedHeader, opacity, tintColor, AppTheme.current.colors.text.default)
93
- val tintIconColor = color.tintIconColor
94
- val backgroundButton = color.backgroundButton
95
- val borderColor = color.borderColor
96
-
97
- var colorFraction by remember { mutableStateOf(0f) }
98
-
99
- LaunchedEffect(scrollState) {
100
- snapshotFlow { scrollState }
101
- .map { (it / 50f).coerceIn(0f, 1f) }
102
- .distinctUntilChanged()
103
- .collect { fraction -> colorFraction = fraction }
104
- }
105
- val animations = useHeaderSearchAnimation(
106
- opacityAni = opacity,
107
- scrollState = scrollState,
108
- headerRightWidth = headerRightWidth,
109
- isBack = goBack != null
110
- )
111
-
112
- val backgroundSearch = animateColor(
113
- Colors.black_01,
114
- AppTheme.current.colors.background.default,
115
- colorFraction
116
- )
117
-
118
- val searchAnimationEnable =
119
- inputSearchProps != null && useAnimationSearch && headerType == HeaderType.EXTENDED
120
- val animatedAlpha by animateFloatAsState(targetValue = opacity, label = "BackgroundAlpha")
121
-
122
- if (headerType != HeaderType.NONE) {
123
- BoxWithConstraints(
124
- Modifier.height(statusBarHeight + HEADER_HEIGHT.dp)
125
- .fillMaxWidth()
126
- .conditional(animatedHeader !== null) { background(Color.White.copy(alpha = animatedAlpha)) }
127
- .zIndex(10f),
128
- contentAlignment = Alignment.BottomCenter
129
- ) {
130
- Row(
131
- modifier = Modifier.height(HEADER_HEIGHT.dp)
132
- .fillMaxWidth()
133
- .padding(horizontal = Spacing.M),
134
- verticalAlignment = Alignment.CenterVertically,
135
- horizontalArrangement = Arrangement.SpaceBetween
136
- ) {
137
- Box {
138
- if (goBack != null) {
139
- Box(
140
- modifier = Modifier
141
- .size(28.dp)
142
- .then(
143
- Modifier.border(
144
- 0.2.dp,
145
- borderColor,
146
- RoundedCornerShape(100)
147
- )
148
- )
149
- .background(
150
- backgroundButton,
151
- RoundedCornerShape(100)
152
- )
153
- .clickable(
154
- onClick = goBack
155
- )
156
- .padding(Spacing.XS)
157
- .setAutomationId("btn_navigation_back"),
158
- contentAlignment = Alignment.Center
159
- ) {
160
- Icon(
161
- source = "arrow-back",
162
- color = tintIconColor,
163
- size = 20.dp,
164
- )
165
- }
166
- }
167
- }
168
-
169
- if (useAnimationSearch || inputSearchProps == null) {
170
- if(headerRight == null){
171
- HeaderRight(opacity = opacity, animatedHeader = animatedHeader, tintColor = tintColor)
172
- } else {
173
- headerRight.invoke()
174
- }
175
- }
176
- }
177
-
178
- // Title
179
- Row(
180
- modifier = Modifier.height(HEADER_HEIGHT.dp)
181
- .fillMaxWidth()
182
- .padding(horizontal = Spacing.M),
183
- verticalAlignment = Alignment.CenterVertically,
184
- ) {
185
- if (goBack != null && titlePosition == TitlePosition.LEFT) {
186
- Spacer(Modifier.width(40.dp))
187
- }
188
- if (inputSearchProps != null && !useAnimationSearch) {
189
- InputSearch(inputSearchProps = inputSearchProps.copy(backgroundColor = backgroundSearch))
190
- } else {
191
- Box(
192
- Modifier.weight(1f).graphicsLayer {
193
- alpha = if (useAnimationSearch) {
194
- 1f - (opacity)
195
- } else {
196
- 1f
197
- }
198
- },
199
- contentAlignment = if (titlePosition == TitlePosition.LEFT) Alignment.TopStart else Alignment.Center
200
- ) {
201
- HeaderTitle(
202
- title = title,
203
- color = tintIconColor,
204
- modifier = Modifier
205
- .setAutomationId("title_navigation_header")
206
- .fillMaxWidth(fraction = if(titlePosition == TitlePosition.LEFT) 0.7f else 0.5f)
207
- ,
208
- textAlign = if(titlePosition == TitlePosition.LEFT) TextAlign.Start else TextAlign.Center
209
- )
210
- }
211
- }
212
- }
213
-
214
- if (searchAnimationEnable) {
215
- AnimationSearchInput(
216
- animations = animations,
217
- inputSearchProps = inputSearchProps!!
218
- )
219
- }
220
- }
221
- }
222
- }