Pakiet SDK dla kampanii produktowych: instrukcje integracji technicznej firm zewnętrznych

Google tworzy na urządzeniu platformę, która porządkuje aplikacje według branż i umożliwia korzystanie ze spersonalizowanych treści w aplikacji. i odkrywania. Dzięki temu partnerzy mogą mają możliwość zaprezentowania swoich najlepszych, bogatych materiałów na specjalnym kanale do aplikacji.

W tym przewodniku znajdziesz instrukcje dla deweloperów dotyczące integrowania w ramach zakupów, korzystając z pakietu SDK dla agencji, aby uwzględnić w nim treści reklamowe i dotychczasowych platform Google, takich jak Entertainment Space.

Szczegóły integracji

Terminologia

Ta integracja obejmuje 5 typów klastrów: Recommendation, Polecane, Koszyk, Lista zakupów, Zmień kolejność i Śledzenie zamówień.

  • Klastry rekomendacji wyświetlają spersonalizowane sugestie zakupów od z konkretnym partnerem ds. deweloperów. Rekomendacje te można dostosować do użytkownika lub uogólnione (np. elementy zyskujące popularność). Za ich pomocą możesz produkty, wydarzenia, wyprzedaże, promocje i subskrypcje.

    Rekomendacje mają następującą strukturę:

    • Klaster rekomendacji: widok interfejsu zawierający grupę rekomendacje od tego samego partnera dewelopera.

    • ShoppingEntity:obiekt reprezentujący pojedynczy produkt w klastrze.

  • Klaster Polecane prezentuje bohatera wybranego przez Ciebie ShoppingEntity partnerów programistów w jednej grupie UI. Jest tylko jedna sekcja Polecane który znajduje się u góry interfejsu użytkownika i ma priorytet miejsce docelowe nad wszystkimi klastrami rekomendacji. Każdy partner deweloperów mogą opublikować pojedynczy obiekt ShoppingEntity w klastrze Polecane.

  • Klaster Koszyk pokazuje podsumowanie koszyków na zakupy z wielu programistów w jednej grupie UI, zachęcając użytkowników do zaległych koszyków. Jeden klaster koszyka na zakupy, który u góry interfejsu, gdzie priorytet znajduje się powyżej Klastry rekomendacji. Każdy partner programistów może transmitować ShoppingCart w klastrze Koszyk.

    Twój koszyk na zakupy ma następującą strukturę:

    • Klaster koszyka: widok interfejsu zawierający grupę zakupów. podglądów koszyka od wielu deweloperów.

    • ShoppingCart: obiekt reprezentujący podgląd koszyka na zakupy jednego partnera programisty, będzie wyświetlana w koszyku klastra. ShoppingCart musi pokazywać łączną liczbę elementów w koszyka i może również zawierać zdjęcia niektórych produktów znajdujących się w koszyku użytkownika.

  • Klaster Shopping List daje możliwość zaprezentowania zakupów od wielu partnerów dewelopera w jednej grupie UI, co zachęca użytkowników do wróć do odpowiedniej aplikacji, aby zaktualizować i uzupełnić listy. Jest listy zakupów w jednym klastrze.

  • Klaster Zmień kolejność pokazuje ujęcia z poprzednich zamówień kilku partnerów w ramach jednej grupy interfejsu, co ułatwia użytkownikom zmianę kolejności. Jest 1 klaster Zmień kolejność.

    • Zmień kolejność klastrów musi wyświetlać łączną liczbę elementów w poprzedniego zamówienia użytkownika i musi też zawierać jeden z następujących elementów:

      • Obrazy X produktów w poprzedniej kolejności użytkownika.
      • Etykiety X elementów w poprzedniej kolejności użytkownika.
  • Klaster Shopping Order Tracking (Śledzenie zamówień) pokazuje zdrapkę oczekujących lub niedawno dokonane zamówienia od wielu deweloperów w jednym interfejsie. dzięki czemu użytkownicy mogą śledzić swoje zamówienia.

    Wyświetlono pojedynczy klaster ShoppingOrderTracking u góry interfejsu, gdzie priorytetowe jest miejsce nad wszystkimi Rekomendacjami klastrów. Każdy partner deweloperów może transmitować wiele Produkty ShoppingOrderTrackingEntity w klastrze śledzenia zamówień w Zakupach Google.

    • Klaster ShoppingOrderTrackingCluster ma następującą strukturę:

      • Klaster ShoppingOrderTracking: widok interfejsu zawierający grupę podglądy śledzenia zamówień od wielu partnerów deweloperów
      • ShoppingOrderTrackingEntity: obiekt reprezentujący zamówienie dla jednego partnera programistycznego, który będzie wyświetlany w Klaster śledzenia zamówień w Zakupach Google. Wartość ShoppingOrderTrackingEntity musi być wyświetlana stan zamówienia i czas jego realizacji. Zdecydowanie zalecamy podając oczekiwany czas dostawy dla ShoppingOrderTrackingEntity, i przeglądanie danych.

Przygotowanie

