Podmiot świadczący usługę

Element Service określa usługi zamawiania jedzenia dostępne w restauracji, np. na wynos lub z dostawą. Aby zdefiniować element Service, użyj typ Service (Usługa). Każda restauracja musi być połączona z co najmniej 1 usługą typu „na wynos” lub z dostawą. i maksymalnie 2 podmioty usług; jeden rodzaj dostawy na wynos i jeden rodzaj dostawy.

Diagram relacji między obiektem usługi
Rysunek 1. Podmiot świadczący usługi pokazujący swoją relację z tą usługą Obszar usługi, godziny obsługi, godziny pracy i jednostki z opłatami.

Element Service określa właściwości, takie jak typ usługi, dostępne godziny otwarcia, i obsługiwany obszar. Element usługi powinien się zmieniać i odświeżać przy każdym przesyłaniu pliku danych.

Przykład encji usługi

Poniższy przykład definiuje podstawowy element Service, który przyjmuje zamówienia zainteresowanych informacjami ze świata.

{
  "@type":"Service",
  "@id":"takeout_1",
  "serviceType":"TAKEOUT",
  "menuId":"menu_1",
  "restaurantId":"restaraunt_1"
}
{
  "@type":"OperationHours",
  "@id":"takeout_1_op_hours",
  "serviceId":"takeout_1",
  "opens":"00:00",
  "closes":"23:59"
}
{
  "@type":"ServiceHours",
  "@id":"takeout_1_service_hours",
  "orderType":"ASAP",
  "serviceId":"takeout_1",
  "operationHoursId":"takeout_1_op_hours",
  "opens":"11:00",
  "closes":"21:00",
  "dayOfWeek":["MONDAY","TUESDAY","WEDNESDAY","THURSDAY", "FRIDAY", "SATURDAY"],
  "leadTimeMin":"20",
  "leadTimeMax":"20",
  "isSpecialHour":false
}
{
  "@type":"ServiceHours",
  "@id":"takeout_1_service_hours_sun",
  "orderType":"ASAP",
  "serviceId":"takeout_1",
  "operationHoursId":"takeout_1_op_hours",
  "opens":"16:00",
  "closes":"21:00",
  "dayOfWeek":["SUNDAY"],
  "leadTimeMin":"20",
  "leadTimeMax":"20",
  "isSpecialHour":false
}
{
  "@type":"Service",
  "@id":"delivery_1",
  "serviceType":"DELIVERY",
  "menuId":"10824",
  "restaurantId":"10824"
}
{
  "@type":"OperationHours",
  "@id":"delivery_1_op_hours",
  "serviceId":"delivery_1",
  "opens":"00:00",
  "closes":"23:59"
}
{
  "@type":"ServiceHours",
  "@id":"delivery_1_service_hours",
  "orderType":"ASAP",
  "serviceId":"delivery_1",
  "operationHoursId":"delivery_1_op_hours",
  "opens":"11:00",
  "closes":"21:00",
  "dayOfWeek":["MONDAY","TUESDAY","WEDNESDAY","THURSDAY", "FRIDAY", "SATURDAY",
  "SUNDAY"],
  "leadTimeMin":"50",
  "leadTimeMax":"50",
  "isSpecialHour":false
}
{
  "@type":"ServiceArea",
  "@id":"delivery_1_service_area",
  "serviceId":"delivery_1",
  "polygon":["37.4818562 -122.25801303 37.48247836 -122.25801303 37.48434484
  -122.25621319 37.48621133 -122.25424681 37.49181077 -122.24704744 37.49305509
  -122.24541414 37.49429942 -122.2436143 37.49803238 -122.23821477 37.49803238
  -122.21285044 37.49367726 -122.15885517 37.49056645 -122.15722187 37.48621133
  -122.15542202 37.48558917 -122.15525548 37.4818562 -122.15525548 37.43191387
  -122.17865343 37.43191387 -122.23444854"]
}
{
  "@type":"Fee",
  "@id":"delivery_1_fee",
  "serviceId":"delivery_1",
  "feeType":"DELIVERY",
  "priceCurrency":"USD",
  "eligibleRegion":"delivery_1_service_area",
  "eligibleTransactionVolumeMin":20,
  "percentageOfCart": 7
}

Jak najszybciej i z wyprzedzeniem

Użytkownicy mogą składać zamówienia jak najszybciej w ServiceHours restauracji lub składać zamówienia z wyprzedzeniem w określonych OperationHours restauracji w określonych ServiceHours. Aby określić godziny pracy z wyprzedzeniem, utwórz element ServiceHours z właściwością orderType ustawioną na ADVANCE. Więcej informacji i przykładów znajdziesz w artykule Godziny dostawy i odbioru.

Tymczasowe wyłączanie elementu Service

Możesz tymczasowo zawiesić lub zastąpić ServiceHours dla określonego okresu, który jest znany z wyprzedzeniem, ustawiając godziny otwarcia w święta i niestandardowe. Aby wyłączyć element Service z nieprzewidzianej przyczyny, wyślij żądanie aktualizacji w czasie rzeczywistym z właściwością Service elementu isDisabled ustawioną na true.

Więcej informacji i przykłady znajdziesz w artykule Usuwanie i wyłączanie jednostek.