Zwiększaj zaangażowanie w aplikację, docierając do użytkowników tam, gdzie się znajdują. Wprowadź obsługę pakietu Engage SDK, aby dostarczać spersonalizowane rekomendacje i treści do kontynuacji bezpośrednio do użytkowników na różnych platformach na urządzeniu, takich jak Kolekcje, Entertainment Space i Sklep Play. Integracja dodaje do średniego pliku APK mniej niż 50 KB (po skompresowaniu) i zajmuje deweloperom większości aplikacji około tygodnia. Więcej informacji znajdziesz na naszej stronie dla firm.
Ten przewodnik zawiera instrukcje dla partnerów deweloperów dotyczące przesyłania treści związanych z podróżami i wydarzeniami do platformy Engage.
Szczegóły integracji
Terminologia
Ta integracja obejmuje te typy klastrów: Rekomendacje, Wyróżnione, Rezerwacja i Kontynuuj wyszukiwanie.
Klastry Rekomendacje zawierają spersonalizowane sugestie dotyczące podróży i wydarzeń od poszczególnych partnerów – deweloperów. Rekomendacje te mogą być spersonalizowane pod kątem użytkownika lub uogólnione (np. popularne produkty). Używaj ich do wyświetlania rekomendacji artykułów, wydarzeń, miejsc noclegowych lub miejsc wartych odwiedzenia.
- Klaster rekomendacji może składać się z
ArticleEntity
,EventEntity
,LodgingEntity
,PointOfInterestEntity
lubStoreEntity
wizytówek, ale nie z mieszanki różnych typów encji.
Rekomendacje mają następującą strukturę:
Klaster rekomendacji: widok interfejsu, który zawiera grupę rekomendacji od tego samego partnera dewelopera.
Jednostka: obiekt reprezentujący pojedynczy element w klastrze. Ta integracja udostępnia niektóre elementy, które byłyby wyświetlane w klastrze rekomendacji:
ArticleEntity: ArticleEntity reprezentuje rekomendację treści tekstowych związanych z podróżami i wydarzeniami. Można go używać w przypadku artykułów, postów na blogu, treści marketingowych, fragmentów wiadomości itp.
Ilustracja 1. Interfejs pokazujący pojedynczy element ArticleEntity w klastrze Rekomendacje. EventEntity: EventEntity reprezentuje wydarzenie, które odbędzie się w przyszłości. Czas rozpoczęcia wydarzenia to kluczowa informacja, którą należy przekazać użytkownikom.
Ilustracja 2. Interfejs pokazujący pojedynczy element EventEntity w klastrze rekomendacji. LodgingEntity: LodgingEntity reprezentuje obiekt noclegowy, taki jak hotel, apartament lub dom wakacyjny na wynajem krótkoterminowy i długoterminowy.
Rysunek 3. Interfejs pokazujący pojedynczy obiekt LodgingEntity w klastrze Rekomendacje. StoreEntity: StoreEntity reprezentuje sklep, restaurację, kawiarnię itp. Wyróżnia treści, w których lokal gastronomiczny lub sklep jest kluczową informacją, którą należy przekazać użytkownikom.
Ilustracja 4. Interfejs pokazujący pojedynczy element StoreEntity w klastrze rekomendacji. PointOfInterestEntity: PointOfInterestEntity reprezentuje miejsce, które może być interesujące dla użytkowników, np. stację benzynową, miejsce wydarzenia, park rozrywki, muzeum, atrakcję turystyczną, szlak turystyczny itp. Podkreśla treści, w których lokalizacja jest kluczową informacją, którą należy przekazać użytkownikom. Nie należy go używać w przypadku obiektów noclegowych, sklepów ani lokali gastronomicznych.
Rysunek 5. Interfejs pokazujący pojedynczy obiekt PointOfInterestEntity w klastrze Recommendations.
- Klaster rekomendacji może składać się z
Klaster Rezerwacja zawiera treści, z którymi ostatnio weszli w interakcję użytkownicy wielu partnerów deweloperów w jednej grupie interfejsu. Każdy partner-deweloper będzie mógł transmitować maksymalnie 10 podmiotów w klastrze Rezerwacja.
Treści rezerwacji mogą mieć taką strukturę:
RestaurantReservationEntity: RestaurantReservationEntity reprezentuje rezerwację w restauracji lub kawiarni i pomaga użytkownikom śledzić zbliżające się lub trwające rezerwacje w restauracjach.
Rysunek 6. Interfejs pokazujący pojedynczy element RestaurantReservationEntity w klastrze Reservation. EventReservationEntity: EventReservationEntity reprezentuje rezerwację wydarzenia i pomaga użytkownikom śledzić rezerwacje nadchodzących lub trwających wydarzeń. Wydarzenia mogą obejmować m.in.:
- Wydarzenia sportowe, np. rezerwacja miejsca na mecz piłki nożnej
- Wydarzenia związane z grami, np. rezerwacja miejsca na e-sport
- wydarzeń rozrywkowych, takich jak rezerwacja biletów na film w kinie, koncert, spektakl teatralny czy spotkanie autorskie;
- rezerwacje podróży lub miejsc, które Cię interesują, np. wycieczki z przewodnikiem czy bilety do muzeum;
- Rezerwacje miejsc na spotkania towarzyskie, seminaria i konferencje
- Rezerwacje sesji edukacyjnych lub szkoleniowych
Rysunek 7. Interfejs pokazujący pojedynczy element EventReservationEntity w klastrze Reservation. LodgingReservationEntity: LodgingEntityReservation reprezentuje rezerwację noclegu w podróży i pomaga użytkownikom śledzić nadchodzące lub trwające rezerwacje hoteli lub kwater wakacyjnych.
Rysunek 8. Interfejs użytkownika pokazujący pojedynczy element LodgingReservationEntity w klastrze Reservation. TransportationReservationEntity: TransportationReservationEntity reprezentuje rezerwację transportu dowolnym środkiem lokomocji i pomaga użytkownikom śledzić rezerwacje nadchodzących lub trwających lotów, promów, pociągów, autobusów, przejazdów taksówką lub rejsów.
Rysunek 9. Interfejs pokazujący pojedynczy element TransportationReservationEntity w klastrze Reservation. VehicleRentalReservationEntity: VehicleRentalReservationEntity reprezentuje rezerwację wynajmu pojazdu i pomaga użytkownikom śledzić nadchodzące lub trwające rezerwacje wynajmu pojazdów.
Rysunek 10. Interfejs użytkownika pokazujący pojedynczy element VehicleRentalReservationEntity w klastrze Reservation.
Klaster Polecane zawiera wybrane podmioty od różnych partnerów deweloperów w jednej grupie interfejsu. Będzie to pojedynczy klaster Wyróżnione, który będzie wyświetlany u góry interfejsu z priorytetowym umiejscowieniem nad wszystkimi klastrami rekomendacji. Każdy partner deweloper będzie mógł transmitować maksymalnie 10 podmiotów w klastrze Polecane.
GenericFeaturedEntity: GenericFeaturedEntity różni się od elementu rekomendacji tym, że element polecany powinien być używany w przypadku pojedynczych treści od deweloperów, które są najważniejsze i najbardziej interesujące dla użytkowników.
Rysunek 11. Interfejs pokazujący FeaturedCluster z listą GenericFeaturedEntity
Klaster Kontynuuj wyszukiwanie pomaga użytkownikom wznowić poprzednią ścieżkę wyszukiwania podróży, wyświetlając listę zapytań, które użytkownik ostatnio wyszukiwał we wszystkich aplikacjach do planowania podróży. Klaster będzie przypięty na drugiej pozycji, po klastrach rezerwacji, a przed klastrami polecanych i wyróżnionych treści. Każdy partner deweloper będzie mógł transmitować maksymalnie 3 podmioty w klastrze Kontynuuj wyszukiwanie.
- PointOfInterestEntity: PointOfInterestEntity reprezentuje miejsce, które może zainteresować użytkownika, np. stację benzynową, miejsce wydarzenia, park rozrywki, muzeum, atrakcję turystyczną, szlak turystyczny itp. Podkreśla treści, których użytkownik wcześniej szukał.
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'
}
Podsumowanie
Projekt opiera się na implementacji usługi powiązanej.
Dane, które klient może publikować, podlegają tym limitom w przypadku różnych typów klastrów:
Typ klastra | Limity klastra | Minimalne limity jednostek w klastrze | Maksymalne limity elementów w klastrze |
---|---|---|---|
Klastry rekomendacji | Maksymalnie 7 | Co najmniej 1 | Maksymalnie 50 (ArticleEntity , EventEntity ,LodgingEntity , StoreEntity lub PointOfInterestEntity ) |
Klaster rezerwacji | Maksymalnie 1 | Co najmniej 1 | Maksymalnie 20 znaków (RestaurantReservationEntity ,EventReservationEntity ,LodgingReservationEntity ,TransportationReservationEntity lubVehicleRentalReservationEntity ) |
Polecany klaster | Maksymalnie 1 | Co najmniej 1 | Maksymalnie 20 (GenericFeaturedEntity ) |
Kontynuuj wyszukiwanie klastra | Maksymalnie 1 | Co najmniej 1 | Maksymalnie 3 (PointOfInterestEntity ) |
Krok 1. Podaj dane podmiotu
Pakiet SDK ma zdefiniowane różne elementy reprezentujące każdy typ produktu. W przypadku kategorii Podróże i wydarzenia obsługujemy te typy danych:
GenericFeaturedEntity
ArticleEntity
EventEntity
LodgingEntity
StoreEntity
PointOfInterestEntity
RestaurantReservationEntity
EventReservationEntity
LodgingReservationEntity
TransportationReservationEntity
VehicleRentalReservationEntity
W tabelach poniżej znajdziesz listę dostępnych atrybutów i wymagań dla każdego typu.
GenericFeaturedEntity
Atrybut | Wymaganie | Opis | Format |
---|---|---|---|
Identyfikator URI działania | Wymagany |
Precyzyjny link do podmiotu w aplikacji dostawcy. Uwaga: precyzyjnych linków możesz używać do atrybucji. Zapoznaj się z odpowiedziami na najczęstsze pytania |
Identyfikator URI |
Obrazy plakatu | Wymagany | Jeśli podasz kilka obrazów, wyświetlimy tylko 1. Zalecany format obrazu to 16:9. Uwaga: jeśli podano plakietkę, zachowaj bezpieczną przestrzeń o wielkości 24 dp zarówno u góry, jak i u dołu obrazu. |
Więcej informacji znajdziesz w sekcji Specyfikacje obrazów. |
Tytuł | Opcjonalny | Nazwa elementu. | Dowolny tekst Zalecany rozmiar tekstu: 50 znaków |
Opis | Opcjonalny | Jeden akapit tekstu opisujący encję. Uwaga: użytkownikowi będzie wyświetlana lista opisów lub lista napisów, ale nie obie jednocześnie. |
Dowolny tekst Zalecany rozmiar tekstu: 180 znaków |
Lista podtytułów | Opcjonalny | Maksymalnie 3 napisy, każdy w jednym wierszu tekstu. Uwaga: użytkownikowi będzie wyświetlana lista opisów lub lista napisów, ale nie obie jednocześnie. |
Dowolny tekst Zalecany rozmiar tekstu każdego podtytułu: maks. 50 znaków |
Odznaki | Opcjonalny | Każda plakietka to tekst (maksymalnie 15 znaków) lub mały obraz. Specjalne traktowanie UX na obrazie lub filmie, np. jako nakładka w postaci plakietki na obrazie
|
|
Plakietka – tekst | Opcjonalny | Tytuł plakietki Uwaga: w przypadku plakietki wymagany jest tekst lub obraz. |
Dowolny tekst Zalecany rozmiar tekstu: maks. 15 znaków |
Plakietka – obraz | Opcjonalny | Mały obraz Specjalne traktowanie pod względem UX, np. nakładka w postaci plakietki na miniaturę obrazu lub filmu. Uwaga: w przypadku plakietki wymagany jest tekst lub obraz. |
Więcej informacji znajdziesz w sekcji Specyfikacje obrazów. |
Kategorie treści | Opcjonalny | Opisz kategorię treści w obiekcie. | Lista wartości w polu enum Wskazówki znajdziesz w sekcji Kategoria treści. |
DisplayTimeWindow (opcjonalnie) – ustaw przedział czasu, w którym treści mają być wyświetlane na platformie. | |||
Sygnatura czasowa rozpoczęcia | Opcjonalny |
Sygnatura czasowa epoki, po której treści powinny być wyświetlane na platformie. Jeśli nie jest ustawiona, treści mogą być wyświetlane w miejscu wyświetlania. |
Sygnatura czasowa epoki w milisekundach |
Sygnatura czasowa zakończenia | Opcjonalny |
Sygnatura czasowa epoki, po której treści nie będą już wyświetlane na platformie. Jeśli nie jest ustawiona, treści mogą być wyświetlane w miejscu wyświetlania. |
Sygnatura czasowa epoki w milisekundach |
ArticleEntity
Atrybut | Wymaganie | Opis | Format |
---|---|---|---|
Identyfikator URI działania | Wymagany |
Precyzyjny link do podmiotu w aplikacji dostawcy. Uwaga: precyzyjnych linków możesz używać do atrybucji. Zapoznaj się z odpowiedziami na najczęstsze pytania |
Identyfikator URI |
Tytuł | Wymagany | Nazwa elementu. | Dowolny tekst Zalecany rozmiar tekstu: maks. 50 znaków |
Obrazy plakatu | Opcjonalny | Jeśli podasz kilka obrazów, wyświetlimy tylko 1. Zalecany format obrazu to 16:9. Uwaga: zdecydowanie zalecamy dodanie obrazu. Jeśli podasz plakietkę, upewnij się, że u góry i u dołu obrazu jest bezpieczna przestrzeń o wielkości 24 dp. |
Więcej informacji znajdziesz w sekcji Specyfikacje obrazów. |
Źródło – tytuł | Opcjonalny | imię i nazwisko autora, nazwę organizacji lub imię i nazwisko reportera; | Dowolny tekst Zalecany rozmiar tekstu: poniżej 25 znaków |
Źródło – obraz | Opcjonalny | zdjęcie źródła, np. autora, organizacji lub reportera; | Więcej informacji znajdziesz w sekcji Specyfikacje obrazów. |
Opis | Opcjonalny | Jeden akapit tekstu opisujący encję. Uwaga: użytkownikowi będzie wyświetlana lista opisów lub lista napisów, ale nie obie jednocześnie. |
Dowolny tekst Zalecany rozmiar tekstu: 180 znaków |
Lista podtytułów | Opcjonalny | Maksymalnie 3 napisy, każdy w jednym wierszu tekstu. Uwaga: użytkownikowi będzie wyświetlana lista opisów lub lista napisów, ale nie obie jednocześnie. |
Dowolny tekst Zalecany rozmiar tekstu każdego podtytułu: maks. 50 znaków |
Odznaki | Opcjonalny | Każda plakietka to tekst (maksymalnie 15 znaków) lub mały obraz. Specjalne traktowanie UX na obrazie lub filmie, np. jako nakładka w postaci plakietki na obrazie.
|
|
Plakietka – tekst | Opcjonalny | Tytuł plakietki Uwaga: w przypadku plakietki wymagany jest tekst lub obraz. |
Dowolny tekst Zalecany rozmiar tekstu: maks. 15 znaków |
Plakietka – obraz | Opcjonalny | Mały obraz Specjalne traktowanie pod względem UX, np. nakładka w postaci plakietki na miniaturę obrazu lub filmu. Uwaga: w przypadku plakietki wymagany jest tekst lub obraz. |
Więcej informacji znajdziesz w sekcji Specyfikacje obrazów. |
Czas publikacji treści | Opcjonalny | Jest to sygnatura czasowa w milisekundach, która określa, kiedy treść została opublikowana lub zaktualizowana w aplikacji. | Sygnatura czasowa epoki w milisekundach |
Czas ostatniego działania związanego z zaangażowaniem | Opcjonalny | Sygnatura czasowa epoki w milisekundach, kiedy użytkownik ostatnio wchodził w interakcję z tym elementem. |
Sygnatura czasowa epoki w milisekundach |
Procent postępu | Opcjonalny | Procent pełnej treści, który użytkownik wykorzystał do tej pory. |
Liczba całkowita z zakresu od 0 do 100 (włącznie). |
Kategorie treści | Opcjonalny | Opisz kategorię treści w obiekcie. | Lista wartości w polu enum Wskazówki znajdziesz w sekcji Kategoria treści. |
DisplayTimeWindow (opcjonalnie) – ustaw przedział czasu, w którym treści mają być wyświetlane na platformie. | |||
Sygnatura czasowa rozpoczęcia | Opcjonalny |
Sygnatura czasowa epoki, po której treści powinny być wyświetlane na platformie. Jeśli nie jest ustawiona, treści mogą być wyświetlane w miejscu wyświetlania. |
Sygnatura czasowa epoki w milisekundach |
Sygnatura czasowa zakończenia | Opcjonalny |
Sygnatura czasowa epoki, po której treści nie będą już wyświetlane na platformie. Jeśli nie jest ustawiona, treści mogą być wyświetlane w miejscu wyświetlania. |
Sygnatura czasowa epoki w milisekundach |
EventEntity
Atrybut | Wymaganie | Opis | Format |
---|---|---|---|
Identyfikator URI działania | Wymagany |
Precyzyjny link do podmiotu w aplikacji dostawcy. Uwaga: precyzyjnych linków możesz używać do atrybucji. Zapoznaj się z odpowiedziami na najczęstsze pytania |
Identyfikator URI |
Tytuł | Wymagany | Nazwa elementu. | Ciąg znaków Zalecany rozmiar tekstu: maks. 50 znaków |
Zlokalizowany czas rozpoczęcia – sygnatura czasowa | Wymagany |
Sygnatura czasowa w formacie epoki, kiedy ma się rozpocząć wydarzenie. |
Joda-Time Instant |
Zlokalizowany czas rozpoczęcia – strefa czasowa | Wymagany |
Strefa czasowa, w której ma się rozpocząć wydarzenie. |
Joda-Time DateTimeZone Wskazówki znajdziesz w specyfikacjach stref czasowych. |
Tryb zdarzenia | Wymagany | Pole wskazujące, czy wydarzenie będzie wirtualne, stacjonarne czy w obu formach. |
Enum: VIRTUAL, IN_PERSON lub HYBRID |
Obrazy plakatu | Wymagany | Jeśli podasz kilka obrazów, wyświetlimy tylko 1. Zalecany format obrazu to 16:9. Uwaga: zdecydowanie zalecamy dodanie obrazu. Jeśli podasz plakietkę, upewnij się, że u góry i u dołu obrazu jest bezpieczna przestrzeń o wielkości 24 dp. |
Więcej informacji znajdziesz w sekcji Specyfikacje obrazów. |
Lokalizacja – kraj | Wymagane warunkowo | Kraj, w którym odbywa się wydarzenie. Uwaga: jest to wymagane w przypadku wydarzeń, które odbywają się OSOBIŚCIE lub HYBRYDOWO. |
Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Lokalizacja – miasto | Wymagane warunkowo | Miasto, w którym odbywa się wydarzenie. Uwaga: jest to wymagane w przypadku wydarzeń, które odbywają się OSOBIŚCIE lub HYBRYDOWO. |
Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Lokalizacja – wyświetlany adres | Wymagane warunkowo | Adres lub nazwa miejsca, w którym odbędzie się wydarzenie, które powinny być wyświetlane użytkownikowi. Uwaga: jest to wymagane w przypadku wydarzeń, które odbywają się OSOBIŚCIE lub HYBRYDOWO. |
Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Lokalizacja – adres | Opcjonalny | Adres ulicy (w odpowiednich przypadkach) miejsca, w którym odbywa się wydarzenie. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Lokalizacja – stan | Opcjonalny | Stan lub województwo (jeśli ma zastosowanie), w którym odbywa się wydarzenie. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Lokalizacja – kod pocztowy | Opcjonalny | Kod pocztowy (jeśli występuje) lokalizacji, w której odbywa się wydarzenie. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Lokalizacja – dzielnica | Opcjonalny | Dzielnica (w stosownych przypadkach), w której odbywa się wydarzenie. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Godzina zakończenia | Opcjonalny |
Sygnatura czasowa w formacie epoki, kiedy wydarzenie ma się zakończyć. Uwaga: ta wartość będzie podana w milisekundach. |
Sygnatura czasowa epoki w milisekundach |
Opis | Opcjonalny | Jeden akapit tekstu opisujący encję. Uwaga: użytkownikowi będzie wyświetlana lista opisów lub lista napisów, ale nie obie jednocześnie. |
Dowolny tekst Zalecany rozmiar tekstu: 180 znaków |
Lista podtytułów | Opcjonalny | Maksymalnie 3 napisy, każdy w jednym wierszu tekstu. Uwaga: użytkownikowi będzie wyświetlana lista opisów lub lista napisów, ale nie obie jednocześnie. |
Dowolny tekst Zalecany rozmiar tekstu każdego podtytułu: maks. 50 znaków |
Odznaki | Opcjonalny |
Każda plakietka to tekst (maksymalnie 15 znaków) lub mały obraz. |
|
Plakietka – tekst | Opcjonalny | Tytuł plakietki Uwaga: w przypadku plakietki wymagany jest tekst lub obraz. |
Dowolny tekst Zalecany rozmiar tekstu: maks. 15 znaków |
Plakietka – obraz | Opcjonalny | Mały obraz Specjalne traktowanie pod względem UX, np. nakładka w postaci plakietki na miniaturę obrazu lub filmu. Uwaga: w przypadku plakietki wymagany jest tekst lub obraz. |
Więcej informacji znajdziesz w sekcji Specyfikacje obrazów. |
Cena – CurrentPrice | Wymagane warunkowo |
Aktualna cena biletu na wydarzenie. Musisz podać cenę, jeśli podasz cenę przekreśloną. |
Dowolny tekst |
Cena – StrikethroughPrice | Opcjonalny | Pierwotna cena biletu na wydarzenie. | Dowolny tekst |
Objaśnienie dotyczące ceny | Opcjonalny | Wywołanie ceny, aby wyróżnić promocję, wydarzenie lub rabat dla uczestników programu (jeśli są dostępne). | Dowolny tekst Zalecany rozmiar tekstu: poniżej 45 znaków (zbyt długi tekst może być wyświetlany z wielokropkiem) |
Kategorie treści | Opcjonalny | Opisz kategorię treści w obiekcie. | Lista kwalifikujących się typów wyliczeniowych
Wskazówki znajdziesz w sekcji Kategoria treści. |
DisplayTimeWindow (opcjonalnie) – ustaw przedział czasu, w którym treści mają być wyświetlane na platformie. | |||
Sygnatura czasowa rozpoczęcia | Opcjonalny |
Sygnatura czasowa epoki, po której treści powinny być wyświetlane na platformie. Jeśli nie jest ustawiona, treści mogą być wyświetlane w miejscu wyświetlania. |
Sygnatura czasowa epoki w milisekundach |
Sygnatura czasowa zakończenia | Opcjonalny |
Sygnatura czasowa epoki, po której treści nie będą już wyświetlane na platformie. Jeśli nie jest ustawiona, treści mogą być wyświetlane w miejscu wyświetlania. |
Sygnatura czasowa epoki w milisekundach |
LodgingEntity
Atrybut | Wymaganie | Opis | Format |
---|---|---|---|
Identyfikator URI działania | Wymagany |
Precyzyjny link do podmiotu w aplikacji dostawcy. Uwaga: precyzyjnych linków możesz używać do atrybucji. Zapoznaj się z odpowiedziami na najczęstsze pytania |
Identyfikator URI |
Tytuł | Wymagany | Nazwa elementu. | Ciąg znaków Zalecany rozmiar tekstu: maks. 50 znaków |
Obrazy plakatu | Wymagany |
Jeśli podasz kilka obrazów, wyświetlimy tylko 1. Zalecany format obrazu to 16:9. Uwaga: jeśli podano plakietkę, upewnij się, że na górze i na dole obrazu jest bezpieczna przestrzeń o wielkości 24 dp. |
Więcej informacji znajdziesz w sekcji Specyfikacje obrazów. |
Lokalizacja – kraj | Wymagany | Kraj, w którym znajduje się obiekt noclegowy. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Lokalizacja – miasto | Wymagany | Miasto, w którym znajduje się obiekt noclegowy. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Lokalizacja – wyświetlany adres | Wymagany | Adres, który będzie wyświetlany użytkownikowi. W większości przypadków zalecamy podanie nazwy miasta, a także stanu lub kraju. Podawaj tylko adres lub nazwę dzielnicy, jeśli użytkownik znajduje się w pobliżu lokalizacji, zna ją lub miasto jest uwzględnione w tytule klastra. Jeśli podajesz adres, użyj skróconej formy, stosując w miarę możliwości skróty (np. „ul.” zamiast „ulica”, „al.” zamiast „aleja”). | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Lokalizacja – adres | Opcjonalny | Adres (jeśli dotyczy) obiektu noclegowego. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Lokalizacja – stan | Opcjonalny | Stan lub województwo (jeśli ma zastosowanie), w którym znajduje się obiekt. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Lokalizacja – kod pocztowy | Opcjonalny | Kod pocztowy (jeśli występuje) obiektu noclegowego. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Lokalizacja – dzielnica | Opcjonalny | Okolica (w odpowiednich przypadkach), w której znajduje się obiekt noclegowy. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Odznaki | Opcjonalny |
Każda plakietka to tekst (maksymalnie 15 znaków) lub mały obraz. |
|
Plakietka – tekst | Opcjonalny | Tytuł plakietki Uwaga: w przypadku plakietki wymagany jest tekst lub obraz. |
Dowolny tekst Zalecany rozmiar tekstu: maks. 15 znaków |
Plakietka – obraz | Opcjonalny | Mały obraz Specjalne traktowanie pod względem UX, np. nakładka w postaci plakietki na miniaturę obrazu lub filmu. Uwaga: w przypadku plakietki wymagany jest tekst lub obraz. |
Więcej informacji znajdziesz w sekcji Specyfikacje obrazów. |
Opis | Opcjonalny | Jeden akapit tekstu opisujący encję. Uwaga: użytkownikowi będzie wyświetlana lista opisów lub lista napisów, ale nie obie jednocześnie. |
Dowolny tekst Zalecany rozmiar tekstu: 180 znaków |
Lista podtytułów | Opcjonalny | Maksymalnie 3 napisy, każdy w jednym wierszu tekstu. Uwaga: użytkownikowi będzie wyświetlana lista opisów lub lista napisów, ale nie obie jednocześnie. |
Dowolny tekst Zalecany rozmiar tekstu każdego podtytułu: maks. 50 znaków |
AvailabilityTimeWindow - Localized Start Time - Timestamp | Opcjonalny | Sygnatura czasowa epoki, kiedy obiekt noclegowy ma być otwarty lub dostępny. | Joda-Time Instant |
AvailabilityTimeWindow - Localized Start Time - Timezone | Opcjonalny | Strefa czasowa, w której obiekt noclegowy ma być otwarty lub dostępny. |
Joda-Time DateTimeZone Wskazówki znajdziesz w specyfikacjach stref czasowych. |
AvailabilityTimeWindow - Localized End Time - Timestamp | Opcjonalny | Sygnatura czasowa w formacie epoki, do której obiekt noclegowy ma być otwarty lub dostępny. | Joda-Time Instant |
AvailabilityTimeWindow - Localized End Time - Timezone | Opcjonalny | Strefa czasowa, w której obiekt noclegowy ma być otwarty lub dostępny. |
Joda-Time DateTimeZone Wskazówki znajdziesz w specyfikacjach stref czasowych. |
Ocena – wartość maksymalna | Opcjonalny | Maksymalna wartość skali oceny. Musisz podać tę wartość, jeśli podasz też aktualną ocenę. |
Liczba >= 0,0 |
Ocena – bieżąca wartość | Opcjonalny | Bieżąca wartość skali ocen. Musisz podać tę wartość, jeśli podasz też maksymalną wartość oceny. |
Liczba >= 0,0 |
Ocena – liczba | Opcjonalny | Liczba ocen obiektu noclegowego. Uwaga: podaj to pole, jeśli chcesz kontrolować sposób wyświetlania tej informacji użytkownikom. Podaj zwięzły ciąg znaków, który może być wyświetlany użytkownikowi. Jeśli np. liczba wynosi 1 000 000, użyj skrótu 1M, aby nie została obcięta na mniejszych ekranach. |
Ciąg znaków |
Ocena – wartość liczby | Opcjonalny | Liczba ocen obiektu noclegowego. Uwaga: podaj wartość w tym polu, jeśli nie chcesz samodzielnie obsługiwać logiki skracania wyświetlanych wartości. Jeśli występują zarówno wartość Count, jak i Count Value, użytkownikom wyświetlimy wartość Count. |
Długie |
Cena – CurrentPrice | Wymagane warunkowo | Obecna cena obiektu. Musisz podać tę wartość, jeśli podasz cenę przekreśloną. |
Dowolny tekst |
Cena – StrikethroughPrice | Opcjonalny | Pierwotna cena obiektu noclegowego, która będzie przekreślona w interfejsie. | Dowolny tekst |
Objaśnienie dotyczące ceny | Opcjonalny | Wywołanie ceny, aby wyróżnić promocję, wydarzenie lub rabat dla uczestników programu (jeśli są dostępne). | Dowolny tekst Zalecany rozmiar tekstu: poniżej 45 znaków (zbyt długi tekst może być wyświetlany z wielokropkiem) |
DisplayTimeWindow (opcjonalnie) – ustaw przedział czasu, w którym treści mają być wyświetlane na platformie. | |||
Sygnatura czasowa rozpoczęcia | Opcjonalny |
Sygnatura czasowa epoki, po której treści powinny być wyświetlane na platformie. Jeśli nie jest ustawiona, treści mogą być wyświetlane w miejscu wyświetlania. |
Sygnatura czasowa epoki w milisekundach |
Sygnatura czasowa zakończenia | Opcjonalny |
Sygnatura czasowa epoki, po której treści nie będą już wyświetlane na platformie. Jeśli nie jest ustawiona, treści mogą być wyświetlane w miejscu wyświetlania. |
Sygnatura czasowa epoki w milisekundach |
StoreEntity
Obiekt StoreEntity
reprezentuje pojedynczy sklep, który partnerzy deweloperzy chcą opublikować, np. popularne miejsce do jedzenia, które jest istotne dla podróżujących.
Atrybut | Wymaganie | Opis | Format |
---|---|---|---|
Obrazy plakatu | Wymagany | Musisz podać co najmniej 1 obraz. | Więcej informacji znajdziesz w sekcji Specyfikacje obrazów. |
Identyfikator URI działania | Wymagany |
Precyzyjny link do podmiotu w aplikacji dostawcy. Uwaga: precyzyjnych linków możesz używać do atrybucji. Zapoznaj się z odpowiedziami na najczęstsze pytania |
Identyfikator URI |
Tytuł | Opcjonalny | Nazwa sklepu. | Dowolny tekst Zalecany rozmiar tekstu: poniżej 45 znaków (zbyt długi tekst może być skrócony do wielokropka) |
Lokalizacja | Opcjonalny | Lokalizacja sklepu. | Dowolny tekst Zalecany rozmiar tekstu: poniżej 45 znaków (zbyt długi tekst może być skrócony do wielokropka) |
Objaśnienie | Opcjonalny | Wywołanie, które wyróżnia promocję, wydarzenie lub aktualizację w sklepie, jeśli jest dostępne. | Dowolny tekst Zalecany rozmiar tekstu: poniżej 45 znaków (zbyt długi tekst może być skrócony do wielokropka) |
Drobny druk objaśnienia | Opcjonalny | Tekst drobnego druku objaśnienia. | Dowolny tekst Zalecany rozmiar tekstu: poniżej 45 znaków (zbyt długi tekst może być skrócony do wielokropka) |
Opis | Opcjonalny | Opis sklepu. | Dowolny tekst Zalecany rozmiar tekstu: poniżej 90 znaków (zbyt długi tekst może być skrócony do wielokropka). |
Kategoria | Opcjonalny | Kategoria sklepu. W przypadku lokali gastronomicznych może to być rodzaj kuchni, np. „francuska”, „nowa amerykańska”, „ramen”, „elegancka restauracja”. |
Dowolny tekst Zalecany rozmiar tekstu: poniżej 45 znaków (zbyt długi tekst może być skrócony do wielokropka) |
Ocena – wartość maksymalna | Opcjonalny | Maksymalna wartość skali oceny. Musisz podać tę wartość, jeśli podasz też aktualną ocenę. |
Liczba >= 0,0 |
Ocena – bieżąca wartość | Opcjonalny | Bieżąca wartość skali ocen. Musisz podać tę wartość, jeśli podasz też maksymalną wartość oceny. |
Liczba >= 0,0 |
Ocena – liczba | Opcjonalny | Liczba ocen obiektu noclegowego. Uwaga: podaj to pole, jeśli chcesz kontrolować sposób wyświetlania tej informacji użytkownikom. Podaj zwięzły ciąg znaków, który może być wyświetlany użytkownikowi. Jeśli np. liczba wynosi 1 000 000, użyj skrótu 1M, aby nie została obcięta na mniejszych ekranach. |
Ciąg znaków |
Ocena – wartość liczby | Opcjonalny | Liczba ocen obiektu noclegowego. Uwaga: podaj wartość w tym polu, jeśli nie chcesz samodzielnie obsługiwać logiki skracania wyświetlanych wartości. Jeśli występują zarówno wartość Count, jak i Count Value, użytkownikom wyświetlimy wartość Count. |
Długie |
DisplayTimeWindow (opcjonalnie) – ustaw przedział czasu, w którym treści mają być wyświetlane na platformie. | |||
Sygnatura czasowa rozpoczęcia | Opcjonalny |
Sygnatura czasowa epoki, po której treści powinny być wyświetlane na platformie. Jeśli nie jest ustawiona, treści mogą być wyświetlane w miejscu wyświetlania. |
Sygnatura czasowa epoki w milisekundach |
Sygnatura czasowa zakończenia | Opcjonalny |
Sygnatura czasowa epoki, po której treści nie będą już wyświetlane na platformie. Jeśli nie jest ustawiona, treści mogą być wyświetlane w miejscu wyświetlania. |
Sygnatura czasowa epoki w milisekundach |
PointOfInterestEntity
Atrybut | Wymaganie | Opis | Format |
---|---|---|---|
Identyfikator URI działania | Wymagany |
Precyzyjny link do podmiotu w aplikacji dostawcy. Uwaga: precyzyjnych linków możesz używać do atrybucji. Zapoznaj się z odpowiedziami na najczęstsze pytania |
Identyfikator URI |
Tytuł | Wymagany | Nazwa elementu. | Ciąg znaków Zalecany rozmiar tekstu: maks. 50 znaków |
Obrazy plakatu | Wymagane warunkowo |
Jeśli podasz kilka obrazów, wyświetlimy tylko 1. Zalecany format obrazu to 16:9. Uwaga: obraz jest wymagany, jeśli podmiot należy do klastra rekomendacji. Jeśli podasz plakietkę, upewnij się, że u góry i u dołu obrazu znajduje się bezpieczny obszar o wielkości 24 dp. |
Więcej informacji znajdziesz w sekcji Specyfikacje obrazów. |
Czas ostatniego działania związanego z zaangażowaniem | Wymagane warunkowo |
Sygnatura czasowa w formacie epoki, która wskazuje, kiedy użytkownik ostatnio wszedł w interakcję z tym elementem. Uwaga: to pole jest wymagane, jeśli podmiot należy do klastra wyszukiwania kontynuowanego. |
Joda-Time Instant |
Lokalizacja – kraj | Wymagane warunkowo |
Kraj, w którym znajduje się ciekawe miejsce. Uwaga: to pole jest wymagane, jeśli element należy do klastra rekomendacji. |
Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Lokalizacja – miasto | Wymagane warunkowo |
Miasto, w którym znajduje się interesujące miejsce. Uwaga: to pole jest wymagane, jeśli element należy do klastra rekomendacji. |
Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Lokalizacja – wyświetlany adres | Wymagane warunkowo |
Adres, który będzie wyświetlany użytkownikowi. Podaj zwięzły adres, używając w miarę możliwości skrótów (np. „St” zamiast „Street”, „Ave” zamiast „Avenue”). Ten ciąg znaków może zostać skrócony w zależności od urządzenia i ustawień użytkownika. Podaj nazwę miasta, aby ułatwić identyfikację. Uwaga: to pole jest wymagane, jeśli element należy do klastra rekomendacji. |
Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 35 znaków |
Lokalizacja – adres | Opcjonalny | Adres ulicy (w odpowiednich przypadkach) ciekawego miejsca. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Lokalizacja – stan | Opcjonalny | Stan lub województwo (jeśli ma zastosowanie), w którym znajduje się punkt orientacyjny. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Lokalizacja – kod pocztowy | Opcjonalny | Kod pocztowy (jeśli występuje) danego miejsca. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Lokalizacja – dzielnica | Opcjonalny | Okolica (jeśli występuje), w której znajduje się dany punkt. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
AvailabilityTimeWindow - Localized Start Time - Timestamp | Opcjonalny | Sygnatura czasowa epoki, kiedy punkt orientacyjny ma być otwarty lub dostępny. | Joda-Time Instant |
AvailabilityTimeWindow - Localized Start Time - Timezone | Opcjonalny | Strefa czasowa, w której punkt orientacyjny powinien być otwarty lub dostępny. |
Joda-Time DateTimeZone Wskazówki znajdziesz w specyfikacjach stref czasowych. |
AvailabilityTimeWindow - Localized End Time - Timestamp | Opcjonalny | Sygnatura czasowa w formacie epoki, do której punkt orientacyjny powinien być otwarty lub dostępny. | Joda-Time Instant |
AvailabilityTimeWindow - Localized End Time - Timezone | Opcjonalny | Strefa czasowa, w której punkt orientacyjny powinien być otwarty lub dostępny. |
Joda-Time DateTimeZone Wskazówki znajdziesz w specyfikacjach stref czasowych. |
Odznaki | Opcjonalny |
Każda plakietka to tekst (maksymalnie 15 znaków) lub mały obraz. |
|
Plakietka – tekst | Opcjonalny | Tytuł plakietki Uwaga: w przypadku plakietki wymagany jest tekst lub obraz. |
Dowolny tekst Zalecany rozmiar tekstu: maks. 15 znaków |
Plakietka – obraz | Opcjonalny | Mały obraz Specjalne traktowanie pod względem UX, np. nakładka w postaci plakietki na miniaturę obrazu lub filmu. Uwaga: w przypadku plakietki wymagany jest tekst lub obraz. |
Więcej informacji znajdziesz w sekcji Specyfikacje obrazów. |
Opis | Opcjonalny | Jeden akapit tekstu opisujący encję. Uwaga: użytkownikowi będzie wyświetlana lista opisów lub lista napisów, ale nie obie jednocześnie. |
Dowolny tekst Zalecany rozmiar tekstu: 180 znaków |
Lista podtytułów | Opcjonalny | Maksymalnie 3 napisy, każdy w jednym wierszu tekstu. Uwaga: użytkownikowi będzie wyświetlana lista opisów lub lista napisów, ale nie obie jednocześnie. |
Dowolny tekst Zalecany rozmiar tekstu każdego podtytułu: maks. 50 znaków |
Ocena – wartość maksymalna | Opcjonalny | Maksymalna wartość skali oceny. Musisz podać tę wartość, jeśli podasz też aktualną ocenę. |
Liczba >= 0,0 |
Ocena – bieżąca wartość | Opcjonalny | Bieżąca wartość skali ocen. Musisz podać tę wartość, jeśli podasz też maksymalną wartość oceny. |
Liczba >= 0,0 |
Ocena – liczba | Opcjonalny | Liczba ocen ciekawego miejsca. Uwaga: podaj to pole, jeśli chcesz kontrolować sposób wyświetlania tej informacji użytkownikom. Podaj zwięzły ciąg znaków, który może być wyświetlany użytkownikowi. Jeśli np. liczba wynosi 1 000 000, użyj skrótu 1M, aby nie została obcięta na mniejszych ekranach. |
Ciąg znaków |
Ocena – wartość liczby | Opcjonalny | Liczba ocen ciekawego miejsca. Uwaga: podaj wartość w tym polu, jeśli nie chcesz samodzielnie obsługiwać logiki skracania wyświetlanych wartości. Jeśli występują zarówno wartość Count, jak i Count Value, użytkownikom wyświetlimy wartość Count. |
Długie |
Cena – CurrentPrice | Wymagane warunkowo |
Aktualna cena biletów lub karnetów do danego miejsca. Musisz podać cenę, jeśli podasz cenę przekreśloną. |
Dowolny tekst |
Cena – StrikethroughPrice | Opcjonalny | Pierwotna cena biletów lub karnetu do atrakcji. | Dowolny tekst |
Objaśnienie dotyczące ceny | Opcjonalny | Wywołanie ceny, aby wyróżnić promocję, wydarzenie lub rabat dla uczestników programu (jeśli są dostępne). |
Dowolny tekst Zalecany rozmiar tekstu: poniżej 45 znaków (zbyt długi tekst może być wyświetlany z wielokropkiem) |
Kategorie treści | Opcjonalny | Opisz kategorię treści w obiekcie. | Lista kwalifikujących się typów wyliczeniowych
Wskazówki znajdziesz w sekcji Kategoria treści. |
DisplayTimeWindow (opcjonalnie) – ustaw przedział czasu, w którym treści mają być wyświetlane na platformie. | |||
Sygnatura czasowa rozpoczęcia | Opcjonalny |
Sygnatura czasowa epoki, po której treści powinny być wyświetlane na platformie. Jeśli nie jest ustawiona, treści mogą być wyświetlane w miejscu wyświetlania. |
Sygnatura czasowa epoki w milisekundach |
Sygnatura czasowa zakończenia | Opcjonalny |
Sygnatura czasowa epoki, po której treści nie będą już wyświetlane na platformie. Jeśli nie jest ustawiona, treści mogą być wyświetlane w miejscu wyświetlania. |
Sygnatura czasowa epoki w milisekundach |
RestaurantReservationEntity
Atrybut | Wymaganie | Opis | Format |
---|---|---|---|
Identyfikator URI działania | Wymagany |
Precyzyjny link do podmiotu w aplikacji dostawcy. Uwaga: precyzyjnych linków możesz używać do atrybucji. Zapoznaj się z odpowiedziami na najczęstsze pytania |
Identyfikator URI |
Tytuł | Wymagany | Nazwa elementu. | Ciąg znaków Zalecany rozmiar tekstu: maks. 50 znaków |
Zlokalizowany czas rozpoczęcia rezerwacji – sygnatura czasowa | Wymagany | Sygnatura czasowa epoki, kiedy ma się rozpocząć rezerwacja. | Joda-Time Instant |
Zlokalizowany czas rozpoczęcia rezerwacji – strefa czasowa | Wymagany | Strefa czasowa, w której ma się rozpocząć rezerwacja. |
Joda-Time DateTimeZone Wskazówki znajdziesz w specyfikacjach stref czasowych. |
Lokalizacja – kraj | Wymagany | Kraj, w którym znajduje się restauracja. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Lokalizacja – miasto | Wymagany | Miasto, w którym znajduje się restauracja. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Lokalizacja – wyświetlany adres | Wymagany | Adres restauracji, który będzie wyświetlany użytkownikowi. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Lokalizacja – adres | Opcjonalny | Adres pocztowy restauracji (w odpowiednich przypadkach). | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Lokalizacja – stan | Opcjonalny | Stan lub województwo (jeśli ma zastosowanie), w którym znajduje się restauracja. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Lokalizacja – kod pocztowy | Opcjonalny | Kod pocztowy restauracji (jeśli występuje). | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Lokalizacja – dzielnica | Opcjonalny | Okolica (jeśli dotyczy), w której znajduje się restauracja. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Obrazy plakatu | Opcjonalny | Jeśli podasz kilka obrazów, wyświetlimy tylko 1. Zalecany format obrazu to 16:9. | Więcej informacji znajdziesz w sekcji Specyfikacje obrazów. |
Opis | Opcjonalny | Jeden akapit tekstu opisujący encję. Uwaga: użytkownikowi będzie wyświetlana lista opisów lub lista napisów, ale nie obie jednocześnie. |
Dowolny tekst Zalecany rozmiar tekstu: 180 znaków |
Lista podtytułów | Opcjonalny | Maksymalnie 3 napisy, każdy w jednym wierszu tekstu. Uwaga: użytkownikowi będzie wyświetlana lista opisów lub lista napisów, ale nie obie jednocześnie. |
Dowolny tekst Zalecany rozmiar tekstu każdego podtytułu: maks. 50 znaków |
Wielkość tabeli | Opcjonalny | Liczba osób w grupie rezerwacji | Liczba całkowita > 0 |
DisplayTimeWindow (opcjonalnie) – ustaw przedział czasu, w którym treści mają być wyświetlane na platformie. | |||
Sygnatura czasowa rozpoczęcia | Opcjonalny |
Sygnatura czasowa epoki, po której treści powinny być wyświetlane na platformie. Jeśli nie jest ustawiona, treści mogą być wyświetlane w miejscu wyświetlania. |
Sygnatura czasowa epoki w milisekundach |
Sygnatura czasowa zakończenia | Opcjonalny |
Sygnatura czasowa epoki, po której treści nie będą już wyświetlane na platformie. Jeśli nie jest ustawiona, treści mogą być wyświetlane w miejscu wyświetlania. |
Sygnatura czasowa epoki w milisekundach |
EventReservationEntity
Atrybut | Wymaganie | Opis | Format |
---|---|---|---|
Identyfikator URI działania | Wymagany |
Precyzyjny link do podmiotu w aplikacji dostawcy. Uwaga: precyzyjnych linków możesz używać do atrybucji. Zapoznaj się z odpowiedziami na najczęstsze pytania |
Identyfikator URI |
Tytuł | Wymagany | Nazwa elementu. | Ciąg znaków Zalecany rozmiar tekstu: maks. 50 znaków |
Zlokalizowany czas rozpoczęcia – sygnatura czasowa | Wymagany |
Sygnatura czasowa w formacie epoki, kiedy ma się rozpocząć wydarzenie. |
Joda-Time Instant |
Zlokalizowany czas rozpoczęcia – strefa czasowa | Wymagany |
Strefa czasowa, w której ma się rozpocząć wydarzenie. |
Joda-Time DateTimeZone Wskazówki znajdziesz w specyfikacjach stref czasowych. |
Tryb zdarzenia | Wymagany | Pole wskazujące, czy wydarzenie będzie wirtualne, stacjonarne czy w obu formach. |
Enum: VIRTUAL, IN_PERSON lub HYBRID |
Lokalizacja – kraj | Wymagane warunkowo | Kraj, w którym odbywa się wydarzenie. Uwaga: jest to wymagane w przypadku wydarzeń, które odbywają się OSOBIŚCIE lub HYBRYDOWO. |
Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Lokalizacja – miasto | Wymagane warunkowo | Miasto, w którym odbywa się wydarzenie. Uwaga: jest to wymagane w przypadku wydarzeń, które odbywają się OSOBIŚCIE lub HYBRYDOWO. |
Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Lokalizacja – wyświetlany adres | Wymagane warunkowo | Adres lub nazwa miejsca, w którym odbędzie się wydarzenie, które powinny być wyświetlane użytkownikowi. Uwaga: jest to wymagane w przypadku wydarzeń, które odbywają się OSOBIŚCIE lub HYBRYDOWO. |
Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Lokalizacja – adres | Opcjonalny | Adres ulicy (w odpowiednich przypadkach) miejsca, w którym odbywa się wydarzenie. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Lokalizacja – stan | Opcjonalny | Stan lub województwo (jeśli ma zastosowanie), w którym odbywa się wydarzenie. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Lokalizacja – kod pocztowy | Opcjonalny | Kod pocztowy (jeśli występuje) lokalizacji, w której odbywa się wydarzenie. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Lokalizacja – dzielnica | Opcjonalny | Dzielnica (w stosownych przypadkach), w której odbywa się wydarzenie. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Obrazy plakatu | Opcjonalny | Jeśli podasz kilka obrazów, wyświetlimy tylko 1. Zalecany format obrazu to 16:9. Uwaga: zdecydowanie zalecamy dodanie obrazu. Jeśli podasz plakietkę, upewnij się, że u góry i u dołu obrazu jest bezpieczna przestrzeń o wielkości 24 dp. |
Więcej informacji znajdziesz w sekcji Specyfikacje obrazów. |
Zlokalizowany czas zakończenia – sygnatura czasowa | Opcjonalny |
Sygnatura czasowa w formacie epoki, kiedy wydarzenie ma się zakończyć. |
Joda-Time Instant |
Zlokalizowany czas zakończenia – strefa czasowa | Opcjonalny |
Strefa czasowa, w której ma się zakończyć wydarzenie. |
Joda-Time DateTimeZone Wskazówki znajdziesz w specyfikacjach stref czasowych. |
Dostawca usług – nazwa | Opcjonalny |
Nazwa dostawcy usługi. Uwaga: w przypadku usługodawcy wymagany jest tekst lub obraz. |
Dowolny tekst. np. nazwa organizatora wydarzenia lub wycieczki. |
Usługodawca – obraz | Opcjonalny |
Logo lub obraz usługodawcy. Uwaga: w przypadku usługodawcy wymagany jest tekst lub obraz. |
Więcej informacji znajdziesz w sekcji Specyfikacje obrazów. |
Opis | Opcjonalny | Jeden akapit tekstu opisujący encję. Uwaga: użytkownikowi będzie wyświetlana lista opisów lub lista napisów, ale nie obie jednocześnie. |
Dowolny tekst Zalecany rozmiar tekstu: 180 znaków |
Lista podtytułów | Opcjonalny | Maksymalnie 3 napisy, każdy w jednym wierszu tekstu. Uwaga: użytkownikowi będzie wyświetlana lista opisów lub lista napisów, ale nie obie jednocześnie. |
Dowolny tekst Zalecany rozmiar tekstu każdego podtytułu: maks. 50 znaków |
Odznaki | Opcjonalny |
Każda plakietka to tekst (maksymalnie 15 znaków) lub mały obraz. |
|
Plakietka – tekst | Opcjonalny | Tytuł plakietki Uwaga: w przypadku plakietki wymagany jest tekst lub obraz. |
Dowolny tekst Zalecany rozmiar tekstu: maks. 15 znaków |
Plakietka – obraz | Opcjonalny | Mały obraz Specjalne traktowanie pod względem UX, np. nakładka w postaci plakietki na miniaturę obrazu lub filmu. Uwaga: w przypadku plakietki wymagany jest tekst lub obraz. |
Więcej informacji znajdziesz w sekcji Specyfikacje obrazów. |
Identyfikator rezerwacji | Opcjonalny | Identyfikator rezerwacji biletu na wydarzenie. | Dowolny tekst |
Cena – CurrentPrice | Wymagane warunkowo |
Aktualna cena biletu na wydarzenie. Musisz podać cenę, jeśli podasz cenę przekreśloną. |
Dowolny tekst |
Cena – StrikethroughPrice | Opcjonalny | Pierwotna cena biletu na wydarzenie. | Dowolny tekst |
Objaśnienie dotyczące ceny | Opcjonalny | Wywołanie ceny, aby wyróżnić promocję, wydarzenie lub rabat dla uczestników programu (jeśli są dostępne). | Dowolny tekst Zalecany rozmiar tekstu: poniżej 45 znaków (zbyt długi tekst może być wyświetlany z wielokropkiem) |
Ocena – wartość maksymalna | Opcjonalny | Maksymalna wartość skali oceny. Musisz podać tę wartość, jeśli podasz też aktualną ocenę. |
Liczba >= 0,0 |
Ocena – bieżąca wartość | Opcjonalny | Bieżąca wartość skali ocen. Musisz podać tę wartość, jeśli podasz też maksymalną wartość oceny. |
Liczba >= 0,0 |
Ocena – liczba | Opcjonalny | Liczba ocen zdarzenia. Uwaga: podaj to pole, jeśli chcesz kontrolować sposób wyświetlania tej informacji użytkownikom. Podaj zwięzły ciąg znaków, który może być wyświetlany użytkownikowi. Jeśli np. liczba wynosi 1 000 000, użyj skrótu 1M, aby nie została obcięta na mniejszych ekranach. |
Ciąg znaków |
Ocena – wartość liczby | Opcjonalny | Liczba ocen zdarzenia. Uwaga: podaj wartość w tym polu, jeśli nie chcesz samodzielnie obsługiwać logiki skracania wyświetlanych wartości. Jeśli występują zarówno wartość Count, jak i Count Value, użytkownikom wyświetlimy wartość Count. |
Długie |
Kategorie treści | Opcjonalny | Opisz kategorię treści w obiekcie. | Lista kwalifikujących się typów wyliczeniowych
Wskazówki znajdziesz w sekcji Kategoria treści. |
DisplayTimeWindow (opcjonalnie) – ustaw przedział czasu, w którym treści mają być wyświetlane na platformie. | |||
Sygnatura czasowa rozpoczęcia | Opcjonalny |
Sygnatura czasowa epoki, po której treści powinny być wyświetlane na platformie. Jeśli nie jest ustawiona, treści mogą być wyświetlane w miejscu wyświetlania. |
Sygnatura czasowa epoki w milisekundach |
Sygnatura czasowa zakończenia | Opcjonalny |
Sygnatura czasowa epoki, po której treści nie będą już wyświetlane na platformie. Jeśli nie jest ustawiona, treści mogą być wyświetlane w miejscu wyświetlania. |
Sygnatura czasowa epoki w milisekundach |
LodgingReservationEntity
Atrybut | Wymaganie | Opis | Format |
---|---|---|---|
Identyfikator URI działania | Wymagany |
Precyzyjny link do podmiotu w aplikacji dostawcy. Uwaga: precyzyjnych linków możesz używać do atrybucji. Zapoznaj się z odpowiedziami na najczęstsze pytania |
Identyfikator URI |
Tytuł | Wymagany | Nazwa elementu. | Dowolny tekst. Na przykład „Twój pobyt od 12 grudnia”. Zalecany rozmiar tekstu: maks. 50 znaków |
Zlokalizowana godzina zameldowania – sygnatura czasowa | Wymagany | Sygnatura czasowa epoki reprezentująca czas zameldowania w przypadku rezerwacji. | Joda-Time Instant |
Zlokalizowana godzina zameldowania – strefa czasowa | Wymagany | Strefa czasowa, w której obowiązuje godzina zameldowania w przypadku rezerwacji. |
Joda-Time DateTimeZone Wskazówki znajdziesz w specyfikacjach stref czasowych. |
Zlokalizowana godzina wymeldowania – sygnatura czasowa | Wymagany | Sygnatura czasowa epoki reprezentująca godzinę wymeldowania z rezerwacji. | Joda-Time Instant |
Zlokalizowana godzina wymeldowania – strefa czasowa | Wymagany | Strefa czasowa, w której obowiązuje godzina wymeldowania w przypadku rezerwacji. |
Joda-Time DateTimeZone Wskazówki znajdziesz w specyfikacjach stref czasowych. |
Lokalizacja – kraj | Wymagany | Kraj, w którym znajduje się obiekt noclegowy. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Lokalizacja – miasto | Wymagany | Miasto, w którym znajduje się obiekt noclegowy. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Lokalizacja – wyświetlany adres | Wymagany | Adres, który będzie wyświetlany użytkownikowi. Podaj zwięzły adres, używając w miarę możliwości skrótów (np. „St” zamiast „Street”, „Ave” zamiast „Avenue”). Ten ciąg znaków może zostać skrócony w zależności od urządzenia i ustawień użytkownika. Aby ułatwić identyfikację, podaj nazwę miasta. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 35 znaków |
Lokalizacja – adres | Opcjonalny | Adres (jeśli dotyczy) obiektu noclegowego. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Lokalizacja – stan | Opcjonalny | Stan lub województwo (jeśli ma zastosowanie), w którym znajduje się obiekt. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Lokalizacja – kod pocztowy | Opcjonalny | Kod pocztowy (jeśli występuje) obiektu noclegowego. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Lokalizacja – dzielnica | Opcjonalny | Okolica (w odpowiednich przypadkach), w której znajduje się obiekt noclegowy. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Obrazy plakatu | Opcjonalny |
Jeśli podasz kilka obrazów, wyświetlimy tylko 1. Zalecany format obrazu to 16:9. Uwaga: jeśli podano plakietkę, zapewnij bezpieczną przestrzeń o wielkości 24 dps u góry i u dołu obrazu. |
Więcej informacji znajdziesz w sekcji Specyfikacje obrazów. |
Opis | Opcjonalny | Jeden akapit tekstu opisujący encję. Uwaga: użytkownikowi będzie wyświetlana lista opisów lub lista napisów, ale nie obie jednocześnie. |
Dowolny tekst Zalecany rozmiar tekstu: 180 znaków |
Lista podtytułów | Opcjonalny | Maksymalnie 3 napisy, każdy w jednym wierszu tekstu. Uwaga: użytkownikowi będzie wyświetlana lista opisów lub lista napisów, ale nie obie jednocześnie. |
Dowolny tekst Zalecany rozmiar tekstu każdego podtytułu: maks. 50 znaków |
Identyfikator rezerwacji | Opcjonalny | Identyfikator rezerwacji obiektu noclegowego. | Dowolny tekst |
Ocena – wartość maksymalna | Opcjonalny | Maksymalna wartość skali oceny. Musisz podać tę wartość, jeśli podasz też aktualną ocenę. |
Liczba >= 0,0 |
Ocena – bieżąca wartość | Opcjonalny | Bieżąca wartość skali ocen. Musisz podać tę wartość, jeśli podasz też maksymalną wartość oceny. |
Liczba >= 0,0 |
Ocena – liczba | Opcjonalny | Liczba ocen obiektu noclegowego. Uwaga: podaj to pole, jeśli chcesz kontrolować sposób wyświetlania tej informacji użytkownikom. Podaj zwięzły ciąg znaków, który może być wyświetlany użytkownikowi. Jeśli np. liczba wynosi 1 000 000, użyj skrótu 1M, aby nie została obcięta na mniejszych ekranach. |
Ciąg znaków |
Ocena – wartość liczby | Opcjonalny | Liczba ocen obiektu noclegowego. Uwaga: podaj wartość w tym polu, jeśli nie chcesz samodzielnie obsługiwać logiki skracania wyświetlanych wartości. Jeśli występują zarówno wartość Count, jak i Count Value, użytkownikom wyświetlimy wartość Count. |
Długie |
Cena – CurrentPrice | Wymagane warunkowo | Obecna cena obiektu. Musisz podać tę wartość, jeśli podasz cenę przekreśloną. |
Dowolny tekst |
Cena – StrikethroughPrice | Opcjonalny | Pierwotna cena obiektu noclegowego, która będzie przekreślona w interfejsie. | Dowolny tekst |
Objaśnienie dotyczące ceny | Opcjonalny | Wywołanie ceny, aby wyróżnić promocję, wydarzenie lub rabat dla uczestników programu (jeśli są dostępne). | Dowolny tekst Zalecany rozmiar tekstu: poniżej 45 znaków (zbyt długi tekst może być wyświetlany z wielokropkiem) |
DisplayTimeWindow (opcjonalnie) – ustaw przedział czasu, w którym treści mają być wyświetlane na platformie. | |||
Sygnatura czasowa rozpoczęcia | Opcjonalny |
Sygnatura czasowa epoki, po której treści powinny być wyświetlane na platformie. Jeśli nie jest ustawiona, treści mogą być wyświetlane w miejscu wyświetlania. |
Sygnatura czasowa epoki w milisekundach |
Sygnatura czasowa zakończenia | Opcjonalny |
Sygnatura czasowa epoki, po której treści nie będą już wyświetlane na platformie. Jeśli nie jest ustawiona, treści mogą być wyświetlane w miejscu wyświetlania. |
Sygnatura czasowa epoki w milisekundach |
TransportationReservationEntity
Atrybut | Wymaganie | Opis | Format |
---|---|---|---|
Identyfikator URI działania | Wymagany |
Precyzyjny link do podmiotu w aplikacji dostawcy. Uwaga: precyzyjnych linków możesz używać do atrybucji. Zapoznaj się z odpowiedziami na najczęstsze pytania |
Identyfikator URI |
Tytuł | Wymagany | Nazwa elementu. | Dowolny tekst. Na przykład „SFO do SAN”. Zalecany rozmiar tekstu: maks. 50 znaków |
Rodzaj transportu | Wymagany | Rodzaj środka transportu w rezerwacji. | Enum: FLIGHT, TRAIN, BUS lub FERRY |
Zlokalizowana godzina wylotu – sygnatura czasowa | Wymagany | Sygnatura czasowa epoki reprezentująca godzinę odjazdu. | Joda-Time Instant |
Zlokalizowana godzina odjazdu – strefa czasowa | Wymagany | Strefa czasowa godziny odjazdu. |
Joda-Time DateTimeZone Wskazówki znajdziesz w specyfikacjach stref czasowych. |
Zlokalizowana godzina przyjazdu – sygnatura czasowa | Wymagany | Sygnatura czasowa epoki reprezentująca czas przyjazdu. | Joda-Time Instant |
Zlokalizowana godzina przyjazdu – strefa czasowa | Wymagany | Strefa czasowa godziny przyjazdu. |
Joda-Time DateTimeZone Wskazówki znajdziesz w specyfikacjach stref czasowych. |
Numer transportu | Wymagany | Numer lotu, autobusu, pociągu lub promu/statku wycieczkowego. | Dowolny tekst |
Zlokalizowana godzina wejścia na pokład – sygnatura czasowa | Wymagany | Sygnatura czasowa epoki reprezentująca godzinę wejścia na pokład w przypadku rezerwacji (jeśli ma to zastosowanie). | Joda-Time Instant |
Zlokalizowana godzina wejścia na pokład – strefa czasowa | Wymagany | Strefa czasowa godziny wejścia na pokład w przypadku rezerwacji (jeśli dotyczy). |
Joda-Time DateTimeZone Wskazówki znajdziesz w specyfikacjach stref czasowych. |
Miejsce wyjazdu – kraj | Opcjonalny | Kraj wyjazdu. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Miejsce wylotu – miasto | Opcjonalny | Miasto wyjazdu. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Lokalizacja początkowa – wyświetlany adres | Opcjonalny | Miejsce wylotu, które będzie wyświetlane użytkownikowi. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Miejsce wylotu – ulica i numer | Opcjonalny | Adres (jeśli dotyczy) miejsca wylotu. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Miejsce wylotu – stan | Opcjonalny | Województwo (lub jego odpowiednik w innych krajach), w którym znajduje się miejsce wylotu (jeśli ma zastosowanie). | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Miejsce wylotu – kod pocztowy | Opcjonalny | Kod pocztowy (jeśli występuje) miejsca wylotu. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Lokalizacja początkowa – okolica | Opcjonalny | Dzielnica (jeśli dotyczy) miejsca wylotu. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Lokalizacja przyjazdu – kraj | Opcjonalny | Kraj przyjazdu. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Lokalizacja docelowa – miasto | Opcjonalny | Miasto przylotu. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Miejsce docelowe – wyświetlany adres | Opcjonalny | Miejsce docelowe, które będzie wyświetlane użytkownikowi. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Miejsce docelowe – adres | Opcjonalny | Adres (jeśli dotyczy) miejsca docelowego. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Lokalizacja docelowa – stan | Opcjonalny | Województwo (lub jego odpowiednik w innym kraju), w którym znajduje się miejsce docelowe (jeśli ma zastosowanie). | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Miejsce docelowe – kod pocztowy | Opcjonalny | Kod pocztowy (jeśli występuje) miejsca docelowego. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Lokalizacja docelowa – dzielnica | Opcjonalny | Okolica (w odpowiednich przypadkach), w której znajduje się miejsce docelowe. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Dostawca usług – nazwa | Opcjonalny |
Nazwa dostawcy usługi. Uwaga: w przypadku usługodawcy wymagany jest tekst lub obraz. |
Dowolny tekst. Na przykład nazwa linii lotniczych |
Usługodawca – obraz | Opcjonalny |
Logo lub obraz usługodawcy. Uwaga: w przypadku usługodawcy wymagany jest tekst lub obraz. |
Więcej informacji znajdziesz w sekcji Specyfikacje obrazów. |
Obrazy plakatu | Opcjonalny |
Jeśli podasz kilka obrazów, wyświetlimy tylko 1. Zalecany format obrazu to 16:9. |
Więcej informacji znajdziesz w sekcji Specyfikacje obrazów. |
Opis | Opcjonalny | Jeden akapit tekstu opisujący encję. Uwaga: użytkownikowi będzie wyświetlana lista opisów lub lista napisów, ale nie obie jednocześnie. |
Dowolny tekst Zalecany rozmiar tekstu: 180 znaków |
Lista podtytułów | Opcjonalny | Maksymalnie 3 napisy, każdy w jednym wierszu tekstu. Uwaga: użytkownikowi będzie wyświetlana lista opisów lub lista napisów, ale nie obie jednocześnie. |
Dowolny tekst Zalecany rozmiar tekstu każdego podtytułu: maks. 50 znaków |
Identyfikator rezerwacji | Opcjonalny | Identyfikator rezerwacji środka transportu. | Dowolny tekst |
Cena – CurrentPrice | Wymagane warunkowo | Obecna cena rezerwacji. Musisz podać tę wartość, jeśli podasz cenę przekreśloną. |
Dowolny tekst |
Cena – StrikethroughPrice | Opcjonalny | Pierwotna cena rezerwacji, która będzie przekreślona w interfejsie. | Dowolny tekst |
Objaśnienie dotyczące ceny | Opcjonalny | Wywołanie ceny, aby wyróżnić promocję, wydarzenie lub rabat dla uczestników programu (jeśli są dostępne). | Dowolny tekst Zalecany rozmiar tekstu: poniżej 45 znaków (zbyt długi tekst może być wyświetlany z wielokropkiem) |
DisplayTimeWindow (opcjonalnie) – ustaw przedział czasu, w którym treści mają być wyświetlane na platformie. | |||
Sygnatura czasowa rozpoczęcia | Opcjonalny |
Sygnatura czasowa epoki, po której treści powinny być wyświetlane na platformie. Jeśli nie jest ustawiona, treści mogą być wyświetlane w miejscu wyświetlania. |
Sygnatura czasowa epoki w milisekundach |
Sygnatura czasowa zakończenia | Opcjonalny |
Sygnatura czasowa epoki, po której treści nie będą już wyświetlane na platformie. Jeśli nie jest ustawiona, treści mogą być wyświetlane w miejscu wyświetlania. |
Sygnatura czasowa epoki w milisekundach |
VehicleRentalReservationEntity
Atrybut | Wymaganie | Opis | Format |
---|---|---|---|
Identyfikator URI działania | Wymagany |
Precyzyjny link do podmiotu w aplikacji dostawcy. Uwaga: precyzyjnych linków możesz używać do atrybucji. Zapoznaj się z odpowiedziami na najczęstsze pytania |
Identyfikator URI |
Tytuł | Wymagany | Nazwa elementu. | Dowolny tekst. Na przykład „Avis Union Square SF” Zalecany rozmiar tekstu: maks. 50 znaków |
Zlokalizowany czas odbioru – sygnatura czasowa | Wymagany | Sygnatura czasowa epoki reprezentująca godzinę odbioru w przypadku rezerwacji. | Joda-Time Instant |
Zlokalizowany czas odbioru – strefa czasowa | Wymagany | Strefa czasowa godziny odbioru w rezerwacji. |
Joda-Time DateTimeZone Wskazówki znajdziesz w specyfikacjach stref czasowych. |
Zlokalizowany czas zwrotu – sygnatura czasowa | Opcjonalny | Sygnatura czasowa epoki reprezentująca godzinę wymeldowania w przypadku rezerwacji. | Joda-Time Instant |
Zlokalizowany czas zwrotu – strefa czasowa | Opcjonalny | Strefa czasowa godziny wymeldowania w przypadku rezerwacji. |
Joda-Time DateTimeZone Wskazówki znajdziesz w specyfikacjach stref czasowych. |
Adres odbioru – kraj | Opcjonalny | Kraj miejsca odbioru. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Adres odbioru – miasto | Opcjonalny | Miasto, w którym znajduje się miejsce odbioru. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Adres odbioru – wyświetlany adres | Opcjonalny | Miejsce odbioru, które będzie wyświetlane użytkownikowi. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Adres odbioru – ulica | Opcjonalny | Adres (jeśli dotyczy) miejsca odbioru. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Adres odbioru – stan | Opcjonalny | Województwo (lub jego odpowiednik w innych krajach), w którym znajduje się miejsce odbioru (jeśli ono występuje). | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Adres odbioru – kod pocztowy | Opcjonalny | Kod pocztowy (jeśli występuje) miejsca odbioru. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Adres odbioru – dzielnica | Opcjonalny | Okolica (w stosownych przypadkach) miejsca odbioru. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Adres zwrotny – kraj | Opcjonalny | Kraj lokalizacji zwrotu. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Adres zwrotny – miasto | Opcjonalny | Miasto adresu zwrotu. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Adres zwrotny – wyświetlany adres | Opcjonalny | Lokalizacja zwrotu, która będzie wyświetlana użytkownikowi. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Adres zwrotny – adres | Opcjonalny | Adres (jeśli dotyczy) miejsca zwrotu. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Adres zwrotny – stan | Opcjonalny | Stan lub prowincja (jeśli ma zastosowanie) miejsca zwrotu. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Adres zwrotny – kod pocztowy | Opcjonalny | Kod pocztowy (jeśli dotyczy) miejsca zwrotu. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Adres zwrotny – dzielnica | Opcjonalny | Okolica (w stosownych przypadkach), w której znajduje się miejsce zwrotu. | Dowolny tekst Zalecany rozmiar tekstu: maks. ok. 20 znaków |
Dostawca usług – nazwa | Opcjonalny |
Nazwa dostawcy usługi. Uwaga: w przypadku usługodawcy wymagany jest tekst lub obraz. |
Dowolny tekst. Na przykład „Wypożyczalnia samochodów Avis”. |
Usługodawca – obraz | Opcjonalny |
Logo lub obraz usługodawcy. Uwaga: w przypadku usługodawcy wymagany jest tekst lub obraz. |
Więcej informacji znajdziesz w sekcji Specyfikacje obrazów. |
Obrazy plakatu | Opcjonalny |
Jeśli podasz kilka obrazów, wyświetlimy tylko 1. Zalecany format obrazu to 16:9. |
Więcej informacji znajdziesz w sekcji Specyfikacje obrazów. |
Opis | Opcjonalny | Jeden akapit tekstu opisujący encję. Uwaga: użytkownikowi będzie wyświetlana lista opisów lub lista napisów, ale nie obie jednocześnie. |
Dowolny tekst Zalecany rozmiar tekstu: 180 znaków |
Lista podtytułów | Opcjonalny | Maksymalnie 3 napisy, każdy w jednym wierszu tekstu. Uwaga: użytkownikowi będzie wyświetlana lista opisów lub lista napisów, ale nie obie jednocześnie. |
Dowolny tekst Zalecany rozmiar tekstu każdego podtytułu: maks. 50 znaków |
Identyfikator potwierdzenia | Opcjonalny | Identyfikator potwierdzenia rezerwacji wypożyczenia pojazdu. | Dowolny tekst |
Cena – CurrentPrice | Wymagane warunkowo | Obecna cena rezerwacji. Musisz podać tę wartość, jeśli podasz cenę przekreśloną. |
Dowolny tekst |
Cena – StrikethroughPrice | Opcjonalny | Pierwotna cena rezerwacji, która będzie przekreślona w interfejsie. | Dowolny tekst |
Objaśnienie dotyczące ceny | Opcjonalny | Wywołanie ceny, aby wyróżnić promocję, wydarzenie lub rabat dla uczestników programu (jeśli są dostępne). | Dowolny tekst Zalecany rozmiar tekstu: poniżej 45 znaków (zbyt długi tekst może być wyświetlany z wielokropkiem) |
DisplayTimeWindow (opcjonalnie) – ustaw przedział czasu, w którym treści mają być wyświetlane na platformie. | |||
Sygnatura czasowa rozpoczęcia | Opcjonalny |
Sygnatura czasowa epoki, po której treści powinny być wyświetlane na platformie. Jeśli nie jest ustawiona, treści mogą być wyświetlane w miejscu wyświetlania. |
Sygnatura czasowa epoki w milisekundach |
Sygnatura czasowa zakończenia | Opcjonalny |
Sygnatura czasowa epoki, po której treści nie będą już wyświetlane na platformie. Jeśli nie jest ustawiona, treści mogą być wyświetlane w miejscu wyświetlania. |
Sygnatura czasowa epoki w milisekundach |
Specyfikacja obrazu
Wymagane specyfikacje komponentów z obrazem są wymienione w tej tabeli:
Format obrazu | Minimalny rozmiar w pikselach | Zalecany rozmiar w pikselach |
---|---|---|
Kwadrat (1:1) Preferowane |
300 x 300 | 1200 x 1200 |
Poziomy (1,91 x 1) | 600 x 314 | 1200 x 628 |
Orientacja pionowa (4x5) | 480 x 600 | 960 x 1200 |
Obrazy muszą być hostowane w publicznych sieciach CDN, aby Google mógł uzyskać do nich dostęp.
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% obrazu.
- Użyj przezroczystego tła, aby obraz mógł być prawidłowo wyświetlany w ustawieniach motywu ciemnego i jasnego.
Specyfikacje strefy czasowej
Preferuj identyfikator (np. „America/Los_Angeles”) zamiast przesunięcia (np. „-07:00”).
Przykładowe użycie: DateTimeZone.forID("America/Los_Angeles")
Kategoria treści
Kategoria treści umożliwia publikowanie w aplikacjach treści należących do wielu kategorii. Dzięki temu treści są mapowane na niektóre z wstępnie zdefiniowanych kategorii, takich jak:
TYPE_EDUCATION
TYPE_SPORTS
TYPE_MOVIES_AND_TV_SHOWS
TYPE_BOOKS
TYPE_AUDIOBOOKS
TYPE_MUSIC
TYPE_DIGITAL_GAMES
TYPE_TRAVEL_AND_LOCAL
TYPE_HOME_AND_AUTO
TYPE_BUSINESS
TYPE_NEWS
TYPE_FOOD_AND_DRINK
TYPE_SHOPPING
TYPE_HEALTH_AND_FITENESS
TYPE_MEDICAL
TYPE_PARENTING
TYPE_DATING
Obrazy muszą być hostowane w publicznych sieciach CDN, aby Google mógł uzyskać do nich dostęp.
Wskazówki dotyczące korzystania z kategorii treści
- Niektóre typy danych, takie jak ArticleEntity i GenericFeaturedEntity, mogą korzystać z dowolnej kategorii treści. W przypadku innych typów elementów, takich jak EventEntity, EventReservationEntity czy PointOfInterestEntity, kwalifikuje się tylko podzbiór tych kategorii. Przed wypełnieniem listy sprawdź listę kategorii kwalifikujących się do danego typu elementu.
W przypadku niektórych kategorii treści używaj konkretnego typu elementu zamiast kombinacji elementów ogólnych i kategorii treści:
- TYPE_MOVIES_AND_TV_SHOWS – przed użyciem ogólnych elementów zapoznaj się z elementami z przewodnika po integracji funkcji Oglądaj.
- TYPE_BOOKS – przed użyciem ogólnych elementów sprawdź EbookEntity.
- TYPE_AUDIOBOOKS – sprawdź AudiobookEntity przed użyciem ogólnych elementów.
- TYPE_SHOPPING - Check out ShoppingEntity before using the generic entities.
- TYPE_FOOD_AND_DRINK – przed użyciem ogólnych elementów zapoznaj się z elementami z przewodnika po integracji z usługami związanymi z jedzeniem.
Pole ContentCategory jest opcjonalne i należy je pozostawić puste, jeśli treść nie należy do żadnej z wcześniej wymienionych kategorii.
Jeśli podasz kilka kategorii treści, podaj je w kolejności ich trafności w stosunku do treści. Najtrafniejsza kategoria treści powinna być pierwsza na liście.
Krok 2. Podaj dane klastra
Zalecamy wykonywanie zadania publikowania treści w tle (np. za pomocą WorkManager) i planowanie go regularnie lub na podstawie zdarzeń (np. za każdym razem, gdy użytkownik otwiera aplikację lub gdy właśnie dodał coś do koszyka).
AppEngageTravelClient
odpowiada za publikowanie klastrów.
Do publikowania klastrów w kliencie służą te interfejsy API:
isServiceAvailable
publishRecommendationClusters
publishFeaturedCluster
publishReservationCluster
publishContinueSearchCluster
publishUserAccountManagementRequest
updatePublishStatus
deleteRecommendationsClusters
deleteFeaturedCluster
deleteReservationCluster
deleteContinueSearchCluster
deleteUserManagementCluster
deleteClusters
isServiceAvailable
Ten interfejs API służy do sprawdzania, czy usługa jest dostępna do integracji i czy treść może być wyświetlana 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
.
Kotlin
client.publishRecommendationClusters(
PublishRecommendationClustersRequest.Builder()
.addRecommendationCluster(
RecommendationCluster.Builder()
.addEntity(entity1)
.addEntity(entity2)
.setTitle("Top Picks For You")
.build()
)
.build()
)
Java
client.publishRecommendationClusters(
new PublishRecommendationClustersRequest.Builder()
.addRecommendationCluster(
new RecommendationCluster.Builder()
.addEntity(entity1)
.addEntity(entity2)
.setTitle("Top Picks For You")
.build())
.build());
Gdy usługa otrzyma żądanie, w ramach jednej transakcji zostaną wykonane te działania:
- Istniejące dane
RecommendationCluster
od partnera dewelopera zostaną usunięte. - Dane z żądania są analizowane i przechowywane w zaktualizowanym klastrze rekomendacji.
W przypadku błędu całe żądanie jest odrzucane, a dotychczasowy stan jest zachowywany.
publishFeaturedCluster
Ten interfejs API służy do publikowania listy obiektów FeaturedCluster
.
Kotlin
client.publishFeaturedCluster(
PublishFeaturedClusterRequest.Builder()
.setFeaturedCluster(
FeaturedCluster.Builder()
.addEntity(entity1)
.addEntity(entity2)
.build())
.build())
Java
client.publishFeaturedCluster(
new PublishFeaturedClustersRequest.Builder()
.addFeaturedCluster(
new FeaturedCluster.Builder()
.addEntity(entity1)
.addEntity(entity2)
.build())
.build());
Gdy usługa otrzyma żądanie, w ramach jednej transakcji zostaną wykonane te działania:
- Istniejące dane
FeaturedCluster
od partnera dewelopera zostaną usunięte. - Dane z żądania są analizowane i zapisywane w zaktualizowanym klastrze polecanych.
W przypadku błędu całe żądanie jest odrzucane, a dotychczasowy stan jest zachowywany.
publishReservationCluster
Ten interfejs API służy do publikowania obiektu ReservationCluster
.
Kotlin
client.publishReservationCluster(
PublishReservationClusterRequest.Builder()
.setReservationCluster(
ReservationCluster.Builder()
.addLodgingReservationEntity(lodgingReservationEntity)
.addVehicleRentalReservationEntity(vehicleRentalReservationEntity)
.addTransportationReservationEntity(transportationReservationEntity)
.addEventReservationEntity(eventReservationEntity)
.addRestaurantReservationEntity(restaurantReservationEntity)
.build())
.build())
Java
client.publishReservationCluster(
new PublishReservationClusterRequest.Builder()
.setReservationCluster(
new ReservationCluster.Builder()
.addLodgingReservationEntity(lodgingReservationEntity)
.addVehicleRentalReservationEntity(vehicleRentalReservationEntity)
.addTransportationReservationEntity(transportationReservationEntity)
.addEventReservationEntity(eventReservationEntity)
.addRestaurantReservationEntity(restaurantReservationEntity)
.build())
.build());
Gdy usługa otrzyma żądanie, w ramach jednej transakcji zostaną wykonane te działania:
- Istniejące dane
ReservationCluster
od partnera dewelopera zostaną usunięte. - Dane z żądania są analizowane i zapisywane w zaktualizowanym klastrze rezerwacji.
W przypadku błędu całe żądanie jest odrzucane, a dotychczasowy stan jest zachowywany.
publishContinueSearchCluster
Ten interfejs API służy do publikowania listy obiektów ContinueSearchCluster
.
Kotlin
client.publishContinueSearchCluster(
PublishContinueSearchClusterRequest.Builder()
.setContinueSearchCluster(
ContinueSearchCluster.Builder()
.addPointOfInterestEntity(entity1)
.addPointOfInterestEntity(entity2)
.build())
.build())
Java
client.publishContinueSearchCluster(
new PublishContinueSearchClusterRequest.Builder()
.setContinueSearchCluster(
new ContinueSearchCluster.Builder()
.addPointOfInterestEntity(entity1)
.addPointOfInterestEntity(entity2)
.build())
.build());
Gdy usługa otrzyma żądanie, w ramach jednej transakcji zostaną wykonane te działania:
- Istniejące dane
ContinueSearchCluster
od partnera dewelopera zostaną usunięte. - Dane z żądania są analizowane i przechowywane w zaktualizowanym klastrze wyszukiwania kontynuowanego.
W przypadku błędu całe żądanie jest odrzucane, a dotychczasowy stan jest zachowywany.
publishUserAccountManagementRequest
Ten interfejs API służy do publikowania karty logowania . Działanie logowania przekierowuje użytkowników na stronę logowania aplikacji, aby mogła ona publikować treści (lub udostępniać bardziej spersonalizowane treści).
Karta logowania zawiera te metadane:
Atrybut | Wymaganie | Opis |
---|---|---|
Identyfikator URI działania | Wymagane | Precyzyjny link do działania (np. przejście do strony logowania w aplikacji) |
Obraz | Opcjonalny – jeśli nie zostanie podany, musi zostać podany tytuł |
Obraz wyświetlany na karcie Obrazy o formacie 16:9 i rozdzielczości 1264 x 712 |
Tytuł | Opcjonalny – jeśli nie zostanie podany, należy podać obraz | Tytuł na karcie |
Tekst działania | Opcjonalny | Tekst wyświetlany w wezwaniu do działania (np. Zaloguj się) |
Podtytuł | Opcjonalny | Opcjonalny podtytuł 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 jednej transakcji zostaną wykonane te działania:
- Dotychczasowe dane
UserAccountManagementCluster
od partnera dewelopera zostaną usunięte. - Dane z żądania są analizowane i przechowywane w zaktualizowanym klastrze UserAccountManagementCluster.
W przypadku błędu całe żądanie jest odrzucane, a dotychczasowy stan jest zachowywany.
updatePublishStatus
Jeśli z jakiegokolwiek powodu wewnętrznego żadna z grup nie jest opublikowana, zdecydowanie zalecamy zaktualizowanie stanu publikacji za pomocą interfejsu API updatePublishStatus. Jest to ważne, ponieważ :
- Podawanie stanu we wszystkich scenariuszach, nawet gdy treść jest opublikowana (STATUS == PUBLISHED), jest kluczowe do wypełniania paneli, które używają tego jawnego stanu do przekazywania informacji o kondycji i innych danych integracji.
- Jeśli żadne treści nie są publikowane, ale stan integracji nie jest uszkodzony (STATUS == NOT_PUBLISHED), Google może uniknąć wywoływania alertów na panelach stanu aplikacji. Potwierdza, że treści nie są publikowane z powodu przewidywanej sytuacji z punktu widzenia dostawcy.
- Pomaga deweloperom określać, kiedy dane są publikowane, a kiedy nie.
- Google może używać kodów stanu, aby zachęcać użytkownika do podejmowania określonych działań w aplikacji, dzięki którym będzie mógł wyświetlać jej zawartość lub rozwiązywać problemy.
Lista kwalifikujących się kodów stanu 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 są publikowane, ponieważ użytkownik nie jest zalogowany, Google zaleca opublikowanie karty logowania. Jeśli z jakiegoś powodu dostawcy nie mogą opublikować karty logowania, zalecamy wywołanie 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 treści z grup rekomendacji.
Kotlin
client.deleteRecommendationClusters()
Java
client.deleteRecommendationClusters();
Gdy usługa otrzyma prośbę, usunie dotychczasowe dane z klastrów rekomendacji. W przypadku błędu całe żądanie jest odrzucane i zachowywany jest dotychczasowy stan.
deleteFeaturedCluster
Ten interfejs API służy do usuwania treści z wyróżnionego klastra.
Kotlin
client.deleteFeaturedCluster()
Java
client.deleteFeaturedCluster();
Gdy usługa otrzyma żądanie, usunie dotychczasowe dane z wyróżnionego klastra. W przypadku błędu całe żądanie jest odrzucane, a dotychczasowy stan pozostaje bez zmian.
deleteReservationCluster
Ten interfejs API służy do usuwania zawartości klastra rezerwacji.
Kotlin
client.deleteReservationCluster()
Java
client.deleteReservationCluster();
Gdy usługa otrzyma żądanie, usunie istniejące dane z klastra rezerwacji. W przypadku błędu całe żądanie jest odrzucane i zachowywany jest dotychczasowy 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, usunie istniejące dane z klastra UserAccountManagement. W przypadku błędu całe żądanie jest odrzucane, a dotychczasowy stan jest zachowywany.
deleteContinueSearchCluster
Ten interfejs API służy do usuwania zawartości klastra wyszukiwania kontynuowanego.
Kotlin
client.deleteContinueSearchCluster()
Java
client.deleteContinueSearchCluster();
Gdy usługa otrzyma żądanie, usunie istniejące dane z klastra wyszukiwania kontynuowanego. W przypadku błędu całe żądanie jest odrzucane, a dotychczasowy stan jest zachowywany.
deleteClusters
Ten interfejs API służy do usuwania treści danego typu klastra.
Kotlin
client.deleteClusters(
DeleteClustersRequest.Builder()
.addClusterType(ClusterType.TYPE_RESERVATION)
.addClusterType(ClusterType.TYPE_FEATURED)
.addClusterType(ClusterType.TYPE_RECOMMENDATION)
.addClusterType(ClusterType.TYPE_CONTINUE_SEARCH)
.build())
Java
client.deleteClusters(
new DeleteClustersRequest.Builder()
.addClusterType(ClusterType.TYPE_RESERVATION)
.addClusterType(ClusterType.TYPE_FEATURED)
.addClusterType(ClusterType.TYPE_RECOMMENDATION)
.addClusterType(ClusterType.TYPE_CONTINUE_SEARCH)
.build());
Gdy usługa otrzyma żądanie, usunie istniejące dane ze wszystkich klastrów pasujących do określonych typów klastrów. Klienci mogą przekazywać jeden lub wiele typów klastrów. W przypadku błędu całe żądanie jest odrzucane, a dotychczasowy stan pozostaje bez zmian.
Obsługa błędów
Zdecydowanie zalecamy odsłuchanie wyniku zadania z interfejsów API publikowania, aby można było podjąć działania następcze w celu odzyskania i ponownego przesłania zadania, które zakończyło się niepowodzeniem.
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 obiekt AppEngageException
, a jego przyczyna jest podana jako kod błędu.
Kod błędu | Nazwa błędu | Uwaga |
---|---|---|
1 |
SERVICE_NOT_FOUND |
Usługa jest niedostępna na danym urządzeniu. |
2 |
SERVICE_NOT_AVAILABLE |
Usługa jest dostępna na danym urządzeniu, ale w momencie połączenia jest niedostępna (np. jest wyraźnie wyłączona). |
3 |
SERVICE_CALL_EXECUTION_FAILURE |
Nie udało się wykonać zadania z powodu problemów z wątkami. W takim przypadku można ponowić próbę. |
4 |
SERVICE_CALL_PERMISSION_DENIED |
Element wywołujący nie ma uprawnień do wykonania wywołania usługi. |
5 |
SERVICE_CALL_INVALID_ARGUMENT |
Żądanie zawiera nieprawidłowe dane (np. więcej klastrów niż dozwolona liczba). |
6 |
SERVICE_CALL_INTERNAL |
Po stronie usługi wystąpił błąd. |
7 |
SERVICE_CALL_RESOURCE_EXHAUSTED |
Wywołanie usługi jest wykonywane zbyt często. |
Krok 3. Obsługa intencji transmisji
Oprócz wykonywania wywołań interfejsu API publikowania treści za pomocą zadania musisz też skonfigurować BroadcastReceiver
, aby otrzymywać prośby o publikowanie treści.
Celem intencji transmisji jest głównie ponowna aktywacja aplikacji i wymuszenie synchronizacji danych. Intencje transmisji nie są przeznaczone do wysyłania zbyt często. Jest ona wywoływana tylko wtedy, gdy usługa Engage uzna, że treść może być nieaktualna (np. ma tydzień). Dzięki temu użytkownik może mieć pewność, że będzie korzystać z aktualnych treści, nawet jeśli aplikacja nie była uruchamiana przez dłuższy czas.
BroadcastReceiver
musi być skonfigurowany na 2 sposoby:
Dynamiczne rejestrowanie instancji klasy
BroadcastReceiver
za pomocąContext.registerReceiver()
. Umożliwia to komunikację z aplikacjami, które są nadal aktywne 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 continue search cluster publish when PUBLISH_CONTINUE_SEARCH
// broadcast is received
// Trigger reservation cluster publish when PUBLISH_RESERVATION broadcast is
// received
}
fun registerBroadcastReceivers(context: Context){
var context = context
context = context.applicationContext
// Register Recommendation Cluster Publish Intent
context.registerReceiver(AppEngageBroadcastReceiver(),
IntentFilter(com.google.android.engage.service.Intents.ACTION_PUBLISH_RECOMMENDATION),
com.google.android.engage.service.BroadcastReceiverPermissions.BROADCAST_REQUEST_DATA_PUBLISH_PERMISSION,
/*scheduler=*/null)
// Register Featured Cluster Publish Intent
context.registerReceiver(AppEngageBroadcastReceiver(),
IntentFilter(com.google.android.engage.service.Intents.ACTION_PUBLISH_FEATURED),
com.google.android.engage.service.BroadcastReceiverPermissions.BROADCAST_REQUEST_DATA_PUBLISH_PERMISSION,
/*scheduler=*/null)
// Register Continue Search Cluster Publish Intent
context.registerReceiver(AppEngageBroadcastReceiver(),
IntentFilter(com.google.android.engage.travel.service.Intents.ACTION_PUBLISH_CONTINUE_SEARCH),
com.google.android.engage.service.BroadcastReceiverPermissions.BROADCAST_REQUEST_DATA_PUBLISH_PERMISSION,
/*scheduler=*/null)
// Register Reservation Cluster Publish Intent
context.registerReceiver(AppEngageBroadcastReceiver(),
IntentFilter(com.google.android.engage.travel.service.Intents.ACTION_PUBLISH_RESERVATION),
com.google.android.engage.service.BroadcastReceiverPermissions.BROADCAST_REQUEST_DATA_PUBLISH_PERMISSION,
/*scheduler=*/null)
}
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 continue search cluster publish when PUBLISH_CONTINUE_SEARCH
// broadcast is received
// Trigger reservation cluster publish when PUBLISH_RESERVATION 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),
com.google.android.engage.service.BroadcastReceiverPermissions.BROADCAST_REQUEST_DATA_PUBLISH_PERMISSION,
/*scheduler=*/null);
// Register Featured Cluster Publish Intent
context.registerReceiver(new AppEngageBroadcastReceiver(),
new IntentFilter(com.google.android.engage.service.Intents.ACTION_PUBLISH_FEATURED),
com.google.android.engage.service.BroadcastReceiverPermissions.BROADCAST_REQUEST_DATA_PUBLISH_PERMISSION,
/*scheduler=*/null);
// Register Continue Search Cluster Publish Intent
context.registerReceiver(new AppEngageBroadcastReceiver(),
new IntentFilter(com.google.android.engage.travel.service.Intents.ACTION_PUBLISH_CONTINUE_SEARCH),
com.google.android.engage.service.BroadcastReceiverPermissions.BROADCAST_REQUEST_DATA_PUBLISH_PERMISSION,
/*scheduler=*/null);
// Register Reservation Cluster Publish Intent
context.registerReceiver(new AppEngageBroadcastReceiver(),
new IntentFilter(com.google.android.engage.travel.service.Intents.ACTION_PUBLISH_RESERVATION),
com.google.android.engage.service.BroadcastReceiverPermissions.BROADCAST_REQUEST_DATA_PUBLISH_PERMISSION,
/*scheduler=*/null);
}
Statycznie zadeklaruj implementację za pomocą tagu
<receiver>
w plikuAndroidManifest.xml
. Dzięki temu aplikacja może odbierać intencje transmisji, gdy nie jest uruchomiona, a także publikować treści.
<application>
<receiver
android:name=".AppEngageBroadcastReceiver"
android:permission="com.google.android.engage.REQUEST_ENGAGE_DATA"
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.travel.PUBLISH_CONTINUE_SEARCH" />
</intent-filter>
<intent-filter>
<action android:name="com.google.android.engage.action.travel.PUBLISH_RESERVATION" />
</intent-filter>
</receiver>
</application>
Usługa wysyła te intencje:
com.google.android.engage.action.PUBLISH_RECOMMENDATION
Zalecamy rozpoczęciepublishRecommendationClusters
połączenia po otrzymaniu tego zamiaru.com.google.android.engage.action.PUBLISH_FEATURED
Zalecamy rozpoczęcie połączeniapublishFeaturedCluster
po otrzymaniu tego zamiaru.com.google.android.engage.action.travel.PUBLISH_CONTINUE_SEARCH
Po otrzymaniu tego zamiaru zalecamy rozpoczęciepublishContinueSearchCluster
połączenia.com.google.android.engage.action.travel.PUBLISH_RESERVATION
Zalecamy rozpoczęciepublishReservationCluster
połączenia po otrzymaniu tego zamiaru.
Przepływ pracy integracji
Szczegółowe instrukcje weryfikacji integracji po jej zakończeniu znajdziesz w sekcji Przepływ pracy integracji z platformą Engage dla programistów.
Najczęstsze pytania
Odpowiedzi na najczęstsze pytania znajdziesz w sekcji Najczęstsze pytania dotyczące pakietu Engage SDK.
Kontakt
Jeśli podczas procesu integracji pojawią się pytania, skontaktuj się z nami pod adresem engage-developers@google.com.
Dalsze kroki
Po zakończeniu integracji wykonaj te czynności:
- Wyślij e-maila na adres engage-developers@google.com i załącz zintegrowany plik APK gotowy do przetestowania przez Google.
- Google przeprowadza weryfikację i sprawdza wewnętrznie, czy integracja działa zgodnie z oczekiwaniami. Jeśli zajdzie taka potrzeba, skontaktujemy się z Tobą, aby przekazać niezbędne informacje.
- Gdy testy zostaną zakończone i nie będą potrzebne żadne zmiany, skontaktujemy się z Tobą, aby poinformować Cię, że możesz rozpocząć publikowanie zaktualizowanego i zintegrowanego pliku APK w Sklepie Play.
- Gdy potwierdzimy, że zaktualizowany plik APK został opublikowany w Sklepie Play, klastry Rekomendacja, Wyróżnione, Rezerwacja i Kontynuuj wyszukiwanie mogą zostać opublikowane i będą widoczne dla użytkowników.