Minimalny poziom interfejsu API: 19

Dodaj bibliotekę com.google.android.engage:engage-core do aplikacji:

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'
}

Więcej informacji znajdziesz w sekcji Widoczność pakietów na Androidzie 11.

Podsumowanie

Projekt opiera się na implementacji powiązanego usługi.

Dane, które klient może publikować, podlegają następującym limitom dla różnych typy klastrów:

Typ klastra Limity klastra Maksymalne limity encji w klastrze
Klastry rekomendacji Maksymalnie 5 Maksymalnie 25 ShoppingEntity
Polecany klaster Maksymalnie 1 Maksymalnie 1 ShoppingEntity
Klaster koszyka na zakupy Maksymalnie 1 Maksymalnie 1 ShoppingCart
Klaster listy zakupów Maksymalnie 1 Maksymalnie 1 ShoppingListEntity
Zmiana kolejności klastra w Zakupach Google Maksymalnie 1 Maksymalnie 1 ReorderEntity
Klaster śledzenia zamówień w Zakupach Google Maksymalnie 3 Maksymalnie 3 ShoppingOrderTrackingEntity

Krok 1. Podaj dane encji

Pakiet SDK ma zdefiniowane różne jednostki reprezentujące każdy typ elementu. W kategorii Zakupy obsługiwane są następujące podmioty:

  1. ShoppingEntity
  2. ShoppingCart
  3. ShoppingList
  4. Reorder
  5. ShoppingOrderTracking

Poniższe tabele przedstawiają dostępne atrybuty i wymagania dla każdego typu.

ShoppingEntity

Obiekt ShoppingEntity reprezentuje produkt, promocję, ofertę, subskrypcję, lub wydarzenie, które chcą publikować partnerzy deweloperów.

ShoppingEntity
Atrybut Wymaganie Opis Format
Plakat Wymagany Musisz przesłać co najmniej 1 obraz. Wskazówki znajdziesz w specyfikacjach obrazów.
Identyfikator URI działania Wymagany

Precyzyjny link do strony w aplikacji, która zawiera szczegółowe informacje o podmiotu zabezpieczeń.

Uwaga: na potrzeby atrybucji możesz używać precyzyjnych linków. Zapoznaj się z tymi odpowiedziami na najczęstsze pytania

Identyfikator URI
Tytuł Opcjonalnie Nazwa elementu.

Dowolny tekst

Zalecany rozmiar tekstu: poniżej 90 znaków (czyli za długi tekst może zawierać wielokropki)

Cena - bieżąca Wymagane warunkowo

Aktualna cena elementu.

Jeśli podano przekreśloną cenę, ta wartość jest wymagana.

Dowolny tekst
Cena – przekreślenie Opcjonalnie Pierwotna cena produktu, która będzie przekreślona Interfejs. Dowolny tekst
Objaśnienie Opcjonalnie Objaśnienie, które powinno zawierać promocję, wydarzenie lub aktualizację podmiotu, jeśli i dostępności informacji.

Dowolny tekst

Zalecany rozmiar tekstu: poniżej 45 znaków (tekst za długi tekst może zawierać wielokropki)

Objaśnienie drobnym drukiem Opcjonalnie Drobny tekst objaśnienia.

Dowolny tekst

Zalecany rozmiar tekstu: poniżej 45 znaków (tekst za długi tekst może zawierać wielokropki)

Ocena (opcjonalna) – uwaga: wszystkie oceny są wyświetlane w naszym standardowym systemie ocen w postaci gwiazdek.
Ocena – wartość maksymalna Opcjonalnie

Maksymalna wartość skali ocen.

Ten atrybut musi być podany, jeśli bieżąca wartość oceny jest również

Liczba >= 0.0
Ocena – bieżąca wartość Opcjonalnie

Bieżąca wartość skali ocen.

Ten atrybut musi być podany, jeśli maksymalna wartość oceny wynosi również

Liczba >= 0.0
Ocena – liczba Opcjonalnie

Liczba ocen elementu.

Uwaga: wypełnij to pole, jeśli Twoja aplikacja określa sposób wyświetlania liczby użytkownikom. Używaj zwięzłego ciągu znaków. Jeśli np. liczba wynosi 1 000 000, możesz użyć skrótu np. 1 mln, aby w przypadku mniejszych wyświetlaczy liczba nie była obcinana.

Ciąg znaków
Ocena – wartość liczby Opcjonalnie

Liczba ocen elementu.

Uwaga: podaj to pole, jeśli nie zajmujesz się musisz samodzielnie stosować skróty klawiszowe. Jeśli zarówno liczba, jak i wartość liczby wartość jest wyświetlana użytkownikom.

Długie
DisplayTimeWindow (opcjonalnie) – ustawianie przedziału czasu aby treści były wyświetlane na platformie
Sygnatura czasowa rozpoczęcia Opcjonalnie

Sygnatura czasowa epoki, po której treść powinna się wyświetlać w na różnych powierzchniach.

Jeśli zasada nie jest skonfigurowana, treści mogą być wyświetlane na platformie.

