diff --git a/app/src/main/java/com/iterable/androidsdk/BannerView.java b/app/src/main/java/com/iterable/androidsdk/BannerView.java
new file mode 100644
index 000000000..a8f0b3814
--- /dev/null
+++ b/app/src/main/java/com/iterable/androidsdk/BannerView.java
@@ -0,0 +1,147 @@
+package com.iterable.androidsdk;
+
+import android.app.Activity;
+import android.content.Context;
+import android.content.Intent;
+import android.graphics.Color;
+import android.graphics.PorterDuff;
+import android.graphics.drawable.GradientDrawable;
+import android.os.Message;
+import android.os.Messenger;
+import android.util.AttributeSet;
+import android.view.View;
+import android.widget.Button;
+import android.widget.LinearLayout;
+import android.widget.TextView;
+import android.widget.ImageView;
+
+
+import androidx.cardview.widget.CardView;
+
+
+import com.squareup.picasso.Picasso;
+
+public class BannerView extends CardView {
+
+ private TextView titleText;
+ private TextView descriptionText;
+ private ImageView image;
+ private CardView cardView;
+ private Button primaryButton;
+ private Button secondaryButton;
+
+ public BannerView(Context context) {
+ super(context);
+ init();
+ }
+
+ public BannerView(Context context, AttributeSet attrs) {
+ super(context, attrs);
+ init();
+ }
+
+ public BannerView(Context context, AttributeSet attrs, int defStyle) {
+ super(context, attrs, defStyle);
+ init();
+ }
+
+ private void init() {
+ inflate(getContext(), R.layout.banner_view, this);
+ titleText = findViewById(R.id.titleText);
+ descriptionText = findViewById(R.id.descriptionText);
+ image = findViewById(R.id.image);
+ cardView = findViewById(R.id.banner_view);
+ primaryButton = findViewById(R.id.primaryButton);
+ secondaryButton = findViewById(R.id.secondaryButton);
+ this.updateValues();
+ }
+
+ public void updateValues() {
+
+ // Retrieve the passed values from the intent
+ Intent intent = ((Activity) getContext()).getIntent();
+
+ //card config
+ cardView.setRadius(intent.getIntExtra("cardRadius", 4));
+ cardView.setCardBackgroundColor(intent.getIntExtra("cardBackgroundColor", Color.parseColor("#ffffff")));
+
+ //title of the card
+ titleText.setText(intent.getStringExtra("titleText"));
+ titleText.setTextSize(intent.getIntExtra("titleTextSize", 20));
+ titleText.setTextColor(intent.getIntExtra("titleTextColor", Color.parseColor("#000000")));
+
+ //description of the card
+ descriptionText.setText(intent.getStringExtra("descriptionText"));
+ descriptionText.setTextSize(intent.getIntExtra("descriptionTextSize", 16));
+ descriptionText.setTextColor(intent.getIntExtra("descriptionTextColor", Color.parseColor("#000000")));
+
+ //primary button of the card
+ primaryButton.setText(intent.getStringExtra("primaryButtonText"));
+ primaryButton.setTextColor(intent.getIntExtra("primaryButtonTextColor", Color.parseColor("#ffffff")));
+
+ //secondary button of the card
+ secondaryButton.setText(intent.getStringExtra("secondaryButtonText"));
+ secondaryButton.setTextColor(intent.getIntExtra("secondaryButtonTextColor", Color.parseColor("#000000")));
+
+ //secondary button visibility
+ if (intent.getBooleanExtra("secondaryButtonVisible", true)) {
+ secondaryButton.setVisibility(View.VISIBLE);
+ } else {
+ secondaryButton.setVisibility(View.GONE);
+ }
+
+ // Get the current background drawable of the button
+ GradientDrawable backgroundDrawable = (GradientDrawable) primaryButton.getBackground();
+ backgroundDrawable.setCornerRadius(intent.getIntExtra("primaryButtonRadius", 50));
+ primaryButton.getBackground().setColorFilter((intent.getIntExtra("primaryButtonBackgroundColor", Color.parseColor("#FF4081"))), PorterDuff.Mode.SRC);
+ primaryButton.setBackground(backgroundDrawable);
+
+ // card image
+ if (!intent.getStringExtra("imageUrl").isEmpty()) {
+ Picasso.get().load(intent.getStringExtra("imageUrl")).into(image);
+ }
+
+ // Get the current layout params of the card image
+ LinearLayout.LayoutParams layoutParams = (LinearLayout.LayoutParams) image.getLayoutParams();
+ layoutParams.width = intent.getIntExtra("imageWidth", LinearLayout.LayoutParams.WRAP_CONTENT);
+ layoutParams.height = intent.getIntExtra("imageHeight", LinearLayout.LayoutParams.WRAP_CONTENT);
+ image.setLayoutParams(layoutParams);
+
+ primaryButton.setOnClickListener(new View.OnClickListener() {
+ @Override
+ public void onClick(View view) {
+ // Get the messenger from the intent
+ Messenger messenger = intent.getParcelableExtra("messenger");
+
+ // Send a message to the main activity
+ Message message = new Message();
+ message.what = 1;
+ message.obj = "Primary Button clicked";
+ try {
+ messenger.send(message);
+ } catch (Exception e) {
+ // Handle the exception
+ }
+ }
+ });
+
+ secondaryButton.setOnClickListener(new View.OnClickListener() {
+ @Override
+ public void onClick(View view) {
+ // Get the messenger from the intent
+ Messenger messenger = intent.getParcelableExtra("messenger");
+
+ // Send a message to the main activity
+ Message message = new Message();
+ message.what = 1;
+ message.obj = "Secondary Button clicked";
+ try {
+ messenger.send(message);
+ } catch (Exception e) {
+ // Handle the exception
+ }
+ }
+ });
+
+ }
+}
diff --git a/app/src/main/java/com/iterable/androidsdk/BannerViewActivity.java b/app/src/main/java/com/iterable/androidsdk/BannerViewActivity.java
new file mode 100644
index 000000000..b53799b34
--- /dev/null
+++ b/app/src/main/java/com/iterable/androidsdk/BannerViewActivity.java
@@ -0,0 +1,12 @@
+package com.iterable.androidsdk;
+
+import android.app.Activity;
+import android.os.Bundle;
+
+public class BannerViewActivity extends Activity {
+ @Override
+ protected void onCreate(Bundle savedInstanceState) {
+ super.onCreate(savedInstanceState);
+ setContentView(R.layout.activity_banner_view);
+ }
+}
diff --git a/app/src/main/res/drawable/dummy_100x100.jpg b/app/src/main/res/drawable/dummy_100x100.jpg
new file mode 100644
index 000000000..323835363
Binary files /dev/null and b/app/src/main/res/drawable/dummy_100x100.jpg differ
diff --git a/app/src/main/res/layout/activity_banner_view.xml b/app/src/main/res/layout/activity_banner_view.xml
new file mode 100644
index 000000000..2546d8613
--- /dev/null
+++ b/app/src/main/res/layout/activity_banner_view.xml
@@ -0,0 +1,9 @@
+
+
+
+
+
+
\ No newline at end of file
diff --git a/app/src/main/res/layout/banner_view.xml b/app/src/main/res/layout/banner_view.xml
new file mode 100644
index 000000000..a1550820e
--- /dev/null
+++ b/app/src/main/res/layout/banner_view.xml
@@ -0,0 +1,100 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+