@momo-kits/native-kits 0.155.1-hello.2 → 0.155.1-hello.2-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/.gitlab-ci.yml +15 -0
- package/.npmignore.backup +22 -0
- package/build.gradle.kts +11 -0
- package/compose/build.gradle.kts +180 -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/gradle/libs.versions.toml +57 -0
- package/gradle/wrapper/gradle-wrapper.jar +0 -0
- package/gradle/wrapper/gradle-wrapper.properties +8 -0
- package/gradle.properties +26 -0
- package/gradlew +252 -0
- package/gradlew.bat +94 -0
- package/local.properties +8 -0
- package/package.json +1 -1
- package/publish_release.sh +103 -0
- package/settings.gradle.kts +52 -0
package/.gitlab-ci.yml
ADDED
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
stages:
|
|
2
|
+
- build_release_publish
|
|
3
|
+
|
|
4
|
+
build_release_publish:
|
|
5
|
+
stage: build_release_publish
|
|
6
|
+
only:
|
|
7
|
+
variables:
|
|
8
|
+
- $CI_COMMIT_MESSAGE =~ /\[ci build\]/
|
|
9
|
+
except:
|
|
10
|
+
variables:
|
|
11
|
+
- $CI_COMMIT_REF_NAME =~ /^engine\/w*/
|
|
12
|
+
tags:
|
|
13
|
+
- momo-publish-package-runner
|
|
14
|
+
script:
|
|
15
|
+
- sh publish_release.sh
|
|
@@ -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
|
package/build.gradle.kts
ADDED
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
plugins {
|
|
2
|
+
// this is necessary to avoid the plugins to be loaded multiple times
|
|
3
|
+
// in each subproject's classloader
|
|
4
|
+
alias(libs.plugins.android.application) apply false
|
|
5
|
+
alias(libs.plugins.android.library) apply false
|
|
6
|
+
alias(libs.plugins.compose) apply false
|
|
7
|
+
alias(libs.plugins.kotlin.compose.compiler) apply false
|
|
8
|
+
alias(libs.plugins.jetbrains.kotlin.multiplatform) apply false
|
|
9
|
+
alias(libs.plugins.jetbrains.kotlin.serialization) apply false
|
|
10
|
+
alias(libs.plugins.vanniktech.mavenPublish) apply false
|
|
11
|
+
}
|
|
@@ -0,0 +1,180 @@
|
|
|
1
|
+
import com.vanniktech.maven.publish.JavadocJar
|
|
2
|
+
import com.vanniktech.maven.publish.KotlinMultiplatform
|
|
3
|
+
import org.jetbrains.kotlin.gradle.dsl.JvmTarget
|
|
4
|
+
|
|
5
|
+
plugins {
|
|
6
|
+
alias(libs.plugins.jetbrains.kotlin.multiplatform)
|
|
7
|
+
alias(libs.plugins.android.library)
|
|
8
|
+
alias(libs.plugins.compose)
|
|
9
|
+
alias(libs.plugins.kotlin.compose.compiler)
|
|
10
|
+
alias(libs.plugins.vanniktech.mavenPublish)
|
|
11
|
+
id(libs.plugins.jetbrains.kotlin.cocoapods.get().pluginId)
|
|
12
|
+
kotlin("plugin.serialization")
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
val gitlabName: String? = findProperty("name") as String? ?: ""
|
|
16
|
+
val gitlabRepo: String? = findProperty("repo") as String? ?: ""
|
|
17
|
+
val gitlabUrl: String? = findProperty("url") as String? ?: ""
|
|
18
|
+
val gitlabGroup: String? = findProperty("group") as String? ?: ""
|
|
19
|
+
val gitlabArtifactId: String = findProperty("artifact.id") as String? ?: ""
|
|
20
|
+
val gitlabVersion: String? = findProperty("version") as String? ?: ""
|
|
21
|
+
val gitlabUser: String? = findProperty("gitlab.user") as String? ?: ""
|
|
22
|
+
val gitlabKey: String? = findProperty("gitlab.password") as String? ?: ""
|
|
23
|
+
|
|
24
|
+
kotlin {
|
|
25
|
+
androidTarget {
|
|
26
|
+
compilerOptions {
|
|
27
|
+
jvmTarget.set(JvmTarget.JVM_17)
|
|
28
|
+
}
|
|
29
|
+
publishLibraryVariants("release")
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
val fwName = gitlabArtifactId
|
|
33
|
+
val iosTargets = listOf(iosX64(), iosArm64(), iosSimulatorArm64())
|
|
34
|
+
iosTargets.forEach {
|
|
35
|
+
it.binaries.framework {
|
|
36
|
+
baseName = fwName
|
|
37
|
+
binaryOption("bundleId", "$gitlabGroup.$fwName")
|
|
38
|
+
isStatic = true
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
cocoapods {
|
|
43
|
+
version = gitlabVersion
|
|
44
|
+
summary = "IOS Shared module"
|
|
45
|
+
homepage = "https://momo.vn"
|
|
46
|
+
ios.deploymentTarget = "15.0"
|
|
47
|
+
|
|
48
|
+
framework {
|
|
49
|
+
baseName = fwName
|
|
50
|
+
isStatic = true
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
pod("lottie-ios") {
|
|
54
|
+
moduleName = "Lottie"
|
|
55
|
+
version = "4.4.3"
|
|
56
|
+
extraOpts += listOf("-compiler-option", "-fmodules")
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
sourceSets {
|
|
61
|
+
commonMain.dependencies {
|
|
62
|
+
implementation(compose.runtime)
|
|
63
|
+
implementation(compose.material)
|
|
64
|
+
implementation(compose.material3)
|
|
65
|
+
implementation(compose.components.resources)
|
|
66
|
+
implementation(libs.ktor.client.core)
|
|
67
|
+
implementation(libs.jetbrains.coroutines.core)
|
|
68
|
+
implementation(libs.navigation.multiplatform)
|
|
69
|
+
implementation(libs.coil.multiplatform.compose)
|
|
70
|
+
implementation(libs.coil.multiplatform.core)
|
|
71
|
+
implementation(libs.coil.multiplatform.network.ktor)
|
|
72
|
+
implementation(libs.jetbrains.serialization.json)
|
|
73
|
+
implementation(libs.kotlinx.datetime)
|
|
74
|
+
api(libs.native.max.api)
|
|
75
|
+
}
|
|
76
|
+
androidMain.dependencies {
|
|
77
|
+
implementation(libs.ktor.client.okhttp)
|
|
78
|
+
implementation(libs.airbnb.lottie)
|
|
79
|
+
}
|
|
80
|
+
iosMain.dependencies {
|
|
81
|
+
implementation(libs.ktor.client.darwin)
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
android {
|
|
87
|
+
namespace = "$gitlabGroup.$gitlabArtifactId"
|
|
88
|
+
compileSdk = libs.versions.android.compileSdk.get().toInt()
|
|
89
|
+
compileOptions {
|
|
90
|
+
sourceCompatibility = JavaVersion.VERSION_17
|
|
91
|
+
targetCompatibility = JavaVersion.VERSION_17
|
|
92
|
+
}
|
|
93
|
+
defaultConfig {
|
|
94
|
+
minSdk = libs.versions.android.minSdk.get().toInt()
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
dependencies {
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
repositories {
|
|
102
|
+
google {
|
|
103
|
+
mavenContent {
|
|
104
|
+
includeGroupAndSubgroups("androidx")
|
|
105
|
+
includeGroupAndSubgroups("com.android")
|
|
106
|
+
includeGroupAndSubgroups("com.google")
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
mavenCentral()
|
|
110
|
+
maven {
|
|
111
|
+
url = uri("https://gitlab.mservice.com.vn/api/v4/projects/5400/packages/maven")
|
|
112
|
+
credentials {username = "download_packages"; password = "gldt-bjDqLpU_sPcHDuXau2ws" }
|
|
113
|
+
}
|
|
114
|
+
maven {
|
|
115
|
+
url = uri("http://nexus.mservice.com.vn:8081/repository/maven-public/")
|
|
116
|
+
isAllowInsecureProtocol = true
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
compose {
|
|
121
|
+
resources {
|
|
122
|
+
publicResClass = true
|
|
123
|
+
packageOfResClass = "vn.momo.uikits.resources"
|
|
124
|
+
generateResClass = always
|
|
125
|
+
}
|
|
126
|
+
}
|
|
127
|
+
|
|
128
|
+
publishing {
|
|
129
|
+
repositories {
|
|
130
|
+
maven {
|
|
131
|
+
name = "${gitlabRepo}Packages"
|
|
132
|
+
credentials {
|
|
133
|
+
username = gitlabUser
|
|
134
|
+
password = gitlabKey
|
|
135
|
+
}
|
|
136
|
+
url = uri("$gitlabUrl")
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
|
|
141
|
+
mavenPublishing {
|
|
142
|
+
configure(
|
|
143
|
+
KotlinMultiplatform(
|
|
144
|
+
javadocJar = JavadocJar.Empty(),
|
|
145
|
+
sourcesJar = true,
|
|
146
|
+
androidVariantsToPublish = listOf("release")
|
|
147
|
+
)
|
|
148
|
+
)
|
|
149
|
+
|
|
150
|
+
repositories {
|
|
151
|
+
maven {
|
|
152
|
+
name = "${gitlabRepo}Packages"
|
|
153
|
+
credentials { username = gitlabUser; password = gitlabKey }
|
|
154
|
+
url = uri("$gitlabUrl")
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
|
|
158
|
+
coordinates(gitlabGroup.toString(), gitlabArtifactId, gitlabVersion.toString())
|
|
159
|
+
|
|
160
|
+
pom {
|
|
161
|
+
name = "$gitlabName Klib"
|
|
162
|
+
description = "$gitlabName"
|
|
163
|
+
url = "https://gitlab.mservice.com.vn"
|
|
164
|
+
licenses {
|
|
165
|
+
license {
|
|
166
|
+
name = "The Apache License, Version 2.0"
|
|
167
|
+
url = "https://www.apache.org/licenses/LICENSE-2.0.txt"
|
|
168
|
+
distribution = "https://www.apache.org/licenses/LICENSE-2.0.txt"
|
|
169
|
+
}
|
|
170
|
+
}
|
|
171
|
+
developers {
|
|
172
|
+
developer {
|
|
173
|
+
id = "kotlin-hands-on"
|
|
174
|
+
name = "Kotlin Developer Advocate"
|
|
175
|
+
url = "https://github.com/kotlin-hands-on/"
|
|
176
|
+
}
|
|
177
|
+
}
|
|
178
|
+
}
|
|
179
|
+
}
|
|
180
|
+
|
|
@@ -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 }
|