@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.
- package/package.json +7 -6
- package/shared/build.gradle.kts +74 -0
- package/CODE_OF_CONDUCT.md +0 -133
- package/CONTRIBUTING.md +0 -114
- package/LICENSE +0 -20
- package/README.md +0 -7
- package/build.gradle.kts +0 -32
- package/compose/MoMoComposeKits.podspec +0 -54
- package/compose/build.gradle.kts +0 -149
- package/compose/src/androidMain/AndroidManifest.xml +0 -2
- package/compose/src/androidMain/kotlin/vn/momo/kits/platform/Platform.android.kt +0 -105
- package/compose/src/commonMain/composeResources/files/lottie_circle_loader.json +0 -1
- package/compose/src/commonMain/composeResources/font/momosignature.otf +0 -0
- package/compose/src/commonMain/composeResources/font/momotrustdisplay.otf +0 -0
- package/compose/src/commonMain/composeResources/font/sfprotext_black.otf +0 -0
- package/compose/src/commonMain/composeResources/font/sfprotext_black.ttf +0 -0
- package/compose/src/commonMain/composeResources/font/sfprotext_bold.ttf +0 -0
- package/compose/src/commonMain/composeResources/font/sfprotext_heavy.ttf +0 -0
- package/compose/src/commonMain/composeResources/font/sfprotext_light.ttf +0 -0
- package/compose/src/commonMain/composeResources/font/sfprotext_medium.ttf +0 -0
- package/compose/src/commonMain/composeResources/font/sfprotext_regular.ttf +0 -0
- package/compose/src/commonMain/composeResources/font/sfprotext_semibold.ttf +0 -0
- package/compose/src/commonMain/composeResources/font/sfprotext_thin.otf +0 -0
- package/compose/src/commonMain/composeResources/font/sfprotext_thin.ttf +0 -0
- package/compose/src/commonMain/composeResources/font/sfprotext_ultralight.otf +0 -0
- package/compose/src/commonMain/composeResources/font/sfprotext_ultralight.ttf +0 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/application/AnimationSearchInput.kt +0 -57
- package/compose/src/commonMain/kotlin/vn/momo/kits/application/FloatingButton.kt +0 -201
- package/compose/src/commonMain/kotlin/vn/momo/kits/application/Header.kt +0 -222
- package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderAnimated.kt +0 -48
- package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderBackground.kt +0 -86
- package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderDefault.kt +0 -76
- package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderExtended.kt +0 -76
- package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderRight.kt +0 -306
- package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderTitle.kt +0 -33
- package/compose/src/commonMain/kotlin/vn/momo/kits/application/LiteScreen.kt +0 -715
- package/compose/src/commonMain/kotlin/vn/momo/kits/application/NavigationContainer.kt +0 -214
- package/compose/src/commonMain/kotlin/vn/momo/kits/application/Screen.kt +0 -236
- package/compose/src/commonMain/kotlin/vn/momo/kits/application/useHeaderSearchAnimation.kt +0 -69
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/Badge.kt +0 -77
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/BadgeDot.kt +0 -27
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/BadgeRibbon.kt +0 -334
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/Button.kt +0 -345
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/CheckBox.kt +0 -90
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/Chip.kt +0 -131
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/CupertinoOverscroll.kt +0 -543
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/Divider.kt +0 -23
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/Icon.kt +0 -69
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/IconButton.kt +0 -143
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/Image.kt +0 -179
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/Information.kt +0 -111
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/Input.kt +0 -384
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputDropDown.kt +0 -160
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputMoney.kt +0 -234
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputOTP.kt +0 -223
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputPhoneNumber.kt +0 -232
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputSearch.kt +0 -236
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputTextArea.kt +0 -228
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/LazyColumnWithBouncing.kt +0 -364
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/PaginationDot.kt +0 -50
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/PaginationNumber.kt +0 -34
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/PaginationScroll.kt +0 -85
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/PaginationWhiteDot.kt +0 -33
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/PopupNotify.kt +0 -338
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/PopupPromotion.kt +0 -95
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/Radio.kt +0 -64
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/Skeleton.kt +0 -89
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/Switch.kt +0 -91
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/Tag.kt +0 -86
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/Text.kt +0 -84
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/Title.kt +0 -208
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/TrustBanner.kt +0 -172
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/datetimepicker/DateTimePicker.kt +0 -199
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/datetimepicker/DateTimePickerTypes.kt +0 -29
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/datetimepicker/DateTimePickerUtils.kt +0 -237
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/datetimepicker/WheelPicker.kt +0 -191
- package/compose/src/commonMain/kotlin/vn/momo/kits/const/Colors.kt +0 -306
- package/compose/src/commonMain/kotlin/vn/momo/kits/const/Radius.kt +0 -12
- package/compose/src/commonMain/kotlin/vn/momo/kits/const/Spacing.kt +0 -13
- package/compose/src/commonMain/kotlin/vn/momo/kits/const/Theme.kt +0 -191
- package/compose/src/commonMain/kotlin/vn/momo/kits/const/Typography.kt +0 -258
- package/compose/src/commonMain/kotlin/vn/momo/kits/layout/Card.kt +0 -2
- package/compose/src/commonMain/kotlin/vn/momo/kits/layout/Item.kt +0 -35
- package/compose/src/commonMain/kotlin/vn/momo/kits/layout/Section.kt +0 -2
- package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/AutomationId.kt +0 -59
- package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/Clickable.kt +0 -68
- package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/Conditional.kt +0 -11
- package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/Shadow.kt +0 -49
- package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/Size.kt +0 -51
- package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/BottomSheet.kt +0 -232
- package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/ModalScreen.kt +0 -111
- package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/Navigation.kt +0 -94
- package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/NavigationContainer.kt +0 -159
- package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/Navigator.kt +0 -232
- package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/ScaleSizeScope.kt +0 -17
- package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/StackScreen.kt +0 -459
- package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/bottomtab/BottomTab.kt +0 -169
- package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/bottomtab/BottomTabBar.kt +0 -216
- package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/bottomtab/CurvedContainer.kt +0 -86
- package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/FloatingButton.kt +0 -180
- package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/Header.kt +0 -251
- package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/HeaderBackground.kt +0 -80
- package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/HeaderRight.kt +0 -306
- package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/HeaderTitle.kt +0 -31
- package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/HeaderUser.kt +0 -385
- package/compose/src/commonMain/kotlin/vn/momo/kits/platform/Platform.kt +0 -38
- package/compose/src/commonMain/kotlin/vn/momo/kits/utils/Icons.kt +0 -1329
- package/compose/src/commonMain/kotlin/vn/momo/kits/utils/Resources.kt +0 -62
- package/compose/src/commonMain/kotlin/vn/momo/kits/utils/Utils.kt +0 -88
- package/compose/src/iosMain/kotlin/vn/momo/kits/platform/Platform.ios.kt +0 -144
- package/gradle.properties +0 -19
- package/gradlew +0 -240
- package/gradlew.bat +0 -91
- package/ios/Application/ApplicationEnvironment.swift +0 -50
- package/ios/Application/Components.swift +0 -263
- package/ios/Application/ComposeApi.swift +0 -22
- package/ios/Application/FloatingButton.swift +0 -172
- package/ios/Application/HeaderRight.swift +0 -271
- package/ios/Application/Screen.swift +0 -249
- package/ios/Badge/BadgeDot.swift +0 -31
- package/ios/Button/Button.swift +0 -211
- package/ios/CalculatorKeyboard/CalculatorKeyboard.swift +0 -126
- package/ios/Checkbox/Checkbox.swift +0 -81
- package/ios/Chip/Chip.swift +0 -96
- package/ios/Colors+Radius+Spacing/Colors.swift +0 -172
- package/ios/Colors+Radius+Spacing/Radius.swift +0 -22
- package/ios/Colors+Radius+Spacing/Spacing.swift +0 -12
- package/ios/Extensions/Color++.swift +0 -25
- package/ios/Icon/Icon.swift +0 -51
- package/ios/Image/Image.swift +0 -70
- package/ios/Input/Input.swift +0 -207
- package/ios/Input/InputPhoneNumber.swift +0 -176
- package/ios/Input/InputSearch.swift +0 -238
- package/ios/Input/InputTextArea.swift +0 -242
- package/ios/Lottie/LottieView.swift +0 -86
- package/ios/OTPKeyboard/KeyboardButton.swift +0 -41
- package/ios/OTPKeyboard/OTPKeyboard.swift +0 -145
- package/ios/Popup/PopupDisplay.swift +0 -284
- package/ios/Popup/PopupInput.swift +0 -96
- package/ios/Popup/PopupPromotion.swift +0 -73
- package/ios/PopupView/FullscreenPopup.swift +0 -251
- package/ios/PopupView/Modifiers.swift +0 -158
- package/ios/PopupView/PopupView.swift +0 -289
- package/ios/PopupView/Utils++.swift +0 -281
- package/ios/ScrollIndicator/ScrollIndicator.swift +0 -110
- package/ios/Swipeable/SwipeCell.swift +0 -278
- package/ios/Swipeable/SwipeCellModel.swift +0 -86
- package/ios/Switch/Switch.swift +0 -44
- package/ios/Template/Logo/Logo.swift +0 -75
- package/ios/Template/TrustBanner/TrustBanner.swift +0 -120
- package/ios/Theme.md +0 -18
- package/ios/Typography/Text.swift +0 -140
- package/ios/Typography/Typography.swift +0 -95
- package/ios/native-kits.podspec +0 -18
- 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":[]}
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
@@ -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
|
-
}
|