Google, kullanıcıların uygulamalarını sektörlere göre düzenleyen ve kişiselleştirilmiş uygulama içeriğinin tüketilmesi ve keşfedilmesi için yeni bir etkileyici deneyim sunan cihaz üzerinde bir yüzey oluşturuyor. Bu tam ekran deneyimi, geliştirici iş ortaklarına en iyi zengin içeriklerini uygulamalarının dışında özel bir kanalda sergileme fırsatı sunar.
Bu kılavuzda, geliştirici iş ortaklarının hem bu yeni yüzey alanını hem de Eğlence Alanı gibi mevcut Google yüzeylerini doldurmak için Engage SDK'sını kullanarak alışveriş içeriklerini entegre etme talimatları yer almaktadır.
Entegrasyon ayrıntıları
Terminoloji
Bu entegrasyon şu beş küme türünü içerir: Öneri, Öne Çıkan, Alışveriş Sepeti, Alışveriş Listesi, Yeniden Sıralama ve Alışveriş Siparişi İzleme.
Öneri kümeleri, tek bir geliştirici iş ortağının kişiselleştirilmiş alışveriş önerilerini gösterir. Bu öneriler kullanıcıya göre kişiselleştirilebilir veya genelleştirilebilir (ör. trend olan öğeler). Ürünleri, etkinlikleri, indirimleri, promosyonları ve abonelikleri uygun gördüğünüz şekilde göstermek için bunları kullanın.
Önerileriniz aşağıdaki yapıya sahiptir:
Öneri Kümesi: Aynı geliştirici iş ortağının bir öneri grubunu içeren kullanıcı arayüzü görünümü.
ShoppingEntity: Bir kümedeki tek bir öğeyi temsil eden nesne.
Öne Çıkan kümesi, birden fazla geliştirici iş ortağından alınmış çeşitli varlıkları tek bir kullanıcı arayüzü gruplandırmasında gösterir. Tek bir Öne Çıkan küme bulunur. Bu küme, kullanıcı arayüzünün üst kısmına yakın bir yerde, tüm Öneriler kümelerinin üzerinde öncelikli olarak yerleştirilir. Her geliştirici iş ortağının, Öne Çıkanlar kümesinde en fazla 10 öğe yayınlamasına izin verilir.
Alışveriş Sepeti kümesi, tek bir kullanıcı arayüzü grubunda birçok geliştirici iş ortağından gelen alışveriş sepetlerine kısa bir bakış sunarak kullanıcıları bekleyen sepetlerini tamamlamaya yönlendirir. Tek bir Alışveriş Sepeti kümesi vardır. Bu küme, kullanıcı arayüzünün üst kısmına yakın bir yerde gösterilir ve tüm öneri kümelerinin üzerinde öncelikli bir yerleşime sahiptir. Her geliştirici iş ortağının, Alışveriş sepeti kümesinde en fazla 3
ShoppingCart
örneği yayınlamasına izin verilir.Alışveriş sepetiniz aşağıdaki yapıya sahiptir:
Alışveriş sepeti kümesi: Birçok geliştirici iş ortağının alışveriş sepeti önizlemelerini içeren bir kullanıcı arayüzü görünümü.
ShoppingCart: Tek bir geliştirici iş ortağı için alışveriş sepeti önizlemesini temsil eden ve Alışveriş sepeti kümesinde gösterilecek bir nesne.
ShoppingCart
, alışveriş sepetindeki toplam öğe sayısını göstermelidir. Ayrıca kullanıcının alışveriş sepetindeki bazı ürünlerin resimlerini de içerebilir.
Alışveriş Listesi kümesi, birden fazla geliştirici iş ortağının alışveriş listelerinin bir kullanıcı arayüzü gruplandırmasında önizlemesini gösterir. Bu sayede kullanıcılar listelerini güncellemek ve tamamlamak için ilgili uygulamaya geri dönebilir. Tek bir Alışveriş Listesi kümesi vardır.
Yeniden sipariş ver kümesi, birden fazla geliştirici iş ortağının önceki siparişlerini tek bir kullanıcı arayüzü gruplandırmasında gösterir ve kullanıcıları yeniden sipariş vermeye teşvik eder. Tek bir yeniden sıralama kümesi vardır.
Yeniden sipariş kümesi, kullanıcının önceki siparişindeki toplam öğe sayısını göstermelidir ve aşağıdakilerden birini de içermelidir:
- Kullanıcının önceki siparişindeki X öğenin resimleri.
- Kullanıcının önceki siparişindeki X öğe için etiketler.
Alışveriş siparişi takibi kümesi, birçok geliştirici iş ortağının bekleyen veya yakın zamanda tamamlanan alışveriş siparişlerini tek bir kullanıcı arayüzü gruplandırmasında gösterir. Bu sayede kullanıcılar siparişlerini takip edebilir.
Kullanıcı arayüzünün üst kısmına yakın bir yerde, tüm öneri kümelerinin üzerinde öncelikli yerleşim alan tek bir ShoppingOrderTracking kümesi vardır. Her geliştirici iş ortağının Alışveriş Sipariş İzleme kümesinde birden fazla Shopping OrderTrackingEntity öğesi yayınlamasına izin verilir.
ShoppingOrderTrackingCluster aşağıdaki yapıya sahiptir:
- Shopping OrderTracking Cluster: Birçok geliştirici iş ortağının sipariş takibi önizlemelerini içeren bir kullanıcı arayüzü görünümü
- ShoppingOrderTrackingEntity: Alışveriş siparişi izleme kümesinde gösterilecek, tek bir geliştirici iş ortağı için alışveriş siparişi izleme önizlemesini temsil eden bir nesne. ShoppingOrderTrackingEntity, siparişin durumunu ve sipariş zamanını göstermelidir. Shopping OrderTrackingEntity için beklenen teslimat süresi, sağlandığında kullanıcılara gösterildiği için bu süreyi doldurmanızı önemle tavsiye ederiz.
Ön çalışma
Minimum API düzeyi: 19
com.google.android.engage:engage-core
kitaplığını uygulamanıza ekleyin:
dependencies {
// Make sure you also include that repository in your project's build.gradle file.
implementation 'com.google.android.engage:engage-core:1.5.2'
}
Daha fazla bilgi için Android 11'de paket görünürlüğü başlıklı makaleyi inceleyin.
Özet
Tasarım, bağlı hizmet uygulamasına dayanır.
Bir istemcinin yayınlayabileceği veriler, farklı küme türleri için aşağıdaki sınırlara tabidir:
Küme türü | Küme sınırları | Bir kümedeki maksimum öğe sınırları |
---|---|---|
Öneri Kümeleri | En çok 5 | En fazla 25 ShoppingEntity |
Öne Çıkan Küme | En fazla 1 | En fazla 10 ShoppingEntity |
Alışveriş Sepeti Kümesi | En fazla 1 | En fazla 3 ShoppingCart
Birden fazla alışveriş sepeti yalnızca satıcı başına ayrı alışveriş sepetleri olan uygulamalarda beklenir. |
Alışveriş Listesi Kümesi | En fazla 1 | En fazla 1 ShoppingListEntity |
Alışveriş Yeniden Sıralama Kümesi | En fazla 1 | En fazla 1 ReorderEntity |
Alışveriş Siparişi İzleme Kümesi | En fazla 3 | En fazla 3 ShoppingOrderTrackingEntity |
1. adım: Öğe verilerini sağlayın
SDK, her öğe türünü temsil etmek için farklı öğeler tanımlamıştır. Alışveriş kategorisi için aşağıdaki varlıklar desteklenir:
ShoppingEntity
ShoppingCart
ShoppingList
Reorder
ShoppingOrderTracking
Aşağıdaki grafiklerde, her tür için kullanılabilen özellikler ve şartlar özetlenmiştir.
ShoppingEntity
ShoppingEntity
nesnesi, geliştirici iş ortaklarının yayınlamak istediği bir ürünü, promosyonu, anlaşmayı, aboneliği veya etkinliği temsil eder.
ShoppingEntity
Özellik | Şartlar | Açıklama | Biçim |
---|---|---|---|
Poster resimleri | Zorunlu | En az bir resim sağlanmalıdır. | Yardım için Resim Özellikleri bölümüne bakın. |
İşlem Uri | Zorunlu |
Uygulamada varlıkla ilgili ayrıntıları gösteren sayfanın derin bağlantısı. Not: İlişkilendirme için derin bağlantıları kullanabilirsiniz. Bu SSS'ye bakın |
URI |
Başlık | İsteğe bağlı | Tüzel kişinin adı. | Serbest metin Önerilen metin boyutu: 90 karakterden az (Çok uzun metinde üç nokta gösterilebilir) |
Fiyat - mevcut | Koşullu olarak zorunlu |
Öğenin mevcut fiyatı. Üstü çizili fiyat sağlanmışsa bu değer de belirtilmelidir. |
Serbest metin |
Fiyat - üstü çizili | İsteğe bağlı | Öğenin orijinal fiyatı. Bu fiyat, kullanıcı arayüzünde üstü çizili olarak gösterilir. | Serbest metin |
Açıklama metni | İsteğe bağlı | Varsa öğeyle ilgili bir promosyonu, etkinliği veya güncellemeyi öne çıkaran açıklama metni. | Serbest metin Önerilen metin boyutu: 45 karakterden kısa (Çok uzun metinlerde üç nokta gösterilebilir) |
Açıklama metni ayrıntıları | İsteğe bağlı | Açıklama metni için küçük yazı metni. | Serbest metin Önerilen metin boyutu: 45 karakterden kısa (Çok uzun metinlerde üç nokta gösterilebilir) |
Puan (İsteğe Bağlı) - Not: Tüm puanlar, standart yıldız puanı sistemimiz kullanılarak gösterilir. | |||
Derecelendirme - Maksimum değer | İsteğe bağlı | Derecelendirme ölçeğinin maksimum değeri. Derecelendirmenin mevcut değeri de sağlanıyorsa sağlanmalıdır. |
Sayı >= 0,0 |
Derecelendirme - Mevcut değer | İsteğe bağlı | Derecelendirme ölçeğinin mevcut değeri. Derecelendirmenin maksimum değeri de sağlanıyorsa sağlanmalıdır. |
Sayı >= 0,0 |
Derecelendirme - Sayı | İsteğe bağlı |
Öğenin aldığı puanların sayısı. Not: Uygulamanız, sayının kullanıcılara nasıl gösterileceğini kontrol ediyorsa bu alanı sağlayın. Özet bir dize kullanın. Örneğin, sayı 1.000.000 ise sayının daha küçük ekran boyutlarında kısaltılmaması için 1M gibi bir kısaltma kullanabilirsiniz. |
Dize |
Derecelendirme - Sayı Değeri | İsteğe bağlı | Öğenin aldığı puanların sayısı. Not: Gösterim kısaltması mantığını kendiniz yönetmezseniz bu alanı sağlayın. Hem Sayı hem de Sayı Değeri varsa kullanıcılara Sayı gösterilir. |
Uzun |
DisplayTimeWindow (İsteğe bağlı) - İçeriğin yüzeyde gösterilmesi için bir zaman aralığı ayarlayın | |||
Başlangıç zaman damgası | İsteğe bağlı |
Sonrasında içeriğin yüzeyde gösterilmesi gereken dönem zaman damgasıdır. Ayarlanmazsa içerik yüzeyde gösterilmeye uygundur. |
Milisaniye cinsinden Unix sıfır zaman damgası |
Bitiş zaman damgası | İsteğe bağlı |
İçeriğin artık ilk sayfada gösterilmediği dönem zaman damgası. Ayarlanmazsa içerik yüzeyde gösterilmeye uygundur. |
Milisaniye cinsinden Unix sıfır zaman damgası |
ShoppingCart
Özellik | Şartlar | Açıklama | Biçim |
---|---|---|---|
İşlem Uri | Zorunlu |
İş ortağının uygulamasındaki alışveriş sepetinin derin bağlantısı. Not: İlişkilendirme için derin bağlantıları kullanabilirsiniz. Bu SSS'ye bakın |
URI |
Ürün sayısı | Zorunlu |
Alışveriş sepetindeki öğe sayısı (yalnızca ürün sayısı değil). Örneğin: Alışveriş sepetinde 3 adet aynı gömlek ve 1 şapka varsa bu sayı 4 olmalıdır. |
Tam sayı >= 1 |
İşlem Metni | İsteğe bağlı |
Alışveriş Sepeti'ndeki düğmenin harekete geçirici mesaj metni (örneğin, Alışveriş Çantanız). Geliştirici tarafından işlem metni sağlanmazsa varsayılan olarak Alışveriş Sepetini Görüntüle kullanılır. Bu özellik 1.1.0 sürümü ve sonraki sürümlerde desteklenir. |
Dize |
Başlık | İsteğe bağlı | Alışveriş sepetinin başlığı (örneğin, Alışveriş Çantanız). Geliştirici tarafından başlık sağlanmazsa varsayılan başlık Alışveriş sepetiniz olur. Geliştirici iş ortağı her satıcı için ayrı bir alışveriş sepeti yayınlıyorsa lütfen başlığa satıcı adını ekleyin. |
Serbest metin Önerilen metin boyutu: 25 karakterden kısa (Çok uzun metinde üç nokta gösterilebilir) |
Alışveriş sepeti resimleri | İsteğe bağlı | Sepetteki her ürünün resimleri. Öncelik sırasına göre en fazla 10 resim sağlanabilir. Gösterilen resimlerin gerçek sayısı cihaz form faktörüne bağlıdır. |
Yardım için Resim Özellikleri bölümüne bakın. |
Öğe etiketleri | İsteğe bağlı | Alışveriş listesindeki öğelerin etiketlerinin listesi. Gösterilen etiketlerin gerçek sayısı cihaz form faktörüne bağlıdır. |
Serbest metin etiketlerinin listesi Önerilen metin boyutu: 20 karakterden kısa (Çok uzun metinlerde üç nokta gösterilebilir) |
Son kullanıcı etkileşimi zaman damgası | İsteğe bağlı | Kullanıcının seple son kez etkileşime geçtiği zamanı tanımlayan, başlangıç zamanından geçen milisaniye sayısı.
Bu, satıcı başına ayrı bir alışveriş sepeti yayınlayan geliştirici iş ortakları tarafından giriş olarak iletilir ve sıralama için kullanılabilir. |
Milisaniye cinsinden Unix sıfır zaman damgası |
DisplayTimeWindow (İsteğe bağlı) - İçeriğin yüzeyde gösterilmesi için bir zaman aralığı ayarlayın | |||
Başlangıç Zaman Damgası | İsteğe bağlı |
Sonrasında içeriğin yüzeyde gösterilmesi gereken dönem zaman damgasıdır. Ayarlanmazsa içerik yüzeyde gösterilmeye uygundur. |
Milisaniye cinsinden Unix sıfır zaman damgası |
Bitiş zaman damgası | İsteğe bağlı |
İçeriğin artık ilk sayfada gösterilmediği dönem zaman damgası. Ayarlanmazsa içerik yüzeyde gösterilmeye uygundur. |
Milisaniye cinsinden Unix sıfır zaman damgası |
ShoppingList
Özellik | Şartlar | Açıklama | Biçim |
---|---|---|---|
İşlem Uri | Zorunlu |
İş ortağının uygulamasındaki alışveriş listesinin derin bağlantısı. Not: İlişkilendirme için derin bağlantıları kullanabilirsiniz. Bu SSS'ye bakın |
URI |
Ürün sayısı | Zorunlu | Alışveriş listesindeki öğelerin sayısı. | Tam sayı >= 1 |
Başlık | İsteğe bağlı |
Listenin başlığı (örneğin, Alışveriş Listeniz). Geliştirici tarafından başlık sağlanmazsa varsayılan olarak Alışveriş listesi kullanılır. |
Serbest metin Önerilen metin boyutu: 25 karakterden kısa (Çok uzun metinlerde üç nokta gösterilebilir) |
Öğe etiketleri | Zorunlu | Alışveriş listesindeki öğelerin etiketlerinin listesi. En az 1 etiket sağlanmalıdır ve öncelik sırasına göre en fazla 10 etiket sağlanabilir. Gösterilen etiketlerin gerçek sayısı cihaz form faktörüne bağlıdır. |
Serbest metin etiketlerinin listesi Önerilen metin boyutu: 20 karakterden kısa (Çok uzun metinlerde üç nokta gösterilebilir) |
ShoppingReorderCluster
Özellik | Şartlar | Açıklama | Biçim |
---|---|---|---|
İşlem Uri | Zorunlu |
İş ortağının uygulamasında yeniden sipariş verilecek derin bağlantı. Not: İlişkilendirme için derin bağlantıları kullanabilirsiniz. Bu SSS'ye bakın |
URI |
İşlem metni | İsteğe bağlı |
Yeniden sipariş ver üzerindeki düğmenin harekete geçirici mesaj metni (örneğin, Tekrar sipariş ver). Geliştirici herhangi bir işlem metni sağlamıyorsa varsayılan olarak Yeniden sırala ayarı kullanılır. Bu özellik 1.1.0 sürümü ve sonraki sürümlerde desteklenir. |
Dize |
Ürün sayısı | Zorunlu |
Önceki siparişteki öğe sayısı (yalnızca ürün sayısı değil). Örneğin: Önceki siparişte 3 küçük kahve ve 1 kruvasan varsa bu sayı 4 olmalıdır. |
Tam sayı >= 1 |
Başlık | Zorunlu | Yeniden sipariş verilen öğenin başlığı. | Serbest metin Önerilen metin boyutu: 40 karakterden kısa (Çok uzun metinlerde üç nokta gösterilebilir) |
Öğe etiketleri | İsteğe bağlı (Yayınlanmamışsa poster resimleri sağlanmalıdır) |
Önceki siparişin öğe etiketlerinin listesi. Öncelik sırasına göre en fazla 10 etiket sağlanabilir. Gösterilen etiketlerin gerçek sayısı cihaz form faktörüne bağlıdır. |
Serbest metin listesi Etiket başına önerilen metin boyutu: 20 karakterden kısa (Çok uzun metinler üç noktayla gösterilebilir) |
Poster resimleri | İsteğe bağlı (Sağlanmamışsa öğe etiketleri sağlanmalıdır) |
Önceki siparişteki öğelerin resimleri. Öncelik sırasına göre en fazla 10 resim sağlanabilir. Görüntülenen gerçek resim sayısı, cihazın form faktörüne bağlıdır. |
Yardım için Resim Özellikleri bölümüne bakın. |
ShoppingOrderTrackingCluster
Özellik | Şartlar | Açıklama | Biçim |
---|---|---|---|
Başlık | Zorunlu |
Takip edilen paketin/öğelerin kısa başlığı veya takip numarası. |
Serbest metin Önerilen metin boyutu: 50 karakter (Çok uzun metinlerde üç nokta gösterilir) |
Sipariş Türü | Zorunlu |
Takip edilen paketin/öğelerin kısa başlığı veya takip numarası. |
Enum: IN_STORE_PICKUP, SAME_DAY_DELIVERY, MULTI_DAY_DELIVERY |
Durum | Zorunlu |
Siparişin mevcut durumu. Örneğin: "Gecikeceğim", "Nakliyede", "Gecikmeli", "Gönderildi", "Teslim edildi", "Stokta yok", "Sipariş hazır" |
Serbest metin Önerilen metin boyutu: 25 karakter (Çok uzun metinlerde üç nokta gösterilir) |
Sipariş zamanı | Zorunlu |
Siparişin verildiği, milisaniye cinsinden sıfır zaman damgası. Beklenen teslimat süresi aralığı mevcut değilse sipariş saati gösterilir |
Milisaniye cinsinden Epoch zaman damgası |
İşlem Uri | Zorunlu |
İş ortağının uygulamasındaki sipariş takibi derin bağlantısı. |
URI |
OrderDeliveryTimeWindow (İsteğe bağlı) - İzlenen sipariş için siparişin verildiği andan itibaren beklenen/gerçek teslimat süresine kadar bir zaman aralığı ayarlayın. | |||
OrderDeliveryTimeWindow - Start Time | İsteğe bağlı |
Siparişin teslim edileceği veya teslim alınmaya hazır olacağının milisaniye cinsinden zaman damgasıdır. |
Milisaniye cinsinden Unix sıfır zaman damgası |
OrderDeliveryTimeWindow - End Time | İsteğe bağlı |
Siparişin teslim edileceği veya teslim alınmaya hazır olacağı zaman/zamandan önce milisaniye cinsinden Unix sıfır zaman damgası. |
Milisaniye cinsinden Epoch zaman damgası |
Poster resimleri | İsteğe bağlı | Siparişe dahil olan bir öğenin/ürünün resmi. Önerilen en boy oranı 1:1'dir. |
Yardım için Resim Özellikleri'ne bakın. |
Ürün sayısı | İsteğe bağlı | Siparişteki öğe sayısı. | Tam sayı >= 1 |
Açıklama | İsteğe bağlı | Siparişteki öğeleri tanımlayan tek bir paragraflık metin. Not: Kullanıcıya açıklama veya altyazı listesi gösterilir, ikisi birden gösterilmez. |
Serbest metin Önerilen metin boyutu: 180 karakter |
Altyazı listesi | İsteğe bağlı | Her biri tek satırdan oluşan en fazla 3 altyazı. Not: Kullanıcıya açıklama veya altyazı listesi gösterilir. |
Serbest metin Her altyazı için önerilen metin boyutu: en fazla 50 karakter |
Sipariş Değeri - Mevcut Fiyat | İsteğe bağlı | Siparişin mevcut değeri. | Serbest metin |
Sipariş numarası | İsteğe bağlı | Siparişi benzersiz bir şekilde tanımlamak için kullanılabilecek sipariş numarası/kimliği. |
Serbest metin Önerilen metin boyutu: en fazla 25 karakter |
Takip numarası | İsteğe bağlı | Sipariş/kargo teslimatı gerekiyorsa sipariş/kargo teslimatı için takip numarası |
Serbest metin Önerilen metin boyutu: en fazla 25 karakter |
Resim özellikleri
Resim öğeleri için gerekli özellikler aşağıda listelenmiştir:
En boy oranı | Minimum piksel sayısı | Önerilen piksel sayısı |
---|---|---|
Kare (1x1) Öne çıkarılmayan kümeler için tercih edilir |
300x300 | 1.200x1.200 |
Yatay (1,91x1) Öne çıkan kümeler için tercih ediliyor |
600x314 | 1.200x628 |
Dikey (4x5) | 480x600 | 960x1200 |
Dosya biçimleri
PNG, JPG, statik GIF, WebP
Maksimum dosya boyutu
5.120 KB
Ek öneriler
- Resim güvenli alanı: Önemli içeriklerinizi ortaya, resmin% 80'lik kısmına yerleştirin.
- Resmin koyu ve açık tema ayarlarında düzgün şekilde gösterilmesi için şeffaf bir arka plan kullanın.
2. adım: Küme verilerini sağlayın
İçerik yayınlama işinin arka planda (ör. WorkManager kullanılarak) yürütülmesi ve düzenli olarak veya etkinlik bazında (ör. kullanıcı uygulamayı her açtığında ya da sepete bir şey eklediğinde) planlanması önerilir.
AppEngageShoppingClient
, alışveriş kümelerini yayınlamaktan sorumludur.
Aşağıdaki API'ler, istemcideki kümeleri yayınlamada kullanılabilir:
isServiceAvailable
publishRecommendationClusters
publishFeaturedCluster
publishShoppingCart
publishShoppingCarts
publishShoppingList
publishShoppingReorderCluster
publishShoppingOrderTrackingCluster
publishUserAccountManagementRequest
updatePublishStatus
deleteRecommendationsClusters
deleteFeaturedCluster
deleteShoppingCartCluster
deleteShoppingListCluster
deleteShoppingReorderCluster
deleteShoppingOrderTrackingCluster
deleteUserManagementCluster
deleteClusters
isServiceAvailable
Bu API, hizmetin entegrasyon için uygun olup olmadığını ve içeriğin cihazda sunulup sunulamayacağını kontrol etmek amacıyla kullanılır.
Kotlin
client.isServiceAvailable.addOnCompleteListener { task -> if (task.isSuccessful) { // Handle IPC call success if(task.result) { // Service is available on the device, proceed with content publish // calls. } else { // Service is not available, no further action is needed. } } else { // The IPC call itself fails, proceed with error handling logic here, // such as retry. } }
Java
client.isServiceAvailable().addOnCompleteListener(task - > { if (task.isSuccessful()) { // Handle success if(task.getResult()) { // Service is available on the device, proceed with content // publish calls. } else { // Service is not available, no further action is needed. } } else { // The IPC call itself fails, proceed with error handling logic here, // such as retry. } });
publishRecommendationClusters
Bu API, RecommendationCluster
nesnelerinin listesini yayınlamak için kullanılır.
RecommendationCluster
nesneleri aşağıdaki özelliklere sahip olabilir:
Özellik | Şartlar | Açıklama |
---|---|---|
ShoppingEntity listesi | Zorunlu | Bu öneri kümesi için önerileri oluşturan ShoppingEntity nesnelerinin listesi. |
Başlık | Zorunlu | Öneri kümesinin başlığı. Önerilen metin boyutu: 25 karakterden kısa (Çok uzun metinlerde üç nokta gösterilebilir) |
Alt başlık | İsteğe bağlı | Öneri kümesinin alt başlığı. |
İşlem Uri | İsteğe bağlı |
Kullanıcıların önerilerin tam listesini görebileceği iş ortağı uygulamasındaki sayfanın derin bağlantısı. Not: İlişkilendirme için derin bağlantıları kullanabilirsiniz. Bu SSS'ye bakın |
Kotlin
client.publishRecommendationClusters( PublishRecommendationClustersRequest.Builder() .addRecommendationCluster( RecommendationCluster.Builder() .addEntity(entity1) .addEntity(entity2) .setTitle("Black Friday Deals") .build()) .build())
Java
client.publishRecommendationClusters( new PublishRecommendationClustersRequest.Builder() .addRecommendationCluster( new RecommendationCluster.Builder() .addEntity(entity1) .addEntity(entity2) .setTitle("Black Friday Deals") .build()) .build());
Hizmet isteği aldığında, bir işlem içinde aşağıdaki işlemler gerçekleştirilir:
- Mevcut tüm öneri kümesi verileri kaldırılır.
- İstekten gelen veriler ayrıştırılır ve yeni öneri kümelerinde depolanır.
Hata olması durumunda isteğin tamamı reddedilir ve mevcut durum korunur.
publishFeaturedCluster
Bu API, FeaturedCluster
nesnesi yayınlamak için kullanılır.
Kotlin
client.publishFeaturedCluster( PublishFeaturedClusterRequest.Builder() .setFeaturedCluster( FeaturedCluster.Builder() ... .build()) .build())
Java
client.publishFeaturedCluster( new PublishFeaturedClusterRequest.Builder() .setFeaturedCluster( new FeaturedCluster.Builder() ... .build()) .build());
Hizmet isteği aldığında tek bir işlemde aşağıdaki işlemler gerçekleşir:
- Geliştirici iş ortağının mevcut
FeaturedCluster
verileri kaldırılır. - İstekten gelen veriler ayrıştırılır ve güncellenen Öne Çıkan Küme'de depolanır.
Bir hata olması durumunda, isteğin tamamı reddedilir ve mevcut durum korunur.
publishShoppingCart
Bu API, ShoppingCartCluster
nesnesi yayınlamak için kullanılır.
Kotlin
client.publishShoppingCart( PublishShoppingCartRequest.Builder() .setShoppingCart( ShoppingCart.Builder() ... .build()) .build())
Java
client.publishShoppingCart( new PublishShoppingCartRequest.Builder() .setShoppingCart( new ShoppingCart.Builder() ... .build()) .build())
Hizmet isteği aldığında tek bir işlemde aşağıdaki işlemler gerçekleşir:
- Geliştirici iş ortağının mevcut
ShoppingCart
verileri kaldırılır. - İstekten gelen veriler ayrıştırılır ve güncellenen Alışveriş Sepeti Kümesi'nde depolanır.
Bir hata olması durumunda, isteğin tamamı reddedilir ve mevcut durum korunur.
publishShoppingCarts
Bu API, birden fazla ShoppingCart
nesnesi yayınlamak için kullanılır. Bu, satıcı başına ayrı alışveriş sepetleri yayınlayan geliştirici iş ortakları için geçerlidir. Bu API'yi kullanırken başlığa satıcı adını ekleyin.
Kotlin
client.publishShoppingCarts( PublishShoppingCartClustersRequest.Builder() .addShoppingCart( ShoppingCart.Builder() ... .build()) .build())
Java
client.publishShoppingCarts( new PublishShoppingCartClustersRequest.Builder() .addShoppingCart( new ShoppingCart.Builder() ... .build()) .build())
Hizmet isteği aldığında tek bir işlemde aşağıdaki işlemler gerçekleşir:
- Geliştirici iş ortağının mevcut
ShoppingCart
verileri kaldırılır. - İstekten gelen veriler ayrıştırılır ve güncellenen Alışveriş Sepeti Kümesi'nde depolanır.
Hata olması durumunda isteğin tamamı reddedilir ve mevcut durum korunur.
publishShoppingList
Bu API, FoodShoppingList
nesnesi yayınlamak için kullanılır.
Kotlin
client.publishFoodShoppingList( PublishFoodShoppingListRequest.Builder() .setFoodShoppingList( FoodShoppingListEntity.Builder() ... .build()) .build())
Java
client.publishFoodShoppingList( new PublishFoodShoppingListRequest.Builder() .setFoodShoppingList( new FoodShoppingListEntity.Builder() ... .build()) .build());
Hizmet isteği aldığında tek bir işlemde aşağıdaki işlemler gerçekleşir:
- Geliştirici iş ortağının mevcut
FoodShoppingList
verileri kaldırılır. - İstekten gelen veriler ayrıştırılır ve güncellenen Alışveriş Listesi Kümesi'nde depolanır.
Bir hata olması durumunda, isteğin tamamı reddedilir ve mevcut durum korunur.
publishShoppingReorderCluster
Bu API, ShoppingReorderCluster
nesnesi yayınlamak için kullanılır.
Kotlin
client.publishShoppingReorderCluster( PublishShoppingReorderClusterRequest.Builder() .setReorderCluster( ShoppingReorderCluster.Builder() ... .build()) .build())
Java
client.publishShoppingReorderCluster( new PublishShoppingReorderClusterRequest.Builder() .setReorderCluster( new ShoppingReorderCluster.Builder() ... .build()) .build());
Hizmet isteği aldığında tek bir işlemde aşağıdaki işlemler gerçekleşir:
- Geliştirici iş ortağının mevcut
ShoppingReorderCluster
verileri kaldırılır. - İstekten gelen veriler ayrıştırılır ve güncellenen yeniden sıralama kümesinde depolanır.
Hata olması durumunda isteğin tamamı reddedilir ve mevcut durum korunur.
publishShoppingOrderTrackingCluster
Bu API, ShoppingOrderTrackingCluster
nesnesi yayınlamak için kullanılır.
Kotlin
client.publishShoppingOrderTrackingCluster( PublishShoppingOrderTrackingClusterRequest.Builder() .setShoppingOrderTrackingCluster( ShoppingOrderTrackingCluster.Builder() ... .build()) .build())
Java
client.publishShoppingOrderTrackingCluster( new PublishShoppingOrderTrackingClusterRequest.Builder() .setShoppingOrderTrackingCluster( new ShoppingOrderTrackingCluster.Builder() ... .build()) .build());
Hizmet isteği aldığında tek bir işlemde aşağıdaki işlemler gerçekleşir:
- Geliştirici iş ortağının mevcut
ShoppingOrderTrackingCluster
verileri kaldırılır. - İstekten elde edilen veriler ayrıştırılır ve güncellenmiş Alışveriş Sipariş İzleme Kümesinde depolanır.
Hata olması durumunda isteğin tamamı reddedilir ve mevcut durum korunur.
publishUserAccountManagementRequest
Bu API, oturum açma kartı yayınlamak için kullanılır. Oturum açma işlemi, uygulamanın içerik yayınlayabilmesi (veya daha kişiselleştirilmiş içerik sunabilmesi) için kullanıcıları uygulamanın oturum açma sayfasına yönlendirir.
Aşağıdaki meta veriler, Oturum Açma Kartının bir parçasıdır:
Özellik | Şartlar | Açıklama |
---|---|---|
İşlem URI'sı | Zorunlu | İşleme derin bağlantı (ör. uygulamanın oturum açma sayfasına yönlendirme) |
Resim | İsteğe bağlı: Sağlanmamışsa başlık belirtilmelidir. |
Kartta gösterilen resim 1264x712 çözünürlüklü, 16x9 en boy oranında resimler |
Başlık | İsteğe bağlı: Sağlanmazsa resim sağlanmalıdır | Karttaki başlık |
İşlem metni | İsteğe bağlı | CTA'da Gösterilen Metin (ör. Oturum aç) |
Alt başlık | İsteğe bağlı | Kartta isteğe bağlı altyazı |
Kotlin
var SIGN_IN_CARD_ENTITY = SignInCardEntity.Builder() .addPosterImage( Image.Builder() .setImageUri(Uri.parse("http://www.x.com/image.png")) .setImageHeightInPixel(500) .setImageWidthInPixel(500) .build()) .setActionText("Sign In") .setActionUri(Uri.parse("http://xx.com/signin")) .build() client.publishUserAccountManagementRequest( PublishUserAccountManagementRequest.Builder() .setSignInCardEntity(SIGN_IN_CARD_ENTITY) .build());
Java
SignInCardEntity SIGN_IN_CARD_ENTITY = new SignInCardEntity.Builder() .addPosterImage( new Image.Builder() .setImageUri(Uri.parse("http://www.x.com/image.png")) .setImageHeightInPixel(500) .setImageWidthInPixel(500) .build()) .setActionText("Sign In") .setActionUri(Uri.parse("http://xx.com/signin")) .build(); client.publishUserAccountManagementRequest( new PublishUserAccountManagementRequest.Builder() .setSignInCardEntity(SIGN_IN_CARD_ENTITY) .build());
Hizmet isteği aldığında, bir işlem içinde aşağıdaki işlemler gerçekleştirilir:
- Geliştirici iş ortağının mevcut
UserAccountManagementCluster
verileri kaldırılır. - İstekten elde edilen veriler ayrıştırılır ve güncellenmiş UserAccountManagementCluster Kümesinde depolanır.
Bir hata olması durumunda, isteğin tamamı reddedilir ve mevcut durum korunur.
updatePublishStatus
Dahili bir işletme nedeniyle kümelerin hiçbiri yayınlanmıyorsa updatePublishStatus API'sini kullanarak yayınlama durumunu güncellemenizi önemle tavsiye ederiz. Bu önemlidir, çünkü :
- İçerik yayınlandığında bile tüm senaryolarda durumu belirtmek (STATUS == YAYINLANDI) entegrasyonunuzun durumunu ve diğer metriklerini iletmek için bu uygunsuz durumu kullanan kontrol panellerini doldurmak açısından çok önemlidir.
- Hiçbir içerik yayınlanmamışsa ancak entegrasyon durumu bozulmamışsa (STATUS == NOT_PUBLISHED) Google, uygulama sağlığı kontrol panellerinde uyarı tetiklemekten kaçınabilir. Sağlayıcı açısından beklenen bir durum nedeniyle içeriğin yayınlanmadığını onaylar.
- Geliştiricilerin verilerin ne zaman yayınlandığı ve ne zaman yayınlanmadığı hakkında analizler sunmasına yardımcı olur.
- Google, uygulama içeriğini görebilmeleri veya üstesinden gelebilmesi amacıyla, durum kodlarını kullanıcıyı uygulamada belirli işlemleri yapmaya yönlendirmek için kullanabilir.
Uygun yayınlama durumu kodlarının listesi şunlardır:
// Content is published
AppEngagePublishStatusCode.PUBLISHED,
// Content is not published as user is not signed in
AppEngagePublishStatusCode.NOT_PUBLISHED_REQUIRES_SIGN_IN,
// Content is not published as user is not subscribed
AppEngagePublishStatusCode.NOT_PUBLISHED_REQUIRES_SUBSCRIPTION,
// Content is not published as user location is ineligible
AppEngagePublishStatusCode.NOT_PUBLISHED_INELIGIBLE_LOCATION,
// Content is not published as there is no eligible content
AppEngagePublishStatusCode.NOT_PUBLISHED_NO_ELIGIBLE_CONTENT,
// Content is not published as the feature is disabled by the client
// Available in v1.3.1
AppEngagePublishStatusCode.NOT_PUBLISHED_FEATURE_DISABLED_BY_CLIENT,
// Content is not published as the feature due to a client error
// Available in v1.3.1
AppEngagePublishStatusCode.NOT_PUBLISHED_CLIENT_ERROR,
// Content is not published as the feature due to a service error
// Available in v1.3.1
AppEngagePublishStatusCode.NOT_PUBLISHED_SERVICE_ERROR,
// Content is not published due to some other reason
// Reach out to engage-developers@ before using this enum.
AppEngagePublishStatusCode.NOT_PUBLISHED_OTHER
İçerik, bir kullanıcı giriş yapmadığı için yayınlanmazsa Google, Oturum Açma kartını yayınlamanızı önerir. Sağlayıcılar herhangi bir nedenle oturum açma kartını yayınlayamıyorsa NOT_PUBLISHED_REQUIRES_SIGN_IN durum koduyla updatePublishStatus API'sini çağırmanızı öneririz.
Kotlin
client.updatePublishStatus( PublishStatusRequest.Builder() .setStatusCode(AppEngagePublishStatusCode.NOT_PUBLISHED_REQUIRES_SIGN_IN) .build())
Java
client.updatePublishStatus( new PublishStatusRequest.Builder() .setStatusCode(AppEngagePublishStatusCode.NOT_PUBLISHED_REQUIRES_SIGN_IN) .build());
deleteRecommendationClusters
Bu API, öneri kümelerinin içeriğini silmek için kullanılır.
Kotlin
client.deleteRecommendationClusters()
Java
client.deleteRecommendationClusters();
Hizmet, isteği aldığında mevcut verileri öneri kümelerinden kaldırır. Bir hata olması durumunda, isteğin tamamı reddedilir ve mevcut durum korunur.
deleteFeaturedCluster
Bu API, Öne Çıkan Küme'nin içeriğini silmek için kullanılır.
Kotlin
client.deleteFeaturedCluster()
Java
client.deleteFeaturedCluster();
Hizmet, isteği aldığında Öne Çıkan Küme'deki mevcut verileri kaldırır. Hata olması durumunda isteğin tamamı reddedilir ve mevcut durum korunur.
deleteShoppingCartCluster
Bu API, Alışveriş Sepeti Kümesi'nin içeriğini silmek için kullanılır.
Kotlin
client.deleteShoppingCartCluster()
Java
client.deleteShoppingCartCluster();
Hizmet, isteği aldığında mevcut verileri Alışveriş Sepeti Kümesi'nden kaldırır. Hata olması durumunda isteğin tamamı reddedilir ve mevcut durum korunur.
deleteShoppingListCluster
Bu API, Alışveriş Listesi Kümesi'nin içeriğini silmek için kullanılır.
Kotlin
client.deleteShoppingListCluster()
Java
client.deleteShoppingListCluster();
Hizmet, isteği aldığında mevcut verileri Alışveriş Listesi Kümesi'nden kaldırır. Hata olması durumunda isteğin tamamı reddedilir ve mevcut durum korunur.
deleteShoppingReorderCluster
Bu API, Alışveriş Tekrar Sipariş Kümesi'nin içeriğini silmek için kullanılır.
Kotlin
client.deleteShoppingReorderCluster()
Java
client.deleteShoppingReorderCluster();
Hizmet, isteği aldığında mevcut verileri Alışveriş Tekrar Sipariş Kümesi'nden kaldırır. Bir hata olması durumunda, isteğin tamamı reddedilir ve mevcut durum korunur.
deleteShoppingOrderTrackingCluster
Bu API, Alışveriş Sipariş İzleme Kümesi'nin içeriğini silmek için kullanılır.
Kotlin
client.deleteShoppingOrderTrackingCluster()
Java
client.deleteShoppingOrderTrackingCluster();
Hizmet, isteği aldığında mevcut verileri Alışveriş Siparişi İzleme Kümesi'nden kaldırır. Bir hata olması durumunda, isteğin tamamı reddedilir ve mevcut durum korunur.
deleteUserManagementCluster
Bu API, UserAccountManagement kümesinin içeriğini silmek için kullanılır.
Kotlin
client.deleteUserManagementCluster()
Java
client.deleteUserManagementCluster();
Hizmet, isteği aldığında mevcut verileri UserAccountManagement kümesinden kaldırır. Hata durumunda isteğinin tamamı reddedilir ve mevcut durum korunur.
deleteClusters
Bu API, belirli bir küme türünün içeriğini silmek için kullanılır.
Kotlin
client.deleteClusters( DeleteClustersRequest.Builder() .addClusterType(ClusterType.TYPE_FEATURED) .addClusterType(ClusterType.TYPE_RECOMMENDATION) ... .build())
Java
client.deleteClusters( new DeleteClustersRequest.Builder() .addClusterType(ClusterType.TYPE_FEATURED) .addClusterType(ClusterType.TYPE_RECOMMENDATION) ... .build());
Hizmet, isteği aldığında belirtilen küme türleriyle eşleşen tüm kümelerdeki mevcut verileri kaldırır. İstemciler bir veya daha fazla küme türünü iletmeyi seçebilir. Hata olması durumunda isteğin tamamı reddedilir ve mevcut durum korunur.
Hata işleme
Yayınlama API'lerinden görev sonucunu dinlemeniz önemle tavsiye edilir. Böylece, başarılı bir görevi kurtarıp yeniden göndermek için takip işlemi yapabilirsiniz.
Kotlin
client.publishRecommendationClusters( PublishRecommendationClustersRequest.Builder() .addRecommendationCluster(..) .build()) .addOnCompleteListener { task -> if (task.isSuccessful) { // do something } else { val exception = task.exception if (exception is AppEngageException) { @AppEngageErrorCode val errorCode = exception.errorCode if (errorCode == AppEngageErrorCode.SERVICE_NOT_FOUND) { // do something } } } }
Java
client.publishRecommendationClusters( new PublishRecommendationClustersRequest.Builder() .addRecommendationCluster(...) .build()) .addOnCompleteListener( task -> { if (task.isSuccessful()) { // do something } else { Exception exception = task.getException(); if (exception instanceof AppEngageException) { @AppEngageErrorCode int errorCode = ((AppEngageException) exception).getErrorCode(); if (errorCode == AppEngageErrorCode.SERVICE_NOT_FOUND) { // do something } } } });
Hata, hata kodu olarak nedeni dahil edilerek AppEngageException
olarak döndürülür.
Hata kodu | Hata adı | Not |
---|---|---|
1 |
SERVICE_NOT_FOUND |
Hizmet, belirtilen cihazda kullanılamıyor. |
2 |
SERVICE_NOT_AVAILABLE |
Hizmet, belirli bir cihazda kullanılabilir ancak arama sırasında kullanılamaz (örneğin, açıkça devre dışı bırakılmıştır). |
3 |
SERVICE_CALL_EXECUTION_FAILURE |
Görev yürütme, mesaj dizileriyle ilgili sorunlar nedeniyle başarısız oldu. Bu durumda, işlem yeniden denenebilir. |
4 |
SERVICE_CALL_PERMISSION_DENIED |
Arayan kullanıcının servis araması yapmasına izin verilmiyor. |
5 |
SERVICE_CALL_INVALID_ARGUMENT |
İstek geçersiz veriler içeriyor (örneğin, izin verilenden daha fazla sayıda küme). |
6 |
SERVICE_CALL_INTERNAL |
Hizmet tarafında bir hata var. |
7 |
SERVICE_CALL_RESOURCE_EXHAUSTED |
Hizmet çağrısı çok sık yapılıyor. |
3. Adım: Yayın intent'lerini işleme
İçerik yayınlama isteğini almak için bir iş üzerinden Content API çağrıları yapmanın yanı sıra bir BroadcastReceiver
oluşturmak da gerekir.
Amaca dayalı yayınların amacı, temel olarak uygulamanın yeniden etkinleştirilmesini sağlamak ve veri senkronizasyonunu zorunlu kılmaktır. Yayın niyeti, çok sık gönderilecek şekilde tasarlanmamıştır. Bu işlem yalnızca Etkileşim Hizmeti tarafından içeriğin eski olabileceğini (örneğin, bir hafta önce) belirlediğinde tetiklenir. Bu sayede, uygulama uzun süre çalıştırılmamış olsa bile kullanıcının yeni bir içerik deneyimi yaşayabileceğinden emin olabilirsiniz.
BroadcastReceiver
aşağıdaki iki şekilde ayarlanmalıdır:
Context.registerReceiver()
kullanarakBroadcastReceiver
sınıfının bir örneğini dinamik olarak kaydedin. Bu sayede, bellekte hâlâ etkin olan uygulamalardan iletişim kurulabilir.
Kotlin
class AppEngageBroadcastReceiver : BroadcastReceiver(){ // Trigger recommendation cluster publish when PUBLISH_RECOMMENDATION // broadcast is received // Trigger featured cluster publish when PUBLISH_FEATURED broadcast is // received // Trigger shopping cart cluster publish when PUBLISH_SHOPPING_CART broadcast // is received // Trigger shopping list cluster publish when PUBLISH_SHOPPING_LIST broadcast // is received // Trigger reorder cluster publish when PUBLISH_REORDER_CLUSTER broadcast is // received // Trigger shopping order tracking cluster publish when // PUBLISH_SHOPPING_ORDER_TRACKING_CLUSTER broadcast is received } fun registerBroadcastReceivers(context: Context){ var context = context context = context.applicationContext // Register Recommendation Cluster Publish Intent context.registerReceiver(AppEngageBroadcastReceiver(), IntentFilter(Intents.ACTION_PUBLISH_RECOMMENDATION)) // Register Featured Cluster Publish Intent context.registerReceiver(AppEngageBroadcastReceiver(), IntentFilter(Intents.ACTION_PUBLISH_FEATURED)) // Register Shopping Cart Cluster Publish Intent context.registerReceiver(AppEngageBroadcastReceiver(), IntentFilter(Intents.ACTION_PUBLISH_SHOPPING_CART)) // Register Shopping List Cluster Publish Intent context.registerReceiver(AppEngageBroadcastReceiver(), IntentFilter(Intents.ACTION_PUBLISH_SHOPPING_LIST)) // Register Reorder Cluster Publish Intent context.registerReceiver(AppEngageBroadcastReceiver(), IntentFilter(Intents.ACTION_PUBLISH_REORDER_CLUSTER)) // Register Shopping Order Tracking Cluster Publish Intent context.registerReceiver(AppEngageBroadcastReceiver(), IntentFilter(Intents.ACTION_PUBLISH_SHOPPING_ORDER_TRACKING_CLUSTER)) }
Java
class AppEngageBroadcastReceiver extends BroadcastReceiver { // Trigger recommendation cluster publish when PUBLISH_RECOMMENDATION broadcast // is received // Trigger featured cluster publish when PUBLISH_FEATURED broadcast is received // Trigger shopping cart cluster publish when PUBLISH_SHOPPING_CART broadcast is // received // Trigger shopping list cluster publish when PUBLISH_SHOPPING_LIST broadcast is // received // Trigger reorder cluster publish when PUBLISH_REORDER_CLUSTER broadcast is // received // Trigger reorder cluster publish when PUBLISH_SHOPPING_ORDER_TRACKING_CLUSTER // broadcast is received } public static void registerBroadcastReceivers(Context context) { context = context.getApplicationContext(); // Register Recommendation Cluster Publish Intent context.registerReceiver(new AppEngageBroadcastReceiver(), new IntentFilter(com.google.android.engage.service.Intents.ACTION_PUBLISH_RECOMMENDATION)); // Register Featured Cluster Publish Intent context.registerReceiver(new AppEngageBroadcastReceiver(), new IntentFilter(com.google.android.engage.service.Intents.ACTION_PUBLISH_FEATURED)); // Register Shopping Cart Cluster Publish Intent context.registerReceiver(new AppEngageBroadcastReceiver(), new IntentFilter(com.google.android.engage.shopping.service.Intents.ACTION_PUBLISH_SHOPPING_CART)); // Register Shopping List Cluster Publish Intent context.registerReceiver(new AppEngageBroadcastReceiver(), new IntentFilter(com.google.android.engage.shopping.service.Intents.ACTION_PUBLISH_SHOPPING_LIST)); // Register Reorder Cluster Publish Intent context.registerReceiver(new AppEngageBroadcastReceiver(), new IntentFilter(com.google.android.engage.shopping.service.Intents.ACTION_PUBLISH_REORDER_CLUSTER)); // Register Shopping Order Tracking Cluster Publish Intent context.registerReceiver(new AppEngageBroadcastReceiver(), new IntentFilter(com.google.android.engage.shopping.service.Intents.ACTION_PUBLISH_SHOPPING_ORDER_TRACKING_CLUSTER)); }
AndroidManifest.xml
dosyanızda<receiver>
etiketiyle uygulamayı statik olarak beyan edin. Bu, uygulamanın çalışmadığında yayın intent'leri almasına ve içeriği yayınlamasına olanak tanır.
<application>
<receiver
android:name=".AppEngageBroadcastReceiver"
android:exported="true"
android:enabled="true">
<intent-filter>
<action android:name="com.google.android.engage.action.PUBLISH_RECOMMENDATION" />
</intent-filter>
<intent-filter>
<action android:name="com.google.android.engage.action.PUBLISH_FEATURED" />
</intent-filter>
<intent-filter>
<action android:name="com.google.android.engage.action.shopping.PUBLISH_SHOPPING_CART" />
</intent-filter>
<intent-filter>
<action android:name="com.google.android.engage.action.shopping.PUBLISH_SHOPPING_LIST" />
</intent-filter>
<intent-filter>
<action android:name="com.google.android.engage.action.shopping.PUBLISH_REORDER_CLUSTER" />
</intent-filter>
<intent-filter>
<action android:name="com.google.android.engage.action.shopping.PUBLISH_SHOPPING_ORDER_TRACKING_CLUSTER" />
</intent-filter>
</receiver>
</application>
Hizmet tarafından aşağıdaki intent'ler gönderilir:
com.google.android.engage.action.PUBLISH_RECOMMENDATION
Bu niyet karşılandığında birpublishRecommendationClusters
araması başlatmanız önerilir.com.google.android.engage.action.PUBLISH_FEATURED
Bu intent alındığında birpublishFeaturedCluster
çağrısı başlatmanız önerilir.com.google.android.engage.action.shopping.PUBLISH_SHOPPING_CART
Bu intent alındığında birpublishShoppingCart
çağrısı başlatmanız önerilir.com.google.android.engage.action.shopping.PUBLISH_SHOPPING_LIST
Bu intent alındığında birpublishShoppingList
çağrısı başlatmanız önerilir.com.google.android.engage.action.shopping.PUBLISH_REORDER_CLUSTER
Bu intent alındığında birpublishReorderCluster
çağrısı başlatmanız önerilir.com.google.android.engage.action.shopping.PUBLISH_SHOPPING_ORDER_TRACKING_CLUSTER
Bu niyet alındığındapublishShoppingOrderTrackingCluster
çağrısı başlatmanız önerilir.
Entegrasyon iş akışı
Entegrasyonunuz tamamlandıktan sonra doğrulamayla ilgili adım adım açıklamalı bir kılavuz için Engage geliştirici entegrasyon iş akışı başlıklı makaleyi inceleyin.
SSS
SSS'ler için Etkileşim SDK'sıyla İlgili Sık Sorulan Sorular bölümüne bakın.
İletişim
Entegrasyon işlemi sırasında sorularınız olursa engage-developers@google.com adresinden bizimle iletişime geçebilirsiniz. Ekibimiz en kısa sürede yanıt verir.
Sonraki adımlar
Bu entegrasyonu tamamladıktan sonra uygulayacağınız adımlar şunlardır:
- engage-developers@google.com adresine bir e-posta gönderin ve Google tarafından test edilmeye hazır olan entegre APK'nızı ekleyin.
- Google, entegrasyonun beklendiği gibi çalıştığından emin olmak için bir doğrulama ve şirket içi inceleme gerçekleştirir. Değişiklik yapılması gerekiyorsa Google gerekli tüm bilgileri sizinle paylaşır.
- Test tamamlandığında ve herhangi bir değişiklik gerekmediğinde Google, güncellenmiş ve entegre APK'yı Play Store'da yayınlamaya başlayabileceğinizi bildirmek için sizinle iletişime geçer.
- Google, güncellenmiş APK'nızın Play Store'da yayınlandığını onayladıktan sonra Öneri, Öne Çıkan, Alışveriş Sepeti, Alışveriş Listesi, Yeniden Sipariş Kümesi ve Alışveriş Siparişi Takip Kümesi kümeleriniz yayınlanabilir ve kullanıcılar tarafından görülebilir.