Sygnatura czasowa epoki w milisekundach
Sygnatura czasowa zakończenia Opcjonalnie

Sygnatura czasowa epoki, po której treść nie jest już wyświetlana na powierzchnię.

Jeśli zasada nie jest skonfigurowana, treści mogą być wyświetlane na platformie.

Sygnatura czasowa epoki w milisekundach

ShoppingCart

Atrybut Wymaganie Opis Format
Identyfikator URI działania Wymagany

Precyzyjny link do koszyka w aplikacji partnera.

Uwaga: na potrzeby atrybucji możesz używać precyzyjnych linków. Zapoznaj się z tymi odpowiedziami na najczęstsze pytania

Identyfikator URI
Liczba elementów Wymagany

Liczba produktów (a nie tylko liczba produktów) w koszyku.

Jeśli na przykład w koszyku są 3 identyczne koszulki i 1 kapelusz, ta liczba powinna wynosić 4.

Liczba całkowita >= 1
Tekst działania Opcjonalnie

Tekst wezwania do działania na przycisku na koszyku (np. Twoja torba na zakupy).

Jeśli deweloper nie przekaże tekstu działania, Domyślne ustawienie to Wyświetl koszyk.

Ten atrybut jest obsługiwany od wersji 1.1.0.

Ciąg znaków
Tytuł Opcjonalnie

Tytuł koszyka (np. Twoja torba na zakupy).

Jeśli deweloper nie podał tytułu, Twój koszyk jest domyślna.

Dowolny tekst

Zalecany rozmiar tekstu: poniżej 25 znaków (tekst za długi tekst może zawierać wielokropki)

Obrazy koszyka Opcjonalnie

Zdjęcia każdego produktu w koszyku.

Można przesłać maksymalnie 10 obrazów w kolejności priorytetu; rzeczywista liczba wyświetlanych obrazów zależy od formy urządzenia

Wskazówki znajdziesz w specyfikacjach obrazów.
Etykiety elementów Opcjonalnie

Lista etykiet produktów na liście zakupów.

Rzeczywista liczba wyświetlanych etykiet zależy od formatu urządzenia.

Lista etykiet dowolnego tekstu

Zalecany rozmiar tekstu: poniżej 20 znaków (czyli za długi tekst może zawierać wielokropki)

DisplayTimeWindow (opcjonalnie) – ustawianie przedziału czasu aby treści były wyświetlane na platformie
Sygnatura czasowa rozpoczęcia Opcjonalnie

Sygnatura czasowa epoki, po której treść powinna się wyświetlać w na różnych powierzchniach.

Jeśli zasada nie jest skonfigurowana, treści mogą być wyświetlane na platformie.

Sygnatura czasowa epoki w milisekundach
Sygnatura czasowa zakończenia Opcjonalnie

Sygnatura czasowa epoki, po której treść nie jest już wyświetlana na powierzchnię.

Jeśli zasada nie jest skonfigurowana, treści mogą być wyświetlane na platformie.

Sygnatura czasowa epoki w milisekundach

ShoppingList

Atrybut Wymaganie Opis Format
Identyfikator URI działania Wymagany

Precyzyjny link do listy zakupów w aplikacji partnera.

Uwaga: na potrzeby atrybucji możesz używać precyzyjnych linków. Zapoznaj się z tymi odpowiedziami na najczęstsze pytania

Identyfikator URI
Liczba elementów Wymagany Liczba produktów na liście zakupów. Liczba całkowita >= 1
Tytuł Opcjonalnie

Tytuł listy (na przykład Twoja lista zakupów).

Jeśli deweloper nie poda tytułu, Domyślną opcją jest Lista zakupów.

Dowolny tekst

Zalecany rozmiar tekstu: poniżej 25 znaków (tekst za długi tekst może zawierać wielokropki)

Etykiety elementów Wymagany

Lista etykiet produktów na liście zakupów.

Należy podać co najmniej 1 etykietę i można dodać maksymalnie 10 etykiet są udostępniane w kolejności według priorytetu; rzeczywista liczba wyświetlanych etykiet zależy od formatu urządzenia.

Lista etykiet dowolnego tekstu

Zalecany rozmiar tekstu: poniżej 20 znaków (czyli za długi tekst może zawierać wielokropki)

ShoppingReorderCluster

Atrybut Wymaganie Opis Format
Identyfikator URI działania Wymagany

Precyzyjny link do zmiany kolejności w aplikacji partnera.

Uwaga: na potrzeby atrybucji możesz używać precyzyjnych linków. Zapoznaj się z tymi odpowiedziami na najczęstsze pytania

Identyfikator URI
Tekst działania Opcjonalnie

Tekst wezwania do działania na przycisku na karcie Zmień kolejność (np. Zamów ponownie).

Jeśli deweloper nie poda tekstu działania, Domyślne ustawienie to Zmień kolejność.

Ten atrybut jest obsługiwany od wersji 1.1.0.

Ciąg znaków
Liczba elementów Wymagany

