@momo-kits/native-kits 0.155.1-hello.1 → 0.155.1-hello.1-debug
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/.npmignore.backup +22 -0
- package/compose/compose.podspec +54 -0
- package/compose/src/androidMain/kotlin/vn/momo/kits/platform/Platform.android.kt +113 -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/Context.kt +95 -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 +305 -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 +121 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/application/Screen.kt +405 -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 +85 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/BadgeDot.kt +35 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/BadgeRibbon.kt +343 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/Button.kt +353 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/CheckBox.kt +98 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/Chip.kt +138 -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 +78 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/IconButton.kt +151 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/Image.kt +190 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/Information.kt +119 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/Input.kt +447 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputDropDown.kt +175 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputMoney.kt +244 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputOTP.kt +233 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputPhoneNumber.kt +233 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputSearch.kt +257 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputTextArea.kt +240 -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 +59 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/PaginationNumber.kt +44 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/PaginationScroll.kt +95 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/PaginationWhiteDot.kt +43 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/PopupNotify.kt +355 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/PopupPromotion.kt +106 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/Radio.kt +72 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/ScaleSizeScope.kt +17 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/Skeleton.kt +99 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/Switch.kt +99 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/Tag.kt +95 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/Text.kt +132 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/Title.kt +217 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/TrustBanner.kt +180 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/components/datetimepicker/DateTimePicker.kt +208 -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 +239 -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 +189 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/const/Typography.kt +285 -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/DeprecatedModifier.kt +15 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/Shadow.kt +50 -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 +241 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/ModalScreen.kt +122 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/Navigation.kt +98 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/NavigationContainer.kt +163 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/Navigator.kt +331 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/StackScreen.kt +499 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/bottomtab/BottomTab.kt +162 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/bottomtab/BottomTabBar.kt +233 -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 +190 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/Header.kt +277 -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 +370 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/SnackBar.kt +135 -0
- package/compose/src/commonMain/kotlin/vn/momo/kits/platform/Platform.kt +42 -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 +152 -0
- package/package.json +1 -1
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
sample/
|
|
2
|
+
gradle/
|
|
3
|
+
compose/
|
|
4
|
+
build/
|
|
5
|
+
|
|
6
|
+
.fleet
|
|
7
|
+
.gradle
|
|
8
|
+
.idea
|
|
9
|
+
.kotlin
|
|
10
|
+
.run
|
|
11
|
+
|
|
12
|
+
.gitattributes
|
|
13
|
+
.gitlab-ci.yml
|
|
14
|
+
|
|
15
|
+
README.md
|
|
16
|
+
build.gradle.kts
|
|
17
|
+
gradle.properties
|
|
18
|
+
gradlew
|
|
19
|
+
gradlew.bat
|
|
20
|
+
local.properties
|
|
21
|
+
publish_release.sh
|
|
22
|
+
settings.gradle.kts
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
Pod::Spec.new do |spec|
|
|
2
|
+
spec.name = 'compose'
|
|
3
|
+
spec.version = '0.155.1-test.6'
|
|
4
|
+
spec.homepage = 'https://momo.vn'
|
|
5
|
+
spec.source = { :http=> ''}
|
|
6
|
+
spec.authors = ''
|
|
7
|
+
spec.license = ''
|
|
8
|
+
spec.summary = 'IOS Shared module'
|
|
9
|
+
spec.vendored_frameworks = 'build/cocoapods/framework/kits.framework'
|
|
10
|
+
spec.libraries = 'c++'
|
|
11
|
+
spec.ios.deployment_target = '15.0'
|
|
12
|
+
spec.dependency 'lottie-ios', '4.4.3'
|
|
13
|
+
|
|
14
|
+
if !Dir.exist?('build/cocoapods/framework/kits.framework') || Dir.empty?('build/cocoapods/framework/kits.framework')
|
|
15
|
+
raise "
|
|
16
|
+
|
|
17
|
+
Kotlin framework 'kits' doesn't exist yet, so a proper Xcode project can't be generated.
|
|
18
|
+
'pod install' should be executed after running ':generateDummyFramework' Gradle task:
|
|
19
|
+
|
|
20
|
+
./gradlew :compose:generateDummyFramework
|
|
21
|
+
|
|
22
|
+
Alternatively, proper pod installation is performed during Gradle sync in the IDE (if Podfile location is set)"
|
|
23
|
+
end
|
|
24
|
+
|
|
25
|
+
spec.xcconfig = {
|
|
26
|
+
'ENABLE_USER_SCRIPT_SANDBOXING' => 'NO',
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
spec.pod_target_xcconfig = {
|
|
30
|
+
'KOTLIN_PROJECT_PATH' => ':compose',
|
|
31
|
+
'PRODUCT_MODULE_NAME' => 'kits',
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
spec.script_phases = [
|
|
35
|
+
{
|
|
36
|
+
:name => 'Build compose',
|
|
37
|
+
:execution_position => :before_compile,
|
|
38
|
+
:shell_path => '/bin/sh',
|
|
39
|
+
:script => <<-SCRIPT
|
|
40
|
+
if [ "YES" = "$OVERRIDE_KOTLIN_BUILD_IDE_SUPPORTED" ]; then
|
|
41
|
+
echo "Skipping Gradle build task invocation due to OVERRIDE_KOTLIN_BUILD_IDE_SUPPORTED environment variable set to \"YES\""
|
|
42
|
+
exit 0
|
|
43
|
+
fi
|
|
44
|
+
set -ev
|
|
45
|
+
REPO_ROOT="$PODS_TARGET_SRCROOT"
|
|
46
|
+
"$REPO_ROOT/../gradlew" -p "$REPO_ROOT" $KOTLIN_PROJECT_PATH:syncFramework \
|
|
47
|
+
-Pkotlin.native.cocoapods.platform=$PLATFORM_NAME \
|
|
48
|
+
-Pkotlin.native.cocoapods.archs="$ARCHS" \
|
|
49
|
+
-Pkotlin.native.cocoapods.configuration="$CONFIGURATION"
|
|
50
|
+
SCRIPT
|
|
51
|
+
}
|
|
52
|
+
]
|
|
53
|
+
spec.resources = ['build/compose/cocoapods/compose-resources']
|
|
54
|
+
end
|
|
@@ -0,0 +1,113 @@
|
|
|
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.draw.drawBehind
|
|
14
|
+
import androidx.compose.ui.graphics.Color
|
|
15
|
+
import androidx.compose.ui.graphics.NativePaint
|
|
16
|
+
import androidx.compose.ui.graphics.Paint
|
|
17
|
+
import androidx.compose.ui.graphics.drawscope.drawIntoCanvas
|
|
18
|
+
import androidx.compose.ui.graphics.toArgb
|
|
19
|
+
import androidx.compose.ui.platform.LocalConfiguration
|
|
20
|
+
import androidx.compose.ui.unit.Dp
|
|
21
|
+
import androidx.compose.ui.unit.dp
|
|
22
|
+
import com.airbnb.lottie.LottieProperty
|
|
23
|
+
import com.airbnb.lottie.compose.LottieAnimation
|
|
24
|
+
import com.airbnb.lottie.compose.LottieCompositionSpec
|
|
25
|
+
import com.airbnb.lottie.compose.LottieConstants
|
|
26
|
+
import com.airbnb.lottie.compose.rememberLottieComposition
|
|
27
|
+
import com.airbnb.lottie.compose.rememberLottieDynamicProperties
|
|
28
|
+
import com.airbnb.lottie.compose.rememberLottieDynamicProperty
|
|
29
|
+
import vn.momo.kits.const.AppNavigationBar
|
|
30
|
+
import vn.momo.kits.const.AppStatusBar
|
|
31
|
+
import vn.momo.kits.utils.readJson
|
|
32
|
+
import androidx.activity.compose.BackHandler as AndroidBackHandler
|
|
33
|
+
|
|
34
|
+
actual fun getPlatformName(): String = "Android"
|
|
35
|
+
|
|
36
|
+
@Composable
|
|
37
|
+
actual fun getScreenDimensions(): ScreenDimension {
|
|
38
|
+
val config = LocalConfiguration.current
|
|
39
|
+
return ScreenDimension(
|
|
40
|
+
config.screenWidthDp, config.screenHeightDp
|
|
41
|
+
)
|
|
42
|
+
}
|
|
43
|
+
|
|
44
|
+
actual fun NativePaint.setMaskFilter(blurRadius: Float) {
|
|
45
|
+
this.maskFilter = BlurMaskFilter(blurRadius, BlurMaskFilter.Blur.NORMAL)
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
@SuppressLint("InternalInsetResource")
|
|
49
|
+
@Composable
|
|
50
|
+
actual fun getStatusBarHeight(): Dp {
|
|
51
|
+
val resourceId = Resources.getSystem().getIdentifier(
|
|
52
|
+
"status_bar_height",
|
|
53
|
+
"dimen",
|
|
54
|
+
"android"
|
|
55
|
+
)
|
|
56
|
+
return if(resourceId > 0) Resources.getSystem().getDimensionPixelSize(resourceId).dp else 0.dp
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
@Composable
|
|
60
|
+
actual fun BackHandler(enabled: Boolean, onBack: () -> Unit) {
|
|
61
|
+
AndroidBackHandler(enabled = enabled, onBack = onBack)
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
@Composable
|
|
65
|
+
actual fun getScreenHeight(): Dp {
|
|
66
|
+
return getScreenDimensions().height.dp + if (getAndroidBuildVersion() >= 35) 0.dp else AppStatusBar.current + AppNavigationBar.current
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
actual fun getAndroidBuildVersion(): Int = Build.VERSION.SDK_INT
|
|
70
|
+
|
|
71
|
+
@Composable
|
|
72
|
+
actual fun LottieAnimation(
|
|
73
|
+
path: String,
|
|
74
|
+
tintColor: Color?,
|
|
75
|
+
bgColor: Color?,
|
|
76
|
+
modifier: Modifier
|
|
77
|
+
) {
|
|
78
|
+
val json = readJson(path)
|
|
79
|
+
|
|
80
|
+
if (json.isEmpty()) {
|
|
81
|
+
Box(modifier)
|
|
82
|
+
return
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
val composition by rememberLottieComposition(
|
|
86
|
+
LottieCompositionSpec.JsonString(json)
|
|
87
|
+
)
|
|
88
|
+
|
|
89
|
+
val colorFilter = PorterDuffColorFilter(
|
|
90
|
+
tintColor?.toArgb() ?: Color.White.toArgb(),
|
|
91
|
+
PorterDuff.Mode.SRC_ATOP
|
|
92
|
+
)
|
|
93
|
+
|
|
94
|
+
val dynamicProperties = rememberLottieDynamicProperties(
|
|
95
|
+
rememberLottieDynamicProperty(
|
|
96
|
+
property = LottieProperty.COLOR_FILTER,
|
|
97
|
+
value = colorFilter,
|
|
98
|
+
keyPath = arrayOf("**")
|
|
99
|
+
)
|
|
100
|
+
)
|
|
101
|
+
|
|
102
|
+
LottieAnimation(
|
|
103
|
+
composition = composition,
|
|
104
|
+
iterations = LottieConstants.IterateForever,
|
|
105
|
+
dynamicProperties = if (tintColor != null) dynamicProperties else null,
|
|
106
|
+
modifier = modifier
|
|
107
|
+
)
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
actual fun NativePaint.setColor(color: Color){
|
|
111
|
+
this.color = color.toArgb()
|
|
112
|
+
}
|
|
113
|
+
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
@@ -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,95 @@
|
|
|
1
|
+
package vn.momo.kits.application
|
|
2
|
+
|
|
3
|
+
import androidx.compose.runtime.Immutable
|
|
4
|
+
import androidx.compose.runtime.staticCompositionLocalOf
|
|
5
|
+
import vn.momo.kits.components.TrustBannerData
|
|
6
|
+
|
|
7
|
+
@Immutable
|
|
8
|
+
data class FeatureFlags(
|
|
9
|
+
val showBaseLineDebug: Boolean? = false,
|
|
10
|
+
)
|
|
11
|
+
|
|
12
|
+
@Immutable
|
|
13
|
+
data class KitConfig(
|
|
14
|
+
val trustBanner: TrustBannerData? = null,
|
|
15
|
+
val headerBar: String? = null,
|
|
16
|
+
val headerGradient: String? = null,
|
|
17
|
+
)
|
|
18
|
+
|
|
19
|
+
@Immutable
|
|
20
|
+
data class MiniAppContext(
|
|
21
|
+
val appIcon: String = "",
|
|
22
|
+
val appName: Any? = null,
|
|
23
|
+
val appId: String = "",
|
|
24
|
+
val appCode: String = "",
|
|
25
|
+
val description: Any? = null,
|
|
26
|
+
val support: Map<String, Any?> = emptyMap(),
|
|
27
|
+
val toolkitConfig: Map<String, Any?> = emptyMap(),
|
|
28
|
+
val providerId: String = "",
|
|
29
|
+
val permissions: List<Map<String, Any>>? = emptyList(),
|
|
30
|
+
val features: FeatureFlags? = null,
|
|
31
|
+
) {
|
|
32
|
+
companion object {
|
|
33
|
+
|
|
34
|
+
fun toMap(context: MiniAppContext?): Map<String, Any?> = mapOf(
|
|
35
|
+
"icon" to (context?.appIcon ?: ""),
|
|
36
|
+
"name" to context?.appName,
|
|
37
|
+
"appId" to (context?.appId ?: ""),
|
|
38
|
+
"code" to (context?.appCode ?: ""),
|
|
39
|
+
"description" to (context?.description ?: ""),
|
|
40
|
+
"support" to (context?.support ?: emptyMap()),
|
|
41
|
+
"toolkitConfig" to (context?.toolkitConfig ?: emptyMap()),
|
|
42
|
+
"providerId" to (context?.providerId ?: ""),
|
|
43
|
+
"permissions" to (context?.permissions ?: emptyList()),
|
|
44
|
+
)
|
|
45
|
+
|
|
46
|
+
fun merge(parent: MiniAppContext?, child: MiniAppContext?): MiniAppContext? {
|
|
47
|
+
if (parent == null && child == null) return null
|
|
48
|
+
if (parent == null) return child
|
|
49
|
+
if (child == null) return parent
|
|
50
|
+
|
|
51
|
+
return MiniAppContext(
|
|
52
|
+
appIcon = parent.appIcon.ifBlank { child.appIcon },
|
|
53
|
+
appName = parent.appName ?: child.appName,
|
|
54
|
+
appId = parent.appId.ifBlank { child.appId },
|
|
55
|
+
appCode = parent.appCode.ifBlank { child.appCode },
|
|
56
|
+
description = parent.description ?: child.description,
|
|
57
|
+
support = mergeMaps(parent.support, child.support),
|
|
58
|
+
toolkitConfig = mergeMaps(parent.toolkitConfig, child.toolkitConfig),
|
|
59
|
+
providerId = parent.providerId.ifBlank { child.providerId },
|
|
60
|
+
permissions = if (!parent.permissions.isNullOrEmpty()) parent.permissions else child.permissions,
|
|
61
|
+
features = mergeFeatureFlags(parent.features, child.features)
|
|
62
|
+
)
|
|
63
|
+
}
|
|
64
|
+
|
|
65
|
+
private fun mergeMaps(parent: Map<String, Any?>, child: Map<String, Any?>): Map<String, Any?> {
|
|
66
|
+
return child + parent
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
private fun mergeFeatureFlags(parent: FeatureFlags?, child: FeatureFlags?): FeatureFlags? {
|
|
70
|
+
if (parent == null && child == null) return null
|
|
71
|
+
if (parent == null) return child
|
|
72
|
+
if (child == null) return parent
|
|
73
|
+
|
|
74
|
+
return FeatureFlags(
|
|
75
|
+
showBaseLineDebug = parent.showBaseLineDebug ?: child.showBaseLineDebug
|
|
76
|
+
)
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
fun MiniAppContext?.isShowBaselineDebug(): Boolean = this?.features?.showBaseLineDebug == true
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
val ApplicationContext = staticCompositionLocalOf<MiniAppContext?> {
|
|
84
|
+
null
|
|
85
|
+
}
|
|
86
|
+
|
|
87
|
+
val AppConfig = staticCompositionLocalOf<KitConfig?> {
|
|
88
|
+
null
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
val AppLanguage = staticCompositionLocalOf<String?> {
|
|
92
|
+
null
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
internal val ScaleSizeMaxRate = staticCompositionLocalOf<Float?> { null }
|
|
@@ -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
|
+
)
|