diff --git a/android/.idea/deploymentTargetDropDown.xml b/android/.idea/deploymentTargetDropDown.xml
index 2afb6d0..f65b26e 100644
--- a/android/.idea/deploymentTargetDropDown.xml
+++ b/android/.idea/deploymentTargetDropDown.xml
@@ -2,12 +2,21 @@
-
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/android/.idea/gradle.xml b/android/.idea/gradle.xml
index 8696c91..2eb04d2 100644
--- a/android/.idea/gradle.xml
+++ b/android/.idea/gradle.xml
@@ -10,6 +10,7 @@
+
diff --git a/android/e2e/.gitignore b/android/e2e/.gitignore
new file mode 100644
index 0000000..42afabf
--- /dev/null
+++ b/android/e2e/.gitignore
@@ -0,0 +1 @@
+/build
\ No newline at end of file
diff --git a/android/e2e/build.gradle.kts b/android/e2e/build.gradle.kts
new file mode 100644
index 0000000..a470777
--- /dev/null
+++ b/android/e2e/build.gradle.kts
@@ -0,0 +1,70 @@
+plugins {
+ id("com.android.application")
+ id("org.jetbrains.kotlin.android")
+}
+
+android {
+ namespace = "com.nativebrik.e2e"
+ compileSdk = 34
+
+ defaultConfig {
+ applicationId = "com.nativebrik.e2e"
+ minSdk = 26
+ targetSdk = 34
+ versionCode = 1
+ versionName = "1.0"
+
+ testInstrumentationRunner = "androidx.test.runner.AndroidJUnitRunner"
+ vectorDrawables {
+ useSupportLibrary = true
+ }
+ }
+
+ buildTypes {
+ release {
+ isMinifyEnabled = false
+ proguardFiles(
+ getDefaultProguardFile("proguard-android-optimize.txt"),
+ "proguard-rules.pro"
+ )
+ }
+ }
+ compileOptions {
+ sourceCompatibility = JavaVersion.VERSION_1_8
+ targetCompatibility = JavaVersion.VERSION_1_8
+ }
+ kotlinOptions {
+ jvmTarget = "1.8"
+ }
+ buildFeatures {
+ compose = true
+ }
+ composeOptions {
+ kotlinCompilerExtensionVersion = "1.5.1"
+ }
+ packaging {
+ resources {
+ excludes += "/META-INF/{AL2.0,LGPL2.1}"
+ }
+ }
+}
+
+dependencies {
+ implementation(project(":nativebrik"))
+
+ implementation("androidx.core:core-ktx:1.12.0")
+ implementation("androidx.lifecycle:lifecycle-runtime-ktx:2.7.0")
+ implementation("androidx.activity:activity-compose:1.8.2")
+ implementation(platform("androidx.compose:compose-bom:2023.08.00"))
+ implementation("androidx.compose.ui:ui")
+ implementation("androidx.compose.ui:ui-graphics")
+ implementation("androidx.compose.ui:ui-tooling-preview")
+ implementation("androidx.compose.material3:material3")
+ testImplementation("junit:junit:4.13.2")
+ androidTestImplementation("androidx.test.ext:junit:1.1.5")
+ androidTestImplementation("androidx.test.espresso:espresso-core:3.5.1")
+ androidTestImplementation(platform("androidx.compose:compose-bom:2023.08.00"))
+ androidTestImplementation("androidx.compose.ui:ui-test-junit4")
+ debugImplementation("androidx.compose.ui:ui-tooling")
+ debugImplementation("androidx.compose.ui:ui-test-manifest")
+}
\ No newline at end of file
diff --git a/android/e2e/proguard-rules.pro b/android/e2e/proguard-rules.pro
new file mode 100644
index 0000000..481bb43
--- /dev/null
+++ b/android/e2e/proguard-rules.pro
@@ -0,0 +1,21 @@
+# Add project specific ProGuard rules here.
+# You can control the set of applied configuration files using the
+# proguardFiles setting in build.gradle.
+#
+# For more details, see
+# http://developer.android.com/guide/developing/tools/proguard.html
+
+# If your project uses WebView with JS, uncomment the following
+# and specify the fully qualified class name to the JavaScript interface
+# class:
+#-keepclassmembers class fqcn.of.javascript.interface.for.webview {
+# public *;
+#}
+
+# Uncomment this to preserve the line number information for
+# debugging stack traces.
+#-keepattributes SourceFile,LineNumberTable
+
+# If you keep the line number information, uncomment this to
+# hide the original source file name.
+#-renamesourcefileattribute SourceFile
\ No newline at end of file
diff --git a/android/e2e/src/androidTest/java/com/nativebrik/e2e/ExampleInstrumentedTest.kt b/android/e2e/src/androidTest/java/com/nativebrik/e2e/ExampleInstrumentedTest.kt
new file mode 100644
index 0000000..636083a
--- /dev/null
+++ b/android/e2e/src/androidTest/java/com/nativebrik/e2e/ExampleInstrumentedTest.kt
@@ -0,0 +1,24 @@
+package com.nativebrik.e2e
+
+import androidx.test.platform.app.InstrumentationRegistry
+import androidx.test.ext.junit.runners.AndroidJUnit4
+
+import org.junit.Test
+import org.junit.runner.RunWith
+
+import org.junit.Assert.*
+
+/**
+ * Instrumented test, which will execute on an Android device.
+ *
+ * See [testing documentation](http://d.android.com/tools/testing).
+ */
+@RunWith(AndroidJUnit4::class)
+class ExampleInstrumentedTest {
+ @Test
+ fun useAppContext() {
+ // Context of the app under test.
+ val appContext = InstrumentationRegistry.getInstrumentation().targetContext
+ assertEquals("com.nativebrik.e2e", appContext.packageName)
+ }
+}
\ No newline at end of file
diff --git a/android/e2e/src/main/AndroidManifest.xml b/android/e2e/src/main/AndroidManifest.xml
new file mode 100644
index 0000000..f713342
--- /dev/null
+++ b/android/e2e/src/main/AndroidManifest.xml
@@ -0,0 +1,26 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/android/e2e/src/main/java/com/nativebrik/e2e/MainActivity.kt b/android/e2e/src/main/java/com/nativebrik/e2e/MainActivity.kt
new file mode 100644
index 0000000..8f29286
--- /dev/null
+++ b/android/e2e/src/main/java/com/nativebrik/e2e/MainActivity.kt
@@ -0,0 +1,87 @@
+package com.nativebrik.e2e
+
+import android.os.Bundle
+import androidx.activity.ComponentActivity
+import androidx.activity.compose.setContent
+import androidx.compose.foundation.layout.Arrangement
+import androidx.compose.foundation.layout.Column
+import androidx.compose.foundation.layout.fillMaxSize
+import androidx.compose.foundation.layout.height
+import androidx.compose.material3.CircularProgressIndicator
+import androidx.compose.material3.MaterialTheme
+import androidx.compose.material3.Surface
+import androidx.compose.material3.Text
+import androidx.compose.ui.Alignment
+import androidx.compose.ui.Modifier
+import androidx.compose.ui.unit.dp
+import com.nativebrik.e2e.ui.theme.NativebrikAndroidTheme
+import com.nativebrik.sdk.Config
+import com.nativebrik.sdk.Nativebrik
+import com.nativebrik.sdk.NativebrikClient
+import com.nativebrik.sdk.NativebrikProvider
+import com.nativebrik.sdk.component.EmbeddingLoadingState
+import com.nativebrik.sdk.remoteconfig.RemoteConfigLoadingState
+
+class MainActivity : ComponentActivity() {
+ private lateinit var nativebrik: NativebrikClient
+
+ override fun onCreate(savedInstanceState: Bundle?) {
+ super.onCreate(savedInstanceState)
+ this.nativebrik = NativebrikClient(
+ config = Config(projectId = "ckto7v223akg00ag3jsg"),
+ context = this.applicationContext,
+ )
+
+ setContent {
+ NativebrikAndroidTheme {
+ // A surface container using the 'background' color from the theme
+ NativebrikProvider(client = nativebrik) {
+ Surface(
+ modifier = Modifier.fillMaxSize(),
+ color = MaterialTheme.colorScheme.background
+ ) {
+ Column(
+ verticalArrangement = Arrangement.Center,
+ horizontalAlignment = Alignment.CenterHorizontally,
+ ) {
+ // embedding
+ Nativebrik.client.experiment.Embedding(
+ "EMBEDDING_FOR_E2E",
+ modifier = Modifier.height(240f.dp),
+ content = {
+ when (it) {
+ is EmbeddingLoadingState.Completed -> {
+ it.view()
+ }
+ is EmbeddingLoadingState.Loading -> {
+ CircularProgressIndicator()
+ }
+ else -> {
+ Text(text = "EMBED IS FAILED")
+ }
+ }
+ }
+ )
+
+ // remote config
+ Nativebrik.client.experiment.RemoteConfig("REMOTE_CONFIG_FOR_E2E") {
+ when (it) {
+ is RemoteConfigLoadingState.Completed -> {
+ Text(text = it.variant.getAsString("message") ?: "")
+ }
+ is RemoteConfigLoadingState.Loading -> {
+ CircularProgressIndicator()
+ }
+ else -> {
+ Text(text = "CONFIG IS FAILED")
+ }
+ }
+ }
+
+ }
+ }
+ }
+ }
+ }
+ }
+}
diff --git a/android/e2e/src/main/java/com/nativebrik/e2e/ui/theme/Color.kt b/android/e2e/src/main/java/com/nativebrik/e2e/ui/theme/Color.kt
new file mode 100644
index 0000000..ae78e16
--- /dev/null
+++ b/android/e2e/src/main/java/com/nativebrik/e2e/ui/theme/Color.kt
@@ -0,0 +1,11 @@
+package com.nativebrik.e2e.ui.theme
+
+import androidx.compose.ui.graphics.Color
+
+val Purple80 = Color(0xFFD0BCFF)
+val PurpleGrey80 = Color(0xFFCCC2DC)
+val Pink80 = Color(0xFFEFB8C8)
+
+val Purple40 = Color(0xFF6650a4)
+val PurpleGrey40 = Color(0xFF625b71)
+val Pink40 = Color(0xFF7D5260)
\ No newline at end of file
diff --git a/android/e2e/src/main/java/com/nativebrik/e2e/ui/theme/Theme.kt b/android/e2e/src/main/java/com/nativebrik/e2e/ui/theme/Theme.kt
new file mode 100644
index 0000000..ed1cdc6
--- /dev/null
+++ b/android/e2e/src/main/java/com/nativebrik/e2e/ui/theme/Theme.kt
@@ -0,0 +1,70 @@
+package com.nativebrik.e2e.ui.theme
+
+import android.app.Activity
+import android.os.Build
+import androidx.compose.foundation.isSystemInDarkTheme
+import androidx.compose.material3.MaterialTheme
+import androidx.compose.material3.darkColorScheme
+import androidx.compose.material3.dynamicDarkColorScheme
+import androidx.compose.material3.dynamicLightColorScheme
+import androidx.compose.material3.lightColorScheme
+import androidx.compose.runtime.Composable
+import androidx.compose.runtime.SideEffect
+import androidx.compose.ui.graphics.toArgb
+import androidx.compose.ui.platform.LocalContext
+import androidx.compose.ui.platform.LocalView
+import androidx.core.view.WindowCompat
+
+private val DarkColorScheme = darkColorScheme(
+ primary = Purple80,
+ secondary = PurpleGrey80,
+ tertiary = Pink80
+)
+
+private val LightColorScheme = lightColorScheme(
+ primary = Purple40,
+ secondary = PurpleGrey40,
+ tertiary = Pink40
+
+ /* Other default colors to override
+ background = Color(0xFFFFFBFE),
+ surface = Color(0xFFFFFBFE),
+ onPrimary = Color.White,
+ onSecondary = Color.White,
+ onTertiary = Color.White,
+ onBackground = Color(0xFF1C1B1F),
+ onSurface = Color(0xFF1C1B1F),
+ */
+)
+
+@Composable
+fun NativebrikAndroidTheme(
+ darkTheme: Boolean = isSystemInDarkTheme(),
+ // Dynamic color is available on Android 12+
+ dynamicColor: Boolean = true,
+ content: @Composable () -> Unit
+) {
+ val colorScheme = when {
+ dynamicColor && Build.VERSION.SDK_INT >= Build.VERSION_CODES.S -> {
+ val context = LocalContext.current
+ if (darkTheme) dynamicDarkColorScheme(context) else dynamicLightColorScheme(context)
+ }
+
+ darkTheme -> DarkColorScheme
+ else -> LightColorScheme
+ }
+ val view = LocalView.current
+ if (!view.isInEditMode) {
+ SideEffect {
+ val window = (view.context as Activity).window
+ window.statusBarColor = colorScheme.primary.toArgb()
+ WindowCompat.getInsetsController(window, view).isAppearanceLightStatusBars = darkTheme
+ }
+ }
+
+ MaterialTheme(
+ colorScheme = colorScheme,
+ typography = Typography,
+ content = content
+ )
+}
\ No newline at end of file
diff --git a/android/e2e/src/main/java/com/nativebrik/e2e/ui/theme/Type.kt b/android/e2e/src/main/java/com/nativebrik/e2e/ui/theme/Type.kt
new file mode 100644
index 0000000..cce0498
--- /dev/null
+++ b/android/e2e/src/main/java/com/nativebrik/e2e/ui/theme/Type.kt
@@ -0,0 +1,34 @@
+package com.nativebrik.e2e.ui.theme
+
+import androidx.compose.material3.Typography
+import androidx.compose.ui.text.TextStyle
+import androidx.compose.ui.text.font.FontFamily
+import androidx.compose.ui.text.font.FontWeight
+import androidx.compose.ui.unit.sp
+
+// Set of Material typography styles to start with
+val Typography = Typography(
+ bodyLarge = TextStyle(
+ fontFamily = FontFamily.Default,
+ fontWeight = FontWeight.Normal,
+ fontSize = 16.sp,
+ lineHeight = 24.sp,
+ letterSpacing = 0.5.sp
+ )
+ /* Other default text styles to override
+ titleLarge = TextStyle(
+ fontFamily = FontFamily.Default,
+ fontWeight = FontWeight.Normal,
+ fontSize = 22.sp,
+ lineHeight = 28.sp,
+ letterSpacing = 0.sp
+ ),
+ labelSmall = TextStyle(
+ fontFamily = FontFamily.Default,
+ fontWeight = FontWeight.Medium,
+ fontSize = 11.sp,
+ lineHeight = 16.sp,
+ letterSpacing = 0.5.sp
+ )
+ */
+)
\ No newline at end of file
diff --git a/android/e2e/src/main/res/drawable/ic_launcher_background.xml b/android/e2e/src/main/res/drawable/ic_launcher_background.xml
new file mode 100644
index 0000000..07d5da9
--- /dev/null
+++ b/android/e2e/src/main/res/drawable/ic_launcher_background.xml
@@ -0,0 +1,170 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/android/e2e/src/main/res/drawable/ic_launcher_foreground.xml b/android/e2e/src/main/res/drawable/ic_launcher_foreground.xml
new file mode 100644
index 0000000..2b068d1
--- /dev/null
+++ b/android/e2e/src/main/res/drawable/ic_launcher_foreground.xml
@@ -0,0 +1,30 @@
+
+
+
+
+
+
+
+
+
+
+
\ No newline at end of file
diff --git a/android/e2e/src/main/res/mipmap-anydpi/ic_launcher.xml b/android/e2e/src/main/res/mipmap-anydpi/ic_launcher.xml
new file mode 100644
index 0000000..6f3b755
--- /dev/null
+++ b/android/e2e/src/main/res/mipmap-anydpi/ic_launcher.xml
@@ -0,0 +1,6 @@
+
+
+
+
+
+
\ No newline at end of file
diff --git a/android/e2e/src/main/res/mipmap-anydpi/ic_launcher_round.xml b/android/e2e/src/main/res/mipmap-anydpi/ic_launcher_round.xml
new file mode 100644
index 0000000..6f3b755
--- /dev/null
+++ b/android/e2e/src/main/res/mipmap-anydpi/ic_launcher_round.xml
@@ -0,0 +1,6 @@
+
+
+
+
+
+
\ No newline at end of file
diff --git a/android/e2e/src/main/res/mipmap-hdpi/ic_launcher.webp b/android/e2e/src/main/res/mipmap-hdpi/ic_launcher.webp
new file mode 100644
index 0000000..c209e78
Binary files /dev/null and b/android/e2e/src/main/res/mipmap-hdpi/ic_launcher.webp differ
diff --git a/android/e2e/src/main/res/mipmap-hdpi/ic_launcher_round.webp b/android/e2e/src/main/res/mipmap-hdpi/ic_launcher_round.webp
new file mode 100644
index 0000000..b2dfe3d
Binary files /dev/null and b/android/e2e/src/main/res/mipmap-hdpi/ic_launcher_round.webp differ
diff --git a/android/e2e/src/main/res/mipmap-mdpi/ic_launcher.webp b/android/e2e/src/main/res/mipmap-mdpi/ic_launcher.webp
new file mode 100644
index 0000000..4f0f1d6
Binary files /dev/null and b/android/e2e/src/main/res/mipmap-mdpi/ic_launcher.webp differ
diff --git a/android/e2e/src/main/res/mipmap-mdpi/ic_launcher_round.webp b/android/e2e/src/main/res/mipmap-mdpi/ic_launcher_round.webp
new file mode 100644
index 0000000..62b611d
Binary files /dev/null and b/android/e2e/src/main/res/mipmap-mdpi/ic_launcher_round.webp differ
diff --git a/android/e2e/src/main/res/mipmap-xhdpi/ic_launcher.webp b/android/e2e/src/main/res/mipmap-xhdpi/ic_launcher.webp
new file mode 100644
index 0000000..948a307
Binary files /dev/null and b/android/e2e/src/main/res/mipmap-xhdpi/ic_launcher.webp differ
diff --git a/android/e2e/src/main/res/mipmap-xhdpi/ic_launcher_round.webp b/android/e2e/src/main/res/mipmap-xhdpi/ic_launcher_round.webp
new file mode 100644
index 0000000..1b9a695
Binary files /dev/null and b/android/e2e/src/main/res/mipmap-xhdpi/ic_launcher_round.webp differ
diff --git a/android/e2e/src/main/res/mipmap-xxhdpi/ic_launcher.webp b/android/e2e/src/main/res/mipmap-xxhdpi/ic_launcher.webp
new file mode 100644
index 0000000..28d4b77
Binary files /dev/null and b/android/e2e/src/main/res/mipmap-xxhdpi/ic_launcher.webp differ
diff --git a/android/e2e/src/main/res/mipmap-xxhdpi/ic_launcher_round.webp b/android/e2e/src/main/res/mipmap-xxhdpi/ic_launcher_round.webp
new file mode 100644
index 0000000..9287f50
Binary files /dev/null and b/android/e2e/src/main/res/mipmap-xxhdpi/ic_launcher_round.webp differ
diff --git a/android/e2e/src/main/res/mipmap-xxxhdpi/ic_launcher.webp b/android/e2e/src/main/res/mipmap-xxxhdpi/ic_launcher.webp
new file mode 100644
index 0000000..aa7d642
Binary files /dev/null and b/android/e2e/src/main/res/mipmap-xxxhdpi/ic_launcher.webp differ
diff --git a/android/e2e/src/main/res/mipmap-xxxhdpi/ic_launcher_round.webp b/android/e2e/src/main/res/mipmap-xxxhdpi/ic_launcher_round.webp
new file mode 100644
index 0000000..9126ae3
Binary files /dev/null and b/android/e2e/src/main/res/mipmap-xxxhdpi/ic_launcher_round.webp differ
diff --git a/android/e2e/src/main/res/values/colors.xml b/android/e2e/src/main/res/values/colors.xml
new file mode 100644
index 0000000..f8c6127
--- /dev/null
+++ b/android/e2e/src/main/res/values/colors.xml
@@ -0,0 +1,10 @@
+
+
+ #FFBB86FC
+ #FF6200EE
+ #FF3700B3
+ #FF03DAC5
+ #FF018786
+ #FF000000
+ #FFFFFFFF
+
\ No newline at end of file
diff --git a/android/e2e/src/main/res/values/strings.xml b/android/e2e/src/main/res/values/strings.xml
new file mode 100644
index 0000000..74008c4
--- /dev/null
+++ b/android/e2e/src/main/res/values/strings.xml
@@ -0,0 +1,3 @@
+
+ e2e
+
\ No newline at end of file
diff --git a/android/e2e/src/main/res/values/themes.xml b/android/e2e/src/main/res/values/themes.xml
new file mode 100644
index 0000000..16f9f5a
--- /dev/null
+++ b/android/e2e/src/main/res/values/themes.xml
@@ -0,0 +1,5 @@
+
+
+
+
+
\ No newline at end of file
diff --git a/android/e2e/src/test/java/com/nativebrik/e2e/ExampleUnitTest.kt b/android/e2e/src/test/java/com/nativebrik/e2e/ExampleUnitTest.kt
new file mode 100644
index 0000000..a9cfba4
--- /dev/null
+++ b/android/e2e/src/test/java/com/nativebrik/e2e/ExampleUnitTest.kt
@@ -0,0 +1,17 @@
+package com.nativebrik.e2e
+
+import org.junit.Test
+
+import org.junit.Assert.*
+
+/**
+ * Example local unit test, which will execute on the development machine (host).
+ *
+ * See [testing documentation](http://d.android.com/tools/testing).
+ */
+class ExampleUnitTest {
+ @Test
+ fun addition_isCorrect() {
+ assertEquals(4, 2 + 2)
+ }
+}
\ No newline at end of file
diff --git a/android/settings.gradle.kts b/android/settings.gradle.kts
index f99443a..3de5e58 100644
--- a/android/settings.gradle.kts
+++ b/android/settings.gradle.kts
@@ -16,3 +16,4 @@ dependencyResolutionManagement {
rootProject.name = "Nativebrik android"
include(":app")
include(":nativebrik")
+include(":e2e")