Liczba produktów (a nie tylko liczba produktów) w poprzedniej wersji zamówienie.

Na przykład: jeśli w poprzednie zamówienie, ta liczba powinna wynosić 4.

Liczba całkowita >= 1
Tytuł Wymagany Tytuł produktu, którego dotyczy zmiana.

Dowolny tekst

Zalecany rozmiar tekstu: poniżej 40 znaków (czyli za długi tekst może zawierać wielokropki)

Etykiety elementów

Opcjonalnie

(jeśli nie, należy przesłać obrazy plakatów)

Lista etykiet produktów w poprzednim zamówieniu.

Można podać maksymalnie 10 etykiet w kolejności priorytetu. rzeczywista liczba wyświetlanych etykiet zależy od formy urządzenia

Lista dowolnego tekstu

Zalecany rozmiar tekstu na etykietę: poniżej 20 znaków (Zbyt długi tekst może zawierać wielokropki)

Plakaty

Opcjonalnie

(Jeśli nie podano tej wartości, należy podać etykiety produktów)

Zdjęcia produktów z poprzedniego zamówienia.

Można przesłać maksymalnie 10 obrazów w kolejności priorytetu; rzeczywista liczba wyświetlanych obrazów zależy od formy urządzenia

Wskazówki znajdziesz w specyfikacjach obrazów.

ShoppingOrderTrackingCluster

Atrybut Wymaganie Opis Format
Tytuł Wymagany

Krótki tytuł śledzonej paczki lub produktów albo śledzenia przesyłki numer.

Dowolny tekst

Zalecany rozmiar tekstu: 50 znaków (zbyt długi tekst pokaż elipsy)

Typ zamówienia Wymagany

Krótki tytuł śledzonej paczki lub produktów albo śledzenia przesyłki numer.

Enum: IN_STORE_PICKUP, SAME_DAY_DELIVERY, MULTI_DAY_DELIVERY

Stan Wymagany

Bieżący stan zamówienia.

Na przykład: „Spóźnienie się”, „W transporcie”, „Opóźnione”, „Wysłano”, „Dostarczono”, „Niedostępny”, „Zamówienie gotowe”

Dowolny tekst

Zalecany rozmiar tekstu: 25 znaków (zbyt długi tekst pokaż elipsy)

Godzina zamówienia Wymagany

Sygnatura czasowa epoki (w milisekundach), w której złożono zamówienie.

Jeśli przewidywany okres dostawy będzie trwał, zostanie wyświetlona godzina zamówienia nie występuje

Sygnatura czasowa epoki w milisekundach
Identyfikator URI działania Wymagany

Precyzyjny link do śledzenia zamówień w aplikacji partnera.

Identyfikator URI
OrderDeliveryTimeWindow (opcjonalnie) – ustaw godzinę dla zamówienia śledzonego od momentu umieszcza się w czasie oczekiwanego/rzeczywistego dostawy.
Przedział czasu dostawy zamówienia – godzina rozpoczęcia Opcjonalnie

Sygnatura czasowa epoki (w milisekundach), po której nastąpi zamówienie dostarczany produkt lub jest gotowy do odbioru.

Sygnatura czasowa epoki w milisekundach
OrderDeliveryTimeWindow – data zakończenia Opcjonalnie

Sygnatura czasowa epoki (w milisekundach), do której nastąpi zamówienie dostarczany produkt lub jest gotowy do odbioru.

Sygnatura czasowa epoki w milisekundach
Plakat Opcjonalnie

Zdjęcie jednego produktu lub produktu, które są częścią zamówienia.

Zalecany współczynnik proporcji to 1:1.

Wskazówki znajdziesz w specyfikacjach obrazów.
Liczba elementów Opcjonalnie Liczba produktów w zamówieniu. Liczba całkowita >= 1
Opis Opcjonalnie

Jeden akapit tekstu na opis produktów w zamówieniu.

Uwaga: opis lub lista napisów zostaną wyświetlane użytkownikowi, a nie jedno i drugie.

Dowolny tekst

Zalecany rozmiar tekstu: 180 znaków

Lista napisów Opcjonalnie

maksymalnie 3 napisy, z których każdy może zawierać jeden wiersz tekstu.

Uwaga: opis lub lista napisów zostaną wyświetlane użytkownikowi, a nie jedno i drugie.

Dowolny tekst

Zalecany rozmiar tekstu dla każdego podtytułu: maks. 50 znaków

Wartość zamówienia – bieżąca cena Opcjonalnie Bieżąca wartość zamówienia. Dowolny tekst
Numer zamówienia Opcjonalnie Numer lub identyfikator zamówienia, który umożliwia jednoznaczną identyfikację zamówienia.

Dowolny tekst

Zalecany rozmiar tekstu: maks. 25 znaków

Numer śledzenia przesyłki Opcjonalnie Numer śledzenia dostawy zamówienia lub paczki na wypadek, gdyby zamówienie wymaga dostarczenia przesyłki.

Dowolny tekst

Zalecany rozmiar tekstu: maks. 25 znaków

