@momo-kits/native-kits 0.152.4-beta.6 → 0.152.4-beta.8
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/CODE_OF_CONDUCT.md +133 -0
- package/CONTRIBUTING.md +114 -0
- package/LICENSE +20 -0
- package/README.md +7 -0
- package/build.gradle.kts +32 -0
- package/compose/MoMoComposeKits.podspec +54 -0
- package/compose/build.gradle.kts +149 -0
- package/compose/src/androidMain/AndroidManifest.xml +2 -0
- package/compose/src/androidMain/kotlin/vn/momo/kits/platform/Platform.android.kt +105 -0
- package/compose/src/commonMain/composeResources/files/lottie_circle_loader.json +1 -0
- 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 +57 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/application/FloatingButton.kt +201 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/application/Header.kt +222 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderAnimated.kt +48 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderBackground.kt +86 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderDefault.kt +76 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderExtended.kt +76 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderRight.kt +306 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderTitle.kt +33 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/application/LiteScreen.kt +715 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/application/NavigationContainer.kt +214 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/application/Screen.kt +396 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/application/useHeaderSearchAnimation.kt +69 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/Badge.kt +77 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/BadgeDot.kt +27 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/BadgeRibbon.kt +334 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/Button.kt +345 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/CheckBox.kt +90 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/Chip.kt +131 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/CupertinoOverscroll.kt +543 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/Divider.kt +23 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/Icon.kt +58 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/IconButton.kt +143 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/Image.kt +179 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/Information.kt +111 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/Input.kt +384 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputDropDown.kt +160 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputMoney.kt +234 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputOTP.kt +223 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputPhoneNumber.kt +232 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputSearch.kt +236 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputTextArea.kt +228 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/LazyColumnWithBouncing.kt +364 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/PaginationDot.kt +50 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/PaginationNumber.kt +34 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/PaginationScroll.kt +85 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/PaginationWhiteDot.kt +33 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/PopupNotify.kt +338 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/PopupPromotion.kt +95 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/Radio.kt +64 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/Skeleton.kt +89 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/Switch.kt +91 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/Tag.kt +86 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/Text.kt +84 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/Title.kt +208 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/TrustBanner.kt +172 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/datetimepicker/DateTimePicker.kt +199 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/datetimepicker/DateTimePickerTypes.kt +29 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/datetimepicker/DateTimePickerUtils.kt +237 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/datetimepicker/WheelPicker.kt +191 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/const/Colors.kt +306 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/const/Radius.kt +12 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/const/Spacing.kt +13 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/const/Theme.kt +191 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/const/Typography.kt +258 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/layout/Card.kt +2 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/layout/Item.kt +35 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/layout/Section.kt +2 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/AutomationId.kt +59 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/Clickable.kt +68 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/Conditional.kt +11 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/Shadow.kt +49 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/Size.kt +51 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/BottomSheet.kt +232 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/ModalScreen.kt +111 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/Navigation.kt +94 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/NavigationContainer.kt +159 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/Navigator.kt +302 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/ScaleSizeScope.kt +17 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/StackScreen.kt +484 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/bottomtab/BottomTab.kt +169 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/bottomtab/BottomTabBar.kt +216 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/bottomtab/CurvedContainer.kt +86 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/FloatingButton.kt +180 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/Header.kt +251 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/HeaderBackground.kt +80 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/HeaderRight.kt +306 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/HeaderTitle.kt +31 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/HeaderUser.kt +385 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/SnackBar.kt +117 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/platform/Platform.kt +38 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/utils/Icons.kt +1329 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/utils/Resources.kt +62 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/utils/Utils.kt +88 -0
- package/compose/src/iosMain/kotlin/vn/momo/kits/platform/Platform.ios.kt +144 -0
- package/gradle.properties +19 -0
- package/gradlew +240 -0
- package/gradlew.bat +91 -0
- package/ios/Application/ApplicationEnvironment.swift +50 -0
- package/ios/Application/Components.swift +263 -0
- package/ios/Application/ComposeApi.swift +22 -0
- package/ios/Application/FloatingButton.swift +172 -0
- package/ios/Application/HeaderRight.swift +271 -0
- package/ios/Application/Screen.swift +249 -0
- package/ios/Badge/BadgeDot.swift +31 -0
- package/ios/Button/Button.swift +211 -0
- package/ios/CalculatorKeyboard/CalculatorKeyboard.swift +126 -0
- package/ios/Checkbox/Checkbox.swift +81 -0
- package/ios/Chip/Chip.swift +96 -0
- package/ios/Colors+Radius+Spacing/Colors.swift +172 -0
- package/ios/Colors+Radius+Spacing/Radius.swift +22 -0
- package/ios/Colors+Radius+Spacing/Spacing.swift +12 -0
- package/ios/Extensions/Color++.swift +25 -0
- package/ios/Icon/Icon.swift +51 -0
- package/ios/Image/Image.swift +70 -0
- package/ios/Input/Input.swift +207 -0
- package/ios/Input/InputPhoneNumber.swift +176 -0
- package/ios/Input/InputSearch.swift +238 -0
- package/ios/Input/InputTextArea.swift +242 -0
- package/ios/Lottie/LottieView.swift +86 -0
- package/ios/OTPKeyboard/KeyboardButton.swift +41 -0
- package/ios/OTPKeyboard/OTPKeyboard.swift +145 -0
- package/ios/Popup/PopupDisplay.swift +284 -0
- package/ios/Popup/PopupInput.swift +96 -0
- package/ios/Popup/PopupPromotion.swift +73 -0
- package/ios/PopupView/FullscreenPopup.swift +251 -0
- package/ios/PopupView/Modifiers.swift +158 -0
- package/ios/PopupView/PopupView.swift +289 -0
- package/ios/PopupView/Utils++.swift +281 -0
- package/ios/ScrollIndicator/ScrollIndicator.swift +110 -0
- package/ios/Swipeable/SwipeCell.swift +278 -0
- package/ios/Swipeable/SwipeCellModel.swift +86 -0
- package/ios/Switch/Switch.swift +44 -0
- package/ios/Template/Logo/Logo.swift +75 -0
- package/ios/Template/TrustBanner/TrustBanner.swift +120 -0
- package/ios/Theme.md +18 -0
- package/ios/Typography/Text.swift +140 -0
- package/ios/Typography/Typography.swift +95 -0
- package/ios/native-kits.podspec +18 -0
- package/package.json +6 -7
- package/settings.gradle.kts +25 -0
- package/shared/build.gradle.kts +0 -74
|
@@ -0,0 +1,57 @@
|
|
|
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
|
+
}
|
|
@@ -0,0 +1,201 @@
|
|
|
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
|
+
)
|
|
@@ -0,0 +1,222 @@
|
|
|
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
|
+
}
|
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
package vn.momo.kits.application
|
|
2
|
+
|
|
3
|
+
import androidx.compose.animation.core.animateFloatAsState
|
|
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.runtime.Composable
|
|
8
|
+
import androidx.compose.runtime.getValue
|
|
9
|
+
import androidx.compose.ui.Modifier
|
|
10
|
+
import androidx.compose.ui.graphics.graphicsLayer
|
|
11
|
+
import androidx.compose.ui.unit.dp
|
|
12
|
+
import vn.momo.kits.components.Image
|
|
13
|
+
|
|
14
|
+
@Deprecated("Use vn.momo.kits.navigation.component.Header instead", ReplaceWith("vn.momo.kits.navigation.component.Header"))
|
|
15
|
+
@Composable
|
|
16
|
+
fun HeaderAnimated(image: String, scrollState: Int = 0) {
|
|
17
|
+
// Scale animation
|
|
18
|
+
val scale by animateFloatAsState(
|
|
19
|
+
targetValue = when {
|
|
20
|
+
scrollState < 0 -> (-(scrollState / 300f)).coerceIn(1f, 4f)
|
|
21
|
+
scrollState.toFloat() in 0f..300f -> 1f
|
|
22
|
+
else -> 1f
|
|
23
|
+
}
|
|
24
|
+
)
|
|
25
|
+
|
|
26
|
+
// Opacity animation
|
|
27
|
+
val opacity by animateFloatAsState(
|
|
28
|
+
targetValue = when {
|
|
29
|
+
scrollState.toFloat() in 0f..150f -> 1f - (scrollState / 300f)
|
|
30
|
+
scrollState.toFloat() in 150f..300f -> 0.5f - ((scrollState - 150f) / 300f)
|
|
31
|
+
else -> 1f
|
|
32
|
+
}
|
|
33
|
+
)
|
|
34
|
+
|
|
35
|
+
// Translation Y animation
|
|
36
|
+
|
|
37
|
+
Box(modifier = Modifier.fillMaxWidth().height(200.dp)
|
|
38
|
+
.graphicsLayer {
|
|
39
|
+
scaleX = scale
|
|
40
|
+
scaleY = scale
|
|
41
|
+
}) {
|
|
42
|
+
if (image.isEmpty()) return
|
|
43
|
+
Image(
|
|
44
|
+
source = image,
|
|
45
|
+
modifier = Modifier.fillMaxWidth().height(200.dp)
|
|
46
|
+
)
|
|
47
|
+
}
|
|
48
|
+
}
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
package vn.momo.kits.application
|
|
2
|
+
|
|
3
|
+
import androidx.compose.animation.animateColorAsState
|
|
4
|
+
import androidx.compose.animation.core.animateFloatAsState
|
|
5
|
+
import androidx.compose.foundation.layout.Box
|
|
6
|
+
import androidx.compose.foundation.layout.fillMaxWidth
|
|
7
|
+
import androidx.compose.runtime.Composable
|
|
8
|
+
import androidx.compose.runtime.getValue
|
|
9
|
+
import androidx.compose.ui.Modifier
|
|
10
|
+
import androidx.compose.ui.graphics.Color
|
|
11
|
+
import vn.momo.kits.const.AppTheme
|
|
12
|
+
import vn.momo.kits.utils.getAppStatusBarHeight
|
|
13
|
+
|
|
14
|
+
enum class TitlePosition {
|
|
15
|
+
LEFT, CENTER,
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
enum class AnimatedHeaderRatio(val value: Float){
|
|
19
|
+
RATIO_16_9(16f / 9f),
|
|
20
|
+
RATIO_1_1(1f),
|
|
21
|
+
RATIO_3_2(3f / 2f)
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
data class AnimatedHeader(
|
|
25
|
+
val aspectRatio: AnimatedHeaderRatio = AnimatedHeaderRatio.RATIO_16_9,
|
|
26
|
+
val isSurface: Boolean = true,
|
|
27
|
+
val composable: @Composable (scrollState: Int) -> Unit = {}
|
|
28
|
+
)
|
|
29
|
+
|
|
30
|
+
fun animateColor(start: Color, stop: Color, fraction: Float): Color {
|
|
31
|
+
return Color(
|
|
32
|
+
red = start.red + fraction * (stop.red - start.red),
|
|
33
|
+
green = start.green + fraction * (stop.green - start.green),
|
|
34
|
+
blue = start.blue + fraction * (stop.blue - start.blue),
|
|
35
|
+
alpha = start.alpha + fraction * (stop.alpha - start.alpha)
|
|
36
|
+
)
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
@Deprecated("Use vn.momo.kits.navigation.component.HeaderBackground instead", ReplaceWith("vn.momo.kits.navigation.component.HeaderBackground"))
|
|
40
|
+
@Composable
|
|
41
|
+
fun HeaderBackground(
|
|
42
|
+
headerType: HeaderType = HeaderType.DEFAULT,
|
|
43
|
+
scrollState: Int,
|
|
44
|
+
headerTransparent: Boolean = false,
|
|
45
|
+
) {
|
|
46
|
+
val statusBarHeight = getAppStatusBarHeight()
|
|
47
|
+
|
|
48
|
+
val opacityAni by animateFloatAsState(
|
|
49
|
+
targetValue = (1 - (scrollState / HEADER_HEIGHT * 1f)).coerceIn(0f, 1f),
|
|
50
|
+
)
|
|
51
|
+
|
|
52
|
+
val backgroundColor by animateColorAsState(
|
|
53
|
+
targetValue = if (headerTransparent) {
|
|
54
|
+
Color.Transparent
|
|
55
|
+
} else {
|
|
56
|
+
animateColor(
|
|
57
|
+
Color.Transparent,
|
|
58
|
+
AppTheme.current.colors.background.surface,
|
|
59
|
+
opacityAni
|
|
60
|
+
)
|
|
61
|
+
}
|
|
62
|
+
)
|
|
63
|
+
|
|
64
|
+
when (headerType) {
|
|
65
|
+
HeaderType.DEFAULT -> {
|
|
66
|
+
HeaderDefault(
|
|
67
|
+
opacityAni = opacityAni,
|
|
68
|
+
statusBarHeight = statusBarHeight,
|
|
69
|
+
backgroundColor = backgroundColor,
|
|
70
|
+
headerTransparent = headerTransparent
|
|
71
|
+
)
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
HeaderType.EXTENDED -> {
|
|
75
|
+
HeaderExtended(
|
|
76
|
+
opacityAni = opacityAni,
|
|
77
|
+
statusBarHeight = statusBarHeight,
|
|
78
|
+
backgroundColor = backgroundColor,
|
|
79
|
+
)
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
else -> {
|
|
83
|
+
Box(modifier = Modifier.fillMaxWidth())
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
}
|
|
@@ -0,0 +1,76 @@
|
|
|
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.runtime.Composable
|
|
8
|
+
import androidx.compose.ui.Modifier
|
|
9
|
+
import androidx.compose.ui.draw.alpha
|
|
10
|
+
import androidx.compose.ui.geometry.Offset
|
|
11
|
+
import androidx.compose.ui.graphics.Brush
|
|
12
|
+
import androidx.compose.ui.graphics.Color
|
|
13
|
+
import androidx.compose.ui.layout.ContentScale
|
|
14
|
+
import androidx.compose.ui.platform.LocalDensity
|
|
15
|
+
import androidx.compose.ui.unit.Dp
|
|
16
|
+
import androidx.compose.ui.unit.dp
|
|
17
|
+
import vn.momo.kits.components.Image
|
|
18
|
+
import vn.momo.kits.components.Options
|
|
19
|
+
import vn.momo.kits.const.AppTheme
|
|
20
|
+
import vn.momo.kits.utils.bottomBorder
|
|
21
|
+
|
|
22
|
+
@Deprecated("Use vn.momo.kits.navigation.component.Header instead", ReplaceWith("vn.momo.kits.navigation.component.Header"))
|
|
23
|
+
@Composable
|
|
24
|
+
fun HeaderDefault(
|
|
25
|
+
opacityAni: Float,
|
|
26
|
+
statusBarHeight: Dp,
|
|
27
|
+
backgroundColor: Color?,
|
|
28
|
+
headerTransparent: Boolean = false
|
|
29
|
+
) {
|
|
30
|
+
val height = statusBarHeight + HEADER_HEIGHT.dp
|
|
31
|
+
Box(
|
|
32
|
+
modifier = Modifier.fillMaxWidth().height(height)
|
|
33
|
+
.background(if(headerTransparent && backgroundColor != null) backgroundColor else AppTheme.current.colors.background.surface)
|
|
34
|
+
.bottomBorder(
|
|
35
|
+
strokeWidth = 1.dp,
|
|
36
|
+
color = if(headerTransparent && backgroundColor != null) backgroundColor else AppTheme.current.colors.border.default
|
|
37
|
+
)
|
|
38
|
+
) {
|
|
39
|
+
Box(
|
|
40
|
+
modifier = Modifier
|
|
41
|
+
.height(height)
|
|
42
|
+
.fillMaxWidth()
|
|
43
|
+
.alpha(opacityAni)
|
|
44
|
+
.background(
|
|
45
|
+
if (headerTransparent)
|
|
46
|
+
Brush.linearGradient(
|
|
47
|
+
colors = listOf(
|
|
48
|
+
Color.Transparent,
|
|
49
|
+
Color.Transparent,
|
|
50
|
+
),
|
|
51
|
+
start = Offset(0f, 0f),
|
|
52
|
+
end = Offset(0f, with(LocalDensity.current) { 154.dp.toPx() })
|
|
53
|
+
)
|
|
54
|
+
else
|
|
55
|
+
Brush.linearGradient(
|
|
56
|
+
colors = listOf(
|
|
57
|
+
Color(0xFFFDCADE),
|
|
58
|
+
Color(0x00FDCADE)
|
|
59
|
+
),
|
|
60
|
+
start = Offset(0f, 0f),
|
|
61
|
+
end = Offset(0f, with(LocalDensity.current) { 154.dp.toPx() })
|
|
62
|
+
)
|
|
63
|
+
)
|
|
64
|
+
)
|
|
65
|
+
if (AppTheme.current.assets.headerBackground != null) {
|
|
66
|
+
Image(
|
|
67
|
+
loading = false,
|
|
68
|
+
source = AppTheme.current.assets.headerBackground!!,
|
|
69
|
+
modifier = Modifier.fillMaxWidth().height(height),
|
|
70
|
+
options = Options(
|
|
71
|
+
contentScale = ContentScale.FillWidth
|
|
72
|
+
)
|
|
73
|
+
)
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
}
|