Podmiot świadczący usługę

Element Service określa usługi zamawiania jedzenia dostępne w restauracji, takie jak dania na wynos lub z dostawą. Podczas definiowania encji Service użyj typu Usługa. Każda restauracja musi być połączona z co najmniej 1 typem usługi (na wynos lub w dostawie) i maksymalnie 2 elementami: 1 na wynos i 1 z dostawą.

Diagram relacji podmiotu
Ilustracja 1. Podmiot świadczący o relacji między podmiotami usługowymi, obszarami usług, godzinami pracy i opłatami

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

Przykład jednostki usługi

Poniższy przykład pokazuje podstawową jednostkę Service, która codziennie przyjmuje zamówienia.

{
  "@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 godziny z wyprzedzeniem

Użytkownicy mogą składać zamówienia jak najszybciej w godzinach ServiceHours restauracji lub składać je z wyprzedzeniem w godzinach otwarcia restauracji, aby mogły zostać zrealizowane w czasie ServiceHours. Aby zdefiniować wcześniejsze godziny otwarcia, utwórz encję ServiceHours z właściwością orderType ustawioną na ADVANCE. Więcej informacji oraz przykłady znajdziesz w artykule Godziny dostawy i odbioru.

Tymczasowe wyłączenie encji Service

Możesz tymczasowo zawiesić lub zastąpić Godziny otwarcia na określony czas, które są znane z wyprzedzeniem, ustawiając święta i niestandardowe godziny pracy. Aby z nieoczekiwanego powodu wyłączyć element Service, wyślij żądanie aktualizacji w czasie rzeczywistym z właściwością isDisabled usługi Service ustawioną na true.

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