Specyfikacja obrazu

Poniżej znajdziesz wymagane specyfikacje komponentów z obrazem:

Format obrazu Minimalny rozmiar w pikselach Zalecany rozmiar w pikselach

Kwadrat (1 x 1)

Preferowana w przypadku klastrów innych niż polecane

300x300 1200x1200

Poziomy (1,91 x 1)

Preferowana w przypadku polecanych klastrów

600x314 1200x628
Orientacja pionowa (4 x 5) 480 × 600 960x1200

Formaty plików

PNG, JPG, statyczny GIF, WebP

Maksymalny rozmiar pliku

5120 KB

Dodatkowe rekomendacje

  • Bezpieczny obszar obrazu: ważne treści umieść w środkowych 80% .
  • Użyj przezroczystego tła, aby obraz był poprawnie wyświetlany Ustawienia ciemnego i jasnego motywu.

Krok 2. Podaj dane klastra

Zaleca się, aby zadanie publikowania treści było wykonywane w tle (na przykład WorkManager). i zaplanowano je regularnie lub według konkretnego wydarzenia (np. za każdym razem, użytkownik otwiera aplikację lub właśnie dodał coś do koszyka).

Za publikowanie klastrów zakupowych odpowiada AppEngageShoppingClient.

Następujące interfejsy API są udostępniane do publikowania klastrów w kliencie:

  • isServiceAvailable
  • publishRecommendationClusters
  • publishFeaturedCluster
  • publishShoppingCart
  • publishShoppingList
  • publishShoppingReorderCluster
  • publishShoppingOrderTrackingCluster
  • publishUserAccountManagementRequest
  • updatePublishStatus
  • deleteRecommendationsClusters
  • deleteFeaturedCluster
  • deleteShoppingCartCluster
  • deleteShoppingListCluster
  • deleteShoppingReorderCluster
  • deleteShoppingOrderTrackingCluster
  • deleteUserManagementCluster
  • deleteClusters

isServiceAvailable

Ten interfejs API służy do sprawdzania, czy usługa jest dostępna do integracji oraz czy treść może być prezentowana na urządzeniu.

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

Ten interfejs API służy do publikowania listy obiektów RecommendationCluster.

Obiekt RecommendationCluster może mieć te atrybuty:

Atrybut Wymaganie Opis
Lista ShoppingEntity Wymagany Lista obiektów ShoppingEntity, które składają się na rekomendacje w tym klastrze rekomendacji.
Tytuł Wymagany

Tytuł klastra rekomendacji.

Zalecany rozmiar tekstu: poniżej 25 znaków (tekst za długi tekst może zawierać wielokropki)

Podtytuł Opcjonalnie Podtytuł klastra rekomendacji.
Identyfikator URI działania Opcjonalnie

Precyzyjny link do strony w aplikacji partnerskiej, na której użytkownicy mogą zobaczyć pełną listę rekomendacji.

Uwaga: na potrzeby atrybucji możesz używać precyzyjnych linków. Zapoznaj się z tymi odpowiedziami na najczęstsze pytania

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());

Gdy usługa otrzyma żądanie, w ramach jedna transakcja:

  • Wszystkie dotychczasowe dane klastra rekomendacji zostaną usunięte.
  • Dane z żądania są analizowane i przechowywane w nowych klastrach rekomendacji.

W przypadku błędu całe żądanie zostaje odrzucone, a obecny stan to i utrzymywane informacje.

publishFeaturedCluster

Ten interfejs API służy do publikowania obiektu FeaturedCluster.

Kotlin

client.publishFeaturedCluster(
            PublishFeaturedClusterRequest.Builder()
                .setFeaturedCluster(
                    FeaturedCluster.Builder()
                        ...
                        .build())
                .build())

Java

client.publishFeaturedCluster(
            new PublishFeaturedClusterRequest.Builder()
                .setFeaturedCluster(
                    new FeaturedCluster.Builder()
                        ...
                        .build())
                .build());

Gdy usługa otrzyma żądanie, w ramach jedna transakcja:

  • Dotychczasowe dane FeaturedCluster pochodzące od partnera dewelopera zostaną usunięte.
  • Dane z żądania są analizowane i przechowywane w zaktualizowanym polecanym klastrze.

W przypadku błędu całe żądanie zostaje odrzucone, a obecny stan to i utrzymywane informacje.

publishShoppingCart

Ten interfejs API służy do publikowania obiektu ShoppingCartCluster.

Kotlin

client.publishShoppingCart(
            PublishShoppingCartRequest.Builder()
                .setShoppingCart(
                    ShoppingCart.Builder()
                        ...
                        .build())
                .build())

Java

client.publishShoppingCart(
            new PublishShoppingCartRequest.Builder()
                .setShoppingCart(
                    new ShoppingCart.Builder()
                        ...
                        .build())
                .build())

Gdy usługa otrzyma żądanie, w ramach jedna transakcja:

  • Dotychczasowe dane ShoppingCart pochodzące od partnera dewelopera zostaną usunięte.
  • Dane z żądania są przeanalizowane i przechowywane w zaktualizowanym koszyku na zakupy Klaster.

