...
12 farklı In-App Message tasarımı mevcut:
Pop-up - Görsel, Başlık, Yazı & Buton | Mini - İkon & Yazı | Tam Ekran Görsel |
---|---|---|
Tam Ekran Görsel ve Buton | Pop-up - Görsel, Başlık, Yazı ve Buton | Pop-up Anket |
Pop-up - Yazı ve Butonlu NPS | Native Alert & Action Sheet | 1-10 Puanlama NPS |
Yıldızlı anket & ikinci pop-up | Yarım Ekran Görsel | Carousel |
Video In-App | ||
1-10 Puanlama NPS - Inline
...
Story Manager
Story Banner ve Story Aksiyonu
Her iki aksiyon içinde implementasyonu için aşağıdaki VisilabsRecyclerView
‘i layout’ta istediğiniz bölüme yerleştirin.
...
language | xml |
---|
...
Mail Üyelik Formu
RMC panelden in-app message’da olduğu gibi mail üyelik formunu oluşturduktan sonra her customEvent çağırdığınız zaman mail üyelik formu olup olmadığı kontrol edilir ardından mail üyelik formu gösterilir. customEvent parametresinde Activity’i alan overloadı çağırmanız gerekmektedir. Örnek kod ve görsel;
Code Block | ||
---|---|---|
| ||
customEvent(String pageName, HashMap<String, String> properties, Activity parent) |
...
Çarkıfelek
RMC panelden in-app message’da olduğu gibi çarkıfelek oluşturduktan sonra her customEvent çağırdığınız zaman çarkıfelek olup olmadığı kontrol edilir ardından çarkıfelek gösterilir. customEvent parametresinde Activity’i alan overloadı çağırmanız gerekmektedir. Örnek kod ve görsel;
Code Block | ||
---|---|---|
| ||
customEvent(String pageName, HashMap<String, String> properties, Activity parent) |
Çarkıfelek Yarım Görünüm | Çarkıfelek Tam Görünüm |
---|---|
Kazı Kazan
RMC panelden in-app message’da olduğu gibi Kazı Kazan oluşturduktan sonra her customEvent çağırdığınız zaman Kazı Kazan olup olmadığı kontrol edilir ardından Kazı Kazan gösterilir. customEvent parametresinde Activity’i alan overloadı çağırmanız gerekmektedir. Örnek kod ve görsel;
Code Block | ||
---|---|---|
| ||
customEvent(String pageName, HashMap<String, String> properties, Activity parent) |
...
App Banner
Uygulamanızın istediğiniz bir layout dosyasında istediğiniz bir yere BannerRecyclerView
ı yerleştiriniz. Örnek xml :
Code Block | ||
---|---|---|
| ||
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:id="@+id/container" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical"> <com.visilabs.inApp.bannercarousel.BannerRecyclerView android:id="@+id/bannerListView" android:layout_width="match_parent" android:layout_height="150dp"/> <Button android:id="@+id/vrvbtn_show_storybanner" android:layout_gravity="center" android:layout_width="match_parent150dp" android:layout_height="50dp" android:layout_marginTop="20dp" android:layout_height="wrap_content"/> |
VisilabsRecyclerView
'i classınızda tanımladıktan sonra StoryItemClickListener
tanımlayarak her bir story’e tıklandığında yapmak istediğiniz yönlendirme ve ya aksiyonu tanımlayınız. Burada örnek olması için Toast Mesajı gösterilmiştir.
...
background="@drawable/rounded_corners_background"
android:text="@string/show_banner" />
</LinearLayout> |
Daha sonra ilgili program dosyasında (Java veya Kotlin) BannerRecyclerView
objesine erişip requestBannerCarouselAction
() methodunun çağırılması gereklidir. Bu method bir zorunlu (context: Context
), 3 opsiyonel parametre(properties: HashMap<String, String>?, bannerRequestListener: BannerRequestListener?, bannerItemClickListener: BannerItemClickListener?
) almaktadır.
properties
parametresi sorguya eklemek istediğiniz ekstra query parametreleri içindir.
bannerRequestListener
parametresi eğer sorgu sonucunda bir şeyler ters gider ve sunuculardan bilgi alınamazsa bunun size bildirimlesi içindir. Böylece layoutunuza eklediğiniz BannerRecyclerView
in visibility sini View.GONE veya View.INVISIBLE yaparak ilgili alanın boş görünmesini engelleyebilirsiniz.
bannerItemClickListener
parametresi kullanıcının herhangi bir banner a tıklaması sonucu SDK’nın otomatik yönlendirmesi yerine kendiniz yönlendirme yapmak istiyorsanız kullanabileceğiniz bir parametredir.
Tüm parametreleri içeren örnek bir kullanım aşağıdaki gibidir.
Code Block | ||
---|---|---|
| ||
bannerItemClickListener = new BannerItemClickListener() { @Override public void bannerItemClicked(String bannerLink) { Toast.makeText(getApplicationContext(), bannerLink, VisilabsRecyclerView visilabsRecyclerView = findViewById(R.id.vrv_story);Toast.LENGTH_SHORT).show(); Log.i("link banner", bannerLink); try { Intent viewIntent = new Intent(Intent.ACTION_VIEW, Uri.parse(bannerLink)); startActivity(viewIntent); } catch (Exception e) { Log.e(LOG_TAG, "The link is not formatted properly!"); } } }; StoryItemClickListenerBannerRequestListener storyItemClickListenerbannerRequestListener = new StoryItemClickListenerBannerRequestListener() { @Override public void storyItemClickedonRequestResult(Stringboolean storyLinkisAvailable) { if Toast.makeText(getApplicationContext(), storyLink, Toast.LENGTH_LONG).show();(!isAvailable) { binding.bannerListView.setVisibility(View.GONE); } } }; visilabsRecyclerView.setStoryAction(getApplicationContext(), storyItemClickListener HashMap<String, String> properties = new HashMap<>(); |
İsterseniz Story Aksiyon Id ile de setleyebilirsiniz.
Code Block | ||
---|---|---|
| ||
visilabsRecyclerViewproperties.setStoryActionId(getApplicationContext()put("OM.inapptype", "250", storyItemClickListener); |
Panelde aktif story looking banner veya story olduğu sürece uygulamanızda gözükecektir.
Mail Üyelik Formu
RMC panelden in-app message’da olduğu gibi mail üyelik formunu oluşturduktan sonra her customEvent çağırdığınız zaman mail üyelik formu olup olmadığı kontrol edilir ardından mail üyelik formu gösterilir. customEvent parametresinde Activity’i alan overloadı çağırmanız gerekmektedir. Örnek kod ve görsel;
Code Block | ||
---|---|---|
| ||
customEvent(String pageName, HashMap<String, String> properties, Activity parent) |
...
Çarkıfelek
RMC panelden in-app message’da olduğu gibi çarkıfelek oluşturduktan sonra her customEvent çağırdığınız zaman çarkıfelek olup olmadığı kontrol edilir ardından çarkıfelek gösterilir. customEvent parametresinde Activity’i alan overloadı çağırmanız gerekmektedir. Örnek kod ve görsel;
Code Block | ||
---|---|---|
| ||
customEvent(String pageName, HashMap<String, String> properties, Activity parent) |
...
Çarkıfelek Yarım Görünüm
...
Çarkıfelek Tam Görünüm
...
...
Kazı Kazan
RMC panelden in-app message’da olduğu gibi Kazı Kazan oluşturduktan sonra her customEvent çağırdığınız zaman Kazı Kazan olup olmadığı kontrol edilir ardından Kazı Kazan gösterilir. customEvent parametresinde Activity’i alan overloadı çağırmanız gerekmektedir. Örnek kod ve görsel;
Code Block | ||
---|---|---|
| ||
customEvent(String pageName, HashMap<String, String> properties, Activity parent) |
...
banner_carousel");
binding.bannerListView.requestBannerCarouselAction(
getApplicationContext(),
properties,
bannerRequestListener,
bannerItemClickListener); |
Ürün Durum Bilgisi
RMC Panelde tanımladığınız Ürün Durum Bilgisi aksiyonu Ürün Görüntüleme, Sepete Ekleme ve Favoriye Ekleme/Çıkarma eventlerinde çalışmaktadır. Bu eventlerde ürün idnin gönderildiğinden emin olmalısınız. Bu eventlerde çağırdığınız customEvent metodunun Activity overloadını alması gerekmektedir.
...