Podmiot świadczący usługę

Element Service określa usługi zamawiania jedzenia w restauracji, np. dania na wynos lub z dostawą. Aby zdefiniować encję Service, użyj typu Service. Każda restauracja musi być połączona z co najmniej 1 usługą (na wynos lub z dostawą) i maksymalnie z 2 podmiotami świadczącymi usługi: na wynos i z dostawą.

Schemat relacji z jednostką usługi
Rysunek 1. Podmiot świadczący usługę na podstawie relacji z podmiotami ServiceArea, ServiceHours, OperationHours i Opłat.

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

Przykład jednostki usługi

Poniższy przykład zawiera definicję podstawowego elementu Service, który 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 wcześniejsze godziny

Użytkownicy mogą składać zamówienia jak najszybciej w godzinach ServiceHours restauracji. Mogą też składać zamówienia z wyprzedzeniem w godzinach OperationHours danej restauracji, które zostaną zrealizowane w okresie ServiceHours. Aby określić godziny obsługi z wyprzedzeniem, utwórz encję 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łączenie elementu Service

Możesz tymczasowo zawiesić lub zastąpić godziny pracy zespołu ServiceHours w wybranym okresie, ustawiając święta i specjalne godziny pracy. Aby wyłączyć element Service z nieprzewidzianego powodu, wyślij żądanie aktualizacji w czasie rzeczywistym z właściwością isDisabled elementu Service ustawioną na true.

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