W przypadku błędu całe żądanie zostaje odrzucone, a obecny stan to i utrzymywane informacje.

publishShoppingList

Ten interfejs API służy do publikowania obiektu FoodShoppingList.

Kotlin

client.publishFoodShoppingList(
            PublishFoodShoppingListRequest.Builder()
                .setFoodShoppingList(
                    FoodShoppingListEntity.Builder()
                        ...
                        .build())
                .build())

Java

client.publishFoodShoppingList(
            new PublishFoodShoppingListRequest.Builder()
                .setFoodShoppingList(
                    new FoodShoppingListEntity.Builder()
                        ...
                        .build())
                .build());

Gdy usługa otrzyma żądanie, w ramach jedna transakcja:

  • Dotychczasowe dane FoodShoppingList pochodzące od partnera dewelopera zostaną usunięte.
  • Dane z żądania są przeanalizowane i przechowywane na zaktualizowanej liście zakupów Klaster.

W przypadku błędu całe żądanie zostaje odrzucone, a obecny stan to i utrzymywane informacje.

publishShoppingReorderCluster

Ten interfejs API służy do publikowania obiektu ShoppingReorderCluster.

Kotlin

client.publishShoppingReorderCluster(
            PublishShoppingReorderClusterRequest.Builder()
                .setReorderCluster(
                    ShoppingReorderCluster.Builder()
                        ...
                        .build())
                .build())

Java

client.publishShoppingReorderCluster(
            new PublishShoppingReorderClusterRequest.Builder()
                .setReorderCluster(
                    new ShoppingReorderCluster.Builder()
                        ...
                        .build())
                .build());

Gdy usługa otrzyma żądanie, w ramach jedna transakcja:

  • Dotychczasowe dane ShoppingReorderCluster pochodzące od partnera dewelopera zostaną usunięte.
  • Dane z żądania są analizowane i przechowywane w zaktualizowanym klastrze Zmień kolejność.

W przypadku błędu całe żądanie zostaje odrzucone, a obecny stan to i utrzymywane informacje.

publishShoppingOrderTrackingCluster

Ten interfejs API służy do publikowania obiektu ShoppingOrderTrackingCluster.

Kotlin

client.publishShoppingOrderTrackingCluster(
            PublishShoppingOrderTrackingClusterRequest.Builder()
                .setShoppingOrderTrackingCluster(
                    ShoppingOrderTrackingCluster.Builder()
                        ...
                        .build())
                .build())

Java

client.publishShoppingOrderTrackingCluster(
            new PublishShoppingOrderTrackingClusterRequest.Builder()
                .setShoppingOrderTrackingCluster(
                    new ShoppingOrderTrackingCluster.Builder()
                        ...
                        .build())
                .build());

Gdy usługa otrzyma żądanie, w ramach jedna transakcja:

  • Dotychczasowe dane ShoppingOrderTrackingCluster od partnera dewelopera są usunięto.
  • Dane z tego żądania są przeanalizowane i przechowywane w zaktualizowanym zamówieniu zakupowym Klaster śledzenia.

W przypadku błędu całe żądanie zostaje odrzucone, a obecny stan to i utrzymywane informacje.

publishUserAccountManagementRequest

Ten interfejs API służy do publikowania karty logowania . Działanie związane z logowaniem kieruje użytkowników do stronie logowania, tak by aplikacja mogła publikować treści (lub udostępniać treści spersonalizowanej)

Te metadane są częścią karty logowania:

Atrybut Wymaganie Opis
Identyfikator URI działania Wymagane Precyzyjny link do działania (powoduje przejście na stronę logowania w aplikacji)
Obraz Opcjonalnie – jeśli nie podano, musisz podać tytuł

Obraz widoczny na karcie

Obrazy o współczynniku proporcji 16 x 9 i rozdzielczości 1264 x 712

Tytuł Opcjonalnie – jeśli nie podano, należy przesłać zdjęcie Tytuł na karcie
Tekst działania Opcjonalnie Tekst widoczny w wezwaniu do działania (np. „Zaloguj się”)
Podtytuł Opcjonalnie Opcjonalny tytuł na karcie

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());

Gdy usługa otrzyma żądanie, w ramach jedna transakcja:

  • Dotychczasowe dane UserAccountManagementCluster od partnera dewelopera są usunięto.
  • Dane z żądania są analizowane i przechowywane w zaktualizowanym Klaster zarządzania kontami użytkowników.

W przypadku błędu całe żądanie zostaje odrzucone, a obecny stan to i utrzymywane informacje.

updatePublishStatus

Jeśli z jakiegoś wewnętrznego powodu biznesowego żaden z klastrów nie zostanie opublikowany, zdecydowanie zalecamy zaktualizowanie stanu publikacji za pomocą interfejsu API updatePublishStatus. To ważne, ponieważ :

  • Podawanie stanu we wszystkich sytuacjach, nawet po opublikowaniu treści (STATUS == PUBLISHED) – ma kluczowe znaczenie przy wypełnianiu paneli, które używają jawny stan, który przekazuje informacje o stanie i inne wskaźniki integracji.
  • Jeśli treści nie zostały opublikowane, ale stan integracji nie jest uszkodzony (STATUS == NOT_PUBLISHED), Google może uniknąć wywoływania alertów w aplikacji paneli stanu. Potwierdza ono, że treść nie została opublikowana z powodu jest oczekiwana z punktu widzenia dostawcy.
  • Pomaga deweloperom określić, kiedy dane są publikowane, a kiedy Nie.
  • Google może używać kodów stanu, aby skłonić użytkownika do wykonania określonych czynności aby wyświetlić jej zawartość lub ją pokonać.

Lista kodów stanu odpowiednich publikacji :

// 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

Jeśli treści nie zostały opublikowane z powodu niezalogowanego użytkownika, Zalecamy opublikowanie karty logowania. Jeśli z jakiegoś powodu dostawcy nie mogą opublikować karty logowania zalecamy wywoływanie interfejsu API updatePublishStatus z kodem stanu NOT_PUBLISHED_REQUIRES_SIGN_IN

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

Ten interfejs API służy do usuwania zawartości klastrów rekomendacji.

Kotlin

client.deleteRecommendationClusters()

Java

client.deleteRecommendationClusters();

Gdy usługa otrzyma żądanie, usuwa istniejące dane z Klastry rekomendacji. W przypadku błędu żądanie zostaje odrzucone w całości. a obecny stan zostaje zachowany.

deleteFeaturedCluster

Ten interfejs API służy do usuwania zawartości polecanego klastra.

Kotlin

client.deleteFeaturedCluster()

Java

client.deleteFeaturedCluster();

Gdy usługa otrzyma żądanie, usuwa istniejące dane z Polecany klaster. W przypadku błędu żądanie zostaje odrzucone w całości. a obecny stan zostaje zachowany.

deleteShoppingCartCluster

Ten interfejs API służy do usuwania zawartości klastra koszyka na zakupy.

Kotlin

client.deleteShoppingCartCluster()

Java

client.deleteShoppingCartCluster();

Gdy usługa otrzyma żądanie, usuwa istniejące dane z Klaster koszyka na zakupy. W przypadku błędu żądanie zostaje odrzucone w całości. a obecny stan zostaje zachowany.

deleteShoppingListCluster

Ten interfejs API służy do usuwania zawartości klastra listy zakupów.

Kotlin

client.deleteShoppingListCluster()

Java

client.deleteShoppingListCluster();

Gdy usługa otrzyma żądanie, usuwa istniejące dane z Klaster listy zakupów. W przypadku błędu żądanie zostaje odrzucone w całości. a obecny stan zostaje zachowany.

deleteShoppingReorderCluster

Ten interfejs API służy do usuwania zawartości klastra zmiany kolejności w Zakupach Google.

Kotlin

client.deleteShoppingReorderCluster()

Java

client.deleteShoppingReorderCluster();

Gdy usługa otrzyma żądanie, usuwa istniejące dane z Klaster zmiany kolejności w Zakupach Google. W przypadku błędu żądanie zostaje odrzucone w całości. a obecny stan zostaje zachowany.

deleteShoppingOrderTrackingCluster

Ten interfejs API służy do usuwania zawartości klastra śledzenia zamówień w Zakupach Google.

Kotlin

client.deleteShoppingOrderTrackingCluster()

Java

client.deleteShoppingOrderTrackingCluster();

Gdy usługa otrzyma żądanie, usuwa istniejące dane z Klaster śledzenia zamówień w Zakupach Google. W przypadku błędu całe żądanie jest odrzucono i zachowany zostanie obecny stan.

deleteUserManagementCluster

Ten interfejs API służy do usuwania zawartości klastra UserAccountManagement.

Kotlin

client.deleteUserManagementCluster()

Java

client.deleteUserManagementCluster();

Gdy usługa otrzyma żądanie, usuwa istniejące dane z Klaster zarządzania kontami użytkowników. W przypadku błędu całe żądanie jest odrzucono i zachowany zostanie obecny stan.

deleteClusters

Ten interfejs API służy do usuwania zawartości klastra określonego typu.

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());

Gdy usługa otrzyma żądanie, usuwa istniejące dane ze wszystkich klastrów pasujących do określonych typów klastrów. Klienci mogą wybrać, czy chcą pozytywnie ocenić dla wielu typów klastrów. W przypadku błędu całe żądanie jest odrzucane, obecny stan zostaje zachowany.

Obsługa błędów

Zdecydowanie zalecamy wsłuchiwanie się w wyniki zadania z interfejsów API do publikowania, takich jak że można podjąć działania, aby odzyskać i ponownie przesłać udane zadanie.

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
                    }
                  }
                }
              });

Błąd jest zwracany jako AppEngageException z przyczyną podaną w atrybucie .

Kod błędu Uwaga:
SERVICE_NOT_FOUND Usługa jest niedostępna na danym urządzeniu.
SERVICE_NOT_AVAILABLE Usługa jest dostępna na danym urządzeniu, ale nie jest dostępna w momencie połączenia (np. funkcja jest wyraźnie wyłączona).
SERVICE_CALL_EXECUTION_FAILURE Nie udało się wykonać zadania z powodu problemów z wątkami. W takim przypadku można spróbować ponownie.
SERVICE_CALL_PERMISSION_DENIED Rozmówca nie może nawiązać połączenia z usługą.
SERVICE_CALL_INVALID_ARGUMENT Żądanie zawiera nieprawidłowe dane (na przykład więcej niż dozwolone liczby klastrów).
SERVICE_CALL_INTERNAL Po stronie usługi wystąpił błąd.
SERVICE_CALL_RESOURCE_EXHAUSTED Dzwonienie do zespołu pomocy jest wykonywane zbyt często.

Krok 3. Obsługa intencji transmisji

Oprócz wykonywania wywołań interfejsu Content API w zadaniu wymagane do skonfigurowania BroadcastReceiver do otrzymania z prośbą o opublikowanie treści.

Celem intencji transmisji jest głównie ponowna aktywacja aplikacji i wymuszenie użycia danych synchronizację. Intencje związane z transmisją nie są przeznaczone do wysyłania zbyt często. Jest tylko uruchamianych, gdy usługa dla Agencji ustali, że zawartość może być nieaktualna (w przypadku np. tydzień). Dzięki temu będzie miała większą pewność, i otwierać nowe treści, nawet jeśli aplikacja nie była uruchamiana przez bardzo długi okres.

BroadcastReceiver trzeba skonfigurować na 2 sposoby:

  • Dynamicznie zarejestruj instancję klasy BroadcastReceiver za pomocą Context.registerReceiver() Umożliwia to komunikację z aplikacji które wciąż są żywe w pamięci.

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));

}
  • Statycznie deklaruj implementację z tagiem <receiver> w sekcji AndroidManifest.xml. Zezwala to aplikacji na odbieranie komunikatów intencje, gdy nie jest uruchomiona, oraz umożliwia publikowanie aplikacji treści.
<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>

Oto zamiary wysyłane przez usługa:

  • com.google.android.engage.action.PUBLISH_RECOMMENDATION Zalecane jest rozpoczęcie połączenia publishRecommendationClusters, gdy .
  • com.google.android.engage.action.PUBLISH_FEATURED Zalecane jest rozpoczęcie wywołania publishFeaturedCluster, gdy ta intencja jest odebrane.
  • com.google.android.engage.action.shopping.PUBLISH_SHOPPING_CART Zalecane jest rozpoczęcie wywołania publishShoppingCart, gdy ta intencja jest odebrane.
  • com.google.android.engage.action.shopping.PUBLISH_SHOPPING_LIST Zalecane jest rozpoczęcie wywołania publishShoppingList, gdy ta intencja jest odebrane.
  • com.google.android.engage.action.shopping.PUBLISH_REORDER_CLUSTER Zalecane jest rozpoczęcie wywołania publishReorderCluster, gdy ta intencja jest odebrane.
  • com.google.android.engage.action.shopping.PUBLISH_SHOPPING_ORDER_TRACKING_CLUSTER Zalecane jest rozpoczęcie połączenia publishShoppingOrderTrackingCluster, gdy i otrzymano tę intencję.

Proces integracji

Szczegółowy przewodnik dotyczący weryfikacji integracji po jej zakończeniu znajdziesz na stronie Przepływ pracy w zakresie integracji dla programistów

Najczęstsze pytania

Przeczytaj Najczęstsze pytania o pakiet SDK dla Agencji dotyczące: Najczęstsze pytania

Kontakt

Kontakt Engage-developers@google.com, jeśli są na ewentualne pytania w trakcie procesu integracji. Nasz zespół odpowiada jak to tylko możliwe.

Dalsze kroki

Po zakończeniu integracji należy wykonać następujące czynności:

  • Wyślij e-maila do engagement-developers@google.com i załącz zintegrowany pakiet APK gotowy do testowania przez Google.
  • Google przeprowadza wewnętrzną weryfikację i weryfikację, aby upewnić się, że jej integracja działa zgodnie z oczekiwaniami. Jeśli potrzebne będą zmiany, Google skontaktuje się z Tobą z niezbędnymi informacjami.
  • Gdy testy zostaną zakończone i nie trzeba będzie wprowadzać żadnych zmian, Google skontaktuje się z Tobą w sprawie: powiadomi Cię, że możesz rozpocząć publikowanie zaktualizowanego i zintegrowanego pliku APK w Sklep Play.
  • Gdy Google potwierdzi, że zaktualizowany pakiet APK został opublikowany w Sklep Play, Twoja Rekomendacja, Polecane, Koszyk, Lista zakupów, Zmień kolejność klastrów i Klaster śledzenia zamówień klastry mogą być opublikowane i widoczne dla użytkowników.